z/Architecture

Principles of Operation
z/Architecture

Principles of Operation
## Contents

### Notices ........................................ xxiii  
Trademarks ........................................ xxiii  

### Preface .......................................... xxv  
Size and Number Notation. ......................... xxvi  
Bytes, Characters, and Codes ..................... xxvii  
Other Publications ................................ xxvii  
Summary of Changes in Eleventh Edition ....... xxviii  
Summary of Changes in Tenth Edition .......... xxx  
Summary of Changes in Ninth Edition .......... xxxi  
Summary of Changes in Eighth Edition ......... xxxv  
Summary of Changes in Seventh Edition ....... xxxvii  
Summary of Changes in Sixth Edition .......... xxxix  
Summary of Changes in Fifth Edition .......... xxxi  
Summary of Changes in Fourth Edition ........ xlii  
Summary of Changes in Third Edition ........ xliii  
Summary of Changes in Second Edition ........ xlv  

### Chapter 1, Introduction ....................... 1-1  
Highlights of Original z/Architecture .......... 1-2  
General Instructions for 64-Bit Integers ....... 1-3  
Other New General Instructions ................ 1-3  
Floating-Point Instructions ...................... 1-4  
Control Instructions .............................. 1-4  
Trimodal Addressing ................................ 1-5  
Modal Instructions ................................ 1-5  
Effects on Bits 0-31 of a General Register ... 1-6  
Input/Output ........................................ 1-6  
Additions to z/Architecture ...................... 1-7  
ASN-and-LX-Reuse Facility ....................... 1-7  
CMPS-C-Enhancement Facility .................... 1-7  
Compare-and-Swap-and-Store Facility .......... 1-7  
Compare-and-Swap-and-Store Facility 2 ....... 1-8  
Conditional-SSKE Facility ....................... 1-8  
Configuration-Topology Facility ................ 1-8  
Constrained-Transactional-Execution Facility . 1-8  
DAT-Enhancement Facility 1 ...................... 1-8  
DAT-Enhancement Facility 2 ...................... 1-8  
Decimal-Floating-Point Facility ............... 1-8  
Decimal-Floating-Point Packed-Conversion Facility ................ 1-9  
Decimal-Floating-Point-Rounding Facility .... 1-9  
Distinct-Operands Facility ....................... 1-9  
Enhanced-DAT Facility 1 ......................... 1-9  
Enhanced-DAT Facility 2 ......................... 1-10  
Enhanced-Monitor Facility ....................... 1-10  
ETF2-Enhancement Facility ....................... 1-11  
ETF3-Enhancement Facility ....................... 1-11  
Execute-Extensions Facility ..................... 1-11  
Execution-Hint Facility ........................ 1-11  
Extended-Immediate Facility .................... 1-11  
Extended-I/O-Measurement-Block Facility .... 1-12  
Extended-I/O-Measurement-Word Facility ...... 1-12  
Extended-Translation Facility 2 ............... 1-12  
Extended-Translation Facility 3 ............... 1-12  
Extract-CPU-Time Facility ....................... 1-13  
Fast-BCR-Serialization Facility ................. 1-13  
Fibre-Channel Extensions (FCX) ................. 1-13  
FCX-Bidirectional-Data-Transfer Facility ..... 1-13  
Floating-Point Extension Facility .............. 1-13  
Floating-Point-Support-Sign-Handling Facility 1-14  
PFR-GR-Transfer Facility ......................... 1-14  
General-Instructions-Extension Facility ..... 1-14  
HFP Multiply-and-Add/Subtract Facility ...... 1-15  
HFP-Unnormalized-Extensions Facility ......... 1-15  
High-Word Facility ................................ 1-15  
IEEE-Exception-Simulation Facility .......... 1-16  
Interlocked-Access Facility 1 ................. 1-16  
Interlocked-Access Facility 2 ................. 1-16  
IPT-E-Range Facility ............................. 1-16  
List-Directed Initial Program Load ............. 1-16  
Load-and-Trap Facility ........................... 1-16  
Load-and-Zero-Rightmost-Byte Facility ....... 1-16  
Load/Store-on-Condition Facility 1 ............ 1-17  
Load/Store-on-Condition Facility 2 ............ 1-17  
Local-TLB-Clearing Facility ..................... 1-17  
Local-Address-Detection Facility ............... 1-17  
Message-Security Assist ......................... 1-17  
Message-Security-Assist Extension 1 ......... 1-18  
Message-Security-Assist Extension 2 .......... 1-18  
Message-Security-Assist Extension 3 .......... 1-18  
Message-Security-Assist Extension 4 .......... 1-19  
Message-Security-Assist Extension 5 .......... 1-20  
Miscellaneous-Instruction-Extensions Facility 1-20  
Modified CCW Indirect Data Addressing ....... 1-20  
Move-Without-Optional-Specifications Facility  1-21  
Multiple-Subchannel-Set Facility .............. 1-21  
Multithreading Facility ......................... 1-21  
Nonquiescing Key-Setting Facility .......... 1-21  
Parsing-Enhancement Facility ................... 1-21  
PER-3 Facility ................................. 1-21  
PER Zero-Address-Detection Facility .......... 1-22  
PFPO Facility ....................................... 1-22  
Population-Count Facility ....................... 1-22  
Processor-Assist Facility ....................... 1-22  
Reset-Reference-Bits-Multiple Facility ...... 1-22  
Restore-Subchannel Facility ..................... 1-22  
Server-Time-Protocol Facility ................. 1-22  
Store-Clock-Fast Facility ....................... 1-23  
Store-Facility-List-Extended Facility ........ 1-23
<table>
<thead>
<tr>
<th>Section</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Program Interruption</td>
<td>6-15</td>
</tr>
<tr>
<td>Data-Exception Code (DXC)</td>
<td>6-16</td>
</tr>
<tr>
<td>Priority of Program Interruptions for Data Exceptions</td>
<td>6-16</td>
</tr>
<tr>
<td>Vector-Exception Code</td>
<td>6-19</td>
</tr>
<tr>
<td>Program-Interruption Conditions</td>
<td>6-19</td>
</tr>
<tr>
<td>Addressing Exception</td>
<td>6-19</td>
</tr>
<tr>
<td>AFX-Translation Exception</td>
<td>6-20</td>
</tr>
<tr>
<td>ALEN-Translation Exception</td>
<td>6-21</td>
</tr>
<tr>
<td>ALE-Sequence Exception</td>
<td>6-21</td>
</tr>
<tr>
<td>ALET-Specification Exception</td>
<td>6-21</td>
</tr>
<tr>
<td>ASC-Translation Exception</td>
<td>6-21</td>
</tr>
<tr>
<td>ASTE-Instance Exception</td>
<td>6-22</td>
</tr>
<tr>
<td>ASTE-Sequence Exception</td>
<td>6-22</td>
</tr>
<tr>
<td>ASTE-Validity Exception</td>
<td>6-23</td>
</tr>
<tr>
<td>ASX-Translation Exception</td>
<td>6-23</td>
</tr>
<tr>
<td>Crypto-Operation Exception</td>
<td>6-23</td>
</tr>
<tr>
<td>Data Exception</td>
<td>6-24</td>
</tr>
<tr>
<td>Decimal-Divide Exception</td>
<td>6-25</td>
</tr>
<tr>
<td>Decimal-Overflow Exception</td>
<td>6-25</td>
</tr>
<tr>
<td>Execute Exception</td>
<td>6-25</td>
</tr>
<tr>
<td>EX-Translation Exception</td>
<td>6-25</td>
</tr>
<tr>
<td>Extended-Authority Exception</td>
<td>6-26</td>
</tr>
<tr>
<td>Fixed-Point-Divide Exception</td>
<td>6-26</td>
</tr>
<tr>
<td>Fixed-Point-Overflow Exception</td>
<td>6-26</td>
</tr>
<tr>
<td>HFP-Divide Exception</td>
<td>6-26</td>
</tr>
<tr>
<td>HFP-Exponent-Overflow Exception</td>
<td>6-27</td>
</tr>
<tr>
<td>HFP-Exponent-Underflow Exception</td>
<td>6-27</td>
</tr>
<tr>
<td>HFP-Significance Exception</td>
<td>6-27</td>
</tr>
<tr>
<td>HFP-Square-Root Exception</td>
<td>6-27</td>
</tr>
<tr>
<td>LFX-Translation Exception</td>
<td>6-27</td>
</tr>
<tr>
<td>LSX-Translation Exception</td>
<td>6-28</td>
</tr>
<tr>
<td>LX-Translation Exception</td>
<td>6-28</td>
</tr>
<tr>
<td>Monitor Event</td>
<td>6-29</td>
</tr>
<tr>
<td>Operand Exception</td>
<td>6-29</td>
</tr>
<tr>
<td>Operation Exception</td>
<td>6-30</td>
</tr>
<tr>
<td>Page-Translation Exception</td>
<td>6-30</td>
</tr>
<tr>
<td>PC-Translation-Specification Exception</td>
<td>6-31</td>
</tr>
<tr>
<td>PER Event</td>
<td>6-31</td>
</tr>
<tr>
<td>Primary-Authority Exception</td>
<td>6-31</td>
</tr>
<tr>
<td>Privileged-Operation Exception</td>
<td>6-32</td>
</tr>
<tr>
<td>Protection Exception</td>
<td>6-32</td>
</tr>
<tr>
<td>Region-First-Translation Exception</td>
<td>6-33</td>
</tr>
<tr>
<td>Region-Second-Translation Exception</td>
<td>6-34</td>
</tr>
<tr>
<td>Region-Third-Translation Exception</td>
<td>6-34</td>
</tr>
<tr>
<td>Secondary-Authority Exception</td>
<td>6-35</td>
</tr>
<tr>
<td>Segment-Translation Exception</td>
<td>6-35</td>
</tr>
<tr>
<td>Space-Switch Event</td>
<td>6-35</td>
</tr>
<tr>
<td>Special-Operation Exception</td>
<td>6-36</td>
</tr>
<tr>
<td>Specification Exception</td>
<td>6-38</td>
</tr>
<tr>
<td>Stack-Empty Exception</td>
<td>6-42</td>
</tr>
<tr>
<td>Stack-Full Exception</td>
<td>6-42</td>
</tr>
<tr>
<td>Stack-Operation Exception</td>
<td>6-42</td>
</tr>
<tr>
<td>Stack-Specification Exception</td>
<td>6-43</td>
</tr>
<tr>
<td>Stack-Type Exception</td>
<td>6-43</td>
</tr>
<tr>
<td>Trace-Table Exception</td>
<td>6-43</td>
</tr>
<tr>
<td>Transaction-Constraint Exception</td>
<td>6-43</td>
</tr>
<tr>
<td>Transactional-Execution-Aborted Event</td>
<td>6-44</td>
</tr>
<tr>
<td>Translation-Specification Exception</td>
<td>6-44</td>
</tr>
<tr>
<td>Vector Processing Exception</td>
<td>6-45</td>
</tr>
<tr>
<td>Collective Program-Interruption Names</td>
<td>6-45</td>
</tr>
<tr>
<td>Recognition of Access Exceptions</td>
<td>6-45</td>
</tr>
<tr>
<td>Multiple Program-Interruption Conditions</td>
<td>6-48</td>
</tr>
<tr>
<td>Access Exceptions</td>
<td>6-51</td>
</tr>
<tr>
<td>ASN-Translation Exceptions</td>
<td>6-53</td>
</tr>
<tr>
<td>Subspace-Replacement Exceptions</td>
<td>6-54</td>
</tr>
<tr>
<td>Trace Exceptions</td>
<td>6-54</td>
</tr>
<tr>
<td>Restart Interruption</td>
<td>6-54</td>
</tr>
<tr>
<td>Supervisor-Call Interruption</td>
<td>6-54</td>
</tr>
<tr>
<td>Priority of Interruptions</td>
<td>6-55</td>
</tr>
</tbody>
</table>

Chapter 7, General Instructions 7-1

Data Format 7-3
Binary-Integer Representation 7-4
Binary Arithmetic 7-5
Signed Binary Arithmetic 7-5
Addition and Subtraction 7-5
Fixed-Point Overflow 7-5
Unsigned Binary Arithmetic 7-6
Signed and Logical Comparison 7-6
Instructions 7-7
ADD 7-25
Chapter 20, Decimal-Floating-Point

Instructions .................................. 20-1

Decimal-Floating-Point Facility ................. 20-1

DFP Arithmetic ................................ 20-2

Finite Floating-Point Number .................. 20-2

Cohort ........................................ 20-2

Quantum ....................................... 20-2

Preferred Quantum ............................. 20-2

Scaled Preferred Quantum ...................... 20-3

Delivered Quantum ............................. 20-3

Special Quantum-Handling Operations ........ 20-3

DFP Data Formats .............................. 20-3

DFP Short Format .............................. 20-3

DFP Long Format ............................... 20-3

DFP Extended Format ........................... 20-4

Sign ............................................. 20-4

Combination .................................... 20-4

Encoded Trailing Significand .................... 20-5

Values of Finite Numbers ...................... 20-5

Significand ................................... 20-5

DFP Significant Digits ......................... 20-5

Canonical Declets ............................ 20-6

DFP Canonical Data ............................ 20-6

Classes of DFP Data ........................... 20-6

Zeros .......................................... 20-6

Subnormal Numbers ............................ 20-6

Normal Numbers ................................ 20-7

Infinities ...................................... 20-7

Infinities ...................................... 20-7

Canonicalization .............................. 20-7

DFP-Format Conversion ......................... 20-7

DFP Rounding .................................. 20-7

DFP Comparison ................................ 20-7

DFP Formatting Instructions .................... 20-7

Signed-Packed-Decimal Format .................. 20-8

Unsigned-Packed-Decimal Format ............... 20-8

Zoned-Decimal Format .......................... 20-8

IEEE Exceptions ............................... 20-9

Summary of Preferred Quantum ................. 20-9

Summary of Rounding And Range Actions ....... 20-10

Result Figures .................................. 20-14

Data-Exception Codes (DXC) and Abbreviations .. 20-14

Instructions .................................... 20-15

ADD ............................................ 20-18

COMPARE ...................................... 20-20

COMPARE AND SIGNAL ......................... 20-22

COMPARE BIASED EXPONENT ..................... 20-22

CONVERT FROM FIXED ......................... 20-23

CONVERT FROM LOGICAL ....................... 20-24

CONVERT FROM SIGNED PACKED ................. 20-25

CONVERT FROM UNSIGNED PACKED ............... 20-27

DIVIDE ....................................... 20-28

CONVERT TO FIXED ........................... 20-28

CONVERT TO LOGICAL ......................... 20-31

CONVERT TO PACKED .......................... 20-32

CONVERT TO SIGNED PACKED ................... 20-34

CONVERT TO UNSIGNED PACKED ................. 20-34

CONVERT TO ZONED ............................ 20-35

DIVIDE ....................................... 20-36

EXTRACT BIASED EXPONENT ..................... 20-38

EXTRACT SIGNIFICANCE ......................... 20-38

INSERT BIASED EXPONENT ...................... 20-39

LOAD AND TEST ................................ 20-40

LOAD COMPLEMENT ............................. 20-41

LOAD LENGTHENED ............................. 20-44

LOAD ROUNDED ................................ 20-45

MULTIPLY ..................................... 20-46

QUANTIZE ..................................... 20-48

REROUND ...................................... 20-51

SHIFT SIGNIFICAND LEFT ....................... 20-53

SHIFT SIGNIFICAND RIGHT ...................... 20-53

SUBTRACT .................................... 20-54

TEST DATA CLASS ................................ 20-55

TEST DATA GROUP ................................ 20-56

Densely Packed Decimal (DPD) ................. 20-57

Decimal-to-DPD Mapping ....................... 20-57

DPD-to-Decimal Mapping ....................... 20-57
Chapter 21, Vector Overview and Support
Instructions ........................................ 21-1

Overview ............................................ 21-1
Vector Registers and Controls .................. 21-1
Vector Enablement Control ....................... 21-1
Vector Storage Accesses ......................... 21-2
Saturating Arithmetic ............................. 21-2
Instructions ......................................... 21-2
VECTOR GATHER ELEMENT ......................... 21-4
VECTOR GENERATE BYTE MASK ................. 21-4
VECTOR GENERATE MASK ......................... 21-4
VECTOR LOAD ...................................... 21-5
VECTOR LOAD AND REPLICATE .................... 21-5
VECTOR LOAD ELEMENT IMMEDIATE ............. 21-6
VECTOR LOAD GR FROM VR ELEMENT ............. 21-7
VECTOR LOAD LOGICAL ELEMENT AND ZERO ... 21-7
VECTOR LOAD MULTIPLE ........................... 21-8
VECTOR LOAD TO BLOCK BOUNDARY ............. 21-8
VECTOR LOAD VR ELEMENT FROM GR ...... 21-9
VECTOR LOAD VR FROM GRS DISJOINT .......... 21-9
VECTOR LOAD WITH LENGTH ....................... 21-10
VECTOR MERGE HIGH ................................ 21-10
VECTOR MERGE LOW ................................ 21-10
VECTOR PACK ....................................... 21-11
VECTOR PACK SATURATE ......................... 21-11
VECTOR PACK LOGICAL SATURATE .............. 21-12
VECTOR PERMUTE .................................... 21-13
VECTOR PERMUTE DOUBLEWORD IMMEDIATE ... 21-13
VECTOR REPPLICATE ............................... 21-14
VECTOR REPPLICATE IMMEDIATE ................. 21-14
VECTOR SCATTER ELEMENT ....................... 21-15
VECTOR SELECT ..................................... 21-15
VECTOR SIGN EXTEND TO DOUBLEWORD ....... 21-15
VECTOR STORE ..................................... 21-16
VECTOR STORE ELEMENT .......................... 21-16
VECTOR STORE MULTIPLE ......................... 21-17
VECTOR STORE WITH LENGTH ..................... 21-17
VECTOR UNPACK HIGH .............................. 21-17
VECTOR UNPACK LOGICAL HIGH .................. 21-18
VECTOR UNPACK LOW ................................ 21-18
VECTOR UNPACK LOGICAL LOW ................... 21-19

Chapter 22, Vector Integer
Instructions ........................................ 22-1

Instructions ......................................... 22-1
VECTOR ADD ........................................ 22-3
VECTOR ADD COMPUTE CARRY ..................... 22-4
VECTOR ADD WITH CARRY ......................... 22-4
VECTOR ADD WITH CARRY COMPUTE CARRY ...... 22-5
VECTOR AND ........................................ 22-5
VECTOR AND WITH COMPLEMENT .................. 22-5
VECTOR AVERAGE .................................. 22-5
VECTOR AVERAGE LOGICAL ....................... 22-6
VECTOR CHECKSUM ................................ 22-6
VECTOR ELEMENT COMPARE ...................... 22-7
VECTOR ELEMENT COMPARE LOGICAL .......... 22-7
VECTOR COMPARE EQUAL ......................... 22-7
VECTOR COMPARE HIGH ............................ 22-8
VECTOR COMPARE HIGH LOGICAL ............... 22-9
VECTOR COUNT LEADING ZEROS .................. 22-10
VECTOR COUNT TRAILING ZEROS ................. 22-10
VECTOR EXCLUSIVE OR ............................ 22-11
VECTOR GARIOIS FIELD MULTIPLY SUM ......... 22-11
VECTOR GARIOIS FIELD MULTIPLY SUM AND ACCUMULATE ................. 22-11
VECTOR LOAD COMPLEMENT ....................... 22-12
VECTOR LOAD POSITIVE ............................ 22-12
VECTOR MAXIMUM .................................. 22-13
VECTOR MAXIMUM LOGICAL ...................... 22-13
VECTOR MINIMUM .................................. 22-13
VECTOR MINIMUM LOGICAL ...................... 22-13
VECTOR MULTIPLY AND ADD LOW ............... 22-14
VECTOR MULTIPLY AND ADD HIGH ............... 22-14
VECTOR MULTIPLY AND ADD LOGICAL HIGH .... 22-15
VECTOR MULTIPLY AND ADD EVEN ............... 22-15
VECTOR MULTIPLY AND ADD LOGICAL EVEN .... 22-15
VECTOR MULTIPLY AND ADD ODD .................. 22-16
VECTOR MULTIPLY AND ADD LOGICAL ODD ...... 22-16
VECTOR MULTIPLY HIGH ............................ 22-16
VECTOR MULTIPLY LOGICAL HIGH ............... 22-16
VECTOR MULTIPLY LOW ............................. 22-17
VECTOR MULTIPLY EVEN ........................... 22-17
VECTOR MULTIPLY LOGICAL EVEN ............... 22-18
VECTOR MULTIPLY ODD ............................. 22-18
VECTOR MULTIPLY LOGICAL ODD ............... 22-18
VECTOR NOR ......................................... 22-19
VECTOR OR .......................................... 22-19
VECTOR POPULATION COUNT ..................... 22-19
VECTOR ELEMENT ROTATE LEFT LOGICAL .... 22-19
VECTOR ELEMENT ROTATE AND INSERT UNDER MASK ...................... 22-20
VECTOR ELEMENT SHIFT LEFT .................... 22-21
VECTOR ELEMENT SHIFT RIGHT ARITHMETIC ................. 22-22
VECTOR ELEMENT SHIFT RIGHT LOGICAL .......... 22-22
VECTOR SHIFT LEFT ................................. 22-23
Chapter 23, Vector String Instructions 23-1
Vector String Facility 23-1
Instructions 23-1
VECTOR FIND ANY ELEMENT EQUAL 23-1
VECTOR FIND ELEMENT EQUAL 23-3
VECTOR FIND ELEMENT NOT EQUAL 23-4
VECTOR ISOLATE STRING 23-5
VECTOR STRING RANGE COMPARE 23-6

Chapter 24, Vector Floating-Point Instructions 24-1
IEEE Exception Handling 24-1
Result Figures 24-1
Instructions 24-2
VECTOR FP ADD 24-3
VECTOR FP COMPARE SCALAR 24-7
VECTOR FP COMPARE AND SIGNAL SCALAR 24-8
VECTOR FP COMPARE EQUAL 24-9
VECTOR FP COMPARE HIGH 24-10
VECTOR FP COMPARE HIGH OR EQUAL 24-12
VECTOR FP CONVERT FROM FIXED 64-BIT 24-13
VECTOR FP CONVERT FROM LOGICAL 64-BIT 24-15
VECTOR FP CONVERT TO FIXED 64-BIT 24-16
VECTOR FP CONVERT TO LOGICAL 64-BIT 24-18
VECTOR FP DIVIDE 24-20
VECTOR LOAD FP INTEGER 24-22
VECTOR FP LOAD LENGTHENED 24-24
VECTOR FP LOAD ROUNDED 24-25
VECTOR FP MULTIPLY 24-26
VECTOR FP MULTIPLY AND ADD 24-27
VECTOR FP MULTIPLY AND SUBTRACT 24-27
VECTOR FP PERFORM SIGN OPERATION 24-29
VECTOR FP SQUARE ROOT 24-30
VECTOR FP SUBTRACT 24-31
VECTOR FP TEST DATA CLASS IMMEDIATE 24-31

Appendix A, Number Representation and Instruction-Use Examples A-1
Number Representation A-2
Binary Integers A-2
Signed Binary Integers A-2
Unsigned Binary Integers A-3
Decimal Integers A-4
Hexadecimal-Floating-Point Numbers A-5
Conversion Example A-6
Instruction-Use Examples A-7
Machine Format A-7
Assembler-Language Format A-7
Addressing Mode in Examples A-7
General Instructions A-7
ADD HALFWORD (AH) A-8
AND (N, NC, NI, NR) A-8
NI Example A-8
Linkage Instructions (BAL, BALR, BAS, BASR, BASSM, BSM) A-8
Other BALR and BASR Examples A-10
BRANCH AND STACK (BAKR) A-10
BAKR Example 1 A-10
BAKR Example 2 A-11
BAKR Example 3 A-11
BRANCH ON CONDITION (BC, BCR) A-12
BRANCH ON COUNT (BCT, BCTR) A-12
BRANCH ON INDEX HIGH (BXH) A-12
BXH Example 1 A-12
BXH Example 2 A-13
BRANCH ON INDEX LOW OR EQUAL (BXLE) A-13
BXLE Example 1 A-14
BXLE Example 2 A-14
COMPARE AND FORM CODEWORD (CFC) A-14
COMPARE HALFWORD (CH) A-14
COMPARE LOGICAL (CL, CLC, CLI, CLR) A-15
CLC Example A-15
CLI Example A-15
CLR Example A-15
COMPARE LOGICAL CHARACTERS UNDER MASK (CLM) A-16
COMPARE LOGICAL LONG (CLCL) A-16
COMPARE LOGICAL STRING (CLST) A-18
Notices

References in this publication to IBM® products, programs or services do not imply that IBM intends to make these available in all countries in which IBM operates. Any reference to an IBM product, program, or service is not intended to state or imply that only IBM's product, program, or service may be used. Any functionally equivalent product, program, or service that does not infringe any of IBM's intellectual property rights may be used instead of the IBM product, program, or service. Evaluation and verification of operation in conjunction with other products, except those expressly designated by IBM, is the user's responsibility.

IBM may have patents or pending patent applications covering subject matter in this document. The furnishing of this document does not give you any license to these patents. You can send license inquiries, in writing, to the IBM Director of Licensing, IBM Corporation, North Castle Drive, Armonk, NY, 10504-1785 USA.

Trademarks

The following terms are trademarks or registered trademarks of the International Business Machines Corporation in the United States, other countries, or both:

AIX/ESA
BookMaster
CICS
DB2
Enterprise Systems Architecture/370
Enterprise Systems Architecture/390
Enterprise Systems Connection Architecture
ESA/370
ESA/390
ESCON
FICON
IBM
IBMLink
MVS/ESA
OS/390
Processor Resource/Systems Manager
PR/SM
Sysplex Timer
System z
System/370
VM/ESA
z/Architecture
zEnterprise
z/OS
z Systems
z/VM
z13

ANSI is a registered trademark of the American National Standards Institute in the United States, other countries, or both.

IEEE is a trademark of the Institute of Electrical and Electronics Engineers, Inc. in the United States, other countries, or both.

Java and all Java-based marks are trademarks or registered trademarks of Oracle America Inc. in the United States and other countries.
Linux is a registered trademark of Linus Torvalds in the United States, other countries or both.

Unicode is a registered trademark of Unicode, Incorporated in the United States, other countries, or both.

UNIX is a registered trademark of The Open Group in the United States and other countries.

Other trademarks and registered trademarks are the properties of their respective companies.
Preface

This publication provides, for reference purposes, a detailed z/Architecture™ description.

The publication applies only to systems operating as defined by z/Architecture. For systems operating in accordance with the Enterprise Systems Architecture/390® (ESA/390™) definition, the IBM ESA/390 Principles of Operation, SA22-7201, should be consulted.

The publication describes each function at the level of detail needed to prepare an assembler-language program that relies on that function. It does not, however, describe the notation and conventions that must be employed in preparing such a program, for which the user must instead refer to the appropriate assembler-language publication.

The information in this publication is provided principally for use by assembler-language programmers, although anyone concerned with the functional details of z/Architecture will find it useful.

This publication is written as a reference and should not be considered an introduction or a textbook. It assumes the user has a basic knowledge of data-processing systems.

All facilities discussed in this publication are not necessarily available on every model. Furthermore, in some instances the definitions have been structured to allow for some degree of extendibility, and therefore certain capabilities may be described or implied that are not offered on any model. Examples of such capabilities are the use of a 16-bit field in the subsystem-identification word to identify the subchannel number, the size of the CPU address, and the number of CPUs sharing main storage. The allowance for this type of extendibility should not be construed as implying any intention by IBM to provide such capabilities. For information about the characteristics and availability of facilities on a specific model, see the functional characteristics publication for that model.

Largely because this publication is arranged for reference, certain words and phrases appear, of necessity, earlier in the publication than the principal discussions explaining them. The reader who encounters a problem because of this arrangement should refer to the index, which indicates the location of the key description.

The information presented in this publication is grouped in 20 chapters and several appendixes:

Chapter 1, Introduction, highlights the major facilities of z/Architecture.

Chapter 2, Organization, describes the major groupings within the system — main storage, expanded storage, the central processing unit (CPU), the external time reference (ETR), and input/output — with some attention given to the composition and characteristics of those groupings.

Chapter 3, Storage, explains the information formats, the addressing of storage, and the facilities for storage protection. It also deals with dynamic address translation (DAT), which, coupled with special programming support, makes the use of a virtual storage possible.

Chapter 4, Control, describes the facilities for the switching of system status, for special externally initiated operations, for debugging, and for timing. It deals specifically with CPU states, control modes, the program-status word (PSW), control registers, tracing, program-event recording, timing facilities, resets, store status, and initial program loading.

Chapter 5, Program Execution, explains the role of instructions in program execution, looks in detail at instruction formats, and describes briefly the use of the program-status word (PSW), of branching, and of interruptions. It contains the principal description of the advanced address-space facilities that were introduced in ESA/370™. It also details the aspects of program execution on one CPU as observed by other CPUs and by channel programs.

Chapter 6, Interruptions, details the mechanism that permits the CPU to change its state as a result of conditions external to the system, within the system, or within the CPU itself. Six classes of interruptions are identified and described: machine-check interruptions, program interruptions, supervisor-call interruptions, external interruptions, input/output interruptions, and restart interruptions.
Chapter 7, General Instructions, contains detailed descriptions of logical and binary-integer data formats and of most of the unprivileged instructions. Other unprivileged instructions are described in chapters 8-10 and 18-20.

Chapter 8, Decimal Instructions, describes in detail decimal data formats and the decimal instructions.

Chapter 9, Floating-Point Overview and Support Instructions, includes an introduction to the floating-point operations, detailed descriptions of those instructions common to binary-floating-point, decimal-floating-point, and hexadecimal-floating-point operations, and summaries of all floating-point instructions.

Chapter 10, Control Instructions, contains detailed descriptions of all of the semiprivileged and privileged instructions except for the I/O instructions.

Chapter 11, Machine-Check Handling, describes the mechanisms for detecting, correcting, and reporting machine malfunctions.

Chapter 12, Operator Facilities, describes the basic manual functions and controls available for operating and controlling the system.

Chapters 13-17 of this publication provide a detailed definition of the functions performed by the channel subsystem and the logical interface between the CPU and the channel subsystem.

Chapter 13, I/O Overview, provides a brief description of the basic components and operation of the channel subsystem.

Chapter 14, I/O Instructions, contains the description of the I/O instructions.

Chapter 15, Basic I/O Functions, describes the basic I/O functions performed by the channel subsystem, including the initiation, control, and conclusion of I/O operations.

Chapter 16, I/O Interruptions, covers I/O interruptions and interruption conditions.

Chapter 17, I/O Support Functions, describes such functions as channel-subsystem usage monitoring, resets, initial-program loading, reconfiguration, and channel-subsystem recovery.

Chapter 18, Hexadecimal-Floating-Point Instructions, contains detailed descriptions of the hexadecimal-floating-point (HFP) data formats and the HFP instructions.

Chapter 19, Binary-Floating-Point Instructions, contains detailed descriptions of the binary-floating-point (BFP) data formats and the BFP instructions.

Chapter 20, Decimal-Floating-Point Instructions, contains detailed descriptions of the decimal-floating-point (DFP) data formats and the DFP instructions.

Chapter 21, Vector Overview and Support Instructions, describes the vector facility support instructions.

Chapter 22, Vector Integer Instructions, describes the vector facility integer instructions.

Chapter 23, Vector String Instructions, describes the vector facility string instructions.

Chapter 24, Vector Floating-Point Instructions, describes the vector facility floating-point instructions.

The Appendixes include:

- Information about number representation
- Instruction-use examples
- Lists of the instructions arranged in several sequences
- A summary of the condition-code settings
- A table of the powers of 2
- Tabular information helpful in dealing with hexadecimal numbers
- A table of EBCDIC and other codes.

Size and Number Notation

In this publication, the letters K, M, G, T, P, and E denote the multipliers \(2^{10}, 2^{20}, 2^{30}, 2^{40}, 2^{50}, \) and \(2^{60}\), respectively. Although the letters are borrowed from the decimal system and stand for kilo \((10^3)\), mega \((10^6)\), giga \((10^9)\), tera \((10^{12})\), peta \((10^{15})\), and exa \((10^{18})\), they do not have the decimal meaning but instead represent the power of 2 closest to the corre-
sponding power of 10. Their meaning in this publication is as follows:

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>K (kilo)</td>
<td>$1,024 = 2^{10}$</td>
</tr>
<tr>
<td>M (mega)</td>
<td>$1,048,576 = 2^{20}$</td>
</tr>
<tr>
<td>G (giga)</td>
<td>$1,073,741,824 = 2^{30}$</td>
</tr>
<tr>
<td>T (tera)</td>
<td>$1,099,511,627,776 = 2^{40}$</td>
</tr>
<tr>
<td>P (peta)</td>
<td>$1,125,899,906,842,624 = 2^{50}$</td>
</tr>
<tr>
<td>E (exa)</td>
<td>$1,152,921,504,606,846,976 = 2^{60}$</td>
</tr>
</tbody>
</table>

In this publication, unless otherwise specified, the value given for a byte is the value obtained by considering the bits of the byte to represent a binary code. Thus, when a byte is said to contain a zero, the value 00000000 binary, or 00 hex, is meant, and not the value for an EBCDIC character “0,” which would be F0 hex.

### Other Publications

1. The parallel-I/O interface is described in the publication *IBM System/360 and System/370 I/O Interface Channel to Control Unit Original Equipment Manufacturers' Information*, GA22-6974.

2. The parallel-I/O channel-to-channel adapter is described in the publication *IBM Enterprise Systems Architecture/390 Channel-to-Channel Adapter for the System/360 and System/370 I/O Interface*, SA22-7091.

3. The Enterprise Systems Connection Architecture® (ESCON®) I/O interface, referred to in this publication along with the FICON I/O interface as the serial-I/O interface, is described in the publication *IBM Enterprise Systems Architecture/390 ESCON I/O Interface*, SA22-7202.


5. The channel-to-channel adapter for the serial-I/O interface is described in the publication *IBM Enterprise Systems Architecture/390 ESCON Channel-to-Channel-Adapter*, SA22-7203.

6. The commands, status, and sense data that are common to all I/O devices that comply with z/Architecture are described in the publication *IBM Enterprise Systems Architecture/390 Common I/O-Device Commands and Self Description*, SA22-7204.

7. The compression facility is described in the publication *IBM Enterprise Systems Architecture/390 Data Compression*, SA22-7208. The z/Architecture form of the COMPRESSION CALL instruction is described in this publication.

8. The interpretive-execution facility is described in the publication *IBM 370-XA Interpretive Execution*, SA22-7095.

9. The load-program-parameter and CPU-measurement facilities are described in the publica-
The Load-Program-Parameter and CPU-Measurement Facilities, SA23-2260.

10. The store-hypervisor-information facility is described in the publication z/VM CP Programming Services (SC24-6179).


14. The cipher-feedback (CFB), output-feedback (OFB), and counter (CTR) modes of encryption and decryption are described in Recommendation for Block Cipher Modes of Operation, National Institute of Standards and Technology (NIST) Special Publication 800-38A, December, 2001.

15. The Galois/counter mode (GCM) multiplication operation is described in Recommendation for Block Cipher Modes of Operation: Galois/Counter Mode (GCM) and GMAC, NIST special publication 800-38D, November, 2007.


17. Binary floating point is described in IEEE Standard for Floating-Point Arithmetic, Institute of Electrical and Electronics Engineers publication IEEE 754-2008.

Summary of Changes in Eleventh Edition

The eleventh edition of this publication differs from the previous edition principally by containing the definitions of the following facilities:

- Decimal-floating-point packed-conversion facility
- FCX-bidirectional-data-transfer facility
- Load-and-zero-rightmost-byte facility
- Load/store-on-condition facility
- Message-security-assist extension 5
- Multithreading facility
- Vector facility for z/Architecture

The eleventh edition also contains the following significant changes relative to the previous edition:

- In the Preface:
  - Summaries of Chapters 21-24 are added.
  - The list of other publications is extended to include additional documents referenced by this document.
- In Chapter 1, “Introduction,” a summary of the new facilities is presented.
- In Chapter 2, “Organization”:
  - New sections are added, describing CPU types, multithreading, and vector registers.
  - Clarification is made as to the contents of bit positions 0-31 of general registers while the CPU is in the ESA/390 mode.
- In Chapter 3, “Storage”:
  - Clarification is made as to the applicability of key-controlled protection’s to the program-interruption TDB.
  - Clarification is made as to the applicability of DAT to certain instructions and events.
  - Bits 62-63 of the format-1 RTTE and STE are made available for programming.
  - The vector-exception code and machine-check-extended-save-area address are added to the assigned-storage locations.
  - Because of their pervasive use by z/OS, three additional assigned-storage locations are made available for use by programming.
- In Chapter 4, “Operation”:
  - Additional constraints are placed on the use of CPU address-compare controls is program-event recording is used.
  - Additional bits are defined in control registers 0 and 2.
– Applicability of VRV-format instructions (used by the vector facility) are added to the description of PER zero-address detection.

– In the section “Timing”:
  • Numerous clarifications are made to the section “Setting and Inspecting the Clock.”
  • Leap second 26 is documented.
  • Descriptions of hardware-based and offset-based TOD-clock steering are added.
  • Description of the UTC-information block (UIB) is added.
  • Clarification is made to the description of the CPU timer.

– The descriptions of various reset operations are updated to account for the addition of the multithreading and vector facilities.

– Clarification is made to the description of CCW-based IPL.

– In the section “Multiprocessing,” the process of CPU-address expansion and contraction is described.

– In the section “CPU Signalling and Response,” various changes are described in support of the multithreading facility:
  • The SIGP set-multithreading order is described.
  • Various changes are made to other SIGP orders in support of multithreading.

– New facility indications are described.

• In Chapter 5, “Program Execution”:
  • Instruction formats are added, most in support of vector-facility for z/Architecture instructions.
  • Clarification is made to the description of instruction nullification and suppression.
  • The section “Condition-Code Alternative to Interruptibility” is updated to account for new instructions.

  • Clarification is added to the description of the TBEGIN-specified TDB.

  • The TDB is updated to include the vector-exception code (VXC).

  • A programming note is added, describing the proper use of branch instructions following a TRANSACTION BEGIN.

  • The section “Multiple-Access References” is updated to account for added instructions.

  • The section “Block-Concurrent References” is updated to account for the vector-facility for z/Architecture instructions.

  • A programming note is added to the section “Storage-Key Accesses,” describing behavior of the nonquiescing key-setting operation.

• In Chapter 6, “Interruptions”:
  • The vector-processing interruption is described.

  • STP timing-alert interruptions are defined to be floating interruptions.

  • Clarification is made to the section “Exceptions Associated with the PSW."

  • Clarification is made to the description of external interruptions.

  • Clarification is made to the description of the warning-track interruption.

  • Because it is used for other instructions besides decimal instructions, data-exception code 0 is renamed general-operand data exception (it was formerly decimal-operand data exception).

  • Descriptions of the vector-exception code, vector-instruction data exception code, and the vector-processing exception are added.

  • The descriptions of various program-interruption codes are updated to account for new instructions.

• In Chapter 7, “General Instructions”:
  • A programming note is added to the BRANCH PREDICTION PRELOAD and BRANCH PREDICTION RELATIVE PRELOAD instructions.
– The CIPHER MESSAGE WITH CFB and CIPHER MESSAGE WITH OFB instructions are renamed to the more descriptive CIPHER MESSAGE WITH CIPHER FEEDBACK and CIPHER MESSAGE WITH OUTPUT FEEDBACK, respectively. The mnemonics for these instructions are unchanged.

– Instructions for the following facilities are described:
  • Load-and-zero-rightmost-byte facility
  • Load/store-on-condition facility 2 (note, the former load/store-on-condition facility is renamed load-store-on-condition facility 1)
  • Message-security-assist extension 5
  • Vector facility for z/Architecture (the LOAD COUNT TO BLOCK BOUNDARY is the only general instruction in this facility; the remaining instructions appear in Chapters 21-24)

– Numerous clarifications and corrections are made to the descriptions of the message-security instructions: CIPHER MESSAGE, CIPHER MESSAGE WITH CHAINING, CIPHER MESSAGE WITH CIPHER FEEDBACK, CIPHER MESSAGE WITH COUNTER, CIPHER MESSAGE WITH OUTPUT FEEDBACK, COMPUTE INTERMEDIATE MESSAGE DIGEST, COMPUTE LAST MESSAGE DIGEST, COMPUTE MESSAGE AUTHENTICATION CODE, and PERFORM CRYPTOGRAPHIC COMPUTATION. Additional clarification is made to the section “Protection of Cryptographic Keys.”

– Clarification is made to the description of access exception for instructions of the interlocked-access facility 1. Also, additional extended mnemonics are described for the instructions of the facility.

– A programming note is added to the description of PERFORM LOCKED OPERATION.

– Programming notes are added to the SHIFT LEFT SINGLE LOGICAL and SHIFT RIGHT SINGLE LOGICAL instructions.

– Clarification is added to programming note 5 for STORE CLOCK and STORE CLOCK FAST.

– Leap second 26 is documented.

– Various changes and clarifications are made to the description of TRANSACTION BEGIN.

• In Chapter 8, “General Instructions”:
  – The description of the signed-packed-decimal format is amended to accommodate the addition of the DFP-packed-conversion facility.
  – The term general-operand data exception replaces the former decimal-operand data exception.

• In Chapter 9, “Floating-Point Overview and Support Instructions”:
  – References to the ANSI/IEEE binary-floating-point standard are updated.
  – Numerous clarifications are made to the description of the PERFORM FLOATING POINT OPERATION instruction and affiliated text.

• In Chapter 10, “Control Instructions”:
  – In the description of BRANCH AND SET AUTHORITY, clarification is made to the discussion of special conditions.
  – In the description of LOAD PAGE TABLE ENTRY ADDRESS, a correction is made to programming notes 2 and 3.
  – Clarification is provided in the description of the LOAD REAL ADDRESS instruction.

– In the description of PERFORM TIMING FACILITY FUNCTION:
  • New functions are added.
  • Numerous other clarifications are made to the instruction description.
  • Leap second 26 is documented.

– The description of SIGNAL PROCESSOR is changed to accommodate the vector facility for z/Architecture and multithreading facility.
– The description of STORE SYSTEM INFORMATION is updated to accommodate the multithreading facility.
– The description of TEST PROTECTION is updated to account for the EDAT-2 facility.

• In Chapter 11, “Machine-Check Handling”:
  – Various sections are updated to accommodate the addition of the vector facility for z/Architecture.
  – The vector-register-validity bit is added to the MCIC.
  – The machine-check extended save area is described.

• In Chapter 12, “Operator Facilities”:
  – Various constraints are put on the use of address-compare controls with using the program-event-recording (PER) facility.
  – Alter-and-display controls accommodate the vector registers.
  – A CPUs-per-core indicator is added in support of the multithreading facility.
  – The section “Multithreading Considerations” is added.

• In Chapter 13, “I/O Overview,” the bidirectional-data-transfer facility and transfer-control-area extension (TCAX) are described.

• In Chapter 15, “Basic I/O Functions”:
  – Description of the bidirectional-data-transfer operations is added to the various transport-mode I/O control structures.
  – Description of the transport-control-area extension (TCAX) is added.
  – Description of the transfer-TCA-Extension (TTE) DCW is added.

• In Chapter 16, “I/O Interruptions,” program-check conditions for bidirectional-data-transfer operations are added.

• In Chapter 19, “Binary-Floating-Point Instructions,” references to the ANSI/IEEE binary-floating-point standard are updated.

• In Chapter 20, “Decimal-Floating-Point Instructions”:
  – The instructions of the DFP-packed-conversion facility are described.
  – The term general-operand data exception replaces the former decimal-operand data exception.
  – In the description of the CONVERT TO ZONED instruction, clarification is made to the description of the zone control.

• Chapters 21-24 are added, describing the instructions of the vector facility for z/Architecture.

• Numerous other minor clarifications and corrections are included.

Summary of Changes in Tenth Edition

The tenth edition of this publication differs from the previous edition principally by containing the definitions of the following facilities:

• Decimal-floating-point zoned-conversion facility
• Enhanced-DAT facility 2
• Execution-hint facility
• Interlocked-access facility 2
• Load-and-trap facility
• Local-TLB-clearing facility
• Miscellaneous-instruction-extensions facility
• PER zero-address-detection facility
• Processor-assist facility
• Transactional-execution facility
• Warning-track-interruption facility

The tenth edition contains the following significant changes relative to the previous edition:

• In Chapter 1, “Introduction,” a summary of the new facilities is presented.

• In Chapter 3, “Storage:”
  – Changes introduced by the enhanced-DAT facility 2 are added.
  – Changes introduced by the execution-hint facility are added.
  – Changes introduced by the transactional-execution facility are added.
• In Chapter 4, “Control:”
  – Changes introduced by the enhanced-DAT facility 2 are added.
  – Changes introduced by the execution-hint facility are added.
  – Changes introduced by the PER zero-address-detection facility are added.
  – Changes introduced by the transactional-execution facility are added.
  – Leap second 25 is documented.
  – Facility indications for the new facilities are added.
• In Chapter 5, “Program Execution:”
  – New instruction formats are defined.
  – Changes introduced by the enhanced-DAT facility 2 are added.
  – Changes introduced by the execution-hint facility are added.
  – Changes introduced by the interlocked-access facility 2 are added.
  – Changes introduced by the transactional-execution facility are added.
  – Clarification is made to the access-register-translation process.
  – Clarification is made to the handling of PER events in the enhanced-monitor counting array.
• In Chapter 6, “Interruptions:”
  – Changes introduced by the load-and-trap facility are added.
  – Changes introduced by the transactional-execution facility are added.
  – Changes introduced by the warning-track-interruption facility are added.
  – Clarification is made to the description of the measurement-alert external interruption.
• In Chapter 7, “General Instructions:”
  – Changes introduced by the execution-hint facility are added.
  – Changes introduced by the interlocked-access facility 2 are added. The original interlocked-access facility is now called the interlocked-access facility 1.
  – Changes introduced by the load-and-trap facility are added.
  – Changes introduced by the miscellaneous-instruction-extension facility are added.
  – Changes introduced by the processor-assist facility are added.
  – Changes introduced by the transactional-execution facility are added.
  – Changes introduced by the PER zero-address-detection facility are added.
  – The EXTRACT CACHE ATTRIBUTE instruction is renamed EXTRACT CPU ATTRIBUTE.
• In Chapter 8, “Decimal Instructions:”
  – Changes introduced by the decimal-floating-point zoned-conversion facility are added.
  – Changes introduced by the transactional-execution facility are added.
• In Chapter 9, “Floating-Point Overview and Support Instructions:”
  – Changes introduced by the transactional-execution facility are added.
  – Miscellaneous corrections are made to Figure 9-21.
  – Miscellaneous clarifications and corrections are made to the description of PERFORM FLOATING POINT OPERATION.
• In Chapter 10, “Control Instructions:”
  – Changes introduced by the enhanced-DAT facility 2 are added.
  – Changes introduced by the local-TLB-clearing facility are added.
  – Changes introduced by the transactional-execution facility are added.
  – Changes introduced by the PER zero-address-detection facility are added.
– Clarification is made to the description of EXTRACT STACKED STATE.

– Clarification is made to the description of STORE CPU ID and STORE SYSTEM INFORMATION.

• In Chapter 12, “Operator Facilities,” clarification is made to the description of the load-unit-address controls.

• In Chapter 13, “I/O Overview:”
  – Clarification is made to the description of the device number.

• In Chapter 14, “I/O Instructions:”
  – Changes introduced by the transactional-execution facility are added.

• In Chapter 15, “Basic I/O Functions:”
  – Various clarifications are made to the description of the output-count field of the transport-control word.
  – Various clarifications and changes are made to the device-command word, including the description of the suppress-length-indication flag.
  – The transport-command DCW is described.
  – Clarifications are made to the description of the Transfer-CBC-offset-block DCW.

• In Chapter 16, “I/O Interruptions:”
  – The incorrect-length subchannel-status indication is described.

• In Chapter 17, “I/O Support Functions:”
  – The interrupt-delay-time and I/O-priority-delay-time fields are described in the measurement block.

• In Chapter 18, “Hexadecimal-Floating-Point Instructions:”
  – Changes introduced by the transactional-execution facility are added.
  – Clarifications are made to the description of CONVERT TO FIXED.

• In Chapter 19, “Binary-Floating-Point Instructions:”
  – Changes introduced by the transactional-execution facility are added.
  – Clarifications and corrections are made to the description of CONVERT TO FIXED.
  – Clarifications and corrections are made to the description of CONVERT TO LOGICAL.

• In Chapter 20, “Decimal-Floating-Point Instructions:”
  – Changes introduced by the decimal-floating-point zoned-conversion facility are added.
  – Changes introduced by the transactional-execution facility are added.

The tenth edition also contains numerous minor corrections and clarifications.

Summary of Changes in Ninth Edition

The ninth edition of this publication differs from the previous edition principally by containing the definitions of the following facilities:

• CMPSC-enhancement facility
• Distinct-operands facility
• Enhanced-monitor facility
• Fast-BCR-serialization facility
• Floating-point extension facility
• High-word facility
• Interlocked-access facility 1
• IPTE-range facility
• Load/store-on-condition facility
• Message-security-assist extension 3
• Message-security-assist extension 4
• Nonquiescing key-setting facility
• Population-count facility
• The Reset-reference-bits-multiple facility

The ninth edition contains the following significant changes relative to the previous edition:

• In Chapter 3, “Storage:”
  – Changes introduced by the reset-reference-bits-multiple are added to various sections.
  – Changes introduced by the enhanced-monitor facility are added.
– Changes introduced by the access-excep-
tion-fetch/store-indication facility are added.
– Clarification is added to the description of the
translation-exception identification.

• In Chapter 4, “Control:"
– Changes introduced by the enhanced-monitor
facility are added.
– Clarification is made to the description of the
PER ASCE identification (AI) and PER
access identification (PAID).
– Changes introduced by the high-word facility
are added.
– Descriptions of the new facility indications
are added.

• In Chapter 5, “Program Execution:"
– A significant editorial change has been made
to the description of the instruction formats.
Instruction formats having variations in
assembler syntax or field content are design-
ated by an alphabetic suffix which is also
reflected in the instruction descriptions in
chapters 7-10, 14, and 18-24.
– Changes introduced by the enhanced-monitor
facility are added.
– Clarification is made to the description of
suppression.
– Changes introduced by the message-secu-
rit,y assist extensions 3 and 4 are added.
– Changes introduced by the nonquiescing-
key-setting facility are added, including the
description of quiescing.
– Changes introduced by the interlocked-
access facility are added, including the
description of an interlocked-fetch reference
and specific-operand serialization.

• In Chapter 6, “Interruptions:"
– Changes introduced by the enhanced-monitor
facility are added.
– Changes introduced by the floating-point
extension facility are added.
– Clarification is provided regarding the han-
dling of data exceptions resulting from the
compare-and-trap instructions.

• In Chapter 7, “General Instructions:"
– Clarification is made as to the content of the
chapter.
– Changes introduced by the distinct-operands
facility are added.
– Changes introduced by the high-word facility
are added.
– Changes introduced by the interlocked-
access facility are added.
– Changes introduced by the load/store-on-
condition facility are added.
– Changes introduced by the message-secu-
rit,y-assist extension 3 are added, including a
new section on the protection of crypto-
graphic keys.
– Changes introduced by the message-secu-
rit,y-assist extension 4 are added.
– Changes introduced by the population-count
facility are added.
– Changes introduced by the instruction-for-
mat clarifications are added.
– Clarifications are made to the description of
COMPARE AND SWAP AND STORE.
– Changes introduced by the CMPSC-
enhancement facility are added.
– Extended assembler mnemonics are defined
for the ROTATE THEN AND SELECTED
BITS, ROTATE THEN OR SELECTED BITS,
and ROTATE THEN EXCLUSIVE OR
SELECTED BITS instructions.
– Clarification is made to the descriptions of
the SEARCH STRING and SEARCH
STRING UNICODE instructions.

• In Chapter 8, “Decimal Instructions:"
– Changes introduced by the instruction-for-
mat clarifications are added.
– Clarification is made to the description of the
EDIT and EDIT AND MARK instructions.
In Chapter 9, “Floating-Point Overview and Support Instructions:”
- Changes introduced by the instruction-format clarifications are added.
- Changes introduced by the floating-point-extension facility are added.

In Chapter 10, “Control Instructions:”
- Clarification is made as to the content of the chapter; specifically, the chapter also contains the description of certain nonprivileged instructions.
- Changes introduced by the instruction-format clarifications are added.
- Changes introduced by the IPTE-range facility are added.
- Changes introduced by the message-security-assist extension 3 are added.
- Changes introduced by the nonquiescing key-setting facility are added.
- Changes introduced by the reset-reference-bits-multiple facility are added.
- Changes are made to the STORE SYSTEM INFORMATION instruction with regards to topology information returned.

In Chapter 14, “Basic I/O Functions,” the CBC-offset block is added for the fibre-channel-extensions facility.

In Chapter 18, “Hexadecimal-Floating Instructions,” changes introduced by the instruction-format clarifications are added.

In Chapter 19, “Binary-Floating-Point Instructions:”
- Changes introduced by the instruction-format clarifications are added.
- Changes introduced by the floating-point-extension facility are added.

In Chapter 20, “Decimal-Floating-Point Instructions:”
- Changes introduced by the instruction-format clarifications are added.
- Changes introduced by the floating-point-extension facility are added.

The ninth edition also contains numerous minor corrections and clarifications.

Summary of Changes in Eighth Edition

The eighth edition of this publication differs from the previous edition principally by containing the definitions of the following facility:

- Fibre-channel-extensions (FCX) facility

The eighth edition contains the following significant changes relative to the previous edition:

- In Chapter 1, “Introduction,” a summary of the fibre-channel-extensions facility is added.
- In Chapter 4, “Control,” the clock setting for the leap second on January 1, 2009 is added to the section “Timing.”
- In Chapter 7, “General Instructions,” the clock setting for the leap second on January 1, 2009 is added to the description of STORE CLOCK EXTENDED.
- In Chapter 13, “I/O Overview,” changes introduced by the fibre-channel-extensions facility are added to various sections.
- In Chapter 14, “I/O Instructions,” changes introduced by the fibre-channel-extensions facility are added to various sections.
- In Chapter 15, “Basic I/O Functions,” changes introduced by the fibre-channel-extensions facility are added to various sections.
- In Chapter 16, “I/O Interruptions,” changes introduced by the fibre-channel-extensions facility are added to various sections.
- In Chapter 17, “I/O Support Functions,” changes introduced by the fibre-channel-extensions facility are added to various sections.

The eighth edition also contains numerous minor corrections and clarifications.
Summary of Changes in Seventh Edition

The seventh edition of this publication differs from the previous edition principally by containing the definitions of the following facilities:

- Compare-and-swap-and-store facility
- Configuration-topology facility
- Enhanced-DAT facility
- Execute-extensions facility
- General-instructions-extension facility
- Message-security-assist extension
- Move-with-optional-specifications facility
- Parsing-enhancement facility
- Restore-subchannel facility

The seventh edition contains the following significant changes relative to the previous edition:

- In Chapter 3, “Storage:”
  - Changes introduced by the enhanced-DAT facility are added to various sections.
  - Changes introduced by the enhanced-suppression-on-protection function are added
  - Changes introduced by the execute-extensions facility are added to various sections.
  - Changes introduced by the general-instructions-extension facility are added to the section “Assigned Storage Locations.”
  - Changes introduced by the move-with-optional-specifications facility are added to the section “Protection.”

- In Chapter 4, “Control:”
  - Changes introduced by the enhanced-DAT facility are added to various sections.
  - Changes introduced by the execute-extensions facility are added to various sections.
  - Changes introduced by the general-instructions-extension facility are added to various sections.
  - Changes introduced by the move-with-optional-specifications facility are added to various sections.

- In Chapter 5, “Program Execution:”
  - In the section “Instruction Formats,” the RIS, RRS, and SIL formats are added. Four new versions of the RIE instruction format and one new version of the RXY format are added.
  - Changes introduced by the enhanced-DAT facility are added to various sections.
  - Changes introduced by the execute-extensions facility are added to various sections.
  - Changes introduced by the general-instructions-extension facility are added to various sections.
  - Changes introduced by the move-with-optional-specifications facility are added to various sections.
  - Changes introduced by the parsing-enhancement facility are added to the section “Multiple-Access References.”

- In Chapter 6, “Interruptions:”
  - Changes introduced by the compare-and-swap-and-store facility are added to the section “Specification Exception.”
  - Changes introduced by the enhanced-DAT facility are added to various sections.
  - Changes introduced by the execute-extensions facility are added to various sections.
  - Changes introduced by the general-instructions-extension facility are added to various sections.
  - Changes introduced by the move-with-optional-specifications facility are added to various sections.
  - Changes introduced by the parsing-enhancement facility are added to section “Specification Exception.”

- In Chapter 7, “General Instructions:”
  - For various instruction descriptions in which multiple instruction formats are present,
headings have been added to distinguish one format from another.

- Changes introduced by the compare-and-swap-and-store facility 2 are added to the description of the COMPARE AND SWAP AND STORE instruction.

- Changes introduced by the message-security-assist extension 2 are added to the descriptions of the CIPHER MESSAGE, CIPHER MESSAGE WITH CHAINING, COMPUTE INTERMEDIATE MESSAGE DIGEST and COMPUTE LAST MESSAGE DIGEST instructions.

- Programming notes are added to the description of the UTF conversion instructions (CU12, CU14, CU21, CU24, CU41, and CU42) indicating that the instructions support big-endian encoding only.

- Changes introduced by the execute-extensions facility are added to various sections, including the description of the EXECUTE RELATIVE LONG instruction.

- Changes introduced by the general-instructions-extension facility are added to various sections, including the descriptions of the facility’s 72 new instructions.

- The description of the MOVE LONG UNICODE instruction is amended such that an odd length specification is permitted.

- Changes introduced by the parsing-enhancement facility are added to various sections, including the descriptions of the TRANSLATE AND TEST EXTENDED and TRANSLATE AND TEST REVERSE EXTENDED instructions.

- In Chapter 10, “Control Instructions:”
  - Changes introduced by the move-with-optimal-specifications facility are added to various sections, including the description of the MOVE WITH OPTIMAL SPECIFICATIONS instruction.
  - Changes introduced by the enhanced-DAT facility are added to various sections.

- In Chapter 11, “Machine-Check Handling:”
  - Changes introduced by the enhanced-DAT facility are added to various sections.

- In Chapter 13, “I/O Overview,” changes introduce by the multiple-subchannel set facility are described.

- In Chapter 14, “I/O Instructions,” changes introduce by the multiple-subchannel set facility are described.

- In Chapter 17, “I/O Support Functions,” changes introduce by the multiple-subchannel set facility are described.

The seventh edition also contains numerous minor corrections and clarifications.

### Summary of Changes in Sixth Edition

The sixth edition of this publication differs from the previous edition principally by containing the definitions of the following facilities:

- Compare-and-swap-and-store facility
- Conditional-SSKE facility
- Decimal-floating-point facility
- Decimal-floating-point-rounding facility
- Extract-CPU-time facility
• Floating-point-support-sign-handling facility
• FPR-GR-transfer facility
• IEEE-exception-simulation facility
• PFPO facility

The sixth edition contains the following significant changes relative to the previous edition:

• In Chapter 3, “Storage”:
  – Changes introduced by the conditional-SSKE facility are added to various sections.
  – In the “Assigned Storage Locations” section, the descriptions of the various fields now include hexadecimal as well as decimal locations.
  – Clarification is made to the definition of the exception access identification and PER access identification at locations 160 and 161, respectively.

• In Chapter 4, “Control”:
  – Changes introduced by the extract-CPU-time facility are added to the section “CPU Timer.”
  – New facility bits for the compare-and-swap-and-store facility, decimal-floating-point facility, decimal-floating-point performance, extract-CPU-time facility, floating-point-support-enhancement facilities (FPR-GR-transfer, FPS-sign-handling, and DFP-rounding), and PFPO (PERFORM FLOATING-POINT OPERATION) facility are added to the section “Facility Indications.”

• In Chapter 5, “Program Execution”:
  – In the section “Instruction Formats”, the RRR and SSF formats are added.
  – Changes introduced by the compare-and-swap-and-store facility are added to various sections.
  – Changes introduced by the extract-CPU-time facility are added to the “Consistency Specification” section.
  – Previous restrictions on storing into the instruction stream in the access-register or home address-space-control modes are removed.

• In Chapter 6, “Interruptions”:
  – Changes introduced by the simulated IEEE exception (IXS) are added to the various sections.
  – Changes introduced by the compare-and-swap-and-store facility are added to various sections.
  – The descriptions of the special-operation and specification program interruptions are updated and rearranged.
  – Clarification is added to the section “Multiple Program- Interruption Conditions.”

• In Chapter 7, “General Instructions”:
  – The descriptions of the COMPARE AND SWAP AND STORE and EXTRACT CPU TIME instructions are added.
  – Programming notes for COMPARE LOGICAL LONG UNICODE and MOVE LONG UNICODE are amended to account for the long-displacement facility.
  – A programming note clarifying the setting of the condition code is added to AND IMMEDIATE, EXCLUSIVE OR IMMEDIATE, and OR IMMEDIATE.

• In Chapter 9, “Floating-Point Overview and Support Instructions”:
  – The concepts of “views” and “quantum” are introduced.
  – The name of the instruction SET ROUNDING MODE is changed to SET BFP ROUNDING MODE and is moved from Chapter 19 to Chapter 9.
  – The following instructions operating on the floating-point-control (FPC) register are moved from Chapter 19 to Chapter 9: EXTRACT FPC, LOAD FPC, SET FPC, and STORE FPC.
  – The FPR-GR-transfer facility instructions, LOAD FPR FROM GR and LOAD GR FROM FPR, are added.
  – The four instructions making up the floating-point-support-sign-handling facility are added: COPY SIGN, LOAD COMPLEMENT, LOAD NEGATIVE, and LOAD POSITIVE.
– The decimal-floating-point-rounding facility is added. This includes a 3-bit DFP rounding mode field in the floating-point control (FPC) register and the instruction SET DFP Rounding Mode.

– The IEEE-exception-simulation facility is added, including the instructions SET FPC AND SIGNAL and LOAD FPC AND SIGNAL.

– The instruction PERFORM FLOATING-POINT OPERATION (PFPO) is added.

In Chapter 10, “Control Instructions”, changes introduced by the conditional-SSKE facility are added to the description of SET STORAGE KEY EXTENDED.

In Chapter 11, “Machine-Check Handling”, changes introduced by the conditional-SSKE facility are added.

In Chapter 12, the operator rate control is now defined to be model dependent.

In Chapter 14, clarification is added to the section “Modified CCW Indirect Data Addressing”.

In Chapter 18, “Hexadecimal-Floating-Point Instructions”: The names of two of the rounding methods used by the instruction CONVERT TO FIXED are changed from “biased round to nearest” and “round to nearest” to “round to nearest with ties away from 0” and “round to nearest with ties to even”, respectively.

In Chapter 19, “Binary-Floating-Point Instructions”: This chapter is updated extensively to be consistent with Chapter 20. This includes the following:

– The terms “normal” and “subnormal”, referring to BFP data classes, replace the obsolete terms “normalized”, and “denormalized”, respectively.

– The name of the instruction SET Rounding Mode is changed to SET BFP Rounding Mode and is moved from Chapter 19 to Chapter 9.

– The following instructions operating on the floating-point-control (FPC) register are moved from Chapter 19 to Chapter 9: EXTRACT FPC, LOAD FPC, SET FPC, and STORE FPC.

– The section “Floating-Point-Control (FPC) Register” is moved to Chapter 9.

– The sections “BFP Rounding”, “BFP Comparison”, “Condition Codes for BFP Instructions”, and “IEEE Exception Conditions” are renamed and moved to Chapter 9.

In Chapter 20, “Decimal-Floating-Point Instructions”: This chapter is new, and describes the decimal-floating-point (DFP) facility.

The sixth edition also contains numerous minor corrections and clarifications.

### Summary of Changes in Fifth Edition

The fifth edition of this publication differs from the previous edition principally by containing the definitions of the following facilities:

- DAT-enhancement facility 2
- ETF2-enhancement facility
- ETF3-enhancement facility
- Extended-immediate facility
- HFP-unnormalized-extensions facility
- Message-security-assist extension 1
- Modified-CCW-indirect-data-addressing facility
- PER-3 facility
- Server-time-protocol facility
- Store-clock-fast facility
- Store-facility-list-extended facility:
- TOD-clock-steering facility

The fifth edition contains minor clarifications and corrections and also the following significant changes relative to the previous edition:

In Chapter 3, “Storage”:

– In the “Information Formats” section, the length of a storage-operand field that is implied by the instruction now includes a 16-byte operand.

– Changes introduced by the modified-CCW-indirect-data-addressing facility are added to various sections.

– Changes introduced by the DAT-enhancement facility 2 are added to various sections.
– Changes introduced by the PER-3 facility are added to the section “Assigned Storage Locations.”

– Changes introduced by the store-facility-list-extended facility are added to section “Assigned Storage Locations.”

• In Chapter 4, “Control”:

– Changes introduced by the store-clock-fast facility are added to various sections.

– Changes introduced by the PER-3 facility, including breaking-event-address recording and PER instruction-fetch nullification, are added to various sections.

– Changes introduced by the server-time protocol (STP) facility are added to various sections.

– Changes introduced by the TOD-clock-steering facility are added to various sections.

– The conditional-emergency-signal and sense-running-status orders are added to the section “Signal-Processor Orders.”

– The location in which the PSW that is preserved as a result of switching from the z/Architecture to the ESA/390 architectural mode is formally named the Captured z/Architecture PSW register.

– The description of all facility-indication bits has been moved to a new section at the end of the chapter.

• In Chapter 5, “Program Execution”:

– The instructions of the message-security assist are added to the section “Condition Code Alternative to Interruptibility.”

– Changes introduced by the DAT-enhancement facility 2 are added to various sections.

– Changes introduced by the modified-CCW-indirect-data-addressing facility are added to the section “Channel-Program Serialization.”

• In Chapter 6, “Interruptions”:

– Changes introduced by the server-time protocol (STP) facility are added to various sections.

– Changes introduced by the TOD-clock-steering facility are added to various sections.

– Changes introduced by the DAT-enhancement facility 2 are added to various sections.

• In Chapter 7, “General Instructions”:

– A note is added to the “Instructions” section indicating that, for certain new or modified instructions, an operand may be optional.

– Descriptions of thirty-four new instructions introduced by the extended-immediate facility are added.

– A description of the STORE CLOCK FAST instruction is added.

– A description of the STORE FACILITY LIST EXTENDED instruction is added.

– Changes introduced by the TOD-clock-steering facility are added to the STORE CLOCK, STORE CLOCK FAST, and STORE CLOCK EXTENDED instructions.

– Descriptions of new functions introduced by the message-security-assist extension 1 are added to the CIPHER MESSAGE, CIPHER MESSAGE WITH CHAINING, COMPUTE INTERMEDIATE MESSAGE DIGEST, and COMPUTE LAST MESSAGE DIGEST instructions.

– Changes introduced by the ETF-2 enhancement facility are added to the TRANSLATE ONE TO ONE, TRANSLATE ONE TO TWO, TRANSLATE TWO TO ONE, and TRANSLATE TWO TO TWO instructions.

– Changes introduced by the ETF-3 enhancement are added to the CONVERT UTF-16 TO UTF-32, CONVERT UTF-16 TO UTF-8, CONVERT UTF-8 TO UTF-16, and CONVERT UTF-8 TO UTF-32 instructions.

• In Chapter 10, “Control Instructions”:
– A description of the LOAD PAGE-TABLE-ENTRY ADDRESS instruction, introduced by the DAT-enhancement facility 2, is added.

– A description of the PERFORM TIMING FACILITY FUNCTION instruction, introduced by the TOD-clock-steering facility, is added.

– Changes introduced by the TOD-clock-steering facility are added to the description of the SET CLOCK instruction.

– The description of all facility-indication bits are moved to Chapter 4 (they are removed from the description of the STORE FACILITY LIST instruction).

– A model-dependent field is defined in the SYSIB 2.2.2 operand stored by the STORE SYSTEM INFORMATION instruction.

– Changes introduced by the store-clock-fast facility are added to the description of the TRACE instruction.

• In Chapter 11, “Machine-Check Handling”:
  – Changes introduced by the store-clock-fast facility are added to the section “CPU Retry.”
  – Changes introduced by the modified-CCW-indirect-data-addressing facility are added to the section “Invalid CBC in Storage”.
  – Changes introduced by the TOD-clock-steering facility are added to the section “Timing-Facility Damage.”
  – Changes introduced by the server-time-protocol facility are added to the section “External-Damage Code.”

• In Chapter 13, “I/O Overview”, changes introduced by the modified-CCW-indirect-data-addressing facility are added to the section “Channel-Program Execution”.

• In Chapter 15, “Basic I/O Functions”:
  • Changes introduced by the modified-CCW-indirect-data-addressing facility are added which include:
    • The modified-indirect-data-address word (MIDAW) is defined.
    • Bit 25 of word 1 of the operation-request block (ORB) is defined as the modified-CCW-indirect-data-addressing control.
  • Bit 7 of the flags field in the channel-command word (CCW) is defined as the modified-indirect-data-addressing flag.

• In Chapter 16, “I/O Interruptions”:
  • Changes introduced by the modified-CCW-indirect-data-address facility are added to the sections “Subchannel-Status Word” and “Extended-Status Word”.
  • Changes are introduced to the section “Interface-Control Check” to support retrying a CCW-type IPL when an interface-control check is detected during the execution of the IPL channel program.

• In Chapter 17, “I/O Support Functions”:
  • Changes are introduced to the section “CCW-Type IPL” to support retrying a CCW-type IPL when an interface-control check is detected during the execution of the IPL channel program.
  • Changes are introduced to the section “List-Directed IPL” to support storing of the subsystem-identification word (SID) for the IPL-device during list-directed IPL, if a subchannel is associated with the IPL-device.

• In Chapter 18, “Hexadecimal-Floating-Point Instructions”, descriptions of the twelve instructions introduced by the HFP-unnormalized-extensions facility are added.

• In Appendix I, character representations of EBCDIC code pages 81C, 94C, 500, and 1047, IBM-PC, and BookMaster symbols are removed. Only the commonly used EBCDIC code page 037 and ISO-8 characters are shown.

Summary of Changes in Fourth Edition

The fourth edition of this publication differs from the previous edition principally by containing the definitions of the extended-translation facility 3 and the ASN-and-LX-reuse facility. The fourth edition contains minor clarifications and corrections and also the following significant changes relative to the previous edition:

• In Chapter 3, “Storage”:
Changes introduced by the ASN-and-LX-reuse facility are added, including changes to the “Address Spaces” and “ASN Translation” sections.

A programming note is added to the “Dynamic Address Translation” section, describing implications in using common segments.

The ATMID and AI fields are corrected in the “Assigned Storage Locations” figure.

In Chapter 4, “Control”:

Changes introduced by the ASN-and-LX-reuse facility are added, including changes to the “Trace” section.

The list-directed IPL function is added to the “Initial Program Load” section.

In the “Trace” section, serialization requirements for instructions that implicitly store into the trace table or linkage stack are relaxed.

In Chapter 5, “Program Execution”:

A new RI and SS instruction format are included.

Changes introduced by the ASN-and-LX-reuse facility are added, including changes to the “Authorization Mechanisms”, “PC-Number Translation”, and “Linkage-Stack Operations” sections.

The instructions of the extended-translation facility 3 (except TRANSLATE AND TEST REVERSED) are added to the sections “Condition-Code Alternative to Interruptibility” and “Multiple-Access References.”

Serialization requirements for instructions that implicitly store into the trace table or linkage stack are relaxed.

In Chapter 6, “Interruptions”:

Changes introduced by the ASN-and-LX-reuse facility include the new LFX translation, LSX translation, LSTE sequence, and ASTE instance exceptions.

An additional condition for TRAP is added to the list of instructions that can cause a special-operation exception to be recognized.

SEARCH STRING UNICODE, a part of the extended-translation facility 3, is added to the list of instructions that can cause a specification exception to be recognized.

In Chapter 7, “General Instructions”:

Six new instructions provided by the extended-translation facility 3 are added. The instructions CONVERT UNICODE TO UTF-8 (CUUTF) and CONVERT UTF-8 TO UNICODE (CUTFU) are renamed to CONVERT UTF-16 TO UTF-8 (CU21) and CONVERT UTF-8 TO UTF-16 (CU12), respectively. The old mnemonics continue to be recognized.

The instruction-format illustrations for STAMY and STMY are corrected.

In Chapter 10, “Control Instructions”:

Changes introduced by the ASN-and-LX-reuse facility include the following:

Four new instructions provided by the facility are added.

The definitions of BRANCH AND STACK, BRANCH IN SUBSPACE GROUP, EXTRACT PRIMARY ASN, EXTRACT SECONDARY ASN, LOAD ADDRESS SPACE PARAMETERS, PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, and SET SECONDARY ASN are updated to account for the facility.

New facility bits for the ASN-and-LX-reuse facility and the extended-translation facility 3 are added to STORE FACILITY LIST.

New fields are added to the system-information block (SYSIB) returned by STORE SYSTEM INFORMATION.

Serialization requirements for instructions that implicitly store into the trace table or linkage stack are relaxed, including PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER (WITH INSTANCE), SET SECONDARY ASN (WITH INSTANCE), and TRACE.

Corrections and clarifications are made to TRAP.

In Chapter 12, “Operator Facilities”: Changes introduced by the list-directed IPL function are
added, including the load-clear-list-directed key and the load-with-dump key.

- In Chapter 14, “I/O Instructions”, Clarifications are added to programming note 1 of the CANCEL SUBCHANNEL instruction description.

- In Chapter 16, “I/O Interruptions”:
  - Bit 1 of the extended-report word (ERW) is defined as the request-logging-only (L) bit.
  - Bit 2 of the ERW is defined as the extended-subchannel-logout-pending (E) bit.
  - Words 2-3 of the format-0 extended-status word (ESW) are defined as the failing-storage address when the failing-storage-address-validity (F) bit, bit 6 of the ERW, is one and as the extended-subchannel-logout descriptor (ESLD) when the extended-subchannel-logout-pending (E) bit, bit 2 of the ERW, is one. The E-bit is always zero when the F-bit is one, and the F-bit is always zero when the E-bit is one.

- In Chapter 17, “I/O Support Functions”, list-directed IPL is added to support initial-program loading (IPL) from devices that are not accessed by CCWs. IPL from devices that are accessed by CCWs is designated CCW-type IPL.

- In Appendix C, “Condition-Code Settings”: The instructions of the extended-translation facility 3 are added.

Summary of Changes in Third Edition

The third edition of this publication differs from the previous edition principally by containing the definitions of the DAT-enhancement, HFP-multiply-add/subtract, and long-displacement facilities and the message-security assist. The third edition contains minor clarifications and corrections and also the following significant changes relative to the previous edition:

- In Chapter 3, “Storage”:
  - Clarifications are added to the description of dynamic-address-translation process.

  - The primary address-space-control element (ASCE) in control register 1 is an attaching ASCE even when the CPU is in the home-space mode, and the home ASCE in control register 13 is an attaching ASCE even when the CPU is in the secondary-space mode.

  - The illustration of the PER code in Figure 3-14 is corrected.

- In Chapter 4, “Control”:
  - The relationships between ETR time (TOD-clock time), UTC, and International Atomic Time are described in programming note 3 on page 4-45.

  - Code 0 of the SIGNAL PROCESSOR set-architecture order, and also a CPU reset due to activation of the load normal key, are changed to save the current z/Architecture PSW when switching to the ESA/390 architectural mode. Also, code 2 of the order is added, and this restores, for CPUs other than the one executing SIGNAL PROCESSOR, the saved PSW when switching to the z/Architecture architectural mode, provided that the saved PSW has not been set to all zeros by certain resets.

- In Chapter 5, “Program Execution”:
  - The I format, the RI format with a M1 operand, and the SS format with the I3 operand are added.

  - The RSY, RXY, and SIY instruction formats are added, and the RSE format is deleted. (All instructions that were of format RSE are now referred to as being of format RSY.)

  - The formation of an operand address using the 20-bit signed displacement of instructions of formats RSY, RXY, and SIY is described.

  - The results when a PER instruction-fetching event occurs along with certain exceptions or exception conditions are clarified. See “Indication of PER Events Concurrently with Other Interruption Conditions” on page 4-36

  - The fetch of the address-space-control element from the ASN-second-table entry during access-register translation is doubleword concurrent as observed by other CPUs.
– The change bit is not necessarily set to one currently with the related storage reference, as observed by other CPUs; it may be set to one before or after the reference, within certain limits. See “Storage-Key Accesses” on page 5-118 for a detailed description of when the change bit is set.

– The five instructions of the message-security assist are added to the list of instructions having multiple-access references.

• In Chapter 6, “Interruptions,” the list of conditions causing a specification exception to be recognized is extended to include those caused by the message-security assist instructions.

• In Chapter 7, “General Instructions”:
  – Thirty-nine instructions provided by the long-displacement facility are added. With the exception of the new LOAD BYTE instruction, the instructions added by the long-displacement facility have names and functions that are the same as existing instructions (but the mnemonics and opcodes are new). The new instructions are of formats RSY, RXY, and SIY and have a 20-bit signed displacement instead of a 12-bit unsigned displacement.

  – All previously existing format-RSE and format-RXE instructions are changed to be of formats RSY and RXY, respectively, by use of a previously unused byte in the instructions. These changes are not marked by a bar in the margin.

  – Five instructions provided by the message-security assist are added.

  – The instruction format of SUPERVISOR CALL is changed to I.

• In Chapter 9, “Floating-Point Overview and Support Instructions,” four instructions provided by the long-displacement facility are added. These are the LOAD (long and short) and STORE (long and short) instructions.

• In Chapter 10, “Control Instructions”:
  – The COMPARE AND SWAP AND PURGE (CSPG) and INVALIDATE DAT TABLE ENTRY instructions provided by the DAT-enhancement facility are added. CSPG operates on a doubleword operand in storage.

  – The definition of LOAD ADDRESS SPACE PARAMETERS is clarified.

  – The LOAD REAL ADDRESS (LRAY) instruction provided by the long-displacement facility is added.

  – All previously existing format-RSE instructions are changed to be of format RSY by use of a previously unused byte in the instructions. These changes are not marked by a bar in the margin.

  – The description of the bits set by STORE FACILITY LIST is clarified, and new bits are assigned.

• In Chapter 14, “I/O Instructions”:
  – The definition of MODIFY SUBCHANNEL is modified.

  – The definition of SET CHANNEL MONITOR is modified.

• In Chapter 15, “Basic I/O Functions,” the following changes are made to the subchannel-information-block (SCHIB):
  – Bit 29 of word 6 of the path-management-control word (PMCW) is defined as the measurement-block-format control.

  – Bit 30 of word 6 of the PMCW is defined as the extended-measurement-word-mode enablement bit.

  – The definition of words 10-11 (words 0-1 of the model-dependent area) are changed to contain a measurement-block address, when the extended-I/O-measurement-block facility is installed.

• In Chapter 16, “I/O Interruptions”, the interruption-response block (IRB) is extended to include the extended-measurement word.

• In Chapter 17, “I/O Support Functions”:
  – The requirement that the measurement block be updated when secondary status is accepted is clarified.

  – The extended-measurement-block facility is added.

  – The extended-measurement-word facility is added.
• In Chapter 18, “Hexadecimal-Floating-Point Instructions,” the MULTIPLY AND ADD (four instructions) and MULTIPLY AND SUBTRACT (four instructions) instructions provided by the HFP-multiply-add/subtract facility are added.

The above changes may affect other chapters besides the ones listed. All technical changes to the text or to an illustration are indicated by a vertical line to the left of the change.

Summary of Changes in Second Edition

The second edition of this publication differs from the previous edition mainly by containing clarifications and corrections. The significant changes are as follows:

• In Chapter 1, “Introduction”:
  – Summaries of DIVIDE LOGICAL and MULTIPLY LOGICAL, TEST ADDRESSING MODE, the set-architecture order of SIGNAL PROCESSOR, and STORE FACILITY LIST are added or improved.
  – An extensive summary of the input/output enhancements placed in z/Architecture is added.
• In Chapter 3, “Storage”:
  – Definitions of absolute locations 0-23 are deleted since they pertain only to an ESA/390 initial program load.
  – The definition of real locations 200-203, stored in by STORE FACILITY LIST, is corrected to state that bit 16 indicates the extended-translation facility 2.
• In Chapter 4, “Control,” a description of unassigned fields in the PSW is corrected to state that bit 4 is unassigned and bit 31 is assigned.
• In Chapter 5, “Program Execution,” the RSL format and an RIL format with an M1 field are added.
• In Chapter 7, “General Instructions”:
  – The definition of BRANCH AND SET MODE is corrected to state that bit 63 of the R1 general register remains unchanged in the 24-bit or 31-bit addressing mode; the bit is not set to zero.
  – The definitions of PACK ASCII, PACK UNICODE, UNPACK ASCII, and UNPACK UNICODE are clarified.
  – It is clarified that the following instructions perform multiple-access references to their storage operands:
    – CHECKSUM
    – COMPARE AND FORM CODEWORD
    – CONVERT UNICODE TO UTF-8
    – CONVERT UTF-8 TO UNICODE
  – It is clarified that the following instructions do not necessarily process their storage operands left to right as observed by other CPUs: MOVE LONG, MOVE LONG EXTENDED, and MOVE LONG UNICODE. Special padding characters of MOVE LONG and MOVE LONG EXTENDED specify whether left-to-right processing should be performed, as observed by other CPUs, and whether the data being moved should or should not be placed in the cache for availability for subsequent processing.
• In Chapter 10, “Control Instructions,” it is clarified that the following instructions perform multiple-access references to their storage operands:
  – LOAD ADDRESS SPACE PARAMETERS
  – RESUME PROGRAM
  – STORE SYSTEM INFORMATION

Chapters 13-17 contain many clarifying changes, all indicated by a vertical line in the margin, in addition to the significant changes listed below.

• In Chapter 13, “I/O Overview,” statements about the suspend flag in a CCW are clarified to describe the flag being specified as a one and being valid because of a one value of the suspend control in the associated ORB.
• In Chapter 14, “I/O Instructions,” the results of MODIFY SUBCHANNEL when the device-number-valid bit at the designated subchannel is zero are corrected.
• In Chapter 15, “Basic I/O Functions”:
  – It is clarified that unlimited prefetching of data and IDAWs associated with the current
and prefetched CCWs is allowed independent of the value of the prefetch control in the associated ORB.

- A specified control-unit-priority number is ignored if the channel-subsystem-I/O-priority facility is not operational due to an operator action.

- It is clarified that address-limit checking applies to data locations and not to locations containing a CCW or IDAW.

- In Chapter 16, “I/O Interruptions,” the form of the address stored in the failing-storage-address field is described in terms of the format-2-IDAW control instead of an addressing mode.

- In Chapter 17, “I/O Support Functions”:
  - The introduction to the channel-subsystem monitoring facilities is clarified.
  - References to the measurement block by the measurement-block-update facility are single-access references and appear to be word concurrent as observed by CPUs. They do not appear to be block concurrent.
  - The description of the channel-subsystem-I/O-priority facility is corrected by including mention of control-unit priority for fibre-channel-attached control units.

The above changes may affect other chapters besides the ones listed.
## Chapter 1. Introduction

<table>
<thead>
<tr>
<th>Highlight</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Highlights of Original z/Architecture</td>
<td>1-2</td>
</tr>
<tr>
<td>General Instructions for 64-Bit Integers</td>
<td>1-3</td>
</tr>
<tr>
<td>Other New General Instructions</td>
<td>1-3</td>
</tr>
<tr>
<td>Floating-Point Support-Sign-Handling Facility</td>
<td>1-4</td>
</tr>
<tr>
<td>Control Instructions</td>
<td>1-4</td>
</tr>
<tr>
<td>Trimonial Addressing</td>
<td>1-5</td>
</tr>
<tr>
<td>Effects on Bits 0-31 of a General Register</td>
<td>1-6</td>
</tr>
<tr>
<td>Additions to z/Architecture</td>
<td>1-7</td>
</tr>
<tr>
<td>ASN-and-LX-Reuse Facility</td>
<td>1-7</td>
</tr>
<tr>
<td>CMPSC-Enhancement Facility</td>
<td>1-7</td>
</tr>
<tr>
<td>Compare-and-Swap-and-Store Facility</td>
<td>1-7</td>
</tr>
<tr>
<td>Compare-and-Swap-and-Store Facility 2</td>
<td>1-8</td>
</tr>
<tr>
<td>Conditional-SSKE Facility</td>
<td>1-8</td>
</tr>
<tr>
<td>Configuration-Topology Facility</td>
<td>1-8</td>
</tr>
<tr>
<td>Constrained-Transactional-Execution Facility</td>
<td>1-8</td>
</tr>
<tr>
<td>DAT-Enhancement Facility 1</td>
<td>1-8</td>
</tr>
<tr>
<td>DAT-Enhancement Facility 2</td>
<td>1-8</td>
</tr>
<tr>
<td>Decimal-Floating-Point Facility</td>
<td>1-8</td>
</tr>
<tr>
<td>Decimal-Floating-Point Packed-Conversion</td>
<td>1-9</td>
</tr>
<tr>
<td>Decimal-Floating-Point-Rounding Facility</td>
<td>1-9</td>
</tr>
<tr>
<td>Distinct-Operands Facility</td>
<td>1-9</td>
</tr>
<tr>
<td>Enhanced-DAT Facility 1</td>
<td>1-9</td>
</tr>
<tr>
<td>Enhanced-DAT Facility 2</td>
<td>1-10</td>
</tr>
<tr>
<td>Enhanced-Monitor Facility</td>
<td>1-10</td>
</tr>
<tr>
<td>ETF2-Enhancement Facility</td>
<td>1-11</td>
</tr>
<tr>
<td>ETF3-Enhancement Facility</td>
<td>1-11</td>
</tr>
<tr>
<td>Execute-Extensions Facility</td>
<td>1-11</td>
</tr>
<tr>
<td>Execution-Hint Facility</td>
<td>1-11</td>
</tr>
<tr>
<td>Extended-Immediate Facility</td>
<td>1-11</td>
</tr>
<tr>
<td>Extended-I/O-Measurement-Block Facility</td>
<td>1-12</td>
</tr>
<tr>
<td>Extended-I/O-Measurement-Word Facility</td>
<td>1-12</td>
</tr>
<tr>
<td>Extended-Translation Facility 2</td>
<td>1-12</td>
</tr>
<tr>
<td>Extended-Translation Facility 3</td>
<td>1-12</td>
</tr>
<tr>
<td>Extract-CPU-Time Facility</td>
<td>1-13</td>
</tr>
<tr>
<td>Fast-BCR-Serialization Facility</td>
<td>1-13</td>
</tr>
<tr>
<td>Fibre-Channel Extensions (FCX)</td>
<td>1-13</td>
</tr>
<tr>
<td>FCX-Bidirectional-Data-Transfer Facility</td>
<td>1-13</td>
</tr>
<tr>
<td>Floating-Point Extension Facility</td>
<td>1-13</td>
</tr>
<tr>
<td>Floating-Point-Support-Sign-Handling Facility</td>
<td>1-14</td>
</tr>
<tr>
<td>FPR-GR-Transfer Facility</td>
<td>1-14</td>
</tr>
<tr>
<td>General-Instructions-Extension Facility</td>
<td>1-14</td>
</tr>
<tr>
<td>HFP Multiply-and-Add/Subtract Facility</td>
<td>1-15</td>
</tr>
<tr>
<td>HFP-Unnormalized-Extensions Facility</td>
<td>1-15</td>
</tr>
<tr>
<td>High-Word Facility</td>
<td>1-15</td>
</tr>
<tr>
<td>IEEE-Exception-Simulation Facility</td>
<td>1-16</td>
</tr>
<tr>
<td>Interlocked-Access Facility 1</td>
<td>1-16</td>
</tr>
<tr>
<td>Interlocked-Access Facility 2</td>
<td>1-16</td>
</tr>
<tr>
<td>IPTE-Range Facility</td>
<td>1-16</td>
</tr>
<tr>
<td>List-Directed Initial Program Load.</td>
<td>1-16</td>
</tr>
<tr>
<td>Load-and-Trap Facility</td>
<td>1-16</td>
</tr>
<tr>
<td>Load-and-Zero-Rightmost-Byte Facility</td>
<td>1-16</td>
</tr>
<tr>
<td>Load/Store-on-Condition Facility 1</td>
<td>1-17</td>
</tr>
<tr>
<td>Load/Store-on-Condition Facility 2</td>
<td>1-17</td>
</tr>
<tr>
<td>Local-TLB-Clearing Facility</td>
<td>1-17</td>
</tr>
<tr>
<td>Long-Displacement Facility</td>
<td>1-17</td>
</tr>
<tr>
<td>Message-Security Assist</td>
<td>1-17</td>
</tr>
<tr>
<td>Message-Security-Assist Extension 1</td>
<td>1-18</td>
</tr>
<tr>
<td>Message-Security-Assist Extension 2</td>
<td>1-18</td>
</tr>
<tr>
<td>Message-Security-Assist Extension 3</td>
<td>1-18</td>
</tr>
<tr>
<td>Miscellaneous-Instruction-Extensions Facility</td>
<td>1-20</td>
</tr>
<tr>
<td>Modified CCW Indirect Data Addressing Facility</td>
<td>1-20</td>
</tr>
<tr>
<td>Move-With-Optional-Specifications Facility</td>
<td>1-21</td>
</tr>
<tr>
<td>Multiple-Subchannel-Set Facility</td>
<td>1-21</td>
</tr>
<tr>
<td>Multithreading Facility</td>
<td>1-21</td>
</tr>
<tr>
<td>Nonquiescing Key-Setting Facility</td>
<td>1-21</td>
</tr>
<tr>
<td>Parsing-Enhancement Facility</td>
<td>1-21</td>
</tr>
<tr>
<td>PER-3 Facility</td>
<td>1-21</td>
</tr>
<tr>
<td>PER Zero-Address-Detection Facility</td>
<td>1-22</td>
</tr>
<tr>
<td>PFPO Facility</td>
<td>1-22</td>
</tr>
<tr>
<td>Population-Count Facility</td>
<td>1-22</td>
</tr>
<tr>
<td>Processor-Assist Facility</td>
<td>1-22</td>
</tr>
<tr>
<td>Reset-Reference-Bits-Multiple Facility</td>
<td>1-22</td>
</tr>
<tr>
<td>Restore-Subchannel Facility</td>
<td>1-22</td>
</tr>
<tr>
<td>Server-Time-Protocol Facility</td>
<td>1-22</td>
</tr>
<tr>
<td>Store-Clock-Fast Facility</td>
<td>1-23</td>
</tr>
<tr>
<td>Store-Facility-List-Extended Facility</td>
<td>1-23</td>
</tr>
<tr>
<td>TOD-Clock-Steering Facility</td>
<td>1-23</td>
</tr>
<tr>
<td>Transactional-Execution Facility</td>
<td>1-23</td>
</tr>
<tr>
<td>Vector Facility for z/Architecture</td>
<td>1-23</td>
</tr>
<tr>
<td>Warning-Track Interruption Facility</td>
<td>1-23</td>
</tr>
<tr>
<td>The ESA/390 Base</td>
<td>1-24</td>
</tr>
<tr>
<td>The ESA/370 and 370-XA Base</td>
<td>1-29</td>
</tr>
<tr>
<td>System Program</td>
<td>1-31</td>
</tr>
<tr>
<td>Compatibility</td>
<td>1-31</td>
</tr>
<tr>
<td>Compatibility among z/Architecture Systems</td>
<td>1-31</td>
</tr>
<tr>
<td>Compatibility between z/Architecture and ESA/390</td>
<td>1-31</td>
</tr>
<tr>
<td>Control-Program Compatibility</td>
<td>1-31</td>
</tr>
<tr>
<td>Problem-State Compatibility</td>
<td>1-31</td>
</tr>
</tbody>
</table>
This publication provides, for reference purposes, a detailed description of z/Architecture™.

The architecture of a system defines its attributes as seen by the programmer, that is, the conceptual structure and functional behavior of the machine, as distinct from the organization of the data flow, the logical design, the physical design, and the performance of any particular implementation. Several dissimilar machine implementations may conform to a single architecture. When the execution of a set of programs on different machine implementations produces the results that are defined by a single architecture, the implementations are considered to be compatible for those programs.

### Highlights of Original z/Architecture

z/Architecture is the next step in the evolution from the System/360 to the System/370™, System/370 extended architecture (370-XA), Enterprise Systems Architecture/370™ (ESA/370™), and Enterprise Systems Architecture/390® (ESA/390™). z/Architecture includes all of the facilities of ESA/390 except for the asynchronous-pageout, asynchronous-data-mover, program-call-fast, and vector facilities. z/Architecture also provides significant extensions, as follows:

- **Sixty-four-bit general registers and control registers.**

- **A 64-bit addressing mode**, in addition to the 24-bit and 31-bit addressing modes of ESA/390, which are carried forward to z/Architecture.

  Both operand addresses and instruction addresses can be 64-bit addresses. The program-status word (PSW) is expanded to 16 bytes to contain the larger instruction address. The PSW also contains a newly assigned bit that specifies the 64-bit addressing mode.

- **Up to three additional levels of dynamic-address-translation (DAT) tables**, called region tables, for translating 64-bit virtual addresses.

A virtual address space may be specified either by a segment-table designation as in ESA/390 or by a region-table designation, and either of these types of designation is called an address-space-control element (ASCE). An ASCE may alternatively be a real-space designation that causes virtual addresses to be treated simply as real addresses without the use of DAT tables.

- **An 8K-byte prefix area for containing larger old and new PSWs and register save areas.**

- **A SIGNAL PROCESSOR order for switching between the ESA/390 and z/Architecture architectural modes.**

  Initial program loading sets the ESA/390 architectural mode. The new SIGNAL PROCESSOR order then can be used to set the z/Architecture mode or to return from z/Architecture to ESA/390. This order causes all CPUs in the configuration always to be in the same architectural mode.

- **Many new instructions**, many of which operate on 64-bit binary integers.

  Some of the new instructions that do not operate on 64-bit binary integers have also been added to ESA/390.

  All of the ESA/390 instructions, except for those of the four facilities named above, are included in z/Architecture.

  The bit positions of the general registers and control registers of z/Architecture are numbered 0-63. An ESA/390 instruction that operates on bit positions 0-31 of a 32-bit register in ESA/390 operates instead on bit positions 32-63 of a 64-bit register in z/Architecture.

z/Architecture was announced in October, 2000. The remainder of this section summarizes the original contents of z/Architecture. Subsequent additions are described in “Additions to z/Architecture” on page 1-7.
### General Instructions for 64-Bit Integers

The 32-bit-binary-integer instructions of ESA/390 have new analogs in z/Architecture that operate on 64-bit binary integers. There are two types of analogs:

- Analogs that use two 64-bit binary integers to produce a 64-bit binary integer. For example, the ESA/390 ADD instruction (A for a storage-to-register operation or AR for a register-to-register operation) has the analogs AG (adds 64 bits from storage to the contents of a 64-bit general register) and AGR (adds the contents of a 64-bit general register to the contents of another 64-bit general register). These analogs are distinguished by having “G” in their mnemonics.

- Analogs that use a 64-bit binary integer and a 32-bit binary integer to produce a 64-bit binary integer. The 32-bit integer is either sign-extended or extended on the left with zeros, depending on whether the operation is signed or unsigned, respectively. For example, the ESA/390 ADD (A or AR) instruction has the analogs AGF (adds 32 bits from storage to the contents of a 64-bit general register) and AGFR (adds the contents of bit positions 32-63 of a 64-bit general register to the contents of another 64-bit general register). These analogs are distinguished by having “GF” in their mnemonics.

### Other New General Instructions

The other additional or significantly enhanced general instructions of z/Architecture are highlighted as follows:

- ADD LOGICAL WITH CARRY and SUBTRACT LOGICAL WITH BORROW operate on either 32-bit or 64-bit unsigned binary integers and include a carry or borrow, as represented by the leftmost bit of the two-bit condition code in the PSW, in the computation. This can improve the performance of operating on extended-precision integers (integers longer than 64 bits).

- AND IMMEDIATE and OR IMMEDIATE combine a two-byte immediate operand with any of the two bytes on two-byte boundaries in a 64-bit general register.

- BRANCH AND SAVE AND SET MODE and BRANCH AND SET MODE are enhanced so that they set bit 63 of the R1 general register to one if the current addressing mode is the 64-bit mode, and they set the 64-bit addressing mode if bit 63 of the R2 general register is one. This allows “pointer-directed” linkages between programs in different addressing modes, including any of the 24-bit, 31-bit, and 64-bit modes.

- BRANCH RELATIVE AND SAVE LONG and BRANCH RELATIVE ON CONDITION LONG are like the BRANCH RELATIVE AND SAVE and BRANCH RELATIVE ON CONDITION instructions of ESA/390 except that the new instructions use a 32-bit immediate field. This increases the target range available through relative branching.

- COMPARE AND FORM CODEWORD is enhanced so that, in the 64-bit addressing mode, the comparison unit is six bytes instead of two and the resulting codeword is eight bytes instead of four. UPDATE TREE is enhanced so that, in the 64-bit addressing mode, a node is 16 bytes instead of eight and the codeword in a node is eight bytes instead of four. This improves the performance of sorting records having long keys.

- DIVIDE LOGICAL uses a 64-bit or 128-bit unsigned binary dividend and a 32-bit or 64-bit unsigned binary divisor, respectively, to produce a 32-bit or 64-bit quotient and remainder, respectively. MULTIPLY LOGICAL uses a 32-bit or 64-bit unsigned binary multiplicand and multiplier to produce a 64-bit or 128-bit product, respectively.

- DIVIDE SINGLE divides a 64-bit dividend by a 32-bit or 64-bit divisor and produces a 64-bit quotient and remainder. MULTIPLY SINGLE is enhanced so it can multiply a 64-bit multiplicand by a 32-bit or 64-bit multiplier and produce a 64-bit product.

- EXTRACT PSW extracts bits 0-63 of the current PSW to allow determination of the current machine state, for example, determination of whether the CPU is in the problem state or the supervisor state.

- INSERT IMMEDIATE inserts a two-byte immediate operand into a 64-bit general register on any of the two-byte boundaries in the register. LOAD LOGICAL IMMEDIATE does the same and also clears the remainder of the register.
- LOAD ADDRESS RELATIVE LONG forms an address relative to the current (unupdated) instruction address by means of a signed 32-bit immediate field.

- LOAD LOGICAL THIRTY ONE BITS places the rightmost 31 bits of either a general register or a word in storage, with 33 zeros appended on the left, in a general register.

- LOAD MULTIPLE DISJOINT loads the leftmost 32 bits of each register in a range of general registers from one area in storage and the rightmost 32 bits of each of those registers from another area in storage. This is for use in place of a LOAD MULTIPLE HIGH instruction and a 32-bit LOAD MULTIPLE instruction when one of the storage areas is addressed by one of the registers loaded.

- LOAD MULTIPLE HIGH and STORE MULTIPLE HIGH load or store the leftmost 32 bits of each register in a range of general registers, allowing augmentation of existing programs that load or store the rightmost 32 bits by means of LOAD MULTIPLE and STORE MULTIPLE. (Sixty-four-bit forms of LOAD MULTIPLE and STORE MULTIPLE also are provided.)

- LOAD PAIR FROM QUADWORD and STORE PAIR TO QUADWORD operate between an even-odd pair of 64-bit general registers and a quadword in storage (16 bytes aligned on a 16-byte boundary). These instructions provide quadword consistency (all bytes appear to be loaded or stored concurrently in a multiple-CPU system). (Only the 64-bit form of COMPARE DOUBLE AND SWAP also provides quadword consistency.)

- LOAD REVERSED and STORE REVERSED load or store a two-byte, four-byte, or eight-byte unit in storage with the left-to-right sequence of the bytes reversed. LOAD REVERSED also can move a four-byte or eight-byte unit between two general registers. These operations allow conversion between “little-endian” and “big-endian” formats.

- PERFORM LOCKED OPERATION is enhanced with two more sets of function codes, with each set providing six different operations. One of the additional sets provides operations on 64-bit operands in 64-bit general registers, and the other provides operations on 128-bit operands in a parameter list.

- ROTATE LEFT SINGLE LOGICAL obtains 32 bits or 64 bits from a general register, rotates them (the leftmost bit replaces the rightmost bit), and places the result in another general register (a nondestructive rotate).

- SET ADDRESSING MODE can set any of the 24-bit, 31-bit, and 64-bit addressing modes.

- SHIFT LEFT SINGLE, SHIFT LEFT SINGLE LOGICAL, SHIFT RIGHT SINGLE, and SHIFT RIGHT SINGLE LOGICAL are enhanced with 64-bit forms that obtain the source operand from one general register and place the result operand in another general register (a nondestructive shift).

- TEST ADDRESSING MODE sets the condition code to indicate whether bits 31 and 32 of the current PSW specify the 24-bit, 31-bit, or 64-bit addressing mode.

- TEST UNDER MASK HIGH and TEST UNDER MASK LOW, which are ESA/390 instructions, are given the alternative name TEST UNDER MASK, and two additional forms are added so that a two-byte immediate operand can be used to test the bits of two bytes located on any of the two-byte boundaries in a 64-bit general register. (The ESA/390 instruction TEST UNDER MASK, which uses a one-byte immediate operand to test a byte in storage, continues to be provided.)

Floating-Point Instructions

The z/Architecture floating-point instructions are the same as in ESA/390 except that instructions are added for converting between 64-bit signed binary integers and either hexadecimal or binary floating-point data. These new instructions have “G” in their mnemonics.

Control Instructions

The new or enhanced control instructions of z/Architecture are highlighted as follows:

- EXTRACT AND SET EXTENDED AUTHORITY is a privileged instruction for changing the extended authorization index in a control register. This enables real-space designations to be used more efficiently by means of access lists.
• EXTRACT STACKED REGISTERS is enhanced to extract optionally all 64 bits of the contents of one or more saved general registers.
• EXTRACT STACKED STATE is enhanced to extract optionally the entire contents of the saved PSW, including a 64-bit instruction address.
• LOAD CONTROL and STORE CONTROL are enhanced for operating optionally on 64-bit control registers.
• LOAD PSW uses an eight-byte storage operand as in ESA/390 and expands this operand to a 16-byte z/Architecture PSW.
• LOAD PSW EXTENDED directly loads a 16-byte PSW.
• LOAD REAL ADDRESS in its ESA/390 form and in the 24-bit or 31-bit addressing mode operates as in ESA/390 if the translation is successful and the obtained real address has a value less than 2G bytes. LOAD REAL ADDRESS in its ESA/390 form and in the 64-bit addressing mode, or in its enhanced z/Architecture form in any addressing mode, loads a 64-bit real address.
• LOAD USING REAL ADDRESS and STORE USING REAL ADDRESS are enhanced to have optionally 64-bit operands.
• SIGNAL PROCESSOR has a new order that can be used to switch all CPUs in the configuration either from the ESA/390 architectural mode to the z/Architecture architectural mode or from z/Architecture to ESA/390. (A system that is to operate using z/Architecture must first be IPLed in the ESA/390 mode.)
• STORE FACILITY LIST is a privileged instruction that stores at real location 200 an indication of whether z/Architecture is installed and of whether it is active. This instruction is added also to ESA/390 and also stores an indication of whether the new z/Architecture instructions that have been added to ESA/390 are available. Real location 200 has previously contained all zeros in most systems and normally can be examined by a problem-state program whether or not STORE FACILITY LIST is installed. The information stored at real location 200 also indicates whether the extended-translation facility 2 is installed.
• STORE REAL ADDRESS is like LOAD REAL ADDRESS except that STORE REAL ADDRESS stores the resulting address instead of placing it in a register.
• TRACE is enhanced to record optionally the contents of 64-bit general registers.

Trimodal Addressing

“Trimodal addressing” refers to the ability to switch between the 24-bit, 31-bit, and 64-bit addressing modes. This switching can be done by means of:

• The old instructions BRANCH AND SAVE AND SET MODE and BRANCH AND SET MODE. Both of these instructions set the 64-bit addressing mode if bit 63 of the R2 general register is one. If bit 63 is zero, the instructions set the 24-bit or 31-bit addressing mode if bit 32 of the register is zero or one, respectively.
• The new instruction SET ADDRESSING MODE (SAM24, SAM31, and SAM64). The instruction sets the 24-bit, 31-bit, or 64-bit addressing mode as determined by the operation code.

Modal Instructions

Trimodal addressing affects the general instructions only in the manner in which logical storage addresses are handled, except as follows.

• The instructions BRANCH AND LINK, BRANCH AND SAVE, BRANCH AND SAVE AND SET MODE, BRANCH AND SET MODE, and BRANCH RELATIVE AND SAVE place information in bit positions 32-39 of general register R1 as in ESA/390 in the 24-bit or 31-bit addressing mode or place address bits in those bit positions in the 64-bit addressing mode. The new instruction BRANCH RELATIVE AND SAVE LONG does the same.
• Certain instructions leave bits 0-31 of a general register unchanged in the 24-bit or 31-bit addressing mode but place or update address or length information in them in the 64-bit addressing mode. These are listed in programming note...
Effects on Bits 0-31 of a General Register

Bits 0-31 of general registers are changed by two types of instructions. The first type is a modal instruction (see the preceding section) when the instruction is executed in the 64-bit addressing mode. The second type is an instruction having, independent of the addressing mode, either a 64-bit result operand in a single general register or a 128-bit result operand in an even-odd general-register pair.

Most of the instructions of the second type are indicated by a “G,” either alone or in “GF,” in their mnemonics. The other instructions that change or may change bits 0-31 of a general register regardless of the current addressing mode are listed in programming note 2 on page 7-8. All of the instructions of the second type are sometimes referred to as “G-type” instructions.

If a program is not executed in the 64-bit addressing mode and does not contain a G-type instruction, it cannot change bits 0-31 of any general register.

Input/Output

Additional I/O functions and facilities are provided when z/Architecture is installed. They are provided in both the ESA/390 and the z/Architecture architectural mode and are as follows:

- Indirect data addressing is enhanced by the provision of a doubleword format-2 IDAW that is intended to allow operations on data at or above the 2G-byte absolute-address boundary in z/Architecture. The previously existing IDAW, a word containing a 31-bit address, is now called a format-1 IDAW. The format-2 IDAW contains a 64-bit address. A bit in the operation-request block (ORB) associated with a channel program specifies whether the program uses format-1 or format-2 IDAWs. A further enhancement is the ability of all format-2 IDAWs of a channel program to specify either 2K-byte or 4K-byte data blocks, as determined by another bit in the ORB. The use of 4K-byte blocks improves the efficiency of data transfers.
- The FICON®-channel facility provides the capabilities of attaching FICON-I/O-interface and FICON-converted-I/O-interface channel paths and of fully utilizing these channel-path types. FICON channel paths can significantly enhance overall data throughput by providing increased data-transfer rates in comparison to ESCON channel paths and by allowing multiple commands and associated data to be “streamed” to control units, thus further improving performance. The facility supports the following additional control mechanisms:
  - The modification-control bit in the ORB allows the program to optimize the performance of FICON channel paths when dynamically modifying channel programs.
  - The synchronization-control bit in the ORB ensures data integrity along with maximum channel-path performance by delaying the execution of a write command until the completion of an immediately preceding read command when performing unlimited prefetching of CCWs and when the data to be written may be the data read.
  - The streaming-mode-control bit in the ORB allows the program to prevent command streaming in cases that require such prevention.
  - The secondary-CCW-address field in the extended-status word assists in the recovery of channel programs that terminate abnormally when command streaming to a control unit is being performed. The field identifies a CCW that failed at the control unit.
- The ORB-extension facility expands the size of the ORB from three words to eight words. This makes fields available for use by the channel-subsystem-I/O-priority facility.
- The channel-subsystem-I/O-priority facility allows the program to establish a priority relationship among subchannels that have pending I/O operations. The priority relationship specifies the order in which I/O operations are initiated by the channel subsystem. Additionally, for fibre-channel-attached control units, the facility allows the program to specify the priority in which I/O operations pending at the control unit are performed.

The input/output enhancements are further highlighted below by describing how they affect the I/O chapters.
• In Chapter 13, “I/O Overview,” FICON and FICON-converted I/O interfaces and the frame-multiplex mode are introduced.

• In Chapter 14, “I/O Instructions”:
  – The CANCEL SUBCHANNEL instruction is described.
  – TEST PENDING INTERRUPTION, when the second-operand address is zero, stores a three-word I/O-interruption code at real locations 184-195. The new third word contains an interruption-identification word that further identifies the source of the I/O interruption.

• In Chapter 15, “Basic I/O Functions”:
  – The ORB is extended to eight words and newly contains a streaming-mode control, modification control, synchronization control, format-2-IDAW control, 2K-IDAW control, ORB-extension control, channel-subsystem priority, and control-unit priority.
  – A doubleword format-2 IDAW and 4K-byte data blocks optionally designated by format-2 IDAWs are added.

• In Chapter 16, “I/O Interruptions”:
  – A secondary-CCW-address-validity bit and failing-storage-address-format bit are added to the extended-report word.
  – A two-word failing-storage address and a secondary-CCW address are added to the format-0 extended-status word.

• In Chapter 17, “I/O Support Functions”:
  – Control-unit-defer time is added. This has an effect on the device-connect time and device-disconnect time in the measurement block.
  – References to the measurement block by the measurement-block-update facility are single-access references and appear to be word concurrent as observed by CPUs.
  – Device-active-only time is added to the measurement block.
  – The channel-subsystem-I/O-priority facility, providing channel-subsystem priority and control-unit priority, is added.

---

**Additions to z/Architecture**

z/Architecture was announced in October, 2000. Any extension added subsequently is summarized below and has the date of its announcement at the end of its summary.

**ASN-and-LX-Reuse Facility**

The *ASN-and-LX-reuse facility* may be available on a model implementing z/Architecture. The facility provides the means by which an address-space number (ASN) that is used in certain space-switching linkage instructions may be safely reused. The facility also adds a 32-bit program-call (PC) number, and it also provides the means by which the linkage index that is used in PC-number translation may be safely reused. The facility provides the following instructions:

- EXTRACT PRIMARY ASN AND INSTANCE
- EXTRACT SECONDARY ASN AND INSTANCE
- PROGRAM TRANSFER WITH INSTANCE
- SET SECONDARY ASN WITH INSTANCE

(May, 2004)

**CMPSC-Enhancement Facility**

The *CMPSC-enhancement facility* may be available on a model implementing z/Architecture. The facility provides performance improvements for the COMPRESSION CALL instruction. (August, 2010)

**Compare-and-Swap-and-Store Facility**

The *compare-and-swap-and-store facility* may be available on a model implementing z/Architecture. The facility performs compare-and-swap operations on 4- or 8-byte operands using interlocked update. If the operands are equal, a subsequent store operation of 1, 2, 4, or 8 bytes is performed. The facility provides the COMPARE AND SWAP AND STORE instruction. (April, 2007)
Compare-and-Swap-and-Store Facility 2

The compare-and-swap-and-store facility 2 may be available on a model implementing z/Architecture. The facility extends the compare-and-swap-and-store facility by providing a 16-byte compare-and-swap function and a 16-byte store operation. (February, 2008)

Conditional-SSKE Facility

The conditional-SSKE facility may be available on a model implementing z/Architecture. The facility provides performance improvements for the SET STORAGE KEY EXTENDED instruction. (April, 2007)

Configuration-Topology Facility

The configuration-topology facility may be available on a model implementing z/Architecture. The facility provides additional topology awareness to the program such that certain optimizations can be performed to improve cache hit ratios and thereby improve overall performance. The facility provides:

- The PERFORM TOPOLOGY FUNCTION (PTF) control instruction.
- A new system-information block (SYSIB 15.1.2) stored by the STORE SYSTEM INFORMATION instruction.

(February, 2008)

Constrained-Transactional-Execution Facility

The constrained-transactional-execution facility may be available on a model implementing z/Architecture. The facility ensures that in the absence of repeated interruptions or conflicts with other CPUs or the I/O subsystem – transactional execution will eventually complete; thus, an abort-handler routine is not required. The facility provides the following general instruction:

- TRANSACTION BEGIN (TBEGINC)

(September, 2012)

DAT-Enhancement Facility 1

The DAT-enhancement facility 1 may be available on a model implementing z/Architecture. The facility provides the following instructions:

- COMPARE AND SWAP AND PURGE (CSPG)
- invalidate DAT TABLE ENTRY

COMPARE AND SWAP AND PURGE (CSPG) provides function similar to that of COMPARE AND SWAP AND PURGE (CSP), but CSPG has 64-bit operands whereas CSP has 32-bit operands.

INvalidate DAT TABLE ENTRY provides the means by which one or more region-table and segment-table entries in storage may be invalidated, and the corresponding TLB entries may be purged. The instruction provides an invalidation-and-clearing operation which invalidates and clears entries based on a specified virtual address, or a clear-by-ASCE operation which clears TLB entries based on the specified ASCE. (June, 2003)

DAT-Enhancement Facility 2

The DAT-enhancement facility 2 may be available on a model implementing z/Architecture. When the DAT-enhancement facility 2 is installed, the LOAD PAGE-TABLE-ENTRY ADDRESS instruction is available. Given a virtual address, the LOAD PAGE-TABLE-ENTRY ADDRESS instruction returns the 64-bit real address of the corresponding page-table entry. The address-space-control mode used by the dynamic-address-translation process is specified in the M4 field of the instruction. (September, 2005)

Decimal-Floating-Point Facility

The decimal-floating-point facility supports three decimal-floating-point (DFP) data formats and provides 54 new instructions to operate on data in these formats. The formats: 32-bit (short), 64-bit (long), and 128-bit (extended), were developed in collaboration with the IEEE floating-point working group. (April, 2007)
Decimal-Floating-Point Packed-Conversion Facility

The decimal floating point packed-conversion facility may be available on models implementing the DFP facility. The facility includes the following instructions:

- CONVERT FROM PACKED (CDPT)
- CONVERT FROM PACKED (CXPT)
- CONVERT TO PACKED (CPDT)
- CONVERT TO PACKED (CPXT)

(March, 2015)

Decimal-Floating-Point-Rounding Facility

The decimal-floating-point-rounding facility provides a 3-bit DFP rounding mode field in the floating-point control (FPC) register, and the instruction SET DFP Rounding Mode, which may be used to set this field. The DFP rounding mode can specify any of eight rounding methods, including the five required by the IEEE floating-point working group.

The DFP rounding mode is used by PFPO and the decimal-floating-point instructions. (April, 2007)

Decimal-Floating-Point Zoned-Conversion Facility

The decimal floating point zoned-conversion facility may be available on models implementing the DFP facility. The facility includes the following features and instructions:

1. In Chapter 8, “Decimal Instructions,” the zoned format is defined to include the ASCII zone value (0011 binary).
2. In Chapter 20, “Decimal-Floating-Point Instructions,” the following instructions are defined:
   - CONVERT FROM ZONED (CDZT)
   - CONVERT FROM ZONED (CXZT)
   - CONVERT TO ZONED (CZDT)
   - CONVERT TO ZONED (CZXT)

(September, 2012)

Distinct-Operands Facility

The distinct-operands facility may be available on a model implementing z/Architecture. The facility provides alternate forms of selected arithmetic and logical instructions in which the result register may be different from either of the source registers. The facility provides alternate forms for the following instructions:

- ADD
- ADD IMMEDIATE
- ADD LOGICAL
- ADD LOGICAL WITH SIGNED IMMEDIATE
- AND
- EXCLUSIVE OR
- OR
- SHIFT LEFT SINGLE
- SHIFT LEFT SINGLE LOGICAL
- SHIFT RIGHT SINGLE
- SHIFT RIGHT SINGLE LOGICAL
- SUBTRACT
- SUBTRACT LOGICAL

(August, 2010)

Enhanced-DAT Facility 1

The enhanced-DAT facility may be available on models implementing z/Architecture. When the facility is installed and enabled, DAT translation may produce either a page-frame real address or a segment-frame absolute address, determined by the STE-format control in the segment-table entry.

When the facility is installed in a configuration, a new bit in control register 0 enables the facility.

Note: The term EDAT-1 applies is used pervasively in this document to describe the condition of when the enhanced-DAT facility 1 is installed in the configuration and enabled by control register 0. See “Enhanced-DAT Terminology:” on page 3-38 for details on this terminology.

When EDAT-1 applies, the following function is available in the DAT process:

- Region-table entries include a DAT-protection bit, providing function similar to the DAT-protection bits in the segment- and page-table entries.
The segment-table entry includes a STE-format control. When the STE-format control is zero, DAT proceeds as if EDAT-1 does not apply.

When the STE-format control is one, the segment-table entry also contains the following:

- A segment-frame absolute address (rather than a page-table origin) specifying the absolute storage location of the 1M-byte block.
- Access-control bits and a fetch-protection bit which optionally may be used instead of the corresponding bits in the segment's individual storage keys.
- A bit which determines the validity of the access-control bits and a fetch-protection bit in the segment-table entry.

The facility adds the PERFORM FRAME MANAGEMENT FUNCTION control instruction. The facility includes enhancements or changes to the following control instructions:

- LOAD PAGE-TABLE-ENTRY ADDRESS
- MOVE PAGE
- SET STORAGE KEY EXTENDED
- TEST PROTECTION

Enhanced-DAT Facility 2

The enhanced-DAT facility 2 may be available on models implementing z/Architecture. When the facility is installed and enabled, DAT translation may produce either a page-frame real address, a segment-frame absolute address, or a region-frame absolute address, determined by format controls in the region-third-table entry (if any) and the segment-table entry (if any).

Note: The term EDAT-2 applies is used pervasively in this document to describe the condition of when the enhanced-DAT facility 2 is installed in the configuration and enabled by control register 0. See “Enhanced-DAT Terminology:” on page 3-38 for details on this terminology.

When EDAT-2 applies, the following function is available in the DAT process:

- EDAT-1 applies.
- The region-third-table entry includes a RTTE-format control. When the RTTE-format control is zero, DAT proceeds as is the case for when EDAT-1 applies.
- When the RTTE-format control is one, the region-third-table entry also contains the following:
  - A region-frame absolute address (rather than a segment-table origin) specifying the absolute storage location of the 2 G-byte block.
  - Access-control bits and a fetch-protection bit which optionally may be used in lieu of the corresponding bits in the region's individual storage keys.
  - A bit which determines the validity of the access-control bits and a fetch-protection bit in the region-third-table entry.

The enhanced-DAT facility 2 adds the COMPARE AND REPLACE DAT TABLE entry instruction, providing for the dynamic replacement of valid, attached DAT-table entries, and the selective clearing of any TLB entries created from the replaced entry.

The enhanced-DAT facility 2 also includes enhancements or changes to the following control instructions:

- INVALIDATE DAT TABLE ENTRY
- LOAD PAGE-TABLE-ENTRY ADDRESS
- MOVE PAGE
- PERFORM FRAME MANAGEMENT FUNCTION
- TEST PROTECTION

When the enhanced-DAT facility 2 is installed, the enhanced-DAT facility 1 is also installed. (September, 2012)

Enhanced-Monitor Facility

The enhanced-monitor facility may be available on a model implementing z/Architecture. The facility provides the means by which executions of the MONITOR CALL instruction may be counted in CPU-specific counter arrays where each entry in the array represents a different monitor code.

The enhanced-monitor facility is controlled by the enhanced-monitor masks in control register 8. The
enhanced-monitor masks work in conjunction with the monitor masks in CR8. Existing programs that use the MONITOR CALL instruction continue to operate compatibly when the enhanced-monitor masks are zero; the enhanced counting operation is only provided when a monitor mask bit and its corresponding enhanced-monitor mask bit are both ones. (August, 2010)

ETF2-Enhancement Facility

The ETF2-enhancement facility may be available on a model implementing z/Architecture. The facility includes modifications to the following instructions:

- New function is added to the TRANSLATE ONE TO ONE, TRANSLATE ONE TO TWO, TRANSLATE TWO TO ONE, and TRANSLATE TWO TO TWO instructions, allowing the test-character comparison to be bypassed.
- For TRANSLATE TWO TO ONE and TRANSLATE TWO TO TWO, the alignment requirements for the translate table are relaxed.

(September, 2005)

ETF3-Enhancement Facility

The ETF3-enhancement facility may be available on a model implementing z/Architecture. The facility provides improved well-formedness checking for the following instructions:

- CONVERT UTF-16 TO UTF-32
- CONVERT UTF-16 TO UTF-8
- CONVERT UTF-8 TO UTF-16
- CONVERT UTF-8 TO UTF-32

(September, 2005)

Execute-Extensions Facility

The execute-extensions facility may be available on a model implementing z/Architecture. The facility provides the EXECUTE RELATIVE LONG instruction. (February, 2008)

Execution-Hint Facility

The execution-hint facility may be available on a model implementing z/Architecture. The facility provides the means by which the program can provide hints which the CPU may take into consideration when deciding what information to maintain and use for storage-operand accesses and branch prediction. The facility provides the following instructions:

- BRANCH PREDICTION PRELOAD (BPP)
- BRANCH PREDICTION RELATIVE PRELOAD (BPRP)
- NEXT INSTRUCTION ACCESS INTENT (NIAI)

Additionally, new prefetch-intent codes are defined for PREFETCH DATA (PFD) and PREFETCH DATA RELATIVE LONG (PFDRL). (September, 2012)

Extended-Immediate Facility

The extended-immediate facility may be available on models implementing z/Architecture. The facility provides 32-bit immediate-operand versions of the following instructions:

- ADD IMMEDIATE
- ADD LOGICAL IMMEDIATE
- AND IMMEDIATE
- COMPARE IMMEDIATE
- COMPARE LOGICAL IMMEDIATE
- EXCLUSIVE OR IMMEDIATE
- INSERT IMMEDIATE
- LOAD IMMEDIATE
- LOAD LOGICAL IMMEDIATE
- OR IMMEDIATE
- SUBTRACT LOGICAL IMMEDIATE

Other new instructions added as a part of the extended-immediate facility include the following:

- FIND LEFTMOST ONE
- LOAD AND TEST (32-bit and 64-bit RXY format)
- LOAD BYTE (RRE format)
- LOAD HALFWORD (RRE format)
- LOAD LOGICAL CHARACTER (64-bit RRE format, and 32-bit RXY and RRE formats)
- LOAD LOGICAL HALFWORD (64-bit RRE format, and 32-bit RXY and RRE formats)

(September, 2005)
Extended-I/O-Measurement-Block Facility

The extended-I/O-measurement-block facility may be available on models implementing z/Architecture. The facility includes the following features:

- A new format of the channel-measurement block. The new measurement block, termed a format-1 channel-measurement block, is expanded to 64 bytes and is addressed using a separate measurement-block address for each subchannel. The new measurement-block format provides additional measurement information and the flexibility to store the measurement blocks in non-contiguous, real storage.

- The previously existing channel-measurement block is termed a format-0 channel-measurement block. A device-busy-time field is added to the format-0 channel-measurement block.

(June, 2003)

Extended-I/O-Measurement-Word Facility

The extended-I/O-measurement-word facility may be available on models implementing z/Architecture. The extended-measurement-word (EMW) is an extension to the interruption-response block (IRB) and allows channel-measurement data to be provided on an I/O operation basis. This reduces program overhead by alleviating the previous requirement that the program fetch the measurement block before and after an operation and calculate the difference between the respective measurement data values. (June, 2003)

Extended-Translation Facility 2

The extended-translation facility 2 may be available on a model implementing z/Architecture. The facility performs operations on double-byte, ASCII, and decimal data. The double-byte data may be Unicode® data – that is, data that uses the binary codes of the Unicode Worldwide Character Standard and enables the use of characters of most of the world’s written languages. The facility provides the following instructions:

- COMPARE LOGICAL LONG UNICODE
- MOVE LONG UNICODE
- PACK ASCII
- PACK UNICODE
- TEST DECIMAL
- TRANSLATE ONE TO ONE
- TRANSLATE ONE TO TWO
- TRANSLATE TWO TO ONE
- TRANSLATE TWO TO TWO
- UNPACK ASCII
- UNPACK UNICODE

The extended-translation facility 2 is called facility 2 since an extended-translation facility, now called facility 1, was introduced in ESA/390. Facility 1 is standard in z/Architecture. Facility 1 provides the instructions:

- CONVERT UNICODE TO UTF-8
- CONVERT UTF-8 TO UNICODE
- TRANSLATE EXTENDED

For when either or both of facility 1 and facility 2 are not installed on the machine, both facilities are simulated by the MVS CSRUNIC macro instruction, which is provided in OS/390® Release 10 and z/OS®.

OS/390 MVS Assembler Services Reference, GC28-1910-10, contains programming requirements, register information, syntax, return codes, and examples for the CSRUNIC macro instruction.

When CSRUNIC is used, the program exceptions listed in this publication do not cause program interruptions; instead, the exception conditions are indicated by CSRUNIC by means of return codes, as described in GC28-1910-10. (October, 2000)

Extended-Translation Facility 3

The extended-translation facility 3 may be available on a model implementing z/Architecture. The facility performs operations on Unicode and Unicode-transformation-format (UTF) characters; it also includes a right-to-left TRANSLATE AND TEST operation. The facility provides the following instructions:

- CONVERT UTF-16 TO UTF-32
- CONVERT UTF-32 TO UTF-16
- CONVERT UTF-32 TO UTF-8
- CONVERT UTF-8 TO UTF-32
- SEARCH STRING UNICODE
- TRANSLATE AND TEST REVERSE
Extract-CPU-Time Facility

The extract-CPU-time facility may be available on a model implementing z/Architecture. The facility adds the general instruction EXTRACT CPU TIME. This instruction provides an efficient means by which a problem-state program can determine the amount of CPU time consumed, without requiring a supervisor-state service routine. (April, 2007)

Fast-BCR-Serialization Facility

The fast-BCR-serialization facility may be available on a model implementing z/Architecture. When the facility is installed, the execution of BRANCH ON CONDITION with the M1 field containing 1110 binary and the R2 field containing 0000 binary causes serialization without checkpoint synchronization. (August, 2010)

Fibre-Channel Extensions (FCX)

The fibre-channel-extensions (FCX) facility may be available on models implementing z/Architecture. The facility includes enhancements and performance extensions that provide the program a means to transport lists of commands to an I/O device for processing without the channel overhead of fetching and decoding each command.

Use of the FCX facility may be restricted to devices accessible by certain channel path types.

The FCX facility includes the following:

- Changes to the operation-request block (ORB), interruption-response block (IRB), and subchannel-information block (SCHIB).
- A form of a channel program that consists of a transport-control word (TCW) that designates a transport-command-control block (TCCB) and transport-status block (TSB). The TCCB includes a transport-command area (TCA) which contains a list of up to 30 I/O commands that are in the form of device-command words (DCWs). The TSB contains completion status and other information related to the TCW channel program that is complementary to the completion information contained in the IRB.
- A TCW may specify the transfer of either input data or output data.
- The ability to directly or indirectly designate any or all of the TCCB, the input data storage area, and the output data storage area. When a storage area is designated directly, the TCW specifies the location of a single, contiguous block of storage. When a storage area is designated indirectly, the TCW designates the location of a list of one or more transport-indirect-data-address words (TIDAWs). TIDAW lists and the storage area designated by each TIDAW in a list are restricted from crossing 4K-byte boundaries.
- An interrogate operation which may be initiated by CANCEL SUBCHANNEL to determine the state of an I/O operation.

FCX-Bidirectional-Data-Transfer Facility

The FCX-bidirectional-data-transfer facility may be available on a model implementing fibre-channel extensions. When the facility is installed and an attached device supports bidirectional-data transfer, transport-mode channel programs may specify the transfer of both input and output data. (September, 2012)

Floating-Point Extension Facility

The floating-point extension facility may be available on models implementing the DFP facility. The extension includes the following features and instructions:

Additions to Chapter 9, “Floating-Point Overview and Support Instructions:”

- A new floating-point-support instruction, SET BFP Rounding Mode (SRNMB), is added.
- A new exception, the quantum exception, is defined for DFP computational operations.
- Bit 5 of the floating-point-control (FPC) register is assigned to the quantum-exception mask.
- Bit 13 of the FPC register is assigned to the quantum-exception flag.
- Data-exception code (DXC) 04 (hex) is assigned to the quantum exception.
• DXC 07 (hex) is assigned to the simulated quantum exception.
• The BFP-rounding-mode field in the FPC register is changed to 3 bits to support one additional BFP rounding mode, round to prepare for shorter precision.
• One new value of the effective rounding method field is assigned to support the round to prepare for shorter precision rounding method for CONVERT HFP TO BFP.
• For PFPO with a DFP result, bit 58 of general register 0 is assigned to be the DFP quantum-permission control.

Additions to Chapter 19, “Binary-Floating-Point Instructions:”

• The following new BFP instructions are added:
  – CONVERT FROM LOGICAL (CXLFBR, CDLFBR, CELFBR, CXLGBR, CDLGBR, and CELGBR).
  – CONVERT TO LOGICAL (CLFXBR, CLFDBR, CLFEBR, CLGXBR, CLGDBR, and CLGEBR).
• One new value of the effective rounding method field is assigned to support the round to prepare for shorter precision rounding method for CONVERT TO FIXED, DIVIDE TO INTEGER, and LOAD FP INTEGER.
• An IEEE-inexact-exception control (XxC) is added to CONVERT TO FIXED and LOAD FP INTEGER.
• An effective rounding method field and an IEEE-inexact-exception control (XxC) are added to CONVERT FROM FIXED and LOAD ROUNDED.

Additions to Chapter 20, “Decimal-Floating-Point Instructions:”

• The following new DFP instructions are added:
  – CONVERT FROM FIXED (CXFR, CDFTR)
  – CONVERT FROM LOGICAL (CXLGTR, CDLGTR, CXLFT, CDLFT)
  – CONVERT TO FIXED (CFXTR, CFDTR)
  – CONVERT TO LOGICAL (CLGXTR, CLGTRT, CLFXTR, CLFTDR)
• All reserved values in the effective rounding method field and a quantum-exception control (XqC) are assigned for LOAD FP INTEGER, LOAD ROUNDED, QUANTIZE, and REROUND.
• All reserved values in the effective rounding method field are assigned for CONVERT TO FIXED.

• An IEEE-inexact-exception control (XxC) is added to CONVERT TO FIXED and LOAD ROUNDED.
• An effective rounding method field and a quantum-exception control (XqC) are added to ADD, DIVIDE, MULTIPLY, and SUBTRACT.
• An effective rounding method field, an IEEE-inexact-exception control (XxC), and a quantum-exception control (XqC) are added to CONVERT FROM FIXED.

(August, 2010).

Floating-Point-Support-Sign-Handling Facility

The floating-point-support-sign-handling facility includes four instructions: COPY SIGN, LOAD COMPLEMENT, LOAD NEGATIVE, and LOAD POSITIVE. These instructions operate on a 64-bit (long) floating-point datum independent of the radix and do not set the condition code. (April, 2007)

FPR-GR-Transfer Facility

The FPR-GR-transfer facility includes the following two instructions:

• LOAD FPR FROM GR
• LOAD GR FROM FPR

These instructions provide the means to move a 64-bit (long) floating-point datum between a floating-point register and a general register. (April, 2007)

General-Instructions-Extension Facility

The general-instructions-extension facility may be available on a model implementing z/Architecture. The facility provides the following new instructions:

• ADD LOGICAL WITH SIGNED IMMEDIATE
• COMPARE AND BRANCH
• COMPARE AND BRANCH RELATIVE
• COMPARE AND TRAP
• COMPARE HALFWORD RELATIVE LONG
• COMPARE IMMEDIATE AND BRANCH
• COMPARE IMMEDIATE AND BRANCH RELATIVE
• COMPARE IMMEDIATE AND TRAP
• COMPARE LOGICAL AND BRANCH
• COMPARE LOGICAL AND BRANCH RELATIVE
• COMPARE LOGICAL AND TRAP
• COMPARE LOGICAL IMMEDIATE AND BRANCH
• COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE
• COMPARE LOGICAL IMMEDIATE AND TRAP
• COMPARE LOGICAL RELATIVE LONG
• COMPARE RELATIVE LONG
• EXTRACT CPU ATTRIBUTE
• LOAD HALFWORD RELATIVE LONG
• LOAD LOGICAL HALFWORD RELATIVE LONG
• LOAD LOGICAL RELATIVE LONG
• LOAD RELATIVE LONG
• MULTIPLY SINGLE IMMEDIATE
• PREFETCH DATA
• PREFETCH DATA RELATIVE LONG
• ROTATE THEN AND SELECTED BITS
• ROTATE THEN EXCLUSIVE OR SELECTED BITS
• ROTATE THEN INSERT SELECTED BITS
• ROTATE THEN OR SELECTED BITS
• STORE HALFWORD RELATIVE LONG
• STORE RELATIVE LONG

Additionally, the following instructions have been enhanced to include additional formats:

• ADD IMMEDIATE
• COMPARE HALFWORD
• COMPARE HALFWORD IMMEDIATE
• COMPARE LOGICAL IMMEDIATE
• LOAD ADDRESS EXTENDED
• LOAD AND TEST
• MOVE
• MULTIPLY
• MULTIPLY HALFWORD

(High-Word Facility)

The high-word facility may be available on a model implementing z/Architecture. For selected 32-bit instructions, the high-word facility effectively provides sixteen additional 32-bit registers by utilizing bits 0-31 of the sixteen 64-bit general registers. The facility provides the following instructions:

• ADD HIGH
• ADD IMMEDIATE HIGH
• ADD LOGICAL HIGH
• ADD LOGICAL WITH SIGNED IMMEDIATE HIGH
• BRANCH RELATIVE ON COUNT HIGH
• COMPARE HIGH
• COMPARE IMMEDIATE HIGH
• COMPARE LOGICAL HIGH
• COMPARE LOGICAL IMMEDIATE HIGH
• LOAD BYTE HIGH
• LOAD HALFWORD HIGH
• LOAD HIGH
• LOAD LOGICAL CHARACTER HIGH
• LOAD LOGICAL HALFWORD HIGH
• ROTATE THEN INSERT SELECTED BITS HIGH
• ROTATE THEN INSERT SELECTED BITS LOW
• STORE CHARACTER HIGH
• STORE HALFWORD HIGH
• SUBTRACT HIGH
• SUBTRACT LOGICAL HIGH

(HFP-Unnormalized-Extensions Facility)

The HFP-unnormalized-extension facility may be available on a model implementing z/Architecture. The facility provides instructions for improved processing of unnormalized hexadecimal floating-point numbers. It extends the capabilities of the HFP-multiply-and-add/subtract facility, by providing the following instructions that operate on unnormalized operands:

• MULTIPLY UNNORMALIZED
• MULTIPLY AND ADD UNNORMALIZED

(HFP Multiply-and-Add/Subtract Facility)

The HFP-multiply-and-add/subtract facility provides instructions for improved processing of hexadecimal floating-point numbers. The MULTIPLY AND ADD (or SUBTRACT) instruction is intended to be used in place of MULTIPLY followed by ADD (or SUBTRACT) NORMALIZED. (June, 2003)
IEEE-Exception-Simulation Facility

The IEEE-exception-simulation facility includes the instructions SET FPC AND SIGNAL and LOAD FPC AND SIGNAL. These instructions provide a means to simulate a data exception program interruption. (April, 2007)

Interlocked-Access Facility 1

The interlocked-access facility 1 may be available on a model implementing z/Architecture. The facility provides the means by which a load, update, and store operation can be performed with interlocked update in a single instruction (as opposed to using a compare-and-swap type of update). The facility also provides an instruction to attempt to load from two distinct storage locations in an interlocked-fetch manner. The facility provides the following instructions.

- LOAD AND ADD
- LOAD AND ADD LOGICAL
- LOAD AND AND
- LOAD AND EXCLUSIVE OR
- LOAD AND OR
- LOAD PAIR DISJOINT

Additionally, when the interlocked-access facility 1 is installed, the storage-operand update reference for the following instructions appears to be an interlocked-update reference as observed by other CPUs and channel programs when the first operand is aligned on an integral boundary corresponding to its size:

- ADD IMMEDIATE (ASI and AGSI)
- ADD LOGICAL WITH SIGNED IMMEDIATE

(August, 2010)

Interlocked-Access Facility 2

The interlocked-access facility 2 may be available on a model. When installed, the storage-operand update reference for the following instructions appears to be an interlocked-update as observed by other CPUs and channel programs.

- AND (NI, NIY)
- OR (OI, OIY)
- EXCLUSIVE OR (XI, XIY)

(September, 2012)

IPTE-Range Facility

The IPTE-range facility may be available on a model implementing z/Architecture. The facility provides performance improvements for the INVALIDATE PAGE TABLE ENTRY instruction. (August, 2010)

List-Directed Initial Program Load

The list-directed initial-program-load (IPL) function may be available on a model. List-directed IPL, also known as SCSI IPL in other System Library publications, provides the means by which a program can be loaded from an I/O device other than a classical channel-attached device (ESCON or FICON). Facilities are also provided for loading a stand-alone dump program using list-directed IPL. (May, 2004)

Load-and-Trap Facility

The load-and-trap facility may be available on a model implementing z/Architecture. The facility adds instructions that can be used to assist the program in determining when a value of all zeros (an address for example) has been loaded into a designated register. The facility provides the following instructions:

- LOAD AND TRAP (LAT and LGAT)
- LOAD HIGH AND TRAP (LFHAT)
- LOAD LOGICAL AND TRAP (LLGFAT)
- LOAD LOGICAL THIRTY ONE BITS AND TRAP (LLGTAT)

(August, 2010)

Load-and-Zero-Rightmost-Byte Facility

The load-and-zero-rightmost-byte facility may be available on a model implementing z/Architecture. The facility instructions of the facility load a value into a register from storage and zero the rightmost eight bits of the register. The facility provides the following instructions:

- LOAD AND ZERO RIGHTMOST BYTE (LZRF, LZRG)

(September, 2012)
• LOAD LOGICAL AND ZERO RIGHTMOST BYTE (LZRGF)

(March, 2015)

Load/Store-on-Condition Facility 1

The load/store-on-condition facility 1 may be available on a model implementing z/Architecture. The facility provides the means by which selected operations may be executed only when a condition-code-mask field of the instruction matches the current condition code in the PSW. The facility provides the following instructions.

• LOAD ON CONDITION
• STORE ON CONDITION

(August, 2010)

Load/Store-on-Condition Facility 2

The load/store-on-condition facility 2 may be available on a model implementing z/Architecture. The facility provides six load-immediate operations, two load-high operations, and one store-high operation; all of which are executed only when a condition-code-mask field of the instruction matches the current condition code in the PSW. The facility includes the following instructions.

• LOAD HALFWORD HIGH IMMEDIATE ON CONDITION (LOCHHI)
• LOAD HALFWORD IMMEDIATE ON CONDITION (LOCHI, LOCACHI)
• LOAD HIGH ON CONDITION (LOCFHR, LOCFH)
• STORE HIGH ON CONDITION (STOCFH)

(March, 2015)

Local-TLB-Clearing Facility

The local-TLB-clearing facility may be available on a model implementing z/Architecture. The facility may provide performance improvements for the INVALIDATE DAT TABLE ENTRY and INVALIDATE PAGE TABLE ENTRY instructions by allowing the program to specify whether TLB clearing should be done in all CPUs of the configuration or only in the CPU executing the instruction.

(Long-Displacement Facility

The long-displacement facility provides a 20-bit signed-displacement field in 69 previously existing instructions (by using a previously unused byte in the instructions) and 44 new instructions. A 20-bit signed displacement allows relative addressing of up to 524,287 bytes beyond the location designated by a base register or base-and-index-register pair and up to 524,288 bytes before that location. The enhanced previously existing instructions generally are ones that handle 64-bit binary integers. The new instructions generally are new versions of instructions for 32-bit binary integers. The new instructions also include (1) a LOAD BYTE instruction that sign-extends a byte from storage to form a 32-bit or 64-bit result in a general register and (2) new floating-point LOAD and STORE instructions. The long-displacement facility provides register-constraint relief by reducing the need for base registers, code size reduction by allowing fewer instructions to be used, and additional improved performance through removal of possible address-generation interlocks.

(June, 2003)

Message-Security Assist

The message-security assist (MSA) may be available on a model implementing z/Architecture. The MSA basic facility includes the following instructions:

• CIPHER MESSAGE
• CIPHER MESSAGE WITH CHAINING
• COMPUTE INTERMEDIATE MESSAGE DIGEST
• COMPUTE LAST MESSAGE DIGEST
• COMPUTE MESSAGE AUTHENTICATION CODE

Also included are five query functions and two functions for generating a message digest based on the secure-hash algorithm (SHA-1). The five query functions, one for each instruction, are used to determine the additional installed MSA facilities, which may include the following.

MSA Data-Encryption-Algorithm (DEA) Facility:

The MSA DEA facility consists of nine functions for ciphering messages, with or without chaining, and for generating a message-authentication code (MAC)
using a 56-bit, 112-bit, or 168-bit cryptographic key. All of these functions are based on the DEA algorithm. (June, 2003)

Message-Security-Assist Extension 1

The message-security-assist extension 1 may be available on models implementing the message-security assist. The extension provides the following functions:

MSA SHA-256 Facility: This facility consists of two functions, one for generating an intermediate message digest and another for generating a final message digest.

MSA Advanced-Encryption-Standard (AES-128) Facility: This facility consists of two functions for ciphering messages, with or without chaining, using the AES-128 algorithm.

MSA Pseudo-Random-Number Generation (PRNG) Facility: This facility consists of a function for generating a multiple of 64-bit pseudo-random numbers using the ANSI® X9.17 pseudo-random-number algorithm. (September, 2005)

Message-Security-Assist Extension 2

The message-security-assist extension 2 may be available on models implementing the message-security assist. The extension provides the following functions:

MSA AES-192 Facility: This facility consists of two functions for ciphering a message, with or without chaining, using the AES-192 algorithm.

MSA AES-256 Facility: This facility consists of two functions for ciphering a message, with or without chaining, using the AES-256 algorithm.

MSA SHA-512 Facility: This facility consists of two functions, one for generating an intermediate message digest and another for generating a final message digest, using the SHA-512 algorithm. (February, 2008)

Message-Security-Assist Extension 3

The message-security-assist extension 3 provides a means to protect user cryptographic keys by encrypting them under machine-generated wrapping keys. When this extension is installed, two wrapping keys are provided for each configuration: one for protecting user DEA keys and another for protecting user AES keys. The wrapping keys reside in the machine so that, with an appropriate setting of controls, no clear value of user cryptographic keys is observed anywhere in the system by any program.

The message-security-assist extension 3 may be available on models implementing the message-security assist. The extension provides the following features:

- A 256-Bit AES Wrapping-Key Register: The register contents are used to protect user AES keys.
- A 256-Bit AES Wrapping-Key Verification-Pattern Register: The register contents are used to identify the version of the AES wrapping key.
- A 192-Bit DEA Wrapping-Key Register: The register contents are used to protect user DEA keys.
- A 192-Bit DEA Wrapping-Key Verification-Pattern Register: The register contents are used to identify the version of the DEA wrapping key.
- The following functions under the CIPHER MESSAGE instruction:
  - Encrypted DEA
  - Encrypted TDEA 128
  - Encrypted TDEA 192
  - Encrypted AES 128
  - Encrypted AES 192
  - Encrypted AES 256

These functions use an encrypted cryptographic key.

---

1. These key lengths reflect the cryptographic strength. In subsequent chapters, they are referred to as 64-bit, 128-bit, or 192-bit, respectively, to include the DEA-key-parity bits.
The following functions under the CIPHER MESSAGE WITH CHAINING instruction:

- Encrypted DEA
- Encrypted TDEA 128
- Encrypted TDEA 192
- Encrypted AES 128
- Encrypted AES 192
- Encrypted AES 256

These functions use an encrypted cryptographic key.

The following functions under the COMPUTE MESSAGE AUTHENTICATION CODE instruction:

- Encrypted DEA
- Encrypted TDEA 128
- Encrypted TDEA 192

These functions use an encrypted cryptographic key.

The PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION instruction with the following functions:

- Query
- Encrypt DEA Key
- Encrypt TDEA 128 Key
- Encrypt TDEA 192 Key
- Encrypt AES 128 Key
- Encrypt AES 192 Key
- Encrypt AES 256 Key

These functions provide a means for importing clear cryptographic keys.

(August, 2010)

**Message-Security-Assist Extension 4**

The message-security-assist extension 4 provides the support for the CFB (cipher feedback) mode, the OFB (output feedback) mode, and the CTR (counter) mode. In addition, a number of primitives are provided to facilitate the support for the CMAC (cipher-based message authentication code) mode, the CCM (counter with cipher block chaining – message authentication code) mode, the GCM (Galois/counter mode), and the XTS mode.

The message-security-assist extension 4 may be available on models implementing the message-security assist. The extension provides the following instructions and functions:

- The CIPHER MESSAGE WITH CIPHER FEEDBACK, CIPHER MESSAGE WITH OUTPUT COUNTER, and CIPHER MESSAGE WITH OUTPUT FEEDBACK instructions. Each of these instructions includes the following functions:
  - Query
  - DEA
  - TDEA 128
  - TDEA 192
  - Encrypted DEA
  - Encrypted TDEA 128
  - Encrypted TDEA 192
  - AES 128
  - AES 192
  - AES 256
  - Encrypted AES 128
  - Encrypted AES 192
  - Encrypted AES 256

- The PERFORM CRYPTOGRAPHIC COMPUTATION instruction with the following functions:
  - Query
  - Compute Last Block CMAC Using DEA
  - Compute Last Block CMAC Using TDEA 128
  - Compute Last Block CMAC Using TDEA 192
  - Compute Last Block CMAC Using Encrypted DEA
  - Compute Last Block CMAC Using Encrypted TDEA 128
  - Compute Last Block CMAC Using Encrypted TDEA 192
  - Compute Last Block CMAC Using AES 128
  - Compute Last Block CMAC Using AES 192
  - Compute Last Block CMAC Using AES 256
  - Compute Last Block CMAC Using Encrypted AES 128
  - Compute Last Block CMAC Using Encrypted AES 192
  - Compute Last Block CMAC Using Encrypted AES 256
  - Compute XTS Parameter Using AES 128
  - Compute XTS Parameter Using AES 256
  - Compute XTS Parameter Using Encrypted AES 128
  - Compute XTS Parameter Using Encrypted AES 256
• The following functions under the CIPHER MESSAGE instruction:
  • XTS AES 128
  • XTS AES 256
  • XTS Encrypted AES 128
  • XTS Encrypted AES 256
• The following function under the COMPUTE INTERMEDIATE MESSAGE DIGEST instruction:
  • GHASH
• The following functions under the COMPUTE MESSAGE AUTHENTICATION CODE instruction:
  • AES 128
  • AES 192
  • AES 256
  • Encrypted AES 128
  • Encrypted AES 192
  • Encrypted AES 256

The message-security-assist extension 4 requires the message-security-assist extension 3 as a prerequisite. (August, 2010)

Message-Security-Assist Extension 5

The message-security-assist extension 5 provides support for deterministic pseudorandom-number seeding and generation that conforms to the National Institute of Standards and Technology (NIST) special publication 800-90A. The message-security-assist extension 5 may be available on models implementing the z/Architecture architectural mode. The extension provides the following instruction:

• PERFORM PSEUDORANDOM NUMBER OPERATION (PPNO)

The PERFORM PSEUDORANDOM NUMBER OPERATION instruction provides the following functions:

• PPNO-Query
• PPNO-SHA-512-DRNG

The message-security-assist extension 5 requires the secure-hash-algorithm (SHA-512) capabilities of the message-security-assist extension 2 as a prerequisite. (March, 2015)

Miscellaneous-Instruction-Extensions Facility

The miscellaneous-instruction-extensions facility may be available on a model implementing the z/Architecture. The facility provides additional instruction formats for the following instructions:

• COMPARE LOGICAL AND TRAP (CLT and CLGT)
• ROTATE THEN INSERT SELECTED BITS (RISBGN)

(September, 2012)

Modified CCW Indirect Data Addressing Facility

The modified-ccw-indirect-data-addressing (MIDA) facility may be available on models implementing z/Architecture and provides the program an alternate means to transfer large amounts of data that spans noncontiguous blocks in main storage without the overhead of data chaining and without the strict boundary and count restrictions imposed by CCW indirect data addressing (IDA). Modified CCW indirect data addressing permits a single channel-command word to control the transfer of up to 65,535 bytes of data that spans noncontiguous blocks in main storage. Each block of main storage to be transferred may be specified on any boundary and length up to 4K bytes, provided the specified block does not cross a 4K-byte boundary.

Use of modified CCW indirect data addressing may be restricted to devices accessible by certain channel-path types.

When modified CCW indirect data addressing is used, the CCW data address is not used to directly address data. Instead, the address points to a contiguous list of up to 256 quadwords called the modified-indirect-data-address list (MIDAL). Each quadword in the MIDAL is called a modified-indirect-data-address word (MIDAW) that describes a block of storage to be transferred and contains flags, a byte count, and a 64-bit address designating a data area in absolute storage. When modified CCW indirect data addressing is used, transfer of control from one MIDAW to the next is made when the count of bytes specified by the MIDAW count field has been transferred and the total count of bytes transferred does not yet equal the
count specified by the CCW. This is dissimilar to indirect data addressing where the transfer of control from one IDAW to the next is made when a program-specified 2K or 4K boundary is reached and the total count of bytes transferred does not yet equal the count specified in the CCW.

In addition to the MIDAW, the ORB modified-CCW-indirect-data-addressing-control bit and the CCW modified-indirect-data-address flag are added. (September, 2005)

**Move-With-Optional-Specifications Facility**

The move-with-optional-specifications facility may be available on a model implementing z/Architecture. The facility adds the semiprivileged MOVE WITH OPTIONAL SPECIFICATIONS instruction. This instruction provides the means of moving from a source operand to a destination operand using different address-space-control modes and different keys for each operand. (February, 2008)

**Multiple-Subchannel-Set Facility**

The multiple-subchannel-set (MSS) facility may be available on a model implementing z/Architecture and increases the maximum number of subchannels that can be configured to a program. When the MSS facility is not installed, a single set of subchannels, in the range 0-65,535, may be provided. When the MSS facility is installed, a maximum of four sets of subchannels may be provided for a program. Each subchannel set provides from one to 64K subchannels in the range 0 to 65,535. (February, 2008)

**Multithreading Facility**

The multithreading (MT) facility may be available on models implementing z/Architecture. The facility provides the means by which more efficient utilization of a configuration’s resources may be realized. The facility introduces the architectural concept of a core, which, when multithreading is enabled, comprises a group of CPUs (sometimes called threads). The CPU comprises all of the architected resources available to the program such as the program-status word, registers, timing facilities, and so forth. When the multithreading facility is not enabled, a core consists of a single CPU.

When the multithreading facility is enabled, the CPUs within a core may share certain hardware resources such as execution units or caches. When one CPU in a core is waiting for other hardware resources (typically, while waiting for a storage access), other CPUs in the core can utilize the shared resources in the core rather than have them remain idle. (March, 2015)

**Nonquiescing Key-Setting Facility**

The nonquiescing key-setting facility may be available on a model implementing z/Architecture. The facility provides performance improvements for the PERFORM FRAME MANAGEMENT FUNCTION and SET STORAGE KEY EXTENDED instruction. (August, 2010)

**Parsing-Enhancement Facility**

The parsing-enhancement facility may be available on a model implementing z/Architecture. The facility adds the following instructions:

- **TRANSLATE AND TEST EXTENDED**
- **TRANSLATE AND TEST REVERSE EXTENDED**

These instructions perform functions similar to those of the TRANSLATE AND TEST and TRANSLATE AND TEST REVERSE instructions, respectively, but provide the capability of processing either single-byte or double-byte argument characters, returning either 8-bit or 16-bit function codes. (February, 2008)

**PER-3 Facility**

The PER-3 facility may be available on a model implementing z/Architecture. When the facility is installed, the following two functions are available for use by the program:

**Breaking-Event Address Register:** The breaking-event-address register is a 64-bit CPU register that is updated with the address of any instruction that causes a break in sequential instruction execution (that is, the instruction address in the PSW is replaced, rather than incremented by the length of the instruction). When the PER-3 facility is installed and a program interruption occurs, whether or not PER is indicated, the contents of the breaking-event-
address register are stored in real storage locations 272-279. This can be used as a debugging assist for wild-branch detection.

**PER Instruction-Fetching Nullification:** Bit 39 of control register 9, when one, specifies that PER instruction-fetching events force nullification. Bit 39 of control register 9 is meaningful only when bit 33 of control register 9, the instruction-fetching PER-event mask, is also one. When the PER-3 facility is not installed, or when bit 39 of control register 9 is zero, nullification is not forced for PER instruction-fetching events (called a PER instruction-fetching basic event).

(September, 2005)

**PER Zero-Address-Detection Facility**

The **PER zero-address-detection facility** may be available on a model implementing z/Architecture. When the facility is installed and enabled, a PER zero-address-detection event is caused by execution of an instruction that accesses storage using an operand address formed from a general register containing zero.

(August, 2010)

**PFPO Facility**

The **PFPO facility** provides the instruction **PERFORM FLOATING-POINT OPERATION.** This instruction, designed for future expansion, currently provides 54 conversion functions (from any of nine floating-point data formats to any of the six formats in another floating-point radix) using any of eight rounding methods. All conversions are correctly rounded.

(April, 2007)

**Population-Count Facility**

The **population-count facility** may be available on a model implementing z/Architecture. The facility provides the **POPULATION COUNT instruction** which provides a count of one bits in each byte of a general register.

(August, 2010)

**Processor-Assist Facility**

The **processor-assist facility** may be available on a model implementing z/Architecture. The facility provides the means by which the program can request that the processor perform an assist function. The program specifies which assist function is to be performed in an immediate (M3) field of the instruction.

The facility provides the following general instruction:

- **PERFORM PROCESSOR ASSIST**

The processor-assist functions provided include the following:

- Transaction-abort assist

(September, 2012)

**Reset-Reference-Bits-Multiple Facility**

The **reset-reference-bits-multiple facility** may be available on a model implementing z/Architecture. The facility provides performance improvements for the inspection and resetting of reference bits by means of the **RESET REFERENCE BITS MULTIPLE instruction.** (August, 2010)

**Restore-Subchannel Facility**

The **restore-subchannel facility** may be available on a model implementing z/Architecture. The facility provides the means for the channel subsystem to recover a damaged subchannel and report the recovery to the program by means of a **CRW.** (February, 2008)

**Server-Time-Protocol Facility:**

The **server-time-protocol facility** may be available on a model implementing z/Architecture. The facility provides the means by which the time-of-day (TOD) clocks in various systems can be synchronized using message links. STP operates in conjunction with the **TOD-clock-steering facility,** providing a new timing mode, new timing states, a new **STP-timing-alert**
external interruption, and a new STP-sync-check machine-check conditions. (September, 2005)

**Store-Clock-Fast Facility**

The *store-clock-fast facility* may be available on a model implementing z/Architecture. The facility provides a means by which an eight-byte time-of-day clock value may be stored without any artificial delay to ensure uniqueness. When the facility is installed, the TOD-clock bits stored by TRACE (TRACE and TRACG) are subject to additional control by a bit in control register 0. The facility provides the STORE CLOCK FAST instruction. (September, 2005)

**Store-Facility-List-Extended Facility:**

The *store-facility-list-extended facility* may be available on a model implementing z/Architecture. The facility extends the function provided by the STORE FACILITY LIST (STFL) instruction. Whereas STFL is a control instruction that can store an indication of 32 facilities at real location 200, the new STORE FACILITY LIST EXTENDED (STFLE) instruction is a general instruction that can store an indication of up to 16,384 facilities at a program-specified location. (September, 2005)

**TOD-Clock-Steering Facility**

The *TOD-clock-steering facility* may be available on a model implementing z/Architecture. The facility provides a means by which apparent stepping rate of the time-of-day clock may be altered without changing the physical hardware oscillator which steps the physical clock. The facility adds the semiprivileged PERFORM TIMING FACILITY FUNCTION (PTFF) instruction which provides the means by which the program can query various timing-related parameters, and, optionally, the means by which an authorized timing-control program can influence certain of these parameters. (September, 2005)

**Transactional-Execution Facility**

The *transactional-execution facility* may be available on a model implementing z/Architecture. The facility provides the means by which a program can issue multiple instructions, the storage accesses of which either (a) appear to occur as a single concurrent operation or (b) do not appear to occur, as observed by other CPUs and by the channel subsystem.

The facility provides the following general instructions:

- EXTRACT TRANSACTION NESTING DEPTH
- NON TRANSACTIONAL STORE
- TRANSACTION ABORT
- TRANSACTION BEGIN (TBEGIN)
- TRANSACTION END

(September, 2012)

**Vector Facility for z/Architecture**

The *vector facility for z/Architecture* may be available on models implementing z/Architecture. When the facility is installed and enabled, vector instructions are available, having access to 32 128-bit registers. The instructions are described in four chapters:

- Chapter 21 describes the vector facility support instructions
- Chapter 22 describes the vector facility integer instructions
- Chapter 23 describes the vector facility string instructions
- Chapter 24 describes the vector facility floating-point instructions.

*Note:* ESA/390 provided an optional vector facility, however this facility was never available on any processor capable of the z/Architecture architectural mode. The vector facility for z/Architecture differs from the ESA/390 vector facility in instruction and register definitions.

(March, 2015)

**Warning-Track Interruption Facility**

The *warning-track-interruption facility* may be available on a model implementing the z/Architecture. The facility provides the means by which a warning-track external interruption can be presented to a CPU in a configuration with shared-CPU resources, such as a logical partition. The control program can use the warning-track external interruption as the signal to make the currently-executing dispatchable unit dispatchable on a different CPU of the configuration.

(September, 2012)
The ESA/390 Base

z/Architecture includes all of the facilities of ESA/390 except for the asynchronous-pageout, asynchronous-data-mover, program-call-fast, and vector facilities. This section briefly outlines most of the remaining facilities that were additions in ESA/390 as compared to ESA/370.

ESA/390 is described in Enterprise Systems Architecture/390 Principles of Operation, SA22-7201.

The CPU-related facilities that were new in ESA/390 are summarized below. ESA/390 was announced in September, 1990. Any extension added subsequently has the date of its announcement in parentheses at the end of its summary.

The following extensions are described in detail in SA22-7201 and in this publication:

- **Access-list-controlled protection** allows store-type storage references to an address space to be prohibited by means of a bit in the access-list entry used to access the space. Thus, different users having different access lists can have different capabilities to store in the same address space.

- The program-event-recording facility 2 (PER 2) is an alternative to the original PER facility, which is now named PER 1. (Neither of the names PER 1 and PER 2 is used in z/Architecture; only “PER” is used.) PER 2 provides the option of having a successful-branching event occur only when the branch target is within the designated storage area, and it provides the option of having a storage-alteration event occur only when the storage area is within designated address spaces. The use of these options improves performance by allowing only PER events of interest to occur. PER 2 deletes the ability to monitor for general-register-alteration events.

- **Concurrent sense** improves performance by allowing sense information to be presented at the time of an interruption due to a unit-check condition, thus avoiding the need for a separate I/O operation to obtain the sense information.

- **Broadcasted purging** provides the COMPARE AND SWAP AND PURGE instruction for conditionally updating tables associated with dynamic address translation and access-register translation and clearing associated buffers in multiple CPUs. This is described in detail beginning in the eighth edition of SA22-7201.

- **Storage-protection override** provides a new form of subsystem storage protection that improves the reliability of a subsystem executed in an address space along with possibly erroneous application programs. When storage-protection override is made active by a control-register bit, fetches and stores by the CPU are permitted to storage locations having a storage key of 9 regardless of the access key used by the CPU. If the subsystem is in key-8 storage and is executed with a PSW key of 8, for example, and the application programs are in key-9 storage and are executed with a PSW key of 9, accesses by the subsystem to the application-program areas are permitted while accesses by the application programs to the subsystem area are denied. (September, 1991)

- **Move-page facility 2** extends the MOVE PAGE instruction introduced in ESA/370 by allowing use of a specified access key for either the source or the destination operand, by allowing improved performance when the destination operand will soon be referenced, and by allowing improved performance when an operand is invalid in both main and expanded storage. The ESA/370 version of MOVE PAGE is now called move-page facility 1 and is in Chapter 7, “General Instructions.” MOVE PAGE of move-page facility 2 is in Chapter 10, “Control Instructions.” Some details about the means for control-program support of MOVE PAGE are not provided. (September, 1991) (The z/Architecture MOVE PAGE instruction is described only in Chapter 10 of this publication. MOVE PAGE no longer can move data to or from expanded storage, and all details about MOVE PAGE are provided.)

- **The square-root facility** consists of the SQUARE ROOT instruction and the square-root exception. The instruction extracts the square root of a floating-point operand in either the long or short format. The instruction is the same as that provided
on some models of the IBM 4341, 4361, and 4381 Processors. (September, 1991)

- The *cancel-I/O facility* allows the program to withdraw a pending start function from a designated subchannel without signaling the device, which is useful in certain error-recovery situations. (September, 1991)

The cancel-I/O facility provides the CANCEL SUBCHANNEL instruction and is described in detail beginning in the eighth edition of SA22-7201.

- The *string-instruction facility* (or *logical string assist*) provides instructions for (1) moving a string of bytes until a specified ending byte is found, (2) logically comparing two strings until an inequality or a specified ending byte is found, and (3) searching a string of a specified length for a specified byte. The first two instructions are particularly useful in a C program in which strings are normally delimited by an ending byte of all zeros. (June, 1992)

- The *suppression-on-protection facility* causes a protection exception due to page protection to result in suppression of instruction execution instead of termination of instruction execution, and it causes the address and an address-space identifier of the protected page to be stored in low storage. This is useful in performing the AIX/ESA® copy-on-write function, in which AIX/ESA causes the same page of different address spaces to map to a single page frame of real storage so long as a store in the page is not attempted and then, when a store is attempted in a particular address space, assigns a unique page frame to the page in that address space and copies the contents of the page to the new page frame. (February, 1993)

- The *immediate-and-relative-instruction facility* includes 13 new instructions, most of which use a halfword-immediate value for either signed-binary arithmetic operations or relative branching. The facility reduces the need for general registers, and, in particular, it eliminates the need to use general registers to address branch targets. As a result, the general registers and access registers can be allocated more efficiently in pro-

- The *subspace-group facility* includes the BRANCH IN SUBSPACE GROUP instruction, which can be used to give or return control from one address space to another in a group of address spaces called a subspace group, with this giving and returning of control being done with better performance than can be obtained by means of the PROGRAM CALL and PROGRAM RETURN or PROGRAM TRANSFER instructions. One address space in the subspace group is called the base space, and the other address spaces in the group are called subspaces. It is intended that each subspace contain a different subset of the storage in the base space, that the base space and each subspace contain a subsystem control program, such as CICS®, and application programs, and that each subspace contain the data for a single transaction being processed under the subsystem control program. The placement of the data for each transaction in a different subspace prevents the processing of a transaction from erroneously damaging the data of other transactions. The data of the control program can be protected from the transaction processing by means of the storage-protection-override facility. (April, 1994)

- The *virtual-address enhancement of suppression on protection* provides that if dynamic address translation (DAT) was on when a protection exception was recognized, the suppression-on-protection result is indicated, and the address of the protected location is stored, only if the address is one that was to be translated by DAT; the suppression-on-protection result is not indicated if the address that would be stored is a real address. This enhancement allows the stored address to be translated reliably by the control program to determine if the exception was due to page protection as opposed to key-controlled protection. The enhancement extends the usefulness of suppression on protection to operating systems like MVS/ESA™ that use key-controlled protection. (September, 1994)

The *set-address-space-control-fast facility* consists of the SET ADDRESS SPACE CONTROL FAST (SACF) instruction, which possibly can be used instead of the previously existing SET ADDRESS SPACE CONTROL (SAC) instruction, depending on whether all of the SAC functions are required. SACF, unlike SAC, does not perform the serialization and checkpoint-synchronization functions, nor does it cause copies of prefetched instructions to be discarded. SACF provides improved performance on some models. (February, 1993)
grams that require many registers. (September, 1996)

- The compare-and-move-extended facility provides new versions of the COMPARE LOGICAL LONG and MOVE LONG instructions. The new versions increase the size of the operand-length specifications from 24 bits to 32 bits, which can be useful when objects larger than 16M bytes are processed through the use of 31-bit addressing. The new versions also periodically complete to allow software polling in a multiprocessing system. (September, 1996)

- The checksum facility consists of the CHECKSUM instruction, which can be used to compute a 16-bit or 32-bit checksum in order to improve Transmission-Control Protocol/Internet Protocol (TCP/IP) performance. (September, 1996)

- The called-space-identification facility improves serviceability by further identifying the called address space in a linkage-stack state entry formed by the PROGRAM CALL instruction. (September, 1996)

- The branch-and-set-authority facility consists of the BRANCH AND SET AUTHORITY instruction, which can be used to improve the performance of linkages within an address space by replacing PROGRAM CALL, PROGRAM TRANSFER, and SET PSW KEY FROM ADDRESS instructions. (June, 1997)

- The perform-locked-operation facility consists of the unprivileged PERFORM LOCKED OPERATION instruction, which appears to provide concurrent interlocked-update references to multiple storage operands. A function code of the instruction can specify any of six operations: compare and load, compare and swap, double compare and swap, compare and swap and store, compare and swap and double store, and compare and swap and triple store. The function code further specifies either word or doubleword operands. The instruction can be used to avoid the use of programmed locks in a multiprocessing system. (June, 1997)

- Four additional floating-point facilities improve the hexadecimal-floating-point (HFP) capability of the machine and add a binary-floating-point (BFP) capability. The facilities are:
  - Basic floating-point extensions, which provides 12 additional floating-point registers to make a total of 16 floating-point registers. This facility also includes a floating-point-control register and means for saving the contents of the new registers during a store-status operation or a machine-check interruption.
  - Floating-point-support (FPS) extensions, which provides eight new instructions, including four to convert data between the HFP and BFP formats.
  - Hexadecimal-floating-point (HFP) extensions, which provides 26 new instructions to operate on data in the HFP format. All of these are counterparts to new instructions provided by the BFP facility, including conversion between floating-point and fixed-point formats, and a more complete set of operations on the extended format.
  - Binary floating-point (BFP), which defines short, long, and extended binary-floating-point (BFP) data formats and provides 87 new instructions to operate on data in these formats. The BFP formats and operations provide everything necessary to conform to the IEEE standard (ANSI/IEEE Standard 754-2008, as defined in Reference [17.] on page xxviii) except for conversion between binary-floating-point numbers and decimal strings, which must be provided in software. (May, 1998)

- The resume-program facility consists of the RESUME PROGRAM instruction, which restores, from a specified save area, the instruction address and certain other fields in the current PSW and also the contents of an access-and-general-register pair. RESUME PROGRAM allows a problem-state interruption-handling program to restore the state of an interrupted program and return to that program despite that a register is required for addressing the save area from which the state is restored. (May, 1998)

- The trap facility provides the TRAP instructions (a two-byte TRAP2 instruction and a four-byte TRAP4 instruction) that can overlay instructions in an application program to give control to a program that can perform fix-up operations on data being processed, such as dates that may be a “Year-2000” problem. RESUME PROGRAM can be used to return from the fix-up program. TRAP and RESUME PROGRAM can improve perfor-
mance by avoiding program interruptions that would otherwise be needed to give control to and from the fix-up program. (May, 1998)

- The extended-TOD-clock facility includes (1) an extension of the TOD clock from 64 bits to 104 bits, allowing greater resolution; (2) a TOD programmable register, which contains a TOD programmable field that can be used to identify the configuration providing a TOD-clock value in a sysplex; (3) the SET CLOCK PROGRAMMABLE FIELD instruction, for setting the TOD programmable field in the TOD programmable register; and (4) the STORE CLOCK EXTENDED instruction, which stores both the longer TOD-clock value and the TOD programmable field. STORE CLOCK EXTENDED can be used in the future when the TOD clock is further extended to contain time values that exceed the current year-2042 limit (when there is a carry out of the current bit 0 of the TOD clock). (August, 1998)

- The TOD-clock-control-override facility provides a control-register bit that allows setting the TOD clock under program control, without use of the manual TOD-clock control of any CPU. (August, 1998)

- The store-system-information facility provides the privileged STORE SYSTEM INFORMATION instruction, which can be used to obtain information about a component or components of a virtual machine, a logical partition, or the basic machine. (January, 1999)

- The extended-translation facility, now called the extended-translation facility 1, includes the CONVERT UNICODE TO UTF-8, CONVERT UTF-8 TO UNICODE, and TRANSLATE EXTENDED instructions, all of which can improve performance. TRANSLATE EXTENDED can be used in place of a TRANSLATE AND TEST instruction that locates an escape character, followed by a TRANSLATE instruction that translates the bytes preceding the escape character. (April, 1999)

The following extensions are described in detail in other publications:

- The Enterprise Systems Connection Architecture® (ESCON®) introduces a new type of channel that uses an optical-fiber communication link between channels and control units. Information is transferred serially by bit, at 200 million bits per second, up to a maximum distance of 60 kilometers. The optical-fiber technology and serial transmission simplify cabling and improve reliability. See the publication IBM Enterprise Systems Architecture/390 ESCON I/O Interface, SA22-7202.

- The ESCON channel-to-channel adapter (ESCON CTCA) provides the same type of function for serial channel paths as is available for the parallel-I/O-interface channel paths. See the publication IBM Enterprise Systems Architecture/390 ESCON Channel-to-Channel Adapter, SA22-7203.

- I/O-device self-description allows a device to describe itself and its position in the I/O configuration. See the publication IBM Enterprise Systems Architecture/390 Common I/O-Device Commands and Self Description, SA22-7204.

- The compression facility performs a Ziv-Lempel type of compression and expansion by means of static (nonadaptive) dictionaries that are to be prepared by a program before the compression and expansion operations. Because the dictionaries are static, the compression facility can provide good compression not only for long sequential data streams (for example, archival or network data) but also for randomly accessed short records (for example, 80 bytes). See the publication IBM Enterprise Systems Architecture/390 Data Compression, SA22-7208. (February, 1993) (The z/Architecture COMPRESSION CALL instruction is described in this publication. However, introductory information and information about dictionary formats still is provided only in SA22-7208.)

The following extensions are described in detail in other publications:

- The integrated cryptographic facility provides a number of instructions to protect data privacy, to support message authentication and personal identification, and to facilitate key management. The high-performance cipher capability of the facility is designed for financial-transaction and bulk-encryption environments, and it complies with the Data Encryption Standard (DES).
  - Usability of the cryptographic facility is extended to virtual-machine environments, which allows the facility to be used by MVS/ESA being executed under VM/ESA®, which in turn may be executed either under
another VM/ESA or in a logical partition. (September, 1991)

- The external-time-reference facility provides a means to initiate and maintain the synchronization of TOD clocks to an external time reference (ETR). Synchronization tolerance of a few microseconds can be achieved, and the effect of leap seconds is taken into account. The facility consists of an ETR sending unit (Sysplex Timer®), which may be duplicated, two or more ETR receiving units, and optical-fiber cables. The cables are used to connect the ETR sending unit, which is an external device, to ETR receiving units of the configuration. CPU instructions are provided for setting the TOD clock to the value supplied by the ETR sending unit.

  - The ETR automatic-propagation-delay-adjustment function adjusts the time signals from the ETR to the attached processors to compensate for the propagation delay on the cables to the processors, thus allowing the cables to be of different lengths. (September, 1991)

  - The ETR external-time-source function synchronizes the ETR to a time signal received from a remote location by means of a telephone or radio. (September, 1991)

- Extended sorting provides instructions that improve the performance of the DB2® sorting function.

- Other PER extensions, besides those described beginning in the fourth edition of this publication, are an augmentation of PER 2 that provide additional PER function in the interpretive-execution mode.

- Channel-subsystem call provides various functions for use in the management of the I/O configuration. Some of the functions acquire information about the configuration from the accessible elements of the configuration, while others dynamically change the configuration.

- The operational extensions are a number of other improvements that result in increased availability and ease of use of the system, as follows:

  - Automatic-reconfiguration permits an operating system in an LPAR partition to declare itself willing to be terminated suddenly, usually to permit its storage and CPU resources to be acquired by an adjacent partition that is dynamically absorbing the work load of another system that has failed. Other functions deactivate and reset designated participating partitions.

    - A new storage-reconfiguration command decreases the time needed to reconfigure storage by allowing multiple requests for reconfiguration to be made by means of a single communication with the service processor.

    - SCP-initiated reset allows a system control program (SCP) to reset its I/O configuration prior to entering the disabled wait state following certain check conditions.

    - Console integration simplifies configuration requirements by reducing by one the number of consoles required by MVS.

    - The processor-availability facility enables a CPU experiencing an unrecoverable error that will cause a check stop to save its state and alert the other CPUs in the configuration. This allows, in many cases, another CPU to continue execution of the program that was in execution on the failing CPU. The facility is applicable in both the ESA/390 mode and the LPAR mode. (April, 1991)

- Extensions for virtual machines are a number of improvements to the interpretive-execution facility, as follows:

  - The VM-data-space facility provides for making the ESA/390 access-register architecture more useful in virtual-machine applications. The facility improves the ability to address a larger amount of data and to share data. For information on how VM/ESA uses the VM-data-space facility, see the publication VM/ESA CP Programming Services, SC24-5520.

    - A new storage-key function improves performance by removing the need for the previously used RCP area.

    - Other improvements include an optional special-purpose lookaside for some of the guest-state information and greater freedom in certain implementation choices.

- The ESCON-multiple-image facility (EMIF) allows multiple logical partitions to share ESCON
channels (and FICON channels) and optionally to share any of the control units and associated I/O devices configured to these shared channels. This can reduce channel requirements, improve channel utilization, and improve I/O connectivity. (June, 1992)

- **PR/SM LPAR mode** is enhanced to allow up to 10 logical partitions in a single-image configuration and 20 in a physically-partitioned configuration. The previous limits were seven and 14, respectively. (June, 1992)

  Coincident with z/Architecture, PR/SM LPAR mode allows 15 logical partitions, and physical partitioning is not supported.

  - The **coupling facility** enables high-performance data sharing among MVS/ESA systems that are connected by means of the facility. The coupling facility provides storage that can be dynamically partitioned for caching data in shared buffers, maintaining work queues and status information in shared lists, and locking data by means of shared lock controls. MVS/ESA services provide access to and manipulation of the coupling-facility contents. (April, 1994)

The ESA/370 and 370-XA Base

ESA/390 includes the complete set of facilities of ESA/370 as its base. This section briefly outlines most of the facilities that were additions in 370-XA as compared to System/370 and that were additions in ESA/370 as compared to 370-XA.

The CPU-related facilities that were new in 370-XA are as follows:

- **Bimodal addressing** provides two modes of operation: a 24-bit addressing mode for the execution of old programs and a 31-bit addressing mode.

- **31-bit logical addressing** extends the virtual address space from the 16M bytes addressable with 24-bit addresses to 2G bytes (2,147,483,648 bytes).

- **31-bit real and absolute addressing** provides addressability for up to 2G bytes of main storage.

- The 370-XA **protection** facilities include key-controlled protection on only 4K-byte blocks, page protection, and, as in System/370, low-address protection for addresses below 512. Fetch-protection override eliminates fetch protection for locations 0-2047.

- The **tracing** facility assists in the determination of system problems by providing an ongoing record in storage of significant events.

- The COMPARE AND FORM CODEWORD and UPDATE TREE instructions facilitate sorting applications.

- The **interpretive-execution facility** allows creation of virtual machines that may operate according to several architectures and whose performance is enhanced because many virtual-machine functions are directly interpreted by the machine rather than simulated by the program. This facility is described in the publication *IBM 370-XA Interpretive Execution*, SA22-7095.

- The **service-call-logical-processor (SCLP) facility** provides a means of communicating between the control program and the service processor for the purpose of describing and changing the configuration. This facility is not described.

The I/O-related differences between 370-XA and System/370 result from the 370-XA **channel subsystem**, which includes:

- **Path-independent addressing** of I/O devices, which permits the initiation of I/O operations without regard to which CPU is executing the I/O instruction or how the I/O device is attached to the channel subsystem. Any I/O interruption can be handled by any CPU enabled for it.

- **Path management**, whereby the channel subsystem determines which paths are available for selection, chooses a path, and manages any busy conditions encountered while attempting to initiate I/O processing with the associated devices.

- **Dynamic reconnection**, which permits any I/O device using this capability to reconnect to any available channel path to which it has access in order to continue execution of a chain of commands.

- **Programmable interruption subclasses**, which permit the programmed assignment of I/O-interruption requests from individual I/O devices to any one of eight maskable interruption queues.
• An additional CCW format for the direct use of 31-bit addresses in channel programs. The new CCW format, called format 1, is provided in addition to the System/370 CCW format, now called format 0.

• Address-limit checking, which provides an additional storage-protection facility to prevent data access to storage locations above or below a specified absolute address.

• Monitoring facilities, which can be invoked by the program to cause the channel subsystem to measure and accumulate key I/O-resource usage parameters.

• Status-verification facility, which reports inappropriate combinations of device-status bits presented by a device.

• A set of 13 I/O instructions, with associated control blocks, which are provided for the control of the channel subsystem.

The facilities that were new in ESA/370 are as follows:

• Sixteen access registers permit the program to have immediate access to storage operands in up to 16 2G-byte address spaces, including the address space in which the program resides. In a dynamic-address-translation mode named access-register mode, the instruction B field, or for certain instructions the R field, designates both a general register and an access register, and the contents of the access register, along with the contents of protected tables, specify the operand address space to be accessed. By changing the contents of the access registers, the program, under the control of an authorization mechanism, can have fast access to hundreds of different operand address spaces.

• A linkage stack is used in a functionally expanded mechanism for passing control between programs in either the same or different address spaces. This mechanism makes use also of the previously existing PROGRAM CALL instruction, an extended entry-table entry, and a new PROGRAM RETURN instruction. The mechanism saves various elements of status, including access-register and general-register contents, during a calling linkage, provides for changing the current status during the calling linkage, and restores the original status during the returning linkage. The linkage stack can also be used to save and restore access-register and general-register contents during a branch-type linkage performed by the new instruction BRANCH AND STACK.

• A translation mode named home-space mode provides an efficient means for the control program to obtain control in the address space, called the home address space, in which the principal control blocks for a dispatchable unit (a task or process) are kept.

• The semiprivileged MOVE WITH SOURCE KEY and MOVE WITH DESTINATION KEY instructions allow bidirectional movement of data between storage areas having different storage keys, without the need to change the PSW key.

• The privileged LOAD USING REAL ADDRESS and STORE USING REAL ADDRESS instructions allow the control program to access data in real storage more efficiently.

• The private-space facility allows an address space not to contain any common segments and causes low-address protection and fetch-protection override not to apply to the address space.

• The unprivileged MOVE PAGE instruction allows the program to move a page of data between main and expanded storage, provided that the source and destination pages are both valid. Some details about the means for control-program support of MOVE PAGE are not provided. The ESA/370 version of MOVE PAGE is now called move-page facility 1.

• The Processor Resource/Systems Manager™ (PR/SM™) feature provides support for multiple preferred guests under VM/XA and provides the logically partitioned (LPAR) mode, with the latter providing flexible partitioning of processor resources among multiple logical partitions. Certain aspects of the LPAR use of PR/SM are described in the publication IBM ES/3090 Processor Complex Processor Resource/Systems Manager Planning Guide, GA22-7123.

• The COMPARE UNTIL SUBSTRING EQUAL instruction provides improved performance of the compression of IMS log data sets and can be useful in other programs also.
System Program

z/Architecture is designed to be used with a control program that coordinates the use of system resources and executes all I/O instructions, handles exceptional conditions, and supervises scheduling and execution of multiple programs.

Compatibility

Compatibility among z/Architecture Systems

Although systems operating as defined by z/Architecture may differ in implementation and physical capabilities, logically they are upward and downward compatible. Compatibility provides for simplicity in education, availability of system backup, and ease in system growth. Specifically, any program written for z/Architecture gives identical results on any z/Architecture implementation, provided that the program:

5. Does not depend on results or functions that are defined in the functional-characteristics publication for a particular model to be deviations from the architecture.

6. Takes into account any changes made to the architecture that are identified as affecting compatibility.

Compatibility between z/Architecture and ESA/390

Control-Program Compatibility

Control programs written for ESA/390 cannot be directly transferred to systems operating as defined by z/Architecture. This is because the general-register and control-register sizes, PSW size, assigned storage locations, and dynamic address translation are changed.

Problem-State Compatibility

A high degree of compatibility exists at the problem-state level in going forward from ESA/390 to z/Architecture. Because the majority of a user's applications are written for the problem state, this problem-state compatibility is useful in many installations.

A problem-state program written for ESA/390 operates with z/Architecture, provided that the program:

1. Complies with the limitations described in “Compatibility among z/Architecture Systems”.

2. Is not dependent on privileged facilities which are unavailable on the system.

Programming Note: This publication assigns meanings to various operation codes, to bit positions in instructions, channel-command words, registers, and table entries, and to fixed locations in the low 512 bytes and bytes 4096-8191 of storage. Unless specifically noted, the remaining operation codes, bit positions, and low-storage locations are reserved for future assignment to new facilities and other extensions of the architecture.

To ensure that existing programs operate if and when such new facilities are installed, programs should not depend on an indication of an exception as a result of invalid values that are currently defined as being checked. If a value must be placed in unassigned positions that are not checked, the program should
enter zeros. When the machine provides a code or field, the program should take into account that new codes and bits may be assigned in the future. The program should not use unassigned low-storage locations for keeping information since these locations may be assigned in the future in such a way that the machine causes the contents of the locations to be changed.

## Availability

Availability is the capability of a system to accept and successfully process an individual job. Systems operating in accordance with z/Architecture permit substantial availability by (1) allowing a large number and broad range of jobs to be processed concurrently, thus making the system readily accessible to any particular job, and (2) limiting the effect of an error and identifying more precisely its cause, with the result that the number of jobs affected by errors is minimized and the correction of the errors facilitated.

Several design aspects make this possible.

- A program is checked for the correctness of instructions and data as the program is executed, and program errors are indicated separate from equipment errors. Such checking and reporting assists in locating failures and isolating effects.

- The protection facilities, in conjunction with dynamic address translation and the separation of programs and data in different address spaces, permit the protection of the contents of storage from destruction or misuse caused by erroneous or unauthorized storing or fetching by a program. This provides increased security for the user, thus permitting applications with different security requirements to be processed concurrently with other applications.

- Dynamic address translation allows isolation of one application from another, still permitting them to share common resources. Also, it permits the implementation of virtual machines, which may be used in the design and testing of new versions of operating systems along with the concurrent processing of application programs. Additionally, it provides for the concurrent operation of incompatible operating systems.

- The use of access registers allows programs, data, and different collections of data to reside in different address spaces, and this further reduces the likelihood that a store using an incorrect address will produce either erroneous results or a system-wide failure.

- Multiprocessing and the channel subsystem permit better use of storage and processing capabilities, more direct communication between CPUs, and duplication of resources, thus aiding in the continuation of system operation in the event of machine failures.

- MONITOR CALL, program-event recording, and the timing facilities permit the testing and debugging of programs without manual intervention and with little effect on the concurrent processing of other programs.

- On most models, error checking and correction (ECC) in main storage, CPU retry, and command retry provide for circumventing intermittent equipment malfunctions, thus reducing the number of equipment failures.

- An enhanced machine-check-handling mechanism provides model-independent fault isolation, which reduces the number of programs impacted by uncorrected errors. Additionally, it provides model-independent recording of machine-status information. This leads to greater machine-check-handling compatibility between models and improves the capability for loading and operating a program on a different model when a system failure occurs.

- A small number of manual controls are required for basic system operation, permitting most operator-system interaction to take place via a unit operating as an I/O device and thus reducing the possibility of operator errors.

- The logical partitions made available by the PR/SM feature allow continued reliable production operations in one or more partitions while new programming systems are tested in other partitions. This is an advancement in particular for non-VM installations.

- The operational extensions and channel-subsystem-call facility of ESA/390 and z/Architecture improve the ability to continue execution of application programs in the presence of system incidents and the ability to make configuration changes with less disruption to operations.
Chapter 2. Organization

Main Storage .................................................. 2-2
Expanded Storage .............................................. 2-2
CPU .......................................................... 2-2
  CPU Types .................................................... 2-3
  Multithreading .............................................. 2-3
PSW .......................................................... 2-3
General Registers ............................................ 2-4
Floating-Point Registers ................................. 2-4
Floating-Point-Control Register ....................... 2-5
Vector Registers ............................................. 2-5
Control Registers ............................................. 2-6
Access Registers ............................................. 2-6
Cryptographic Facility ..................................... 2-7
External Time Reference ................................. 2-7
I/O .......................................................... 2-7
  Channel Subsystem ....................................... 2-7
  Channel Paths ............................................. 2-7
I/O Devices and Control Units .......................... 2-8
Operator Facilities ......................................... 2-8

Logically, a system consists of main storage, one or more central processing units (CPUs), operator facilities, a channel subsystem, and I/O devices. I/O devices are attached to the channel subsystem through control units. The connection between the channel subsystem and a control unit is called a channel path.

A channel path employs either a parallel-transmission protocol or a serial-transmission protocol and, accordingly, is called either a parallel or a serial channel path. A serial channel path may connect to a control unit through a dynamic switch that is capable of providing different internal connections between the ports of the switch.

Expanded storage may also be available in the system, a cryptographic unit may be included in a CPU, and an external time reference (ETR) may be connected to the system.

The physical identity of the above functions may vary among implementations, called “models”. Figure 2-1 depicts the logical structure of a two-CPU multiprocessor system that includes expanded storage and a cryptographic unit and that is connected to an ETR.

Specific processors may differ in their internal characteristics, the installed facilities, the number of subchannels, channel paths, and control units which can be attached to the channel subsystem, the size of main and expanded storage, and the representation of the operator facilities.

A system viewed without regard to its I/O devices is referred to as a configuration. All of the physical equipment, whether in the configuration or not, is referred to as the installation.

Figure 2-1. Logical Structure of a z/Architecture System with Two CPUs

Model-dependent reconfiguration controls may be provided to change the amount of main and expanded storage and the number of CPUs and channel paths in the configuration. In some instances, the reconfiguration controls may be used to partition a single configuration into multiple configurations. Each of the configurations so reconfigured has the same structure, that is, main and expanded storage and one or more CPUs, a channel subsystem, and I/O devices.
storage, one or more CPUs, and one or more sub-channels and channel paths in the channel subsystem.

Each configuration is isolated in that the main and expanded storage in one configuration is not directly addressable by the CPUs and the channel subsystem of another configuration. It is, however, possible for one configuration to communicate with another by means of shared I/O devices or a channel-to-channel adapter. At any one time, the storage, CPUs, sub-channels, and channel paths connected together in a system are referred to as being in the configuration. Each CPU, subchannel, channel path, main-storage location, and expanded-storage location can be in only one configuration at a time.

Main Storage

Main storage, which is directly addressable, provides for high-speed processing of data by the CPUs and the channel subsystem. Both data and programs must be loaded into main storage from input devices before they can be processed. The amount of main storage available in the system depends on the model, and, depending on the model, the amount in the configuration may be under control of model-dependent configuration controls. The storage is available in multiples of 4K-byte blocks. At any instant, the channel subsystem and all CPUs in the configuration have access to the same blocks of storage and refer to a particular block of main-storage locations by using the same absolute address.

Main storage may include a faster-access buffer storage, sometimes called a cache. Each CPU may have an associated cache. The effects, except on performance, of the physical construction and the use of distinct storage media are not observable by the program.

Expanded Storage

Expanded storage may be available on some models. Expanded storage, when available, can be accessed by all CPUs in the configuration by means of instructions that transfer 4K-byte blocks of data from expanded storage to main storage or from main storage to expanded storage. These instructions are the PAGE IN and PAGE OUT instructions, described in "PAGE IN" on page 10-70 and "PAGE OUT" on page 10-71.

Each 4K-byte block of expanded storage is addressed by means of a 32-bit unsigned binary integer called an expanded-storage block number.

CPU

The central processing unit (CPU) is the controlling center of the system. It contains the sequencing and processing facilities for instruction execution, interruption action, timing functions, initial program loading, and other machine-related functions.

The physical implementation of the CPU may differ among models, but the logical function remains the same. The result of executing an instruction is the same for each model, providing that the program complies with the compatibility rules.

The CPU, in executing instructions, can process binary integers and floating-point numbers (binary, decimal, and hexadecimal) of fixed length, decimal integers of variable length, and logical information of either fixed or variable length. Processing may be in parallel or in series; the width of the processing elements, the multiplicity of the shifting paths, and the degree of simultaneity in performing the different types of arithmetic differ from one model of CPU to another without affecting the logical results.

Instructions which the CPU executes fall into eight classes: general, decimal, floating-point-support (FPS), binary-floating-point (BFP), decimal-floating-point (DFP), hexadecimal-floating-point (HFP), control, and I/O instructions. The general instructions are used in performing binary-integer-arithmetic operations and logical, branching, and other nonarithmetic operations. The decimal instructions operate on data in the decimal format. The BFP, DFP, and HFP instructions operate on data in the BFP, DFP, and HFP formats, respectively, while the FPS instructions operate on floating-point data independent of the format or convert from one format to another. The privileged control instructions and the I/O instructions can be executed only when the CPU is in the supervisor state; the semiprivileged control instructions can be executed in the problem state, subject to the appropriate authorization mechanisms.
The CPU provides registers which are available to programs but do not have addressable representations in main storage. They include the current program-status word (PSW), the general registers, the floating-point registers and floating-point-control register, the vector registers, the control registers, the access registers, the prefix register, the breaking-event-address register, the TOD-programmable register, and the registers for the clock comparator and the CPU timer; this set of registers is sometimes referred to as the CPU’s *architected register context*. Each CPU in an installation provides access to a time-of-day (TOD) clock, which is shared by all CPUs in the installation. The instruction operation code determines which type of register is to be used in an operation. See Figure 2-2 on page 2-5 for the format of the control, access, general, and floating-point registers.

**CPU Types**
Each CPU has a type attribute that indicates whether it provides the full complement of functions and facilities (called a general CPU), or whether it is intended to process specific types of workloads. A primary CPU is either a general CPU or a CPU having the same type as the CPU started following the last IPL operation (the IPL CPU). A secondary CPU is any CPU other than a general CPU, and whose CPU type differs from that of the IPL CPU.

**Programming Note:** CPUs intended to process specific types of workloads include those used by the integrated facility for Linux (IFL), the internal coupling facility (ICF), the IBM zEnterprise Application-Assist Processor (zAAP), and the IBM z Integrated Information Processor (zIIP).

**Multithreading**
When the multithreading (MT) facility is installed, it may be enabled by execution of the set-multithreading SITP order (see “Set Multithreading” on page 4-69 for details). The following terms are applicable when the MT facility is installed:

**Core:** When the multithreading facility is enabled, the following applies:

- The number of CPUs in the configuration is increased by a multiple, the value of which is determined by a program-specified maximum thread identification (thread ID, or simply TID). The number of CPUs in a core is one more than the program-specified maximum thread identification.
- A number of CPUs corresponding to this multiple are grouped into a *core*.
- Each core has the same number of CPUs. Each CPU within a core is of the same CPU type; however, based on the model and CPU type, some CPUs within a core may not be operational.

When the multithreading facility is not installed, or the facility is installed but not enabled, a core comprises a single CPU, and the term CPU is generally used in favor of the term core.

**Thread:** When the multithreading facility is installed, a *thread* is synonymous with a CPU that is a member of a core. When the multithreading facility is not installed, or when the facility is installed but not enabled, the term thread is not applicable.

A control program must explicitly enable multithreading in order for it to be usable, as described in “Set Multithreading” on page 4-69. However, an application program is generally unaware of whether multithreading has been enabled.

When multithreading is enabled, the CPU addresses of all CPUs in the configuration are adjusted to include a core identification (or core ID) in the leftmost bits of the address and a thread identification (thread ID, or TID) in the rightmost bits of the address. See “CPU-Address Identification” on page 4-63 for details on the core-ID and thread-ID fields of the CPU address.

CPUs within a core may share certain hardware facilities such as execution units or lower-level caches, thus execution within one CPU of a core may affect the performance of other CPUs in the core.

**PSW**
The program-status word (PSW) includes the instruction address, condition code, and other information used to control instruction sequencing and to determine the state of the CPU. The active or controlling PSW is called the current PSW. It governs the program currently being executed.

The CPU has an interruption capability, which permits the CPU to switch rapidly to another program in response to exceptional conditions and external stim-
When an interruption occurs, the CPU places the current PSW in an assigned storage location, called the old-PSW location, for the particular class of interruption. The CPU fetches a new PSW from a second assigned storage location. This new PSW determines the next program to be executed. When it has finished processing the interruption, the program handling the interruption may reload the old PSW, making it again the current PSW, so that the interrupted program can continue.

There are six classes of interruption: external, I/O, machine check, program, restart, and supervisor call. Each class has a distinct pair of old-PSW and new-PSW locations permanently assigned in real storage.

**General Registers**

Instructions may designate information in one or more of 16 general registers. The general registers may be used as base-address registers and index registers in address arithmetic and as accumulators in general arithmetic and logical operations. Each register contains 64 bit positions. The general registers are identified by the numbers 0-15 and are designated by a four-bit R field in an instruction. Some instructions provide for addressing multiple general registers by having several R fields. For some instructions, the use of a specific general register is implied rather than explicitly designated by an R field of the instruction.

For some operations, either bits 32-63 or bits 0-63 of two adjacent general registers are coupled, providing a 64-bit or 128-bit format, respectively. In these operations, the program must designate an even-numbered register, which contains the leftmost (high-order) 32 or 64 bits. The next higher-numbered register contains the rightmost (low-order) 32 or 64 bits.

In addition to their use as accumulators in general arithmetic and logical operations, 15 of the 16 general registers are also used as base-address and index registers in address generation. In these cases, the registers are designated by a four-bit B field or X field in an instruction. A value of zero in the B or X field specifies that no base or index is to be applied, and, thus, general register 0 cannot be designated as containing a base address or index.

While in the ESA/390 architectural mode, the contents of bit positions 0-31 of the 64-bit general registers of all CPUs in the configuration cannot be altered by any instruction.

**Floating-Point Registers**

All floating-point instructions (FPS, BFP, DFP, and HFP) use the same set of floating-point registers. The CPU has 16 floating-point registers. The floating-point registers are identified by the numbers 0-15 and are designated by a four-bit R field in floating-point instructions. Each floating-point register is 64 bits long and can contain either a short (32-bit) or a long (64-bit) floating-point operand. As shown in Figure 2-2 on page 2-5, pairs of floating-point registers can be used for extended (128-bit) operands. Each of the eight pairs is referred to by the number of the lower-numbered register of the pair.
### Floating-Point-Control Register

The floating-point-control (FPC) register is a 32-bit register that contains mask bits, flag bits, a data-exception code, and rounding-mode bits. The FPC register is described in the section “Floating-Point-Control (FPC) Register” on page 9-9.

### Vector Registers

All vector instructions use the same set of 32 vector registers identified by the numbers 0-31 and are designated by the concatenation of a single register number extension bit with a four-bit field. Each vector register is 128 bits long and can contain from one to sixteen equal sized elements. When there are multi-

---

#### Table: Control, Access, General, and Floating-Point Registers

<table>
<thead>
<tr>
<th>R Field and Register Number</th>
<th>Control Registers</th>
<th>Access Registers</th>
<th>General Registers</th>
<th>Floating-Point Registers</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0001 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0010 2</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0011 3</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0100 4</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0101 5</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0110 6</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0111 7</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1000 8</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1001 9</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1010 10</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1011 11</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1100 12</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1101 13</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1110 14</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1111 15</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Note:** The arrows indicate that the two registers may be coupled as a double-register pair, designated by specifying the lower-numbered register in the R field. For example, the floating-point register pair 13 and 15 is designated by 1101 binary in the R field.

*Figure 2-2. Control, Access, General, and Floating-Point Registers*
ple elements in the register the elements are indexed from left to right starting at element zero.

The floating-point registers overlay the vector registers as shown in Figure 2-3 on page 2-6. Bits 0-63 of vector registers 0-15 correspond to floating-point registers 0-15. Whenever a floating-point instruction or floating point support instruction writes to a floating point register, or a floating point instruction that reads a register pair reads from floating-point registers, bits 64-127 of the corresponding vector register are unpredictable. Any use of vector registers 0-15 by a vector instruction, except for VECTOR LOAD ELEMENT specifying an element not in bits 0-63 of the vector register will cause the data in the floating point register to be overwritten as well.

<table>
<thead>
<tr>
<th>FPR 0 or VR 0 (bits 0-63)</th>
<th>VR 0 (bits 64-127)</th>
</tr>
</thead>
<tbody>
<tr>
<td>FPR 1 or VR 1 (bits 0-63)</td>
<td>VR 1 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 2 or VR 2 (bits 0-63)</td>
<td>VR 2 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 3 or VR 3 (bits 0-63)</td>
<td>VR 3 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 4 or VR 4 (bits 0-63)</td>
<td>VR 4 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 5 or VR 5 (bits 0-63)</td>
<td>VR 5 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 6 or VR 6 (bits 0-63)</td>
<td>VR 6 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 7 or VR 7 (bits 0-63)</td>
<td>VR 7 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 8 or VR 8 (bits 0-63)</td>
<td>VR 8 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 9 or VR 9 (bits 0-63)</td>
<td>VR 9 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 10 or VR 10 (bits 0-63)</td>
<td>VR 10 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 11 or VR 11 (bits 0-63)</td>
<td>VR 11 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 12 or VR 12 (bits 0-63)</td>
<td>VR 12 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 13 or VR 13 (bits 0-63)</td>
<td>VR 13 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 14 or VR 14 (bits 0-63)</td>
<td>VR 14 (bits 64-127)</td>
</tr>
<tr>
<td>FPR 15 or VR 15 (bits 0-63)</td>
<td>VR 15 (bits 64-127)</td>
</tr>
<tr>
<td>VR 16</td>
<td></td>
</tr>
<tr>
<td>VR 17</td>
<td></td>
</tr>
<tr>
<td>VR 18</td>
<td></td>
</tr>
<tr>
<td>VR 19</td>
<td></td>
</tr>
<tr>
<td>VR 20</td>
<td></td>
</tr>
<tr>
<td>VR 21</td>
<td></td>
</tr>
<tr>
<td>VR 22</td>
<td></td>
</tr>
<tr>
<td>VR 23</td>
<td></td>
</tr>
<tr>
<td>VR 24</td>
<td></td>
</tr>
<tr>
<td>VR 25</td>
<td></td>
</tr>
<tr>
<td>VR 26</td>
<td></td>
</tr>
<tr>
<td>VR 27</td>
<td></td>
</tr>
<tr>
<td>VR 28</td>
<td></td>
</tr>
<tr>
<td>VR 29</td>
<td></td>
</tr>
<tr>
<td>VR 30</td>
<td></td>
</tr>
<tr>
<td>VR 31</td>
<td></td>
</tr>
</tbody>
</table>

**Control Registers**

The CPU has 16 control registers, each having 64 bit positions. The bit positions in the registers are assigned to particular facilities in the system, such as program-event recording, and are used either to specify that an operation can take place or to furnish special information required by the facility.

The control registers are identified by the numbers 0-15 and are designated by four-bit R fields in the instructions LOAD CONTROL and STORE CONTROL. Multiple control registers can be addressed by these instructions.

While in the ESA/390 architectural mode, the contents of bit positions 0-31 of the 64-bit control registers of all CPUs in the configuration cannot be altered by any instruction.

**Access Registers**

The CPU has 16 access registers numbered 0-15. An access register consists of 32 bit positions containing an indirect specification (not described here in detail) of an address-space-control element. An address-space-control element is a parameter used by the dynamic-address-translation (DAT) mechanism to translate references to a corresponding address space. When the CPU is in a mode called the access-register mode (controlled by bits in the PSW), an instruction B field, used to specify a logical address for a storage-operand reference, designates an access register, and the address-space-control element specified by the access register is used by DAT for the reference being made. For some instructions, an R field is used instead of a B field. Instructions are provided for loading and storing the contents of the access registers and for moving the contents of one access register to another.

Each of access registers 1-15 can designate any address space, including the current instruction space (the primary address space). Access register 0 always designates the current instruction space. When one of access registers 1-15 is used to designate an address space, the CPU determines which address space is designated by translating the contents of the access register. When access register 0 is used to designate an address space, the CPU treats the access register as designating the current instruction space, and it does not examine the actual
contents of the access register. Therefore, the 16 access registers can designate, at any one time, the current instruction space and a maximum of 15 other spaces.

Cryptographic Facility

Depending on the model, an integrated cryptographic facility may be provided as an extension of the CPU. When the cryptographic facility is provided on a CPU, it functions as an integral part of that CPU. A summary of the benefits of the cryptographic facility is given on page 1-27; the facility is otherwise not described.

External Time Reference

Depending on the model, an external time reference (ETR) may be connected to the configuration. A summary of the benefits of the ETR is given on page 1-28; the facility is otherwise not described.

I/O

Input/output (I/O) operations involve the transfer of information between main storage and an I/O device. I/O devices and their control units attach to the channel subsystem, which controls this data transfer.

Channel Subsystem

The channel subsystem directs the flow of information between I/O devices and main storage. It relieves CPUs of the task of communicating directly with I/O devices and permits data processing to proceed concurrently with I/O processing. The channel subsystem uses one or more channel paths as the communication link in managing the flow of information to or from I/O devices. As part of I/O processing, the channel subsystem also performs the path-management function of testing for channel-path availability, selecting an available channel path, and initiating execution of the operation with the I/O device. Within the channel subsystem are subchannels.

One subchannel is provided for and dedicated to each I/O device accessible to the channel subsystem. Each subchannel contains storage for information concerning the associated I/O device and its attachment to the channel subsystem. The subchannel also provides storage for information concerning I/O operations and other functions involving the associated I/O device. Information contained in the subchannel can be accessed by CPUs using I/O instructions as well as by the channel subsystem and serves as the means of communication between any CPU and the channel subsystem concerning the associated I/O device. The actual number of subchannels provided depends on the model and the configuration; the maximum number of subchannels is 65,536.

Channel Paths

I/O devices are attached through control units to the channel subsystem via channel paths. Control units may be attached to the channel subsystem via more than one channel path, and an I/O device may be attached to more than one control unit. In all, an individual I/O device may be accessible to a channel subsystem by as many as eight different channel paths, depending on the model and the configuration. The total number of channel paths provided by a channel subsystem depends on the model and the configuration; the maximum number of channel paths is 256.

A channel path can use one of three types of communication links:

- System/360 and System/370 I/O interface, called the parallel-I/O interface; the channel path is called a parallel channel path
- ESCON I/O interface, called a serial-I/O interface; the channel path is called a serial channel path
- FICON I/O interface, also called a serial-I/O interface; the channel path again is called a serial channel path

Each parallel-I/O interface consists of a number of electrical signal lines between the channel subsystem and one or more control units. Eight control units can share a single parallel-I/O interface. Up to 256 I/O devices can be addressed on a single parallel-I/O interface. The parallel-I/O interface is described in the publication IBM System/360 and System/370 I/O Interface Channel to Control Unit Original Equipment Manufacturers’ Information, GA22-6974.
Each serial-I/O interface consists of two optical-fiber conductors between any two of a channel subsystem, a dynamic switch, and a control unit. A dynamic switch can be connected by means of multiple serial-I/O interfaces to either the same or different channel subsystems and to multiple control units. The number of control units which can be connected on one channel path depends on the channel-subsystem and dynamic-switch capabilities. Up to 256 devices can be attached to each control unit that uses the serial-I/O interface, depending on the control unit. The ESCON I/O interface is described in the publication ESA/390 ESCON I/O Interface, SA22-7202. The FICON I/O interface is described in the ANSI standards document Fibre Channel - Single-Byte Command Code Sets-2 (FC-SB-2).

I/O Devices and Control Units

I/O devices include such equipment as printers, magnetic-tape units, direct-access-storage devices, displays, keyboards, communications controllers, teleprocessing devices, and sensor-based equipment. Many I/O devices function with an external medium, such as paper or magnetic tape. Other I/O devices handle only electrical signals, such as those found in displays and communications networks. In all cases, I/O-device operation is regulated by a control unit that provides the logical and buffering capabilities necessary to operate the associated I/O device. From the programming point of view, most control-unit functions merge with I/O-device functions. The control-unit function may be housed with the I/O device or in the CPU, or a separate control unit may be used.

Operator Facilities

The operator facilities provide the functions necessary for operator control of the machine. Associated with the operator facilities may be an operator-console device, which may also be used as an I/O device for communicating with the program.

The main functions provided by the operator facilities include resetting, clearing, initial program loading, start, stop, alter, and display.
This chapter discusses the representation of information in main storage, as well as addressing, protection, and reference and change recording. The various types of addresses, and the manner in which they are used to address assigned storage locations, are discussed. The recognition of address exceptions and the handling of address translation are also covered.

For example, the various types of addresses, and the manner in which they are used to address assigned storage locations, are discussed. The recognition of address exceptions and the handling of address translation are also covered.
which one type of address is translated to another type of address.

A list of permanently assigned storage locations appears at the end of the chapter.

Main storage provides the system with directly addressable fast-access storage of data. Both data and programs must be loaded into main storage (from input devices) before they can be processed.

Main storage may include one or more smaller faster-access buffer storages, sometimes called caches. A cache is usually physically associated with a CPU or an I/O processor. The effects, except on performance, of the physical construction and use of distinct storage media are generally not observable by the program.

Separate caches may be maintained for instructions and for data operands. Information within a cache is maintained in contiguous bytes on an integral boundary called a cache block or cache line (or line, for short). A model may provide the EXTRACT CPU ATTRIBUTE instruction which returns various cache attributes such as line size, number of cache levels, and set associativity. A model may also provide any or all of the PREFETCH DATA, PREFETCH DATA RELATIVE LONG, and NEXT INSTRUCTION ACCESS INTENT instructions which affect the prefetching of storage into the data cache, the releasing of data from the cache, or indicating access intent of storage operands.

Fetching and storing of data by a CPU are not normally affected by any concurrent channel-subsystem activity or by a concurrent reference to the same storage location by another CPU. When concurrent requests to a main-storage location occur, access normally is granted in a sequence determined by the system. If a reference changes the contents of the location, any subsequent storage fetches obtain the new contents. However, when the transactional-execution facility is installed, a transaction executing on one CPU may be aborted due to conflicting fetches and stores by another CPU or by the channel subsystem.

Main storage may be volatile or nonvolatile. If it is volatile, the contents of main storage are not preserved when power is turned off. If it is nonvolatile, turning power off and then back on does not affect the contents of main storage, provided all CPUs are in the stopped state and no references are made to main storage when power is being turned off. In both types of main storage, the contents of storage keys are not necessarily preserved when the power for main storage is turned off.

Note: Because most references in this publication apply to virtual storage, the abbreviated term “storage” is often used in place of “virtual storage.” The term “storage” may also be used in place of “main storage,” “absolute storage,” or “real storage” when the meaning is clear. The terms “main storage” and “absolute storage” are used to describe storage which is addressable by means of an absolute address. The terms describe fast-access storage, as opposed to auxiliary storage, such as that provided by direct-access storage devices. “Real storage” is synonymous with “absolute storage” except for the effects of prefixing.

Programming Note: On models that implement separate caches for instructions and data operands, a significant delay may be experienced if the program stores into a cache line from which instructions are subsequently fetched, regardless of whether the store alters the instructions that are subsequently fetched.

Storage Addressing

Storage is viewed as a long horizontal string of bits. For most operations, accesses to storage proceed in a left-to-right sequence. The string of bits is subdivided into units of eight bits. An eight-bit unit is called a byte, which is the basic building block of all information formats.

Each byte location in storage is identified by a unique nonnegative integer, which is the address of that byte location or, simply, the byte address. Adjacent byte locations have consecutive addresses, starting with 0 on the left and proceeding in a left-to-right sequence. Addresses are unsigned binary integers and are 24, 31, or 64 bits. Addresses are described in “Address Size and Wraparound” on page 3-5.

Information Formats

Information is transmitted between storage and a CPU or the channel subsystem one byte, or a group of bytes, at a time. Unless otherwise specified, a group of bytes in storage is addressed by the left-
most byte of the group. The number of bytes in the group is either implied or explicitly specified by the operation to be performed. When used in a CPU operation, a group of bytes is called a field.

Within each group of bytes, bits are numbered in a left-to-right sequence. The leftmost bits are sometimes referred to as the “high-order” bits and the rightmost bits as the “low-order” bits. Bit numbers are not storage addresses, however. Only bytes can be addressed. To operate on individual bits of a byte in storage, it is necessary to access the entire byte.

The bits in a byte are numbered 0 through 7, from left to right.

The bits in an address may be numbered 8-31 or 40-63 for 24-bit addresses or 1-31 or 33-63 for 31-bit addresses; they are numbered 0-63 for 64-bit addresses. Within any other fixed-length format of multiple bytes, the bits making up the format are consecutively numbered starting from 0.

For purposes of error detection, and in some models for correction, one or more check bits may be transmitted with each byte or with a group of bytes. Such check bits are generated automatically by the machine and cannot be directly controlled by the program. References in this publication to the length of data fields and registers exclude mention of the associated check bits. All storage capacities are expressed in number of bytes.

When the length of a storage-operand field is implied by the operation code of an instruction, the field is said to have a fixed length, which can be one, two, four, eight, or sixteen bytes. Larger fields may be implied for some instructions.

When the length of a storage-operand field is not implied but is stated explicitly, the field is said to have a variable length. Variable-length operands can vary in length by increments of one byte.

When information is placed in storage, the contents of only those byte locations are replaced that are included in the designated field, even though the width of the physical path to storage may be greater than the length of the field being stored.

Integral Boundaries

Certain units of information must be on an integral boundary in storage. A boundary is called integral for a unit of information when its storage address is a multiple of the length of the unit in bytes. Special names are given to fields of 2, 4, 8, 16, and 32 bytes on an integral boundary. A halfword is a group of two consecutive bytes on a two-byte boundary and is the basic building block of instructions. A word is a group of four consecutive bytes on a four-byte boundary. A doubleword is a group of eight consecutive bytes on an eight-byte boundary. A quadword is a group of 16 consecutive bytes on a 16-byte boundary. An octoword is a group of 32 consecutive bytes on a 32-byte boundary. (See Figure 3-1 on page 3-4.)

When storage addresses designate halfwords, words, doublewords, quadwords, and octowords, the binary representation of the address contains one, two, three, four, or five rightmost zero bits, respectively.

Instructions must be on two-byte integral boundaries, and CCWs, IDAWs, MIDAWs, TIDAWs, and the storage operands of certain instructions must be on other integral boundaries. The storage operands of most instructions do not have boundary-alignment requirements.

Programming Note: For fixed-field-length operations with field lengths that are a power of 2, significant performance degradation is possible when storage operands are not positioned at addresses that are integral multiples of the operand length. To
improve performance, frequently used storage operands should be aligned on integral boundaries.

Address Types and Formats

Address Types

For purposes of addressing main storage, three basic types of addresses are recognized: absolute, real, and virtual. The addresses are distinguished on the basis of the transformations that are applied to the address during a storage access. Address translation converts virtual to real, and prefixing converts real to absolute. In addition to the three basic address types, additional types are defined which are treated as one or another of the three basic types, depending on the instruction and the current mode.

Absolute Address

An absolute address is the address assigned to a main-storage location. An absolute address is used for a storage access without any transformations performed on it.

The channel subsystem and all CPUs in the configuration refer to a shared main-storage location by using the same absolute address. Available main storage is usually assigned contiguous absolute addresses starting at 0, and the addresses are always assigned in complete 4K-byte blocks on integral boundaries. An exception is recognized when an attempt is made to use an absolute address in a block which has not been assigned to physical locations. On some models, storage-reconfiguration controls may be provided which permit the operator to change the correspondence between absolute addresses and physical locations. However, at any one time, a physical location is not associated with more than one absolute address.

Storage consisting of byte locations sequenced according to their absolute addresses is referred to as absolute storage.

Real Address

A real address identifies a location in real storage. When a real address is used for an access to main storage, it is converted, by means of prefixing, to an absolute address.

At any instant there is one real-address to absolute-address mapping for each CPU in the configuration. When a real address is used by a CPU to access main storage, it is converted to an absolute address by prefixing. The particular transformation is defined by the value in the prefix register for the CPU.
Storage consisting of byte locations sequenced according to their real addresses is referred to as real storage.

**Virtual Address**
A virtual address identifies a location in virtual storage. When a virtual address is used for an access to main storage, it is translated by means of dynamic address translation, either (a) to a real address which is then further converted by prefixing to an absolute address, or (b) directly to an absolute address.

**Primary Virtual Address**
A primary virtual address is a virtual address which is to be translated by means of the primary address-space-control element. Logical addresses are treated as primary virtual addresses when in the primary-space mode. Instruction addresses are treated as primary virtual addresses when in the primary-space mode, secondary-space mode, or access-register mode. The first-operand address of MOVE TO PRIMARY and the second-operand address of MOVE TO SECONDARY are always treated as primary virtual addresses.

**Secondary Virtual Address**
A secondary virtual address is a virtual address which is to be translated by means of the secondary address-space-control element. Logical addresses are treated as secondary virtual addresses when in the secondary-space mode. The second-operand address of MOVE TO PRIMARY and the first-operand address of MOVE TO SECONDARY are always treated as secondary virtual addresses.

**AR-Specified Virtual Address**
An AR-specified virtual address is a virtual address which is to be translated by means of an access-register-specified address-space-control element. Logical addresses are treated as AR-specified addresses when in the access-register mode.

**Home Virtual Address**
A home virtual address is a virtual address which is to be translated by means of the home address-space-control element. Logical addresses and instruction addresses are treated as home virtual addresses when in the home-space mode.

**Logical Address**
Except where otherwise specified, the storage-operand addresses for most instructions are logical addresses. Logical addresses are treated as real addresses in the real mode, as primary virtual addresses in the primary-space mode, as secondary virtual addresses in the secondary-space mode, as AR-specified virtual addresses in the access-register mode, and as home virtual addresses in the home-space mode. Some instructions have storage-operand addresses or storage accesses associated with the instruction which do not follow the rules for logical addresses. In all such cases, the instruction definition contains a definition of the type of address.

**Instruction Address**
Addresses used to fetch instructions from storage are called instruction addresses. Instruction addresses are treated as real addresses in the real mode, as primary virtual addresses in the primary-space mode, as secondary-space mode, or access-register mode, and as home virtual addresses in the home-space mode. The following are instruction addresses:

- The instruction address in the current PSW
- The target address of execute-type instructions (EXECUTE and EXECUTE RELATIVE LONG)
- The instruction address in the transaction-abort PSW
- The aborted-transaction instruction address (in the transaction diagnostic block)

**Effective Address**
In some situations, it is convenient to use the term “effective address.” An effective address is the address which exists before any transformation by dynamic address translation or prefixing is performed. An effective address may be specified directly in a register or may result from address arithmetic. Address arithmetic is the addition of the base and displacement or of the base, index, and displacement.

**Address Size and Wraparound**
An address size refers to the maximum number of significant bits that can represent an address. Three sizes of addresses are provided: 24-bit, 31-bit, and 64-bit. A 24-bit address can accommodate a maximum of 16,777,216 (16M) bytes; with a 31-bit address, 2,147,483,648 (2G) bytes can be addressed; and, with a 64-bit address, 18,446,744,073,709,551,616 (16E) bytes can be...
addressed. The bits of a 24-bit, 31-bit, or 64-bit address produced by address arithmetic under the control of the current addressing mode are numbered 40-63, 33-63, and 0-63, respectively, corresponding to the numbering of base-address and index bits in a general register, as shown below:

<table>
<thead>
<tr>
<th>24-bit Address</th>
<th>31-bit Address</th>
<th>64-bit Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 40 63</td>
<td>0 33 63</td>
<td></td>
</tr>
<tr>
<td>0 63</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The byte and bit positions of a 64-bit address and corresponding power-of-two and numerical values are shown in Figure 3-2.

<table>
<thead>
<tr>
<th>Byte</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit Position</td>
<td>0</td>
<td>8</td>
<td>24</td>
<td>32</td>
<td>40</td>
<td>48</td>
<td>56</td>
<td>64</td>
</tr>
<tr>
<td>Power of 2</td>
<td>2</td>
<td>5</td>
<td>6</td>
<td>10</td>
<td>16</td>
<td>32</td>
<td>64</td>
<td></td>
</tr>
<tr>
<td>Value</td>
<td>8</td>
<td>E</td>
<td>E</td>
<td>2</td>
<td>5</td>
<td>6</td>
<td>8</td>
<td>4</td>
</tr>
</tbody>
</table>

Figure 3-2: 64-Bit Address Attributes

The bits of an address that is 31 bits regardless of the addressing mode are numbered 1-31, and, when a 24-bit or 31-bit address is contained in a four-byte field in storage, the bits are numbered 8-31 or 1-31, respectively:

<table>
<thead>
<tr>
<th>24-bit Address</th>
<th>31-bit Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 23 31</td>
<td>0 30 31</td>
</tr>
</tbody>
</table>

A 24-bit or 31-bit virtual address is expanded to 64 bits by appending 40 or 33 zeros, respectively, on the left before it is translated by means of the DAT process, and a 24-bit or 31-bit real address is similarly expanded to 64 bits before it is transformed by prefixing. A 24-bit or 31-bit absolute address is expanded to 64 bits before main storage is accessed. Thus, the 24-bit address always designates a location in the first 16M-byte block of the 16E-byte storage addressable by a 64-bit address, and the 31-bit address always designates a location in the first 2G-byte block.

Unless specifically stated to the contrary, the following definition applies in this publication: whenever the machine generates and provides to the program a 24-bit or 31-bit address, the address is made available (placed in storage or loaded into a general register) by being imbedded in a 32-bit field, with the leftmost eight bits or one bit in the field, respectively, set to zeros. When the address is loaded into a general register, bits 0-31 of the register remain unchanged.

The size of effective addresses is controlled by bits 31 and 32 of the PSW, the extended-addressing-mode bit and the basic-addressing-mode bit, respectively. When bits 31 and 32 are both zero, the CPU is in the 24-bit addressing mode, and 24-bit operand and instruction effective addresses are specified. When bit 31 is zero and bit 32 is one, the CPU is in the 31-bit addressing mode, and 31-bit operand and instruction effective addresses are specified. When bits 31 and 32 are both one, the CPU is in the 64-bit addressing mode, and 64-bit operand and instruction effective addresses are specified (see “Address Generation” on page 5-10).

The sizes of the real or absolute addresses used or yielded by the ASN-translation, ASN-authorization, PC-number-translation, and access-register-translation processes are always 31 bits regardless of the current addressing mode. Similarly, the sizes of the real or absolute addresses used or yielded by the DAT, stacking, unstacking, and tracing processes are always 64 bits.
The size of the data address in a CCW is under control of the CCW-format-control bit in the operation-request block (ORB) designated by a START SUB-CHANNEL instruction. The CCWs with 24-bit and 31-bit addresses are called format-0 and format-1 CCWs, respectively. Format-0 and format-1 CCWs are described in “Basic I/O Functions” on page 15-1. Similarly, the size of the data address in an IDAW is under control of the IDAW-format-control bit in the ORB. The IDAWs with 31-bit and 64-bit addresses are called format-1 and format-2 IDAWs, respectively. MIDAWs contain 64-bit data addresses. IDAWs and MIDAWs are described in Chapter 15, “Basic I/O Functions.”

Address Wraparound
The CPU performs address generation when it forms an operand or instruction address or when it generates the address of a table entry from the appropriate table origin and index. It also performs address generation when it increments an address to access successive bytes of a field. Similarly, the channel subsystem performs address generation when it increments an address (1) to fetch a CCW, (2) to fetch an IDAW, (3) to fetch a MIDAW, (4) to transfer data, or (5) to compute the address of an I/O measurement block.

When, during the generation of the address, an address is obtained that exceeds the value allowed for the address size (2^{24} - 1, 2^{31} - 1, or 2^{64} - 1), one of the following two actions is taken:

1. The carry out of the high-order bit position of the address is ignored. This handling of an address of excessive size is called wraparound.
2. An interruption condition is recognized.

The effect of wraparound is to make an address space appear circular; that is, address 0 appears to follow the maximum allowable address. Address arithmetic and wraparound occur before transformation, if any, of the address by DAT or prefixing.

Addresses generated by the CPU that may be virtual addresses always wrap. Wraparound also occurs when the linkage-stack-entry address in control register 15 is decremented below 0 by PROGRAM RETURN. For CPU table entries that are addressed by real or absolute addresses, it is unpredictable whether the address wraps or an addressing exception is recognized.

For channel-program execution, when the generated address exceeds the value for the address size (or, for the read-backward command is decremented below 0), an I/O program-check condition is recognized.

Figure 3-3 on page 3-7 identifies what limit values apply to the generation of different addresses and how addresses are handled when they exceed the allowed value.

<table>
<thead>
<tr>
<th>Address Generation for</th>
<th>Address Type</th>
<th>Handling when Address Would Wrap</th>
</tr>
</thead>
<tbody>
<tr>
<td>Instructions and operands when EAM and BAM are zero</td>
<td>L,I,R,V</td>
<td>W24</td>
</tr>
<tr>
<td>Successive bytes of instructions and operands when EAM and BAM are zero</td>
<td>I,L,V</td>
<td>W24</td>
</tr>
<tr>
<td>Instructions and operands when EAM is zero and BAM is one</td>
<td>L,I,R,V</td>
<td>W31</td>
</tr>
<tr>
<td>Successive bytes of instructions and operands when EAM is zero and BAM is one</td>
<td>I,L,V</td>
<td>W31</td>
</tr>
<tr>
<td>Instructions and operands when EAM and BAM are one</td>
<td>L,I,R,V</td>
<td>W64</td>
</tr>
<tr>
<td>Successive bytes of instructions and operands when EAM and BAM are one</td>
<td>I,L,V</td>
<td>W64</td>
</tr>
<tr>
<td>DAT-table entries when used for implicit translation or for LPTEA, LRA, LRAG, or STRAG</td>
<td>A or R²</td>
<td>X64</td>
</tr>
<tr>
<td>ASN-second-table, authority-table (during ASN authorization), linkage-table, linkage-first-table, linkage-second-table, and entry-table entries</td>
<td>R</td>
<td>X31</td>
</tr>
<tr>
<td>Authority-table (during access-register translation) and access-list entries</td>
<td>A or R²</td>
<td>X31</td>
</tr>
</tbody>
</table>

Figure 3-3. Address Wraparound (Part 1 of 3).
<table>
<thead>
<tr>
<th>Address Generation for</th>
<th>Address Type</th>
<th>Handling when Address Would Wrap</th>
</tr>
</thead>
<tbody>
<tr>
<td>Linkage-stack entry</td>
<td>V</td>
<td>W64</td>
</tr>
<tr>
<td>I/O measurement block</td>
<td>A</td>
<td>P31</td>
</tr>
</tbody>
</table>

For a channel program with format-0 CCWs:
- Successive CCWs: A P24
- Successive IDAWs: A P24
- Successive MIDAWs: A P24
- Successive bytes of I/O data (without IDAWs and MIDAWs): A P24
- Successive bytes of I/O data (with format-1 IDAWs): A P31
- Successive bytes of I/O data (with format-2 IDAWs): A P64
- Successive bytes of I/O data (with MIDAWs): A P64

For a channel program with format-1 CCWs:
- Successive CCWs: A P31
- Successive IDAWs: A P31
- Successive MIDAWs: A P31
- Successive bytes of I/O data (without IDAWs and MIDAWs): A P31
- Successive bytes of I/O data (with format-1 IDAWs): A P31
- Successive bytes of I/O data (with format-2 IDAWs): A P64
- Successive bytes of I/O data (with MIDAWs): A P64

*Figure 3-3. Address Wraparound (Part 2 of 3).*
A storage key is associated with each 4K-byte block of storage that is available in the configuration. The storage key has the following format:

```
0 1 2 3 4 5 6
```

The bit positions in the storage key are allocated as follows:

**Access-Control Bits (ACC):** If a reference is subject to key-controlled protection, the four access-control bits, bits 0-3, are matched with the four-bit access key when information is stored and when information is fetched from a location that is protected against fetching.

**Fetch-Protection Bit (F):** If a reference is subject to key-controlled protection, the fetch-protection bit, bit 4, controls whether key-controlled protection applies to fetch-type references: a zero indicates that only store-type references are monitored and that fetching with any access key is permitted; a one indicates that key-controlled protection applies to both fetching and storing. No distinction is made between the fetching of instructions and of operands.

**Reference Bit (R):** The reference bit, bit 5, normally is set to one each time a location in the corresponding storage block is referred to either for storing or for fetching of information.

**Change Bit (C):** The change bit, bit 6, is set to one each time information is stored at a location in the corresponding storage block.

Storage keys are not part of addressable storage. The entire storage key may be set by SET STORAGE KEY EXTENDED and inspected by INSERT STORAGE KEY EXTENDED. RESET REFERENCE BIT EXTENDED provides a means of inspecting the reference and change bits and of setting the reference bit to zero. RESET REFERENCE BITS MULTIPLE provides a means of inspecting the reference bits of 64 contiguous 4 K-byte blocks and setting the reference bits to zero. Bits 0-4 of the storage key are inspected by the INSERT VIRTUAL STORAGE KEY instruction. The contents of the storage key are

---

### Table: Address Generation for Address Wraparound

<table>
<thead>
<tr>
<th>Address Type</th>
<th>Handling when Address Would Wrap</th>
</tr>
</thead>
<tbody>
<tr>
<td>I</td>
<td>Real addresses do not apply in this case since the instructions which designate operands by means of real addresses cannot designate operands that cross boundary $2^{24}$, $2^{31}$, $2^{64}$.</td>
</tr>
<tr>
<td>A</td>
<td>Absolute address.</td>
</tr>
<tr>
<td>BAM</td>
<td>Basic-addressing-mode bit in the PSW.</td>
</tr>
<tr>
<td>EAM</td>
<td>Extended-addressing-mode bit in the PSW.</td>
</tr>
<tr>
<td>L</td>
<td>Logical address.</td>
</tr>
<tr>
<td>P24</td>
<td>An I/O program-check condition is recognized when the address exceeds $2^{24} - 1$ or is decremented below zero.</td>
</tr>
<tr>
<td>P31</td>
<td>An I/O program-check condition is recognized when the address exceeds $2^{31} - 1$ or is decremented below zero.</td>
</tr>
<tr>
<td>P64</td>
<td>An I/O program-check condition is recognized when the address exceeds $2^{64} - 1$ or is decremented below zero.</td>
</tr>
<tr>
<td>R</td>
<td>Real address.</td>
</tr>
<tr>
<td>V</td>
<td>Virtual address.</td>
</tr>
<tr>
<td>W24</td>
<td>Wrap to location 0 after location $2^{24} - 1$ and vice versa.</td>
</tr>
<tr>
<td>W31</td>
<td>Wrap to location 0 after location $2^{31} - 1$ and vice versa.</td>
</tr>
<tr>
<td>W64</td>
<td>Wrap to location 0 after location $2^{64} - 1$ and vice versa.</td>
</tr>
<tr>
<td>X31</td>
<td>When the address exceeds $2^{31} - 1$, it is unpredictable whether the address wraps to location 0 after location $2^{31} - 1$ or whether an addressing exception is recognized.</td>
</tr>
<tr>
<td>X64</td>
<td>When the address exceeds $2^{64} - 1$, it is unpredictable whether the address wraps to location 0 after location $2^{64} - 1$ or whether an addressing exception is recognized.</td>
</tr>
</tbody>
</table>

Figure 3-3. Address Wraparound (Part 3 of 3).
unpredictable during and after the execution of the usability test of the TEST BLOCK instruction. When the conditional SSKE facility is installed, SET STORAGE KEY EXTENDED may be used to set all or portions of a storage key based on program-specified criteria. When the enhanced-DAT facility is installed, the SET STORAGE KEY EXTENDED or PERFORM FRAME MANAGEMENT FUNCTION instructions may be used to set all or portions of one or more storage keys based on program-specified criteria.

When EDAT-1 applies,¹ the invalid bit of the segment-table entry used in the translation is zero, and the STE-format-control is one, the following additional conditions are in effect:

- Bit position 47 of the segment-table entry contains the ACCF-validity control. The ACCF-validity control determines the validity of the access-control and fetch-protection bits in the STE. When the ACCF-validity control is zero, key-controlled protection uses the access-control and fetch-protection bits in the storage key for the 4K-byte block corresponding to the address.

- When the ACCF-validity control is one, bit positions 48-52 of the segment-table entry contain the access-control bits and the fetch-protection bit for the segment. When determining accessibility to a storage operand, it is unpredictable whether bits 48-52 of the STE or bits 0-4 of the individual storage keys for the 4K-byte blocks composing the segment are examined. See “Translation Process” on page 3-48 for further details.

When EDAT-2 applies¹, the invalid bit of the region-third-table entry (RTTE) used in the translation is zero, and the RTTE-format-control is one, the following conditions are in effect:

- Bit position 47 of the RTTE contains the ACCF-validity control. The ACCF-validity control determines the validity of the access-control and fetch-protection bits in the RTTE. When the ACCF-validity control is zero, key-controlled protection uses the access-control and fetch-protection bits in the storage key for the 4K-byte block corresponding to the address.

- When the ACCF-validity control is one, bit positions 48-52 of the RTTE contain the access-control bits and the fetch-protection bit for the region.

When determining accessibility to a storage operand, it is unpredictable whether bits 48-52 of the RTTE or bits 0-4 of the individual storage keys for the 4K-byte blocks composing the segment are examined. See “Translation Process” on page 3-48 for further details.

**Programming Note:** When EDAT-1 applies, and both the ACCF-validity control and the STE-format control (bits 47 and 53 of the segment-table entry, respectively) are one, bits 48-52 of the STE contain access-control and fetch-protection bits which may be used in lieu of the corresponding bits in the storage keys. In this case, the program is responsible for ensuring that the access-control and fetch-protection bits in the STE are identical to the corresponding bits in each of the 256 storage keys for the segment.

Similarly, when EDAT-2 applies, and both the ACCF-validity control and the RTTE-format control (bits 47 and 53 of the region-third-table entry, respectively) are one, bits 48-52 of the RTTE contain access-control and fetch-protection bits which may be used in lieu of the corresponding bits in the storage keys. In this case, the program is responsible for ensuring that the access-control and fetch-protection bits in the RTTE are identical to the corresponding bits in each of the 524,288 storage keys for the region.

See “Modification of Translation Tables” on page 3-62 for restrictions on (a) modifying the STE or the storage keys when the STE-format control is one or (b) modifying the RTTE or the storage keys when the RTTE-format control is one.

### Protection

Four protection facilities are provided to protect the contents of main storage from destruction or misuse by programs that contain errors or are unauthorized: key-controlled protection, access-list-controlled protection, DAT protection, and low-address protection. The protection facilities are applied independently; access to main storage is only permitted when none of the facilities prohibits the access.

Key-controlled protection affords protection against improper storing or against both improper storing and fetching, but not against improper fetching alone.

---

¹ See “Enhanced-DAT Terminology:” on page 3-38 for an explanation of EDAT applicability.
Key-Controlled Protection

When key-controlled protection applies to a storage access, a store is permitted only when the storage key matches the access key associated with the request for storage access; a fetch is permitted when the keys match or when the fetch-protection bit of the storage key is zero.

The keys are said to match when the four access-control bits of the storage key are equal to the access key, or when the access key is zero.

The protection action is summarized in Figure 3-4.

<table>
<thead>
<tr>
<th>Conditions</th>
<th>Is Access to Storage Permitted</th>
</tr>
</thead>
<tbody>
<tr>
<td>Fetch-Protection Bit of Storage Key</td>
<td>Key Relation</td>
</tr>
<tr>
<td>0</td>
<td>Match</td>
</tr>
<tr>
<td>0</td>
<td>Mismatch</td>
</tr>
<tr>
<td>1</td>
<td>Match</td>
</tr>
<tr>
<td>1</td>
<td>Mismatch</td>
</tr>
</tbody>
</table>

Explanation:
- Match: The four access-control bits of the storage key are equal to the access key, or the access key is zero.
- Yes: Access is permitted.
- No: Access is not permitted. On fetching, the information is not made available to the program; on storing, the contents of the storage location are not changed.

Figure 3-4. Summary of Protection Action

When a CPU access is prohibited because of key-controlled protection, the execution of the instruction is terminated, and a program interruption for a protection exception takes place. However, the unit of operation or the execution of the instruction may be suppressed, as described in the section “Suppression on Protection” on page 3-14. When a channel-program access is prohibited, the start function is ended, and the protection-check condition is indicated in the associated interruption-response block (IRB). When a measurement-block access is prohibited, the I/O measurement-block protection-check condition is indicated.

When a store access is prohibited because of key-controlled protection, the contents of the protected location remain unchanged. When a fetch access is prohibited, the protected information is not loaded into a register, moved to another storage location, or provided to an I/O device. For a prohibited instruction fetch, the instruction is suppressed, and an arbitrary instruction-length code is indicated.

Key-controlled protection is independent of whether the CPU is in the problem or the supervisor state and, except as described below, does not depend on the type of CPU instruction or channel-command word being executed.

Except where otherwise specified, all accesses to storage locations that are explicitly designated by the program and that are used by the CPU to store or fetch information are subject to key-controlled protection.

Key-controlled protection does not apply when the storage-protection-override control is one and the value of the four access-control bits of the storage key is 9. Key-controlled protection for fetches may or may not apply when the fetch-protection-override
control is one, depending on the effective address and the private-space control.

The storage-protection-override control and fetch-protection-override control do not affect storage references made by the channel subsystem.

Accesses to the second operand of TEST BLOCK are not subject to key-controlled protection.

All storage accesses by the channel subsystem to access the I/O measurement block, or by a channel program to fetch a CCW, IDAW, or MIDAW or to access a data area designated during the execution of a CCW, are subject to key-controlled protection. However, if a CCW, an IDAW, a MIDAW, or output data is prefetched, a protection check is not indicated until the CCW, IDAW, or MIDAW is due to take control or until the data is due to be written.

Key-controlled protection is not applied to accesses that are implicitly made for any of such sequences as:

- An interruption
- CPU logout
- Fetching of table entries for access-register translation, dynamic-address translation, PC-number translation, ASN translation, or ASN authorization
- Tracing
- A store-status function
- Storing in real locations 184-191 when TEST PENDING INTERRUPTION has an operand address of zero
- Initial program loading
- Storing in real locations 6,144-6,399 when transactional execution is aborted due to an unfiltered program-exception condition

Similarly, protection does not apply to accesses initiated via the operator facilities for altering or displaying information. However, when the program explicitly designates these locations, they are subject to protection.

Storage-Protection-Override Control

Bit 39 of control register 0 is the storage-protection-override control. When this bit is one, storage-protection override is active. When this bit is zero, storage-protection override is inactive. When storage-protection override is active, key-controlled storage protection is ignored for storage locations having an associated storage-key value of 9. When storage-protection override is inactive, no special action is taken for a storage-key value of 9.

Storage-protection override applies to instruction fetch and to the fetch and store accesses of instructions whose operand addresses are logical, virtual, or real. It does not apply to accesses made for the purpose of channel-program execution or for the purpose of channel-subsystem monitoring.

Storage-protection override has no effect on accesses which are not subject to key-controlled protection.

Programming Notes:

1. Storage-protection override can be used to improve reliability in the case when a possibly erroneous application program is executed in conjunction with a reliable subsystem, provided that the application program needs to access only a portion of the storage accessed by the subsystem. The technique for doing this is as follows. The storage accessed by the application program is given storage key 9. The storage accessed by only the subsystem is given some other nonzero storage key, for example, key 8. The application is executed with PSW key 9. The subsystem is executed with PSW key 8 (in this example). As a result, the subsystem can access both the key-8 and the key-9 storage, while the application program can access only the key-9 storage.

2. Storage-protection override affects the accesses to storage made by the CPU and also affects the result set by TEST PROTECTION. However, those instructions which, in the problem state, test the PSW-key mask to determine if a particular key value may be used are not affected by whether storage-protection override is active. These instructions include, among others, MOVE WITH KEY and SET PSW KEY FROM ADDRESS. To permit these instructions to use an access key of 9 in the problem state, bit 9 of the PSW-key mask must be one.

Fetch-Protection-Override Control

Bit 38 of control register 0 is the fetch-protection-override control. When the bit is one, fetch protection is ignored for locations at effective addresses 0-2047. An effective address is the address which exists before any transformation by dynamic address trans-
lation or prefixing. However, fetch protection is not ignored if the effective address is subject to dynamic address translation and the private-space control, bit 55, is one in the address-space-control element used in the translation.

Fetch-protection override applies to instruction fetch and to the fetch accesses of instructions whose operand addresses are logical, virtual, or real. It does not apply to fetch accesses made for the purpose of channel-program execution or for the purpose of channel-subsystem monitoring. When this bit is set to zero, fetch protection of locations at effective addresses 0-2047 is determined by the state of the fetch-protection bit of the storage key associated with those locations.

Fetch-protection override has no effect on accesses which are not subject to key-controlled protection.

**Programming Note:** The fetch-protection-override control allows fetch protection of locations at addresses 2048-4095 along with no fetch protection of locations at addresses 0-2047.

**Access-List-Controlled Protection**

In the access-register mode, bit 6 of the access-list entry, the fetch-only bit, controls which types of operand references are permitted to the address space specified by the access-list entry. When the entry is used in the access-register-translation part of a reference and bit 6 is zero, both fetch-type and store-type references are permitted; when bit 6 is one, only fetch-type references are permitted, and an attempt to store causes a protection exception to be recognized and the execution of the instruction to be suppressed.

The fetch-only bit is included in the ALB access-list entry. A change to the fetch-only bit in an access-list entry in main storage does not necessarily have an immediate, if any, effect on whether a protection exception is recognized. However, this change to the bit will have an effect immediately after PURGE ALB or a COMPARE AND SWAP AND PURGE instruction that purges the ALB is executed.

**DAT Protection**

The DAT-protection function\(^2\) controls access to virtual storage by using the DAT-protection bit in each page-table entry and segment-table entry, and, when the enhanced-DAT facility is installed, in each region-table entry. It provides protection against improper storing.

The DAT-protection bit, bit 54 of the page-table entry, controls whether storing is allowed into the corresponding 4K-byte page. When the bit is zero, both fetching and storing are permitted; when the bit is one, only fetching is permitted. When an attempt is made to store into a protected page, the contents of the page remain unchanged, the unit of operation or the execution of the instruction is suppressed, and a program interruption for protection takes place.

The DAT-protection bit, bit 54 of the segment-table entry, controls whether storing is allowed into the corresponding 1M-byte segment, as follows:

- When EDAT-1 does not apply, or when EDAT-1 applies and the STE-format control is zero, the DAT-protection bit of the segment-table entry is treated as being ORed into the DAT-protection-bit position of each entry in the page table designated by the segment-table entry. Thus, when the segment-table-entry DAT-protection bit is one, the effect is as if the DAT-protection bit were one in each entry in the designated page table.

- When EDAT-1 applies and the STE-format control is one, the DAT-protection bit of the segment-table entry controls whether storing is allowed into the corresponding 1 M-byte segment. When the bit is zero, both fetching and storing are permitted; when the bit is one, only fetching is permitted. When an attempt is made to store into a protected segment, the contents of the segment remain unchanged, the unit of operation or the execution of the instruction is suppressed, and a program interruption for protection takes place.

**Programming Note:** A violation of access-list-controlled protection always causes suppression. A violation of any of the other protection types may cause termination.

---

2. Prior to the enhanced-DAT facility, the DAT-protection function was known as the page-protection facility.
execution of the instruction is suppressed, and a program interruption for protection takes place.

When EDAT-1 applies, the DAT-protection bit, bit 54 of the region-table entry, controls whether storing is allowed into the corresponding region(s). The DAT-protection bit in a region-table entry is treated as being ORed into the DAT-protection bit position of any subsequent region-table entry and segment-table entry that is used in the translation. When the STE-format control is zero, the DAT-protection bit is further propagated to the page-table entry, as described above.

DAT protection applies to all store-type references that use a virtual address.

Low-Address Protection

The low-address-protection facility provides protection against the destruction of main-storage information used by the CPU during interruption processing. This is accomplished by prohibiting instructions from storing with effective addresses in the ranges 0 through 511 and 4096 through 4607 (the first 512 bytes of each of the first and second 4K-byte effective-address blocks). The range criterion is applied before address transformation, if any, of the address by dynamic address translation or prefixing. However, the range criterion is not applied, with the result that low-address protection does not apply, if the effective address is subject to dynamic address translation and the private-space control, bit 55, is one in the address-space-control element used in the translation. Low-address protection does not apply if the address-space-control element to be used is not available due to another type of exception.

Low-address protection is under control of bit 35 of control register 0, the low-address-protection-control bit. When the bit is zero, low-address protection is off; when the bit is one, low-address protection is on.

If an access is prohibited because of low-address protection, the contents of the protected location remain unchanged, the execution of the instruction is terminated, and a program interruption for a protection exception takes place. However, the unit of operation or the execution of the instruction may be suppressed, as described in the section “Suppression on Protection” on page 3-14.

Any attempt by the program to store by using effective addresses in the range 0 through 511 or 4096 through 4607 is subject to low-address protection. Low-address protection is applied to the store accesses of instructions whose operand addresses are logical, virtual, real, or absolute. Low-address protection is also applied to the trace table.

Low-address protection is not applied to accesses made by the CPU or the channel subsystem for such sequences as interruptions, CPU logout, the storing of the I/O-interruption code in real locations 184-195 by TEST PENDING INTERRUPTION, the storing of the results of STORE FACILITY LIST in real locations 200-203, and the initial-program-loading and store-status functions, nor is it applied to data stores during I/O data transfer. When the enhanced-monitor facility is installed, low-address protection is not applied when a monitor-event counting operation results in the updating the enhanced-monitor exception count in real locations 268-271. However, explicit stores by a program at any of these locations are subject to low-address protection.

Programming Notes:

1. Low-address protection and key-controlled protection apply to the same store accesses, except that:
   a. Low-address protection does not apply to storing performed by the channel subsystem, whereas key-controlled protection does.
   b. Key-controlled protection does not apply to tracing, the second operand of TEST BLOCK, or instructions that operate specifically on the linkage stack, whereas low-address protection does.

2. Because fetch-protection override and low-address protection do not apply to an address space for which the private-space control is one in the address-space-control element, locations 0-2047 and 4096-4607 in the address space are usable the same as the other locations in the space.

Suppression on Protection

Some instruction definitions specify that the operation is always suppressed if a protection exception due to any type of protection is recognized. When that specification is absent, the execution of an
instruction is always suppressed if a protection exception due to access-list-controlled protection or DAT protection is recognized, and it may be either suppressed or terminated if a protection exception due to low-address protection or key-controlled protection is recognized.

The suppression-on-protection function allows the control program to locate the segment-table entry, page-table entry, and, when EDAT-1 applies, the region-table entry used in the translation of a virtual address that caused a protection exception, in order to determine if the exception was due to DAT protection. This is necessary for the implementation of the POSIX fork function (discussed in a programming note). The function also allows the control program to avoid locating the segment-table and page-table entries if the address was not virtual or the exception was due to access-list-controlled protection; when EDAT-1 applies, the control program may also avoid locating the region-table entries if the address was not virtual or the exception was due to access-list-controlled protection.

During a program interruption due to a protection exception, either a one or a zero is stored in bit position 61 of real locations 168-175. The storing of a one in bit position 61 indicates that:

- The unit of operation or instruction execution during which the exception was recognized was suppressed.
- If dynamic address translation (DAT) was on, as indicated by the DAT-mode bit in the program old PSW, the effective address that caused the exception is one that was to be translated by DAT. (The effective address is the address which exists before any transformation by DAT or prefixing.) Bit 61 is set to zero if DAT was on but the effective address was not to be translated by DAT because it is a real address. If DAT was off, the protection exception cannot have been due to DAT protection or access-list-controlled protection.
- Bit positions 0-51 of real locations 168-175 contain bits 0-51 of the effective address that caused the exception. The contents of bit positions 52-59 of real locations 168-175 are always unpredictable.

If DAT was on, indicating that the effective address was to be translated by DAT, bit positions 62 and 63 of real locations 168-175, and real location 160, contain the same information as is stored during a program interruption due to a page-translation exception — this information identifies the address space containing the protected address. Also, bit 60 of real locations 168-175 is zero if the protection exception was not due to access-list-controlled protection or is one if the exception was due to access-list-controlled protection. A one in bit position 60 indicates that the exception was not due to DAT protection. If DAT was off, the contents of bit positions 60, 62, and 63 of real locations 168-175, and the contents of real location 160, are unpredictable.

Bit 61 being zero indicates that the operation was either suppressed or terminated and that the contents of the remainder of real locations 168-175, and of real location 160 are unpredictable.

Bit 61 is set to one if the protection exception was due to access-list-controlled protection or DAT protection. Bit 61 may be set to one if the protection exception was due to low-address protection or key-controlled protection.

If a protection-exception condition exists due to either access-list-controlled protection or DAT protection but also exists due to either low-address protection or key-controlled protection, it is unpredictable whether bit 61 is set to zero or one.

**Programming Notes:**

1. The suppression-on-protection function is useful in performing the POSIX fork function, which causes a duplicate address space to be created. The following discussion pertains to (a) when EDAT-1 does not apply, (b) when EDAT-1 applies but the STE-format-control in the segment-table entry is zero, or (c) when EDAT-2 applies but the RTTE-format control in the region-third-table entry is zero. When forking occurs, the control program causes the same page of different address spaces to map to a single page frame of real storage as long as a store in the page is not attempted. Then, when a store is attempted in a particular address space, the control program

---

3. The suppression-on-protection function originated as the ESA/390 suppression-on-protection facility. Suppression for page protection (now called DAT protection) was new as part of that facility.
assigns a unique page frame to the page in that address space and copies the contents of the page to the new page frame. This last action is sometimes called the copy-on-write function. The control program sets the DAT-protection bit to one in the page-table entry for a page in order to detect an attempt to store in the page. The control program may initially set the DAT-protection bit to one in a segment-table entry to detect an attempt to store anywhere in the specified segment.

When EDAT-1 applies, and the STE-format control in the segment-table entry is one, a similar technique may be used to map a single segment frame of absolute storage. Similarly, when EDAT-2 applies, and the RTTE-format control in the region-third-table entry is one, this technique may be used to map a single region frame of absolute storage.

2. Bit 61 being one in real locations 168-175 when DAT was on indicates that the address that caused a protection exception is virtual. This indication allows programmed forms of access-register translation and dynamic address translation to be performed to determine whether the exception was due to DAT protection as opposed to low-address or key-controlled protection.

3. The results of suppression on protection are summarized in Figure 3-5.

**Enhanced Suppression on Protection**

When the enhanced suppression-on-protection function is installed, there are the following additional constraints on what may occur during a protection exception. These constraints take precedence over any constraints defined in the original suppression-on-protection function.

During a program interruption due to a protection exception, bit 61 of real locations 168-175 indicates the type of protection exception recognized. Bit 61 is set to one if the protection exception was due to access-list-controlled protection or DAT protection. Bit 61 is set to zero if the protection exception was due to low-address protection or key-controlled protection.

If a protection-exception condition exists due to either access-list-controlled protection or DAT protection but also exists due to either low-address protection or key-controlled protection, it is unpredictable which exception is recognized and whether bit 61 is set to zero or one. However, while it is unpredictable which exception is recognized, the recognized exception will produce consistent behavior as summarized in

<table>
<thead>
<tr>
<th>Exception Conditions</th>
<th>Presented Fields</th>
</tr>
</thead>
<tbody>
<tr>
<td>LA or Key-Cont. Prot.</td>
<td>ALC or DAT Prot.</td>
</tr>
<tr>
<td>No</td>
<td>On</td>
</tr>
<tr>
<td>Yes</td>
<td>On</td>
</tr>
<tr>
<td>Yes</td>
<td>Off</td>
</tr>
<tr>
<td>Yes</td>
<td>Off</td>
</tr>
<tr>
<td>Yes</td>
<td>On</td>
</tr>
<tr>
<td>Yes</td>
<td>On</td>
</tr>
</tbody>
</table>

**Explanation:**

– Immaterial or not applicable.
0R Zero because effective address is real.
1A One if bit 61 is set to one because of access-list-controlled protection; zero otherwise.
ALC Access-list-controlled.
LA Low-address.
Log. Logical.
P Predictable.
R/A Real or absolute.
U1 Unpredictable because low-address or key-controlled protection may be recognized instead of access-list-controlled or DAT protection.
U2 Unpredictable because bit 61 is only required to be set to one for access-list-controlled or DAT protection.
U3 Unpredictable because DAT is off.

*Figure 3-5. Suppression-on-Protection Results*
When the access-exception-fetch/store-indication facility is installed, for an access-list-controlled protection or a DAT protection exception, bits 52 and 53 of real locations 168-175 are handled in the same manner as described in "Access-Exception Fetch/Store Indication:" on page 3-71. When the access-exception-fetch/store-indication facility is not installed, the contents of bit positions 52 and 53 are unpredictable.

Reference recording provides information for use in selecting pages for replacement. Reference recording uses the reference bit, bit 5 of the storage key. The reference bit is set to one each time a location in the corresponding storage block is referred to either for fetching or for storing information, regardless of whether DAT is on or off.

Reference recording is always active and takes place for all storage accesses, including those made by any CPU, any operator facility, or the channel subsystem. It takes place for implicit accesses made by the machine, such as those which are part of interruptions and I/O-instruction execution.

Reference recording does not occur for operand accesses of the following instructions since they directly refer to a storage key without accessing a storage location:

- INSERT STORAGE KEY EXTENDED
- RESET REFERENCE BIT EXTENDED (reference bit is set to zero)
- RESET REFERENCE BITS MULTIPLE (reference bits of 64 consecutive 4 K-byte blocks are set to zero)
- PERFORM FRAME MANAGEMENT FUNCTION and SET STORAGE KEY EXTENDED (reference bit may be set to a specified value)

The record provided by the reference bit is substantially accurate. The reference bit may be set to one by fetching data or instructions that are neither designated nor used by the program, and, under certain conditions, a reference may be made without the reference bit being set to one. Under certain unusual circumstances, a reference bit may be set to zero by other than explicit program action.

When the CPU is in the transactional-execution mode, it is unpredictable whether the reference bit is set coincident with the transaction’s storage accesses or at the end of the transaction. Reference bits that are set during the execution of a transaction may remain set if the transaction is aborted.

Change recording provides information as to which pages have to be saved in auxiliary storage when they are replaced in main storage. Change recording uses the change bit, bit 6 of the storage key.

The change bit is set to one each time a store access causes the contents of the corresponding storage block to be changed.

The change bit is not set to one for an attempt to store if the access is prohibited. In particular:

1. For the CPU, a store access is prohibited whenever an access exception exists for that access,
or whenever an exception exists which is of higher priority than the priority of an access exception for that access.

2. For the channel subsystem, a store access is prohibited whenever a key-controlled-protection violation exists for that access.

Change recording is always active and takes place for all store accesses to storage, including those made by any CPU, any operator facility, or the channel subsystem. It takes place for implicit references made by the machine, such as those which are part of interruptions.

Change recording does not take place for the operands of the following instructions since they directly modify a storage key without modifying a storage location:

- RESET REFERENCE BIT EXTENDED
- RESET REFERENCE BITS MULTIPLE
- SET STORAGE KEY EXTENDED (change bit may be set to a specified value)

Change bits which have been changed from zeros to ones are not necessarily restored to zeros on CPU retry (see “CPU Retry” on page 11-2). See “Exceptions to Nullification and Suppression” on page 5-26 for a description of the handling of the change bit in certain unusual situations.

When the condition specified by the M3 field of a STORE ON CONDITION instruction is not met, it is model dependent whether the change bit is set for the storage location designated by the second operand.

When the CPU is in the transactional-execution mode, it is unpredictable whether the change bit is set coincident with the transaction’s store accesses or at the end of the transaction. Change bits that are set during the execution of a transaction may remain set if the transaction is aborted.

Prefixing

Prefixing provides the ability to assign the range of real addresses 0-8191 to a different block in absolute storage for each CPU, thus permitting more than one CPU sharing main storage to operate concurrently with a minimum of interference, especially in the processing of interruptions.

Prefixing causes real addresses in the range 0-8191 to correspond one-for-one to the block of 8K-byte absolute addresses (the prefix area) identified by the value in bit positions 0-50 of the prefix register for the CPU, and the block of real addresses identified by that value in the prefix register to correspond one-for-one to absolute addresses 0-8191. The remaining real addresses are the same as the corresponding absolute addresses. This transformation allows each CPU to access all of main storage, including the first 8K bytes and the locations designated by the prefix registers of other CPUs.
The relationship between real and absolute addresses is graphically depicted in Figure 3-7 on page 3-19.

The prefix is a 51-bit quantity contained in bit positions 0-50 of the prefix register. The register has the following format:

Bits 0-32 of the register are always all zeros. Bits 33-50 of the register can be set and inspected by the privileged instructions SET PREFIX and STORE PREFIX, respectively.

SET PREFIX sets bits 33-50 of the prefix register with the value in bit positions 1-18 of a word in storage, and it ignores the contents of bit positions 0 and 19-31 of the word. STORE PREFIX stores the value in bit positions 33-50 of the prefix register in bit positions 1-18 of a word in storage, and it stores zeros in bit positions 0 and 19-31 of the word.

When the contents of the prefix register are changed, the change is effective for the next sequential instruction.

When prefixing is applied, the real address is transformed into an absolute address by using one of the following rules, depending on bits 0-50 of the real address:

1. Bits 0-50 of the address, if all zeros, are replaced with bits 0-50 of the prefix.
2. Bits 0-50 of the address, if equal to bits 0-50 of the prefix, are replaced with zeros.
3. Bits 0-50 of the address, if not all zeros and not equal to bits 0-50 of the prefix, remain unchanged.

(1) Real addresses in which bits 0-50 are equal to bits 0-50 of the prefix for this CPU (A or B).

(2) Absolute addresses of the block that contains for this CPU (A or B) the real locations 0-8191.

Figure 3-7. Relationship between Real and Absolute Addresses
Only the address presented to storage is translated by prefixing. The contents of the source of the address remain unchanged.

The distinction between real and absolute addresses is made even when the prefix register contains all zeros, in which case a real address and its corresponding absolute address are identical.

### Address Spaces

An address space is a consecutive sequence of integer numbers (virtual addresses), together with the specific transformation parameters which allow each number to be associated with a byte location in storage. The sequence starts at zero and proceeds left to right.

When a virtual address is used by a CPU to access main storage, it is first converted, by means of dynamic address translation (DAT), to a real address, and then, by means of prefixing, to an absolute address. DAT may use from five to two levels of tables (region first table, region second table, region third table, segment table, and page table) as transformation parameters. The designation (origin and length) of the highest-level table for a specific address space is called an address-space-control element, and it is found for use by DAT in a control register or as specified by an access register. Alternatively, the address-space-control element for an address space may be a real-space designation, which indicates that DAT is to translate the virtual address simply by treating it as a real address and without using any tables.

DAT uses, at different times, the address-space-control elements in different control registers or specified by the access registers. The choice is determined by the translation mode specified in the current PSW. Four translation modes are available: primary-space mode, secondary-space mode, access-register mode, and home-space mode. Different address spaces are addressable depending on the translation mode.

At any instant when the CPU is in the primary-space mode or secondary-space mode, the CPU can translate virtual addresses belonging to two address spaces — the primary address space and the secondary address space. At any instant when the CPU is in the access-register mode, it can translate virtual addresses of up to 16 address spaces — the primary address space and up to 15 AR-specified address spaces. At any instant when the CPU is in the home-space mode, it can translate virtual addresses of the home address space.

The primary address space is identified as such because it consists of primary virtual addresses, which are translated by means of the primary address-space-control element (ASCE). Similarly, the secondary address space consists of secondary virtual addresses translated by means of the secondary ASCE, the AR-specified address spaces consist of AR-specified virtual addresses translated by means of AR-specified ASCEs, and the home address space consists of home virtual addresses translated by means of the home ASCE. The primary and secondary ASCEs are in control registers 1 and 7, respectively. The AR-specified ASCEs are in control registers 1 and 7 and in table entries called ASN-second-table entries. The home ASCE is in control register 13.

### Changing to Different Address Spaces

A program can cause different address spaces to be addressable by using the semiprivileged SET ADDRESS SPACE CONTROL or SET ADDRESS SPACE CONTROL FAST instruction to change the translation mode to the primary-space mode, secondary-space mode, access-register mode, or home-space mode. However, SET ADDRESS SPACE CONTROL and SET ADDRESS SPACE CONTROL FAST can set the home-space mode only in the supervisor state. The program can cause still other address spaces to be addressable by using unprivileged instructions to change the contents of the access registers and by using semiprivileged or privileged instructions to change the address-space-control elements in control registers 1 and 7. The semiprivileged instructions are ones that cause linkage from one address space to another and are the BRANCH IN SUBSPACE GROUP, PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, and SET SECONDARY ASN WITH INSTANCE instructions. The privileged instructions are the LOAD ADDRESS SPACE PARAMETERS and LOAD CONTROL instructions. Only LOAD CONTROL is available for changing the home address-space-control element in control register 13.
Address-Space Number
An address space may be assigned an address-space number (ASN) by the control program. The ASN designates, within a two-level table structure in main storage, an ASN-second-table entry containing information about the address space. If the ASN-second-table entry is marked as valid, it contains the address-space-control element that defines the address space.

Under certain circumstances, the semiprivileged instructions which place a new address-space-control element in control register 1 or 7 fetch this element from an ASN-second-table entry. Some of these instructions use an ASN-translation mechanism which, given an ASN, can locate the designated ASN-second-table entry.

The 16-bit unsigned binary format of the ASN permits 64K unique ASNs.

The ASNs for the primary and secondary address spaces are assigned positions in control registers. The ASN for the primary address space, called the primary ASN, is assigned bits 48-63 in control register 4, and that for the secondary address space, called the secondary ASN, is assigned bits 48-63 in control register 3. Bits 48-63 of these registers have the following formats:

Control Register 4

<table>
<thead>
<tr>
<th>…</th>
<th>PASN</th>
</tr>
</thead>
<tbody>
<tr>
<td>48</td>
<td>63</td>
</tr>
</tbody>
</table>

Control Register 3

<table>
<thead>
<tr>
<th>…</th>
<th>SASN</th>
</tr>
</thead>
<tbody>
<tr>
<td>48</td>
<td>63</td>
</tr>
</tbody>
</table>

A semiprivileged instruction that loads the primary or secondary address-space-control element into the appropriate control register also loads the corresponding ASN into the appropriate control register.

The ASN for the home address space is not assigned a position in a control register.

An access register containing the value 0 or 1 specifies the primary or secondary address space, respectively; and the address-space-control element specified by the access register is in control register 1 or 7, respectively. An access register containing any other value designates an entry in a table called an access list. The designated access-list entry contains the real address of an ASN-second-table entry for the address space specified by the access register. The address-space-control element specified by the access register is in the ASN-second-table entry. Translating the contents of an access register to obtain an address-space-control element for use by DAT does not involve the use of an ASN.

Note: Virtual storage consisting of byte locations ordered according to their virtual addresses in an address space is usually referred to as “storage.”

Programming Note: Because an ASN-second-table entry is located from an access-list entry by means of its address instead of by means of its ASN, the ASN-second-table entries designated by access-list entries can be “pseudo” ASN-second-table entries, that is, entries which are not in the two-level structure able to be indexed by means of the ASN-translation process. The number of unique pseudo ASN-second-table entries can be greater than the number of unique ASNs and is limited only by the amount of storage available to be occupied by the ASN-second-table entries. Thus, in a sense, there is no limit on the number of possible address spaces.

ASN-Second-Table-Entry Sequence Number

The ASN-second-table entry contains an ASN-second-table-entry sequence number (ASTESN) that may be used to control storage references to the related address space by means of an access register or through use of the SET SECONDARY ASN, SET SECONDARY ASN WITH INSTANCE, or LOAD ADDRESS SPACE PARAMETERS instruction and that may be used to control linkages to or back to the address space by means of the BRANCH IN SUBSPACE GROUP, PROGRAM CALL, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, and PROGRAM RETURN instructions. These uses of the ASTESN are described below.

When any instruction uses an access register to designate an access-list entry, which in turn designates an ASN-second-table entry, to perform a storage reference to the address space specified by the ASN-second-table entry, an ASTESN in the access-list entry is compared to the ASTESN in the ASN-second-table entry, and these ASTESNs must be equal; otherwise, an ASTE-sequence exception is recognized. This use of the ASTESN allows an access-list
entry to be made unusable if some authorization policy is changed or the designated ASN-second-table entry is reassigned to specify a conceptually different address space. The entry can be made unusable by changing the ASTESN in the ASN-second-table entry. The use is further described in “Revoking Accessing Capability:” on page 5-52.

The ASTESN is used in connection with subspace groups as follows:

- When BRANCH IN SUBSPACE GROUP uses an access register to designate an access-list entry, which in turn designates an ASN-second-table entry, to transfer control to the subspace specified by the ASN-second-table entry, an ASTESN in the access-list entry is compared to the ASTESN in the ASN-second-table entry, and these ASTESNs must be equal.

- When BRANCH IN SUBSPACE GROUP uses, in an access register, an access-list-entry token with the value 00000001 hex to transfer control to the subspace specified by the subspace-ASN-second-table-entry origin in the current dispatchable-unit control table (designated by control register 2), a subspace-ASN-second-table-entry sequence number (SSASTESN) in the dispatchable-unit control table is compared to the ASTESN in the ASN-second-table entry for the subspace, and the SSASTESN and ASTESN must be equal.

- When LOAD ADDRESS SPACE PARAMETERS, PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, or SET SECONDARY ASN WITH INSTANCE sets the primary address-space-control element in control register 1 or the secondary address-space-control element in control register 7 with bits of the address-space-control element in the ASN-second-table entry for a subspace, the SSASTESN is compared to the ASTESN in the ASN-second-table entry for the subspace, and the SSASTESN and ASTESN must be equal.

Otherwise, in all of the above three cases, an ASTE-sequence exception is recognized, except that LOAD ADDRESS SPACE PARAMETERS sets condition code 1 or 2 depending on whether the subspace is the primary address space or the secondary address space, respectively. These uses of the ASTESN allow an access-list entry and the subspace-ASN-second-table-entry origin in the current dispatchable-unit control table to be made unusable when the ASN-second-table entry either of them designates is reassigned to specify a conceptually different address space. The access-list entry and subspace-ASN-second-table-entry origin can be made unusable by changing the ASTESN in the ASN-second-table entry. The uses are further described in “Subspace Groups” on page 5-67.

Programming Note: The above operations use an ASN-second-table-entry origin in either an access-list entry or the dispatchable-unit control table; they do not use an ASN. The designated ASN-second-table entry is normally a pseudo ASN-second-table entry (one not in the structure able to be indexed by means of an ASN).

ASN-Second-Table-Entry Instance Number and ASN Reuse

The ASN-and-LX-reuse facility may be installed on the model. If this facility is installed, the ASN-second-table entry contains an ASN-second-table-entry instance number (ASTEIN), and certain new definitions related to the ASTEIN and to a new linkage-second-table-entry sequence number (LSTESN) apply. The definitions related to the ASTEIN are summarized below and also given in the appropriate sections of this publication.

- The ASN-and-LX-reuse facility includes the following new instructions:
  - EXTRACT PRIMARY ASN AND INSTANCE
  - EXTRACT SECONDARY ASN AND INSTANCE
  - PROGRAM TRANSFER WITH INSTANCE
  - SET SECONDARY ASN WITH INSTANCE

- The facility also includes the following new control bits:
  - The ASN-and-LX-reuse control (R), bit 44 of control register 0
  - The controlled-ASN bit (CA), bit 30 of word 1 of the ASN-second-table entry
  - The reusable-ASN bit (RA), bit 31 of word 1 of the ASN-second-table entry

The three control bits are shown as follows:
The facility also includes the primary ASTEIN in bit positions 0-31 of control register 4 and the secondary ASTEIN in bit positions 0-31 of control register 3. The primary ASTEIN is a copy of the ASTEIN in the ASN-second-table entry for the current primary address space specified by the PASN in control register 4, and the secondary ASTEIN is a copy of the ASTEIN in the ASN-second-table entry for the current secondary address space specified by the SASN in control register 3. The complete formats of control registers 3 and 4 are as follows:

Control Register 3

<table>
<thead>
<tr>
<th>AX</th>
<th>ATL</th>
<th>SASTEIN</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>28</td>
</tr>
<tr>
<td>32</td>
<td>48</td>
<td>63</td>
</tr>
</tbody>
</table>

Control Register 4

<table>
<thead>
<tr>
<th>PASTEIN</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>28</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>63</td>
</tr>
</tbody>
</table>

The following operations are performed if the ASN-and-LX-reuse control, bit 44 of control register 0, is one. When LOAD ADDRESS SPACE PARAMETERS, PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, or SET SECONDARY ASN (1) sets the primary ASN in control register 4 or the secondary ASN in control register 3 equal to a specified ASN and (2) sets the primary address-space-control element in control register 1 or the secondary address-space-control element in control register 7, respectively, with the value of an address-space-control element obtained from an ASN-second-table entry located by means of ASN translation of the specified ASN (or located, by PROGRAM CALL only, by means of an ASTEIN address), the instruction also sets the primary ASTEIN in control register 4 or secondary ASTEIN in control register 3, respectively, with the value of the ASTEIN in the ASN-second-table entry. However, PROGRAM TRANSFER and SET SECONDARY ASN, which are performing their space-switching operations, recognize a special-operation exception if the reusable-ASN bit, bit 31 of word 1, in the ASN-second-table entry is one.

When the ASN-and-LX-reuse control is one and any of the instructions named above or BRANCH IN SUBSPACE GROUP sets the secondary ASN and secondary address-space-control element equal to the primary ASN (in the space-switching stacking PROGRAM CALL operation, this may be the old or the new primary ASN, as determined by a bit in the entry-table entry used) and primary address-space-control element, respectively, it also sets the secondary ASTEIN in control register 3 equal to the primary ASTEIN in control register 4 (again, in the space-switching stacking PROGRAM CALL case, this may be the old or the new primary ASTEIN). Since this function does not include the accessing of an ASN-second-table entry, it is not affected by a reusable-ASN bit.

PROGRAM TRANSFER WITH INSTANCE and SET SECONDARY ASN WITH INSTANCE operate as described above except (1) independent of the value of the ASN-and-LX-reuse control (they always update the primary ASTEIN and secondary ASTEIN as described above), (2) without recognizing an exception due to the reusable-ASN bit (they ignore the bit), and (3) in their space-switching forms and the problem state at the beginning of the operation, by recognizing a special-operation exception if the controlled-ASN bit, bit 30 of word 1, is one in the ASN-second-table entry located by ASN translation. PROGRAM TRANSFER WITH INSTANCE and SET SECONDARY ASN WITH INSTANCE ignore the controlled-ASN bit if the CPU is in the supervisor state at the beginning of the operation. (PROGRAM TRANSFER WITH INSTANCE may switch the CPU from the supervisor state to the problem state.)

PROGRAM TRANSFER WITH INSTANCE and SET SECONDARY ASN WITH INSTANCE operate the same as PROGRAM TRANSFER and SET SECONDARY ASN, respectively, except as
described in the preceding item and except as follows.

Independent of the ASN-and-LX-reuse control and the reusable-ASN bit, but not of the controlled-ASN bit, each of PROGRAM TRANSFER WITH INSTANCE with space switching and SET SECONDARY ASN WITH INSTANCE with space switching, after it has used the ASN in the R_1 general register to locate an ASN-second-table entry, compares an ASTEIN in bit positions 0-31 of general register R_1 to the ASTEIN in the entry. The two ASTEINs must be equal; otherwise, an ASTE-instance exception is recognized. This comparison is performed in both the problem and the supervisor state.

- The following operations are performed if the ASN-and-LX-reuse control is one. Each of stacking PROGRAM CALL and BRANCH AND STACK places the current primary ASTEIN in bytes 180-183 of the linkage-stack state entry that it forms, and it places the current secondary ASTEIN, bits 0-31 of control register 3, in bytes 176-179 of the state entry.

Note: There is not a test of an ASTEIN related to the ASN in the entry-table entry used by PROGRAM CALL. There may be a test of a linkage-second-table-entry sequence number related to the linkage index used to locate the entry-table entry, as summarized in “ASN-and-LX-Reuse Control:” on page 5-31.

- The following operations are performed if the ASN-and-LX-reuse control is one. PROGRAM RETURN with space switching, after it has used the PASN in bytes 134 and 135 of the linkage-stack program-call state entry to locate an ASN-second-table entry (because that PASN is not equal to the current PASN in control register 4), compares the primary ASTEIN in bytes 180-183 of the state entry to the ASTEIN in the ASN-second-table entry. PROGRAM RETURN to current primary or with space switching, if it uses the SASN in bytes 130 and 131 of the state entry to locate an ASN-second-table entry (because that SASN is not equal to the new PASN), compares the secondary ASTEIN in bytes 176-179 of the state entry to the ASTEIN in the ASN-second-table entry. The one or two comparisons of ASTEINs must each give equal results; otherwise, an ASTE-instance exception is recognized. These operations occur independent of the controlled-ASN and reusable-ASN bits in the ASN-second-table entry. PROGRAM RETURN does not compare ASTEINs when it unstacks a branch state entry.

- The following format applies, and the operations are performed, if the ASN-and-LX-reuse control is one. The first operand of LOAD ADDRESS SPACE PARAMETERS is two consecutive doublewords having the following format:

First Operand of LOAD ADDRESS SPACE PARAMETERS

<table>
<thead>
<tr>
<th>0</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>63</td>
</tr>
<tr>
<td>64</td>
<td>95</td>
</tr>
<tr>
<td>96</td>
<td>127</td>
</tr>
</tbody>
</table>

If PASN translation is performed to locate an ASN-second-table entry, PASTEIN-d is compared to the ASTEIN in the ASN-second-table entry, and they must be equal; otherwise, condition code 1 is set. If SASN translation is performed to locate an ASN-second-table entry, SASTEIN-d is compared to the ASTEIN in the ASN-second-table entry, and they must be equal; otherwise, condition code 2 is set. These operations are performed independent of the controlled-ASN and reusable-ASN bits in the ASN-second-table entries.

- Independent of the ASN-and-LX-reuse control, EXTRACT PRIMARY ASN AND INSTANCE places the current primary ASN, bits 48-63 of control register 4, in bit positions 48-63 of general register R_1; places the current primary ASTEIN, bits 0-31 of control register 4, in bit positions 0-31 of the general register; and places zeros in bit positions 32-47 of the general register. EXTRACT SECONDARY ASN AND INSTANCE operates the same except that it obtains the secondary ASN and secondary ASTEIN in control register 3 for placement in the general register.

- Independent of the ASN-and-LX-reuse control, a new code, code 5, of the EXTRACT STACKED STATE instruction is valid. Code 5 causes the saved secondary ASTEIN, bytes 176-179 of the state entry, to be placed in bit positions 0-31 of
the Rₗ general register and the saved primary ASTEIN, bytes 180-183 of the state entry, to be placed in bit positions 0-31 of general register Rₗ + 1. Bits 32-63 of the general registers remain unchanged.

These uses of the ASTEIN allow, in all cases except one, an ASN associated with a particular ASTEIN to be made unusable when the ASN and the ASN-second-table entry it designates are reassigned to specify a conceptually different address space. The ASN-and-ASTEIN combination can be made unusable by (1) setting to one the reusable-ASN bit in the ASN-second-table entry, which prevents the use of PROGRAM TRANSFER and SET SECONDARY ASN, and (2) changing the ASTEIN in the ASN-second-table entry, which prevents the use of LOAD ADDRESS SPACE PARAMETERS, PROGRAM TRANSFER WITH INSTANCE, PROGRAM RETURN, and SET SECONDARY ASN WITH INSTANCE. The uncovered case is that of an ASN (and the corresponding ASN-second-table-entry address) in an entry-table entry, and this case should be handled by means of deletion, by the control program, of the entry-table entry. However, if the control program then reforms the entry-table entry (forms an entry-table entry located by means of the same PC number, used by PROGRAM CALL, as was the deleted entry-table entry), a PC number that was used to link to the conceptually deleted address space will then be usable to link to a different (different ASN) or conceptually different (same ASN but different contents) address space, and this error should be avoided by using the linkage-second-table-entry sequence number as described in "ASN-and-LX-Reuse Control:" on page 5-31.

Programming Notes:

1. The reusable-ASN bit of the ASN-and-LX-reuse facility provides reliability, availability, and serviceability. Most importantly, it provides availability since it allows ASNs to be reused. However it does not provide system integrity since the ASTEIN in the general register used by PROGRAM TRANSFER WITH INSTANCE or SET SECONDARY ASN WITH INSTANCE is provided by the program. (The authorization index used by those instructions normally provides system integrity but may fail to do so if an ASN authorized by an unchanged authorization index is reused.) The controlled-ASN bit provides system integrity since, if the CPU is in the problem state at the beginning of the operation, PROGRAM TRANSFER WITH INSTANCE and SET SECONDARY ASN WITH INSTANCE are unable to proceed successfully after accessing an ASN-second-table entry in which the controlled-ASN bit is one. When the calling program and called program are both executed in the problem state, a program in an address space for which the controlled-ASN bit is one should perform linkages to programs in other address spaces only by means of stacking PROGRAM CALL. If that is done, the return by means of PROGRAM RETURN will always be successful, or will fail appropriately when the ASN of the first address space has been changed, because of the comparison to the saved primary ASTEIN in the linkage-stack state entry.

2. A program given control by a basic PROGRAM CALL operation can use EXTRACT SECONDARY ASN AND INSTANCE to obtain the ASTEIN to be used by PROGRAM TRANSFER WITH INSTANCE to return to the calling program or by SET SECONDARY ASN WITH INSTANCE to restore its secondary address space after a change of that space. This EXTRACT SECONDARY ASN AND INSTANCE instruction should be executed while the original secondary space remains continuously the secondary space; otherwise, depending on actions by the control program, EXTRACT SECONDARY ASN AND INSTANCE may return an ASTEIN that allows return to or use of a conceptually incorrect secondary space for which the ASTEIN has been changed.

3. A summary of the functions related to ASN reuse is given in Figure 3-8 on page 3-26.

4. There are certain programming errors, or situations that are not necessarily errors, that will not be detected. These cases are described in the definitions of the named instructions and are as follows:

- In LOAD ADDRESS SPACE PARAMETERS:
  - SASN translation is performed only when, but not necessarily when, SASN-d is not equal to PASN-d. When SASN-d is equal to PASN-d, SASCE-new and SASTEIN-new are set equal to PASCE-new and PASTEIN-new, respectively. In this case, there is not a test of whether SASTEIN-d is equal to PASTEIN-d; SASTEIN-d is ignored.
When SASN-\(d\) is not equal to PASN-\(d\) and is equal to SASN-old, bit 61 (force ASN translation) is zero, and bit 63 (skip ASN authorization) is one, SASN translation is not performed, and SASCE-old and SASTEIN-old become SASCE-new and SASTEIN-new, respectively. In this case, there is not a test of whether SASTEIN-\(d\) is equal to SASTEIN-old; SASTEIN-\(d\) is ignored.

- In PROGRAM RETURN, if the new SASN is equal to the new PASN, the SASCE in control register 7 is set equal to the new PASCE in control register 1. The SASTEIN, PKM, and SASN in control register 3 remain as restored from the state entry. In this case, there is not a test of whether the new SASTEIN is equal to the new PASTEIN. (There has already been a test of whether the PASTEIN saved in the entry, which becomes the new PASTEIN, equals the ASTEIN in the new PASTE.)

- In the PROGRAM TRANSFER WITH INSTANCE to-current-primary operation, there is not a test of whether the current PASTEIN equals the ASTEIN specified in bit positions 0-31 of general register \(R_i\); the ASTEIN is ignored.

- In the SET SECONDARY ASN WITH INSTANCE to-current-primary operation, there is not a test of whether the current PASTEIN (to which the SASTEIN is set equal) equals the ASTEIN specified in bit positions 0-31 of general register \(R_i\); the ASTEIN is ignored.

<table>
<thead>
<tr>
<th>Function</th>
<th>Required Bit Value</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
</tr>
<tr>
<td>LASP, PC, and PR update PASTEIN or SASTEIN in a control register after accessing an ASN-second-table entry</td>
<td>1</td>
</tr>
<tr>
<td>PT and SSAR update PASTEIN or SASTEIN in a control register after accessing an ASN-second-table entry</td>
<td>1</td>
</tr>
<tr>
<td>BSG, LASP, PC, PR, PT, and SSAR set SASTEIN equal to PASTEIN</td>
<td>1</td>
</tr>
</tbody>
</table>

Figure 3-8. Summary of Functions Related to ASN Reuse (Part 1 of 3)

<table>
<thead>
<tr>
<th>Function</th>
<th>Required Bit Value</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
</tr>
<tr>
<td>PTI and SSAIR update PASTEIN or SASTEIN in a control register after accessing an ASN-second-table entry</td>
<td>–</td>
</tr>
<tr>
<td>PTI and SSAIR set SASTEIN equal to PASTEIN</td>
<td>–</td>
</tr>
<tr>
<td>PTI and SSAIR after accessing an ASN-second-table entry, compare ASTEIN in general register (R_i) to ASTEIN in the entry</td>
<td>–</td>
</tr>
<tr>
<td>Stacking PC and BAKR copy PASTEIN and SASTEIN from control registers to state entry</td>
<td>1</td>
</tr>
<tr>
<td>PR, after accessing an ASN-second-table entry, compares PASTEIN or SASTEIN in the state entry to ASTEIN in the ASN-second-table entry(^3)</td>
<td>1</td>
</tr>
<tr>
<td>LASP, after accessing an ASN-second-table entry, compares PASTEIN-d or SASTEIN-d to ASTEIN in the entry(^3)</td>
<td>1</td>
</tr>
<tr>
<td>EPAIR copies PASTEIN and PASN from control register 4 to general register (R_i)</td>
<td>–</td>
</tr>
<tr>
<td>ESAIR copies SASTEIN and SASN from control register 3 to general register (R_i)</td>
<td>–</td>
</tr>
</tbody>
</table>

Figure 3-8. Summary of Functions Related to ASN Reuse (Part 2 of 3)
ASN Translation

ASN translation is the process of translating a 16-bit ASN to locate the ASN-second-table entry designated by the ASN. ASN translation is performed as part of PROGRAM TRANSFER with space switching (PT-ss) PROGRAM TRANSFER WITH INSTANCE with space switching (PTI-ss), SET SECONDARY ASN with space switching (SSAR-ss), and SET SECONDARY ASN WITH INSTANCE with space switching (SSAIR-ss), and it may be performed as part of LOAD ADDRESS SPACE PARAMETERS. For PT-ss and PTI-ss the ASN which is translated replaces the primary ASN in control register 4. For SSAR-ss and SSAIR-ss, the ASN which is translated replaces the secondary ASN in control register 3. These two translation processes are called primary ASN translation and secondary ASN translation, respectively, and both can occur for LOAD ADDRESS SPACE PARAMETERS. The ASN-translation process is the same for both primary and secondary ASN translation; only the uses of the results of the process are different.

ASN translation may also be performed as part of PROGRAM RETURN. Primary ASN translation is performed as part of PROGRAM RETURN with space switching (PR-ss). Secondary ASN translation is performed if the secondary ASN restored by PROGRAM RETURN (PR-ss or PROGRAM RETURN to current primary) does not equal the primary ASN restored by PROGRAM RETURN.

PROGRAM CALL with space switching (PC-ss) performs the equivalent of primary ASN translation by obtaining a primary ASN and the address of the corresponding ASN-second-table entry from an entry-table entry.

The ASN-translation process uses two tables, the ASN first table and the ASN second table. They are used to locate the ASN-second-table entry and a third table, the authority table, which is used when ASN authorization is performed.

For the purposes of this translation, the 16-bit ASN is considered to consist of two parts: the ASN-first-table index (AFX) is the leftmost 10 bits of the ASN, and the ASN-second-table index (ASX) is the six rightmost bits. The ASN has the following format:

```
  AFX   ASX
0 10 15
```

The AFX is used to select an entry from the ASN first table. The origin of the ASN first table is designated by the ASN-first-table origin in control register 14. The ASN-first-table entry contains the origin of the ASN second table. The ASX is used to select an entry from the ASN second table.

As a result of primary ASN translation and during the operation of PROGRAM CALL with space switching, the address of the located ASN-second-table entry (ASTE) is placed in control register 5 as the new primary-ASTE origin (PASTE).
Control Register 14

<table>
<thead>
<tr>
<th></th>
<th></th>
<th>T</th>
<th>AFTO</th>
</tr>
</thead>
<tbody>
<tr>
<td>44</td>
<td>45</td>
<td>63</td>
<td></td>
</tr>
</tbody>
</table>

**ASN-Translation Control (T):** Bit 44 of control register 14 is the ASN-translation-control bit. This bit provides a mechanism whereby the control program can indicate whether ASN translation can occur while a particular program is being executed, and also whether the execution of PROGRAM CALL with space switching is allowed. Bit 44 must be one to allow completion of these instructions:

- LOAD ADDRESS SPACE PARAMETERS
- PROGRAM CALL with space switching
- PROGRAM RETURN with space switching or when the restored SASN does not equal the restored PASN
- PROGRAM TRANSFER with space switching
- PROGRAM TRANSFER WITH INSTANCE with space switching
- SET SECONDARY ASN
- SET SECONDARY ASN WITH INSTANCE

Otherwise, a special-operation exception is recognized. The ASN-translation-control bit is examined in both the problem and the supervisor states.

**ASN-First-Table Origin (AFTO):** Bits 45-63 of control register 14, with 12 zeros appended on the right, form a 31-bit real address that designates the beginning of the ASN first table.

**ASN-Translation Tables**

The ASN-translation process consists in a two-level lookup using two tables: an ASN first table and an ASN second table. These tables reside in real storage.

**ASN-First-Table Entries**

An entry in the ASN first table has the following format:

<table>
<thead>
<tr>
<th>I</th>
<th>ASTO</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

The fields in the entry are allocated as follows:

**AFX-Invalid Bit (I):** Bit 0 controls whether the ASN second table associated with the ASN-first-table entry is available. When bit 0 is zero, ASN translation proceeds by using the designated ASN second table. When the bit is one, the ASN translation cannot continue.

**ASN-Second-Table Origin (ASTO):** Bits 1-25, with six zeros appended on the right, are used to form a 31-bit real address that designates the beginning of the ASN second table.

**ASN-Second-Table Entries**

The ASN-second-table entry has a length of 64 bytes, with only the first 48 bytes currently in use. Bytes 0-47 of the entry have the following format:

<table>
<thead>
<tr>
<th>I</th>
<th>ATO</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

The entry has a length of 64 bytes, with only the first 48 bytes currently in use. Bytes 0-47 of the entry have the following format:

<table>
<thead>
<tr>
<th>AX</th>
<th>ATL</th>
<th>CR</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>48</td>
<td>60</td>
</tr>
</tbody>
</table>

The entry has a length of 64 bytes, with only the first 48 bytes currently in use. Bytes 0-47 of the entry have the following format:

<table>
<thead>
<tr>
<th>RTO, STO, or RSTKO</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
</tr>
</tbody>
</table>

The entry has a length of 64 bytes, with only the first 48 bytes currently in use. Bytes 0-47 of the entry have the following format:

<table>
<thead>
<tr>
<th>RTO/STO (Continued)</th>
</tr>
</thead>
<tbody>
<tr>
<td>96</td>
</tr>
</tbody>
</table>

The entry has a length of 64 bytes, with only the first 48 bytes currently in use. Bytes 0-47 of the entry have the following format:

<table>
<thead>
<tr>
<th>RTO/STO (Continued)</th>
</tr>
</thead>
<tbody>
<tr>
<td>96</td>
</tr>
</tbody>
</table>

The entry has a length of 64 bytes, with only the first 48 bytes currently in use. Bytes 0-47 of the entry have the following format:

<table>
<thead>
<tr>
<th>ASTESN</th>
</tr>
</thead>
<tbody>
<tr>
<td>160</td>
</tr>
</tbody>
</table>

If ASN-and-LX Reuse Is Not Enabled

<table>
<thead>
<tr>
<th>LTD</th>
</tr>
</thead>
<tbody>
<tr>
<td>192</td>
</tr>
</tbody>
</table>

If ASN-and-LX Reuse Is Enabled

<table>
<thead>
<tr>
<th>LFTD</th>
</tr>
</thead>
<tbody>
<tr>
<td>192</td>
</tr>
</tbody>
</table>

Available for programming

<table>
<thead>
<tr>
<th>224</th>
<th>255</th>
</tr>
</thead>
</table>

Available for programming

| 256 | 287 |
The fields in bytes 0-47 of the ASN-second-table entry are allocated as follows. Only the fields that are used in or as a result of ASN translation or PROGRAM CALL with space switching are described in detail.

**ASX-Invalid Bit (I):** Bit 0 controls whether the address space associated with the ASN-second-table entry is available. When bit 0 is zero, ASN translation proceeds. When the bit is one, the ASN translation cannot continue.

**Authority-Table Origin (ATO):** Bits 1-29, with two zeros appended on the right, are used to form a 31-bit real address that designates the beginning of the authority table.

**Base-Space Bit (B):** Bit 31 specifies, when one, that the address space associated with the ASN-second-table entry is the base space of a subspace group. Bit 31 is further described in “Subspace-Group ASN-Second-Table Entries” on page 5-69.

**Authorization Index (AX):** Bits 32-47 are used in ASN authorization as an index to locate the authority bits in the authority table. The AX field is used as a result of primary ASN translation by PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, and, possibly, LOAD ADDRESS SPACE PARAMETERS. It is also used by PROGRAM CALL with space switching. The AX field is ignored after secondary ASN translation.

**Authority-Table Length (ATL):** Bits 48-59 specify the length of the authority table in units of four bytes, thus making the authority table variable in multiples of 16 entries. The length of the authority table, in units of four bytes, is one more than the ATL value. The contents of the ATL field are used to establish whether the entry designated by a particular AX falls within the authority table.

**Controlled-ASN Bit (CA):** PROGRAM TRANSFER WITH INSTANCE with space switching and SET SECONDARY ASN WITH INSTANCE with space switching recognize a special-operation exception if bit 62 is one and the CPU is in the problem state at the beginning of the operation. Bit 62 is ignored in the supervisor state.

**Reusable-ASN Bit (RA):** If the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0, PROGRAM TRANSFER with space switching and SET SECONDARY ASN with space switching recognize a special-operation exception if bit 63 is one in the problem or the supervisor state.

**Address-Space-Control Element (ASCE):** Bits 64-127 are an eight-byte address-space-control element (ASCE) that may be a region-table designation (RTD), a segment-table designation (STD), or a real-space designation (RSD). (The term “region-table designation” is used to mean a region-first-table designation, region-second-table designation, or region-third-table designation.) The ASCE field is used as a result of ASN translation or in PROGRAM CALL with space switching to replace the primary ASCE (PASCE) or the secondary ASCE (SASCE). For PROGRAM CALL with space switching, the ASCE field replaces the PASCE, bits 0-63 of control register 1. For SET SECONDARY ASN, and SET SECONDARY ASN WITH INSTANCE, the ASCE field replaces the SASCE, bits 0-63 of control register 7. Each of these actions may occur independently for LOAD ADDRESS SPACE PARAMETERS. For PROGRAM TRANSFER, and PROGRAM TRANSFER WITH INSTANCE, the ASCE field replaces both the PASCE and the SASCE. For PROGRAM RETURN, as a result of primary ASN translation, the ASCE field replaces the PASCE, and, as a result of secondary ASN translation, the ASCE field replaces the SASCE. The contents of the entire ASCE field are placed in the appropriate control registers without being inspected for validity.

The subspace-group-control bit (G), bit 118 of the ASCE field, indicates, when one, that the ASCE specifies an address space that is the base space or a subspace of a subspace group. The bit is further described in “Subspace-Group ASN-Second-Table Entries” on page 5-69.

Bit 121 (X) of the ASCE field is the space-switch-event-control bit. When, in the space-switching operations of PROGRAM CALL, PROGRAM RETURN, and PROGRAM TRANSFER, and PROGRAM TRANSFER WITH INSTANCE, this bit is one in control register 1 either before or after the execution of
the instruction, a program interruption for a space-switch event occurs after the execution of the instruction is completed. A space-switch-event program interruption also occurs after the completion of a SET ADDRESS SPACE CONTROL, SET ADDRESS SPACE CONTROL FAST, or RESUME PROGRAM instruction that changes the translation mode either to or from the home-space mode when this bit is one in either control register 1 or control register 13. When, in LOAD ADDRESS SPACE PARAMETERS, this bit is one during primary ASN translation, this fact is indicated by the condition code.

The real-space-control bit (R), bit 122 of the ASCE field, indicates, when zero, that the ASCE is a region-table or segment-table designation or, when one, that the ASCE is a real-space designation.

When bit 122 is zero, the designation-type-control bits (DT), bits 124 and 125 of the ASCE field, indicate the designation type of the ASCE. A value 11, 10, 01, or 00 binary of bits 124 and 125 indicates a region-first-table designation, region-second-table designation, region-third-table designation, or segment-table designation, respectively.

The other fields in the ASCE (RTO, STO, P, S, TL, and RSTKO) are described in “Control Register 1” on page 3-39.

Access-List Designation (ALD): The access-list-designation (ALD) field is described in “ASN-Second-Table Entries” on page 5-58.

ASN-Second-Table-Entry Sequence Number (ASTESEN): The ASTE-sequence-number (ASTESEN) field is described in “ASN-Second-Table Entries” on page 5-58.

Linkage-Table Designation (LTD) or Linkage-First-Table Designation (LFTD): The linkage-table-designation (LTD) or linkage-first-table designation (LFTD) field in the ASN-second-table entry is described in “PC-Number Translation Control” on page 5-35.

ASN-Second-Table-Entry Instance Number (ASTEIN): When the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control in control register 0, bits 352-383 are compared to an ASTEIN specified along with an ASN for use by PROGRAM RETURN or LOAD ADDRESS SPACE PARAMETERS. The ASTEINs must be equal; otherwise, an ASTE-instance exception is recognized by PROGRAM RETURN or condition code 1 or 2 is set by LOAD ADDRESS SPACE PARAMETERS. This comparison and the exception result also occur in the operations of PROGRAM TRANSFER WITH INSTANCE and SET SECONDARY ASN WITH INSTANCE except independent of the ASN-and-LX-reuse control.

Bits 224-319 in the ASN-second-table entry are available for use by programming.

Programming Note: All unused fields in the ASN-second-table entry, including the unused fields in bytes 0-31 and all of bytes 40-43 and 48-63 should be set to zeros. These fields are reserved for future extensions, and programs which place nonzero values in these fields may not operate compatibly on future machines.

ASN-Translation Process

This section describes the ASN-translation process as it is performed during the execution of the space-switching forms of PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, and SET SECONDARY ASN WITH INSTANCE, and also in PROGRAM RETURN when the restored secondary ASN does not equal the restored primary ASN. ASN translation for LOAD ADDRESS SPACE PARAMETERS is the same except that AFX-translation and ASX-translation exceptions do not occur; such conditions are instead indicated by the condition code. Translation of an ASN is performed by means of two tables, an ASN first table and an ASN second table, both of which reside in main storage.

The ASN first index is used to select an entry from the ASN first table. This entry designates the ASN second table to be used.

The ASN second index is used to select an entry from the ASN second table.

If the I bit is one in either the ASN-first-table entry or the ASN-second-table entry, the entry is invalid, and the ASN-translation process cannot be completed. An AFX-translation exception or ASX-translation exception is recognized.

Whenever access to main storage is made during the ASN-translation process for the purpose of fetching
an entry from an ASN first table or ASN second table, key-controlled protection does not apply.

The ASN-translation process is shown in Figure 3-9 on page 3-31.

**Figure 3-9. ASN Translation**

**ASN-First-Table Lookup**

The AFX portion of the ASN, in conjunction with the ASN-first-table origin, is used to select an entry from the ASN first table.

The 31-bit real address of the ASN-first-table entry is obtained by appending 12 zeros on the right to the AFT origin contained in bit positions 45-63 of control register 14 and adding the AFX portion with two rightmost and 19 leftmost zeros appended. This addition cannot cause a carry into bit position 0. The 31-bit address is formed and used regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

All four bytes of the ASN-first-table entry appear to be fetched concurrently as observed by other CPUs. The fetch access is not subject to protection. When the storage address which is generated for fetching the ASN-first-table entry designates a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

Bit 0 of the four-byte AFT entry specifies whether the corresponding AST is available. If this bit is one, an AFX-translation exception is recognized. The entry fetched from the AFT is used to access the AST.
ASN-Second-Table Lookup
The ASX portion of the ASN, in conjunction with the
ASN-second-table origin contained in the ASN-first-
table entry, is used to select an entry from the ASN
second table.

The 31-bit real address of the ASN-second-table
entry is obtained by appending six zeros on the right
to bits 1-25 of the ASN-first-table entry and adding
the ASX with six rightmost and 19 leftmost zeros
appended. When a carry into bit position 0 occurs
during the addition, an addressing exception may be
recognized, or the carry may be ignored, causing the
table to wrap from $2^{31} - 1$ to zero. The 31-bit address
is formed and used regardless of whether the current
PSW specifies the 24-bit, 31-bit, or 64-bit addressing
mode.

The fetch of the 64 bytes of the ASN-second-table
entry appears to be word concurrent as observed by
other CPUs, with the leftmost word fetched first. The
order in which the remaining 15 words are fetched is
unpredictable. The fetch access is not subject to pro-
tection. When the storage address which is gener-
ated for fetching the ASN-second-table entry
designates a location which is not available in the
configuration, an addressing exception is recognized,
and the operation is suppressed.

Bit 0 of the ASN-second-table entry specifies
whether the address space is accessible. If this bit is
one, an ASX-translation exception is recognized.

Recognition of Exceptions during ASN
Translation
The exceptions which can be encountered during the
ASN-translation process are collectively referred to
as ASN-translation exceptions. A list of these excep-
tions and their priorities is given in Chapter 6, “Inter-
ruptions”.

ASN Authorization
ASN authorization is the process of testing whether
the program associated with the current authorization
index is permitted to establish a particular address
space. The ASN authorization is performed as part of
PROGRAM TRANSFER with space switching (PT-
s), PROGRAM TRANSFER WITH INSTANCE with
space switching (PTI-ss), SET SECONDARY ASN
with space switching (SSAR-ss), and SET SECOND-
ARY ASN WITH INSTANCE with space switching
(SSAIR-ss), and may be performed as part of LOAD
ADDRESS SPACE PARAMETERS. ASN authoriza-
tion is performed after the ASN-translation process
for these instructions.

ASN authorization is also performed as part of PRO-
GRAM RETURN when the restored secondary ASN
does not equal the restored primary ASN. ASN
authorization of the restored secondary ASN is per-
fomed after ASN translation of the restored second-
ary ASN.

When performed as part of PT-ss or PTI-ss, the ASN
authorization tests whether the ASN can be estab-
lished as the primary ASN and is called primary-ASN
authorization. When performed as part of LOAD
ADDRESS SPACE PARAMETERS, PROGRAM
RETURN, SSAR-ss, or SSAIR-ss, the ASN authori-
ization tests whether the ASN can be established as
the secondary ASN and is called secondary-ASN
authorization.

The ASN authorization is performed by means of an
authority table in real storage which is designated by
the authority-table-origin and authority-table-length
fields in the ASN-second-table entry.

ASN-Authorization Controls
ASN authorization uses the authority-table origin and
the authority-table length from the ASN-second-table
entry, together with an authorization index.

Control Register 4
For PT-ss, PTI-ss, SSAR-ss, and SSAIR-ss, the cur-
rent contents of control register 4 include the authori-
zation index. For LOAD ADDRESS SPACE
PARAMETERS and PROGRAM RETURN, the value
which will become the new contents of control regis-
ter 4 is used. The register has the following format:

```
<table>
<thead>
<tr>
<th>32</th>
<th>48</th>
</tr>
</thead>
<tbody>
<tr>
<td>AX</td>
<td></td>
</tr>
</tbody>
</table>
```

**Authorization Index (AX):** Bits 32-47 of control
register 4 are used as an index to locate the authority
bits in the authority table.

ASN-Second-Table Entry
The ASN-second-table entry which is fetched as part
of the ASN translation process contains information
which is used to designate the authority table. An entry in the ASN second table has the following format:

<table>
<thead>
<tr>
<th>P</th>
<th>S</th>
</tr>
</thead>
</table>
| 0 | 1

**Authority-Table Origin (ATO):** Bits 1-29, with two zeros appended on the right, are used to form a 31-bit real address that designates the beginning of the authority table.

**Authority-Table Length (ATL):** Bits 48-59 specify the length of the authority table in units of four bytes, thus making the authority table variable in multiples of 16 entries. The length of the authority table, in units of four bytes, is equal to one more than the ATL value. The contents of the length field are used to establish whether the entry designated by the authorization index falls within the authority table.

**Authority-Table Entries**

The authority table consists of entries of two bits each; accordingly, each byte of the authority table contains four entries in the following format:

<table>
<thead>
<tr>
<th>P</th>
<th>S</th>
<th>P</th>
<th>S</th>
<th>P</th>
<th>S</th>
</tr>
</thead>
</table>
| 0 | 7

**Primary Authority (P):** The left bit of an authority-table entry controls whether the program with the authorization index corresponding to the entry is permitted to establish the address space as a primary address space. If the P bit is one, the establishment is permitted. If the P bit is zero, the establishment is not permitted.

**Secondary Authority (S):** The right bit of an authority-table entry controls whether the program with the corresponding authorization index is permitted to establish the address space as a secondary address space. If the S bit is one, the establishment is permitted. If the S bit is zero, the establishment is not permitted.

The authority table is also used in the extended-authorization process, as part of access-register translation. Extended authorization is described in “Authorizing the Use of the Access-List Entry” on page 5-64.

**ASN-Authorization Process**

This section describes the ASN-authorization process as it is performed during the execution of PROGRAM TRANSFER with space switching, PROGRAM TRANSFER WITH INSTANCE with space switching, SET SECONDARY ASN with space switching, and SET SECONDARY ASN WITH INSTANCE with space switching. For these two instructions, the ASN-authorization process is performed by using the authorization index currently in control register 4. Secondary authorization for PROGRAM RETURN, when the restored secondary ASN does not equal the restored primary ASN, and for LOAD ADDRESS SPACE PARAMETERS is the same, except that the value which will become the new contents of control register 4 is used for the authorization index. Also, for LOAD ADDRESS SPACE PARAMETERS, a secondary-authority exception does not occur. Instead, such a condition is indicated by the condition code.

The ASN-authorization process is performed by using the authorization index, in conjunction with the authority-table origin and length from the AST entry, to select an authority-table entry. The entry is fetched, and either the primary- or the secondary-authority bit is examined, depending on whether the primary- or secondary-ASN-authorization process is being performed. The ASN-authorization process is shown in Figure 3-10.

**Authority-Table Lookup**

The authorization index, in conjunction with the authority-table origin contained in the ASN-second-table entry, is used to select an entry from the authority table.

The authorization index is contained in bit positions 32-47 of control register 4.

Bit positions 1-29 of the AST entry contain the leftmost 29 bits of the 31-bit real address of the authority table (ATO), and bit positions 48-59 contain the length of the authority table (ATL).

The 31-bit real address of a byte in the authority table is obtained by appending two zeros on the right to the authority-table origin and adding the 14 leftmost
bits of the authorization index with 17 zeros appended on the left. When a carry into bit position 0 occurs during the addition, an addressing exception may be recognized, or the carry may be ignored, causing the table to wrap from $2^{31}-1$ to zero. The 31-bit address is formed and used regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

As part of the authority-table-entry-lookup process, bits 0-11 of the authorization index are compared against the authority-table length. If the compared portion is greater than the authority-table length, a primary-authority exception or secondary-authority exception is recognized for PT-ss, PTI-ss, SSAR-ss, or SSAIR-ss, respectively. For LOAD ADDRESS SPACE PARAMETERS, when the authority-table length is exceeded, condition code 2 is set.

The fetch access to the byte in the authority table is not subject to protection. When the storage address which is generated for fetching the byte designates a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

The byte contains four authority-table entries of two bits each. The rightmost two bits of the authorization index, bits 46 and 47 of control register 4, are used to select one of the four entries. The left or right bit of the entry is then tested, depending on whether the authorization test is for a primary ASN or a secondary ASN. The following table shows the bit which is selected from the byte as a function of bits 46 and 47 of the authorization index and the instruction PT-ss,
PTI-ss, SSAR-ss, SSAIR-ss, PROGRAM RETURN, or LOAD ADDRESS SPACE PARAMETERS.

If the selected bit is one, the ASN is authorized, and the appropriate fields in the AST entry are loaded into the appropriate control registers. If the selected bit is zero, the ASN is not authorized, and a primary-authority exception is recognized for PT-ss or PTI-ss, or a secondary-authority exception is recognized for SSAR-ss, SSAIR-ss, or PROGRAM RETURN. For LOAD ADDRESS SPACE PARAMETERS, when the ASN is not authorized, condition code 2 is set.

### Recognition of Exceptions during ASN Authorization

The exceptions which can be encountered during the primary- and secondary-ASN-authorization processes and their priorities are described in the definitions of the instructions in which ASN authorization is performed.

**Programming Note:** The primary- and secondary-authority exceptions cause nullification in order to permit dynamic modification of the authority table. Thus, when an address space is created or “swapped in,” the authority table can first be set to all zeros and the appropriate authority bits set to one only when required.

### Dynamic Address Translation

Dynamic address translation (DAT) provides the ability to interrupt the execution of a program at an arbitrary moment, record it and its data in auxiliary storage, such as a direct-access storage device, and at a later time return the program and the data to different main-storage locations for resumption of execution. The transfer of the program and its data between main and auxiliary storage may be performed piecemeal, and the return of the information to main storage may take place in response to an attempt by the CPU to access it at the time it is needed for execution. These functions may be performed without change or inspection of the program and its data, do not require any explicit programming convention for the relocated program, and do not disturb the execution of the program except for the time delay involved.

With appropriate support by an operating system, the dynamic-address-translation facility may be used to provide to a user a system wherein storage appears to be larger than the main storage which is available in the configuration. This apparent main storage is referred to as virtual storage, and the addresses used to designate locations in the virtual storage are referred to as virtual addresses. The virtual storage of a user may far exceed the size of the main storage which is available in the configuration and normally is maintained in auxiliary storage. The virtual storage is considered to be composed of blocks of addresses, called pages. Only the most recently referred-to pages of the virtual storage are assigned to occupy blocks of physical main storage. As the user refers to pages of virtual storage that do not appear in main storage, they are brought in to replace pages in main storage that are less likely to be needed. The swapping of pages of storage may be performed by the operating system without the user’s knowledge.

The sequence of virtual addresses associated with a virtual storage is called an address space. With appropriate support by an operating system, the dynamic-address-translation facility may be used to provide a number of address spaces. These address spaces may be used to provide degrees of isolation between users. Such support can consist of a completely different address space for each user, thus providing complete isolation, or a shared area may be provided by mapping a portion of each address space to a single common storage area. Also, instructions are provided which permit a semiprivileged program to access more than one such address space. Dynamic address translation provides for the translation of virtual addresses from multiple different address spaces without requiring that the translation parameters in the control registers be changed. These address spaces are called the primary address space, secondary address space, and AR-specified address spaces. A privileged program can also cause the home address space to be accessed.

In the process of replacing blocks of main storage by new information from an external medium, it must be
determined which block to replace and whether the block being replaced should be recorded and preserved in auxiliary storage. To aid in this decision process, a reference bit and a change bit are associated with the storage key.

Dynamic address translation may be specified for instruction and data addresses generated by the CPU but is not available for the addressing of data and of CCWs, IDAWs, and MIDAWs in I/O operations. The CCW-indirect-data-addressing facility and modified-CCW-indirect-data-addressing facilities are provided to aid I/O operations in a virtual-storage environment.

Address computation can be carried out in the 24-bit, 31-bit, or 64-bit addressing mode. When address computation is performed in the 24-bit or 31-bit addressing mode, 40 or 33 zeros, respectively, are appended on the left to form a 64-bit address. Therefore, the resultant logical address is always 64 bits in length. The real or absolute address that is formed by dynamic address translation, and the absolute address that is then formed by prefixing, are always 64 bits in length.

Dynamic address translation is the process of translating a virtual address during a storage reference into the corresponding real or absolute address. The virtual address may be a primary virtual address, secondary virtual address, AR-specified virtual address, or home virtual address. These addresses are translated by means of the primary, the secondary, an AR-specified, or the home address-space-control element, respectively. After selection of the appropriate address-space-control element, the translation process is the same for all of the four types of virtual address. An address-space-control element may be a segment-table designation specifying a 2G-byte address space, a region-table designation specifying a 4T-byte, 8P-byte, or 16E-byte space, or a real-space designation specifying a 16E-byte space. (The letters K, M, G, T, P, and E represent kilo, 2^10, mega, 2^20, giga, 2^30, tera, 2^40, peta, 2^50, and exa, 2^60, respectively.) A segment-table designation or region-table designation causes translation to be performed by means of tables established by the operating system in real or absolute storage. A real-space designation causes the virtual address simply to be treated as a real address, without the use of tables in storage.

In the process of translation when using a segment-table designation or a region-table designation, three types of units of information are recognized—regions, segments, and pages. A region is a block of sequential virtual addresses spanning 2G bytes and beginning at a 2G-byte boundary. A segment is a block of sequential virtual addresses spanning 1M bytes and beginning at a 1M-byte boundary. A page is a block of sequential virtual addresses spanning 4K bytes and beginning at a 4K-byte boundary.

The virtual address, accordingly, is divided into four principal fields. Bits 0-32 are called the region index (RX), bits 33-43 are called the segment index (SX), bits 44-51 are called the page index (PX), and bits 52-63 are called the byte index (BX). The virtual address has the following format:

<table>
<thead>
<tr>
<th>RX</th>
<th>SX</th>
<th>PX</th>
<th>BX</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>33</td>
<td>44</td>
<td>52</td>
</tr>
</tbody>
</table>

As determined by its address-space-control element, a virtual address space may be a 2G-byte space consisting of one region, or it may be up to a 16E-byte space consisting of up to 8G regions. The RX part of a virtual address applying to a 2G-byte address space must be all zeros; otherwise, an exception is recognized.

The RX part of a virtual address is itself divided into three fields. Bits 0-10 are called the region first index (RFX), bits 11-21 are called the region second index (RSX), and bits 22-32 are called the region third index (RTX). Bits 0-32 of the virtual address have the following format:

<table>
<thead>
<tr>
<th>RFX</th>
<th>RSX</th>
<th>RTX</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>11</td>
<td>22</td>
</tr>
</tbody>
</table>

A virtual address in which the RTX is the leftmost significant part (a 42-bit address) is capable of addressing 4T bytes (2K regions), one in which the RSX is the leftmost significant part (a 53-bit address) is capable of addressing 8P bytes (4M regions), and one in which the RFX is the leftmost significant part (a 64-bit address) is capable of addressing 16E bytes (8G regions).

A virtual address in which the RX is always zero can be translated into real addresses by means of one or two translation tables, as follows:

- When enhanced DAT does not apply, or when enhanced DAT applies but the STE-format control, bit 53 of the segment-table entry, is zero, the
virtual address can be translated by means of a segment table and a page table.

- When enhanced DAT applies and the STE-format control of the segment-table entry is one, the virtual address can be translated by means of a segment table only.

If the RX may be nonzero, from one to three additional translation tables are required, as follows. If the RFX may be nonzero, a region first table, region second table, and region third table are required. If the RFX is always zero but the RSX may be nonzero, a region second table and region third table are required. If the RFX and RSX are always zero but the RTX may be nonzero, a region third table is required. An exception is recognized if the address-space-control element for an address space does not designate the highest level of table (beginning with the region first table and continuing downward to the segment table) needed to translate a reference to the address space.

A region first table, region second table, or region third table is sometimes referred to simply as a region table. Similarly, a region-first-table designation, region-second-table designation, or region-third-table designation is sometimes referred to as a region-table designation.

The region, segment, and, when applicable, page tables reflect the current assignment of real or absolute storage.

When EDAT-1 does not apply, or when EDAT-1 applies but the STE-format control, bit 53 of the segment-table entry, is zero, the assignment of real storage occurs in units of pages, the real locations being assigned contiguously within a page. The pages need not be adjacent in real storage even though assigned to a set of sequential virtual addresses.

When EDAT-1 applies and the STE-format control of the segment-table entry is one, the assignment of real storage occurs in units of segments, the absolute locations being assigned contiguously within a segment. The segments need not be adjacent in absolute storage even though assigned to a set of sequential virtual addresses.

Similarly, when EDAT-2 applies and the RTTE-format control of the region-third-table entry is one, the assignment of real storage occurs in units of regions, the absolute locations being assigned contiguously within a region. The regions need not be adjacent in absolute storage even though assigned to a set of sequential virtual addresses.

To improve performance, translation normally is performed by means of table copies maintained in a special buffer called the translation-lookaside buffer (TLB). The TLB may also contain entries that provide the virtual-equals-real translation specified by a real-space designation.

Translation Control

Address translation is controlled by three bits in the PSW and by a set of bits referred to as the translation parameters. The translation parameters are in control registers 0, 1, 7, and 13. Additional controls are located in the translation tables.

Additional controls are provided as described in Chapter 5, “Program Execution.” These controls determine whether the contents of each access register can be used to obtain an address-space-control element for use by DAT.

Translation Modes

The three bits in the PSW that control dynamic address translation are bit 5, the DAT-mode bit, and bits 16 and 17, the address-space-control bits. When the DAT-mode bit is zero, then DAT is off, and the CPU is in the real mode. When the DAT-mode bit is one, then DAT is on, and the CPU is in the translation mode designated by the address-space-control bits: 00 designates the primary-space mode, 01 designates the access-register mode, 10 designates the secondary-space mode, and 11 designates the home-space mode.

For certain instructions such as LOAD PAGE TABLE ENTRY ADDRESS, LOAD REAL ADDRESS and STORE REAL ADDRESS, and for monitor-event counting operations, dynamic address translation is performed even when the DAT-mode bit in the PSW is off.

The various modes are shown in Figure 3-11, along with the handling of addresses in each mode.

Control Register 0

Bit 37 is provided in control register 0 for use in controlling dynamic address translation. When the enhanced-DAT facility is installed, bit 40 is also pro-
vided for use in controlling dynamic-address translation. The bit assignments are as follows:

<table>
<thead>
<tr>
<th>PSW Bit</th>
<th>DAT Mode</th>
<th>Instruction Addresses</th>
<th>Logical Addresses</th>
</tr>
</thead>
<tbody>
<tr>
<td>5 16 17</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 0 0 0</td>
<td>Off</td>
<td>Real mode</td>
<td>Real</td>
</tr>
<tr>
<td>0 0 0 1</td>
<td>Off</td>
<td>Real mode</td>
<td>Real</td>
</tr>
<tr>
<td>0 1 0 0</td>
<td>Off</td>
<td>Real mode</td>
<td>Real</td>
</tr>
<tr>
<td>0 1 1 0</td>
<td>Off</td>
<td>Real mode</td>
<td>Real</td>
</tr>
<tr>
<td>1 0 0 0</td>
<td>On</td>
<td>Primary-space mode</td>
<td>Primary virtual</td>
</tr>
<tr>
<td>1 0 1 0</td>
<td>On</td>
<td>Access-register mode</td>
<td>Primary virtual</td>
</tr>
<tr>
<td>1 1 0 0</td>
<td>On</td>
<td>Secondary-space mode</td>
<td>Primary virtual</td>
</tr>
<tr>
<td>1 1 1 0</td>
<td>On</td>
<td>Home-space mode</td>
<td>Home virtual</td>
</tr>
</tbody>
</table>

**Secondary-Space Control (SS):** Bit 37 of control register 0 is the secondary-space-control bit. When this bit is zero and execution of MOVE TO PRIMARY, MOVE TO SECONDARY, or SET ADDRESS SPACE CONTROL is attempted, a special-operation exception is recognized. A special-operation exception is also recognized when this bit is zero, execution of MOVE WITH OPTIONAL SPECIFICATIONS is attempted, and the operand-access control for either operand designates the secondary space. When this bit is one, it indicates that the region table or segment table designated by the secondary address-space-control element is attached when the CPU is in the primary-space mode.

**Enhanced-DAT-Enablement Control (ED):** When the enhanced-DAT facility 1 is installed, bit 40 of control register 0 is the enhanced-DAT-enablement control. When this bit is zero, dynamic address translation proceeds as though the enhanced-DAT facility was not installed. When the bit is one, the following conditions apply:

- The DAT-protection bit is defined in bit position 54 of each region-table entry.
- The STE-format control is defined in bit position 53 of the segment-table entry. When the STE-format control is zero, bits 0-52 of the segment-table entry are used to locate the page table (as occurs when the enhanced-DAT facility 1 is not installed or enabled)

When the STE-format control is one, the following apply:

- Bits 0-43 of the segment-table entry form the segment-frame absolute address. There is no designation of a page table, and no page-table entries are used.
- Bit 47 of the segment-table entry determines the validity of the access-control bits and fetch-protection bit (in bits 48-52 of the STE).
- Bits 48-52 of the segment-table entry contain access-control bits and a fetch-protection bit for the segment.

When the enhanced-DAT facility 1 is not installed, bit 40 of control register 0 is reserved and should contain zero; otherwise, the program may not operate compatibly in the future.

When the enhanced-DAT facility 2 is installed, and the enhanced-DAT-enablement control is one, the RTTE-format control is defined in bit position 53 of the region-third-table entry. When the RTTE-format control is zero, bits 0-51 of the region-third-table entry are used to locate the segment table (as occurs when the enhanced-DAT facility 2 is not installed). When the RTTE-format control is one, the following apply:

- Bits 0-32 of the region-third-table entry form the region-frame absolute address. There is no designation of a segment table, and no segment-table entries are used.
- Bit 47 of the region-third-table entry determines the validity of the access-control bits and fetch-protection bit (in bits 48-52 of the RTTE).
- Bits 48-52 of the region-third-table entry contain access-control bits and a fetch-protection bit for the region.

When the enhanced-DAT facility 2 is installed, the enhanced-DAT facility 1 is also installed.

**Enhanced-DAT Terminology:** For the purpose of brevity, the following terms are used in conjunction with the enhanced-DAT facilities:
• The term “EDAT-1 applies” refers to the case where all of the following are true:
  – The enhanced-DAT facility 1 is installed.
  – The enhanced-DAT-enablement control, bit 40 of control register 0, is one.
  – The address is translated by means of DAT-table entries.

• The term “EDAT-2 applies” refers to the case where both of the following are true:
  – The enhanced-DAT facility 2 is installed.
  – EDAT-1 applies.

• The term “EDAT-1 does not apply” refers to the case where any of the following are true:
  – The enhanced-DAT facility 1 is not installed.
  – The enhanced-DAT facility 1 is installed, but the enhanced-DAT-enablement control is zero.
  – The address is not translated by means of DAT-table entries (that is, DAT is off and is not being used implicitly; DAT is on, but the ASCE designates a real space; or the instruction uses a real address such as LOAD USING REAL ADDRESS or STORE USING REAL ADDRESS).
  – A real address is implicitly used, for example in the handling of an interruption, CPU logout, or fetching of table entries for ART, ASN translation, ASN authorization, DAT, or PC-number translation.

• The term “EDAT-2 does not apply” refers to the case where either of the following is true:
  – EDAT-1 does not apply
  – The enhanced-DAT facility 2 is not installed.

Programming Notes:

1. Before DAT is enabled or implicitly performed (such as in LOAD REAL ADDRESS), the program should ensure that the enhanced-DAT-enablement control is consistent with the enhanced-DAT-enablement control in any other CPU in the configuration that may be performing DAT for the same address space.

2. If the program changes the state of the enhanced-DAT-enablement control, then it should also issue an instruction to clear the TLB of the CPU.

Failure to follow these rules may result in unpredictable results, including the possibility of a delayed-access machine-check condition being recognized.

Control Register 1

Control register 1 contains the primary address-space-control element (PASCE). The register has one of the following two formats, depending on the real-space-control bit (R) in the register:

Primary Region-Table or Segment-Table Designation (R=0)

Primary Real-Space Designation (R=1)

The fields in the primary address-space-control element are allocated as follows:

Primary Region-Table or Segment-Table Origin

Primary Real-Space Token Origin

Primary Subspace-Group Control (G): Bit 54 of control register 1, when one, indicates that the address space specified by the PASCE is the base space or a subspace of a subspace group. When bit 54 is zero, the address space is not in a subspace group.

Primary Private-Space Control (P): If bit 55 of control register 1 is one, then (1) a one value of the common-segment bit in a translation-lookaside-buffer (TLB) representation of a segment-table entry prevents the entry and any TLB page-table copy it desig-
nates from being used when translating references to the primary address space, even with a match between the table or token origin in control register 1 and the table origin in the TLB entry, (2) low-address protection and fetch-protection override do not apply to the primary address space; and (3) a translation-specification exception is recognized if a reference to the primary address space is translated by means of a segment-table entry in storage and the common-segment bit is one in the entry. Item 2 in the above list applies even when the contents of control register 1 are a real-space designation.

When EDAT-2 applies and bit 55 of control register 1 is one, then (1) a one value of the common-region bit in a translation-lookaside-buffer (TLB) representation of a region-third-table entry prevents the entry and any TLB segment- and page-table copy it designates from being used when translating references to the primary address space, even with a match between the table or token origin in control register 1 and the table origin in the TLB entry, (2) low-address protection and fetch-protection override do not apply to the primary address space; and (3) a translation-specification exception is recognized if a reference to the primary address space is translated by means of a region-third-table entry in storage and the common-region bit is one in the entry. Item 2 in the above list applies even when the contents of control register 1 are a real-space designation.

Programming Note: With respect to item 1 in the above lists, when the contents of control register 1 are a real-space designation, a one value of the common-segment bit in a TLB representation of a segment-table entry prevents the entry and any TLB page-table copy it designates from being used regardless of the value of the private-space control in the real-space designation. Similarly, when EDAT-2 applies and the contents of control register 1 are a real-space designation, a one value of the common-region bit in a TLB representation of a region-third-table entry prevents the entry and any TLB segment- and page-table copies it designates from being used regardless of the value of the private-space control in the real-space designation.

**Primary Storage-Alteration-Event Control (S):** When the storage-alteration-space control in control register 9 is one, bit 56 of control register 1 specifies, when one, that the primary address space is one for which storage-alteration events can occur. Bit 56 is examined when the PASCE is used to perform dynamic-address translation for a storage-operand store reference. Bit 56 is ignored when the storage-alteration-space control is zero.

**Primary Space-Switch-Event Control (X):** When bit 57 of control register 1 is one:

- A space-switch-event program interruption occurs when execution of the space-switching form of PROGRAM CALL (PC-ss), PROGRAM RETURN (PR-ss), or PROGRAM TRANSFER (PT-ss) is completed. The interruption occurs if bit 57 is one either before or after the operation.

- A space-switch-event program interruption occurs upon completion of a RESUME PROGRAM, SET ADDRESS SPACE CONTROL, or SET ADDRESS SPACE CONTROL FAST instruction that changes the address space from which instructions are fetched either to or from the home address space; that is, when instructions are fetched from the home address space either before or after the operation but not both before and after the operation.

- Condition code 3 is set by LOAD ADDRESS SPACE PARAMETERS.

**Primary Real-Space Control (R):** If bit 58 of control register 1 is zero, the register contains a region-table or segment-table designation. If bit 58 is one, the register contains a real-space designation. When bit 58 is one, a one value of the common-segment bit in a translation-lookaside-buffer (TLB) representation of a segment-table entry prevents the entry and any TLB page-table copy it designates from being used when translating references to the primary address space, even with a match between the table or token origin in control register 1 and the table origin in the TLB entry. Similarly, when EDAT-2 applies and bit 58 is one, a one value of the common-region bit in a translation-lookaside-buffer (TLB) representation of a region-third-table entry prevents the entry and any TLB segment- and page-table copies it designates from being used when translating references to the primary address space, even with a match between the token origin in control register 1 and the table origin in the TLB entry.

**Primary Designation-Type Control (DT):** When R is zero, the type of table designation in control regis-
ter 1 is specified by bits 60 and 61 in the register, as follows:

<table>
<thead>
<tr>
<th>Bits 60 and 61</th>
<th>Designation Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>11</td>
<td>Region-first-table</td>
</tr>
<tr>
<td>10</td>
<td>Region-second-table</td>
</tr>
<tr>
<td>01</td>
<td>Region-third-table</td>
</tr>
<tr>
<td>00</td>
<td>Segment-table</td>
</tr>
</tbody>
</table>

When R is zero, bits 60 and 61 must be 11 binary when an attempt is made to use the PASCE to translate a virtual address in which the leftmost one bit is in bit positions 0-10 of the address. Similarly, bits 60 and 61 must be 11 or 10 binary when the leftmost one bit is in bit positions 11-21 of the address, and they must be 11, 10, or 01 binary when the leftmost one bit is in bit positions 22-32 of the address. Otherwise, an ASCE-type exception is recognized.

**Primary Region-Table or Segment-Table Length (TL):** Bits 62 and 63 of the primary region-table designation or segment-table designation in control register 1 specify the length of the primary region table or segment table in units of 4,096 bytes, thus making the length of the region table or segment table variable in multiples of 512 entries. The length of the primary region table or segment table, in units of 4,096 bytes, is one more than the TL value. The contents of the length field are used to establish whether the portion of the virtual address (RFX, RSX, RTX, or SX) to be translated by means of the table designates an entry that falls within the table.

**Primary Real-Space Token Origin:** Bits 0-51 of the primary real-space designation in control register 1, with 12 zeros appended on the right, form a 64-bit address that may be used in forming and using TLB entries that provide a virtual-equals-real translation for references to the primary address space. Although this address is used only as a token and is not used to perform a storage reference, it still must be a valid address; otherwise, an incorrect TLB entry may be used when the contents of control register 1 are used.

The following bits of control register 1 are not assigned and are ignored: bits 52, 53, and 59 if the register contains a region-table designation or segment-table designation, and bits 52, 53 and 59-63 if the register contains a real-space designation.

**Control Register 7**
Control register 7 contains the secondary address-space-control element (SASCE). The register has one of the following two formats, depending on the real-space-control bit (R) in the register:

**Secondary Region-Table or Segment-Table Designation (R=0)**

<table>
<thead>
<tr>
<th>Secondary Region-Table or Segment-Table Origin</th>
</tr>
</thead>
<tbody>
<tr>
<td>32 52 54 55 56 57 58 59 60 62 63</td>
</tr>
<tr>
<td>GPS  R  DT  TL</td>
</tr>
</tbody>
</table>

**Secondary Real-Space Designation (R=1)**

<table>
<thead>
<tr>
<th>Secondary Real-Space Token Origin</th>
</tr>
</thead>
<tbody>
<tr>
<td>32 52 54 55 56 57 58 59 63</td>
</tr>
<tr>
<td>GPS  R</td>
</tr>
</tbody>
</table>

The secondary region-table origin, secondary segment-table origin, secondary subspace-group control (G), secondary private-space control (P), secondary storage-alteration-event control (S), secondary real-space control (R), secondary designation-type control (DT), secondary region-table or segment-table length (TL), and secondary real-space token origin in control register 7 are defined the same as the fields in the same bit positions in control register 1, except that control register 7 applies to the secondary address space.

The following bits of control register 7 are not assigned and are ignored: bits 52, 53, 57, and 59 if the register contains a region-table designation or segment-table designation, and bits 52, 53, 57, and 59-63 if the register contains a real-space designation.

**Control Register 13**
Control register 13 contains the home address-space-control element (HASCE). The register has one of the following two formats, depending on the real-space-control bit (R) in the register:
Home Region-Table or Segment-Table Designation (R=0)

Home Region-Table or Segment-Table Designation (R=0)

Home Real-Space Designation (R=1)

Home Real-Space Designation (R=1)

Home Space-Switch-Event Control (X): When bit 57 of control register 13 is one, a space-switch-event program interruption occurs upon completion of a RESUME PROGRAM, SET ADDRESS SPACE CONTROL, or SET ADDRESS SPACE CONTROL FAST instruction that changes the address space from which instructions are fetched either to or from the home address space; that is, when instructions are fetched from the home address space either before or after the operation but not both before and after the operation.

The home region-table origin, home segment-table origin, home private-space control (P), home storage-alteration-event control (S), home real-space control (R), home designation-type control (DT), home region-table or segment-table length (TL), and home real-space token origin in control register 13 are defined the same as the fields in the same bit positions in control register 1, except that control register 13 applies to the home address space.

The following bits of control register 13 are not assigned and are ignored: bits 52-54 and 59 if the register contains a region-table designation or segment-table designation, and bits 52-54 and 59-63 if the register contains a real-space designation.

Programming Notes:

1. The validity of the information loaded into a control register, including that pertaining to dynamic address translation, is not checked at the time the register is loaded. This information is checked and the program exception, if any, is indicated at the time the information is used.

2. The information pertaining to dynamic address translation is considered to be used when an instruction is executed with DAT on, or when the enhanced-monitor counting array is accessed, or when COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE DAT TABLE ENTRY, INVALIDATE PAGE TABLE ENTRY, LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, or STORE REAL ADDRESS is executed. The information is not considered to be used when the PSW specifies translation but an I/O, external, restart, or machine-check interruption occurs before an instruction is executed, or when the PSW specifies the wait state.

Translation Tables

When the address-space-control element (ASCE) used in a translation is a region-first-table designation, the translation process consists in a five-level lookup using five tables: a region first table, a region second table, a region third table, a segment table, and a page table. These tables reside in real or absolute storage. When the ASCE is a region-second-table designation, region-third-table designation, or segment-table designation, the lookups in the levels of tables above the designated level are omitted, and the higher-level tables themselves are omitted.

Note: The terms higher and lower are used to describe the level of DAT tables or table entries, either in storage or in the translation-lookaside buffer. A higher-level table entry maps a larger portion of virtual storage than a lower-level table entry. Thus, a region-first-table entry is the highest level of DAT-table entries, and a page-table entry is the lowest level.

Region-Table Entries

The term “region-table entry” means a region-first-table entry, region-second-table entry, or region-third-table entry.

The entries fetched from the region first table, region second table, and region third table have the following formats. The level (first, second, or third) of the table containing an entry is identified by the table-type (TT) bits in the entry.
Region-First-Table Entry (TT=11)

Region-Second-Table Origin

Region-Second-Table Origin (continued)

Region-Third-Table Origin

Region-Third-Table Origin (continued)

Segment-Table Origin

Segment-Table Origin (continued)

Region-Third-Table Entry (TT=01, FC=0)

Region-Third-Table Entry (TT=01, FC=1)

Region-Frame Absolute Address (RFAA)

The fields in the three levels of region-table entries are allocated as follows:

Region-Second-Table Origin, Region-Third-Table Origin, and Segment-Table Origin: A region-first-table entry contains a region-second-table origin. A region-second-table entry contains a region-third-table origin. When EDAT-2 does not apply, or when EDAT-2 applies and the RTTE-format control in the region-third-table entry is zero, a region-third-table entry contains a segment-table origin. The following description applies to each of the three origins. Bits 0-51 of the entry, with 12 zeros appended on the right, form the 64-bit address that designates the beginning of the next-lower-level table. It is unpredictable whether the address is real or absolute.

Region-Frame Absolute Address (RFAA): When EDAT-2 applies and the RTTE-format control is one, the access-control-bits and fetch-protection bit (ACCF) validity control. When the AV control is zero, bits 48-52 of the region-third-table entry are ignored. When the AV control is one, bits 48-52 are used as described below.

ACCF-Validity Control (AV): When EDAT-2 applies and the RTTE-format control is one, bit 47 is the access-control-bits and fetch-protection bit (ACCF) validity control. When the AV control is zero, bits 48-52 of the entry contain the access-control bits that may be used for any key-controlled access checking that applies to the address. It is unpredictable whether the CPU uses these bits or the access-control bits in the storage key of the 4K-byte block corresponding to the address.

Access-Control Bits (ACC): When EDAT-2 applies, and both the RTTE-format control and the AV control in the region-third-table-entry are one, bits 48-51 of the entry contain the access-control bits that may be used for any key-controlled access checking that applies to the address. It is unpredictable whether the CPU uses these bits or the access-control bits in the storage key of the 4K-byte block corresponding to the address.

Fetch-Protection Bit (F): When EDAT-2 applies, and both the RTTE-format control and the AV control in the region-third-table-entry are one, bit 52 of the entry contains the fetch-protection bit that may be used for any key-controlled access checking that applies to the address. It is unpredictable whether the CPU uses this bit or the fetch-protection bit in the storage key of the 4K-byte block corresponding to the address.

Format Control (FC): When EDAT-2 applies, bit 53 of the region-third table entry is the RTTE-format control for the entry, as follows:

- When the FC bit is zero, bits 0-51 of the entry form the segment-table origin, and bits 52 and 55 are reserved.
- When the FC bit is one, bits 0-32 of the entry form the region-frame absolute address, bit 47 is the ACCF-validity control, bits 48-51 are the access-control bits, bit 52 is the fetch-protection bit, and bits 55-57, and 62-63 are reserved.

When EDAT-2 does not apply, bit 53 of the region-third table entry is reserved. Bit 53 is reserved in region-first- and region-second-table entries.

DAT-Protection Bit (P): When EDAT-1 applies, bit 54 is treated as being ORed with the DAT-protection bit in each subsequent region-table entry, and, when applicable, segment-table entry, and page-table entry used in the translation. Thus, when the bit is one,
DAT protection applies to the entire region or regions specified by the region-table entry.

When the enhanced-DAT facility 1 is not installed, or when the facility is installed but the enhanced-DAT-enablement control is zero, bit 54 of the region-table entry is ignored.

Region-Second-Table Offset, Region-Third-Table Offset, and Segment-Table Offset (TF): A region-first-table entry contains a region-second-table offset. A region-second-table entry contains a region-third-table offset. When EDAT-2 does not apply, or when EDAT-2 applies but the RTTE-format control in the region-third table entry is zero, a region-third-table entry contains a segment-table offset. The following description applies to each of the three offsets. Bits 56 and 57 of the entry specify the length of a portion of the next-lower-level table that is missing at the beginning of the table, that is, the bits specify the location of the first entry actually existing in the next-lower-level table. The bits specify the length of the missing portion in units of 4,096 bytes, thus making the length of the missing portion variable in multiples of 512 entries. The length of the missing portion, in units of 4,096 bytes, is equal to the TF value. The contents of the offset field, in conjunction with the length field, bits 62 and 63, are used to establish whether the portion of the virtual address (RSX, RTX, or SX) to be translated by means of the next-lower-level table designates an entry that actually exists in the table.

When EDAT-2 applies and the RTTE-format-control of a region-third-table entry is one, bits 56-57 of the entry are reserved.

Region-Invalid Bit (I): Bit 58 in a region-first-table entry or region-second-table entry controls whether the set of regions associated with the entry is available. Bit 58 in a region-third-table entry controls whether the single region associated with the entry is available. When bit 58 is zero, address translation proceeds by using the region-table entry. When the bit is one, the entry cannot be used for translation.

Common-Region Bit (CR): When EDAT-2 applies, bit 59 controls the use of the translation-lookaside-buffer (TLB) copies of the region-third-table entry. When EDAT-2 applies but the RTTE-format control is zero, bit 59 also controls the use of the TLB copies of any segment table designated by the region-third-table entry, and any page table designated by the segment-table entry.

A zero identifies a private region; in this case, the region-third-table entry, and any lower-level table entries it designates may be used only in association with the region-third-table origin that designates the region-third table in which the region-third-table entry resides, except that on models that implement a TLB composite table entry that includes the region-third-table entry, the TLB composite table entry and any lower-level tables it designates may be used only when (a) the table origin in the TLB composite table entry matches the ASCE table origin or table origin of a higher-level region-table entry, and (b) the region indices in the TLB composite table entry match the corresponding indices of the virtual address.

A one identifies a common region; in this case, the region-third-table entry and any lower-level tables it designates may continue to be used for translating addresses corresponding to the region-third index, even though a different region-third table is specified. However, TLB copies of the region-third-table entry and lower-level tables for a common region are not usable if the private-space control, bit 55, is one in the address-space-control element used in the translation or if that address-space-control element is a real-space designation. The common-region bit must be zero if the region-third-table entry is fetched from storage during a translation when the private-space control is one in the address-space-control element being used; otherwise, a translation-specification exception is recognized.

Bit 59 is ignored in the region-first- and region-second-table entries, and, when EDAT-2 does not apply, in the region-third-table entry.

Table-Type Bits (TT): Bits 60 and 61 of the region-first-table entry, region-second-table entry, and region-third-table entry identify the level of the table containing the entry, as follows:

<table>
<thead>
<tr>
<th>Bits 60 and 61</th>
<th>Region-Table Level</th>
</tr>
</thead>
<tbody>
<tr>
<td>11</td>
<td>First</td>
</tr>
<tr>
<td>10</td>
<td>Second</td>
</tr>
<tr>
<td>01</td>
<td>Third</td>
</tr>
</tbody>
</table>

Bits 60 and 61 must identify the correct table level, considering the type of table designation that is the address-space-control element being used in the translation and the number of table levels that have so far been used; otherwise, a translation-specification exception is recognized.
Region-Second-Table Length, Region-Third-Table Length, and Segment-Table Length (TL): A
region-first-table entry contains a region-second-table length. A region-second-table entry contains a
region-third-table length. When EDAT-2 does not apply, or when EDAT-2 applies but the RTTE-format
control in the region-third table entry is zero, a region-third-table entry contains a segment-table
length. The following description applies to each of the three lengths. Bits 62 and 63 of the entry specify
the length of the next-lower-level table in units of 4,096 bytes, thus making the length of the table variable
in multiples of 512 entries. The length of the next-lower-level table, in units of 4,096 bytes, is one
more than the TL value. The contents of the length field, in conjunction with the offset field, bits 56 and
57, are used to establish whether the portion of the virtual address (RSX, RTX, or SX) to be translated by
means of the next-lower-level table designates an entry that actually exists in the table.

When EDAT-2 applies and the RTTE-format-control of a region-third-table entry is one, bits 62-63 of the
entry are available for programming.

All other bit positions of the region-table entry are reserved for possible future extensions and should contain zeros; otherwise, the program may not operate compatibly in the future. When EDAT-1 applies, the reserved bit positions of the region-table entry should contain zeros even if the table entry is invalid.

Programming Note: When the common-region (CR) bit is one in a valid region-third-table entry fetched from storage during dynamic-address translation for a non-private address space, that is, for an address space in which the private-space control is zero in the address-space-control element being used, then the following conditions apply:

1. The region-third-table entries corresponding to the same virtual address in all other non-private address spaces must be identical.

   If the program alters such a region-third-table entry in one non-private address space, then it must also (a) identically alter all other region-third-table entries corresponding to the same virtual address in all other non-private address spaces, and (b) ensure that the affected entries are cleared from the TLBs of all CPUs in the configuration.

   If the program fails to maintain consistent DAT table entries as described above, results are unpredictable and may include the presentation of a delayed-access-exception machine check, as described in “Delayed Access Exception” on page 11-17.

   3. If the program fails to maintain consistent DAT table entries as described above, results are unpredictable and may include the presentation of a delayed-access-exception machine check, as described in “Delayed Access Exception” on page 11-17.

Segment-Table Entries
When EDAT-1 does not apply, or when enhanced DAT applies and the STE-format control, bit 53 of the
segment-table entry is zero, the entry fetched from the segment table has the following format:

Segment-Table Entry (TT=00, FC=0)

Page-Table Origin

<table>
<thead>
<tr>
<th>P</th>
<th>C</th>
<th>I</th>
<th>C</th>
</tr>
</thead>
<tbody>
<tr>
<td>F</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Page-Table Origin (continued)

TT

When EDAT-1 applies and the STE-format control is one, the entry fetched from the segment table has the following format:
Segment-Table Entry (TT=00, FC=1)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Page-Table Origin</td>
<td>When EDAT-1 does not apply, or when EDAT-1 applies but the STE-format control, bit 53 of the segment-table entry, is zero, bits 0-52, with 11 zeros appended on the right, form a 64-bit address that designates the beginning of a page table. It is unpredictable whether the address is real or absolute.</td>
</tr>
<tr>
<td>Segment-Frame Absolute Address</td>
<td>When EDAT-1 applies and the STE-format control is one, bits 0-43 of the entry, with 20 zeros appended on the right, form the 64-bit absolute address of the segment.</td>
</tr>
<tr>
<td>ACCF-Validity Control (AV)</td>
<td>When EDAT-1 applies and the STE-format control is one, bit 47 is the access-control-bits and fetch-protection bit (ACCF) validity control. When the AV control is zero, bits 48-52 of the segment-table entry are ignored. When the AV control is one, bits 48-52 are used as described below.</td>
</tr>
<tr>
<td>Access-Control Bits (ACC)</td>
<td>When EDAT-1 applies, and both the STE-format control and the AV control in the segment-table entry are one, bits 48-51 of the segment-table entry contain the access-control bits that may be used for any key-controlled access checking that applies to the address. It is unpredictable whether the CPU uses these bits or the access-control bits in the storage key of the 4K-byte block corresponding to the address.</td>
</tr>
<tr>
<td>Fetch-Protection Bit (F)</td>
<td>When EDAT-1 applies, and both the STE-format control and the AV control in the segment-table entry are one, bit 52 of the segment-table entry contains the fetch-protection bit that may be used for any key-controlled access checking that applies to the address. It is unpredictable whether the CPU uses this bit or the fetch-protection bit in the storage key of the 4K-byte block corresponding to the address.</td>
</tr>
</tbody>
</table>

STE-Format Control (FC): When EDAT-1 applies, bit 53 is the format control for the segment-table entry, as follows:

- When the FC bit is zero, bits 0-52 of the entry form the page-table origin, and bit 55 is reserved.
- When the FC bit is one, bits 0-43 of the entry form the segment-frame absolute address, bit 47 is the ACCF-validity control, bits 48-51 are the access-control bits, bit 52 is the fetch-protection bit, and bit 55 is ignored.

When EDAT-1 does not apply, bit 53 is ignored.

DAT-Protection Bit (P): Bit 54, when one, indicates that DAT protection applies to the entire segment.

When EDAT-1 does not apply, bit 54 is treated as being ORed with the DAT-protection bit in the page-table entry used in the translation.

When EDAT-1 applies, the DAT-protection bit in any and all region-table entries used in the translation are treated as being ORed with the DAT-protection bit in the segment-table entry; when the STE-format control is zero, the DAT-protection bit in the STE is further treated as being ORed with the DAT-protection bit in the page-table entry.

Segment-Invalid Bit (I): Bit 58 controls whether the segment associated with the segment-table entry is available. When the bit is zero, address translation proceeds by using the segment-table entry. When the bit is one, the segment-table entry cannot be used for translation.

Common-Segment Bit (CS): Bit 59 controls the use of the translation-lookaside-buffer (TLB) copies of the segment-table entry. When EDAT-1 does not apply or when EDAT-1 applies but the format control is zero, bit 59 also controls the use of the TLB copies of the page table designated by the segment-table entry.

A zero identifies a private segment; in this case, the segment-table entry and any page table it designates may be used only in association with the segment-table origin that designates the segment table in which the segment-table entry resides, except that on models that implement a TLB composite table entry that includes the STE, the TLB composite table entry and any page table it designates may be used
only when (a) the table origin in the TLB composite table entry matches the ASCE table origin or table origin of a higher-level region-table entry, and (b) the region and segment indices in the TLB composite table entry match the corresponding indices of the virtual address.

A one identifies a common segment; in this case, the segment-table entry and any page table it designates may continue to be used for translating addresses corresponding to the segment index, even though a different segment table is specified. However, TLB copies of the segment-table entry and any page table for a common segment are not usable if the private-space control, bit 55, is one in the address-space-control element used in the translation or if that address-space-control element is a real-space designation. The common-segment bit must be zero if the segment-table entry is fetched from storage during a translation when the private-space control is one in the address-space-control element being used; otherwise, a translation-specification exception is recognized.

When EDAT-2 applies, the effective value of the common-segment bit is the logical OR of bits 59 of the segment-table entry and any region-third-table entry designating the segment-table entry.

**Table-Type Bits (TT):** Bits 60 and 61 of the segment-table entry are 00 binary to identify the level of the table containing the entry. The meanings of all possible values of bits 60 and 61 in a region-table entry or segment-table entry are as follows:

<table>
<thead>
<tr>
<th>Bits 60 and 61</th>
<th>Table Level</th>
</tr>
</thead>
<tbody>
<tr>
<td>11</td>
<td>Region-first</td>
</tr>
<tr>
<td>10</td>
<td>Region-second</td>
</tr>
<tr>
<td>01</td>
<td>Region-third</td>
</tr>
<tr>
<td>00</td>
<td>Segment</td>
</tr>
</tbody>
</table>

Bits 60 and 61 must identify the correct table level, considering the type of table designation that is the address-space-control element being used in the translation and the number of table levels that have so far been used; otherwise, a translation-specification exception is recognized.

Bits 62-63 are available for programming.

All other bit positions of the segment-table entry are reserved for possible future extensions and should contain zeros; otherwise, the program may not operate compatibly in the future. When EDAT-1 applies, the reserved bit positions of the segment-table entry should contain zeros even if the table entry is invalid.

**Programming Note:** When the common-segment (CS) bit is one in a valid segment-table entry fetched from storage during dynamic-address translation for a non-private address space, that is, for an address space in which the private-space control is zero in the address-space-control element being used, then the following conditions apply:

1. The segment-table entries corresponding to the same virtual address in all other non-private address spaces must be identical.

   If the program alters such a segment-table entry in one non-private address space, then it must also (a) identically alter all other segment-table entries corresponding to the same virtual address in all other non-private address spaces, and (b) ensure that the affected entries are cleared from the TLBs of all CPUs in the configuration. Further information on clearing TLB entries may be found in “Modification of Translation Tables” on page 3-62.

2. The program must ensure that segment-table entries in which the CS bit is set to one, and any region-table entries used by the DAT process to locate such segment-table entries, are consistent across all address spaces. That is, if the DAT process can successfully locate a segment-table entry in which the CS bit is one in one non-private address space, then there must be no exception condition that prevents DAT from locating the segment-table entry corresponding to the same virtual address in any other non-private address spaces.

   If the program alters such a segment-table entry or region-table entry in one non-private address space, then it must also (a) perform consistent alteration to all corresponding table entries in all other non-private address spaces, and (b) ensure that the affected entries are cleared from the TLBs of all CPUs in the configuration.

3. If the program fails to maintain consistent DAT table entries as described above, results are unpredictable and may include the presentation of a delayed-access-exception machine check, as described in “Delayed Access Exception” on page 11-17.
Page-Table Entries

The entry fetched from the page table entry has the following format:

<table>
<thead>
<tr>
<th>Page-Frame Real Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

The fields in the page-table entry are allocated as follows:

**Page-Frame Real Address (PFRA):** Bits 0-51 provide the leftmost bits of a real storage address. When these bits are concatenated with the 12-bit byte-index field of the virtual address on the right, a 64-bit real address is obtained.

**Page-Invalid Bit (I):** Bit 53 controls whether the page associated with the page-table entry is available. When the bit is zero, address translation proceeds by using the page-table entry. When the bit is one, the page-table entry cannot be used for translation.

**DAT-Protection Bit (P):** Bit 54 controls whether store accesses can be made in the page. This protection mechanism is in addition to the key-controlled-protection and low-address-protection mechanisms. The bit has no effect on fetch accesses. If the bit is zero, stores are permitted to the page, subject to the following additional constraints:

- The DAT-protection bit being zero in the segment-table entry used in the translation,
- When EDAT-1 applies, the DAT-protection bit being zero in all region-table entries used in the translation,
- Other protection mechanisms

If the bit is one, stores are disallowed. When no higher priority exception conditions exist, an attempt to store when the DAT-protection bit is one causes a protection exception to be recognized. The DAT-protection bit in the segment-table entry is treated as being ORed with bit 54 when determining whether DAT protection applies to the page. When EDAT-1 applies, the DAT-protection bits in any region-table entries used in translation are also treated as being ORed with bit 54 when determining whether DAT-protection applies.

Bit position 52 of the entry must contain zero; otherwise, a translation-specification exception is recognized as part of the execution of an instruction using that entry for address translation.

When EDAT-1 does not apply, bit 55 of the page-table entry must contain zero; otherwise, a translation-specification exception is recognized as part of the execution of an instruction using that entry for address translation. When EDAT-1 applies and the STE-format control is zero, bit 55 of the page-table entry is ignored.

Bit positions 56-63 are not assigned and are ignored.

**Programming Note:** Bit 55 of the format-1 region-third-table entry, format-1 segment-table entry, and page table entry was formerly defined to be the change-recording override (CO). The change-recording override was never implemented on any IBM processor, and this feature has been removed from the architecture.

Translation Process

This section describes the translation process as it is performed implicitly before a virtual address is used to access main storage. Explicit translation, which is the process of translating the operand address of LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, STORE REAL ADDRESS, and TEST PROTECTION, is the same, except that, for LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS and TEST PROTECTION, region-first-translation, region-second-translation, region-third-translation, and segment-translation exceptions are not recognized, and for LOAD REAL ADDRESS and TEST PROTECTION, page-translation exceptions are not recognized; such conditions are instead indicated by the condition code. Translation of the operand address of LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS and STORE REAL ADDRESS also differs in that the CPU may be in the real mode.

Translation of a virtual address is controlled by the DAT-mode bit and address-space-control bits in the PSW and by the address-space-control elements (ASCEs) in control registers 1, 7, and 13 and as specified by the access registers. When the ASCE used in a translation is a region-first-table designation, the translation is performed by means of a region first table, region second table, region third
table, and, when applicable, a segment table and page table, all of which reside in real or absolute storage. When the ASCE is a lower-level type of table designation (region-second-table designation, region-third-table designation, or segment-table designation) the translation is performed by means of only the table levels beginning with the designated level, and the virtual-address bits that would, if nonzero, require use of a higher level or levels of table must be all zeros; otherwise, an ASCE-type exception is recognized. When the ASCE is a real-space designation, the virtual address is treated as a real address, and table entries in real or absolute storage are not used.

The address-space-control element (ASCE) used for a particular address translation is called the effective ASCE. Accordingly, when a primary virtual address is translated, the contents of control register 1 are used as the effective ASCE. Similarly, for a secondary virtual address, the contents of control register 7 are used; for an AR-specified virtual address, the ASCE specified by the access register is used; and for a home virtual address, the contents of control register 13 are used.

When the real-space control in the effective ASCE is zero, the designation-type control in the ASCE specifies the table-designation type of the ASCE: region-first-table designation, region-second-table designation, region-third-table designation, or segment-table designation. The corresponding portion of the virtual address (region first index, region second index, region third index, or segment index) is checked against the table-length field in the designation, and it is added to the origin in the designation to select an entry in the designated table. If the selected entry is outside its table, as determined by the table-length field in the current table entry, or if the I bit is one in the selected entry, a region-first-translation, region-second-translation, region-third-translation, or segment-translation exception is recognized, depending on the level of the next table. If the table-type bits in the selected entry do not indicate the expected table level, a translation-specification exception is recognized.

Processing of portions of the virtual address continues by means of any successive table levels. When EDAT-1 applies, the DAT-protection bit in any and all region-table entries used during the translation are treated as being ORed with the respective bit in any segment-table entry used in the translation.

When EDAT-2 applies, the region-third-table entry contains a common-region bit that controls the use of the TLB copies of any lower-level tables designated by the region-third-table entry. The common-region bit is logically ORed with the common-segment bit of any segment-table entry used in the translation. When EDAT-2 applies and a region-third-table entry in which the RTTE-format control is one is selected, the following conditions are in effect:

- The region-third-table entry contains the leftmost 33 bits of the absolute address that represents the translation of the virtual address.
- The segment-index, page-index and byte-index fields of the virtual address are used unchanged as the rightmost 31 bit positions of the real address.
- The region-third-table entry also contains the ACCF-validity control, the access-control bits, the fetch-protection bit, the DAT-protection bit, and the common-region bit that apply to the region.

When EDAT-1 applies and a segment-table entry in which the STE-format control is one is selected, the following conditions are in effect:

- The segment-table entry contains the leftmost bits of the absolute address that represents the translation of the virtual address.
• The page-index and byte-index fields of the virtual address are used unchanged as the rightmost bit positions of the real address.

• The segment-table entry also contains the ACCF-validity control, the access-control bits, the fetch-protection bit, the DAT-protection bit, and common-segment bit that apply to the segment.

When EDAT-1 does not apply, or when EDAT-1 applies but the STE-format control is zero, the following conditions are in effect:

• The segment-table entry contains a DAT-protection bit that applies to all pages in the specified segment; the segment-table entry also contains a common-segment bit that controls the use of the TLB copies of the page table designated by the segment-table entry.

• The segment-table entry designates the page table to be used.

• The page-index portion of the virtual address is added to the page-table origin in the segment-table entry to select an entry in the page table. If the I bit is one in the page-table entry, a page-translation exception is recognized. The page-table entry contains the leftmost bits of the real address that represents the translation of the virtual address, and it contains a DAT-protection bit that applies only to the page specified by the page-table entry.

• The byte-index field of the virtual address is used unchanged as the rightmost bit positions of the real address.

In order to eliminate the delay associated with references to translation tables in real or absolute storage, the information fetched from the tables normally is also placed in a special buffer, the translation-lookaside buffer (TLB), and subsequent translations involving the same table entries may be performed by using the information recorded in the TLB. The TLB may also record virtual-equals-real translations related to a real-space designation. The operation of the TLB is described in “Translation-Lookaside Buffer” on page 3-58.

Whenever access to real or absolute storage is made during the address-translation process for the purpose of fetching an entry from a region table, segment table, or page table, key-controlled protection does not apply.

The translation process, including the effect of the TLB, is shown graphically in Figure 3-12 on page 3-51.

**Inspection of Real-Space Control**

When the effective address-space-control element (ASCE) contains a real-space control, bit 58, having the value zero, the ASCE is a region-table or segment-table designation. When the real-space control is one, the ASCE is a real-space designation.

**Inspection of Designation-Type Control**

When the real-space control is zero, the designation-type control, bits 60 and 61 of the effective address-space-control element (ASCE), specifies the table-designation type of the ASCE. Depending on the type, some number of leftmost bits of the virtual address being translated must be zeros; otherwise, an ASCE-type exception is recognized. For each possible value of bits 60 and 61, the table-designa-
Figure 3-12. Translation Process (Part 1 of 3)
Figure 3-12. Translation Process  (Part 2 of 3)
tion type and the virtual-address bits required to be zeros are as follows:

<table>
<thead>
<tr>
<th>Bits 60 and 61 Designation Type</th>
<th>Virtual-Address Bits Required to be Zeros</th>
</tr>
</thead>
<tbody>
<tr>
<td>11 Region-first-table</td>
<td>None</td>
</tr>
<tr>
<td>10 Region-second-table</td>
<td>0-10</td>
</tr>
<tr>
<td>01 Region-third-table</td>
<td>0-21</td>
</tr>
<tr>
<td>00 Segment-table</td>
<td>0-32</td>
</tr>
</tbody>
</table>

Lookup in a Table Designated by an Address-Space-Control Element

The designation-type control, bits 60 and 61 of the effective address-space-control element (ASCE), specifies both the table-designation type of the ASCE and the portion of the virtual address that is to be translated by means of the designated table, as follows:

<table>
<thead>
<tr>
<th>Bits 60 and 61 Designation Type</th>
<th>Virtual-Address Portion Translated by the Table</th>
</tr>
</thead>
<tbody>
<tr>
<td>11 Region-first-table</td>
<td>Region first index (bits 0-10)</td>
</tr>
<tr>
<td>10 Region-second-table</td>
<td>Region second index (bits 11-21)</td>
</tr>
<tr>
<td>01 Region-third-table</td>
<td>Region third index (bits 22-32)</td>
</tr>
<tr>
<td>00 Segment-table</td>
<td>Segment index (bits 33-43)</td>
</tr>
</tbody>
</table>

Region-First-Table Lookup: When bits 60 and 61 have the value 11 binary, the region-first-index portion of the virtual address, in conjunction with the
region-first-table origin contained in the ASCE, is used to select an entry from the region first table.

The 64-bit address of the region-first-table entry in real or absolute storage is obtained by appending 12 zeros to the right of bits 0-51 of the region-first-table designation and adding the region first index with three rightmost and 50 leftmost zeros appended. When a carry out of bit position 0 occurs during the addition, an addressing exception may be recognized, or the carry may be ignored, causing the table to wrap from $2^{34} - 1$ to zero. All 64 bits of the address are used, regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode. When forming the address of a region-first-, region-second-, region-third-, or segment-table entry, it is unpredictable whether prefixing, if any, is applied to the respective table origin contained in the ASCE before the addition of the table index value, or prefixing is applied to the table-entry address that is formed by the addition of the table origin and table index value.

As part of the region-first-table-lookup process, bits 0 and 1 of the virtual address (which are bits 0 and 1 of the region first index) are compared against the table length, bits 62 and 63 of the region-first-table designation, to establish whether the addressed entry is within the region first table. If the value in the table-length field is less than the value in the corresponding bit positions of the virtual address, a region-first-translation exception is recognized. The comparison against the table length may be omitted if the equivalent of a region-first-table entry in the translation-lookaside buffer is used in the translation.

All eight bytes of the region-first-table entry appear to be fetched concurrently as observed by other CPUs. The fetch access is not subject to protection. When the storage address generated for fetching the region-first-table entry designates a location which is not available in the configuration, an addressing exception is recognized, and the unit of operation is suppressed.

Bit 58 of the entry fetched from the region first table specifies whether the corresponding set of regions is available. This bit is inspected, and, if it is one, a region-first-translation exception is recognized.

A translation-specification exception is recognized if the table-type bits, bits 60 and 61, in the region-first-table entry do not have the same value as bits 60 and 61 of the ASCE.

When no exceptions are recognized in the process of region-first-table lookup, the entry fetched from the region first table designates the beginning and specifies the offset and length of the corresponding region second table.

Region-Second-Table Lookup: When bits 60 and 61 of the ASCE have the value 10 binary, the region-second-index portion of the virtual address, in conjunction with the region-second-table origin contained in the ASCE, is used to select an entry from the region second table. Bits 11 and 12 of the virtual address (which are bits 0 and 1 of the region second index) are compared against the table length in the ASCE. If the value in the table-length field is less than the value in the corresponding bit positions of the virtual address, a region-second-translation exception is recognized. The comparison against the table length may be omitted if the equivalent of a region-second-table entry in the translation-lookaside buffer is used in the translation. The region-second-table-lookup process is otherwise the same as the region-first-table-lookup process, except that a region-second-translation exception is recognized if bit 58 is one in the region-second-table entry. When no exceptions are recognized, the entry fetched from the region second table designates the beginning and specifies the offset and length of the corresponding region third table.

Region-Third-Table Lookup: When bits 60 and 61 of the ASCE have the value 01 binary, the region-third-index portion of the virtual address, in conjunction with the region-third-table origin contained in the ASCE, is used to select an entry from the region third table. Bits 22 and 23 of the virtual address (which are bits 0 and 1 of the region third index) are compared against the table length in the ASCE. If the value in the table-length field is less than the value in the corresponding bit positions of the virtual address, a region-third-translation exception is recognized. The comparison against the table length may be omitted if the equivalent of a region-third-table entry in the translation-lookaside buffer is used in the translation. When EDAT-2 applies, a translation-specification exception is recognized if (1) the private-space control, bit 55, in the ASCE is one and (2) the common-region bit, bit 59, in the entry fetched from the region-third table is one. The region-third-table-lookup process is otherwise the same as the region-first-table-lookup process, including the checking of the table-type bits in the region-third-table entry, except that a region-third-translation exception is recognized if bit 58 is one in the region-third-table entry.
When no exceptions are recognized, processing is as follows:

- When EDAT-2 does not apply, or when EDAT-2 applies but the RTTE-format control is zero, the entry fetched from the region third table designates the beginning and specifies the offset and length of the corresponding segment table.

- When EDAT-2 applies and the RTTE-format control is one, the entry fetched from the region-third table contains the leftmost bits of the region-frame absolute address. If the DAT-protection bit, bit 54, is one either in any region-table entry used in the translation or in the segment-table entry, and the storage reference for which the translation is being performed is a store, a protection exception is recognized.

**Segment-Table Lookup:** When bits 60 and 61 of the ASCE have the value 00 binary, the segment-index portion of the virtual address, in conjunction with the segment-table origin contained in the ASCE, is used to select an entry from the segment table. Bits 33 and 34 of the virtual address (which are bits 0 and 1 of the segment index) are compared against the table length in the ASCE. If the value in the table-length field is less than the value in the corresponding bit positions of the virtual address, a segment-translation exception is recognized. The comparison against the table length may be omitted if the equivalent of a segment-table entry in the translation-lookaside buffer is used in the translation. A translation-specification exception is recognized if (1) the private-space control, bit 55, in the ASCE is one and (2) the common-segment bit, bit 59, in the entry fetched from the segment table is one. When EDAT-2 applies and the common-region bit is one in a region-third-table entry designating the segment table, then the common-segment bit is assumed to be one in all entries in the segment table. The segment-table-lookup process is otherwise the same as the region-first-table-lookup process, including the checking of the table-type bits in the segment-table entry, except that a segment-translation exception is recognized if bit 58 is one in the segment-table entry. When no exceptions are recognized, processing is as follows:

- When EDAT-1 does not apply, or when EDAT-1 applies but the STE-format control is zero, the entry fetched from the segment table designates the beginning of the corresponding page table, and processing continues as described in “Page-Table Lookup”, below.

- When EDAT-1 applies and the STE-format control is one, the entry fetched from the segment table contains the leftmost bits of the segment-frame absolute address. If the DAT-protection bit, bit 54, is one either in any region-table entry used in the translation or in the segment-table entry, and the storage reference for which the translation is being performed is a store, a protection exception is recognized.

**Lookup in a Table Designated by a Region-Table Entry**

When the effective address-space-control element (ASCE) is a region-table designation, a region-table entry is selected as described in the preceding section. Then the contents of the selected entry and the next index portion of the virtual address are used to select an entry in the next-lower-level table, which may be another region table or a segment table.

**Region-Second-Table Lookup:** When the table entry selected by means of the ASCE is a region-first-table entry, the region-second-index portion of the virtual address, in conjunction with the region-second-table origin contained in the region-first-table entry, is used to select an entry from the region second table.

The 64-bit address of the region-second-table entry in real or absolute storage is obtained by appending 12 zeros to the right of bits 0-51 of the region-first-table entry and adding the region second index with three rightmost and 50 leftmost zeros appended. When a carry out of bit position 0 occurs during the addition, an addressing exception may be recognized, or the carry may be ignored, causing the table to wrap from $2^{64} - 1$ to zero. All 64 bits of the address are used, regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode. When forming the address of a region-second-, region-third-, or segment-table entry, it is unpredictable whether prefixing, if any, is applied to the respective table origin contained in the higher-level table entry before the addition of the table index value, or prefixing is applied to the table-entry address that is formed by the addition of the table origin and table index value.

As part of the region-second-table-lookup process, bits 11 and 12 of the virtual address (which are bits 0 and 1 of the region second index) are compared against the table offset, bits 56 and 57 of the region-first-table entry, and against the table length, bits 62...
and 63 of the region-first-table entry, to establish whether the addressed entry is within the region second table. If the value in the table-offset field is greater than the value in the corresponding bit positions of the virtual address, or if the value in the table-length field is less than the value in the corresponding bit positions of the virtual address, a region-second-translation exception is recognized.

All eight bytes of the region-second-table entry appear to be fetched concurrently as observed by other CPUs. The fetch access is not subject to protection. When the storage address generated for fetching the region-second-table entry designates a location which is not available in the configuration, an addressing exception is recognized, and the unit of operation is suppressed.

Bit 58 of the entry fetched from the region second table specifies whether the corresponding set of regions is available. This bit is inspected, and, if it is one, a region-second-translation exception is recognized.

A translation-specification exception is recognized if the table-type bits, bits 60 and 61, in the region-second-table entry do not have a value that is one less than the value of those bits in the next-higher-level table.

When no exceptions are recognized in the process of region-second-table lookup, the entry fetched from the region second table designates the beginning and specifies the offset and length of the corresponding region third table.

Region-Third-Table Lookup: When the table entry selected by means of the ASCE is a region-second-table entry, or if a region-second-table entry has been selected by means of the contents of a region-first-table entry, then the region-third-index portion of the virtual address, in conjunction with the region-third-table origin contained in the region-second-table entry, is used to select an entry from the region third table. Bits 22 and 23 of the virtual address (which are bits 0 and 1 of the region third index) are compared against the table offset and table length in the region-third-table entry. A region-third-translation exception is recognized if the table offset is greater than bits 22 and 23 or if the table length is less than bits 22 and 23. When EDAT-2 applies, a translation-specification exception is recognized if (1) the private-space control, bit 55, in the ASCE is one and (2) the common-region bit, bit 59, in the entry fetched from the region-third table is one. The region-third-table-lookup process is otherwise the same as the region-second-table-lookup process, including the checking of the table-type bits in the region-third-table entry, except that a region-third-translation exception is recognized if bit 58 is one in the region-third-table entry. When no exceptions are recognized, processing is as follows:

- When EDAT-2 does not apply, or when EDAT-2 applies but the RTTE-format control is zero, the entry fetched from the region third table designates the beginning and specifies the offset and length of the corresponding segment table.

- When EDAT-2 applies and the RTTE-format control is one, the entry fetched from the region-third table contains the leftmost bits of the region-frame absolute address. If the DAT-protection bit, bit 54, is one either in any region-table entry used in the translation, and the storage reference for which the translation is being performed is a store, a protection exception is recognized.

Segment-Table Lookup: When (1) the table entry selected by means of the ASCE is a region-third-table entry, or a region-third-table entry has been selected by means of the contents of a region-second-table entry, and (2) EDAT-2 does not apply, or EDAT-2 applies but the RTTE-format control is zero, then the segment-index portion of the virtual address, in conjunction with the segment-table origin contained in the region-third-table entry, is used to select an entry from the segment table. Bits 33 and 34 of the virtual address (which are bits 0 and 1 of the segment index) are compared against the table offset and table length in the region-third-table entry. A segment-translation exception is recognized if the table offset is greater than bits 33 and 34 or if the table length is less than bits 33 and 34. A translation-specification exception is recognized if (1) the private-space control, bit 55, in the ASCE is one and (2) the common-segment bit, bit 59, in the entry fetched from the segment table is one. When EDAT-2 applies and the common-region bit is one in a region-third-table entry designating the segment table, then the common-segment bit is assumed to be one in all entries in the segment table. The segment-table-lookup process is otherwise the same as the region-second-table-lookup process, including the checking of the table-type bits in the segment-table entry, except that a segment-translation exception is recognized if bit 58 is one in the segment-table entry.
When no exceptions are recognized, processing is as follows:

- When EDAT-1 does not apply, or when EDAT-1 applies but the STE-format control is zero, the entry fetched from the segment table designates the beginning of the corresponding page table, and processing continues as described in “Page-Table Lookup”, below.

- When EDAT-1 applies and the STE-format control is one, the entry fetched from the segment table contains the leftmost bits of the segment-frame absolute address. If the DAT-protection bit, bit 54, is one either in any region-table entry used in the translation or in the segment-table entry, and the storage reference for which the translation is being performed is a store, a protection exception is recognized.

Page-Table Lookup

When EDAT-1 does not apply, or when EDAT-1 applies but the STE-format control is zero, the page-index portion of the virtual address, in conjunction with the page-table origin contained in the segment-table entry, is used to select an entry from the page table.

The 64-bit address of the page-table entry in real or absolute storage is obtained by appending 11 zeros to the right of the page-table origin and adding the page index, with three rightmost and 53 leftmost zeros appended. A carry out of bit position 0 cannot occur. All 64 bits of the address are used, regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

All eight bytes of the page-table entry appear to be fetched concurrently as observed by other CPUs. The fetch access is not subject to protection. When the storage address generated for fetching the page-table entry designates a location which is not available in the configuration, an addressing exception is recognized, and the unit of operation is suppressed.

The entry fetched from the page table indicates the availability of the page and contains the leftmost bits of the page-frame real address. The page-invalid bit, bit 53, is inspected to establish whether the corresponding page is available. If this bit is one, a page-translation exception is recognized. If bit position 52 contains a one, a translation-specification exception is recognized. When EDAT-1 does not apply, or EDAT-1 applies and the STE-format control is zero, a translation-specification exception is also recognized if bit position 55 contains a one. If the DAT-protection bit, bit 54, is one either in the segment-table entry used in the translation, in the page-table entry, or, when EDAT-1 applies, in any region-table entry used during the translation, and the storage reference for which the translation is being performed is a store, a protection exception is recognized.

Formation of the Real and Absolute Addresses

When the effective address-space-control element (ASCE) is a real-space designation, bits 0-63 of the virtual address are used directly as the real storage address. The real address is then subjected to prefixing to form an absolute address.

When the effective ASCE is not a real-space designation and no exceptions in the translation process are encountered, the following conditions apply:

- When EDAT-2 applies and the RTTE-format control is one, the region-frame absolute address and the segment-index, page-index and byte-index portions of the virtual address are concatenated, left to right, respectively, to form the absolute address which corresponds to the virtual address.

- When EDAT-1 applies and the STE-format control is one, the segment-frame absolute address and the page-index and byte-index portions of the virtual address are concatenated, left to right, respectively, to form the absolute address which corresponds to the virtual address.

- When EDAT-1 does not apply, or when EDAT-1 applies but the STE format control is zero, the page-frame real address is obtained from the page-table entry. The page-frame real address and the byte-index portion of the virtual address are concatenated, with the page-frame real address forming the leftmost part. The result is the real storage address which corresponds to the virtual address. The real address is then subjected to prefixing to form an absolute address.

All 64 bits of the real and absolute addresses are used, regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.
Recognition of Exceptions during Translation

Invalid addresses and invalid formats can cause exceptions to be recognized during the translation process. Exceptions are recognized when information contained in table entries is used for translation and is found to be incorrect.

The information pertaining to DAT is considered to be used when an instruction is executed with DAT on, when the enhanced-monitor counting array is accessed, or when COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE DAT TABLE ENTRY, INVALIDATE PAGE TABLE ENTRY, LOAD PAGE-ENTRY ADDRESS, LOAD REAL ADDRESS, or STORE REAL ADDRESS is executed. The information is not considered to be used when the PSW specifies DAT on but an I/O, external, restart, or machine-check interruption occurs before an instruction is executed, or when the PSW specifies the wait state. Only that information required in order to translate a virtual address is considered to be in use during the translation of that address, and, in particular, addressing exceptions that would be caused by the use of an address-space-control element are not recognized when that address-space-control element is not the one actually used in the translation.

A list of translation exceptions, with the action taken for each exception and the priority in which the exceptions are recognized when more than one is applicable, is provided in “Recognition of Access Exceptions” on page 6-45.

Translation-Lookaside Buffer

To enhance performance, the dynamic-address-translation mechanism normally is implemented such that some of the information specified in the region tables, segment tables, and page tables is maintained in a special buffer, referred to as the translation-lookaside buffer (TLB). The CPU necessarily refers to a DAT-table entry in real or absolute storage only for the initial access to that entry. This information may be placed in the TLB, and subsequent translations may be performed by using the information in the TLB. For consistency of operation, the virtual-equals-real translation specified by a real-space designation also may be performed by using information in the TLB. The presence of the TLB affects the translation process to the extent that (1) a modification of the contents of a table entry in real or absolute storage does not necessarily have an immediate effect, if any, on the translation, (2) a region-first-table origin, region-second-table origin, region-third-table origin, segment-table origin, or real-space token origin in an address-space-control element (ASCE) may select a TLB entry that was formed by means of an ASCE containing an origin of the same value even when the two origins are of different types, and (3) the comparison against the table length in an address-space-control element may be omitted if a TLB equivalent of the designated table is used. In a multiple-CPU configuration, each CPU has its own TLB.

Entries within the TLB are not explicitly addressable by the program.

Information is not necessarily retained in the TLB under all conditions for which such retention is permissible. Furthermore, information in the TLB may be cleared under conditions additional to those for which clearing is mandatory.

TLB Structure

The description of the logical structure of the TLB covers the implementation by all systems operating as defined by z/Architecture. The TLB entries are considered as being of six types: TLB region-first-table entries, TLB region-second-table entries, TLB region-third-table entries (collectively called TLB region-table entries), TLB segment-table entries, TLB page-table entries, and TLB real-space entries. A TLB region-table entry, TLB segment-table entry, or TLB page-table entry is considered as containing within it both the information obtained from the table entry in real or absolute storage and the attributes used to fetch this information from storage. A TLB real-space entry is considered as containing a page-frame real address and the real-space token origin and region, segment, and page indexes used to form the entry.

Any applicable TLB region-table entries, the TLB segment-table entry, and the TLB page-table entry may be merged into a single entry called a TLB composite table entry. In a similar manner, an implementation may combine any contiguous subset of table levels. When this happens, the intermediate table origins, offsets, and lengths need not be buffered.

An equivalent to the TLB combined region-and-segment-table entry (CRSTE), described in previous versions of the architecture, may be formed which maps a table origin, region index, segment index, and com-
mon-segment bit to a segment-frame absolute address or page-table origin (and other designated fields).

The token origin in a TLB real-space entry is indistinguishable from the table origin in a TLB composite-, region-, or segment-table entry.

**Note:** The following sections describe the conditions under which information may be placed in the TLB, the conditions under which information from the TLB may be used for address translation, and how changes to the translation tables affect the translation process.

### Formation of TLB Entries

The formation of TLB region-table entries, TLB segment-table entries and TLB page-table entries from table entries in real or absolute storage, and the effect of any manipulation of the contents of table entries in storage by the program, depend on whether the entries in storage are attached to a particular CPU and on whether the entries are valid.

The *attached* state of a table entry denotes that the CPU to which it is attached can attempt to use the table entry for implicit address translation, except that a table entry for the primary or home address space may be attached even when the CPU does not fetch from either of those spaces. A table entry may be attached to more than one CPU at a time.

The *valid* state of a table entry denotes that the region set, region, segment, or page associated with the table entry is available. An entry is valid when the region-invalid, segment-invalid, or page-invalid bit in the entry is zero.

A region-table entry, segment-table entry, or page-table entry may be placed in the TLB whenever the entry is attached and valid and would not cause a translation-specification exception if used for translation.

The region-table entries, if any, and the segment-table entry, if any, used to translate a virtual address are called a *translation path*. The highest-level table entry in a translation path is attached when it is within a table designated by an attaching address-space-control element (ASCE). “Within a table” means as determined by the origin and length fields in the ASCE. An ASCE is an attaching ASCE when all of the following conditions are met:

1. The current PSW specifies DAT on.
2. The current PSW contains no errors that would cause an early specification exception to be recognized.
3. The ASCE meets the requirements in a, b, c, or d, below.
   a. The ASCE is the primary ASCE in control register 1.
   b. The ASCE is the secondary ASCE in control register 7, and any of the following requirements is met:
      - The CPU is in the secondary-space mode or access-register mode.
      - The CPU is in the primary-space mode, and the secondary-space control, bit 37 of control register 0, is one.
      - The $M_4$ operand of LOAD PAGE TABLE ENTRY ADDRESS explicitly allows access to the secondary space or explicitly allows access-register translation.
      - Either operand's operand-access control (OAC) of MOVE WITH OPTIONAL SPECIFICATIONS explicitly allows access to the secondary space or explicitly allows access-register translation.
   c. The ASCE is in either an attached and valid ASN-second-table entry (ASTE) or a usable ALB ASTE, and any of the following requirements is met:
      - The CPU is in the access-register mode.
      - The $M_4$ field of LOAD PAGE TABLE ENTRY ADDRESS explicitly allows access-register translation to be performed.
      - Either operand's OAC of MOVE WITH OPTIONAL SPECIFICATIONS explicitly allows access-register translation to be performed.

For further explanation of the term “explicitly allows,” used in the above two items, see the programming note, below.

For further explanation of the term “explicitly allows,” used in the above two items, see the programming note, below.
d. The ASCE is the home ASCE in control register 13.

Regardless of whether DAT is on or off, an ASCE is also an attaching ASCE when the current PSW contains no errors that would cause an early specification exception to be recognized, and any of the following conditions is met:

- The home ASCE is considered to be an attaching ASCE when a monitor-event counting operation occurs.

Each of the remaining table entries in a translation path is attached when it is within the table designated either by an attached and valid entry of the next higher level which would not cause a translation-specification exception if used for translation or by a usable TLB entry of the next higher level. “Within the table” means as determined by the origin, offset, and length fields in the next-higher-level entry. A usable TLB entry is explained in the next section.

A page-table entry is attached when it is within the page table designated by either an attached and valid segment-table entry that would not cause a translation-specification exception if used for translation or a usable TLB segment-table entry.

A region-table entry or segment-table entry causes a translation-specification exception if the table-type bits, bits 60 and 61, in the entry are inconsistent with the level at which the entry would be encountered when using the translation path in the translation process. A segment-table entry also causes a translation-specification exception if the private-space-control bit is one in the address-space-control element used to select it and the common-segment bit is one in the entry. When EDAT-2 applies, a region-third-table entry also causes a translation-specification exception if the private-space-control bit is one in the address-space-control element used to select it and the common-region bit is one in the entry. A page-table entry causes a translation-specification exception if bit 52 in the entry is one. When EDAT-1 does not apply, a page-table entry also causes a translation-specification exception if bit 55 in the entry is one.

A TLB real-space entry may be formed whenever an attaching real-space designation exists. The entry is formed using the real-space token origin in the designation and any value of bits 0-51 of a virtual address.

Subject to the attached and valid constraints defined above, the CPU may form TLB entries in anticipation of future storage references or as a result of the speculative execution of instructions. See “Overlapped Operation of Instruction Execution” on page 5-112 for additional details.

Programming Note: In the above list of conditions for an ASCE to be attaching, item 3.b and 3.c use the term “explicitly allows …”, as explained below:

- LPTEA explicitly allows access to the secondary space when the M₄ field is 0010 binary.
- LPTEA explicitly allows ART to be performed when the M₄ field is 0001 binary.
- Either operand of MVCOS explicitly allows access to the secondary space when bits 8-9 of the operand’s OAC are 10 binary, bit 15 of the OAC is one, and the secondary-space control, bit 37 of control register 0, is one.
- Either operand of MVCOS explicitly allows ART to be performed when bits 8-9 of the operand’s OAC are 01 binary, and bit 15 of the OAC is one.

Use of TLB Entries

The usable state of a TLB entry denotes that the CPU can attempt to use the TLB entry for implicit address translation. A usable TLB entry attaches the next-lower-level table, if any, and may be usable for a particular instance of implicit address translation.

With reference to a TLB entry, the term “current level” refers to the level of translation table (region first table, region second table, region third table, segment table, or page table) from which the TLB entry was formed. Likewise, the “current-level index” is that portion of the virtual address used as an index into the current level of translation table.

A TLB region- or segment-table entry is in the usable state when all of the following conditions are met:

1. The current PSW specifies DAT on.
2. The current PSW contains no errors that would cause an early specification exception to be recognized.
3. The TLB entry meets at least one of the following requirements:

   a. The common-region bit is one in a TLB region-third-table entry.

   b. The common-segment bit is one in a TLB segment-table entry.

   c. The ASCE-table-origin (ASCETO) field in the TLB entry matches the table- or token-origin field in an attaching address-space-control element.

   d. The TLB entry is a TLB region-second-table, region-third-table, or segment-table entry, and the current-level table-origin field in the TLB entry matches one of the following:
      - The table-origin field in an attaching ASCE which directly designates the current table level (as indicated by the R and DT bits)
      - The table-origin field in an attached region-table entry of the next higher level
      - The table-origin field of the same level in a usable TLB region-table entry of the next higher level

A TLB region-table entry may be used for a particular instance of implicit address translation only when the entry is in the usable state, the current-level index field in the TLB entry matches the corresponding index field of the virtual address being translated, and any of the following conditions is met:

1. The ASCE-table-origin (ASCETO) field in the TLB entry matches the table- or token-origin field in the address-space-control element being used in the translation, and the portion of the virtual address being translated which is to the left of the current-level index matches the corresponding index fields in the TLB entry.

2. The address-space-control element being used in the translation designates a table of the current level, and the current-level table-origin field in the TLB entry matches the table origin in that address-space-control element.

3. The current-level table-origin field in the TLB entry matches the table origin of the same level in the next-higher-level table entry or TLB entry being used in the translation.

4. For a TLB region-third-table entry, the common-region bit is one in the TLB entry, and the region-first-index and region-second-index fields in the TLB entry matches those of the virtual address being translated.

However, when EDAT-2 applies, the TLB region-third-table entry is not used if the common-region bit is one in the entry and either the private-space-control bit is one in the address-space-control element being used in the translation or that address-space-control element is a real-space designation. In both these cases, the TLB entry is not used even if the ASCE-table-origin (ASCETO) field in the entry and the table- or token-origin field in the address-space-control element match.

A TLB segment-table entry may be used for a particular instance of implicit address translation only when the entry is in the usable state, the segment-index field in the TLB entry matches that of the virtual address being translated, and any of the following conditions is met:

1. The ASCE-table-origin (ASCETO) field in the TLB entry matches the table- or token-origin field in the address-space-control element being used in the translation, and the region-index field in the TLB entry matches that of the virtual address being translated.

2. The segment-table-origin field in the TLB entry matches the table-origin field in the address-space-control element being used in the translation, and that address-space-control element is a segment-table designation.

3. The segment-table-origin field in the TLB entry matches the segment-table-origin field in the region-third-table entry or TLB region-third-table entry being used in the translation.

4. The common-segment bit is one in the TLB entry, and the region-index field in the TLB entry matches that of the virtual address being translated.

However, the TLB segment-table entry is not used if the common-segment bit is one in the entry and either the private-space-control bit is one in the address-space-control element being used in the translation or that address-space-control element is a real-space designation. In both these cases, the TLB entry is not used even if the ASCE-table-origin (ASCETO) field in the entry and the table- or token-

3-61
origin field in the address-space-control element match.

A TLB page-table entry may be used for a particular instance of implicit address translation only when the page-table-origin field in the entry matches the page-table-origin field in the segment-table entry or TLB segment-table entry being used in the translation and the page-index field in the TLB page-table entry matches the page index of the virtual address being translated.

A TLB real-space entry may be used for implicit address translation only when the token-origin field in the TLB entry matches the table- or token-origin field in the address-space-control element being used in the translation and the region-index, segment-index, and page-index fields in the TLB entry match those of the virtual address being translated.

The operand addresses of LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, and STORE REAL ADDRESS, and accesses to the enhanced-monitor counting array may be translated with the use of the TLB contents whether DAT is on or off. However, for LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, and STORE REAL ADDRESS, TLB entries still are formed only if DAT is on.

Programming Notes:

1. Although contents of a table entry may be copied into the TLB only when the table entry is both attached and valid, the copy may remain in the TLB even when the table entry itself is no longer attached or valid.

2. Except when translations are performed as a result of enhanced-monitor counting operations, no contents can be copied into the TLB when DAT is off because the table entries at this time are not attached. In particular, translation of the operand address of LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS and STORE REAL ADDRESS with DAT off does not cause entries to be placed in the TLB.

Conversely, when DAT is on, information may be copied into the TLB from all translation-table entries that could be used for address translation, given the current translation parameters, the setting of the address-space-control bits, and the contents of the access registers. The loading of the TLB does not depend on whether the entry is used for translation as part of the execution of the current instruction, and such loading can occur when the CPU is in the wait state.

3. More than one copy of contents of a table entry may exist in the TLB. For example, some implementations may cause a copy of contents of a valid table entry to be placed in the TLB for the table origin in each address-space-control element by which the entry becomes attached.

Modification of Translation Tables

When an attached and invalid table entry is made valid and no entry usable for translation of the associated virtual address is in the TLB, the change takes effect no later than the end of the current unit of operation. Similarly, when an unattached and valid table entry is made attached and no usable entry for the associated virtual address is in the TLB, the change takes effect no later than the end of the current unit of operation.

When a valid and attached table entry is changed, and when, before the TLB is cleared of entries that qualify for substitution for that entry, an attempt is made to refer to storage by using a virtual address requiring that entry for translation, unpredictable results may occur, to the following extent. The use of the new value may begin between instructions or during the execution of an instruction, including the instruction that caused the change. Moreover, until the TLB is cleared of entries that qualify for substitution for that entry, the TLB may contain both the old and the new values, and it is unpredictable whether the old or new value is selected for a particular access. If both old and new values of a higher-level table entry are present in the TLB, a lower-level table entry may be fetched by using one value and placed in the TLB associated with the other value. If the new value of the entry is a value that would cause an exception, the exception may or may not cause an interruption to occur. If an interruption does occur, the result fields of the instruction may be changed even though the exception would normally cause suppression or nullification.

Entries are cleared from the TLB in accordance with the following rules:

1. All entries are cleared from the TLB by the execution of PURGE TLB or SET PREFIX and by CPU reset.
2. All entries may be cleared from all TLBs in the configuration by the execution of COMPARE AND SWAP AND PURGE by any of the CPUs in the configuration, depending on a bit in a general register used by the instruction.

3. Selected entries are cleared from all TLBs in the configuration by the execution of COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE DAT TABLE ENTRY or INVALIDATE PAGE TABLE ENTRY by any of the CPUs in the configuration when the local-TLB-clearing facility is not installed, or when the facility is installed but the instruction does not specify local clearing.

Only the entries in the TLB of the CPU executing COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE DAT TABLE ENTRY or INVALIDATE PAGE TABLE ENTRY are cleared when the local-TLB-clearing facility is installed and the instruction specifies local clearing.

4. Some or all TLB entries may be cleared at times other than those required by the preceding rules.

Programming Notes:

1. Entries in the TLB may continue to be used for translation after the table entries from which they have been formed have become unattached or invalid. These TLB entries are not necessarily removed unless explicitly cleared from the TLB.

A change made to an attached and valid entry or a change made to a table entry that causes the entry to become attached and valid is reflected in the translation process for the next instruction, or earlier than the next instruction, unless a TLB entry qualifies for substitution for that table entry. However, a change made to a table entry that causes the entry to become unattached or invalid is not necessarily reflected in the translation process until the TLB is cleared of entries that qualify for substitution for that table entry.

2. Exceptions associated with dynamic address translation may be established by a pretest for operand accessibility that is performed as part of the initiation of instruction execution. Consequently, a region-first-translation, region-second-translation, region-third-translation, segment-translation, or page-translation exception may be indicated when a table entry is invalid at the start of execution even if the instruction would have validated the table entry it uses and the table entry would have appeared valid if the instruction was considered to process the operands one byte at a time.

3. A change made to an attached table entry, except to set the I bit to zero, to set the CO bit of a segment- or page-table entry to one, or to alter the rightmost byte of a page-table entry, may produce unpredictable results if that entry is used for translation before the TLB is cleared of all copies of contents of that entry. The use of the new value may begin between instructions or during the execution of an instruction, including the instruction that caused the change. When an instruction, such as MOVE (MVC), makes a change to an attached table entry, including a change that makes the entry invalid, and subsequently uses the entry for translation, a changed entry is being used without a prior clearing of the entry from the TLB, and the associated unpredictability of result values and of exception recognition applies.

Manipulation of attached table entries may cause spurious table-entry values to be recorded in a TLB. For example, if changes are made piece-meal, modification of a valid attached entry may cause a partially updated entry to be recorded, or, if an intermediate value is introduced in the process of the change, a supposedly invalid entry may temporarily appear valid and may be recorded in the TLB. Such an intermediate value may be introduced if the change is made by an I/O operation that is retried, or if an intermediate value is introduced during the execution of a single instruction.

As another example, if a segment-table entry is changed to designate a different page table and used without clearing the TLB, the new page-table entries may be fetched and associated with the old page-table origin. In such a case, execution of INVALIDATE PAGE TABLE ENTRY designating the new page-table origin will not necessarily clear the page-table entries fetched from the new page table.

4. To facilitate the manipulation of page tables, the INVALIDATE PAGE TABLE ENTRY instruction is provided. This instruction sets the I bit in a page-table entry to one and clears one or more TLBs
in the configuration of entries formed from those table entries as follows:

a. All TLBs in the configuration are cleared when the local-TLB-clearing facility is not installed, or when the facility is installed and the instruction specifies the clearing of all TLBs (that is, the local-clearing control in the instruction is zero).

b. Only the TLB in the CPU executing the INVALD STATE ENTRY instruction is cleared when the local-TLB-clearing facility is installed and the instruction specifies the clearing of only the local TLB (that is, the local-clearing control in the instruction is one).

The following aspects of the TLB operation should be considered when using INVALD STATE ENTRY. (See also the programming notes for INVALD STATE ENTRY.)

a. INVALD STATE ENTRY should be executed before making any change to a page-table entry other than changing the rightmost byte; otherwise, the selective-clearing portion of INVALD STATE ENTRY may not clear the TLB copies of the entry.

b. Invalidation of all the page-table entries within a page table by means of INVALD STATE ENTRY does not necessarily clear the TLB of any segment-table entry designating the page table. When it is desired to invalidate and clear the TLB of a region- or segment-table entry, the rules in note 5 below must be followed.

Similarly, invalidation of all the lower-level table entries within a region or segment table by means of INVALD DAT TABLE ENTRY does not necessarily clear the TLB of any higher-level table entry designating the lower-level table. When it is desired to invalidate and clear the TLB of a higher-level table entry, the rules in note 5 below must be followed.

c. When a large number of page-table entries are to be invalidated at a single time, the overhead involved in using COMPARE AND SWAP AND PURGE (one that purges the TLB), INVALD DAT TABLE ENTRY, or PURGE TLB and in following the rules in note 5 below may be less than in issuing INVALD STATE ENTRY for each page-table entry.

5. Manipulation of table entries should be in accordance with the following rules. If these rules are complied with, translation is performed as if the table entries from real or absolute storage were always used in the translation process.

a. A valid table entry must not be changed while it is attached to any CPU and may be used for translation by that CPU except to (1) invalidate the entry by using INVALD STATE ENTRY or INVALD DAT TABLE ENTRY, (2) alter bits 56-63 of a page-table entry, (3) make a change by means of a COMPARE AND SWAP AND PURGE instruction that purges the TLB, or (4) replace an entry by using COMPARE AND REPLACE DAT TABLE ENTRY.

b. When any change is made to an attached and valid or unattached table entry other than a change to bits 56-63 of a page-table entry, each CPU which may have a TLB entry formed from that entry must be caused to purge its TLB after the change occurs and prior to the use of that entry for implicit translation by that CPU. (Note that a separate purge is unnecessary if the change was made by using COMPARE AND REPLACE DAT TABLE ENTRY, INVALD DAT TABLE ENTRY, INVALD STATE ENTRY, or a COMPARE AND SWAP AND PURGE instruction that purges the TLB.) In the case when the table entry is attached and valid, this rule applies when it is known that a program is not being executed that may require the entry for translation.

c. When any change is made to an invalid table entry in such a way as to allow intermediate valid values to appear in the entry, each CPU to which the entry is attached must be caused to purge its TLB after the change occurs and prior to the use of the entry for implicit address translation by that CPU.

d. When any change is made to an offset or length specified for a table, each CPU which may have a TLB entry formed from a table entry that no longer lies within its table must
be caused to purge its TLB after the change occurs and prior to the use of the table for implicit translation by that CPU.

Note that when an invalid page-table entry is made valid without introducing intermediate valid values, the TLB need not be cleared in a CPU which does not have any TLB entries formed from that entry. Similarly, when an invalid region-table or segment-table entry is made valid without introducing intermediate valid values, the TLB need not be cleared in a CPU which does not have any TLB entries formed from entries in a page table attached by means of that validated entry.

The execution of PURGE TLB, COMPARE AND SWAP AND PURGE, or SET PREFIX may have an adverse effect on the performance of some models. Use of these instructions should, therefore, be minimized in conformance with the above rules.

6. In addition to the constraints described in programming note 3 on page 3-63, the following considerations are in effect when EDAT-1 applies:

a. When the STE-format and ACCF-validity controls are both one, it is unpredictable whether the CPU inspects the access-control bits and the fetch-protection bit in the segment-table entry or in the storage key of the corresponding 4K-byte block for any given key-controlled-protection check. Therefore, the program should ensure that the access-control bits and fetch-protection bit in the segment-table entry are identical to the respective fields in all 256 storage keys for the constituent 4K-byte blocks of the segment, before setting the invalid bit in the STE to zero.

b. Prior to changing the ACCF-validity control, the access-control bits, or the fetch-protection bit in the segment-table entry, and prior to changing the access-control bits or fetch-protection bit in any of the segment’s 256 storage keys, the program should first set the invalid bit to one in the segment-table entry and clear all entries in all TLBs in the configuration, as described previously in this section.

When EDAT-2 applies, the following additional considerations are in effect:

a. When the RTTE-format control and ACCF-validity control are both one, it is unpredictable whether the CPU inspects the access-control bits and the fetch-protection bit in the region-third-table entry or in the storage key of the corresponding 4K-byte block for any given key-controlled-protection check. Therefore, the program should ensure that the access-control bits and fetch-protection bit in the region-third-table entry are identical to the respective fields in all 524,288 storage keys for the constituent 4K-byte blocks of the region, before setting the invalid bit in the RTTE to zero.

b. Prior to changing the ACCF-validity control, the access-control bits, or the fetch-protection bit in the region-third-table entry, and prior to changing the access-control bits or fetch-protection bit in any of the region’s 524,288 storage keys, the program should first set the invalid bit to one in the region-third-table entry and clear all entries in all TLBs in the configuration, as described previously in this section.

Failure to observe these procedures may lead to unpredictable results, possibly including a delayed-access-exception machine-check or failure to record a change.

Address Summary

Addresses Translated

Most addresses that are explicitly specified by the program and are used by the CPU to refer to storage are instruction or logical addresses and are subject to implicit translation when DAT is on. Analogously, the corresponding addresses indicated to the program on an interruption or as the result of executing an instruction are instruction or logical addresses. The operand address of LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, and STORE REAL ADDRESS is explicitly translated, regardless of whether the PSW specifies DAT on or off.

Translation is not applied to quantities that are formed from the values specified in the B and D fields.
of an instruction but that are not used to address storage. This includes operand addresses in EXTRACT CPU ATTRIBUTE, LOAD ADDRESS, LOAD ADDRESS EXTENDED, MONITOR CALL, the second operand address in LOAD ADDRESS SPACE PARAMETERS and SHIFT AND ROUND PACKED, and the shifting instructions. This also includes the addresses in control registers 10 and 11 designating the starting and ending locations for PER.

Except as noted below, the addresses explicitly designating storage keys (operand addresses in INSERT STORAGE KEY EXTENDED, PERFORM FRAME MANAGEMENT FUNCTION, RESET REFERENCE BIT EXTENDED, and SET STORAGE KEY EXTENDED) are real addresses.

- For INSERT VIRTUAL STORAGE KEY, the address designating the storage key is virtual.
- For PERFORM FRAME MANAGEMENT FUNCTION when the set-key control and frame-size code are both 1, for RESET REFERENCE BITS MULTIPLE, and for SET STORAGE KEY EXTENDED when the multiple-block control is one, the address designating the storage keys is absolute.

- For TEST PROTECTION, the address designating the block to be tested is logical.

The addresses implicitly used by the CPU for such sequences as interruptions are real addresses.

The addresses used by channel programs to transfer data and to refer to CCWs, IDAWs, or MIDAWs are absolute addresses.

The handling of storage addresses associated with DIAGNOSE is model-dependent.

The processing of addresses, including dynamic address translation and prefixing, is discussed in “Address Types” on page 3-4. Prefixing, when provided, is applied after the address has been translated by means of the dynamic-address-translation facility. For a description of prefixing, see “Prefixing” on page 3-18.

Handling of Addresses

The handling of addresses is summarized in Figure 3-13. This figure lists all addresses that are encountered by the program and specifies the address type.

Virtual Addresses

- Address of storage operand for INSERT VIRTUAL STORAGE KEY
- Operand address in LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, and STORE REAL ADDRESS
- Addresses of storage operands for MOVE TO PRIMARY, MOVE TO SECONDARY, and MOVE WITH OPTIONAL SPECIFICATIONS
- Address stored in the doubleword at real location 168 on a program interruption for ASCE-type, region-first-translation, region-second-translation, region-third-translation, segment-translation, or page-translation exception
- Linkage-stack-entry address in control register 15
- Backward stack-entry address in linkage-stack header entry
- Forward-section-header address in linkage-stack trailer entry
- Trap-control-block address in dispatchable-unit-control table
- Trap-save-area address and trap-program address in trap control block
- Address of the enhanced-monitor counter array in the doubleword at real location 256

Figure 3-13. Handling of Addresses (Part 1 of 3).
Instruction Addresses

- Instruction address in PSW
- Branch address
- Target of EXECUTE and EXECUTE RELATIVE LONG
- Address stored in the doubleword at real location 152 on a program interruption for PER
- Address placed in general register by BRANCH AND LINK, BRANCH AND SAVE, BRANCH AND SAVE AND SET MODE, BRANCH AND STACK, BRANCH IN SUBSPACE GROUP, BRANCH RELATIVE AND SAVE, BRANCH RELATIVE AND SAVE LONG, and PROGRAM CALL
- Address used in general register by BRANCH AND STACK
- Address placed in general register by BRANCH AND SET AUTHORITY executed in reduced-authority state
- Addresses used by BRANCH PREDICTION PRELOAD and BRANCH PREDICTION RELATIVE PRELOAD
- Aborted-transaction instruction address (in the transaction diagnostic block)

Logical Addresses

- Addresses of storage operands for instructions not otherwise specified
- Address placed in general register 1 by EDIT AND MARK and TRANSLATE AND TEST
- Addresses in general registers updated by MOVE LONG, MOVE LONG EXTENDED, COMPARE LOGICAL LONG, and COMPARE LOGICAL LONG EXTENDED
- Addresses in general registers updated by CHECKSUM, COMPARE AND FORM CODEWORD, and UPDATE TREE
- Address for TEST PENDING INTERRUPTION when the second-operand address is nonzero
- Address of parameter list of RESUME PROGRAM
- Address of the TBEGIN-specified transaction-diagnostic block

Real Addresses

- Address of storage key for INSERT STORAGE KEY EXTENDED, and RESET REFERENCE BIT EXTENDED
- Address of storage key for SET STORAGE KEY EXTENDED (when the enhanced-DAT facility is not installed, or when the enhanced-DAT facility is installed but the multiple-block control is zero)
- Address of second operand for PERFORM FRAME MANAGEMENT FUNCTION when frame-size code is 0.
- Address of storage operand for LOAD USING REAL ADDRESS, STORE USING REAL ADDRESS, and TEST BLOCK
- The translated address generated by LOAD REAL ADDRESS and STORE REAL ADDRESS
- Page-frame real address in page-table entry
- Trace-entry address in control register 12
- ASN-first-table origin in control register 14
- ASN-second-table origin in ASN-first-table entry
- Authority-table origin in ASN-second-table entry, except when used by access-register translation
- Linkage-table origin in primary ASN-second-table entry
- Entry-table origin in linkage-table entry
- Dispatchable-unit-control-table origin in control register 2
- Primary-ASN-second-table-entry origin in control register 5
- Base-ASN-second-table-entry origin and subspace-ASN-second-table-entry origin in dispatchable-unit control table
- ASN-second-table-entry address in entry-table entry and access-list entry

Permanently Assigned Real Addresses

- Address of the doubleword into which TEST PENDING INTERRUPTION stores when the second-operand address is zero
- Addresses of PSWs, interruption codes, and the associated information used during interruption
- Addresses used for machine-check logout and save areas
- Address of STORE FACILITY LIST operand

Figure 3-13. Handling of Addresses (Part 2 of 3).
Addresses which Are Unpredictably Real or Absolute

- Region-first-table origin, region-second-table origin, region-third-table origin, or segment-table origin in control registers 1, 7, and 13, in access-register-specified address-space-control element, and in region-first-table entry, region-second-table entry, or region-third-table entry
- Page-table origin in segment-table entry and in INVALIDATE PAGE TABLE ENTRY
- Address of segment-table entry or page-table entry provided by LOAD REAL ADDRESS
- Address of region-first-table entry, region-second-table entry, region-third-table entry, segment-table entry, or page-table entry provided by LOAD PAGE-TABLE-ENTRY ADDRESS
- The dispatchable-unit or primary-space access-list origin and the authority-table origin (in the ASTE designated by the ALE used) used by access-register translation

Absolute Addresses

- Prefix value
- Channel-program address in ORB
- Data address in CCW
- IDA/W address in a CCW specifying indirect data addressing
- MIDA/W address in a CCW specifying modified indirect data addressing
- CCW address in a CCW specifying transfer in channel
- Data address in IDA/W
- Data address in MIDA/W
- Measurement-block origin specified by SET CHANNEL MONITOR
- Address limit specified by SET ADDRESS LIMIT
- Addresses used by the store-status-at-address SIGNAL PROCESSOR order
- Address of storage key for RESET REFERENCE BITS MULTIPLE
- Address of storage key for SET STORAGE KEY EXTENDED (when the enhanced-DAT facility is installed and the multiple-block control is one)
- Address of second operand for PERFORM FRAME MANAGEMENT FUNCTION when frame-size code is 1.
- Failing-storage address stored in the doubleword at real location 248
- CCW address in SCSW

Permanently Assigned Absolute Addresses

- Addresses used for the store-status function
- Addresses of PSW and first two CCWs used for initial program loading

Addresses Not Used to Reference Storage

- PER starting address in control register 10
- PER ending address in control register 11
- Address stored in the doubleword at real location 176 for a monitor event
- Address in shift instructions and other instructions specified not to use the address to reference storage
- Real-space token origin in real-space designation

Figure 3-13. Handling of Addresses  (Part 3 of 3).

Assigned Storage Locations

Figure 3-14 on page 3-76 shows the format and extent of the assigned locations in storage. The locations are used as follows.

128-131 (80-83 hex) .......... Real Address

External-Interruption Parameter: During an external interruption due to service signal or timing alert, the parameter associated with the interruption is stored at locations 128-131.
132-133 (84-85 hex) . . . . . . . . . . . . . . Real Address

CPU Address: During an external interruption due to malfunction alert, emergency signal, or external call, the CPU address associated with the source of the interruption is stored at locations 132-133. For all other external-interruption conditions, zeros are stored at locations 132-133.

134-135 (86-87 hex) . . . . . . . . . . . . . . Real Address

External-Interruption Code: During an external interruption, the interruption code is stored at locations 134-135.

136-139 (88-B8 hex) . . . . . . . . . . . . . . Real Address

Supervisor-Call-Interruption Identification: During a supervisor-call interruption, the instruction-length code is stored in bit positions 5 and 6 of location 137, and the interruption code is stored at locations 138-139. Zeros are stored at location 136 and in the remaining bit positions of location 137.

140-143 (8C-8F hex) . . . . . . . . . . . . . . Real Address

Program-Interruption Identification: During a program interruption, the instruction-length code is stored in bit positions 5 and 6 of location 141, and the interruption code is stored at locations 142-143. Zeros are stored at location 140 and in the remaining bit positions of location 141.

When a transaction is aborted due to a program interruption, the instruction-length code is respective to the instruction at which the exception condition was detected.

144-147 (90-93 hex) . . . . . . . . . . . . . . Real Address

Data-Exception Code (DXC): During a program interruption due to a data exception, the data-exception code is stored at location 147, and zeros are stored at locations 144-146. The DXC is described in “Data-Exception Code (DXC)” on page 6-16.

Vector-Exception Code (VXC): During a program interruption due to a vector-processing exception, the vector-exception code is stored at location 147, and zeros are stored at locations 144-146. The VXC is described in “Vector-Exception Code” on page 6-19.

148-149 (94-95 hex) . . . . . . . . . . . . . . Real Address

Monitor-Class Number: During a program interruption due to a monitor event, the monitor-class number is stored at location 149, and zeros are stored at location 148.

150-151 (96-97 hex) . . . . . . . . . . . . . . Real Address

PER Code: During a program interruption due to a PER event the PER code is stored in bit positions 0-7 of locations 150-151, and other information is or may be stored as described in “Identification of Cause” on page 4-27.

152-159 (98-9F hex) . . . . . . . . . . . . . . Real Address

PER Address: During a program interruption due to a PER event, the PER address is stored at locations 152-159.

160 (A0 hex) . . . . . . . . . . . . . . . . . . . . Real Address

Exception Access Identification: During a program interruption due to an ASCE-type, region-first-translation, region-second-translation, region-third-translation, segment-translation, or page-translation exception, an indication of the address space to which the exception applies may be stored at location 160, as follows:

- If the access was a storage-operand reference that used an AR-specified address-space-control element, the number of the access register used is stored in bit positions 4-7 of location 160, and zeros are stored in bit positions 0-3.

- If the CPU was in the access-register mode and either (a) the access was an instruction fetch, including a fetch of the target of an execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG), or (b) the access was to the second operand of the relative-long form of COMPARE, COMPARE HALF-WORD, COMPARE LOGICAL, COMPARE LOGICAL HALFWORD, LOAD, LOAD HALF-WORD, LOAD LOGICAL, LOAD LOGICAL HALFWORD, STORE or STORE HALF-WORD, then zeros are stored at location 160.

In either of the two cases described above, storing at location 160 occurs regardless of the value stored in bit positions 62 and 63 of real locations 168-175. Otherwise, the contents of location 160 are unpredictable.
During a program interruption due to an ALEN-translation, ALE-sequence, ASTE-validity, ASTE-sequence, or extended-authority exception recognized during access-register translation, the number of the access register used is stored in bit positions 4-7 of location 160, and zeros are stored in bit positions 0-3. During a program interruption due to an ASTE-validity or ASTE-sequence exception recognized during a sub-space-replacement operation, all zeros are stored at location 160.

During a program interruption due to an ASTE-instance exception recognized due to use of the ASN-and-LX-reuse facility, (1) a one is stored in bit position 2, and zeros are stored in bit positions 0, 1, and 3-7, if the exception was recognized after primary ASN translation in PROGRAM TRANSFER WITH INSTANCE or PROGRAM RETURN, or (2) a one is stored in bit position 3, and zeros are stored in bit positions 0-2 and 4-7, if the exception was recognized after secondary ASN translation in SET SECONDARY ASN WITH INSTANCE or PROGRAM RETURN.

During a program interruption due to a protection exception, information is stored at location 160 as described in “Suppression on Protection” on page 3-14.

161 (A1 hex) . . . . . . . . . . . . . . . . . . . . Real Address

PER Access Identification: During a program interruption due to a PER storage-alteration event or PER zero-address-detection event, an indication of the address space to which the event applies may be stored at location 161. If the access used an AR-specified address-space-control element, the number of the access register used is stored in bit positions 4-7 of location 161, and zeros are stored in bit positions 0-3. The contents of location 161 are unpredictable if the access did not use an AR-specified address-space-control element.

Programming Note: The PER ASCE identification may be inspected to determine whether the PER storage-alteration event or PER zero-address-detection event used an AR-specified ASCE. See “PER ASCE Identification (AI)” on page 4-28 for further details.

162 (A2 hex) . . . . . . . . . . . . . . . . . . . . . Real Address

Operand Access Identification: When EDAT-1 does not apply, and a program interruption due to a page-translation exception is recognized by the MOVE PAGE instruction, the contents of the R1 field of the instruction are stored in bit positions 0-3 of location 162, and the contents of the R2 field are stored in bit positions 4-7. If the page-translation exception was recognized during the execution of an instruction other than MOVE PAGE, or if an ASCE-type, region-first-translation, region-second-translation, region-third-translation, or segment-translation exception was recognized, the contents of location 162 are unpredictable.

When EDAT-1 applies, and a program interruption due to a region-first-translation, region-second-translation, region-third-translation, segment-translation, or page-translation exception is recognized by the MOVE PAGE instruction, the contents of the R1 and R2 fields are stored in location 162 as described above. If any of the exceptions listed in the preceding sentence was recognized during the execution of an instruction other than MOVE PAGE, or if an ASCE-type exception was recognized, the contents of location 162 are unpredictable.

163 (A3 hex) . . . . . . . . . . . . . . . . . Absolute Address

Store-Status Architectural-Mode Identification: During the execution of the store-status operation, zeros are stored in bit positions 0-6 of location 163, and a one is stored in bit position 7. A zero stored in bit position 7 indicates the ESA/390 architectural mode, and a one indicates the z/Architecture architectural mode.

163 (A3 hex) . . . . . . . . . . . . . . . . . . . . . Real Address

Machine-Check Architectural-Mode Identification: During a machine-check interruption, zeros are stored in bit positions 0-6 of location 163, and a one is stored in bit position 7. A zero stored in bit position 7 indicates the ESA/390 architectural mode, and a one indicates the z/Architecture architectural mode.

168-175 (A8-AF hex) . . . . . . . . . . . . . . Real Address

Translation-Exception Identification for DAT Exceptions: During a program interruption due to an ASCE-type, region-first-translation, region-second-translation, region-third-translation, seg-
ment-translation, or page-translation exception, bits 0-51 of the virtual address causing the exception are stored in bit positions 0-51 of locations 168-175. This address is sometimes referred to as the translation-exception address.

When the access-exception-fetch/store-indication facility is installed, bits 52 and 53 of locations 168-175 are set as described below.

**Access-Exception Fetch/Store Indication:** Bit positions 52-53 of locations 168-175 contain an indication of whether the exception was due to a fetch or a store operation, as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>52</td>
<td>53</td>
<td>0 0 Could not determine whether the exception was due to a fetch or store</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 1 Exception was due to a store operation</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 0 Exception was due to a fetch operation</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 1 Reserved</td>
</tr>
</tbody>
</table>

When the access-exception-fetch/store-indication facility is not installed, bits 52 and 53 of locations 168-175 are unpredictable.

The access-exception fetch/store indication is stored for ASCE-type, page-translation, protection, region-first-translation, region-second-translation, region-third translation, and segment-translation exceptions.

For a storage-operand update reference, it is unpredictable whether a fetch or store access is indicated. When multiple access-exception conditions exist — for one or more operands — the condition recognized is determined based on the discussion of “Multiple Program-Interruption Conditions” on page 6-48.

The enhanced suppression on protection facility is a prerequisite for the access-exception-fetch/store-indication facility.

**MOVE PAGE Indication:** When EDAT-1 does not apply, and the exception was a page-translation exception that was recognized during the execution of MOVE PAGE, bit 61 of locations 168-175 is set to one. If the exception was a page-translation exception recognized during the execution of an instruction other than MOVE PAGE, bit 61 is set to zero. If the exception was an ASCE-type, region-first-translation, region-second-translation, region-third-translation, or segment-translation exception, bit 61 of locations 168-175 is unpredictable. See the definition of real location 162 for related information.

When EDAT-1 applies, and the exception was a region-first-, region-second, region-third-, segment-, or page-translation exception that was recognized during the execution of MOVE PAGE, bit 61 of locations 168-175 is set to one. If the exception was a region-first-, region-second, region-third-, segment-, or page-translation exception recognized during the execution of an instruction other than MOVE PAGE, bit 61 is set to zero. If the exception was an ASCE-type exception, bit 61 of locations 168-175 is unpredictable. See the definition of real location 162 for related information.

**ASCE Identifier:** Bits 62 and 63 of locations 168-175 are set to identify the address-space-control element (ASCE) used in the translation, as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>62</td>
<td>63</td>
<td>0 0 Primary ASCE was used.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 1 CPU was in the access-register mode, and either the access was an instruction fetch or it was a storage-operand reference that used an AR-specified ASCE (the access was not an implicit reference to the linkage stack). The exception access id, real location 160, can be examined to determine the ASCE used. However, if the primary, secondary, or home ASCE was used, bits 62 and 63 may be set to 00, 10, or 11, respectively, instead of 01.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 0 Secondary ASCE was used.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 1 Home ASCE was used (includes the case of an implicit reference to the linkage stack).</td>
</tr>
</tbody>
</table>

The CPU may avoid setting bits 62 and 63 to 01 by recognizing that the access was an instruction fetch, that access-list-entry token 00000000 or 00000001 hex was used, or that the access-list-entry token designated, through an access-list entry, an ASN-second-table entry containing an ASCE equal to the primary ASCE, secondary ASCE, or home ASCE.

Bits 54-60 are unpredictable.

**Translation-Exception Identification for Protection Exceptions:** During a program interruption due to a protection exception, information is stored at locations 168-175 as described in “Suppression on Protection” on page 3-14 and in
"Enhanced Suppression on Protection" on page 3-16.

**Translation-Exception Identification for ASN-Translation Exceptions:** During a program interruption due to an AFX-translation, ASX-translation, primary-authority, or secondary-authority exception, the ASN being translated is stored at locations 174 and 175, zeros are stored at locations 172 and 173, and the contents of locations 168-171 remain unchanged.

**Translation-Exception Identification for Space-Switch Events:** During a program interruption due to a space-switch event, an identification of the old instruction space is stored at locations 174 and 175, the old instruction-space space-switch-event-control bit is placed in bit position 0 and zeros are placed in bit positions 1-15 of locations 172 and 173, and the contents of locations 168-171 remain unchanged. The identification and bit stored are as follows:

- If the CPU was in the primary-space, secondary-space, or access-register mode before the operation, the old PASN, bits 48-63 of control register 4 before the operation, is stored at locations 174 and 175, and the old primary space-switch-event-control bit, bit 57 of control register 1 before the operation, is placed in bit position 0 of locations 172 and 173.
- If the CPU was in the home-space mode before the operation, zeros are stored at locations 174 and 175, and the home space-switch-event-control bit, bit 57 of control register 13, is placed in bit position 0 of locations 172 and 173.

**Translation-Exception Identification During PC-Number Translation:** During a program interruption due to an EX-translation or LX-translation exception recognized by PROGRAM CALL when ASN-and-LX reuse is not installed or is not enabled by a one value of the ASN-and-LX-reuse control in control register 0, bits 44-63 of the second-operand address used by PROGRAM CALL (a 20-bit PC number), with 12 zeros appended on the left, are stored at locations 172-175. If bit 44 of the second-operand address is one, bits 32-63 of the address (a 32-bit PC number) are stored at locations 172-175. In either of these cases, the contents of locations 168-171 remain unchanged.

176-183 (B0-B7 hex) . . . . . . . . . . . . . . Real Address

**Monitor Code:** During a program interruption due to a monitor event, the monitor code is stored at locations 176-183.

184-187 (B8-BB hex) . . . . . . . . . . . . . . Real Address

**Subsystem-Identification Word:** During an I/O interruption, the subsystem-identification word is stored at locations 184-187.

188-191 (BC-BF hex) . . . . . . . . . . . . . . Real Address

**I/O-Interruption Parameter:** During an I/O interruption, the interruption parameter from the associated subchannel is stored at locations 188-191.

192-195 (C0-C3 hex) . . . . . . . . . . . . . . Real Address

**I/O-Interruption-Identification Word:** During an I/O interruption, the I/O-interruption-identification word, which further identifies the source of the I/O interruption, is stored at locations 192-195.

200-203 (C8-CB hex) . . . . . . . . . . . . . . Real Address

**STFL Facility List:** The STORE FACILITY LIST instruction stores information at real locations 200-203. The information describes which facilities are provided by the configuration. The information stored is identical in format to the first 32 bits stored by the STORE FACILITY LIST EXTENDED instruction. Figure 4-24, “Assigned Facility Bits” on page 4-76 shows the meanings of the assigned facility bits.

232-239 (E8-EF hex) . . . . . . . . . . . . . . Real Address

**Machine-Check-Interruption Code:** During a machine-check interruption, the machine-check-interruption code is stored at locations 232-239.
External-Damage Code: During a machine-check interruption due to certain external-damage conditions, depending on the model, an external-damage code may be stored at locations 244-247.

Failing-Storage Address: During a machine-check interruption, a 64-bit failing-storage address may be stored at locations 248-255.

Enhanced-Monitor Counter-Array Origin: Bits 0-60 of the doubleword at location 256, appended on the right with three binary zeros, form the 64-bit virtual address of the enhanced-monitor counter array in the home address space.

During the execution of the MONITOR CALL instruction when the enhanced-monitor facility is installed, both the monitor-mask bit and enhanced-monitor-mask bit in control register 8 corresponding to the monitor class are ones, and the monitor code derived from the first-operand address is less than the enhanced-monitor counter-array size in location 264, then the enhanced-monitor counter designated by the first-operand location is incremented by one.

Programming Note: It is recommended that the enhanced-monitor counter array be allocated on a cache-line boundary of the CPU’s first-level data cache. The cache line size may be determined by the EXTRACT CPU ATTRIBUTES (ECAG) instruction.

Enhanced-Monitor Counter-Array Size: The word at location 264 contains a 32-bit unsigned binary value that is referenced during the execution of the MONITOR CALL instruction when the enhanced-monitor facility is installed, and both the monitor-mask bit and enhanced-monitor-mask bit in control register 8 corresponding to the monitor class are both ones. In this case, if the monitor code derived from the first-operand address is less than the enhanced-monitor counter-array size in location 264, then the counter designated by the first-operand location is incremented by one; otherwise, the enhanced-monitor exception counter at location 268 is incremented.

Enhanced-Monitor Exception Count: The word at location 268 contains a 32-bit unsigned binary value that may be updated during the execution of the MONITOR CALL instruction when the enhanced-monitor facility is installed, and the monitor-class bit and corresponding enhanced-monitor-class bit in control register 8 are both ones. The word is updated in either of the following two cases:

- The monitor code derived from the first-operand address is greater than or equal to than the enhanced-monitor counter-array size in location 264.
- The counter designated by the first-operand location is inaccessible.

Breaking-Event Address: If the PER-3 facility is installed, then, during a program interruption, the contents of the breaking-event-address register are stored in locations 272-279. If the breaking-event-address-recording facility is not installed, this location remains unchanged.

Restart Old PSW: The current PSW is stored as the old PSW at locations 288-303 during a restart interruption.

External Old PSW: The current PSW is stored as the old PSW at locations 304-319 during an external interruption.

Supervisor-Call Old PSW: The current PSW is stored as the old PSW at locations 320-335 during a supervisor-call interruption.

Program Old PSW: The current PSW is stored as the old PSW at locations 336-351 during a program interruption.
352-367 (160-16F hex) .............. Real Address

**Machine-Check Old PSW:** The current PSW is stored as the old PSW at locations 352-367 during a machine-check interruption.

368-383 (170-17F hex) .............. Real Address

**Input/Output Old PSW:** The current PSW is stored as the old PSW at locations 368-383 during an I/O interruption.

416-431 (1A0-1AF hex) .............. Real Address

**Restart New PSW:** The new PSW is fetched from locations 416-431 during a restart interruption.

432-447 (1B0-1BF hex) .............. Real Address

**External New PSW:** The new PSW is fetched from locations 432-447 during an external interruption.

448-463 (1C0-1CF hex) .............. Real Address

**Supervisor-Call New PSW:** The new PSW is fetched from locations 448-463 during a supervisor-call interruption.

464-479 (1D0-1DF hex) .............. Real Address

**Program New PSW:** The new PSW is fetched from locations 464-479 during a program interruption.

480-495 (1E0-1EF hex) .............. Real Address

**Machine-Check New PSW:** The new PSW is fetched from locations 480-495 during a machine-check interruption.

496-511 (1F0-1FF hex) .............. Real Address

**Input/Output New PSW:** The new PSW is fetched from locations 496-511 during an I/O interruption.

4528-4535 (11B0-11B7 hex) ........... Real Address

**Machine-Check-Extended-Save-Area Address:** During a machine check interruption, bits 0-53 of locations 4528-4535, with 10 zeros appended on the right, are used as the absolute address of a 1024-byte extended save area. Bits 54-63 are reserved and should be zeros. They are ignored when forming the address of the extended save area. When bits 0-53 are all zeros, storing is not performed in the extended save area.

4544-4607 (11C0-11FF hex) ........... Real Address

**Available for Programming:** Locations 4544-4607 are available for use by programming.

4608-4735 (1200-127F hex) .......... Absolute Address

**Store-Status Floating-Point-Register Save Area:** During the execution of the store-status operation, the contents of the floating-point registers are stored at locations 4608-4735.

4608-4735 (1200-127F hex) .......... Absolute Address

**Machine-Check Floating-Point-Register Save Area:** During a machine-check interruption, the contents of the floating-point registers are stored at locations 4608-4735.

4736-4863 (1280-12FF hex) .......... Absolute Address

**Store-Status General-Register Save Area:** During the execution of the store-status operation, the contents of the general registers are stored at locations 4736-4863.

4736-4863 (1280-12FF hex) .......... Absolute Address

**Machine-Check General-Register Save Area:** During a machine-check interruption, the contents of the general registers are stored at locations 4736-4863.

4864-4879 (1300-130F hex) .......... Absolute Address

**Store-Status PSW Save Area:** During the execution of the store-status operation, the contents of the current PSW are stored at locations 4864-4879.

4864-4879 (1300-130F hex) .......... Absolute Address

**Fixed-Logout Area:** Depending on the model, logout information may be stored at locations 4864-4879 during a machine-check interruption.

4880-4887 (1310-1317 hex) .......... Absolute Address

**Assigned to IBM internal use.**

4888-4891 (1318-131B hex) .......... Absolute Address

**Store-Status Prefix Save Area:** During the execution of the store-status operation, the contents of the prefix register are stored at locations 4888-4891.
Store-Status Floating-Point-Control-Register Save Area: During the execution of the store-status operation, the contents of the floating-point control register are stored at locations 4892-4895.

Machine-Check Floating-Point-Control-Register Save Area: During a machine-check interruption, the contents of the floating-point control register are stored at locations 4892-4895.

Store-Status TOD-Programmable-Register Save Area: During the execution of the store-status operation, the contents of the TOD programmable register are stored at locations 4900-4903.

Machine-Check TOD-Programmable-Register Save Area: During a machine-check interruption, the contents of the TOD programmable register are stored at locations 4900-4903.

Store-Status CPU-Timer Save Area: During the execution of the store-status operation, the contents of the CPU timer are stored at locations 4904-4911.

Machine-Check CPU-Timer Save Area: During a machine-check interruption, the contents of the CPU timer are stored at locations 4904-4911.

Store-Status Clock-Comparator Save Area: During the execution of the store-status operation, the contents of bit positions 0-55 of the clock comparator are stored at locations 4913-4919. When this store occurs, zeros are stored at location 4912.

Machine-Check Clock-Comparator Save Area: During a machine-check interruption, the contents of bit positions 0-55 of the clock comparator are stored at locations 4913-4919. When this store occurs, zeros are stored at location 4912.

Store-Status Access-Register Save Area: During the execution of the store-status operation, the contents of the access registers are stored at locations 4928-4991.

Machine-Check Access-Register Save Area: During a machine-check interruption, the contents of the access registers are stored at locations 4928-4991.

Store-Status Control-Register Save Area: During the execution of the store-status operation, the contents of the control registers are stored at locations 4992-5119.

Machine-Check Control-Register Save Area: During a machine-check interruption, the contents of the control registers are stored at locations 4992-5119.

Programming Notes:

1. When the CPU is in the access-register mode, some instructions, such as MVCL, which address operands in more than one address space, may cause a storage-alteration PER event in one address space concurrently with a region-translation, segment-translation, or page-translation exception in another address space. The access registers used to cause these conditions in such a case are different. In order to identify both access registers, two access identifications, namely the exception access identification and the PER access identification, are provided.

2. The store-status and machine-check architectural-mode identifications at absolute and real locations 163, respectively, indicate that the CPU
is in the z/Architecture architectural mode. When z/Architecture is installed on the CPU but the CPU is in the ESA/390 mode, the store-status and machine-check-interruption operations store zero at location 163.

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Fields</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td></td>
</tr>
<tr>
<td>C</td>
<td>12</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>16</td>
<td>Available for Use by Programming (after IPL)</td>
</tr>
<tr>
<td>14</td>
<td>20</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>24</td>
<td></td>
</tr>
<tr>
<td>1C</td>
<td>28</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>32</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>36</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>40</td>
<td></td>
</tr>
<tr>
<td>2C</td>
<td>44</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>48</td>
<td></td>
</tr>
<tr>
<td>34</td>
<td>52</td>
<td></td>
</tr>
<tr>
<td>38</td>
<td>56</td>
<td></td>
</tr>
<tr>
<td>3C</td>
<td>60</td>
<td></td>
</tr>
<tr>
<td>40</td>
<td>64</td>
<td></td>
</tr>
<tr>
<td>44</td>
<td>68</td>
<td></td>
</tr>
<tr>
<td>48</td>
<td>72</td>
<td></td>
</tr>
<tr>
<td>4C</td>
<td>76</td>
<td></td>
</tr>
<tr>
<td>50</td>
<td>80</td>
<td></td>
</tr>
<tr>
<td>54</td>
<td>84</td>
<td></td>
</tr>
<tr>
<td>58</td>
<td>88</td>
<td></td>
</tr>
<tr>
<td>5C</td>
<td>92</td>
<td></td>
</tr>
<tr>
<td>60</td>
<td>96</td>
<td></td>
</tr>
<tr>
<td>64</td>
<td>100</td>
<td></td>
</tr>
<tr>
<td>68</td>
<td>104</td>
<td></td>
</tr>
<tr>
<td>6C</td>
<td>108</td>
<td></td>
</tr>
<tr>
<td>70</td>
<td>112</td>
<td></td>
</tr>
<tr>
<td>74</td>
<td>116</td>
<td></td>
</tr>
<tr>
<td>78</td>
<td>120</td>
<td></td>
</tr>
<tr>
<td>7C</td>
<td>124</td>
<td></td>
</tr>
<tr>
<td>80</td>
<td>128</td>
<td></td>
</tr>
<tr>
<td>84</td>
<td>132</td>
<td>CPU Address</td>
</tr>
<tr>
<td>88</td>
<td>136</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
<tr>
<td>8C</td>
<td>140</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
<tr>
<td>90</td>
<td>144</td>
<td></td>
</tr>
<tr>
<td>94</td>
<td>148</td>
<td>Monitor-Class Number</td>
</tr>
<tr>
<td>98</td>
<td>152</td>
<td></td>
</tr>
<tr>
<td>9C</td>
<td>156</td>
<td></td>
</tr>
<tr>
<td>A0</td>
<td>160</td>
<td>Exception Access ID</td>
</tr>
<tr>
<td>A4</td>
<td>164</td>
<td></td>
</tr>
<tr>
<td>AC</td>
<td>172</td>
<td></td>
</tr>
<tr>
<td>B4</td>
<td>180</td>
<td></td>
</tr>
</tbody>
</table>

*Figure 3-14. Assigned Storage Locations (Part 1 of 4).*
<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Fields</th>
</tr>
</thead>
<tbody>
<tr>
<td>B8</td>
<td>184</td>
<td>Subsystem-Identification Word</td>
</tr>
<tr>
<td>BC</td>
<td>188</td>
<td>I/O-Interruption Parameter</td>
</tr>
<tr>
<td>C0</td>
<td>192</td>
<td>I/O-Interruption-Identification Word</td>
</tr>
<tr>
<td>C4</td>
<td>196</td>
<td></td>
</tr>
<tr>
<td>C8</td>
<td>200</td>
<td>STFL Facility List</td>
</tr>
<tr>
<td>CC</td>
<td>204</td>
<td></td>
</tr>
<tr>
<td>D0</td>
<td>208</td>
<td></td>
</tr>
<tr>
<td>D4</td>
<td>212</td>
<td></td>
</tr>
<tr>
<td>D8</td>
<td>216</td>
<td>Available for Use by Programming</td>
</tr>
<tr>
<td>DC</td>
<td>220</td>
<td></td>
</tr>
<tr>
<td>E0</td>
<td>224</td>
<td></td>
</tr>
<tr>
<td>E4</td>
<td>228</td>
<td></td>
</tr>
<tr>
<td>E8</td>
<td>232</td>
<td>Machine-Check Interruption Code</td>
</tr>
<tr>
<td>EC</td>
<td>236</td>
<td></td>
</tr>
<tr>
<td>F0</td>
<td>240</td>
<td></td>
</tr>
<tr>
<td>F4</td>
<td>244</td>
<td>External-Damage Code</td>
</tr>
<tr>
<td>F8</td>
<td>248</td>
<td>Failing-Storage Address</td>
</tr>
<tr>
<td>FC</td>
<td>252</td>
<td></td>
</tr>
<tr>
<td>100</td>
<td>256</td>
<td>Enhanced-Monitor Counter-Array Origin</td>
</tr>
<tr>
<td>104</td>
<td>260</td>
<td></td>
</tr>
<tr>
<td>108</td>
<td>264</td>
<td>Enhanced-Monitor Counter-Array Size</td>
</tr>
<tr>
<td>10C</td>
<td>268</td>
<td>Enhanced-Monitor Exception Count</td>
</tr>
<tr>
<td>110</td>
<td>272</td>
<td>Breaking-Event Address</td>
</tr>
<tr>
<td>114</td>
<td>276</td>
<td></td>
</tr>
<tr>
<td>118</td>
<td>280</td>
<td></td>
</tr>
<tr>
<td>11C</td>
<td>284</td>
<td></td>
</tr>
<tr>
<td>120</td>
<td>288</td>
<td></td>
</tr>
<tr>
<td>124</td>
<td>292</td>
<td></td>
</tr>
<tr>
<td>128</td>
<td>296</td>
<td></td>
</tr>
<tr>
<td>12C</td>
<td>300</td>
<td></td>
</tr>
<tr>
<td>130</td>
<td>304</td>
<td></td>
</tr>
<tr>
<td>134</td>
<td>308</td>
<td></td>
</tr>
<tr>
<td>138</td>
<td>312</td>
<td></td>
</tr>
<tr>
<td>13C</td>
<td>316</td>
<td></td>
</tr>
<tr>
<td>140</td>
<td>320</td>
<td></td>
</tr>
<tr>
<td>144</td>
<td>324</td>
<td></td>
</tr>
<tr>
<td>148</td>
<td>328</td>
<td></td>
</tr>
<tr>
<td>14C</td>
<td>332</td>
<td></td>
</tr>
<tr>
<td>150</td>
<td>336</td>
<td></td>
</tr>
<tr>
<td>154</td>
<td>340</td>
<td></td>
</tr>
<tr>
<td>158</td>
<td>344</td>
<td></td>
</tr>
<tr>
<td>15C</td>
<td>348</td>
<td></td>
</tr>
<tr>
<td>160</td>
<td>352</td>
<td></td>
</tr>
<tr>
<td>164</td>
<td>356</td>
<td></td>
</tr>
<tr>
<td>168</td>
<td>360</td>
<td></td>
</tr>
<tr>
<td>16C</td>
<td>364</td>
<td></td>
</tr>
<tr>
<td>170</td>
<td>368</td>
<td></td>
</tr>
<tr>
<td>174</td>
<td>372</td>
<td></td>
</tr>
<tr>
<td>178</td>
<td>376</td>
<td></td>
</tr>
<tr>
<td>17C</td>
<td>380</td>
<td></td>
</tr>
</tbody>
</table>

Figure 3-14. Assigned Storage Locations (Part 2 of 4).
<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Fields</th>
</tr>
</thead>
<tbody>
<tr>
<td>180</td>
<td>384</td>
<td></td>
</tr>
<tr>
<td>184</td>
<td>388</td>
<td></td>
</tr>
<tr>
<td>188</td>
<td>392</td>
<td></td>
</tr>
<tr>
<td>18C</td>
<td>396</td>
<td></td>
</tr>
<tr>
<td>190</td>
<td>400</td>
<td></td>
</tr>
<tr>
<td>194</td>
<td>404</td>
<td></td>
</tr>
<tr>
<td>198</td>
<td>408</td>
<td></td>
</tr>
<tr>
<td>19C</td>
<td>412</td>
<td></td>
</tr>
<tr>
<td>1A0</td>
<td>416</td>
<td>Restart New PSW</td>
</tr>
<tr>
<td>1A4</td>
<td>420</td>
<td></td>
</tr>
<tr>
<td>1A8</td>
<td>424</td>
<td></td>
</tr>
<tr>
<td>1AC</td>
<td>428</td>
<td></td>
</tr>
<tr>
<td>1B0</td>
<td>432</td>
<td></td>
</tr>
<tr>
<td>1B4</td>
<td>436</td>
<td>External New PSW</td>
</tr>
<tr>
<td>1B8</td>
<td>440</td>
<td></td>
</tr>
<tr>
<td>1BC</td>
<td>444</td>
<td></td>
</tr>
<tr>
<td>1C0</td>
<td>448</td>
<td>Supervisor-Call New PSW</td>
</tr>
<tr>
<td>1C4</td>
<td>452</td>
<td></td>
</tr>
<tr>
<td>1C8</td>
<td>456</td>
<td></td>
</tr>
<tr>
<td>1CC</td>
<td>460</td>
<td></td>
</tr>
<tr>
<td>1D0</td>
<td>464</td>
<td></td>
</tr>
<tr>
<td>1D4</td>
<td>468</td>
<td>Program New PSW</td>
</tr>
<tr>
<td>1D8</td>
<td>472</td>
<td></td>
</tr>
<tr>
<td>1DC</td>
<td>476</td>
<td></td>
</tr>
<tr>
<td>1E0</td>
<td>480</td>
<td></td>
</tr>
<tr>
<td>1E4</td>
<td>484</td>
<td>Machine-Check New PSW</td>
</tr>
<tr>
<td>1E8</td>
<td>488</td>
<td></td>
</tr>
<tr>
<td>1EC</td>
<td>492</td>
<td></td>
</tr>
<tr>
<td>1F0</td>
<td>496</td>
<td>Input/Output New PSW</td>
</tr>
<tr>
<td>1F4</td>
<td>500</td>
<td></td>
</tr>
<tr>
<td>1F8</td>
<td>504</td>
<td></td>
</tr>
<tr>
<td>1FC</td>
<td>508</td>
<td></td>
</tr>
<tr>
<td>200</td>
<td>512</td>
<td></td>
</tr>
<tr>
<td>204</td>
<td>516</td>
<td></td>
</tr>
<tr>
<td>FF8</td>
<td>4088</td>
<td></td>
</tr>
<tr>
<td>FFC</td>
<td>4092</td>
<td></td>
</tr>
<tr>
<td>1000</td>
<td>4096</td>
<td>(448 bytes)</td>
</tr>
<tr>
<td>11BC</td>
<td>4540</td>
<td></td>
</tr>
<tr>
<td>11C0</td>
<td>4544</td>
<td></td>
</tr>
<tr>
<td>11C4</td>
<td>4548</td>
<td>Available for Use by Programming (64 bytes)</td>
</tr>
<tr>
<td>11F8</td>
<td>4600</td>
<td></td>
</tr>
<tr>
<td>11FC</td>
<td>4604</td>
<td></td>
</tr>
<tr>
<td>1200</td>
<td>4608</td>
<td>Store-Status or Machine-Check Floating-Point-Register Save Area (128 bytes)</td>
</tr>
<tr>
<td>1204</td>
<td>4612</td>
<td></td>
</tr>
<tr>
<td>1278</td>
<td>4728</td>
<td></td>
</tr>
<tr>
<td>127C</td>
<td>4732</td>
<td></td>
</tr>
</tbody>
</table>

Figure 3-14. Assigned Storage Locations (Part 3 of 4).
<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Fields</th>
</tr>
</thead>
<tbody>
<tr>
<td>1280</td>
<td>4736</td>
<td>Store-Status or Machine-Check General-Register Save Area (128 bytes)</td>
</tr>
<tr>
<td>1284</td>
<td>4740</td>
<td>Store-Status PSW Save Area; or Fixed Logout Area</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Assigned to IBM internal use</td>
</tr>
<tr>
<td>1318</td>
<td>4888</td>
<td>Store-Status Prefix Save Area</td>
</tr>
<tr>
<td>131C</td>
<td>4924</td>
<td>Store-Status or Machine-Check Floating-Point-Control-Register Save Area</td>
</tr>
<tr>
<td>1324</td>
<td>4960</td>
<td>Store-Status or Machine-Check TOD-Programmable-Register Save Area</td>
</tr>
<tr>
<td>1328</td>
<td>4992</td>
<td>Store-Status or Machine-Check CPU-Timer Save Area</td>
</tr>
<tr>
<td>1334</td>
<td>4996</td>
<td>Store-Status or Machine-Check Clock-Comparator Bits 0-55 Save Area</td>
</tr>
<tr>
<td>1340</td>
<td>4998</td>
<td>Store-Status or Machine-Check Access-Register Save Area (64 bytes)</td>
</tr>
<tr>
<td>1384</td>
<td>5120</td>
<td>Store-Status or Machine-Check Control-Register Save Area (128 bytes)</td>
</tr>
<tr>
<td>1400</td>
<td>5124</td>
<td>Program-Interruption Transaction Diagnostic Block (256 bytes)</td>
</tr>
</tbody>
</table>

Figure 3-14. Assigned Storage Locations (Part 4 of 4).
# Chapter 4. Control

Stopped, Operating, Load, and Check-Stop States ........................................... 4-2  
Stopped State .......................................................................................... 4-2  
Operating State ....................................................................................... 4-2  
Load State ............................................................................................... 4-3  
Check-Stop State .................................................................................... 4-3  
Program-Status Word ........................................................................... 4-3  
Program-Status-Word Format ................................................................. 4-5  
Control Registers ..................................................................................... 4-7  
Control-Register Allocation and Address- 
Space-Control Element ................................................................. 4-24  
PER Operation ...................................................................................... 4-26  
Identification of Cause ........................................................................ 4-27  
Priority of Indication ........................................................................... 4-30  
Storage-Area Designation ............................................................ 4-31  
PER Events ............................................................................................ 4-32  
Successful Branching ........................................................................... 4-32  
Instruction Fetching ............................................................................... 4-33  
Storage Alteration ................................................................................. 4-33  
Store Using Real Address ...................................................................... 4-34  
Zero-Address Detection ....................................................................... 4-34  
Transaction End ..................................................................................... 4-36  
Indication of PER Events Concurrently with 
Other Interruption Conditions ............................................................... 4-36  
Breaking-Event-Address Recording ......................................................... 4-39  
Breaking-Event-Address Register ............................................................... 4-40  
Execution-Break Instructions ................................................................. 4-40  
Timing .................................................................................................... 4-41  
Time-of-Day Clock ................................................................................ 4-41  
Format ..................................................................................................... 4-41  
States ....................................................................................................... 4-41  
Changes in Clock State ......................................................................... 4-43  
Setting and Inspecting the Clock ............................................................... 4-43  
TOD Programmable Register ................................................................. 4-45  
TOD-Clock Synchronization .................................................................. 4-47  
Timing Mode ........................................................................................... 4-47  
Timing State ............................................................................................ 4-47  
STP Clock Source State ......................................................................... 4-48  
TOD-Clock Steering ................................................................................ 4-48  
Offset-Based TOD-Clock Steering ........................................................... 4-49  
Overview ............................................................................................... 4-49  
Hardware-Based TOD-Clock-Steering 
Overview ............................................................................................... 4-49  
TOD-Offset-Update Events .................................................................... 4-49  
Episodes ................................................................................................ 4-50  
TOD-Clock-Steering Registers ............................................................... 4-50  
UTC Information Block (UIB) ................................................................. 4-51  
Clock Comparator .................................................................................. 4-53  
CPU Timer ............................................................................................. 4-54  
externally Initiated Functions ............................................................... 4-55  
Resets .................................................................................................... 4-55  
CPU Reset ............................................................................................ 4-58  
Initial CPU Reset ............................................................................... 4-59  
Subsystem Reset .................................................................................. 4-60  
Clear Reset ............................................................................................ 4-60  
Power-On Reset .................................................................................... 4-61  
Initial Program Loading .......................................................................... 4-61  
CCW-Type IPL ....................................................................................... 4-61  
Store Status ............................................................................................ 4-62  
Multiprocessing ..................................................................................... 4-63  
Shared Main Storage ............................................................................ 4-63  
CPU-Address Identification .................................................................. 4-63  
CPU-Address Expansion ...................................................................... 4-63  
CPU-Address Contraction .................................................................... 4-64  
CPU Signaling and Response ................................................................. 4-64  
Signal-Processor Orders ....................................................................... 4-64  
Sense ...................................................................................................... 4-65  
External Call ......................................................................................... 4-65  
Emergency Signal ............................................................................... 4-65  
Start ........................................................................................................ 4-65  
Stop ........................................................................................................ 4-65  
Restart .................................................................................................... 4-65  
Stop and Store Status ........................................................................... 4-65  
Initial CPU Reset .................................................................................. 4-65  
CPU Reset ............................................................................................ 4-66  
Set Prefix .............................................................................................. 4-66  
Store Status at Address ......................................................................... 4-66  
Set Architecture .................................................................................... 4-67  
Conditional Emergency Signal ............................................................... 4-68  
Sense Running Status ........................................................................... 4-69  
Set Multithreading ............................................................................... 4-69  
Store Additional Status at Address ......................................................... 4-70  
Conditions Determining Response ......................................................... 4-71  
Conditions Precluding Interpretation of the 
Order Code ............................................................................................ 4-71  
Status Bits ............................................................................................. 4-72  
Facility Indications ............................................................................... 4-75  

© Copyright IBM Corp. 1990-2015

4-1
This chapter describes in detail the facilities for controlling, measuring, and recording the operation of one or more CPUs.

**Stopped, Operating, Load, and Check-Stop States**

The stopped, operating, load, and check-stop states are four mutually exclusive states of the CPU. When the CPU is in the stopped state, instructions and interruptions, other than the restart interruption, are not executed. In the operating state, the CPU executes instructions and takes interruptions, subject to the control of the program-status word (PSW) and control registers, and in the manner specified by the setting of the operator-facility rate control. The CPU is in the load state during the initial-program-loading operation of ESA/390. The CPU enters the check-stop state only as the result of machine malfunctions.

A change between these four CPU states can be effected by use of the operator facilities or by acceptance of certain SIGNAL PROCESSOR orders addressed to that CPU. The states are not controlled or identified by bits in the PSW. The stopped, load, and check-stop states are indicated to the operator by means of the manual indicator, load indicator, and check-stop indicator, respectively. These three indicators are off when the CPU is in the operating state.

The CPU timer is updated when the CPU is in the operating state or the load state. The TOD clock is not affected by the state of any CPU.

**Stopped State**

The CPU changes from the operating state to the stopped state by means of the stop function. The stop function is performed when:

- The stop key is activated while the CPU is in the operating state.
- The CPU accepts a stop or stop-and-store-status order specified by a SIGNAL PROCESSOR instruction addressed to this CPU while it is in the operating state.
- The CPU has finished the execution of a unit of operation initiated by performing the start function with the rate control set to the instruction-step position.

When the stop function is performed, the transition from the operating to the stopped state occurs at the end of the current unit of operation. When the wait-state bit of the PSW is one, the transition takes place immediately, provided no interruptions are pending for which the CPU is enabled. In the case of interruptible instructions, the amount of data processed in a unit of operation depends on the particular instruction and may depend on the model.

Before entering the stopped state by means of the stop function, all pending allowed interruptions occur while the CPU is still in the operating state. They cause the old PSW to be stored and the new PSW to be fetched before the stopped state is entered. While the CPU is in the stopped state, interruption conditions remain pending.

The CPU is also placed in the stopped state when:

- CPU reset is completed. However, when the reset operation is performed as part of initial program loading for this CPU, then the CPU is placed in the load state and does not necessarily enter the stopped state.
- An address comparison indicates equality and stopping on the match is specified.

The execution of resets is described in “Resets” on page 4-55, and address comparison is described in “Address-Compare Controls” on page 12-1.

If the CPU is in the stopped state when a COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE DAT TABLE ENTRY or INVALIDATE PAGE TABLE ENTRY instruction is executed on another CPU in the configuration and the instruction specifies the clearing of all TLBs in the configuration, the clearing of TLB entries is completed before the CPU leaves the stopped state.

**Operating State**

The CPU changes from the stopped state to the operating state by means of the start function or when a restart interruption (see “Restart Interruption” on page 6-54) occurs.
The start function is performed if the CPU is in the stopped state and (1) the start key associated with that CPU is activated or (2) that CPU accepts the start order specified by a SIGNAL PROCESSOR instruction addressed to that CPU. The effect of performing the start function is unpredictable when the stopped state has been entered by means of a reset.

When the rate control is set to the process position and the start function is performed, the CPU starts operating at normal speed. When the rate control is set to the instruction-step position and the wait-state bit is zero, one instruction or, for interruptible instructions, one unit of operation is executed, and all pending allowed interruptions occur before the CPU returns to the stopped state. When the rate control is set to the instruction-step position and the wait-state bit is one, the start function does not cause an instruction to be executed, but all pending allowed interruptions occur before the CPU returns to the stopped state.

Load State

The CPU enters the load state when the load-normal, load-with-dump, load-clear, or load-clear-list-directed key is activated. (See "Initial Program Loading" on page 4-61. See also "Initial Program Loading" on page 17-16.) This sets the architectural mode to the ESA/390 mode. For ease of reference, the additional elements of the description of the ESA/390 load state are given below.

If a CCW-type initial-program-loading operation is completed successfully, the CPU changes from the load state to the operating state, provided the rate control is set to the process position; if the rate control is set to the instruction-step position, the CPU changes from the load state to the stopped state.

Check-Stop State

The check-stop state, which the CPU enters on certain types of machine malfunction, is described in “Check-Stop State” on page 11-10. The CPU leaves the check-stop state when CPU reset is performed.

Programming Notes:

1. Except for the relationship between execution time and real time, the execution of a program is not affected by stopping the CPU.

2. When, because of a machine malfunction, the CPU is unable to end the execution of an instruction, the stop function is ineffective, and a reset function has to be invoked instead. A similar situation occurs when an unending string of interruptions results from a PSW with a PSW-format error of the type that is recognized early, or from a persistent interruption condition, such as one due to the CPU timer.

3. Pending I/O operations may be initiated, and active I/O operations continue to suspension or completion, after the CPU enters the stopped state. The interruption conditions due to suspension or completion of I/O operations remain pending when the CPU is in the stopped state.

Program-Status Word

The current program-status word (PSW) in the CPU contains information required for the execution of the currently active program. The PSW is 128 bits in length and includes the instruction address, condition code, and other control fields. In general, the PSW is used to control instruction sequencing and to hold and indicate much of the status of the CPU in relation to the program currently being executed. Additional control and status information is contained in control registers and permanently assigned storage locations.

The status of the CPU can be changed by loading a new PSW or part of a PSW.

Control is switched during an interruption of the CPU by storing the current PSW, so as to preserve the status of the CPU, and then loading a new PSW.

Execution of LOAD PSW or LOAD PSW EXTENDED, or the successful conclusion of the initial-program-loading sequence, introduces a new PSW. The instruction address is updated by sequential instruction execution and replaced by successful branches. Other instructions are provided which operate on a portion of the PSW. Figure 4-1 on page 4-4 summarizes these instructions.

A new or modified PSW becomes active (that is, the information introduced into the current PSW assumes control over the CPU) when the interruption or the execution of an instruction that changes the PSW is completed. The interruption for PER associ-
**Table: Operations on PSW Fields**

<table>
<thead>
<tr>
<th>Instruction</th>
<th>System Mask (PSW Bits 0-7)</th>
<th>PSW Key (PSW Bits 8-11)</th>
<th>Problem State (PSW Bit 15)</th>
<th>Address-Space Control (PSW Bits 16-17)</th>
<th>Condition Code and Program Mask (PSW Bits 18-23)</th>
<th>Basic Addressing Mode (PSW Bit 24)</th>
<th>Extended Addressing Mode (PSW Bit 31)</th>
</tr>
</thead>
<tbody>
<tr>
<td>BRANCH AND LINK</td>
<td>Saved</td>
<td>Set</td>
<td>Saved</td>
<td>Saved</td>
<td>Saved</td>
<td>Saved</td>
<td>Set</td>
</tr>
<tr>
<td>BRANCH AND SAVE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>24AM</td>
<td>31AM</td>
</tr>
<tr>
<td>BRANCH AND SAVE AND SET MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BAM</td>
<td>Yes</td>
</tr>
<tr>
<td>BRANCH AND SET AUTHORITY</td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
<td></td>
<td>BAM</td>
<td>Yes¹</td>
</tr>
<tr>
<td>BRANCH AND SET MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BAM</td>
<td>Yes¹</td>
</tr>
<tr>
<td>BRANCH AND STACK</td>
<td>Yes</td>
<td></td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes¹</td>
</tr>
<tr>
<td>BRANCH IN SUBSPACE GROUP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BAM</td>
<td>Yes</td>
</tr>
<tr>
<td>BRANCH RELATIVE AND SAVE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BAM</td>
<td>Yes</td>
</tr>
<tr>
<td>BRANCH RELATIVE AND SAVE AND SET MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BAM</td>
<td>Yes¹</td>
</tr>
<tr>
<td>EXTRACT PSW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BAM</td>
<td>Yes</td>
</tr>
<tr>
<td>INSERT PROGRAM MASK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>INSERT PSW KEY</td>
<td></td>
<td></td>
<td>Yes</td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>INSERT ADDRESS SPACE CONTROL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BAM</td>
<td>BAM</td>
</tr>
<tr>
<td>Basic PROGRAM CALL</td>
<td></td>
<td></td>
<td>Yes</td>
<td></td>
<td></td>
<td>Yes</td>
<td>BAM</td>
</tr>
<tr>
<td>Stacking PROGRAM CALL</td>
<td>Yes</td>
<td></td>
<td>Yes</td>
<td></td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>PROGRAM RETURN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>PROGRAM TRANSFER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>RESUME PROGRAM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>SET ADDRESS SPACE CONTROL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>SET ADDRESSING MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>SET PROGRAM MASK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>SET PSW KEY FROM ADDRESS</td>
<td></td>
<td></td>
<td>Yes</td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>SET SYSTEM MASK</td>
<td></td>
<td></td>
<td>Yes</td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>STORE THEN AND SYSTEM MASK</td>
<td>Yes</td>
<td></td>
<td>ANDs</td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>STORE THEN OR SYSTEM MASK</td>
<td></td>
<td></td>
<td>ORs</td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>TRAP</td>
<td></td>
<td></td>
<td>Yes</td>
<td></td>
<td></td>
<td>Yes</td>
<td>Yes</td>
</tr>
</tbody>
</table>

**Explanation:**

<table>
<thead>
<tr>
<th>No.</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>The action takes place only if the associated R field in the instruction is nonzero.</td>
</tr>
<tr>
<td>2</td>
<td>In the reduced-authority state, the action takes place only if the R&lt;sub&gt;1&lt;/sub&gt; field in the instruction is nonzero.</td>
</tr>
<tr>
<td>3</td>
<td>The action also takes place in the 64-bit addressing mode if the R&lt;sub&gt;1&lt;/sub&gt; field in the instruction is zero.</td>
</tr>
<tr>
<td>4</td>
<td>PROGRAM RETURN does not change the PER mask.</td>
</tr>
<tr>
<td>5</td>
<td>PROGRAM TRANSFER does not change the problem-state bit from one to zero.</td>
</tr>
<tr>
<td>BAM</td>
<td>The basic-addressing-mode bit is saved or set in the 24-bit or 31-bit addressing mode.</td>
</tr>
<tr>
<td>PKC</td>
<td>When the PSW-key-control bit, bit 131 of the entry-table entry, is zero, the PSW key remains unchanged. When the PSW-key-control bit is one, the PSW key is set with the entry key, bits 136-139 of the entry-table entry.</td>
</tr>
<tr>
<td>24AM</td>
<td>The condition code and program mask are saved in the 24-bit addressing mode.</td>
</tr>
<tr>
<td>31AM</td>
<td>The basic-addressing-mode bit is saved in the 31-bit addressing mode.</td>
</tr>
</tbody>
</table>

**Figure 4-1. Operations on PSW Fields.**

Bits 0-7 of the PSW are collectively referred to as the system mask.

**Programming Note:** A summary of the operations which save or set the problem state, addressing...
mode, and instruction address is contained in “Subroutine Linkage without the Linkage Stack” on page 5-14.

**Program-Status-Word Format**

<table>
<thead>
<tr>
<th>Field</th>
<th>Bit Position</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>1</td>
<td>PER Mask (R): Controls whether the CPU is enabled for interruptions associated with program-event recording (PER). When the bit is zero, no PER event can cause an interruption; when the bit is one, interruptions are permitted, subject to the PER-event-mask bits in control register 9. Depending on the model, when bit position 1 of the PSW transitions back to zero, see “Address-Compare Controls” on page 12-1 for details.</td>
</tr>
<tr>
<td>I</td>
<td>5</td>
<td>DAT Mode (T): Controls whether implicit dynamic address translation of logical and instruction addresses used to access storage takes place. When the bit is zero, DAT is off, and logical and instruction addresses are treated as real addresses; when the bit is one, DAT is on, and the dynamic-address-translation mechanism is invoked.</td>
</tr>
<tr>
<td>O</td>
<td>6</td>
<td>I/O Mask (IO): Controls whether the CPU is enabled for I/O interruptions. When the bit is zero, an I/O interruption cannot occur; when the bit is one, I/O interruptions are subject to the I/O-interruption subclass-mask bits in control register 6. An I/O-interruption subclass-mask bit is zero when the I/O-interruption subclass cannot occur; when the I/O-interruption subclass-mask bit is one, an I/O interruption for that I/O-interruption subclass can occur.</td>
</tr>
<tr>
<td>E</td>
<td>7</td>
<td>External Mask (EX): Controls whether the CPU is enabled for interruption by conditions included in the external class. When the bit is zero, an external interruption cannot occur; when the bit is one, an external interruption is subject to the corresponding external subclass-mask bits in control register 0; when the subclass-mask bit is zero, conditions associated with the subclass cannot cause an interruption; when the subclass-mask bit is one, an interruption in that subclass can occur.</td>
</tr>
<tr>
<td>Key</td>
<td>8-11</td>
<td>PSW Key: Form the access key for storage references by the CPU. If the reference is subject to key-controlled protection, the PSW key is matched with a storage key when information is stored or when information is fetched from a location that is protected against fetching. However, for one of the operands of each of MOVE TO PRIMARY, MOVE TO SECONDARY, MOVE WITH KEY, MOVE WITH SOURCE KEY, and MOVE WITH DESTINATION KEY, and for either or both operands of MOVE WITH OPTIONAL SPECIFICATIONS, an access key specified as an operand is used instead of the PSW key.</td>
</tr>
<tr>
<td>M</td>
<td>13</td>
<td>Machine-Check Mask (M): Controls whether the CPU is enabled for interruption by machine-check conditions. When the bit is zero, a machine-check interruption cannot occur; when the bit is one, machine-check interruptions due to system damage and instruction-processing damage are permitted, but interruptions due to other machine-check-subclass conditions are subject to the subclass-mask bits in control register 14.</td>
</tr>
<tr>
<td>W</td>
<td>14</td>
<td>Wait State (W): When bit 14 is one, the CPU is waiting; that is, no instructions are processed by the CPU, but interruptions may take place. When bit 14 is zero, instruction fetching and execution occur in the normal manner. The wait indicator is on when the bit is one.</td>
</tr>
</tbody>
</table>
| P     | 15           | Problem State (P): When bit 15 is one, the CPU is in the problem state. When bit 15 is zero, the CPU is in the supervisor state. In the supervisor state, all instructions are valid. In the problem state, only those instructions are valid that provide meaningful information to the problem program and that cannot affect system integrity; such instructions are called unprivileged instructions. The instructions that are never valid in the problem state are called privileged instructions. When a CPU in the problem state...

*Figure 4-2. PSW Format*

The following is a summary of the functions of the PSW fields. (See Figure 4-2.)

**PER Mask (R):** Bit 1 controls whether the CPU is enabled for interruptions associated with program-event recording (PER). When the bit is zero, no PER event can cause an interruption. When the bit is one, interruptions are permitted, subject to the PER-event-mask bits in control register 9.

Depending on the model, when bit position 1 of the PSW contains one, address-compare controls may be disabled and remain disabled, even if bit position 1 of the PSW transitions back to zero. See “Address-Compare Controls” on page 12-1 for details.

**DAT Mode (T):** Bit 5 controls whether implicit dynamic address translation of logical and instruction addresses used to access storage takes place. When the bit is zero, DAT is off, and logical and instruction addresses are treated as real addresses. When the bit is one, DAT is on, and the dynamic-address-translation mechanism is invoked.

**I/O Mask (IO):** Bit 6 controls whether the CPU is enabled for I/O interruptions. When the bit is zero, an I/O interruption cannot occur. When the bit is one, I/O interruptions are subject to the I/O-interruption subclass-mask bits in control register 6. When an I/O-interruption subclass-mask bit is zero, an I/O interruption for that I/O-interruption subclass cannot occur; when the I/O-interruption subclass-mask bit is one, an I/O interruption for that I/O-interruption subclass can occur.

**External Mask (EX):** Bit 7 controls whether the CPU is enabled for interruption by conditions included in the external class. When the bit is zero, an external interruption cannot occur. When the bit is one, an external interruption is subject to the corresponding external subclass-mask bits in control register 0; when the subclass-mask bit is zero, conditions associated with the subclass cannot cause an interruption; when the subclass-mask bit is one, an interruption in that subclass can occur.

**PSW Key:** Bits 8-11 form the access key for storage references by the CPU. If the reference is subject to key-controlled protection, the PSW key is matched with a storage key when information is stored or when information is fetched from a location that is protected against fetching. However, for one of the operands of each of MOVE TO PRIMARY, MOVE TO SECONDARY, MOVE WITH KEY, MOVE WITH SOURCE KEY, and MOVE WITH DESTINATION KEY, and for either or both operands of MOVE WITH OPTIONAL SPECIFICATIONS, an access key specified as an operand is used instead of the PSW key.

**Machine-Check Mask (M):** Bit 13 controls whether the CPU is enabled for interruption by machine-check conditions. When the bit is zero, a machine-check interruption cannot occur. When the bit is one, machine-check interruptions due to system damage and instruction-processing damage are permitted, but interruptions due to other machine-check-subclass conditions are subject to the subclass-mask bits in control register 14.

**Wait State (W):** When bit 14 is one, the CPU is waiting; that is, no instructions are processed by the CPU, but interruptions may take place. When bit 14 is zero, instruction fetching and execution occur in the normal manner. The wait indicator is on when the bit is one.

**Problem State (P):** When bit 15 is one, the CPU is in the problem state. When bit 15 is zero, the CPU is in the supervisor state. In the supervisor state, all instructions are valid. In the problem state, only those instructions are valid that provide meaningful information to the problem program and that cannot affect system integrity; such instructions are called unprivileged instructions. The instructions that are never valid in the problem state are called privileged instructions. When a CPU in the problem state...
attempts to execute a privileged instruction, a privileged-operation exception is recognized. Another group of instructions, called semiprivileged instructions, are executed by a CPU in the problem state only if specific authority tests are met; otherwise, a privileged-operation exception or some other program exception is recognized, depending on the particular requirement which is violated.

**Address-Space Control (AS):** Bits 16 and 17, in conjunction with PSW bit 5, control the translation mode. See “Translation Modes” on page 3-37.

**Condition Code (CC):** Bits 18 and 19 are the two bits of the condition code. The condition code is set to 0, 1, 2, or 3, depending on the result obtained in executing certain instructions. Most arithmetic and logical operations, as well as some other operations, set the condition code. The instruction BRANCH ON CONDITION can specify any selection of the condition-code values as a criterion for branching. A table in Appendix C summarizes the condition-code values that may be set for all instructions which set the condition code of the PSW.

**Program Mask:** Bits 20-23 are the four program-mask bits. Each bit is associated with a program exception, as follows:

<table>
<thead>
<tr>
<th>Program-Mask Bit</th>
<th>Program Exception</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>Fixed-point overflow</td>
</tr>
<tr>
<td>21</td>
<td>Decimal overflow</td>
</tr>
<tr>
<td>22</td>
<td>HFP exponent underflow</td>
</tr>
<tr>
<td>23</td>
<td>HFP significance</td>
</tr>
</tbody>
</table>

When the mask bit is one, the exception results in an interruption. When the mask bit is zero, no interruption occurs. The setting of the HFP-exponent-underflow-mask bit or the HFP-significance-mask bit also determines the manner in which the operation is completed when the corresponding exception occurs.

**Bit 24 (RI):** Bit 24 is reserved for IBM use. LOAD PSW EXTENDED may or may not recognize an early specification exception when bit 24 of the operand is one.

**Extended Addressing Mode (EA):** Bit 31 controls the size of effective addresses and effective-address generation in conjunction with bit 32, the basic-addressing-mode bit. When bit 31 is zero, the addressing mode is controlled by bit 32. When bits 31 and 32 are both one, 64-bit addressing is specified.

**Basic Addressing Mode (BA):** Bits 31 and 32 control the size of effective addresses and effective-address generation. When bits 31 and 32 are both zero, 24-bit addressing is specified. When bit 31 is zero and bit 32 is one, 31-bit addressing is specified. When bits 31 and 32 are both one, 64-bit addressing is specified. Bit 31 one and bit 32 zero is an invalid combination that causes a specification exception to be recognized. The addressing mode does not control the size of PER addresses or of addresses used to access DAT, ASN, dispatchable-unit-control, linkage, entry, and trace tables or access lists or the linkage stack. See “Address Generation” on page 5-10 and “Address Size and Wraparound” on page 3-5. The control of the addressing mode by bits 31 and 32 of the PSW is summarized as follows:

<table>
<thead>
<tr>
<th>PSW.31</th>
<th>PSW.32</th>
<th>Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>24-bit</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>31-bit</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>64-bit</td>
</tr>
</tbody>
</table>

**Instruction Address:** Bits 64-127 of the PSW are the instruction address. This address designates the location of the leftmost byte of the next instruction to be executed, unless the CPU is in the wait state (bit 14 of the PSW is one).

Bit positions 0, 2-4, 25-30, and 33-63 are unassigned and must contain zeros. A specification exception is recognized when these bit positions do not contain zeros.

When bits 31 and 32 of the PSW specify the 24-bit addressing mode, bits 64-103 of the instruction address must be zeros, or, when bits 31 and 32 specify the 31-bit mode, bits 64-96 must be zeros. Otherwise, a specification exception is recognized. A specification exception is also recognized when bit 31 is one and bit 32 is zero or when bit position 12 does not contain a zero.

LOAD PSW EXTENDED has a 16-byte second operand. The instruction loads the operand unchanged and without examination as the current PSW.

LOAD PSW has an eight-byte second operand. The operand is treated as an ESA/390 PSW, except that
bit 31 (the z/Architecture extended-addressing-mode bit) may be one.

Depending on the model, either LOAD PSW recognizes a specification exception if bit 12 of its second operand is not one or this error is indicated by an early specification exception after the completion of the execution of LOAD PSW. LOAD PSW loads bits 0-32 of its second operand, except with bit 12 inverted, and bits 33-63 of the operand as bits 0-32 and 97-127, respectively, of the current PSW, and it sets bits 33-96 of the current PSW to zeros.

**Control Registers**

The control registers provide for maintaining and manipulating control information outside the PSW. There are sixteen 64-bit control registers.

The LOAD CONTROL (LCTLG) instruction causes all control-register bit positions within those registers designated by the instruction to be loaded from storage. The LOAD CONTROL (LCTL) instruction loads only bit positions 32-63 of the control registers, and bits 0-31 of the registers remain unchanged. The instructions BRANCH AND SET AUTHORITY, BRANCH AND STACK, BRANCH IN SUBSPACE GROUP, EXTRACT AND SET EXTENDED AUTHORITY, LOAD ADDRESS SPACE PARAME-TERS, PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, and SET SECONDARY ASN WITH INSTANCE, provide specialized functions to place information into certain control-register bit positions.

Information loaded into the control registers becomes active (that is, assumes control over the system) at the completion of the instruction that causes the information to be loaded.

At the time the registers are loaded, the information is not checked for exceptions, such as an address designating an unavailable or protected location. The validity of the information is checked and the exceptions, if any, are indicated at the time the information is used.

The STORE CONTROL (STCTG) instruction causes the contents of all control-register bit positions, within those registers designated by the instruction, to be placed in storage. The STORE CONTROL (STCTL) instruction places the contents of bit positions 32-63 of the control registers in storage, and bits 0-31 of the registers are ignored. The instructions EXTRACT AND SET EXTENDED AUTHORITY, EXTRACT PRIMARY ASN, EXTRACT PRIMARY ASN AND INSTANCE, EXTRACT SECONDARY ASN, EXTRACT SECONDARY ASN AND INSTANCE, and PROGRAM CALL provide specialized functions to obtain information from certain control-register bit positions.

Only the general structure of the control registers is described here; the definition of a particular control-register bit position appears in the description of the facility with which the position is associated. Figure 4-4 on page 4-8 shows the control-register bit positions which are assigned and the initial values of the positions upon execution of initial CPU reset. All
Control-register bit positions not listed in the figure are initialized to zero.

<table>
<thead>
<tr>
<th>Control Register</th>
<th>Bits</th>
<th>Name of Field</th>
<th>Associated with</th>
<th>Initial Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8-17</td>
<td>Transactional-execution control</td>
<td>Transactional execution</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>9-17</td>
<td>Transactional-execution program-interruption filtering override</td>
<td>Transactional execution</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>15</td>
<td>Measurement-counter-extraction-authorization control</td>
<td>CPU measurement(^4)</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>30</td>
<td>Warning-track subclass mask</td>
<td>Virtual machines</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>32</td>
<td>TRACE TOD-clock control</td>
<td>Tracing</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>33</td>
<td>SSM-suppression control</td>
<td>SET SYSTEM MASK</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>34</td>
<td>TOD-clock-sync control</td>
<td>TOD clock</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>35</td>
<td>Low-address-protection control</td>
<td>Low-address-protection</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>36</td>
<td>Extraction-authority control</td>
<td>Instruction authorization</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>37</td>
<td>Secondary-space control</td>
<td>Instruction authorization</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>38</td>
<td>Fetch-protection-overide control</td>
<td>Key-controlled protection</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>39</td>
<td>Storage-protection-overide control</td>
<td>Key-controlled protection</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>40</td>
<td>Enhanced-DAT-enablement control</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>44</td>
<td>ASN-and-LX-reuse control</td>
<td>Instruction authorization</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>45</td>
<td>AFP-register control</td>
<td>Floating point</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>46</td>
<td>Vector enablement control</td>
<td>Vector facility for z/Architecture</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>48</td>
<td>Malfunction-alert subclass mask</td>
<td>External interruptions</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>49</td>
<td>Emergency-sign subclass mask</td>
<td>External interruptions</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>50</td>
<td>External-call subclass mask</td>
<td>External interruptions</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>52</td>
<td>Clock-comparator subclass mask</td>
<td>External interruptions</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>53</td>
<td>CPU-timer subclass mask</td>
<td>External interruptions</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>54</td>
<td>Service_signal subclass mask</td>
<td>External interruptions</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>56</td>
<td>Unused(^1)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>57</td>
<td>Interrupt-key subclass mask</td>
<td>External interruptions</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>58</td>
<td>Measurement-alert subclass mask</td>
<td>CPU measurement(^4)</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>59</td>
<td>Timing-alert subclass mask</td>
<td>External interruptions</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>61</td>
<td>Crypto control</td>
<td>Cryptography</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0-51</td>
<td>Primary region-table origin(^2)</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0-51</td>
<td>Primary segment-table origin(^2)</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0-51</td>
<td>Primary real-space token origin(^2)</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>54</td>
<td>Primary subspace-group control</td>
<td>Subspace groups</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>55</td>
<td>Primary private-space control</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>56</td>
<td>Primary storage-alteration-event</td>
<td>Program-event recording control</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>57</td>
<td>Primary space-switch-event control</td>
<td>Program interruptions</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>58</td>
<td>Primary real-space control</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>60-61</td>
<td>Primary designation-type control(^3)</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>62-63</td>
<td>Primary table length(^3)</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>33-57</td>
<td>Dispatchable-unit-control-table origin</td>
<td>Access-register translation</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>61</td>
<td>Transaction diagnostic scope</td>
<td>Transactional execution</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>62-63</td>
<td>Transaction diagnostic control</td>
<td>Transactional execution</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0-31</td>
<td>Secondary ASN-second-table-entry instance number</td>
<td>Instruction authorization</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>32-47</td>
<td>PSW-key mask</td>
<td>Instruction authorization</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>48-63</td>
<td>Secondary ASN</td>
<td>Address spaces</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0-31</td>
<td>Primary ASN-second-table-entry instance number</td>
<td>Instruction authorization</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>32-47</td>
<td>Authorization index</td>
<td>Instruction authorization</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>48-63</td>
<td>Primary ASN</td>
<td>Address spaces</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>33-57</td>
<td>Primary-ASN-second-table-entry origin</td>
<td>Access-register translation</td>
<td>0</td>
</tr>
</tbody>
</table>

Figure 4-4. Assignment of Control-Register Fields  (Part 1 of 3)
<table>
<thead>
<tr>
<th>Control Register</th>
<th>Bits</th>
<th>Name of Field</th>
<th>Associated with</th>
<th>Initial Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>6</td>
<td>32-39</td>
<td>I/O-interruption subclass mask</td>
<td>I/O interruptions</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0-51</td>
<td>Secondary region-table origin²</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0-51</td>
<td>Secondary segment-table origin²</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0-51</td>
<td>Secondary real-space token origin²</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>54</td>
<td>Secondary subspace-group control</td>
<td>Subspace groups</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>55</td>
<td>Secondary private-space control</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>56</td>
<td>Secondary storage-alteration-event</td>
<td>Program-event recording control</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>58</td>
<td>Secondary real-space control</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>60-61</td>
<td>Secondary designation-type control³</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>62-63</td>
<td>Secondary table length³</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>16-31</td>
<td>Enhanced-monitor masks</td>
<td>MONITOR CALL</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>32-47</td>
<td>Extended authorization index</td>
<td>Access-register translation</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>48-63</td>
<td>Monitor masks</td>
<td>MONITOR CALL</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>32</td>
<td>Successful-branching-event mask</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>33</td>
<td>Instruction-fetching-event mask</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>34</td>
<td>Storage-alteration-event mask</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>36</td>
<td>Store-using-real-address-event mask</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>37</td>
<td>Zero-address-detection-event mask</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>38</td>
<td>Transaction-end event mask</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>39</td>
<td>Instruction-fetching-nullification-event mask</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>40</td>
<td>Branch-address control</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>41</td>
<td>Per-event-suppression control</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>42</td>
<td>Storage-alteration-space control</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0-63</td>
<td>PER starting address</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0-63</td>
<td>PER ending address</td>
<td>Program-event recording</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>Branch-trace control</td>
<td>Tracing</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>1</td>
<td>Mode-trace control</td>
<td>Tracing</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>2-61</td>
<td>Trace-entry address</td>
<td>Tracing</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>62</td>
<td>ASN-trace control</td>
<td>Tracing</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>63</td>
<td>Explicit-trace control</td>
<td>Tracing</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0-51</td>
<td>Home region-table origin²</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0-51</td>
<td>Home segment-table origin²</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0-51</td>
<td>Home real-space token origin²</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>55</td>
<td>Home private-space control</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>56</td>
<td>Home storage-alteration-event</td>
<td>Program-event recording control</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>57</td>
<td>Home space-switch-event control</td>
<td>Program interruptions</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>58</td>
<td>Home real-space control</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>60-61</td>
<td>Home designation-type control³</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>62-63</td>
<td>Home table length³</td>
<td>Dynamic address translation</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>32</td>
<td>Unused¹</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>33</td>
<td>Unused¹</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>35</td>
<td>Channel-report-pending subclass mask</td>
<td>I/O machine-check handling</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>36</td>
<td>Recovery subclass mask</td>
<td>Machine-check handling</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>37</td>
<td>Degradation subclass mask</td>
<td>Machine-check handling</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>38</td>
<td>External-damage subclass mask</td>
<td>Machine-check handling</td>
<td>1</td>
</tr>
<tr>
<td>14</td>
<td>39</td>
<td>Warning subclass mask</td>
<td>Machine-check handling</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>42</td>
<td>TOD-clock-control-override control</td>
<td>TOD clock</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>44</td>
<td>ASN-translation control</td>
<td>Instruction authorization</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>45-63</td>
<td>ASN-first-table origin</td>
<td>ASN translation</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0-60</td>
<td>Linkage-stack-entry address</td>
<td>Linkage-stack operations</td>
<td>0</td>
</tr>
</tbody>
</table>

*Figure 4-4. Assignment of Control-Register Fields (Part 2 of 3)*
Programming Notes:

1. The detailed definition of a particular control-register bit position can be located by referring to the entry "control-register assignment" in the Index.

2. To ensure that existing programs operate correctly if and when new facilities using additional control-register bit positions are installed, the program should load zeros in unassigned positions.

Tracing

Tracing assists in the determination of system problems by providing an ongoing record in storage of significant events. Tracing consists of four separately controllable functions which cause entries to be made in a trace table: branch tracing, ASN tracing, mode tracing, and explicit tracing. Branch tracing, ASN tracing, and mode tracing together are referred to as implicit tracing.

When branch tracing is on, a branch trace entry is made in the trace table for each execution of certain branch instructions when they cause branching. The branch address is placed in the trace entry. The trace entry also indicates the following about the addressing mode in effect after branching and the branch address: (1) the CPU is in the 24-bit addressing mode, (2) the CPU is in the 31-bit addressing mode or is in the 64-bit addressing mode and bits 0-32 of the branch address are all zeros, or (3) the CPU is in the 64-bit addressing mode and bits 0-32 of the branch address are not all zeros. The branch instructions that are traced are:

- BRANCH AND LINK (BALR only) when the R\textsubscript{2} field is not zero
- BRANCH AND SAVE (BASR only) when the R\textsubscript{2} field is not zero
- BRANCH AND SAVE AND SET MODE when the R\textsubscript{3} field is not zero
- BRANCH AND SET AUTHORITY
- BRANCH AND STACK when the R\textsubscript{2} field is not zero
- BRANCH IN SUBSPACE GROUP
- RESUME PROGRAM
- TRAP

However, a branch trace entry is made for BRANCH IN SUBSPACE GROUP only if ASN tracing is not on.

If both branch tracing and mode tracing are on and BRANCH AND SAVE AND SET MODE or RESUME PROGRAM changes the extended-addressing-mode bit, PSW bit 31, a mode-switching-branch trace entry is made instead of a branch trace entry.

When ASN tracing is on, an entry named the same as the instruction is made in the trace table for each execution of the following instructions:

- BRANCH IN SUBSPACE GROUP
- PROGRAM CALL
- PROGRAM RETURN
- PROGRAM TRANSFER
- SET SECONDARY ASN

Figure 4-4. Assignment of Control-Register Fields  (Part 3 of 3)
However, the entry for PROGRAM RETURN is made only when PROGRAM RETURN unstacks a linkage-stack state entry that was formed by PROGRAM CALL, not when PROGRAM RETURN unstacks an entry formed by BRANCH AND STACK.

When ASN tracing is on, a PROGRAM TRANSFER trace entry is also made for each execution of PROGRAM TRANSFER WITH INSTANCE, and a SET SECONDARY ASN trace entry is also made for each execution of SET SECONDARY ASN WITH INSTANCE. In either case, a bit in the trace entry indicates whether the entry was made due to the without-instance or the with-instance instruction.

If both ASN tracing and mode tracing are on and PROGRAM CALL uses a 20-bit PC number and changes PSW bit 31, first a PROGRAM CALL trace entry is made, and then a mode-switch trace entry is made. In this case except when PROGRAM CALL uses a 32-bit PC number, only a PROGRAM CALL trace entry is made since it indicates the old and new values of the extended-addressing-mode bit, PSW bit 31. A 32-bit PC number may be used if the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0.

Mode tracing records a switch from a basic (24-bit or 31-bit) addressing mode to the extended (64-bit) addressing mode or from the extended mode to a basic mode.

When mode tracing is on, a mode-switch trace entry is made in the trace table for each execution of the following instructions if the execution changes PSW bit 31:

- BRANCH AND SAVE AND SET MODE
- BRANCH AND SET MODE
- PROGRAM CALL
- PROGRAM RETURN
- RESUME PROGRAM
- SET ADDRESSING MODE

However, a mode-switch trace entry is not made for PROGRAM RETURN if ASN tracing is on and PROGRAM RETURN unstacks a state entry formed by PROGRAM CALL; a PROGRAM RETURN trace entry is made instead, and it contains information about PSW bit 31.

BRANCH AND SAVE AND SET MODE and RESUME PROGRAM cause trace entries to be made as follows: a branch trace entry if only branch tracing is on, a mode-switching-brach trace entry if both branch tracing and mode tracing are on, or a mode-switch trace entry if only mode tracing is on.

The trace entries produced by implicit tracing are summarized in Figure 4-5.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Implicit Tracing Enabled</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Branch</td>
</tr>
<tr>
<td></td>
<td>Trace Entries Made</td>
</tr>
<tr>
<td>BAKR</td>
<td>B</td>
</tr>
<tr>
<td>BALR</td>
<td>B</td>
</tr>
<tr>
<td>BASR</td>
<td>B</td>
</tr>
<tr>
<td>BASSM</td>
<td>B</td>
</tr>
<tr>
<td>BSA</td>
<td>B</td>
</tr>
<tr>
<td>BSG</td>
<td>B</td>
</tr>
<tr>
<td>BSM</td>
<td>–</td>
</tr>
<tr>
<td>PC-20</td>
<td>–</td>
</tr>
<tr>
<td>PC-32</td>
<td>–</td>
</tr>
<tr>
<td>PR-b</td>
<td>–</td>
</tr>
<tr>
<td>PR-pc</td>
<td>–</td>
</tr>
<tr>
<td>PT or PTI</td>
<td>–</td>
</tr>
<tr>
<td>RP</td>
<td>B</td>
</tr>
<tr>
<td>SSAR or SSAIR</td>
<td>–</td>
</tr>
<tr>
<td>SAM24/31/64</td>
<td>–</td>
</tr>
</tbody>
</table>

Figure 4-5. Summary of Implicit Tracing
When explicit tracing is on, execution of TRACE (TRACE or TRACG) causes an entry to be made in the trace table. The entry for TRACE (TRACE) includes bits 16-63 from the TOD clock, the second operand of the TRACE instruction, and bits 32-63 of a range of general registers. The entry for TRACE (TRACG) is the same except that it includes bits 0-79 from the TOD clock and bits 0-63 of a range of general registers.

When the CPU is in the transactional-execution mode, an instruction that would otherwise cause tracing to occur is restricted. Attempted execution of such an instruction causes the transaction to be aborted with abort code 11, and the condition code is set to 3.

### Control-Register Allocation

The information to control tracing is contained in control register 12 and has the following format:

<table>
<thead>
<tr>
<th>Branch-Trace-Control Bit (B): Bit 0 of control register 12 controls whether branch tracing is turned on or off. If the bit is zero, branch tracing is off; if the bit is one, branch tracing is on.</th>
</tr>
</thead>
<tbody>
<tr>
<td>Mode-Trace-Control Bit (M): Bit 1 of control register 12 controls whether mode tracing is turned on or off. If the bit is zero, mode tracing is off; if the bit is one, mode tracing is on.</td>
</tr>
<tr>
<td>ASN-Trace-Control Bit (A): Bit 62 of control register 12 controls whether ASN tracing is turned on or off. If the bit is zero, ASN tracing is off; if the bit is one, ASN tracing is on.</td>
</tr>
<tr>
<td>Explicit-Trace-Control Bit (E): Bit 63 of control register 12 controls whether explicit tracing is turned on or off. If the bit is zero, explicit tracing is off, which causes the TRACE instruction to be executed as a no-operation; if the bit is one, the execution of the TRACE instruction creates an entry in the trace table, except that no entry is made when bit 0 of the second operand of the TRACE instruction is one.</td>
</tr>
</tbody>
</table>

### Trace Entries

Trace entries are of nine types, with most types having more than one detailed format. The types and numbers of formats are as follows:

- Branch (three formats)
- BRANCH IN SUBSPACE GROUP (two formats)
- Mode switch (three formats)
- Mode-switching branch (three formats)
- PROGRAM CALL (seven formats)
- PROGRAM RETURN (nine formats)
- PROGRAM TRANSFER (three formats)
- SET SECONDARY ASN (one format)
- TRACE (two formats)

Format-1 and format-2 PROGRAM CALL trace entries are made if the ASN-and-LX reuse facility is not enabled. Entries of formats 3-7 are made if the facility is enabled.

The PROGRAM TRANSFER trace entry is also made for PROGRAM TRANSFER WITH INSTANCE, and the SET SECONDARY ASN trace entry is also made for SET SECONDARY ASN WITH INSTANCE. In either case, bit 15 (N) of the entry is one if the entry was made because of execution of the with-instance instruction.

The entries are shown in Figure 4-6. In that figure, each entry is labeled with "Fn," indicating a format number, to allow references to each format within a trace-entry type. Also, "Branch," referring to the mnemonic of an instruction that causes a branch trace entry, refers to BAKR, BALR, BASR, BASSM, BSA, or BSG.

Figure 4-7 on page 4-20 lists the trace entries in ascending order of values in bit fields that identify the entries.
F1 Mode Switch (BASSM, BSM, PC, PR, RP, or SAM64 from 24-Bit or 31-Bit Mode when Resulting PSW Bit 31 is One (See Note))

<table>
<thead>
<tr>
<th>0 1 0 1 0 0 0 1 0 0 1 1</th>
<th>All Zeros</th>
<th>A</th>
<th>Updated Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 12 32 33</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

F2 Mode Switch (BASSM, BSM, PC, PR, RP, SAM24, or SAM31 from 64-Bit Mode to 24-Bit or 31-Bit Mode when Bits 0-31 of Updated Instruction Address Are All Zeros)

<table>
<thead>
<tr>
<th>0 1 0 1 0 0 0 1 0 0 1 0</th>
<th>All Zeros</th>
<th>Bits 32-63 of Updated Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 12 32</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

F3 Mode Switch (BASSM, BSM, PC, PR, or RP from 64-Bit Mode to 24-Bit or 31-Bit Mode when Bits 0-31 of Updated Instruction Address Are Not All Zeros)

<table>
<thead>
<tr>
<th>0 1 0 1 0 0 1 0 1 1 0</th>
<th>All Zeros</th>
<th>Bits 0-31 of Updated Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 12 32 63</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

F1 Mode-Switching Branch (BASSM or RP from 64-Bit Mode to 24-Bit or 31-Bit Mode)

<table>
<thead>
<tr>
<th>0 1 0 1 0 0 0 1 1 0 1 0</th>
<th>All Zeros</th>
<th>A</th>
<th>Branch Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 12 32 33</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

F2 Mode-Switching Branch (BASSM or RP from 24-Bit or 31-Bit Mode when Resulting PSW Bit 31 Is One (See Note) and Bits 0-31 of Branch Address Are All Zeros)

<table>
<thead>
<tr>
<th>0 1 0 1 0 0 0 1 1 0 1 1</th>
<th>All Zeros</th>
<th>Bits 32-63 of Branch Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 12 32 63</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

F3 Mode-Switching Branch (BASSM or RP from 24-Bit or 31-Bit Mode when Resulting PSW Bit 31 Is One (See Note) and Bits 0-31 of Branch Address Are Not All Zeros)

<table>
<thead>
<tr>
<th>0 1 0 1 0 0 0 1 1 1 1 1</th>
<th>All Zeros</th>
<th>Bits 0-31 of Branch Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 12 32 63</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

F1 PROGRAM CALL (in 24-Bit or 31-Bit Mode, Regardless of Resulting Mode, if ASN-and-LX Reuse Is Not Enabled)

<table>
<thead>
<tr>
<th>0 0 1 0 0 0 0 1 0 0 0 0 0 1</th>
<th>PSW Key</th>
<th>PC Number</th>
<th>A</th>
<th>Bits 33-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 12 32 33</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 4-6. Trace Entries (Part 2 of 7)
F2 PROGRAM CALL (in 64-Bit Mode, Regardless of Resulting Mode, if ASN-and-LX Reuse Is Not Enabled)

00100010 PSW

<table>
<thead>
<tr>
<th>Key</th>
<th>PC Number</th>
<th>Bits 0-31 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8 12 32</td>
<td>63</td>
</tr>
</tbody>
</table>

Bits 32-62 of Return Address

0 8 12 32 63

F3 PROGRAM CALL (in 24-Bit or 31-Bit Mode, Regardless of Resulting Mode, if ASN-and-LX Reuse Is Enabled and 20-Bit PC Number is Used)

00100001 PSW

<table>
<thead>
<tr>
<th>Key</th>
<th>Bits 1-19 of 20-Bit PC Number</th>
<th>A</th>
<th>Bits 33-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8 12 13 32 63</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

F4 PROGRAM CALL (in 64-Bit Mode, Regardless of Resulting Mode, if ASN-and-LX Reuse Is Enabled and 20-Bit PC Number Is Used)

00100010 PSW

<table>
<thead>
<tr>
<th>Key</th>
<th>Bits 1-19 of 20-Bit PC Number</th>
<th>Bits 0-31 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8 12 13</td>
<td>63</td>
</tr>
</tbody>
</table>

Bits 32-62 of Return Address

0 8 12 13 32 63

F5 PROGRAM CALL (in 24-Bit or 31-Bit Mode, Regardless of Resulting Mode, if ASN-and-LX Reuse Is Enabled and 32-Bit PC Number is Used)

00100010 PSW

<table>
<thead>
<tr>
<th>Key</th>
<th>All Zeros</th>
<th>A</th>
<th>Bits 33-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1 0 0 E</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

32-Bit PC Number

0 8 12 15 16 32 63

F6 PROGRAM CALL (in 64-Bit Mode, Regardless of Resulting Mode, if ASN-and-LX Reuse Is Enabled, 32-Bit PC Number Is Used, and Bits 0-31 of Return Address Are All Zeros)

00100010 PSW

<table>
<thead>
<tr>
<th>Key</th>
<th>All Zeros</th>
<th>Bits 32-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1 0 1 E</td>
<td></td>
</tr>
</tbody>
</table>

32-Bit PC Number

0 8 12 15 16 32 63

Figure 4-6. Trace Entries  (Part 3 of 7)
F7 PROGRAM CALL (in 64-Bit Mode, Regardless of Resulting Mode, if ASN-and-LX Reuse Is Enabled, 32-Bit PC
Number Is Used, and Bits 0-31 of Return Address Are Not All Zeros)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>Key</th>
<th>Bits 0-31 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 1 0 0 0 1 1</td>
<td>1 1 1</td>
<td>E</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits 32-62 of Return Address</th>
<th>32-Bit PC Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>P</td>
<td>95</td>
</tr>
</tbody>
</table>

F1 PROGRAM RETURN (in 24-Bit or 31-Bit Mode when Resulting Mode Is 24-Bit or 31-Bit)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 33-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 1 1 0 0 1 0</td>
<td>0 0 0 0</td>
<td>A</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits 33-63 of Updated Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
</tr>
</tbody>
</table>

F2 PROGRAM RETURN (in 64-Bit Mode when Bits 0-31 of Updated Instruction Address Are All Zeros and Resulting
Mode Is 24-Bit or 31-Bit)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 33-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 1 1 0 0 1 0</td>
<td>0 0 1 0</td>
<td>A</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits 32-63 of Updated Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
</tr>
</tbody>
</table>

F3 PROGRAM RETURN (in 64-Bit Mode when Bits 0-31 of Updated Instruction Address Are Not All Zeros and
Resulting Mode Is 24-Bit or 31-Bit)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 33-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 1 1 0 0 1 1</td>
<td>0 0 1 1</td>
<td>A</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Updated Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
</tr>
</tbody>
</table>

F4 PROGRAM RETURN (in 24-Bit or 31-Bit Mode when Resulting PSW Bit 31 Is One (See Note) and Bits 0-31 of
Return Address Are All Zeros)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 32-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 1 1 0 0 1 0</td>
<td>1 0 0 0</td>
<td>A</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits 33-63 of Updated Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
</tr>
</tbody>
</table>

Figure 4-6. Trace Entries (Part 4 of 7)
F5 PROGRAM RETURN (in 64-Bit Mode when Bits 0-31 of Updated Instruction Address Are All Zeros, Resulting PSW Bit 31 Is One (See Note), and Bits 0-31 of Return Address Are All Zeros)

<table>
<thead>
<tr>
<th>PSW</th>
<th>Key</th>
<th>New PASN</th>
<th>Bits 32-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 1 1 0 0 1 0</td>
<td>1 0 1 0</td>
<td></td>
<td>P</td>
</tr>
</tbody>
</table>

Bits 32-63 of Updated Instruction Address

F6 PROGRAM RETURN (in 64-Bit Mode when Bits 0-31 of Updated Instruction Address Are Not All Zeros, Resulting PSW Bit 31 Is One (See Note), and Bits 0-31 of Return Address Are All Zeros)

<table>
<thead>
<tr>
<th>PSW</th>
<th>Key</th>
<th>New PASN</th>
<th>Bits 32-62 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 1 1 0 0 1 1</td>
<td>1 0 1 1</td>
<td></td>
<td>P</td>
</tr>
</tbody>
</table>

Updated Instruction Address

F7 PROGRAM RETURN (in 24-Bit or 31-Bit Mode when Resulting PSW Bit 31 Is One (See Note) and Bits 0-31 of Return Address Are Not All Zeros)

<table>
<thead>
<tr>
<th>PSW</th>
<th>Key</th>
<th>New PASN</th>
<th>Bits 0-31 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 1 1 0 0 1 1</td>
<td>1 1 0 0</td>
<td></td>
<td>P</td>
</tr>
</tbody>
</table>

Bits 32-62 of Return Address

F8 PROGRAM RETURN (in 64-Bit Mode when Bits 0-31 of Updated Instruction Address Are All Zeros, Resulting PSW Bit 31 Is One (See Note), and Bits 0-31 of Return Address Are Not All Zeros)

<table>
<thead>
<tr>
<th>PSW</th>
<th>Key</th>
<th>New PASN</th>
<th>Bits 0-31 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 1 1 0 0 1 1</td>
<td>1 1 1 0</td>
<td></td>
<td>P</td>
</tr>
</tbody>
</table>

Figure 4-6. Trace Entries (Part 5 of 7)
F9 PROGRAM RETURN (in 64-Bit Mode when Bits 0-31 of Updated Instruction Address Are Not All Zeros, Resulting PSW Bit 31 Is One (See Note), and Bits 0-31 of Return Address Are Not All Zeros)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 0-31 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>00110100</td>
<td>111</td>
<td>Bits 32-62 of Return Address</td>
</tr>
<tr>
<td>0 8 12 16 32</td>
<td>63</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 0-31 of Updated Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>00110100</td>
<td>111</td>
<td>Bits 32-63 of Updated Instruction Address</td>
</tr>
<tr>
<td>0 8 12 16 32 63</td>
<td>127</td>
<td></td>
</tr>
</tbody>
</table>

F1 PROGRAM TRANSFER (WITH INSTANCE if N Is One) (in 24-Bit or 31-Bit Mode)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 32-63 of R2 before</th>
</tr>
</thead>
<tbody>
<tr>
<td>001100001</td>
<td>000</td>
<td>Bits 32-63 of R2 before</td>
</tr>
<tr>
<td>0 8 12 15 16 32 63</td>
<td>63</td>
<td></td>
</tr>
</tbody>
</table>

F2 PROGRAM TRANSFER (WITH INSTANCE if N Is One) (in 64-Bit Mode when Bits 0-31 of R2 Are All Zeros)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 32-63 of R2 before</th>
</tr>
</thead>
<tbody>
<tr>
<td>001100001</td>
<td>100</td>
<td>Bits 32-63 of R2 before</td>
</tr>
<tr>
<td>0 8 12 15 16 32 63</td>
<td>63</td>
<td></td>
</tr>
</tbody>
</table>

F3 PROGRAM TRANSFER (WITH INSTANCE if N Is One) (in 64-Bit Mode when Bits 0-31 of R2 Are Not All Zeros)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New PASN</th>
<th>Bits 0-31 of R2 before</th>
</tr>
</thead>
<tbody>
<tr>
<td>00110010</td>
<td>110</td>
<td>Bits 0-31 of R2 before</td>
</tr>
<tr>
<td>0 8 12 15 16 32 63</td>
<td>63</td>
<td></td>
</tr>
</tbody>
</table>

F1 SET SECONDARY ASN (WITH INSTANCE if N Is One)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>New SASN</th>
</tr>
</thead>
<tbody>
<tr>
<td>0001000000000000</td>
<td>New SASN</td>
</tr>
<tr>
<td>0 8 15 31</td>
<td>31</td>
</tr>
</tbody>
</table>

F1 TRACE (TRACE)

<table>
<thead>
<tr>
<th>PSW Key</th>
<th>TOD-Clock Bits 16-63</th>
</tr>
</thead>
<tbody>
<tr>
<td>0111</td>
<td>TOD-Clock Bits 16-63</td>
</tr>
<tr>
<td>0 4 8 16</td>
<td>63</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TRACE Operand</th>
<th>(R1) – (R3)</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
<td>95</td>
</tr>
</tbody>
</table>

Figure 4-6. Trace Entries (Part 6 of 7)
The fields in the trace entries are defined as follows. The fields are described in the order in which they first appear in Figure 4-6 on page 4-13.

**Branch Address:** The branch address is the address of the next instruction to be executed when the branch is taken. In a branch trace entry made when the 24-bit addressing mode is in effect after branching (a format-1 entry), bit positions 8-31 contain bits 40-63 of the branch address. When the 31-bit addressing mode is in effect after branching or PSW bit 31 is one after branching and bits 0-32 of the branch address are all zeros, bit positions 1-31 of the trace entry (format 2) contain bits 33-63 of the branch address. When PSW bit 31 is one after branching and bits 0-32 of the branch address are not all zeros, bit positions 32-95 of the trace entry (format 3), contain bits 0-63 of the branch address.

In a mode-switching-branch trace entry made on a switch from the 64-bit addressing mode to the 24-bit or 31-bit addressing mode (a format-1 entry) contains the basic-addressing-mode bit that replaces PSW bit 32. Bit position 32 of a PROGRAM CALL trace entry made on execution in the 24-bit or 31-bit addressing mode (regardless of the resulting addressing mode) (a format-1 entry) contains the basic-addressing-mode bit, bit 32, from the current PSW.

0-31 of the branch address are zeros, or bits 32-95 of the entry (format 3) contain bits 0-63 of the branch address if bits 0-31 of the branch address are not all zeros.

**Primary-List Bit (P) and Bits 9-31 of ALET:** Bit position 8 of a BRANCH IN SUBSPACE GROUP trace entry contains bit 7 of the access-list-entry token (ALET) in the access register designated by the R2 field of the instruction. Bit positions 9-31 of the trace entry contain bits 9-31 of the ALET.

**Basic-Addressing-Mode Bit (A):** Bit position 32 of a BRANCH IN SUBSPACE GROUP trace entry made on execution in the 24-bit or 31-bit addressing mode (format-1 entry) contains the basic-addressing-mode bit that replaces bit 32 of the PSW.

Bit position 32 of a mode-switch trace entry that indicates a switch from PSW bit 31 being off to the bit being on (a format-1 entry) contains the value of PSW bit 32 that existed before the mode-switch operation.

Bit position 32 of a mode-switching-branch trace entry that indicates a switch from the 64-bit addressing mode to the 24-bit or 31-bit addressing mode (a format-1 entry) contains the value that replaces PSW bit 32.

Bit position 32 of a PROGRAM CALL trace entry made on execution in the 24-bit or 31-bit addressing mode (regardless of the resulting addressing mode) (a format-1 entry) contains the basic-addressing-mode bit, bit 32, from the current PSW.

---

**F2 TRACE (TRACG)**

<table>
<thead>
<tr>
<th>0111 N</th>
<th>10000000</th>
<th>TOD-Clock Bits 0-47</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 4 8 16 63</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TOD-Clock Bits 48-79</th>
<th>TRACG Operand</th>
</tr>
</thead>
<tbody>
<tr>
<td>64 96 127</td>
<td></td>
</tr>
</tbody>
</table>

(R1) – (R3)  
128 127 + 64(N+1)

**Note:** The terminology “when Resulting PSW Bit 31 Is One” is used instead of “when Resulting Mode Is 64-Bit” because, if the resulting PSW bit 32 is zero, an early specification exception will be recognized. PROGRAM RETURN can set PSW bit 31 to one and bit 32 to zero.

*Figure 4-6. Trace Entries (Part 7 of 7)*
Bit position 32 of a PROGRAM RETURN trace entry made when the resulting addressing mode is the 24-bit or 31-bit mode (a format-1, format-2, or format-3 entry) contains the basic-addressing-mode bit that replaces bit 32 of the PSW.

Bit position 64 of a PROGRAM RETURN trace entry made in the 24-bit or 31-bit addressing mode when the return address occupies only one word in the entry, (a format-1 or format-4 entry), contains the value of PSW bit 32 that existed before the PROGRAM RETURN operation. When the return address occupies two words (a format-7 entry), bit position 96 contains that value of PSW bit 32.

Updated Instruction Address: Bit positions 33-63 of a mode-switch trace entry that indicates a switch from PSW bit 31 being off to the bit being on (a format-1 entry) contains bits 33-63 of the updated instruction address in the PSW (bits 97-127 of the PSW) before that address is replaced, if it is replaced, by the mode-switch operation. Bit positions 32-63 of a mode-switch trace entry (format 2) that indicates a switch from the 64-bit addressing mode to the 24-bit or 31-bit addressing mode contains bits 32-63 of the updated instruction address in the PSW (bits 96-127 of the PSW) before that address is replaced, if it is replaced, by the mode-switch operation, if bits 0-31 of the updated instruction address are zeros; or bit positions 32-95 of the trace entry (format 3) contain bits 0-63 of that updated instruction address (bits 64-127 of the PSW) if bits 0-31 of the address are not all zeros.

The following description of a PROGRAM RETURN trace entry applies when the return address in the entry occupies only one word in the entry. Bit positions 65-95 of the trace entry made on execution in the 24-bit or 31-bit addressing mode (a format-1 or format-4 entry) contains bits 32-63 of the updated instruction address in the PSW (bits 97-127 of the PSW) before that address is replaced from the linkage-stack state entry; or, when the execution is in the 64-bit addressing mode, bit positions 64-95 of the trace entry (format 2 or 5) contain bits 32-63 of that updated instruction address (bits 64-127 of the PSW) if bits 0-31 of the address are not all zeros.

The following description of a PROGRAM RETURN trace entry applies when the return address in the entry occupies two words, the updated instruction address in the entry is moved one word to the right in the entry (formats 7-9).
**PSW Key:** Bit positions 8-11 of a PROGRAM CALL, PROGRAM TRANSFER, or PROGRAM RETURN trace entry contain the PSW key from the current PSW.

**PC Number:** Bit positions 12-31 of a PROGRAM CALL trace entry of format 1-4 contain the value of the rightmost 20 bits of the second-operand address. Bit positions 64-95 of a format-5 or format-6 PROGRAM CALL trace entry, or bit positions 96-127 of a format-7 entry, contain the value of the rightmost 32 bits of the second-operand address.

**Return Address:** Bit positions 33-62 of a PROGRAM CALL trace entry made on execution in the 24-bit or 31-bit addressing mode (a format-1, format-3, or format-5 entry) contain bits 33-62 of the updated instruction address in the PSW (bits 97-126 of the PSW) before that address is replaced from the entry-table entry; or, when the execution is in the 64-bit addressing mode, bit positions 32-94 of the trace entry (format 2, 4, or 7) contain bits 0-62 of that updated instruction address (bits 64-126 of the PSW), or, when bits 0-31 of the address are all zeros, bit positions 32-62 of the trace entry (format 6) contain bits 32-62 of the address.

**Extended-Addressing-Mode Bit (E):** Bit position 15 of a PROGRAM CALL trace entry made using a 32-bit PC number (a format-5, format-6, or format-7 entry) contains the extended-addressing-mode bit that replaces bit 31 of the PSW.

Bit positions 33-62 of a PROGRAM RETURN trace entry made when the resulting addressing mode is the 24-bit or 31-bit mode (a format-1 entry) contain bits 32-63 of the general register designated by the R2 field of the instruction (bits 32 and 33-62 of that register replace bits 32 and 97-126, respectively, of the PSW. Bit 63 of the register replaces the problem-state bit in the PSW.) When PROGRAM TRANSFER or PROGRAM TRANSFER WITH INSTANCE is executed in the 64-bit addressing mode, bit positions 32-63 of the trace entry (format 2) contain bits 32-63 of the R2 general register if bits 0-31 of the register are zeros, or bit positions 32-95 of the trace entry (format 3) contain bits 0-63 of the register if bits 0-31 of the register are not all zeros.

**New PASN:** Bit positions 16-31 a PROGRAM TRANSFER trace entry contain the new PASN (which may be zero) specified in bit positions 48-63 of general register R1.

Bit positions 16-31 of a PROGRAM RETURN trace entry contain the new PASN that is restored from the linkage-stack state entry.

**Bits 32-63 of R2 before:** Bit positions 32-63 of a PROGRAM TRANSFER trace entry made on execution in the 24-bit or 31-bit addressing mode (a format-1 entry) contain bits 32-63 of the general register designated by the R2 field of the instruction. (Bits 32 and 33-62 of that register replace bits 32 and 97-126, respectively, of the PSW. Bit 63 of the register replaces the problem-state bit in the PSW.) When PROGRAM TRANSFER or PROGRAM TRANSFER WITH INSTANCE is executed in the 64-bit addressing mode, bit positions 32-63 of the trace entry (format 2) contain bits 32-63 of the R2 general register if bits 0-31 of the register are zeros, or bit positions 32-95 of the trace entry (format 3) contain bits 0-63 of the register if bits 0-31 of the register are not all zeros.

**New SASN:** Bit positions 16-31 of a SET SECONDARY ASN trace entry contain the ASN value loaded into control register 3 by the instruction.

**Number of Registers (N):** Bits 4-7 of the trace entry for TRACE contain a value which is one less than the number of general registers which have been provided in the trace entry. The value of N ranges from zero, meaning the contents of one general register are provided in the trace entry, to 15, meaning the contents of all 16 general registers are provided.
**TOD-Clock Bits 16-63 or 0-79:** When the store-clock-fast facility is not installed, or when the TRACE TOD-clock control in bit 32 of control register 0 is zero, bits 16-63 of the trace entry for TRACE (TRACE) are obtained from bit positions 16-63 of the TOD clock, as would be provided by a STORE CLOCK instruction executed at the time the TRACE instruction was executed. When the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register zero is one, bits 16-63 of the trace entry for TRACE (TRACE) are obtained from bit positions 16-63 of the TOD clock, as would be provided by a STORE CLOCK FAST instruction executed at the time the TRACE instruction was executed.

Bits 16-95 of the trace entry for TRACE (TRACG) are obtained from bit positions 0-79 of the TOD clock, as would be provided by a STORE CLOCK EXTENDED instruction executed at the time the TRACE instruction was executed. See programming note 2 for information about a carry from bit position 0 of the TOD clock.

**TRACE Operand:** When the store-clock-fast facility is not installed, or when the TRACE TOD-clock control in bit 32 of control register 0 is zero, bit positions 64-95 of the trace entry for TRACE (TRACE) and bit positions 96-127 of the trace entry for TRACE (TRACG) contain a copy of the 32 bits of the second operand of the TRACE instruction for which the entry is made. When the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register 0 is one, the trace-operand field in the trace entry is formed as follows.

- Bit positions 64-71 and 80-95 of the trace entry for TRACE (TRACE) and bit positions 96-103 and 112-127 of the trace entry for TRACE (TRACG) contain a copy of bits 0-7 and 16-31, respectively, of the second operand of the TRACE instruction for which the entry is made.

- The contents of bit positions 72-79 of the trace entry for TRACE (TRACE) and the contents of bit positions 104-111 for TRACE (TRACG) are set to a model-dependent value.

\((R_1)-(R_3)\): The four-byte fields starting with bit 96 of the trace entry for TRACE (TRACE) contain the contents of bit positions 32-63 of the general registers whose range is specified by the \(R_1\) and \(R_3\) fields of the TRACE instruction. The general registers are stored in ascending order of register numbers, starting with general register \(R_1\) and continuing up to and including general register \(R_3\), with general register 0 following general register 15. The eight-byte fields starting with bit 128 of the trace entry for TRACE (TRACG) similarly contain the contents of bit positions 0-63 of those registers.

**Programming Notes:**

1. The size of the trace entry for TRACE (TRACE) in units of words is \(3 + (N + 1)\). The maximum size of an entry is 19 words, or 76 bytes. For TRACE (TRACG), the size in units of words is \(4 + 2(N + 1)\), and the maximum size is 36 words, or 144 bytes.

2. At some time in the future, the TOD clock on new models will have a leftmost extension so that there can be a carry from bit position 0 of the clock into the extension; see programming note 14 on page 4-47. On these models, the rightmost bit of the extension will be stored in bit position 15 of the TRACE (TRACG) trace entry. It may be desired to have programs that process TRACE (TRACG) trace entries take this future development into account.

**Trace Operation**

When an instruction which is subject to tracing is executed and the corresponding tracing function is turned on, a trace entry of the appropriate type and format is made, except as noted below. The real address of the trace entry is formed by appending two zero bits on the left and two on the right to the value in bit positions 2-61 of control register 12. The address in control register 12 is subsequently increased by the size of the entry created.

No trace entry is stored if the incrementing of the address in control register 12 would cause a carry to be propagated into bit position 51 (that is, if the trace-entry address would be in the next 4K-byte block). If this would be the case for the entry to be made, a trace-table exception is recognized and the operation is nullified. When PROGRAM CALL is to form both a PROGRAM CALL trace entry and a mode-switch trace entry, neither entry is stored, and a trace-table exception is recognized, if either entry would cause a carry into bit position 51. For the purpose of recognizing the trace-table exception in the case of a
TRACE instruction, the maximum length of 76 (TRACE) or 144 (TRACG) bytes is used instead of the actual length.

When the CPU is in the transactional-execution mode, an instruction that would otherwise cause tracing to occur is restricted. Attempted execution of such an instruction causes the transaction to be aborted with abort code 11, and the condition code is set to 3; no trace entry is made, and no trace-table exception condition (if any) is recognized.

The storing of a trace entry is not subject to key-controlled protection (nor, since the trace-entry address is real, is it subject to DAT protection), but it is subject to low-address protection; that is, if the address of the trace entry due to be created is in the range 0-511 or 4096-4607 and bit 35 of control register 0 is one, a protection exception is recognized, and instruction execution is suppressed. If the address of a trace entry is invalid, an addressing exception is recognized, and instruction execution is suppressed.

The three exceptions associated with storing a trace entry (addressing, protection, and trace table) are collectively referred to as trace exceptions.

If a program interruption takes place for a condition which is not a trace-exception condition and for which execution of an instruction is not completed, it is unpredictable whether part or all of any trace entry due to be made for such an interrupted instruction is stored in the trace table. Thus, for a condition which would ordinarily cause nullification or suppression of instruction execution, storage locations may have been altered beginning at the location designated by control register 12 and extending up to the length of the entry that would have been created.

When PROGRAM RETURN unstacks a linkage-stack state entry that was formed by BRANCH AND STACK and ASN tracing is on, trace exceptions may be recognized, even though a trace entry is not made and no part of a trace entry is stored.

The order in which information is placed in a trace entry is unpredictable. Furthermore, as observed by other CPUs and by channel programs, the contents of a byte of a trace entry may appear to change more than once before completion of the instruction for which the entry is made.

The trace-entry address in control register 12 is updated only on completion of execution of an instruction for which a trace entry is made.

A serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed. However, it is unpredictable whether or not a store into a trace-table entry from which a subsequent instruction is fetched will be observed by the CPU that performed the store. Additionally, when the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register 0 is one, it is unpredictable whether explicit tracing causes serialization to be performed.

Program-Event Recording

The purpose of PER is to assist in debugging programs. It permits the program to be alerted to the following types of events:

- Execution of a successful branch instruction. The option is provided of having an event occur only when the branch-target location is within the designated storage area.
- Fetching of an instruction from the designated storage area.
- Alteration of the contents of the designated storage area. The option is provided of having an event occur only when the storage area is within designated address spaces.
- Execution of the STORE USING REAL ADDRESS instruction.
- Execution of the TRANSACTION END instruction.

The PER zero-address-detection facility may be available on a model implementing z/Architecture and is only available in the z/Architecture architectural mode. When this facility is installed, the program may be alerted to the following additional event:

- Execution of an instruction that accesses storage using an operand address formed from a general register containing zero.

The program can selectively specify that one or more of the above types of events be recognized, except that the event for STORE USING REAL ADDRESS can be specified only along with the storage-alteration event. The information concerning a PER event
is provided to the program by means of a program interruption, with the cause of the interruption being identified in the interruption code.

**PER Instruction-Fetching Nullification**

The PER-3 facility may be available on a model implementing z/Architecture and is available only in the z/Architecture architectural mode. When this facility is installed, bit 39 of control register 9, when one, specifies that PER instruction-fetching events force nullification. Bit 39 is effective for this purpose only when bit 33 of control register 9, the instruction-fetching PER-event mask bit, is also one. When bit 33 is zero, PER instruction-fetching events are not recognized, and bit 39 has no effect. When the PER-3 facility is not installed or bit 39 is zero, PER instruction-fetching events do not force nullification. A PER instruction-fetching event that forces nullification is referred to as a PER instruction-fetching nullification event. A PER event that does not force nullification is referred to as a PER basic event.

When the PER-3 facility is installed, and bit 39 is one, the interruption caused by a PER instruction-fetching event occurs before the fetched instruction is executed, the PER instruction-fetching nullification event is indicated, no other PER events and no other program interruption conditions are reported, and execution of the instruction is nullified. When the PER-3 facility is not installed, or bit 39 is zero, nullification is not forced, the PER instruction-fetching basic event is indicated, other PER events and other program interruption conditions may be concurrently reported, and the execution of the instruction may be completed, terminated, suppressed, or nullified. In the absence of other conditions, the interruption caused by the PER instruction-fetching basic event occurs after execution of the fetched instruction, or units of operation thereof, are completed.

**Control-Register Allocation and Address-Space-Control Element**

The information for controlling PER resides in control registers 9, 10, and 11 and the address-space-control element.

Depending on the model, when any or all of control registers 9, 10, or 11 contain nonzero values, address-compare controls may be disabled and remain disabled even if all of control registers 9-11 transition back to zeros. See “Address-Compare Controls” on page 12-1 for details.

The information in the control registers has the following format:

**Control Register 9**

| Bit 0 | Bit 1 | Bit 2 | Bit 3 | Bit 4 | Bit 5 | Bit 6 | Bit 7 | Bit 8 | Bit 9 | Bit 10 | Bit 11 | Bit 12 | Bit 13 | Bit 14 | Bit 15 | Bit 16 | Bit 17 | Bit 18 | Bit 19 | Bit 20 | Bit 21 | Bit 22 | Bit 23 | Bit 24 | Bit 25 | Bit 26 | Bit 27 | Bit 28 | Bit 29 | Bit 30 | Bit 31 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**Control Register 10**

| Bit 0 | Bit 1 | Bit 2 | Bit 3 | Bit 4 | Bit 5 | Bit 6 | Bit 7 | Bit 8 | Bit 9 | Bit 10 | Bit 11 | Bit 12 | Bit 13 | Bit 14 | Bit 15 | Bit 16 | Bit 17 | Bit 18 | Bit 19 | Bit 20 | Bit 21 | Bit 22 | Bit 23 | Bit 24 | Bit 25 | Bit 26 | Bit 27 | Bit 28 | Bit 29 | Bit 30 | Bit 31 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**Control Register 11**

| Bit 0 | Bit 1 | Bit 2 | Bit 3 | Bit 4 | Bit 5 | Bit 6 | Bit 7 | Bit 8 | Bit 9 | Bit 10 | Bit 11 | Bit 12 | Bit 13 | Bit 14 | Bit 15 | Bit 16 | Bit 17 | Bit 18 | Bit 19 | Bit 20 | Bit 21 | Bit 22 | Bit 23 | Bit 24 | Bit 25 | Bit 26 | Bit 27 | Bit 28 | Bit 29 | Bit 30 | Bit 31 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**PER-Event Masks (EM):** Bits 32-34 and 36 of control register 9 specify which types of events are recognized. When the PER zero-address-detection facility is installed, bit 37 of the PER-event masks is also used. When the transactional-execution facility is installed, bit 38 of the PER-event masks is also used. When the PER-3 facility is installed, bit 39 of the PER-event masks is also used. The bits are assigned as follows:

- Bit 32: Successful-branching event
- Bit 33: Instruction-fetching event
- Bit 34: Storage-alteration event
- Bit 36: Store-using-real-address event (bit 34 must also be one)
- Bit 37: Zero-address-detection event
- Bit 38: Transaction-end event
- Bit 39: Instruction-fetching nullification event (bit 33 must also be one)

Bits 32-34 and bit 36, when ones, specify that the corresponding types of events be recognized. However, bit 36 is effective for this purpose only when bit 34 is also one. When bit 34 is one, the storage-alteration event is recognized. When bits 34 and 36 are
ones, both the storage-alteration event and the store-using-real-address event are recognized. When a bit is zero, the corresponding type of event is not recognized. When bit 34 is zero, both the storage-alteration event and the store-using-real-address event are not recognized.

When the PER-3 facility is not installed, bit 39 is ignored. Bit 39 is effective only when bit 33 is also one. When bit 33 is one, and the PER-3 facility is installed, and bit 39 is one, the PER instruction-fetching nullification event is recognized. When bit 33 is one and bit 39 is zero (or the PER-3 facility is not installed) the PER instruction-fetching basic event is recognized. When bit 33 is zero, neither the PER instruction-fetching basic event nor the PER instruction-fetching nullification event is recognized.

When the transactional-execution facility is not installed, or when the facility is installed and bit 38 is zero, transaction-end events are not recognized. When the transactional-execution facility is installed and bit 38 is one, a transaction-end event is recognized as a result of the completion of an outermost TRANSACTION END instruction.

**Branch-Address Control (B):** Bit 40 of control register 9 specifies, when one, that successful-branching events occur only for branches that are to a location within the designated storage area. When bit 40 is zero, successful branching events occur regardless of the branch-target address.

**Event-Suppression Control (ES):** When the CPU is in the transactional-execution mode at the beginning of an instruction, bit 41 of control register 9 specifies, when one, that successful-branching events occur only for branches that are to a location within the designated storage area. When bit 41 of the register is zero, all PER event masks operate as defined.

When an outermost TRANSACTION BEGIN instruction is executed and the ES control is one, any PER storage-alteration or zero-address-detection event for the TBEGIN-specified TDB and any instruction-fetching basic event are suppressed; instruction-fetching nullification events are not suppressed in this case.

**Storage-Alteration-Space Control (S):** Bit 42 of control register 9 specifies, when one, that storage-alteration events occur as a result of references to the designated storage area only within designated address spaces. An address space is designated as one for which storage-alteration events occur by means of the storage-alteration-event bit in the address-space-control element that is used to translate references to the address space. Bit 42 is ignored when DAT is not in effect. When DAT is not in effect or bit 42 is zero, storage-alteration events are not restricted to occurring for only particular address spaces.

**PER Starting Address:** Bits 0-63 of control register 10 are the address of the beginning of the designated storage area.

**PER Ending Address:** Bits 0-63 of control register 11 are the address of the end of the designated storage area.

**Storage-Alteration-Event Bit (S):** When the storage-alteration-space control in control register 9 is one, bit 56 of the address-space control element (ASCE) specifies, when one, that the address space defined by the ASCE is one for which storage-alteration events can occur. See the sections “Control Register 1” on page 3-39, “Control Register 7” on page 3-41, and “Control Register 13” on page 3-41 for illustrations of the ASCE.

Bit 56 of the ASCE is examined when the ASCE is used to perform dynamic-address translation for a storage-operand store reference. The address-space-control element may be the PASCE, SASCE, or HASCE in control register 1, 7, or 13, respectively, or it may be obtained from an ASN-second-table entry during access-register translation. Instead of being obtained from an ASN-second-table entry in main storage, bit 56 of the ASCE may be obtained from an ASN-second-table entry in the ART-lookaside buffer (ALB). Bit 56 of the ASCE is ignored when the storage-alteration-space control is zero.

**Programming Notes:**

1. Models may operate at reduced performance while the CPU is enabled for PER events. In order to ensure that CPU performance is not degraded because of the operation of the PER facility, programs that do not use it should disable the CPU for PER events by setting either the PER mask in the PSW to zero or the PER-event masks in control register 9 to zero, or both. No degradation due to PER occurs when either of these fields is zero.
2. Some degradation may be experienced on some models every time control registers 9, 10, and 11 are loaded, even when the CPU is disabled for PER events (see the programming note under “Storage-Area Designation”).

3. Enabling the CPU for PER instruction-fetching nullification may be used to determine the state of the CPU before execution of any instruction within the storage area designated by control registers 10 and 11. The instruction nullified could be the first instruction after a successful branch, after LOAD PSW, or after LOAD PSW EXTENDED; or it could be the target of an execute-type instruction or the leftmost instruction in the storage area and accessed in the process of sequential execution. After recording the desired information, in order to allow the CPU to execute this instruction, either the CPU must be disabled for instruction-fetching nullification or control registers 10 and 11 must be changed to designate a different storage area. This can be contrasted to enabling for PER successful branching within the same storage area, which causes a PER event to be reported only in the first case mentioned above, but does not require special action to continue.

| PER Operation |

PER is under control of bit 1 of the PSW, the PER mask. When the PER mask and a particular PER-event mask bit are all ones, the CPU is enabled for the corresponding type of event; otherwise, it is disabled. However, the CPU is enabled for the store-using-real-address event only when the storage-alteration mask bit and the store-using-real-address mask bit are both one.

The CPU is enabled for the PER instruction-fetching nullification event only when the PER-3 facility is installed, and then only when the instruction-fetching-event mask bit, the instruction-fetching-nullification-event mask bit, and the PER mask are all ones. An interruption due to a PER instruction-fetching nullification event causes the execution of the instruction causing the event to be nullified.

An interruption due to a PER basic event normally occurs after the execution of the instruction responsible for the event. The occurrence of the event does not affect the execution of the instruction, which may be completed, partially completed, terminated, suppressed, or nullified. However, recognition of a storage-alteration event causes no more than 4K bytes to be stored beginning with the byte that caused the event, and recognition of a zero-address-detection event may occur on completion of a unit of operation; recognition of these PER events may result in partial completion of an interruptible instruction.

An interruption for an instruction-fetching nullification event occurs before the instruction responsible for the event is executed, and the operation is nullified.

When a PER event is recognized while the CPU is in the transactional-execution mode, the transaction is aborted as described in “Transaction Abort Processing” on page 5-103, and bit 6 is set in the program-interruption code, indicating that the interruption occurred while the CPU was in the transactional-execution mode. For storage-alteration events that occur while the CPU is in the transactional-execution mode (except for those caused by NONTRANSACTIONAL STORE), the store is discarded even though the event results in a PER interruption.

A PER storage-alteration or zero-address-detection event is detected for the TBEGIN-specified transaction diagnostic block during the execution of the outermost TRANSACTION BEGIN instruction rather than during transaction abort processing. It is unpredictable whether a PER storage-alteration or zero-address-detection event is detected for the TBEGIN-specified TDB during the execution of inner TBEGIN instructions.

When the CPU is disabled for a particular PER event at the time it occurs, either by the PER mask in the PSW or by the masks in control register 9, the event is not recognized.

A change to the PER mask in the PSW or to the PER control fields in control registers 9, 10, and 11 affects PER starting with the execution of the immediately following instruction. Thus, if, as a result of the change, an instruction-fetching nullification event applies to the immediately following instruction, execution of that instruction will be nullified and the instruction-fetching nullification event reported.

A change to the storage-alteration-event bit in an address-space-control element in control register 1, 7, or 13 also affects PER starting with the execution of the immediately following instruction. A change to the storage-alteration-event bit in an address-space-control element that may be obtained, during access-
register translation, from an ASN-second-table entry in either main storage or the ALB does not necessarily have an immediate, if any, effect on PER. However, PER is affected immediately after either PURGE ALB or COMPARE AND SWAP AND PURGE that purges the ALB is executed.

If a PER basic event occurs during the execution of an instruction which changes the CPU from being enabled to being disabled for that type of event, that PER event is recognized.

PER basic events may be recognized in a trial execution of an instruction, and subsequently the instruction, DAT-table entries, and operands may be refetched for the actual execution. If any refetched field was modified by another CPU or by a channel program between the trial execution and the actual execution, it is unpredictable whether the PER events indicated are for the trial or the actual execution.

For special-purpose instructions that are not described in this publication, the operation of PER may not be exactly as described in this section.

Identification of Cause

A program interruption for PER sets bit 8 of the interruption code to one and places identifying information in real storage locations 150-159. When the PER event is a storage-alteration event or a zero-address-detection event, information is also stored in location 161. Additional information is provided by means of the instruction address in the program old PSW and the ILC.

Locations 150-151:

<table>
<thead>
<tr>
<th>PER Code</th>
<th>ATMID</th>
<th>AI</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>14 15</td>
</tr>
</tbody>
</table>

**PER Code:** The occurrence of PER events is indicated by ones in bit positions 0-2 and 4-7. The bit position in the PER code for a particular type of event is as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>PER Event</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Successful-branching</td>
</tr>
<tr>
<td>1</td>
<td>Instruction-fetching</td>
</tr>
<tr>
<td>2</td>
<td>Storage-alteration</td>
</tr>
<tr>
<td>4</td>
<td>Store-using-real-address</td>
</tr>
<tr>
<td>5</td>
<td>Zero-address-detection</td>
</tr>
<tr>
<td>6</td>
<td>Transaction-end</td>
</tr>
<tr>
<td>7</td>
<td>Instruction-fetching nullification (PER-3)</td>
</tr>
</tbody>
</table>

A one in bit position 2 and a zero in bit position 4 of location 150 indicate a storage-alteration event, while ones in bit positions 2 and 4 indicate a store-using-real-address event. When a program interruption occurs, more than one type of PER basic event can be concurrently indicated. However, when a storage-alteration event and a zero-address-detection event are concurrently recognized, only the storage-alteration event is indicated. Additionally, if another program-interruption condition exists, the interruption code for the program interruption may indicate both the PER basic events and the other condition.

When a program interruption occurs for a PER instruction-fetching nullification event, bits 1 and 7 are set to one in the PER code. No other PER events are concurrently indicated.

When the transactional-execution facility is installed, and a program interruption occurs for a transaction-end event, bit 6 is set to one in the PER code. If an instruction-fetching basic event coincides with the transaction-end event, bit 1 is also set to one in the PER code. No other PER events are concurrently indicated with a transaction-end event.

A zero is stored in bit position 3 of locations 150-151. When the PER zero-address-detection facility is not installed, zero is stored in bit position 5. When the transactional-execution facility is not installed, zero is stored in bit position 6. When PER-3 is not installed, zero is stored in bit position 7.

**Addressing-and-Translation-Mode Identification (ATMID):** During a program interruption when a PER event is indicated, bits 31, 32, 5, 16, and 17 of the PSW at the beginning of the execution of the instruction that caused the event may be stored in bit positions 8 and 10-13, respectively, of real locations 150-151. If bits 31, 32, 5, 16, and 17 are stored, then a one bit is stored in bit position 9 of locations 150-151. If bits 31, 32, 5, 16, and 17 are not stored, then zero bits are stored in bit positions 8-13 of locations 150-151.

Bits 8-13 of real locations 150-151 are named the addressing-and-translation-mode identification (ATMID). Bit 9 is named the ATMID-validity bit. When bit 9 is zero, it indicates that an invalid ATMID (all zeros) was stored.
The meanings of the bits of a valid ATMID are as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>PSW bit 31</td>
</tr>
<tr>
<td>9</td>
<td>ATMID-validity bit</td>
</tr>
<tr>
<td>10</td>
<td>PSW bit 32</td>
</tr>
<tr>
<td>11</td>
<td>PSW bit 5</td>
</tr>
<tr>
<td>12</td>
<td>PSW bit 16</td>
</tr>
<tr>
<td>13</td>
<td>PSW bit 17</td>
</tr>
</tbody>
</table>

A valid ATMID is necessarily stored only if the PER event was caused by one of the following instructions:

- BRANCH AND SAVE AND SET MODE (BASSM)
- BRANCH AND SET AUTHORITY (BSA)
- BRANCH AND SET MODE (BSM)
- BRANCH IN SUBSPACE GROUP (BSG)
- LOAD PSW (LPSW)
- LOAD PSW EXTENDED (LPSWE)
- PROGRAM CALL (PC)
- PROGRAM RETURN (PR)
- PROGRAM TRANSFER (PT)
- PROGRAM TRANSFER WITH INSTANCE (PTI)
- RESUME PROGRAM (RP)
- SET ADDRESS SPACE CONTROL (SAC)
- SET ADDRESS SPACE CONTROL FAST (SACF)
- SET ADDRESSING MODE (SAM24, SAM31, SAM64)
- SET SYSTEM MASK (SSM)
- STORE THEN AND SYSTEM MASK (STNSM)
- STORE THEN OR SYSTEM MASK (STOSM)
- SUPERVISOR CALL (SVC)
- TRAP (TRAP2, TRAP4)

It is unpredictable whether a valid ATMID is stored if the PER event was caused by any other instruction. The value of the PER instruction-fetching-nullification-event mask bit does not affect the contents of the ATMID field.

**PER ASCE Identification (AI):** If the PER code contains an indication of a storage-alteration event or a zero-address detection event, but the event occurred when PSW bit 5 was 0, bits 14 and 15 of locations 150-151 are unpredictable.

If either of the following is true, zeros are stored in bit positions 14 and 15 of locations 150-151.

- An ASCE was not used to translate the reference that caused the event.
- The PER code indicates that neither a storage-alteration event, nor a store-using-real-address event, nor a zero-address-detection event occurred (that is, bits 2 and 5 of the code are both zeros).
**Programming Note:** Except for references to the enhanced-monitor counting array, an ASCE is not used to translate the reference when DAT is off or when the operand is defined to contain a real address (as is the case for COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE DAT TABLE ENTRY, INVALIDATE PAGE TABLE ENTRY, LOAD USING REAL ADDRESS, and STORE USING REAL ADDRESS). An ASCE is also not used to translate the reference when the operand is defined to contain a real or absolute address (as is the case for PERFORM FRAME MANAGEMENT FUNCTION).

**PER Address:** The PER-address field at locations 152-159 contains the instruction address used to fetch the instruction responsible for the recognized PER event or events, as shown below.

Locations 152-159:

<table>
<thead>
<tr>
<th>Location</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-31</td>
<td>PER Address</td>
</tr>
<tr>
<td>32-63</td>
<td>PER Address (continued)</td>
</tr>
</tbody>
</table>

When the instruction is the target of an execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG), the instruction address used to fetch the execute-type instruction is placed in the PER-address field.

**PER Access Identification (PAID):** If a storage-alteration event or zero-address-detection event is indicated in the PER code, and the PER ASCE identification (AI, bits 14-15 of locations 150-151) contains 01 binary, an indication of the address space to which the event applies is stored at location 161, as shown below.

Location 161:

<table>
<thead>
<tr>
<th>Location</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-3</td>
<td>PAID</td>
</tr>
<tr>
<td>4-7</td>
<td></td>
</tr>
</tbody>
</table>

The number of the access register used is stored in bit positions 4-7 of location 161, and zeros are stored in bit positions 0-3. The contents of location 161 are unpredictable if when the PER ASCE identification does not contain 01 binary.

**Instruction Address:** The instruction address in the program old PSW is the address of the instruction which would have been executed next, unless another program condition is also indicated, in which case the instruction address is that determined by the instruction ending due to that condition. When a PER instruction-fetching nullification event is recognized, the instruction address in the program old PSW is the address of the instruction responsible for the event. This is the same address stored in the PER address field in real storage locations 152-159.

**ILC:** For PER instruction nullification events, the ILC is 0. For PER basic events, the ILC indicates the length of the instruction designated by the PER address, except when a concurrent specification exception for the PSW introduced by LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, or a supervisor-call interruption sets an ILC of 0.

**Programming Notes:**

1. PSW bit 31 is the extended-addressing-mode bit, and PSW bit 32 is the basic-addressing-mode bit. When PSW bit 31 and 32 are both one, they specify the 64-bit addressing mode. When PSW bit 31 is zero, PSW 32 specifies the 24-bit addressing mode if the bit is zero or the 31-bit addressing mode if the bit is one. PSW bit 5 is the DAT-mode bit, and PSW bits 16 and 17 are the address-space-control bits. For the handling of instruction and logical addresses in the different translation modes, see “Translation Modes” on page 3-37.

2. A valid ATMID allows the program handling the PER event to determine the address space from which the instruction that caused the event was fetched and also to determine which translation mode applied to the storage-operand references of the instruction, if any. Each of the instructions for which a valid ATMID is necessarily stored can change one or more of PSW bits 5, 16, and 17, with the result that the values of those bits in the program old PSW that is stored because of the PER event are not necessarily the values that existed at the beginning of the execution of the instruction that caused the event. The instructions for which a valid ATMID is necessarily stored are the only instructions that can change any of PSW bits 5, 16, and 17.

3. If a storage-alteration PER event or zero-address-detection event is indicated and DAT was on when the event occurred, an indication of the address-space-control element that was
used to translate the reference that caused the event is given by the PER ASCE identification, bits 14 and 15 indicate that an AR-specified address-space-control element was used, the PER access identification in real location 161 can be used to determine the address space that was referenced. To determine if DAT was on, the program handling the PER event should first examine the ATMID-validity bit to determine whether a valid ATMID was stored and, if it was stored, then examine the DAT-mode bit in the ATMID. If a valid ATMID was not stored, the program should examine the DAT-mode bit in the program old PSW.

4. If a valid ATMID is stored, it also allows the program handling the PER event to determine the addressing mode (24-bit, 31-bit, or 64-bit) that existed for the instruction that caused the PER event. This knowledge of the addressing mode allows the program to determine, without any chance of error, the meaning of one bits in bit positions 0-39 of the addresses of the instruction and of the storage operands, if any, of the instruction and, thus, to determine accurately the locations of the instruction and operands. Note that the address of the instruction is not necessarily provided without error by the PER address in real locations 152-159 because that address may be the address of an execute-type instruction, with the address of the target instruction still to be determined from the fields that specify the second-operand address of the execute-type instruction. Also note that another possible source of error is that, in the 24-bit or 31-bit addressing mode, an instruction or operand may wrap around in storage by beginning just below the 16M-byte or 2G-byte boundary, respectively.

5. A valid ATMID is necessarily stored for all instructions that can change the addressing-mode bits. However, the ATMID mechanism does not provide complete assurance that the instruction causing a PER event and the instruction's operands can be located accurately because LOAD CONTROL and LOAD ADDRESS SPACE PARAMETERS can change the address-space-control element that was used to fetch the instruction.

**Priority of Indication**

When a PER instruction-fetching nullification event is recognized and other program interruption conditions exist, only the program interruption condition with the highest priority is indicated. See “Multiple Program-Interruption Conditions” on page 6-48 for a description of the priority of program interruption conditions.

When a PER instruction-fetching nullification event is indicated, no other PER events are indicated. When a PER instruction-fetching nullification event is not indicated, then more than one PER basic event may be recognized and reported. The remainder of this section applies to these cases.

When a program interruption occurs and more than one PER basic event has been recognized, all recognized PER events are concurrently indicated in the PER code. However, when either a storage-alteration or store-using-real-address event is recognized concurrently with a zero-address-detection event, only the storage alteration or store-using-real-address event is indicated. Additionally, if another program-interruption condition concurrently exists, the interruption code for the program interruption indicates both the PER condition and the other condition.

When a zero-address-detection event is recognized for more than one storage operand, it is unpredictable which operand’s ASCE identification and AR number, if applicable, are stored in locations 150-151 and 161.

In the case of an instruction-fetching basic event for SUPERVISOR CALL, the program interruption occurs immediately after the supervisor-call interruption.

If a PER basic event is recognized during the execution of an instruction which also introduces a new PSW with the type of PSW-format error which is recognized early (see “Exceptions Associated with the PSW” on page 6-9), both the specification exception and PER are indicated concurrently in the interruption code of the program interruption. If the PSW-format error is of the type which is recognized late, only PER is indicated in the interruption code. In both cases, the invalid PSW is stored as the program old PSW.

Recognition of a PER basic event does not normally affect the ending of instruction execution. However, in the following cases, execution of an interruptible instruction is not completed normally:

1. When the instruction is due to be interrupted for an asynchronous condition (I/O, external, restart,
or repressible machine-check condition), a program interruption for the PER event occurs first, and the other interruptions occur subsequently (subject to the mask bits in the new PSW) in the normal priority order.

2. When the stop function is performed, a program interruption indicating the PER event occurs before the CPU enters the stopped state.

3. When any program exception is recognized, PER events recognized for that instruction execution are indicated concurrently.

4. Depending on the model, in certain situations, recognition of a PER event may appear to cause the instruction to be interrupted prematurely without concurrent indication of a program exception, without an interruption for any asynchronous condition, and without the CPU entering the stopped state. In particular, recognition of a storage-alteration event causes no more than 4K bytes to be stored beginning with the byte that caused the event, and recognition of a zero-address-detection event may occur on completion of a unit of operation.

In cases 1 and 2 above, if the only PER event that has been recognized is an instruction-fetching basic event and another unit of operation of the instruction remains to be executed, the event may be discarded, with the result that a program interruption does not occur. Whether the event is discarded is unpredictable.

Recognition of a PER instruction-fetching nullification event causes execution of the instruction responsible for the event to be nullified.

Programming Notes:

1. In the following cases, an instruction can both cause a program interruption for a PER basic event and change the value of fields controlling an interruption for PER events. The original field values determine whether a program interruption takes place for the PER event.

   a. The instructions LOAD PSW, LOAD PSW EXTENDED, SET SYSTEM MASK, STORE THEN AND SYSTEM MASK, and SUPERVISOR CALL can cause an instruction-fetching event and disable the CPU for PER interruptions. Additionally, STORE THEN AND SYSTEM MASK can cause a storage-alteration event to be indicated. In all these cases, the program old PSW associated with the program interruption for the PER event may indicate that the CPU was disabled for PER events.

   b. An instruction-fetching event or a zero-address-detection event may be recognized during execution of a LOAD CONTROL instruction that changes the value of the PER-event masks in control register 9 or the addresses in control registers 10 and 11 controlling indication of instruction-fetching events.

   c. In the access-register mode, a storage-alteration event that is permitted by a one value of the storage-alteration-event bit in an address-space-control element in an ASN-second-table entry (designated by an access-list entry) may be caused by any store-type instruction that changes the value of the bit from one to zero.

2. When a PER interruption for a PER basic event occurs during the execution of an interruptible instruction, the ILC indicates the length of that instruction or execute-type instruction, as appropriate. When a PER interruption for a PER basic event occurs as a result of LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, or SUPERVISOR CALL, the ILC indicates the length of the instruction or of the execute-type instruction which designates the interrupted type of instruction as its target, as appropriate, unless a concurrent specification exception on LOAD PSW, LOAD PSW EXTENDED, or PROGRAM RETURN calls for an ILC of 0.

3. When a PER interruption is caused by branching, the PER address identifies the branch instruction (or execute-type instruction, as appropriate), whereas the old PSW points to the next instruction to be executed. When the interruption occurs during the execution of an interruptible instruction, the PER address and the instruction address in the old PSW are the same.

Storage-Area Designation

Two types of PER events — instruction fetching and storage alteration — always involve the designation of an area in storage. Successful-branching events may involve this designation. The storage area starts
at the location designated by the starting address in control register 10 and extends up to and including the location designated by the ending address in control register 11. The area extends to the right of the starting address.

An instruction-fetching event occurs whenever the first byte of an instruction or the first byte of the target of an execute-type instruction is fetched from the designated area. A storage-alteration event occurs when a store access is made to the designated area by using an operand address that is defined to be a logical or a virtual address. However, when DAT is on and the storage-alteration-space control in control register 9 is one, a storage-alteration event occurs only when the storage area is within an address space for which the storage-alteration-event bit in the address-space-control element is one. A storage-alteration event does not occur for a store access made with an operand address defined to be a real address. When the branch-address control in control register 9 is one, a successful-branching event occurs when the first byte of the branch-target instruction is within the designated area.

The set of addresses designated for successful-branching, instruction-fetching, and storage-alteration events wraps around at address 2^{64} - 1; that is, address 0 is considered to follow address 2^{64} - 1. When the starting address is less than the ending address, the area is contiguous. When the starting address is greater than the ending address, the set of locations designated includes the area from the starting address to address 2^{64} - 1 and the area from address 0 to, and including, the ending address. When the starting address is equal to the ending address, only that one location is designated.

Address comparison for successful-branching, instruction-fetching, and storage-alteration events is always performed using 64-bit addresses. This is accomplished in the 24-bit or 31-bit addressing mode by extending the virtual, logical, or instruction address on the left with 40 or 33 zeros, respectively, before comparing it with the starting and ending addresses.

Programming Note: In some models, performance of address-range checking is assisted by means of an extension to each page-table entry in the TLB. In such an implementation, changing the contents of control registers 10 and 11 when the successful-branching, instruction-fetching, or storage-alteration-event mask is one, or setting any of these PER-event masks to one, may cause the TLB to be cleared of entries. This degradation may be experienced even when the CPU is disabled for PER events. Thus, when possible, the program should avoid loading control registers 9, 10, or 11.

**PER Events**

**Successful Branching**

When the branch-address control in control register 9 is zero, a successful-branching event occurs independent of the branch-target address. When the branch-address control is one, a successful-branching event occurs only when the first byte of the branch-target instruction is in the storage area designated by control registers 10 and 11.

Subject to the effect of the branch-address control, a successful-branching event occurs whenever one of the following instructions causes branching:

- BRANCH AND LINK (BAL, BALR)
- BRANCH AND SAVE (BAS, BASR)
- BRANCH AND SAVE AND SET MODE (BASSM)
- BRANCH AND SET AUTHORITY (BSA)
- BRANCH AND SET MODE (BSM)
- BRANCH AND STACK (BAKR)
- BRANCH IN SUBSPACE GROUP (BSG)
- BRANCH ON CONDITION (BC, BCR)
- BRANCH ON COUNT (BCT, BCTR, BCTG, BCTGR)
- BRANCH ON INDEX HIGH (BXH, BXHG)
- BRANCH ON INDEX LOW OR EQUAL (BXLE, BXLEG)
- BRANCH RELATIVE AND SAVE (BRAS)
- BRANCH RELATIVE AND SAVE LONG (BRASL)
- BRANCH RELATIVE ON CONDITION (BRC)
- BRANCH RELATIVE ON CONDITION LONG (BRCL)
- BRANCH RELATIVE ON COUNT (BRCT, BRCTG)
- BRANCH RELATIVE ON COUNT HIGH (BRCTH)
- BRANCH RELATIVE ON INDEX HIGH (BRXH, BRXHG)
- BRANCH RELATIVE ON INDEX LOW OR EQUAL (BRXLE, BRXLEG)
- COMPARE AND BRANCH (CRB, CGRB)
- COMPARE AND BRANCH RELATIVE (CRJ, CGRJ)
Subject to the effect of the branch-address control, a successful-branching event also occurs whenever one of the following instructions causes branching:

- PROGRAM CALL (PC)
- PROGRAM RETURN (PR)
- PROGRAM TRANSFER (PT)
- PROGRAM TRANSFER WITH INSTANCE (PTI)

For PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, and PROGRAM TRANSFER WITH INSTANCE, the branch-target address is considered to be the new instruction address that is placed in the PSW by the instruction.

A successful-branching event causes a PER successful-branching event to be recognized if bit 32 of the PER-event masks is one and the PER mask in the PSW is one.

A PER successful-branching event is indicated by setting bit 0 of the PER code to one.

Instruction Fetching
An instruction-fetching event occurs if the first byte of the instruction is within the storage area designated by control registers 10 and 11. An instruction-fetching event also occurs if the first byte of the target of an execute-type instruction is within the designated storage area.

Instruction-Fetching Basic Event: An instruction-fetching event causes a PER instruction-fetching basic event to be recognized if the PER mask in the PSW is one and bit 33 of the PER-event masks is one and either the PER-3 facility is not installed, or bit 39 of the PER-event masks is zero.

If an instruction-fetching basic event is the only PER event recognized for an interruptible instruction that is to be interrupted because of an asynchronous condition (I/O, external, restart, or repressible machine-check condition) or the performance of the stop function, and if a unit of operation of the instruction remains to be executed, the instruction-fetching event may be discarded, and whether it is discarded is unpredictable.

The PER instruction-fetching basic event is indicated by setting bit 1 of the PER code to one and bit 7 of the PER code to zero.

Instruction-Fetching Nullification Event: An instruction-fetching event causes a PER instruction-fetching nullification event to be recognized if the PER mask in the PSW is one and bit 33 of the PER-event masks is one and the PER-3 facility is installed and bit 39 of the PER-event masks is one.

The PER instruction-fetching nullification event is indicated by setting bits 1 and 7 of the PER code to one.

Storage Alteration
A storage-alteration event occurs whenever a CPU, by using a logical or virtual address, makes a store access without an access exception to the storage area designated by control registers 10 and 11. However, when DAT is on and the storage-alteration-space control in control register 9 is one, the event occurs only if the storage-alteration-event bit is one in the address-space-control element that is used by DAT to translate the reference to the storage location.

The contents of storage are considered to have been altered whenever the CPU executes an instruction that causes all or part of an operand to be stored within the designated storage area. Alteration is considered to take place whenever storing is considered to take place for purposes of indicating protection exceptions, except that recognition does not occur for the storing of data by a channel program. (See “Recognition of Access Exceptions” on page 6-45.) Storing constitutes alteration for PER purposes even if the value stored is the same as the original value. Additionally, the contents of a TBEGIN-specified TDB are considered to have been altered by the execution of an outermost TBEGIN instruction, regardless of whether the TDB is actually stored by a transaction being aborted; it is unpredictable whether a PER
storage-alteration event is detected for the first-operand location of an inner TBEGIN instruction.

Implied locations that are referred to by the CPU are not monitored. Such locations include PSW and interruption-code locations, the program-interruption transaction diagnostic block, the enhanced-monitor exception counter, and the trace entry designated by control register 12. These locations, however, are monitored when information is stored there explicitly by an instruction. Similarly, monitoring does not apply to the storing of data by a channel program. Implied locations in the linkage stack, which are stored in by instructions that operate on the linkage stack, and enhanced-monitor-counting-array entries which are stored in by the MONITOR CALL instruction, are monitored.

The I/O instructions are considered to alter the second-operand location only when storing actually occurs.

Storage alteration does not apply to instructions whose operands are specified to have real or absolute addresses. Thus, storage alteration does not apply to COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE DAT TABLE ENTRY (invalidation-and-clearing operation), INVALIDATE PAGE TABLE ENTRY, PAGE IN, PERFORM FRAME MANAGEMENT FUNCTION, RESET REFERENCE BIT EXTENDED, RESET REFERENCE BITS MULTIPLE, STORE USING REAL ADDRESS, TEST BLOCK, and TEST PENDING INTERRUPTION (when the effective address is zero). Storage alteration does not apply to the store to real location 200 by STORE FACILITY LIST, nor does it apply to stores to the trace table by instructions that cause tracing to occur.

A storage-alteration event causes a PER storage-alteration event to be recognized if bit 34 of the PER-event masks is one and the PER mask in the PSW is one. Bit 36 of the PER-event masks is ignored when determining whether a PER storage-alteration event is to be recognized.

A PER storage-alteration event is indicated by setting bit 2 of the PER code to one and bit 4 of the PER code to zero.

**Store Using Real Address**

A store-using-real-address event occurs whenever the STORE USING REAL ADDRESS instruction is executed.

There is no relationship between the store-using-real-address event and the designated storage area.

A store-using-real-address event causes a PER store-using-real-address event to be recognized if bits 34 and 36 of the PER-event mask are ones and the PER mask in the PSW is one.

A PER store-using-real-address event is indicated by setting bits 2 and 4 of the PER code to one.

**Zero-Address Detection**

When the PER zero-address-detection facility is installed, a zero-address-detection event occurs whenever a CPU makes a storage access using an effective operand address formed from a general register, or subfield of a general register, containing zero. However, during execution of an RX-, RXE-, RXF-, RXY-, or VRX-format instruction, the event occurs only if the CPU makes a storage access using an effective operand address formed under one of the following conditions:

1. The base register number is zero, the index register number is nonzero, and the index register contains zero.
2. The index register number is zero, the base register number is nonzero, and the base register contains zero.
3. When both the base register number and the index register number are nonzero, it is unpredictable which one of the following conditions causes the event:
   
   (a) The base register contains zero.
   (b) The sum of the contents of the base register and the index register is zero.

During the execution of a VRV-format instruction, it is unpredictable which one or more of the following conditions will cause the event to occur if the CPU makes a storage access:

1. The base register number is zero, and the value of the indexed element of the second operand is zero.
2. The base register number is non-zero and the base register contains zero.

3. The sum of the contents of the base register and the value of the indexed element is zero.

Except as noted below, zero-address detection for an operand address is performed whenever a fetch, store, or update reference is made to storage using the address, and zero-address detection is performed only when an operand address is used to access storage.

Zero-address detection is not performed on the branch address of branch-type instructions, the target-instruction address of the EXECUTE instruction, and the contents of general register R2 for the TEST BLOCK instruction.

For COMPRESSION CALL, CONVERT UTF-16 TO UTF-32, CONVERT UTF-16 TO UTF-8, CONVERT UTF-32 TO UTF-16, CONVERT UTF-32 TO UTF-8, CONVERT UTF-8 TO UTF-16, and CONVERT UTF-8 TO UTF-32, it is unpredictable whether a PER zero-address-detection event is recognized for any storage operand when the end of the first operand is reached, but the end of the second operand has not been reached.

Conditions for causing a zero-address-detection event are evaluated at the start of instruction execution. It is unpredictable if those conditions are reevaluated during instruction execution.

Except as noted below, the determination of whether a register's contents are zero is dependent upon the current addressing mode, as follows:

- In the 24- and 31-bit addressing modes, a register is considered to contain zero if bits 32-63 are all zeros.
- In the 64-bit addressing mode, a register is considered to contain zero if bits 0-63 are all zeros.

For COMPARE AND REPLACE DAT TABLE ENTRY, when bit position 59 of general register R2 contains zero, general register R2 is considered to contain zero if bits 0-52 are all zeros; when bit position 59 of general register R2 contains one, general register R2 is considered to contain zero if bits 0-51 are all zeros. For INVALIDATE DAT TABLE ENTRY, general register R1 is considered to contain zero if bits 0-51 are all zeros, and for INVALIDATE PAGE TABLE ENTRY, general register R1 is considered to contain zero if bits 0-52 are all zeros, regardless of the addressing mode.

A zero-address-detection event causes a PER zero-address-detection event to be recognized if the PER mask in the PSW is one and bit 37 of the PER-event mask is one.

A PER zero-address-detection event is indicated by setting bit 5 of the PER code to one.

**Programming Notes:**

1. Following are examples of instructions and corresponding general register values that cause a zero-address-detection event:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>General Register Values</th>
</tr>
</thead>
<tbody>
<tr>
<td>LAM 3,4,8(7)</td>
<td>GR7=0</td>
</tr>
<tr>
<td>LG 1,8(0,3)</td>
<td>GR3=0</td>
</tr>
<tr>
<td>L 5,87(4,0)</td>
<td>GR4=0</td>
</tr>
<tr>
<td>LG 6,0(1,2)</td>
<td>GR2=0</td>
</tr>
<tr>
<td>MVCL 2,4</td>
<td>GR2=0 or GR4=0</td>
</tr>
<tr>
<td>MVCL 0,8</td>
<td>GR0=0 or GR8=0</td>
</tr>
</tbody>
</table>

   The examples using the MVCL instructions will cause the event only if a nonzero second-operand length is specified in general register R2 + 1; see Programming Note 3.

2. A zero-address-detection event may occur for normal programming situations. In particular, an instruction that intentionally accesses the prefix storage area or a data space with an origin of zero may use a base register containing zero in the formation of a storage operand address, and thus cause a zero-address-detection event to occur. If normal execution of a program frequently uses registers containing zero in the formation of storage addresses, then the PER zero-address-detection event will be of limited use in locating programming bugs involving the unintentional use of a general register containing zero in the formation of a storage address.

3. A PER zero-address-detection event is not recognized for an operand address that is not used to access storage. For example, when the MOVE LONG instruction is executed with a second-operand length of zero specified in general register R2 + 1, a PER zero-address-detection event is not recognized when the second-operand address is zero.

4. Recognition of a PER zero-address-detection event is unpredictable for instructions where it is
unpredictable whether access exceptions are recognized when the operand values allow the operation to complete without storage being accessed.

**Architecture Note:**

**Transaction End**
When the CPU is in the transactional-execution mode at the beginning of an outermost TRANSACTION END instruction, a transaction-end event occurs at the completion of the instruction.

There is no relationship between the transaction-end event and the designated storage area.

A transaction-end event causes a PER transaction-end event to be recognized if bit 38 of the PER-event mask is one and the PER mask in the PSW is one.

A PER transaction-end event is indicated by setting bit 6 of the PER code to one.

A transaction-end event is not recognized when a TRANSACTION END instruction is executed and the CPU is not in the transactional-execution mode.

**Indication of PER Events Concurrently with Other Interruption Conditions**

When a PER instruction-fetching nullification event is reported, no other PER events and no other program interruption conditions other than transaction-abort exception (if applicable) are reported.

The following rules govern the indication of PER basic events caused by an instruction that also causes a program exception, a monitor event, a space-switch event, or a supervisor-call interruption.

1. The indication of an instruction-fetching basic event does not depend on whether the execution of the instruction was completed, terminated, suppressed, or nullified. However, special cases of suppression and nullification are as follows:
   a. When the instruction is designated by an odd instruction address in the PSW, the instruction-fetching event is not indicated.
   b. When an access exception applies to the first, second, or third halfword of the instruction, and the PER-3 facility is installed, the instruction-fetching event is not indicated. However, if the PER-3 facility is not installed, it is unpredictable whether the instruction-fetching event is indicated.
   c. When the target address of EXECUTE is odd or an access exception applies to the first, second, or third halfword of the target instruction, and the PER-3 facility is installed, the instruction-fetching event is not indicated for the target location. However, if the PER-3 facility is not installed, it is unpredictable whether the instruction-fetching event is indicated for the target instruction, and it is also unpredictable whether the event is indicated for the EXECUTE instruction.

2. When the operation is completed or partially completed, the event is indicated, regardless of whether any program exception, space-switch event, or monitor event is also recognized.

3. Successful branching, zero-address detection, storage alteration, and store using real address are not indicated for an operation or, in case the instruction is interruptible, for a unit of operation that is suppressed or nullified.

4. When the execution of the instruction is terminated, storage alteration or zero-address detection is indicated whenever the event has occurred. A model may indicate the event if the event would have occurred had the execution of the instruction been completed, even if altering the contents of the result field is contingent on operand values. For purposes of this definition, the occurrence of those exceptions which permit termination (addressing, protection, and data) is considered to cause termination, even if no result area is changed.

5. When LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, SET SYSTEM MASK, STORE THEN OR SYSTEM MASK, or SUPERVISOR CALL causes a PER basic condition and at the same time introduces a new PSW with the type of PSW-format error that is recognized immediately after the PSW becomes active, the interruption code identifies both the PER basic condition and the specification exception.

6. When LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, or SUPERVISOR CALL
causes a PER condition and at the same time introduces a new PSW with the type of PSW-format error that is recognized as part of the execution of the following instruction, the introduced PSW is stored as the old PSW without the following instruction being fetched or executed and without the specification exception being recognized.

7. When an outermost TRANSACTION BEGIN instruction causes a PER basic event and a concurrent program exception, the event-suppression control does not apply.

When a PER event occurs while the CPU is in the transactional-execution mode, the transaction is aborted as described in “Transaction Abort Processing” on page 5-103, and bit 6 is set in the program-interruption code.

The indication of PER basic events concurrently with other program-interruption conditions for the same instruction, as described in cases 1-4 above, is summarized in Figure 4-8 on page 4-38. Cases 5 and 6 are shown in Figure 4-9 on page 4-39.

Programming Notes:

1. The execution of the interruptible instructions COMPARE AND FORM CODEWORD, COMPARE LOGICAL LONG, COMPARE UNTIL SUBSTRING EQUAL, COMPRESSION CALL, MOVE LONG, TEST BLOCK, and UPDATE TREE can cause events for instruction fetching and zero-address detection. The execution of the interruptible instructions PERFORM FRAME MANAGEMENT FUNCTION (when the enhanced-DAT facility is installed, and the frame-size code designates a 1M-byte frame), SET STORAGE KEY EXTENDED (when the enhanced-DAT facility is installed, and the multiple-block control is one) and TEST BLOCK can cause events for instruction-fetching. Execution of COMPRESSION CALL, MOVE LONG, and UPDATE TREE can cause events for instruction-fetching, zero-address detection and storage-alteration.

   Interruption of such an instruction may cause a PER basic event to be indicated more than once. It may be necessary, therefore, for a program to remove the redundant event indications from the PER data. The following rules govern the indication of the applicable events during execution of these instructions:

   a. The instruction-fetching basic event is indicated whenever the instruction is fetched for execution, regardless of whether it is the initial execution or a resumption, except that the event may be discarded (not indicated) if it is the only PER event to be indicated, the interruption is due to an asynchronous interruption condition or the performance of the stop function, and a unit of operation of the instruction remains to be executed.

   b. The storage-alteration event is indicated only when data has been stored in the designated storage area by the portion of the operation starting with the last initiation and ending with the last byte transferred before the interruption. No special indication is provided on premature interruptions as to whether the event will occur again upon the resumption of the operation. When the designated storage area is a single byte location, a storage-alteration event can be recognized only once in the execution of MOVE LONG or COMPRESSION CALL, but could be recognized more than once for UPDATE TREE.

2. The following is an outline of the general action a program must take to delete multiple entries for PER basic events in the PER data for an interruptible instruction so that only one entry for each complete execution of the instruction is obtained:

   a. Check to see if the PER address is equal to the instruction address in the old PSW and if the last instruction executed was interruptible.

   b. If both conditions are met, delete instruction-fetching events.

   c. If both conditions are met and the event is storage alteration, delete the event if some part of the remaining destination operand is within the designated storage area.

3. An example of the indication of a PER instruction-fetching basic event caused by either a LOAD PSW (or LOAD PSW EXTENDED) instruction or the following instruction, in connection with an early PSW-format error or odd instruction address introduced by the LOAD
PSW instruction, is shown in Figure 4-9 on page 4-39.

<table>
<thead>
<tr>
<th>Concurrent Condition</th>
<th>Type of Ending</th>
<th>Branch</th>
<th>Instr. Fetch</th>
<th>Storage Alter.</th>
<th>STURA</th>
<th>TEND</th>
<th>Z-Addr Detect</th>
</tr>
</thead>
<tbody>
<tr>
<td>Specification</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Odd instruction address in the PSW</td>
<td>S</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>Instruction access (without PER-3)</td>
<td>N or S</td>
<td>No</td>
<td>U</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>Instruction access (with PER-3)</td>
<td>N or S</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>Specification</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXECUTE target address odd (without PER-3)</td>
<td>S</td>
<td>No</td>
<td>U</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>No</td>
</tr>
<tr>
<td>EXECUTE target address odd (with PER-3)</td>
<td>S</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>No</td>
</tr>
<tr>
<td>EXECUTE target access (without PER-3)</td>
<td>N or S</td>
<td>No</td>
<td>U</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>No</td>
</tr>
<tr>
<td>EXECUTE target access (with PER-3)</td>
<td>N or S</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>No</td>
</tr>
<tr>
<td>Other nullifying</td>
<td>N</td>
<td>No</td>
<td>Yes</td>
<td>No</td>
<td>1</td>
<td>–</td>
<td>No</td>
</tr>
<tr>
<td>Other suppressing</td>
<td>S</td>
<td>No</td>
<td>Yes</td>
<td>No</td>
<td>1</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>All terminating</td>
<td>T</td>
<td>No</td>
<td>Yes</td>
<td>Yes</td>
<td>2</td>
<td>–</td>
<td>U</td>
</tr>
<tr>
<td>All completing</td>
<td>C</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>–</td>
<td>–</td>
<td>Yes</td>
</tr>
</tbody>
</table>

**Explanation:**

- The condition does not apply.
- Although PER events of this type are not indicated for the current unit of operation of an interruptible instruction, PER events of this type that were recognized on completed units of operation of the interruptible instruction are indicated.
- This event may be indicated, depending on the model, if the event has not occurred but would have been indicated if execution had been completed.
- The operation or, in the case of the interruptible instructions, the unit of operation is completed.
- The operation or, in the case of the interruptible instructions, the unit of operation is nullified.
- The operation or, in the case of the interruptible instructions, the unit of operation is suppressed.
- The execution of the instruction is terminated.
- The PER event is indicated with the other program interruption condition if the event has occurred; that is, the instruction address in the PSW was replaced and the branch-address control and PER designated storage area allow the event occurrence, an attempt was made to execute an instruction whose first byte is located in the designated storage area, the contents of the designated storage area was altered, or a general register containing zero was used in the formation of an operand address used to reference storage.
- The PER event is not indicated.
- It is unpredictable whether the PER event is indicated.

*Figure 4-8. Indication of PER Basic Events with Other Concurrent Conditions*
Breaking-Event-Address Recording

When the PER-3 facility is installed, it provides the program with the address of the last instruction to cause a break in the sequential execution of the CPU. Breaking-event-address recording can be used as a debugging assist for wild-branch detection. This facility provides a 64-bit register in the CPU, called the breaking-event-address register. Each time an instruction other than TRANSACTION ABORT causes a break in the sequential instruction execution (that is, the instruction address in the PSW is replaced, rather than incremented by the length of the instruction) the address of that instruction is placed in the breaking-event-address register. Whenever a program interruption occurs, whether or not PER is indicated, the current contents of the breaking-event-address register are placed in real storage locations 272-279.

<table>
<thead>
<tr>
<th>PSW Has Early PSW-Format Error</th>
<th>Instruction Address in PSW</th>
<th>6000-6001</th>
<th>Interruption Code</th>
<th>Address in Program Old PSW</th>
<th>ILC</th>
<th>PER Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>N</td>
<td>6000</td>
<td>N N</td>
<td>None</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>N</td>
<td>6000</td>
<td>N Y</td>
<td>P</td>
<td>6002</td>
<td>1</td>
<td>6000</td>
</tr>
<tr>
<td>N</td>
<td>6000</td>
<td>Y -</td>
<td>P</td>
<td>6000</td>
<td>2</td>
<td>4000</td>
</tr>
<tr>
<td>N</td>
<td>6001</td>
<td>N N</td>
<td>S</td>
<td>6001+J</td>
<td>K</td>
<td>None</td>
</tr>
<tr>
<td>N</td>
<td>6001</td>
<td>N Y</td>
<td>S²</td>
<td>6001+J</td>
<td>K²</td>
<td>None</td>
</tr>
<tr>
<td>N</td>
<td>6001</td>
<td>Y -</td>
<td>P² ³</td>
<td>6001² ³</td>
<td>2</td>
<td>4000</td>
</tr>
<tr>
<td>Y</td>
<td>6000</td>
<td>N -</td>
<td>S</td>
<td>6000</td>
<td>0⁴</td>
<td>None</td>
</tr>
<tr>
<td>Y</td>
<td>6000</td>
<td>Y -</td>
<td>P⁵ ³</td>
<td>6000² ³</td>
<td>0⁴</td>
<td>4000</td>
</tr>
<tr>
<td>Y</td>
<td>6001</td>
<td>N -</td>
<td>S</td>
<td>6001+J</td>
<td>K⁴</td>
<td>None</td>
</tr>
<tr>
<td>Y</td>
<td>6001</td>
<td>Y -</td>
<td>P⁵ ³</td>
<td>6001² ³</td>
<td>0⁴</td>
<td>4000</td>
</tr>
</tbody>
</table>

Explanation:
1. Immaterial or not applicable.
2. See "ILC on Instruction-Fetching Exceptions" on page 6-7.
3. See "Indication of PER Events Concurrently with Other Interruption Conditions" on page 4-36.
4. See "Priority of Indication" on page 4-30.
J. Unpredictably 2, 4, or 6.
K. 1, 2, or 3 depending on whether J is 2, 4, or 6, respectively.
N. No.
P. PER instruction-fetching basic event.
S. Specification exception.
Y. Yes.

Figure 4-9. Example of Instruction-Fetching PER Basic Event and Early PSW-Format Error or Odd Instruction Address
Programming Note: The addressing mode and address space used to translate the instruction address are not preserved; therefore, breaking-event-address recording is most effective for debugging code that does not contain address-space switches or addressing mode changes.

Breaking-Event-Address Register
When the PER-3 facility is installed, each CPU has a 64-bit register called the breaking-event-address register.

Each time execution of an instruction other than TRANSACTION ABORT replaces the instruction address in the PSW by any means other than sequential instruction execution, the instruction address used to fetch that instruction is placed in the breaking-event-address register. If the instruction causing the breaking event is the target of an execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG), then the instruction address used to fetch the execute-type instruction is placed in the breaking-event-address register.

Each time a program interruption occurs, the contents of the breaking-event-address register are placed in real storage locations 272-279.

The contents of the breaking-event-address register are unpredictable after the SIGNAL PROCESSOR set-architecture order.

The contents of the breaking-event-address register are reset to a value of 0000000000000001 hex by initial CPU reset.

Execution-Break Instructions
A breaking event is considered to occur whenever one of the following instructions causes branching:
- BRANCH AND LINK (BAL, BALR)
- BRANCH AND SAVE (BAS, BASR)
- BRANCH AND SAVE AND SET MODE (BASSM)
- BRANCH AND SET MODE (BSM)
- BRANCH AND STACK (BAKR)
- BRANCH ON CONDITION (BC, BCR)
- BRANCH ON COUNT (BCT, BCTR, BCTG, BCTGR)
- BRANCH ON INDEX HIGH (BXH, BXHG)
- BRANCH ON INDEX LOW OR EQUAL (BXLE, BXLEG)
- BRANCH RELATIVE ON CONDITION (BRC)
- BRANCH RELATIVE ON CONDITION LONG (BRCL)
- BRANCH RELATIVE ON COUNT (BRCT, BRCTG)
- BRANCH RELATIVE ON COUNT HIGH (BRCTH)
- BRANCH RELATIVE ON INDEX HIGH (BRXH, BRXHG)
- BRANCH RELATIVE ON INDEX LOW OR EQUAL (BRXLE, BRXLEG)
- COMPARE AND BRANCH (CRB, CGRB)
- COMPARE AND BRANCH RELATIVE (CRJ, CGRJ)
- COMPARE IMMEDIATE AND BRANCH (CIB, CGIB)
- COMPARE IMMEDIATE AND BRANCH RELATIVE (CIJ, CGIJ)
- COMPARE LOGICAL AND BRANCH (CLRB, CLGRB)
- COMPARE LOGICAL AND BRANCH RELATIVE (CLRJ, CLGRJ)
- COMPARE LOGICAL IMMEDIATE AND BRANCH (CLIB, CLGIB)
- COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (CLIJ, CLGIJ)

A breaking event is also considered to occur whenever one of the following instructions completes:
- BRANCH AND SET AUTHORITY (BSA)
- BRANCH IN SUBSPACE GROUP (BSG)
- BRANCH RELATIVE AND SAVE (BRAS)
- BRANCH RELATIVE AND SAVE LONG (BRASL)
- LOAD PSW (LPSW)
- LOAD PSW EXTENDED (LPSWE)
- PROGRAM CALL (PC)
- PROGRAM RETURN (PR)
- PROGRAM TRANSFER (PT)
- PROGRAM TRANSFER WITH INSTANCE (PTI)
- RESUME PROGRAM (RP)
- TRAP (TRAP2, TRAP4)

A breaking event is not considered to occur as a result of a transaction being aborted (either implicitly or as a result of the TRANSACTION ABORT instruction).
Timing

The timing facilities include three facilities for measuring time: the TOD clock, the clock comparator, and the CPU timer. A TOD programmable register is associated with the TOD clock.

In a multiprocessing configuration, a single TOD clock is shared by all CPUs. Each CPU has its own clock comparator, CPU timer, and TOD programmable register.

Time-of-Day Clock

The time-of-day (TOD) clock provides a high-resolution measure of real time suitable for the indication of date and time of day. The cycle of the clock is approximately 143 years. A single TOD clock is shared by all CPUs in the configuration.

Format

The TOD clock is a 104-bit register.

The TOD clock nominally is incremented by adding a one in bit position 51 every microsecond. In models having a higher or lower resolution, a different bit position is incremented at such a frequency that the rate of advancing the clock is the same as if a one were added in bit position 51 every microsecond. The resolution of the TOD clock is such that the incrementing rate is comparable to the instruction-execution rate of the model.

Figure 4-10 illustrates the format of the TOD clock and TOD-programmable field, and their relationship to the operands of the instructions that inspect or set them.

When incrementing of the clock causes a carry to be propagated out of bit position 0, the carry is ignored, and counting continues from zero. The program is not alerted, and no interruption condition is generated as a result of the overflow.

The operation of the clock is not affected by any normal activity or event in the system. Incrementing of the clock does not depend on whether the wait-state bit of the PSW is one or whether the CPU is in the operating, load, stopped, or check-stop state. Its operation is not affected by CPU, initial-CPU, or clear resets or by initial program loading. Operation of the clock is also not affected by the setting of the rate control or by an initial-machine-loading operation. Depending on the model and the configuration, the TOD clock may or may not be powered independent of the CPU.

States

The following states are distinguished for the TOD clock: set, not set, stopped, error, and not operational. The state determines the condition code set by execution of STORE CLOCK, STORE CLOCK EXTENDED, and STORE CLOCK FAST. The clock is incremented, and is said to be running, when it is in either the set state or the not-set state.
**Not-Set State:** When the power for the clock is turned on, the clock is set to zero, and the clock enters the not-set state. The clock is incremented when in the not-set state. When the TOD-clock-steering facility is installed, the TOD clock is never reported to be in the not-set state, as the TOD clock is placed in the set state as part of the initial-machine-loading (IML) process.

When the clock is in the not-set state, execution of STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST causes condition code 1 to be set and the current value of the running clock to be stored.

**Stopped State:** The clock enters the stopped state when SET CLOCK is executed and the execution results in the clock being set. This occurs when SET CLOCK is executed without encountering any exceptions and either any manual TOD-clock control in the configuration is set to the enable-set position or the TOD-clock-control-override control, bit 42 of control register 14, is one. The clock can be placed in the stopped state from the set, not-set, and error states. The clock is not incremented while in the stopped state.

When the clock is in the stopped state, execution of STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST causes condition code 3 to be set and the value of the stopped clock to be stored.

**Set State:** The clock enters the set state only from the stopped state. The change of state is under control of the TOD-clock-sync-control bit, bit 34 of control register 0, of the CPU which most recently caused the clock to enter the stopped state. If the bit is zero, the clock enters the set state at the completion of execution of SET CLOCK. If the bit is one, the clock remains in the stopped state until the bit is set to zero on that CPU or until another CPU executes a SET CLOCK instruction affecting the clock. If an external time reference (ETR) is installed, a signal from the ETR may be used to set the set state from the stopped state. When the system is not in the interpretive-execution mode, and an external time reference (ETR) is not attached to the configuration, the TOD-clock-sync control is treated as being zero, regardless of its actual value; in this case, the clock enters the set state and resumes incrementing upon completion of the instruction.

**Programmable Note:** The STP facility does not provide a signal that will cause the clock to transition from the stopped state to the set state. If SET CLOCK is executed when the configuration is in STP-timing mode and bit 34 of control register 0 is one, the clock remains in the stopped state until the bit is set to zero on that CPU or until another CPU executes a SET CLOCK instruction affecting the clock.

Incrementing of the clock begins with the first stepping pulse after the clock enters the set state.

When the clock is in the set state, execution of STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST causes condition code 0 to be set and the current value of the running clock to be stored.

**Error State:** The clock enters the error state when a malfunction is detected that is likely to have affected the validity of the clock value. It depends on the model whether the clock can be placed in this state. A timing-facility-damage machine-check-interruption condition is generated on each CPU in the configuration whenever the clock enters the error state. When the TOD-clock-steering facility is installed, the TOD clock is never reported to be in the error state. Errors in the TOD clock cause a system check stop.

When STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST is executed and the clock is in the error state, condition code 2 is set, and the value stored is zero.

**Not-Operational State:** The clock is in the not-operational state when its power is off or when it is disabled for maintenance. It depends on the model whether the clock can be placed in this state. Whenever the clock enters the not-operational state, a timing-facility-damage machine-check-interruption condition is generated on each CPU in the configuration. When the TOD-clock-steering facility is installed, the TOD clock is never reported to be in the not-operational state.

When the clock is in the not-operational state, execution of STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST causes condition code 3 to be set, and zero is stored.
**Programming Note:** When the TOD-clock-steering facility is installed, the TOD clock has only two states, the set state and the stopped state. Assuming proper operation by the operating system, problem programs are never dispatched while the TOD clock is in the stopped state. Thus, as observed by the problem program, the TOD clock is always in the set state and there is no need to test the condition code after issuing STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST.

**Changes in Clock State**

When the TOD-clock-steering facility is not installed, and the TOD clock changes value because of the execution of SET CLOCK or changes state, interruption conditions pending for the clock comparator and CPU timer may or may not be recognized for up to 1.048576 seconds (220 microseconds) after the change.

When the TOD-clock-steering facility is installed and SET CLOCK is issued, interruption conditions for the clock comparator and CPU timer may or may not be recognized while the physical clock is in the stopped state. After the physical clock enters the set state, interruption conditions for the clock comparator are not necessarily recognized until one of the following instructions is issued: SET CLOCK COMPARATOR (SCKC), STORE CLOCK (STCK), or STORE CLOCK EXTENDED (STCKE). After the physical clock enters the set state, interruption conditions for the CPU timer are not necessarily recognized until SET CPU TIMER (SPT) is issued. If a CPU is in the wait state when the physical clock is set or changes state, the CPU does not necessarily recognize interruption conditions for the clock comparator or CPU timer until after it leaves the wait state and the appropriate aforementioned instruction is executed.

When the TOD-clock-steering facility is installed and the logical TOD clock is changed by PTFF-ATO or PTFF-STO, interruption conditions for the clock comparator are not necessarily recognized until one of the following instructions is issued: SET CLOCK COMPARATOR (SCKC), STORE CLOCK (STCK), or STORE CLOCK EXTENDED (STCKE). If a CPU is in the wait state when the logical TOD clock is changed, the CPU may or may not recognize interruption conditions for the clock comparator until after it leaves the wait state and one of the aforementioned instructions is executed. The CPU timer and CPU-timer interruptions are not affected by PTFF-STO and PTFF-ATO.

The results of channel-subsystem-monitoring-facility operations may be unpredictable as a result of changes to the TOD clock.

**Setting and Inspecting the Clock**

The clock can be set to a specified value by execution of SET CLOCK if the manual TOD-clock control of any CPU in the configuration is in the enable-set position or the TOD-clock-control-override control, bit 42 of control register 14, is one. SET CLOCK sets bits of the clock with the contents of corresponding bit positions of a doubleword operand in storage.

Setting the clock replaces the values in all bit positions from bit position 0 through the rightmost position that is incremented when the clock is running. However, on some models, the rightmost bits starting at or to the right of bit 52 of the specified value are ignored, and zeros are placed in the corresponding positions of the clock. Zeros are also placed in positions to the right of bit position 63 of the clock.

The TOD clock can be inspected by executing STORE CLOCK or STORE CLOCK FAST, which causes bits 0-63 of the clock to be stored in an eight-byte operand in storage, or by executing STORE CLOCK EXTENDED, which causes bits 0-103 of the clock to be stored in bytes 1-13 of a 16-byte operand in storage. STORE CLOCK EXTENDED stores zeros in the leftmost byte, byte 0, of its storage operand, and it obtains the TOD programmable field from bit positions 16-31 of the TOD programmable register and stores it in byte positions 14 and 15 of the storage operand. Figure 4-10 on page 4-41 shows the format of the operands stored by STORE CLOCK, STORE CLOCK EXTENDED, and STORE CLOCK FAST.

At some time in the future, STORE CLOCK EXTENDED on new models will store a leftmost extension of the TOD clock in byte position 0 of its storage operand; see programming note 14 on page 4-47.

The following discussion of the results of STORE CLOCK, STORE CLOCK EXTENDED, and STORE CLOCK FAST assumes that the TOD clock is running and in the set state; TOD-clock values or portions thereof are considered to be unsigned binary integers.

- The values stored by any of the following sequence of instructions always correctly imply
the sequence of execution of these instructions by one or more CPUs for all cases where the sequence can be discovered by the program:

- Two executions of STORE CLOCK
- Two executions of STORE CLOCK EXTENDED
- An execution of STORE CLOCK followed by an execution of STORE CLOCK EXTENDED
- An execution of STORE CLOCK EXTENDED followed by an execution of STORE CLOCK

To ensure that unique values are obtained, non-zero values may be stored in positions to the right of the rightmost incremented bit position. When stored by STORE CLOCK EXTENDED, the value in bit positions 64-103 of the clock (bit positions 72-111 of the storage operand) is always nonzero; this ensures that values stored by STORE CLOCK EXTENDED are always unique when compared with values stored by STORE CLOCK, extended on the right with zeros.

For the purpose of establishing uniqueness and sequence of occurrence of the results of STORE CLOCK and STORE CLOCK EXTENDED, the 64-bit value provided by STORE CLOCK may be considered to be extended to a full 104-bit TOD value by appending 40 zeros on the right.

- Regardless of which instruction is executed first, STORE CLOCK and STORE CLOCK FAST executed on either the same or different CPUs do not necessarily return different values of the clock. The result of the second execution may be less than, equal to, or greater than that of the first execution.

- Two executions of STORE CLOCK FAST do not necessarily return different values of the clock. When executed on the same CPU, and in the absence of a carry out of bit position 0 of the TOD clock, the result of the second execution may be equal to or greater than that of the first execution. When executed on different CPUs in the same configuration, the result of the second execution may be less than, equal to, or greater than that of the first execution.

- Regardless of which instruction is executed first, STORE CLOCK EXTENDED and STORE CLOCK FAST executed on either the same or different CPUs do not necessarily return different values for the common TOD-clock bit positions stored by the instructions (that is, the entire 64-bit result of STORE CLOCK FAST as compared with bit positions 8-71 of the result of STORE CLOCK EXTENDED). When executed on the same CPU, and in the absence of a carry out of bit position 0 of the TOD clock, the result of the second execution may be either equal to or greater than that of the first execution. When executed on different CPUs in the same configuration, the result of the second execution may be less than, equal to, or greater than that of the first execution.

Figure 4-11 summarizes the interdependencies of the results of STCK, STCKE, and STCKF described above.

<table>
<thead>
<tr>
<th>First Execution by:</th>
<th>Result of Second Execution by: STCK</th>
<th>STCKE</th>
<th>STCKF</th>
</tr>
</thead>
</table>
| STCK                | A: >                               | A: > 1| A: <=>
| STCKE               | A: >1                              | A: > 2| S: =>2 |
| STCKF               | A: <=2                             | S: =>2| D: <=2 |

Explanation:

1. STCK results extended on the right with 40 binary zeros.
2. STCKF results compared with bits 8-71 of STCKE results.
<=
Result of the second execution may be less than, equal to, or greater than that of the first execution.
>
Result the second execution is greater than that of the first execution.
=>
Result of the second execution is equal to or greater than that of the first execution.
A:
First and second execution are on any CPU.
D:
First and second execution on different CPUs.
S:
First and second execution on the same CPU.

Figure 4-11. Interdependencies of the Results of STCK, STCKE, and STCKF
STORE CLOCK FAST instruction executed by another CPU may find the clock in the stopped state even when the TOD-clock-sync-control bit, bit 34 of control register 0, of each CPU is zero. Since the clock enters the set state before incrementing, the first STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST instruction executed after the clock enters the set state may still find the original value introduced by SET CLOCK.

**TOD Programmable Register**

Each CPU has a TOD programmable register. Bits 16-31 of the register contain the programmable field that is appended on the right to the TOD-clock value by STORE CLOCK EXTENDED. The register has the following format:

```
   0 1 6 3 1
```

The register is loaded by SET CLOCK PROGRAMMABLE FIELD. The contents of the register are reset to a value of all zeros by initial CPU reset.

**Programming Notes:**

1. Bit position 31 of the clock is incremented every 1.048576 seconds; for some applications, reference to the leftmost 32 bits of the clock may provide sufficient resolution.

2. Communication between systems is facilitated by establishing a standard time origin that is the calendar date and time to which a clock value of zero corresponds. January 1, 1900, 0 a.m. Coordinated Universal Time (UTC) is recommended as this origin, and it is said to begin the standard epoch for the clock. This is also the epoch used when the TOD clock is synchronized to the external time reference (ETR), and, for this reason, the epoch is sometimes referred to as ETR time. The former term, Greenwich Mean Time (GMT), is now obsolete and has been replaced with the more precise UTC.

3. Historically, one of the most important uses of standard time has been for navigation. Prior to 1972, standard time, then called GMT, was defined to have a variable-length second and was synchronized to within 100 milliseconds of the rotational position of the earth. Synchronization was accomplished by occasional changes in the length of the second, typically in parts per billion, and also by occasional insertion and deletion of small increments of time, typically 50 or 100 milliseconds. Beginning in 1972, a new standard time scale, called UTC, was defined to have a fixed-length second and be kept synchronized to within 900 milliseconds of the rotational position of the earth by means of occasional adjustments of exactly one second called a leap second. The change from GMT to UTC occurred between the last second of the day on December 31, 1971 and the first second of the day on January 1, 1972 and included insertion of 107.758 milliseconds in the standard time scale to make UTC exactly 10 seconds behind International Atomic Time (TAI). For reasons of simplicity in this document, the term UTC is sometimes extrapolated backward before 1972 by assuming no time adjustments in that time scale before 1972. For the same reasons, conversion between ETR time and UTC does not take into consideration the time adjustments prior to 1972, and, thus, ETR time differs from TAI by a fixed amount of 10 seconds. Coincident with the occurrence of the 26th leap second, UTC will be behind TAI by 36 seconds.

4. A program using the clock value as a time-of-day and calendar indication must be consistent with the programming support under which the program is to be executed. If the programming support uses the standard epoch, bit 0 of the clock remains one through the years 1972-2041. (Bit 0 turned on at 11:56:53.685248 (UTC) May 11, 1971.) Ordinarily, testing bit 0 for a one is sufficient to determine if the clock value is in the standard epoch.

5. In converting to or from the current date or time, the programming support must take into account that leap seconds have been inserted or deleted because of time-correction standards. When the TOD clock has been set correctly to a time within the standard epoch, the sum of the accumulated leap seconds must be subtracted from the clock time to determine UTC time.

6. Because of the limited accuracy of manually setting the clock value, the rightmost bit positions of the clock, expressing fractions of a second, are normally not valid as indications of the time of day. However, they permit elapsed-time measurements of high resolution.

7. The following chart shows the time interval between instants at which various bit positions of the TOD clock are stepped. This time value may
also be considered as the weighted time value that the bit, when one, represents.

<table>
<thead>
<tr>
<th>TOD-Clock Bit</th>
<th>Stepping Interval</th>
<th>Days</th>
<th>Hours</th>
<th>Min.</th>
<th>Seconds</th>
</tr>
</thead>
<tbody>
<tr>
<td>51</td>
<td>0.000 001</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>47</td>
<td>0.000 016</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>43</td>
<td>0.000 256</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>39</td>
<td>0.004 096</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>35</td>
<td>0.065 536</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>31</td>
<td>1.048 576</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>16.777 216</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>4 28.435 456</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>1 34.967 296</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>19 5 19.476 736</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>12 17 11.627 776</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>203 14 6.044 416</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>3257 19 36.710 656</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

8. The following chart shows the TOD clock setting for 00:00:00 (0 am), UTC time, for several dates: January 1, 1900, January 1, 1972, and for that instant in time just after each of the 26 leap seconds that will have occurred through July, 2015. Each of these leap seconds is inserted in the UTC time scale beginning at 23:59:60 UTC of the day previous to the one listed and ending at 00:00:00 UTC of the day listed.

<table>
<thead>
<tr>
<th>Year</th>
<th>Month</th>
<th>Day</th>
<th>Leap Sec.</th>
<th>Clock Setting (Hex)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1900</td>
<td>1</td>
<td>1</td>
<td>0000 0000</td>
<td>0000 0000 0000 0000</td>
</tr>
<tr>
<td>1972</td>
<td>1</td>
<td>1</td>
<td>8126 D60E</td>
<td>4600 0000 0000 0000</td>
</tr>
<tr>
<td>1972</td>
<td>7</td>
<td>1</td>
<td>820B A981</td>
<td>1E24 0000 0000 0000</td>
</tr>
<tr>
<td>1973</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>82F3 00AE E248 0000</td>
</tr>
<tr>
<td>1974</td>
<td>1</td>
<td>1</td>
<td>3</td>
<td>84BD E971 146C 0000</td>
</tr>
<tr>
<td>1975</td>
<td>1</td>
<td>1</td>
<td>4</td>
<td>8688 D233 4690 0000</td>
</tr>
<tr>
<td>1976</td>
<td>1</td>
<td>1</td>
<td>5</td>
<td>8853 BAf5 7B84 0000</td>
</tr>
<tr>
<td>1977</td>
<td>1</td>
<td>1</td>
<td>6</td>
<td>8A1F E595 2D88 0000</td>
</tr>
<tr>
<td>1978</td>
<td>1</td>
<td>1</td>
<td>7</td>
<td>88EA CE57 52FC 0000</td>
</tr>
<tr>
<td>1979</td>
<td>1</td>
<td>1</td>
<td>8</td>
<td>8D5B B719 8520 0000</td>
</tr>
<tr>
<td>1980</td>
<td>1</td>
<td>1</td>
<td>9</td>
<td>8F80 9FDB B744 0000</td>
</tr>
<tr>
<td>1981</td>
<td>1</td>
<td>1</td>
<td>10</td>
<td>9230 5C0F CD68 0000</td>
</tr>
<tr>
<td>1982</td>
<td>7</td>
<td>1</td>
<td>11</td>
<td>93F8 44D1 FF8C 0000</td>
</tr>
<tr>
<td>1983</td>
<td>7</td>
<td>1</td>
<td>12</td>
<td>95C6 2D94 31B0 0000</td>
</tr>
<tr>
<td>1985</td>
<td>7</td>
<td>1</td>
<td>13</td>
<td>995D 40F5 17D4 0000</td>
</tr>
<tr>
<td>1988</td>
<td>1</td>
<td>1</td>
<td>14</td>
<td>9DAA 69A5 57FB 0000</td>
</tr>
<tr>
<td>1990</td>
<td>1</td>
<td>1</td>
<td>15</td>
<td>A171 7D06 3E1C 0000</td>
</tr>
<tr>
<td>1991</td>
<td>1</td>
<td>1</td>
<td>16</td>
<td>A33C 65C8 7040 0000</td>
</tr>
</tbody>
</table>

9. The stepping value of TOD-clock bit position 63, if implemented, is $2^{12}$ microseconds, or approximately 244 picoseconds. This value is called a clock unit.

The following chart shows various time intervals in clock units expressed in hexadecimal notation.

<table>
<thead>
<tr>
<th>Interval</th>
<th>Clock Units (Hex)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 microsecond</td>
<td>1000</td>
</tr>
<tr>
<td>1 millisecond</td>
<td>3E 8000</td>
</tr>
<tr>
<td>1 second</td>
<td>F424 0000</td>
</tr>
<tr>
<td>1 minute</td>
<td>39 3870 0000</td>
</tr>
<tr>
<td>1 hour</td>
<td>D69 3A40 0000</td>
</tr>
<tr>
<td>1 day</td>
<td>1 41DD 7600 0000</td>
</tr>
<tr>
<td>365 days</td>
<td>1CA E8C1 3E00 0000</td>
</tr>
<tr>
<td>366 days</td>
<td>1CC 2A9E B400 0000</td>
</tr>
<tr>
<td>1,461 days*</td>
<td>72C E4E2 6E00 0000</td>
</tr>
</tbody>
</table>

Explanation:

* Number of days in four years, including a leap year. Note that the year 1900 was not a leap year. Thus, the four-year span starting in 1900 has only 1,460 days.

10. The charts in notes 7-9 are useful when examining the value stored by STORE CLOCK. Similar charts for use when examining the value stored by STORE CLOCK EXTENDED are in programming notes at the end of the definition of that instruction.

11. In a multiprocessing configuration, after the TOD clock is set and begins running, the program should delay activity for $2^{20}$ microseconds (1.048576 seconds) to ensure that the CPU-timer and clock-comparator interruption conditions are recognized by the CPU.

12. Due to the sequencing rules for the results of STORE CLOCK and STORE CLOCK EXTENDED, the execution of STORE CLOCK may be considerably slower than that of STORE
CLOCK EXTENDED and STORE CLOCK FAST. Depending on the model, the relative slowness of STORE CLOCK (as compared with STORE CLOCK EXTENDED and STORE CLOCK FAST) is particularly noticeable when multiple STORE CLOCK instructions are executed within a short period of time.

13. Uniqueness of TOD-clock values can be extended to apply to processors in separate configurations by including a configuration identification in the TOD programmable field.

14. At some time in the future, new models will use a carry from bit position 0 of the TOD clock to increment an additional eight-bit binary counter. STORE CLOCK EXTENDED will store the contents of this counter in byte position 0 of its storage operand. These actions will allow the TOD clock to continue to measure time within the standard epoch after the current 143-year limit caused by a carry from bit position 0 has been exceeded, and they will allow continued use of the clock comparator. It may be desired to have programs that process 16-byte STORE CLOCK EXTENDED operands take these future developments into account.

15. The results of STORE CLOCK FAST are intended to be approximately equivalent to either (a) the results of STORE CLOCK or (b) bits 8-71 of the results of STORE CLOCK EXTENDED. However, when compared with the results of STORE CLOCK or STORE CLOCK EXTENDED, the values returned by STORE CLOCK FAST do not necessarily indicate the correct sequence of execution of the instruction by one or more CPUs. STORE CLOCK FAST should not be used in programs where a monotonically increasing result is required.

TOD-Clock Synchronization

The following functions are provided if the configuration is part of an ETR network:

- A clock in the stopped state, with the TOD-clock-sync-control bit (bit 34 of control register 0) set to one, is placed in the set state and starts incrementing when an ETR signal occurs.
- The stepping rates for the TOD clock and the ETR are synchronized.
- Bits 32 through the rightmost incremented bit of a clock in the set state are compared with the same bits of the ETR. An unequal condition is signaled by an external-damage machine-check-interruption condition. The machine-check-interruption condition may not be recognized for up to 1.048576 seconds (2^20 microseconds) after the unequal condition occurs.

When the server timer protocol (STP) facility is installed, the timing mode, timing state and STP-clock-source state are defined as described below.

Timing Mode

The timing mode specifies the method by which the TOD clock is maintained for purposes of synchronization within a timing network. A TOD clock operates in one of the following timing modes:

Local Timing Mode: When the configuration is in local timing mode, the TOD clock has been initialized to a local time and is being stepped at the rate of the local hardware oscillator. The configuration is not part of a synchronized timing network.

ETR Timing Mode: When the configuration is in ETR-timing mode, the TOD clock has been initialized to the ETR and is being stepped by stepping signals from ETR. To be in ETR-timing mode, the configuration must be part of an ETR network.

STP Timing Mode: When the configuration is in STP-timing mode, the TOD clock has been initialized to coordinated server time (CST) and is being stepped at the rate of the local hardware oscillator. In STP timing mode, the TOD clock is steered so as to maintain, or attain, synchronization with CST. To be in STP-timing mode, the configuration must be part of an STP network.

Timing State

The timing state indicates the synchronization state of the TOD clock with respect to the timing network reference time.

Synchronized State: When a configuration is in the synchronized timing state, the TOD clock is in synchronization with the timing-network reference time as defined below:
• If the configuration is in ETR-timing mode, the configuration is synchronized with the ETR.

• If the configuration is in STP timing mode, the configuration is synchronized with coordinated server time (CST).

A configuration that is in the local-timing or uninitialized-timing mode is never in the synchronized state.

Unsynchronized State: When a configuration is in the unsynchronized timing state, the TOD clock is not in synchronization with the timing network reference time as defined below:

• If the configuration is in ETR-timing mode, the configuration has lost synchronization with the ETR.

• If the configuration is in STP timing mode, the configuration has lost or has not been able to attain synchronization with coordinated server time (CST). The configuration is out of synchronization with CST when the TOD clock differs from CST by an amount that exceeds a model-dependent STP-sync-check-threshold value.

Stopped State: When a configuration is in the stopped state, the TOD clock is either in the stopped state or TOD-clock recovery is in progress. After TOD-clock recovery completes, the TOD clock enters either the synchronized or unsynchronized state.

STP Clock Source State
The STP-clock-source state indicates whether a usable STP-clock source is available. The STP-clock source is used to determine the coordinated server time (CST) required to be able to synchronize the TOD clock.

Not Usable: The not-usable-STP-clock-source state indicates that a usable STP-clock source is not available to the STP facility. When a usable STP-clock source is not available, CST can not be determined.

Usable: The usable-STP-clock-source state indicates that a usable STP-clock source is available to the STP facility. When a usable STP-clock source is available, CST has been determined and can be used to synchronize the TOD clock to the STP network.

Programming Notes:
1. ETR TOD-clock synchronization provides for synchronizing and checking only bits 32 through the rightmost incremented bit of the TOD clock. Bits 0-31 of the TOD clock may be different from those of the ETR.

2. If the configuration is part of an ETR network, SET CLOCK must place all zeros in bit positions 32 through the rightmost incremented bit position of the TOD clock; otherwise, an external-damage machine-check-interruption condition will be recognized.

TOD-Clock Steering
TOD clock steering provides the means by which the TOD clock can be steered to maintain synchronization to a selected clock source. TOD clock steering is performed using one of the following steering mechanisms:

Offset-Based TOD-Clock Steering: The apparent stepping rate of the TOD clock is changed without changing the physical hardware oscillator which steps the physical clock. This is accomplished by means of a TOD offset register which is added to the physical clock to produce the TOD clock.

Hardware-Based TOD-Clock Steering: The stepping rate of the physical hardware oscillator is directly modifiable and provides the TOD clock frequency. A physical clock is made available via PTFF that is derived from the TOD clock in a manner that provides the appearance of a fixed-frequency physical clock. This is accomplished by means of a TOD-clock offset that is subtracted from the TOD clock to produce the physical clock.

When the STP-hardware-based-TOD-clock-steering facility is not installed, TOD-clock steering is performed using offset-based TOD-clock steering. When the STP-hardware-based-TOD-clock-steering facility is installed, steering is performed using hardware-based TOD-clock steering.

The steering method used by the CPU is transparent to all programs.

TOD-clock steering includes the semiprivileged instruction PERFORM TIMING FACILITY FUNCTION (PTFF), which is in the “E” format, provides a
7-bit function code in general register 0 and a parameter block address in general register 1.

The presence of the TOD-clock steering facility is indicated by bit 28 of the facility list, as stored by the STORE FACILITY LIST or STORE FACILITY LIST EXTENDED instructions. Facility-indication bit 28, when one indicates that the TOD-clock steering facility is installed. The instruction PERFORM TIMING FACILITY FUNCTION (PTFF) is installed only in the z/Architecture architectural mode. Steering, however, is not turned off if the machine is set back to ESA/390 mode.

The total steering rate is made up of two components, a fine-steering rate and a gross-steering rate.

The fine-steering rate is used to correct that inaccuracy in the local oscillator which is stable over a relatively long period of time. The value will normally be less than the specified tolerance of the local oscillator (typically ± 2.0 ppm), changes will occur infrequently (on the order of once per day to once per week), and changes will be small (typically less than ± 0.2 ppm).

The gross-steering rate is used as a dynamic correction for all other effects, the most predominate being to synchronize time with an external time source and with other clocks in the timing network. The value will normally change frequently (on the order of once per second to once per minute); and the value may range to more than ± 40 ppm.

TOD-clock steering includes the PTFF set-TOD-offset and set-TOD-offset-user control functions which allow a program to apply a TOD epoch difference to the TOD clock.

When the configuration is in STP timing mode, and the timing-control program detects an excessive offset between the system TOD and some reference clock, a new episode may be started with a step change to the TOD offset (see “Episodes” on page 4-50). This is however not visible to programs, as the epoch difference is adjusted in a complementary way. The epoch difference therefore consists of two components: a sync-check offset, and a user-specified epoch difference. A control program may request sync check notification, and subsequently request that its uncorrected sync check offset be corrected, resulting in a program-visible step in the TOD in a controlled manner.

TOD-clock steering also includes several query functions which may be used by the problem-state program to determine the quality of the TOD clock.

**Offset-Based TOD-Clock Steering Overview**

When the STP-hardware-based-TOD-clock-steering facility is not installed, offset-based TOD-clock steering is performed by computing a TOD-clock offset that is added to the physical clock to form the system TOD clock. Offset-based TOD-clock steering is accomplished by means of three values that are used to compute the TOD-clock offset: a start time (s), a base offset (b), and a steering rate (r).

The steering rate is a 32-bit signed binary fixed-point value and considered to be scaled by a factor of $2^{-44}$.

The start time is a 64-bit unsigned binary integer with a resolution equal to bit 63 of the TOD clock that is set to the physical clock start time for the current steering episode (see “Episodes” on page 4-50). The base offset is a 64-bit signed binary integer with a resolution equal to bit 63 of the TOD clock.

**Hardware-Based TOD-Clock-Steering Overview**

When the STP-hardware-based-TOD-clock-steering facility is installed, hardware-based steering of the TOD clock is accomplished by changing the stepping rate of the hardware oscillator. At the start of each steering episode, the hardware steering rate is set to a steering rate that reflects the current total steering rate for the configuration. At an episode start time, the TOD-clock base offset is updated to include the accumulated hardware steering for the previous (old) episode. The TOD-clock base offset is used to compute a current TOD-clock offset that is used to determine the physical clock at any given time. The conceptual steering parameters are the same as for offset-based TOD-clock steering: a start time (s), a base offset (b), and a steering rate (r) (see “Episodes” on page 4-50).

When hardware-based TOD-clock steering is installed, ETR steering does not apply.

**TOD-Offset-Update Events**

When the STP-hardware-based-TOD-clock-steering facility is not installed, the TOD offset is updated periodically rather than being computed continuously.
This update is referred to as a TOD-offset-update event. A TOD-offset-update event is triggered by the carry out of a bit position of the physical clock. The bit position depends on the model, but is chosen such that for normal steering rates, the difference between the values computed for the TOD offset (d) by consecutive TOD-offset-update events is less than the resolution of the TOD clock.

When the STP-hardware-based-TOD-clock-steering facility is installed, the steering rate can be viewed as being applied continuously. The TOD offset is calculated immediately, whenever it is needed; thus, there is no TOD-offset-update event.

Episodes

The three values, start time (s), base offset (b), and steering rate (r), define a linear steering adjustment which can be applied indefinitely. The duration that these values are applied without being changed is called an episode.

When the STP-hardware-based-TOD-clock-steering facility is not installed, a request by the timing-facility-control program to change the steering rate, the machine schedules a new episode to take effect at a future time. To provide a smooth transition, the machine schedules the start time for the new episode to be at the next TOD-offset-update event and computes a new base offset such that there will be no discontinuity in the value of the TOD offset at the instant the new values take effect.

When the STP-hardware-based-TOD-clock-steering facility is installed, a request by timing-facility-control program to change the steering rate, causes a new episode to begin immediately. A new base offset is computed such that there is no discontinuity in the value of the TOD offset at the instant the new values take effect.

The machine places the new values into special registers called new-episode start time (new.s), new-episode base offset (new.b), new-episode fine-steering rate (new.f), and new-episode gross-steering rate (new.g); and the previous contents of these four registers are preserved by placing them into registers called old-episode start time (old.s), old-episode base offset (old.b), old-episode fine-steering rate (old.f), and old-episode gross-steering rate (old.g), respectively. The machine continues to use the values for the old episode until the new-episode start time (new.s) and then automatically switches to use the values for the new episode. The registers in use at any particular instant in time are called current start time (s), current base offset (b), and current total steering rate (r). These are collectively referred to as the current-episode registers. Additionally, when the STP-hardware-based-TOD-clock-steering facility is installed, the hardware steering rate (hr) is set to a value that corresponds to the current steering rate in a model-dependent manner.

TOD-Clock-Steering Registers

Figure 4-12 summarizes the TOD-clock-steering registers. The contents of all TOD-clock-steering registers are initialized to zero by power-on reset, except

| Old-Episode Start Time (old.s) |
| Old-Episode Base Offset (old.b) |
| OEFS Rate (old.f) |
| OEGS Rate (old.g) |
| New-Episode Start Time (new.s) |
| New-Episode Base Offset (new.b) |
| NEFS Rate (new.f) |
| NEGS Rate (new.g) |
| Current Start Time (s) |
| Current Base Offset (b) |
| C Fine S Rate (f) |
| C Gross S Rate (g) |
| C Total S Rate (r) |
| TOD Offset (d) |

Figure 4-12. TOD-Clock-Steering Registers
for the user-specified-clock offset, whose initial value may be part of configuration information.

*Current Start Time (s)*: When the machine is operating in the old episode, the current start time is obtained from the old-episode start time (old.s); and when in the new episode, it is obtained from the new-episode start time (new.s). The current start time (s) is a 64-bit unsigned binary integer that has a resolution equal to bit 63 of the TOD clock.

*Current Base Offset (b)*: When the machine is operating in the old episode, the current base offset is obtained from the old-episode base offset (old.b); and when in the new episode, it is obtained from the new-episode base offset (new.b). The current base offset (b) is a 64-bit signed binary integer that has a resolution equal to bit 63 of the TOD clock.

*Current Steering Rates (f,g,r)*: When the machine is operating in the old episode, the current fine-steering rate (f) and current gross-steering rate (g) are obtained from the old-episode fine-steering rate (old.f) and gross-steering rate (old.g), respectively; when in the new episode, they are obtained from the new-episode fine-steering rate (new.f) and gross-steering rate (new.g), respectively.

The current total steering rate (r) is obtained from the sum of the current fine-steering rate (f) and the current gross-steering rate (g). A carry, if any, out of bit position 0, is ignored in this addition. The current total steering rate (r) is a 32-bit signed binary fixed-point value and considered to be scaled by a factor of $2^{-44}$.

*Programming Note*: Bits 0 and 31 of the steering-rate represent steering rates of $-2^{-13}$ and $2^{-44}$, respectively. Thus, steering rates of ±122 parts per million (10.5 seconds per day) may be specified with a precision of 4.9 nanoseconds per day.

*TOD Offset (d)*: The TOD offset (d) is a 64-bit signed binary integer with a resolution equal to bit 63 of the TOD clock.

When the STP-hardware-based-TOD-clock-steering facility is not installed, the contents of the TOD offset are added to the physical clock to obtain the system TOD clock. When the STP-hardware-based-TOD-clock-steering facility is installed, the contents of the TOD offset are subtracted from the system TOD clock to obtain the physical clock.

Depending on the model, rightmost bits of the TOD offset corresponding to bits beyond the resolution of the TOD clock may not be implemented and are treated as zeros.

**UTC Information Block (UIB)**

The UIB includes information to convert from a TOD clock timestamp to primary reference time (PRT) and then to convert PRT to UTC. The UIB can be inspected by executing **PERFORM TIMING FACILITY FUNCTION** specifying the PTFF-QUI (Query UTC Information) function. Conversion from TOD to PRT uses the TOD-to-PRT parameters and conversion from PRT to UTC uses the leap-second information.

The information in the UIB is provided by the server-time-protocol (STP) facility that also controls TOD-clock steering. When STP is not installed, all fields in the UIB are zero. STP manages a coordinated timing network (CTN) that provides the illusion of a single global TOD clock – known as coordinated server time (CST) – shared by several machines.

The format of the UIB is shown in Figure 4-13.
**Timing Mode (TM):** Bits 0-3 of byte 0 of the UIB contain a 4-bit code indicating the timing mode of the system. The codes are defined as follows:

<table>
<thead>
<tr>
<th>Code</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Local Timing Mode</td>
</tr>
<tr>
<td>1</td>
<td>ETR Timing Mode</td>
</tr>
<tr>
<td>2</td>
<td>STP Timing Mode</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Timing State:** Bits 4-7 of byte 0 of the UIB contain a 4-bit code indicating the timing state of the system. The codes are defined as follows:

<table>
<thead>
<tr>
<th>Code</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Unsynchronized</td>
</tr>
<tr>
<td>1</td>
<td>Synchronized</td>
</tr>
<tr>
<td>2-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Leap Second Information:** Three fields in the UIB provide information for converting from primary reference time to UTC. These are the leap-second-event time, old-leap-seconds, and new-leap-seconds fields. For a primary reference time less than the leap-second-event time, the old-leap-seconds value applies; for a primary reference time equal to or greater than the leap-second-event time, the new-leap-seconds value applies. The applicable leap-second value is subtracted from the primary reference time (PRT) to form UTC.

**Leap Second Event Time:** Bytes 8-15 of the UIB, when valid, contain a 64-bit time in TOD-clock timestamp format that specifies the primary reference time at which the new-leap-seconds is to take effect.

**Old Leap Seconds:** Bytes 16-17 of the UIB contain a 16-bit signed binary integer indicating the number of leap seconds in effect prior to the leap-second-event time. Thus, when the leap-second-event time is nonzero, the old-leap-seconds value is in effect for a primary reference time less than the leap-second-event time. When the leap-second-event time is zero, no change has been scheduled, and the old-leap-seconds and new-leap-seconds fields contain the same value. The value is provided in seconds with the low-order bit equaling one second.

**New Leap Seconds:** Bytes 18-19 of the UIB contain a 16-bit signed binary integer indicating the number of leap seconds in effect for a primary reference time equal to or greater than the leap-second-event time. The value is provided in seconds with the low-order bit equaling one second.

**PRT Timestamp:** Bytes 24-31 of the UIB, when valid, contain a 64-bit value timestamp that specifies the time at which the primary-reference-time (PRT) parameters (PRT dispersion, PRT offset, PRT-correction-steering-start time, and PRT-correction time) were last updated within the CTN. This field has the same format as bits 0-63 of the TOD clock. The PRT-update-event-time field is valid only when it is nonzero.

**PRT Dispersion:** Bytes 32-39 of the UIB, when valid, contain a 64-bit unsigned binary integer indicating the total maximum possible dispersion of the PRT offset provided at the most recent PRT-update event. This field has the same format as bits 0-63 of the TOD clock. The PRT-dispersion field is valid only when the PRT-timestamp field is nonzero.

**PRT Offset:** Bytes 40-47 of the UIB, when valid, contain a 64-bit signed binary integer indicating the PRT offset provided for the most recent PRT information. This field has the same format as bits 0-63 of the TOD clock. The value is the amount to be added to the system TOD to match the estimated time at the primary-reference time source. The margin of error of this value is equal to the PRT dispersion.

**PRT Correction Steering Start Time:** Bytes 48-55 of the UIB, when valid, contain a 64-bit timestamp having the same format as bits 0-63 of the TOD clock and indicating the time at which PRT-correction steering is to be, or has been, initiated within the CTN. A value of zero indicates that no PRT correction was planned at the time when the UIB was last updated.

**PRT Correction Time:** Bytes 56-63 of the UIB, when valid, contain a 64-bit unsigned binary integer indicating the estimated amount of time required to correct the PRT offset which is the amount of time.
PRT-correction will be in effect. This field has the same format as bits 0-63 of the TOD clock. The field is valid when the PRT-correction-steering-start time is nonzero.

**CST Reference Time:** Bytes 64-71 of the UIB, when valid, contain a 64-bit value in TOD-clock timestamp format indicating the value of the system TOD clock at the most recent time that the CST parameters (CST-TOD dispersion and CST offset) were updated. The field is valid when it is nonzero.

**CST-TOD Dispersion:** Bytes 72-79 of the UIB, when valid, contain a 64-bit unsigned binary integer indicating the CST-TOD dispersion computed at the most recent CST parameter update. The value has a resolution equal to bit 63 of the TOD clock. The CST-TOD-dispersion field is valid when the CST-reference-time field is nonzero.

**CST Offset:** Bytes 80-87 of the UIB, when valid, contain a 64-bit signed binary value that indicates the offset of the system TOD clock to the TOD clock at the machine selected as the time source. The CST offset is added to the system-TOD clock to form the Coordinated Server Time (CST) at the machine. For the add operation, a carry out of bit 0 is ignored. Bit 63 of the CST offset has a resolution equal to that of bit 63 of the TOD clock. The CST-offset field is valid when the CST-reference-time field is nonzero. For stratum-1 servers, the field is set to zero (by definition, CST is the system TOD at the stratum-1 server).

**Maximum Unknown Skew Rate:** Bytes 88-91 of the UIB, when valid, contain a 32-bit unsigned binary integer indicating the absolute value of the unknown skew rate of the physical clock. The value has a resolution of one part per $2^{34}$. The maximum-skew-rate field is valid when it is nonzero.

**Clock Comparator**

The clock comparator provides a means of causing an interruption when the TOD-clock value exceeds a value specified by the program.

In a configuration with more than one CPU, each CPU has a separate clock comparator.

The clock comparator has the same format as bits 0-63 of the TOD clock. The clock comparator nominally consists of bits 0-47, which are compared with the corresponding bits of the TOD clock. In some models, higher resolution is obtained by providing more than 48 bits. The bits in positions provided in the clock comparator are compared with the corresponding bits of the clock. When the resolution of the clock is less than that of the clock comparator, the contents of the clock comparator are compared with the clock value as this value would be stored by executing STORE CLOCK or STORE CLOCK FAST.

The clock comparator causes an external interruption with the interruption code 1004 hex. When the TOD-clock-steering facility is not installed, a request for a clock-comparator interruption exists whenever either of the following conditions exists:

1. The TOD clock is running and the value of the clock comparator is less than the value in the compared portion of the clock, both values being considered unsigned binary integers. Comparison follows the rules of unsigned binary arithmetic.

2. The TOD clock is in the error state or the not-operational state.

When the TOD-clock-steering facility is installed, a request for a clock-comparator interruption exists whenever the physical clock is in the set state and the value of the clock comparator is less than the value in the compared portion of the logical TOD clock, both values being considered unsigned binary integers. Comparison follows the rules of unsigned binary arithmetic.

A request for a clock-comparator interruption does not remain pending when the value of the clock comparator is made equal to or greater than that of the logical TOD clock or when the value of the logical TOD clock is made less than the clock-comparator value. The latter may occur as a result of the physical clock or logical TOD clock being set or the logical TOD clock wrapping to zero.

The clock comparator can be inspected by executing the instruction STORE CLOCK COMPARATOR and can be set to a specified value by executing the SET CLOCK COMPARATOR instruction.

The contents of the clock comparator are initialized to zero by initial CPU reset.
Programming Notes:

1. An interruption request for the clock comparator persists as long as the clock-comparator value is less than that of the TOD clock or as long as the TOD clock is in the error state or the not-operational state. Therefore, one of the following actions must be taken after an external interruption for the clock comparator has occurred and before the CPU is again enabled for external interruptions: the value of the clock comparator must be replaced, the TOD clock must be set, the TOD clock must wrap to zero, or the clock-comparator-subclass mask must be set to zero. Otherwise, loops of external interruptions are formed.

2. The instruction STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST may store a value which is greater than that in the clock comparator, even though the CPU is enabled for the clock-comparator interruption. This is because the TOD clock may be incremented one or more times between when instruction execution is begun and when the clock value is accessed. In this situation, the interruption occurs when the execution of STORE CLOCK, STORE CLOCK EXTENDED, or STORE CLOCK FAST is completed.

CPU Timer

The CPU timer provides a means for measuring elapsed CPU time and for causing an interruption when a specified amount of time has elapsed.

In a configuration with more than one CPU, each CPU has a separate CPU timer.

The CPU timer is a binary counter with a format which is the same as that of bits 0-63 of the TOD clock, except that bit 0 is considered a sign. The CPU timer nominally is decremented by subtracting a one in bit position 51 every microsecond. In models having a higher or lower resolution, a different bit position is decremented at such a frequency that the rate of decrementing the CPU timer is the same as if a one were subtracted in bit position 51 every microsecond. The resolution of the CPU timer is such that the stepping rate is comparable to the instruction-execution rate of the model.

The CPU timer requests an external interruption with the interruption code 1005 hex whenever the CPU-timer value is negative (bit 0 of the CPU timer is one). The request does not remain pending when the CPU-timer value is changed to a nonnegative value.

When the TOD-clock-steering facility is not installed, and both the CPU timer and the TOD clock are running, the stepping rates are synchronized such that both are stepped at the same rate.

When the TOD-clock-steering facility is installed and the STP-hardware-based-TOD-clock-steering facility is not installed, the CPU timer and TOD clock do not necessarily step at the same rate and may differ by as much as the maximum steering rate. When the TOD-clock-steering facility is installed and the STP-hardware-based-TOD-clock-steering facility is installed, the CPU timer and TOD clock step at the same rate.

Normally, decrementing the CPU timer is not affected by concurrent I/O activity. However, in some models the CPU timer may stop during extreme I/O activity and other similar interference situations. In these cases, the time recorded by the CPU timer provides a more accurate measure of the CPU time used by the program than would have been recorded had the CPU timer continued to step.

The CPU timer is decremented when the CPU is in the operating state or the load state. When the manual rate control is set to instruction step, the CPU timer is decremented only during the time in which the CPU is actually performing a unit of operation. However, depending on the model, the CPU timer may be decremented when the TOD clock is in the error, stopped, or not-operational state.

Depending on the model, the CPU timer may or may not be decremented when the CPU is in the checkstop state.

The CPU timer can be inspected by executing the privileged instruction STORE CPU TIMER and can be set to a specified value by executing the privileged SET CPU TIMER instruction. The general instruction EXTRACT CPU TIME may be used in determining the amount of CPU time consumed by a task.

Depending on the model, the value of the CPU timer stored by an execution of STORE CPU TIMER may be the same as the value stored by a subsequent execution of STORE CPU TIMER on the same CPU.
The CPU timer is set to zero by initial CPU reset.

Programming Notes:

1. The CPU timer in association with a program may be used both to measure CPU-execution time and to signal the end of a time interval on the CPU.

2. The time measured for the execution of a sequence of instructions may depend on the effects of such things as I/O interference, the availability of pages, and instruction retry. Therefore, repeated measurements of the same sequence on the same installation may differ.

3. The fact that a CPU-timer interruption does not remain pending when the CPU timer is set to a positive value eliminates the problem of an undesired interruption. This would occur if, between the time when the old value is stored and a new value is set, the CPU is disabled for CPU-timer interruptions and the CPU timer value goes from positive to negative.

4. The fact that CPU-timer interruptions are requested whenever the CPU timer is negative (rather than just when the CPU timer goes from positive to negative) eliminates the requirement for testing a value to ensure that it is positive before setting the CPU timer to that value.

As an example, assume that a program being timed by the CPU timer is interrupted for a cause other than the CPU timer, external interruptions are disallowed by the new PSW, and the CPU-timer value is then saved by STORE CPU TIMER. This value could be negative if the CPU timer went from positive to negative since the interruption. Subsequently, when the program being timed is to continue, the CPU timer may be set to the saved value by SET CPU TIMER. A CPU-timer interruption occurs immediately after external interruptions are again enabled if the saved value was negative.

The persistence of the CPU-timer-interruption request means, however, that after an external interruption for the CPU timer has occurred, the value of the CPU timer must be replaced, the value in the CPU timer must wrap to a positive value, or the CPU-timer-subclass mask must be set to zero before the CPU is again enabled for external interruptions. Otherwise, loops of external interruptions are formed.

Although an initial CPU reset causes the CPU timer to be set to zero, it also clears the CPU-timer enablement mask (bit 53 of control register 0). Thus, even if an IPL-new PSW is enabled for external interruptions, a CPU-timer interruption will not immediately occur.

5. The instruction STORE CPU TIMER may store a negative value even though the CPU is enabled for the interruption. This is because the CPU-timer value may be decremented one or more times between when instruction execution is begun and when the CPU timer is accessed. In this situation, the interruption occurs when the execution of STORE CPU TIMER is completed.

Externally Initiated Functions

Resets

Five reset functions are provided:

- CPU reset
- Initial CPU reset
- Subsystem reset
- Clear reset
- Power-on reset

CPU reset provides a means of clearing equipment-check indications and any resultant unpredictability in the CPU state with the least amount of information destroyed. In particular, it is used to clear check conditions when the CPU state is to be preserved for analysis or resumption of the operation. If a CPU reset is caused by the activation of the load-normal or load-with-dump key, (a) it sets the architectural mode to the ESA/390 mode, and (b) if the multi-threading facility is installed and enabled, it is disabled. When CPU reset sets the ESA/390 mode, it saves the current PSW so that PSW can be restored by a SIGNAL PROCESSOR set-architecture order that changes the architectural mode back to z/Archi-
tecture. See “CPU Reset” on page 4-58 for details.

Initial CPU reset provides the functions of CPU reset together with initialization of the current PSW, CPU timer, clock comparator, and the following registers: breaking-event-address, captured-z/Architecture-PSW, control, floating-point-control, prefix, and TOD programmable registers. Initial CPU reset sets the architectural mode to the ESA/390 mode if it is caused by activation of the load-normal or load-with-dump key. If multithreading is enabled when initial CPU reset is caused by activation of the load-normal or load-with-dump key, the initial-CPU-reset functions are performed for the lowest-numbered CPU of a core, and CPU reset is performed for all other CPUs in the core.

Subsystem reset provides a means for clearing floating interruption conditions as well as for invoking I/O-system reset.

Clear reset causes initial CPU reset and subsystem reset to be performed and, additionally, clears or initializes all storage locations and registers in all CPUs in the configuration, with the exception of the TOD clock. Such clearing is useful in debugging programs and in ensuring user privacy. Clear reset also releases all locks used by the PERFORM LOCKED OPERATION instruction. Clear reset sets the architectural mode to the ESA/390 mode. Clearing does not affect external storage, such as direct-access storage devices used by the control program to hold the contents of unaddressable pages.

CPU power-on reset causes initial CPU reset to be performed and clears the contents of general registers, access registers, floating-point registers, and vector registers to zeros with valid checking-block code. Locks used by PERFORM LOCKED OPERATION and associated with the CPU are released unless they are held by a CPU already powered on. The power-on-reset sequences for the TOD clock, main storage, and the channel subsystem may be included as part of the CPU power-on sequence, or the power-on sequence for these units may be initiated separately. If CPU power-on reset establishes the configuration, it sets the architectural mode to the ESA/390 mode; otherwise, it sets the architectural mode to that of the CPUs already in the configuration.

CPU reset, initial CPU reset, subsystem reset, and clear reset may be initiated manually by using the operator facilities (see Chapter 12, “Operator Facilities”). Initial CPU reset is part of the initial-program-loading function. Figure 4-14 on page 4-56 summarizes how these four resets are manually initiated. Power-on reset is performed as part of turning power on. The reset actions are tabulated in Figure 4-15 on page 4-57. For information concerning which resets can be performed by the SIGNAL PROCESSOR instruction, see “Signal-Processor Orders” on page 4-64.

<table>
<thead>
<tr>
<th>Key Activated</th>
<th>Function Performed on1</th>
<th>CPU on Which Key Was Activated</th>
<th>Other CPUs in Config.</th>
<th>Remainder of Config.</th>
</tr>
</thead>
<tbody>
<tr>
<td>System-reset-normal key</td>
<td>CPU reset</td>
<td>CPU reset</td>
<td>Subsystem reset</td>
<td></td>
</tr>
<tr>
<td>System-reset-clear key</td>
<td>Clear reset2</td>
<td>Clear reset2</td>
<td>Clear reset3</td>
<td></td>
</tr>
<tr>
<td>Load-normal or load-with-dump key</td>
<td>Initial CPU reset4, followed by IPL</td>
<td>CPU reset</td>
<td>Subsystem reset</td>
<td></td>
</tr>
<tr>
<td>Load-clear or load-clear-list-directed key</td>
<td>Clear reset2, followed by IPL</td>
<td>Clear reset2</td>
<td>Clear reset3</td>
<td></td>
</tr>
</tbody>
</table>

Explanation:

1 Activation of a system-reset or load key may change the configuration, including the connection with I/O, storage units, and other CPUs.
2 Only the CPU elements of this reset apply.
3 Only the non-CPU elements of this reset apply.
4 When multithreading is enabled, initial CPU reset applies only to the lowest-numbered CPU of a core; CPU reset applies to all other CPUs of the core.

Figure 4-14. Manual Initiation of Resets
### Explanation:

# If the architectural mode is changed from z/Architecture to ESA/390 (the reset is due to activation of the load-normal key on another CPU), the 16-byte PSW first is placed in the captured-z/Architecture-PSW register, and then does not remain unchanged. Instead, it is changed to an eight-byte PSW, and the bits of the eight-byte PSW are set as follows. Bits 0-11 and 13-32 are set equal to the same bits of the 16-byte PSW, bit 12 is set to one, and bits 33-63 are set equal to bits 97-127 of the 16-byte PSW. The PSW is invalid in the ESA/390 mode if PSW bit 31 is one.

* Clearing the contents of the PSW to zero causes the PSW to be invalid if the architectural mode is ESA/390.

1 When the IPL sequence follows the reset function on that CPU, the CPU does not necessarily enter the stopped state, and the PSW is not necessarily cleared to zeros.

2 When these units are separately powered, the action is performed only when the power for the unit is turned on.

3 Access to change expanded storage at the time a reset function is performed may cause the contents of the 4K-byte block in expanded storage to be unpredictable. Access to examine expanded storage does not affect the contents of the expanded storage.

4 Access to the TOD clock by means of STORE CLOCK at the time a reset function is performed does not cause the value of the TOD clock to be affected.

5 When the channel subsystem is separately powered or consists of multiple elements which are separately powered, the reset action is applied only to those subchannels, channel paths, and I/O control units and devices on those paths associated with the element which is being powered on.

C The condition or contents are cleared. If the area affected is a field, the contents are set to zero with valid checking-block code.

### Figure 4-15. Summary of Reset Actions (Part 1 of 2)
CPU Reset

CPU reset causes the following actions:

1. The execution of the current instruction or other processing sequence, such as an interruption, is terminated, and all program-interruption and supervisor-call-interruption conditions are cleared.

2. If the CPU was in the transactional-execution mode, the transaction nesting depth is set to zero, and the CPU leaves the transactional-execution mode.

3. Any pending external-interruption conditions which are local to the CPU are cleared. Floating external-interruption conditions are not cleared.

4. Any pending machine-check-interruption conditions and error indications which are local to the CPU and any check-stop states are cleared. Floating machine-check-interruption conditions are not cleared. Any machine-check condition which is reported to all CPUs in the configuration and which has been made pending to a CPU is said to be local to the CPU.

5. All copies of prefetched instructions or operands are cleared. Additionally, any results to be stored because of the execution of instructions in the current checkpoint interval are cleared.

6. The ART-lookaside buffer and translation-lookaside buffer are cleared of entries.

7. If the reset is caused by activation of the load-normal or load-with-dump key on any CPU in the configuration, the following actions occur:

   a. The current PSW is saved for subsequent use by a SIGNAL PROCESSOR set-architecture order that restores the z/Architecture mode.

   b. If the configuration is enabled for multithreading, the following actions occur:

      1) CPU address contraction is performed as described on page 4-64.
2) Multithreading is disabled.

c. The architectural mode of the CPU (and of all other CPUs in the configuration because of the initial CPU reset or CPU resets performed by them) is changed from the z/Architecture mode to the ESA/390 mode.

The current PSW is changed from 16 bytes to eight bytes. The bits of the eight-byte PSW are set as follows: bits 0-11 and 13-32 are set equal to the same bits of the 16-byte PSW, bit 12 is set to one, and bits 33-63 are set equal to bits 97-127 of the 16-byte PSW.

A CPU reset caused by activation of the system-reset-normal key or by the SIGNAL PROCESSOR CPU-reset order, and any CPU reset in the ESA/390 mode, do not affect the captured-z/Architecture-PSW register or the enablement of the multithreading facility.

8. The CPU is placed in the stopped state after actions 1-7 have been completed. When the CCW-type IPL sequence follows the reset function on that CPU, the CPU enters the load state at the completion of the reset function and does not necessarily enter the stopped state during the execution of the reset operation. When the list-directed IPL sequence follows the reset function on that CPU, the CPU enters the operating state and does not necessarily enter the stopped state during the execution of the reset operation.

Registers, storage contents, and the state of conditions external to the CPU remain unchanged by CPU reset. However, the subsequent contents of the register, location, or state are unpredictable if an operation is in progress that changes the contents at the time of the reset. A lock held by the CPU when executing PERFORM LOCKED OPERATION is not released by CPU reset.

When the reset function in the CPU is initiated at the time the CPU is executing an I/O instruction or is performing an I/O interruption, the current operation between the CPU and the channel subsystem may or may not be completed, and the resultant state of the associated channel-subsystem facility may be unpredictable.

Programming Notes:

1. Most operations which would change a state, a condition, or the contents of a field cannot occur when the CPU is in the stopped state. However, some signal-processor functions and some operator functions may change these fields. To eliminate the possibility of losing a field when CPU reset is issued, the CPU should be stopped, and no operator functions should be in progress.

2. If the architectural mode is changed to the ESA/390 mode and bit 31 of the current PSW is one, the PSW is invalid.

Initial CPU Reset

Initial CPU reset combines the CPU reset functions with the following clearing and initializing functions:

1. If the reset is caused by activation of the load-normal or load-with-dump key, (a) if the multithreading facility is enabled, CPU address contraction is performed and the multithreading facility is disabled, and (b) the architectural mode of the CPU (and of all other CPUs in the configuration) is set to the ESA/390 mode.

2. The contents of the current PSW, captured-z/Architecture-PSW, prefix, CPU timer, clock comparator, and TOD programmable register are set to zero. When the IPL sequence follows the reset function on that CPU, the contents of the PSW are not necessarily set to zero.

3. The contents of the control registers are set to their initial z/Architecture values. All 64 bits of the control registers are set regardless of whether the CPU is in the ESA/390 or the z/Architecture architectural mode.

4. The contents of the floating-point-control register are set to zero.

5. The contents of the breaking-event-address register are initialized to 00000000000000001 hex.

These clearing and initializing functions include validation.

Setting the current PSW to zero when the CPU is in the ESA/390 architectural mode at the end of the operation causes the PSW to be invalid, since PSW bit 12 must be one in that mode. Thus, in this case if the CPU is placed in the operating state after a reset without first introducing a new PSW, a specification exception is recognized.

Programming Note: When the multithreading facility is installed and enabled, an initial-CPU reset that is
caused by the execution of a SIGP initial-CPU-reset order does not cause multithreading to be disabled.

Subsystem Reset
Subsystem reset operates only on those elements in the configuration which are not CPUs. It performs the following actions:

1. I/O-system reset is performed by the channel subsystem (see “I/O-System Reset” on page 17-13).
2. All floating interruption conditions in the configuration are cleared.
3. The warning-track-interruption facility is unregistered.

As part of I/O-system reset, pending I/O-interruption conditions are cleared, and system reset is signaled to all control units and devices attached to the channel subsystem (see “I/O-System Reset” on page 17-13). The effect of system reset on I/O control units and devices and the resultant control-unit and device state are described in the appropriate System Library publication for the control unit or device. A system reset, in general, resets only those functions in a shared control unit or device that are associated with the particular channel path signaling the reset.

Clear Reset
Clear reset combines the initial-CPU-reset function with an initializing function which causes the following actions:

1. If the multithreading facility is enabled, CPU address contraction is performed and the multithreading facility is disabled.
2. The architectural mode of all CPUs in the configuration is set to the ESA/390 mode.
3. The access, general, floating-point, and vector registers of all CPUs in the configuration are set to zero. All 64 bits of the general registers and all 128 bits of the vector registers are set to zero regardless of whether the CPU was in the ESA/390 or z/Architecture architectural mode when the clear-reset function was initiated.
4. The contents of the main storage in the configuration and the associated storage keys are set to zero with valid checking-block code.
5. The locks used by any CPU in the configuration when executing the PERFORM LOCKED OPERATION instruction are released.
6. A subsystem reset is performed.
7. A new set of wrapping keys and their associated verification patterns are generated.

Validation is included in setting registers and in clearing storage and storage keys.

Programming Notes:

1. The architectural mode is not changed by activation of the system-reset-normal key or by execution of a SIGNAL PROCESSOR CPU-reset or initial-CPU-reset order. All CPUs in the configuration are always in the same architectural mode.
2. For the CPU-reset operation not to affect the contents of fields that are to be left unchanged, the CPU must not be executing instructions and must be disabled for all interruptions at the time of the reset. Except for the operation of the CPU timer and for the possibility of a machine-check interruption occurring, all CPU activity can be stopped by placing the CPU in the wait state and by disabling it for I/O and external interruptions. To avoid the possibility of causing a reset at the time that the CPU timer is being updated or a machine-check interruption occurs, the CPU must be in the stopped state.
3. CPU reset, initial CPU reset, subsystem reset, and clear reset do not affect the value and state of the TOD clock.
4. The conditions under which the CPU enters the check-stop state are model-dependent and include malfunctions that preclude the completion of the current operation. Hence, if CPU reset or initial CPU reset is executed while the CPU is in the check-stop state, the contents of the PSW, registers, and storage locations, including the storage keys and the storage location accessed at the time of the error, may have unpredictable values, and, in some cases, the contents may still be in error after the check-stop state is cleared by these resets. In this situation, a clear reset is required to clear the error.
Power-On Reset
The power-on-reset function for a component of the machine is performed as part of the power-on sequence for that component.

The power-on sequences for the TOD clock, main storage, expanded storage, and channel subsystem may be included as part of the CPU power-on sequence, or the power-on sequence for these units may be initiated separately. The following sections describe the power-on resets for the CPU, TOD clock, TOD-clock-steering registers, main storage, expanded storage, and channel subsystem. See also “I/O Support Functions” on page 17-1, and the appropriate System Library publication for the channel subsystem, control units, and I/O devices.

CPU Power-On Reset: The power-on reset causes initial CPU reset to be performed and may or may not cause I/O-system reset to be performed in the channel subsystem. The contents of general registers, access registers, floating-point registers, and vector registers are cleared to zeros with valid checking-block code. Locks used by PERFORM LOCKED OPERATION and associated with the CPU are released unless they are held by a CPU already powered on. If the reset is associated with establishing a configuration, the CPU is placed in the ESA/390 mode; otherwise, the CPU is placed in the architectural mode of the CPUs already in the configuration, and the CPU address is expanded if the multithreading facility is already enabled in the configuration.

TOD-Clock Power-On Reset: The power-on reset causes the value of the TOD clock to be set to zero with valid checking-block code and causes the clock to enter the not-set state. When the TOD-clock-steering facility is installed, the TOD clock is never reported to be in the not-set state, as the TOD clock is placed in the set state as part of the initial-machine-loading (IML) process.

TOD-Clock-Steering-Registers Power-On Reset: The power-on reset causes the value of the TOD-clock-steering registers to be set to zero with valid checking-block code.

Main-Storage Power-On Reset: For volatile main storage (one that does not preserve its contents when power is off) and for storage keys, power-on reset causes zeros with valid checking-block code to be placed in these fields. The contents of nonvolatile main storage, including the checking-block code, remain unchanged.

Expanded-Storage Power-On Reset: The contents of expanded storage are cleared to zeros with valid checking-block code.

Channel-Subsystem Power-On Reset: The channel-subsystem power-on reset causes I/O-system reset to be performed in the channel subsystem. (See “I/O-System Reset” on page 17-13.)

Initial Program Loading
Initial program loading (IPL) provides a manual means for causing a program to be read from a designated device and for initiating execution of that program.

Some models may provide additional controls and indications relating to IPL; this additional information is specified in the System Library publication for the model.

There are two types of IPL: CCW-type IPL and list-directed IPL. CCW-type IPL is provided by all machine configurations. List-directed IPL may be provided, depending on the model.

CCW-type IPL is described below. List-directed IPL is described in “List-Directed IPL” on page 17-19.

CCW-Type IPL
CCW-type IPL is initiated manually by setting the load-unit-address controls to a four-digit number to designate an input device and by subsequently activating the load-clear or load-normal key. On some models, load-normal and load-clear keys are provided for each primary CPU in the configuration. On other models, a single load-normal and load-clear key are provided for the entire configuration, and apply to the lowest-numbered primary online CPU that is not in the check-stop state. In the description which follows, the term “this CPU” refers to either (a) the CPU in the configuration for which the load-clear load-normal key was activated or (b) the lowest-numbered online primary CPU (as described above). When the multithreading facility is enabled, “this CPU” refers to the CPU which results from CPU address contraction (“CPU-Address Contraction” on page 4-64).

Activating the load-clear key causes a clear reset to be performed on the configuration.
Activating the load-normal key causes an initial CPU reset to be performed on this CPU, a CPU reset to be propagated to all other CPUs in the configuration, and a subsystem reset to be performed on the remainder of the configuration.

Activating the load-clear key or the load-normal key sets the architectural mode to the ESA/390 mode. For ease of reference, the additional elements of the description of ESA/390 initial program loading are given below.

In the loading part of the operation, after the resets have been performed, this CPU then enters the load state. This CPU does not necessarily enter the stopped state during the execution of the reset operations. The load indicator is on while the CPU is in the load state.

Subsequently, a channel-program read operation is initiated from the I/O device designated by the load-unit-address controls. The effect of executing the channel program is as if a format-0 CCW beginning at absolute storage location 0 specified a read command with the modifier bits zeros, a data address of zero, a byte count of 24, the chain-command and SLI flags ones, and all other flags zeros.

The details of the channel-subsystem portion of the IPL operation are defined in “Initial Program Loading” on page 17-16.

When the IPL I/O operation is completed successfully, the subsystem-identification word for the IPL device is stored in absolute storage locations 184-187, zeros are stored in absolute storage locations 188-191, and a new PSW is loaded from absolute storage locations 0-7. If the PSW loading is successful and no machine malfunctions are detected, this CPU leaves the load state, and the load indicator is turned off. If the rate control is set to the process position, the CPU enters the operating state, and the CPU operation proceeds under control of the new PSW. If the rate control is set to the instruction-step position, the CPU enters the stopped state, with the manual indicator on, after the new PSW is loaded.

If the IPL I/O operation or the PSW loading is not completed successfully, the CPU remains in the load state, and the load indicator remains on. The contents of absolute storage locations 0-7 are unpredictable.

### Store Status

The store-status operation places an architectural-mode identification and the contents of the CPU registers, except for the TOD clock, in assigned storage locations.

Figure 4-16 on page 4-62 lists the fields that are stored, their length, and their location in main storage.

<table>
<thead>
<tr>
<th>Field</th>
<th>Length in Bytes</th>
<th>Absolute Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Architectural-mode id</td>
<td>1</td>
<td>163</td>
</tr>
<tr>
<td>Floating-point registers 0-15</td>
<td>128</td>
<td>4608</td>
</tr>
<tr>
<td>General registers 0-15</td>
<td>128</td>
<td>4736</td>
</tr>
<tr>
<td>Current PSW</td>
<td>16</td>
<td>4864</td>
</tr>
<tr>
<td>Prefix</td>
<td>4</td>
<td>4888</td>
</tr>
<tr>
<td>Floating-point control register</td>
<td>4</td>
<td>4892</td>
</tr>
<tr>
<td>TOD programmable register</td>
<td>4</td>
<td>4900</td>
</tr>
<tr>
<td>CPU timer</td>
<td>8</td>
<td>4904</td>
</tr>
<tr>
<td>Zeros</td>
<td>1</td>
<td>4912</td>
</tr>
<tr>
<td>Bits 0-55 of clock comparator</td>
<td>7</td>
<td>4913</td>
</tr>
<tr>
<td>Access registers 0-15</td>
<td>64</td>
<td>4928</td>
</tr>
<tr>
<td>Control registers 0-15</td>
<td>128</td>
<td>4992</td>
</tr>
</tbody>
</table>

Figure 4-16. Assigned Storage Locations for Store Status

During the execution of the store-status operation, zeros are stored in bit positions 0-6, and a one is stored in bit position 7, of absolute location 163, the store-status architectural-mode identification.

When the CPU is in the ESA/390 architectural mode, the store-status operation stores all zeros at absolute location 163.

When bits 0-55 of the clock comparator are stored beginning at absolute location 4913, zeros are stored at absolute location 4912.

The contents of the registers are not changed. If an error is encountered during the operation, the CPU enters the check-stop state.

The store-status operation can be initiated manually by use of the store-status key (see “Store-Status Key” on page 12-5). The store-status operation can also be initiated at the addressed CPU by executing SIGNAL PROCESSOR, specifying the stop-and-store-status order. Execution of SIGNAL PROCESSOR specifying the store-status-at-address order permits the same status information, except for the store-status architectural-mode identification, to be
stored at a designated address (see “Signal-Processor Orders” on page 4-64).

**Multiprocessing**

The multiprocessing facility provides for the interconnection of CPUs, via a common main storage, in order to enhance system availability and to share data and resources. The multiprocessing facility includes the following facilities:

- Shared main storage
- CPU-to-CPU interconnection
- TOD-clock synchronization

Associated with these facilities is an external-interruption condition (malfunction alert), which is described in “Malfunction Alert” on page 6-13; and control-register positions for the TOD-clock-sync-control bit and for the mask for the external-interruption condition, which are listed in “Control Registers” on page 4-7.

The channel subsystem, including all subchannels, in a multiprocessing configuration can be accessed by all CPUs in the configuration. I/O-interruption conditions are floating and can be accepted by any CPU in the configuration.

**Shared Main Storage**

The shared-main-storage facility permits more than one CPU to have access to common main-storage locations. All CPUs having access to a common main-storage location have access to the entire 4K-byte block containing that location and to the associated storage key. The channel subsystem and all CPUs in the configuration refer to a shared main-storage location using the same absolute address.

**CPU-Address Identification**

Each CPU has a number assigned, called its CPU address. A CPU address uniquely identifies one CPU within a configuration. The CPU is designated by specifying this address in the CPU-address field of SIGNAL PROCESSOR. The CPU signaling a malfunction alert, emergency signal, or external call is identified by storing this address in the CPU-address field with the interruption. The CPU address is assigned by the configuration-definition process and, except as indicated below, is not changed as a result of reconfiguration changes. The program can determine the address of the CPU by using STORE CPU ADDRESS.

**CPU-Address Expansion**

When multithreading is enabled, the CPU address comprises a core identification (core ID), concatenated with an identification of a CPU within the core; the CPU identification within a core is commonly called a thread identification (thread ID, or TID). Within a configuration, all cores provide the same number of CPUs; however, depending on the model and CPU type, some CPUs in a core may not be operational.

Based on the program-specified maximum thread identification specified in bits 59-63 of the parameter register used by the SIGNAL PROCESSOR set-multithreading order, a fixed number of bits are required to represent the thread identification; this number of bits is referred to as the TID width.

The core ID is formed from the rightmost bits of the CPU address before multithreading is enabled. The core ID is shifted left by TID-width bits, resulting in the leftmost bits of the CPU address after multithreading is available. The thread ID requires the same TID-width number of bits, and occupies the rightmost bits of the CPU address after multithreading is enabled. Thread IDs are assigned in a contiguous range of numbers beginning with zero and extending to a maximum of 31; however, a model may implement fewer CPUs per core.
Figure 4-17 illustrates the adjustment of the CPU address when multithreading is enabled.

<table>
<thead>
<tr>
<th>Program-Specified Maximum TID</th>
<th>TID Width</th>
<th>CPU Address Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Core ID: 0-15, Thread ID: –</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Core ID: 0-14, Thread ID: 15</td>
</tr>
<tr>
<td>2-3</td>
<td>2</td>
<td>Core ID: 0-13, Thread ID: 14-15</td>
</tr>
<tr>
<td>4-7</td>
<td>3</td>
<td>Core ID: 0-12, Thread ID: 13-15</td>
</tr>
<tr>
<td>8-15</td>
<td>4</td>
<td>Core ID: 0-11, Thread ID: 12-15</td>
</tr>
<tr>
<td>16-31</td>
<td>5</td>
<td>Core ID: 0-10, Thread ID: 11-15</td>
</tr>
</tbody>
</table>

Explanation:
1. Specified in bits 56-63 of the parameter register for the SIGP set-multithreading order. The number of CPUs per core is one more than the program-specified maximum thread identification.
2. Not applicable; multithreading is not enabled.

CPU-Address Contraction

When a reset function disables multithreading, (a) the CPU address(es) of the CPU(s) having the thread-ID zero are shifted to the right by the same TID-width number of bits used during enablement, (b) zeros are inserted in the TID-width number of bits on the left of the address, and (c) the CPU address reverts to its original non-multithreading format. All CPUs in a core having nonzero thread IDs when multithreading is enabled are no longer operational when multithreading is disabled.

When multithreading is not enabled, the CPU address remains unchanged from the value assigned by the configuration-definition process. In this case, the thread identification does not exist.

**CPU Signaling and Response**

The CPU-signaling-and-response facility consists of SIGNAL PROCESSOR and a mechanism to interpret and act on several order codes. The facility provides for communications among CPUs, including transmitting, receiving, and decoding a set of assigned order codes; initiating the specified operation; and responding to the signaling CPU. A CPU can address SIGNAL PROCESSOR to itself. SIGNAL PROCESSOR is described in “SIGNAL PROCESSOR” on page 10-129.

**Signal-Processor Orders**

The signal-processor orders are specified in bit positions 56-63 of the second-operand address of SIGNAL PROCESSOR and are encoded as shown in Figure 4-19.
The orders are defined as follows:

**Sense**
The addressed CPU presents its status to the issuing CPU (see “Status Bits” on page 4-72 for a definition of the bits). No other action is caused at the addressed CPU. The status, if not all zeros, is stored in the general register designated by the R₁ field of the SIGNAL PROCESSOR instruction, and condition code 1 is set; if all status bits are zeros, condition code 0 is set.

**External Call**
An external-call external-interruption condition is generated at the addressed CPU. The interruption condition becomes pending during the execution of SIGNAL PROCESSOR. The associated interruption occurs when the CPU is enabled for that condition and does not necessarily occur during the execution of SIGNAL PROCESSOR. The address of the CPU sending the signal is provided with the interruption code when the interruption occurs. Only one external-call condition can be kept pending in a CPU at a time. The order is accepted only when the addressed CPU is in the stopped or the operating state.

**Emergency Signal**
An emergency-signal external-interruption condition is generated at the addressed CPU. The interruption condition becomes pending during the execution of SIGNAL PROCESSOR. The associated interruption occurs when the CPU is enabled for that condition and does not necessarily occur during the execution of SIGNAL PROCESSOR. The address of the CPU sending the signal is provided with the interruption code when the interruption occurs. At any one time the receiving CPU can keep pending one emergency-signal condition for each CPU in the configuration, including the receiving CPU itself. The order is accepted only when the addressed CPU is in the stopped or the operating state.

**Start**
The addressed CPU performs the start function (see “Stopped, Operating, Load, and Check-Stop States” on page 4-2). The CPU does not necessarily enter the operating state during the execution of SIGNAL PROCESSOR. The order is effective only when the addressed CPU is in the stopped state. The effect of performing the start function is unpredictable when the stopped state has been entered by reset.

**Stop**
The addressed CPU performs the stop function (see “Stopped, Operating, Load, and Check-Stop States” on page 4-2). The CPU does not necessarily enter the stopped state during the execution of SIGNAL PROCESSOR. The order is effective only when the CPU is in the operating state.

**Restart**
The addressed CPU performs the restart operation (see “Restart Interruption” on page 6-54). The CPU does not necessarily perform the operation during the execution of SIGNAL PROCESSOR. The order is effective only when the addressed CPU is in the stopped or the operating state.

**Stop and Store Status**
The addressed CPU performs the stop function, followed by the store-status operation (see “Store Status” on page 4-62). The CPU does not necessarily complete the operation, or even enter the stopped state, during the execution of SIGNAL PROCESSOR. The order is effective only when the addressed CPU is in the stopped or the operating state.

**Initial CPU Reset**
The addressed CPU performs initial CPU reset (see “Resets” on page 4-55). The execution of an initial-CPU reset initiated by SIGNAL PROCESSOR does not affect the architectural mode or other CPUs, does not disable multithreading, and does not cause I/O to be reset. The reset operation is not necessarily completed during the execution of SIGNAL PROCESSOR.

**CPU Reset**
The addressed CPU performs CPU reset (see “Resets” on page 4-55). The execution of a CPU reset initiated by SIGNAL PROCESSOR does not
affect the architectural mode or other CPUs, does not disable multithreading, and does not cause I/O to be reset. The reset operation is not necessarily completed during the execution of SIGNAL PROCESSOR.

Set Prefix
The contents of bit positions 33-50 of the parameter register of the SIGNAL PROCESSOR instruction are treated as a prefix value, which replaces bits 33-50 of the prefix register of the addressed CPU. Bits 0-32 and 51-63 of the parameter register are ignored. The order is accepted only if the addressed CPU is in the stopped state, the value to be placed in the prefix register designates an 8K block which is available in the configuration, and no other condition precludes accepting the order. Verification of the stopped state of the addressed CPU and of the availability of the designated storage is performed during execution of SIGNAL PROCESSOR. If accepted, the order is not necessarily completed during the execution of SIGNAL PROCESSOR.

The parameter register has the following format:

```
  / Prefix Value /
0 31 32 33 51 63
```

The set-prefix order is completed as follows:

- If the addressed CPU is not in the stopped state, the order is not accepted. Instead, bit 54 (incorrect state) of the general register designated by the R1 field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.
- The value to be placed in the prefix register of the addressed CPU.
- The ALB and TLB of the addressed CPU are cleared of their contents.
- A serializing and checkpoint-synchronizing function is performed on the addressed CPU following insertion of the new prefix value.

Store Status at Address
The contents of bit positions 33-54 of the parameter register of the SIGNAL PROCESSOR instruction are used as the origin of a 512-byte area on a 512-byte boundary in absolute storage into which the status of the addressed CPU is stored. Bits 0-32 and 55-63 of the parameter register are ignored.

The order is accepted only if the addressed CPU is in the stopped state, the status-area origin designates a location which is available in the configuration, and no other condition precludes accepting the order. Verification of the stopped state of the addressed CPU and of the availability of the designated storage is performed during execution of SIGNAL PROCESSOR. If accepted, the order is not necessarily completed during the execution of SIGNAL PROCESSOR.

The parameter register has the following format:

```
  / Status-Area Origin /
0 31 32 33 55 63
```

The store-status-at-address order is completed as follows:

- If the addressed CPU is not in the stopped state, the order is not accepted. Instead, bit 54 (incorrect state) of the general register designated by the R1 field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.
- The value is placed in the prefix register of the addressed CPU.
- The ALB and TLB of the addressed CPU are cleared of their contents.
- A serializing and checkpoint-synchronizing function is performed on the addressed CPU following insertion of the new prefix value.

address of a 512-byte area of storage is formed by appending 9 zeros to the right and 33 zeros to the left of bits 33-54 of the parameter value. This address is treated as a 64-bit absolute address regardless of whether the sending and receiving CPUs are in the 24-bit, 31-bit, or 64-bit addressing mode. The 512-byte block of storage at this address is accessed. The access is not subject to protection, and the associated reference bit may or may not be set to one. If the block is not available in the configuration, the order is not accepted by the addressed CPU, bit 55 (invalid parameter) of the general register designated by the R1 field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.

- The status of the addressed CPU is placed in the designated area. The information stored, and the format of the area receiving the information, are the same as for the stop-and-store-status order, except that each field, rather than being stored at an offset from the beginning of absolute storage, is stored in the designated area at the offsets listed in Figure 4-20, and except that an architectural-mode identification and the vector registers are not stored. Bytes 288-291 and 312-319 of the designated area remain unchanged.

- A serialization and checkpoint-synchronization function is performed on the addressed CPU following storing of the status.

The order is accepted only if the code is 0, 1, or 2, the CPU is not already in the mode specified by the code, each of all other CPUs is in either the stopped or the check-stop state, and no other condition precludes accepting the order. If accepted, the order is completed by all CPUs during the execution of SIGNAL PROCESSOR. In no case can different CPUs be in different architectural modes.

The set-architecture order is completed as follows:

- If the code in the parameter register is not 0, 1, or 2, or if the CPU is already in the architectural mode specified by the code, the order is not accepted. Instead, bit 55 (invalid parameter) of the general register designated by the R1 field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.

- If the code in the parameter register is 0 and multithreading is enabled, return to the ESA/390 architectural mode is not possible and the order is not accepted. Instead, bit 54 (incorrect state)
of the general register designated by the \( R_1 \) field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.

- If it is not true that all other CPUs in the configuration are in the stopped or check-stop state, the order is not accepted. Instead, bit 54 (incorrect state) of the general register designated by the \( R_1 \) field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.

- The architectural mode of all CPUs in the configuration is set as specified by the code.

- If the order changes the architectural mode from ESA/390 to z/Architecture and the code is 1, then, for each CPU in the configuration, the eight-byte current PSW is changed to a 16-byte PSW, and the bits of the 16-byte PSW are set as follows: bits 0-11 and 13-32 are set equal to the same bits of the eight-byte PSW, bit 12 and bits 33-96 are set to zeros, and bits 97-127 are set equal to bits 33-63 of the eight-byte PSW. Also, bit 19 of the ESA/390 prefix, which becomes bit 51 of the z/Architecture prefix, is set to zero.

If the code is 2, the PSW of the CPU executing SIGNAL PROCESSOR and the prefix values of all CPUs are set as in the code-1 case. For each of all other CPUs in the configuration, the PSW is set with the value of the captured-z/Architecture-PSW register — a PSW saved when the CPU last went from the z/Architecture mode to the ESA/390 mode because of a set-architecture order with code 0 or a CPU reset due to activation of the load-normal or load-with-dump key. However, the captured-z/Architecture-PSW register has been set to all zeros if the CPU performed a reset, other than CPU reset, either at the time of the architectural-mode transition or subsequently.

- If the order changes the architectural mode from z/Architecture to ESA/390, then, for each CPU in the configuration, (1) the current PSW, which is the updated PSW in the case of the CPU executing SIGNAL PROCESSOR, is saved in the captured-z/Architecture-PSW register, and (2) the 16-byte current PSW is changed to an eight-byte PSW by setting the bits of the eight-byte PSW as follows: bits 0-11 and 13-32 are set equal to the same bits of the 16-byte PSW, bit 12 is set to one, and bits 33-63 are set equal to bits 97-127 of the 16-byte PSW. Bit 51 of the z/Architecture prefix, which becomes bit 19 of the ESA/390 prefix, remains unchanged.

- The ALBs and TLBs of all CPUs in the configuration are cleared of their contents.

- A serialization and checkpoint-synchronization function is performed on all CPUs in the configuration.

If the order changes the architectural mode from z/Architecture to ESA/390 and the SIGNAL PROCESSOR instruction causes occurrence of an instruction-fetching PER event, only the rightmost 31 bits of the address of the instruction are stored in the ESA/390 PER-address field.

**Programming Note:** If the set-architecture order changes the architectural mode from z/Architecture to ESA/390 and bit 31 of the PSW is one, the PSW is invalid.

### Conditional Emergency Signal

An emergency-signal external-interruption condition may be generated at the addressed CPU. The contents of bit positions 48-63 of the parameter register of the SIGNAL PROCESSOR instruction are treated as a check-ASN value which is used as part of the condition checking of the addressed CPU. If signaling is permitted, the interruption condition becomes pending during the execution of SIGNAL PROCESSOR. The associated interruption occurs when the CPU is enabled for that condition and does not necessarily occur during the execution of SIGNAL PROCESSOR. The address of the CPU sending the signal is provided with the interruption code when the interruption occurs. At any one time the receiving CPU can keep pending one emergency-signal condition for each CPU in the configuration, including the receiving CPU itself.

The order is accepted only when the addressed CPU is in the stopped or the operating state and one of the following conditions of the addressed CPU can be determined:

- The PSW is disabled for external interruptions, I/O interruptions, or both.

- The CPU is in the wait state and the instruction address in the PSW is not zero.

- The CPU is not in the wait state, and the specified check-ASN value equals an ASN of the CPU.
(primary, secondary, both), regardless of the setting of bit positions 16-17 of the PSW.

When making the above determination of possible conditions is precluded, the conditional nature of the order is not effective, and instead the order is accepted as if an emergency-signal order had been specified.

If the order is accepted, the interruption is made pending, and condition code 0 is set. Otherwise, the interruption is not made pending, bit 54 (incorrect state) of the status register is set to one, and condition code 1 is set.

The parameter register has the following format:

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
| 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 |

Check ASN

Sense Running Status
When the multithreading facility is not enabled, the following applies:

- If the addressed CPU is running, condition code 0 is set.
- If the addressed CPU is not running, status bit 53 is set to one and all other status bits are set to zero in the general register designated by the R1 field of the SIGNAL PROCESSOR instruction, and condition code 1 is set.

When the multithreading facility is enabled, the following applies:

- If any CPU of the core in which the addressed CPU is a member is running, condition code 0 is set.
- If all CPUs of the core in which the addressed CPU is a member are not running, status bit 53 is set to one and all other status bits are set to zero in the general register designated by the R1 field of the SIGNAL PROCESSOR instruction, and condition code 1 is set.

No other action is caused at the addressed CPU.

Programming Note: When the multithreading facility is enabled, a sense-running-status order addressed to a stopped CPU will complete with condition code 0 if any other CPU in the same core is running.

Set Multithreading
The set-multithreading order enables the multithreading facility.

Bit positions 59-63 of the parameter register contain the program-specified maximum thread identification to be provided in the configuration. The program-specified maximum thread identification is one less than the number of CPUs to be made addressable in each core. For example, a value of 3 in bit positions 59-63 indicates that four threads are to be provided. Bits 0-58 of the parameter register are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.

The contents of the CPU-address register of the SIGNAL PROCESSOR instruction are ignored; all CPUs in the configuration are considered to be addressed.

If accepted, the order is completed by all CPUs during the execution of SIGNAL PROCESSOR. The set-multithreading order is completed as follows:

- If the multithreading facility is not installed or the CPU is not in the z/Architecture architectural mode, or an external control prevents the use of multithreading, the order is not accepted. Instead, bit 62 (invalid order) of the general register designated by the R1 field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.
- If it is not true that all other CPUs in the configuration are in the stopped or check-stop state, or if the configuration is already enabled for multithreading, the order is not accepted. Instead, bit 54 (incorrect state) of the general register designated by the R1 field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.
- If the program-specified maximum thread identification in bit positions 59-63 of the parameter register contains a value not supported by the model, the order is not accepted. Instead, bit 55 (invalid parameter) of the general register designated by the R1 field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.
• When the program-specified maximum thread identification is nonzero, the following is performed:
  – The configuration is enabled for multithreading, resulting in CPU-address expansion as described in “CPU-Address Expansion” on page 4-63.
  – The meaning of a CPU-type topology-list entry (TLE) of a SYSIB 15.1.x in the STORE SYSTEM INFORMATION instruction is changed (see “Fields Specific to a CPU-type TLE” on page 10-151).
  – The ALBs and TLBs of all CPUs in the configuration are cleared of their contents.
  – The MT-diagnostic counter set is set to the active state.

When the program-specified maximum thread identification is zero, the configuration is not enabled for multithreading.

• A serialization and checkpoint-synchronization function is performed on all CPUs in the configuration.

Upon successful completion, all CPUs other than the CPU executing the set-multithreading order remain in the stopped or check-stop state. However, if a CPU was in the check-stop state before multithreading is enabled, it is unpredictable whether the CPUs having nonzero thread IDs in the same core are placed in the stopped or check-stopped state.

The architected register context (that is, the contents of the PSW, CPU timer, clock comparator, general registers, floating-point registers and floating-point-control register, vector registers, control registers, access registers, prefix register, and TOD-programmable register) of each CPU before multithreading is enabled becomes the architected register context of the CPU having TID zero of each respective core after multithreading is enabled. Similarly, the architected register context of the CPU having TID zero of each core of an MT-enabled configuration becomes the architected register context of each respective CPU when multithreading is disabled as a result of the activation of the load-normal or load-with-dump key.

If the multithreading facility is subsequently re-enabled without an intervening clear reset, the architected register context of all CPUs having a nonzero thread identification are restored.

When multithreading is re-enabled after having been disabled by the activation of the load-normal or load-with-dump key, if the value of the program-specified maximum thread identification in bits 59-63 of the parameter register differs from that used in the preceding enablement, then the architected register context of all CPUs having nonzero thread IDs is unpredictable.

### Store Additional Status at Address

The contents of bit positions 0-53 of the parameter register of the SIGNAL PROCESSOR instruction are used as the origin of a 1024-byte area on a 1024-byte boundary in absolute storage into which the status of the addressed CPU is stored. Bits 54-63 of the parameter register must be zero.

The order is accepted only if the addressed CPU is in the stopped state, the status-area origin designates a location which is available in the configuration, and no other condition precludes accepting the order. Verification of the stopped state of the addressed CPU and of the availability of the designated storage is performed during execution of SIGNAL PROCESSOR. If accepted, the order is not necessarily completed during the execution of SIGNAL PROCESSOR.

The parameter register has the following format:

<table>
<thead>
<tr>
<th>Status-Area Origin</th>
<th>0</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>Status-Area Origin (cont.)</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>32</td>
<td>54</td>
<td>63</td>
</tr>
</tbody>
</table>

The store-additional-status-at-address order is completed as follows:

• If the vector facility for z/Architecture is not installed, the order is not accepted. Instead, bit 62 (invalid order) of the general register designated by the R1 field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.

• If the addressed CPU is not in the stopped state, the order is not accepted. Instead, bit 54 (incorrect...
rect state) of the general register designated by the $R_1$ field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.

- The address of the area into which status is to be stored is tested for availability. The absolute address of a 1024-byte area of storage is formed by appending 10 zeros to the right of bits 0-53 of the parameter value. This address is treated as a 64-bit absolute address regardless of whether the sending and receiving CPUs are in the 24-bit, 31-bit, or 64-bit addressing mode. The 1024-byte block of storage at this address is accessed. The access is not subject to protection, and the associated reference bit may or may not be set to one. If the block is not available in the configuration, or bits 54-63 of the parameter register are not zero, the order is not accepted by the addressed CPU, bit 55 (invalid parameter) of the general register designated by the $R_1$ field of the SIGNAL PROCESSOR instruction is set to one, and condition code 1 is set.

- A serialization and checkpoint-synchronization function is performed on the addressed CPU following storing of the status.

### Table: Location of Additional Status Fields in Designated Area

<table>
<thead>
<tr>
<th>Field</th>
<th>Length in Bytes</th>
<th>Offset in Bytes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vector registers 0-31</td>
<td>512</td>
<td>0</td>
</tr>
<tr>
<td>Reserved (unchanged)</td>
<td>512</td>
<td>512</td>
</tr>
</tbody>
</table>

*Figure 4-21. Location of Additional Status Fields in Designated Area*

**Programming Note:** For a discussion of the relative performance of the SIGNAL PROCESSOR orders, see the programming note following the instruction “SIGNAL PROCESSOR” on page 10-129.

### Conditions Determining Response

#### Conditions Precluding Interpretation of the Order Code

The following situations preclude the initiation of the order. The sequence in which the situations are listed is the order of priority for indicating concurrently existing situations:

1. The access path to the addressed CPU is busy because a concurrently executed SIGNAL PROCESSOR is using the CPU-signaling-and-response facility. The CPU which is concurrently executing the instruction can be any CPU in the configuration other than this CPU, and the CPU address can be any address, including that of this CPU or an invalid address. The order is rejected. Condition code 2 is set.

2. The addressed CPU is not operational; that is, it is not provided in the installation, it is not in the configuration, its use is restricted based on model or CPU type, it is in any of certain customer-engineer test modes, or its power is off. The order is rejected. Condition code 3 is set. This condition cannot arise as a result of a SIGNAL PROCESSOR instruction executed by a CPU addressing itself.

3. One of the following conditions exists at the addressed CPU:

   a. A previously issued start, stop, restart, stop-and-store-status, set-prefix, store-status-at-address order, or store-additional-status-at-address has been accepted by the addressed CPU, and execution of the function requested by the order has not yet been completed.

   b. A manual start, stop, restart, or store-status function has been initiated at the addressed CPU, and the function has not yet been completed. This condition cannot arise as a result of a SIGNAL PROCESSOR instruction executed by a CPU addressing itself.

If the currently specified order is sense, external call, emergency signal, start, stop, restart, stop and store status, set prefix, store status at address, set architecture, set multithreading, or store additional status at address, then the order is rejected, and condition code 2 is set. If the currently specified order is one of the reset orders, or an unassigned or not-implemented order, the order code is interpreted as described in “Status Bits” on page 4-72.

4. One of the following conditions exists at the addressed CPU:

   a. A previously issued initial-CPU-reset or CPU-reset order has been accepted by the addressed CPU, and execution of the function requested by the order has not yet been completed.

   b. A manual-reset function has been initiated at the addressed CPU, and the function has not
yet been completed. This condition cannot arise as a result of a SIGNAL PROCESSOR instruction executed by a CPU addressing itself.

If the currently specified order is sense, external call, emergency signal, start, stop, restart, stop and store status, set prefix, store status at address, set multithreading, or set architecture, then the order is rejected, and condition code 2 is set. If the currently specified order is one of the reset orders, or an unassigned or not-implemented order, either the order is rejected and condition code 2 is set or the order code is interpreted as described in “Status Bits” on page 4-72.

When any of the conditions described in items 3 and 4 exists, the addressed CPU is referred to as “busy.” Busy is not indicated if the addressed CPU is in the check-stop state or when the operator-intervening condition exists. A CPU-busy condition is normally of short duration; however, the conditions described in item 3 may last indefinitely because of a string of interruptions. In this situation, however, the CPU does not appear busy to any of the reset orders.

When the conditions described in items 1 and 2 above do not apply and operator-intervening and receiver-check status conditions do not exist at the addressed CPU, reset orders may be accepted regardless of whether the addressed CPU has completed a previously accepted order. This may cause the previous order to be lost when it is only partially completed, making unpredictable whether the results defined for the lost order are obtained.

### Status Bits

Various status conditions are defined whereby the issuing and addressed CPUs can indicate their responses to the specified order. The status conditions and their bit positions in the general register designated by the R₁ field of the SIGNAL PROCESSOR instruction are shown in Figure 4-22.

<table>
<thead>
<tr>
<th>Bit Position</th>
<th>Status Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>Equipment check</td>
</tr>
<tr>
<td>33-52</td>
<td>Unassigned; zeros stored</td>
</tr>
<tr>
<td>53</td>
<td>Not running</td>
</tr>
<tr>
<td>54</td>
<td>Incorrect state</td>
</tr>
<tr>
<td>55</td>
<td>Invalid parameter</td>
</tr>
</tbody>
</table>

The status condition assigned to bit position 32, and to bit position 55 when the order is set architecture or set multithreading, are generated by the CPU executing SIGNAL PROCESSOR. The remaining status conditions are generated by the addressed CPU.

When the invalid-parameter condition exists for the set-architecture or set multithreading order, bit 55 of the general register designated by the R₁ field of the SIGNAL PROCESSOR instruction is set to one, all other bits in bit positions 32-63 are set to zeros, bits 0-31 of the register remain unchanged, and condition code 1 is set. No other action is taken.

When the equipment-check condition exists, except when the invalid-parameter condition exists for the set-architecture or set multithreading order, bit 32 of the general register designated by the R₁ field of the SIGNAL PROCESSOR instruction is set to one, unassigned bits in bit positions 32-63 of the status register are set to zeros, the other status bits are unpredictable, and bits 0-31 of the register remain unchanged. In this case, condition code 1 is set independent of whether the access path to the addressed CPU is busy and independent of whether the addressed CPU is not operational, is busy, or has presented zero status.

When the access path to the addressed CPU is not busy and the addressed CPU is operational and does not indicate busy to the currently specified order, the addressed CPU presents its status to the issuing CPU. These status bits are of two types:

1. Status bits 53, 54, and 55 when the order is neither set architecture nor set-multithreading, 56-59, and 61 indicate the presence of the corresponding conditions in the addressed CPU at the time the order code is received. Except in response to the sense order and the sense-running-status order, each condition is indicated...
only when the condition precludes the successful execution of the specified order, although invalid parameter is not necessarily indicated when any other precluding condition exists. In the case of sense, all existing status conditions except not-running are indicated; the operator-intervening condition is indicated if it precludes the execution of any installed order.

2. Status bits 62 and 63 indicate that the corresponding conditions were detected by the addressed CPU during reception of the order.

If the presented status is all zeros, the addressed CPU has accepted the order, and condition code 0 is set at the issuing CPU; if the presented status is not all zeros, the order has been rejected, the status is stored at the issuing CPU in the general register designated by the R1 field of the SIGNAL PROCESSOR instruction, zeros are stored in the unassigned positions in bit positions 32-63 of the register, bits 0-31 of the register remain unchanged, and condition code 1 is set.

When the order is set architecture or set multithreading, “the addressed CPU” refers to each of the other CPUs in the configuration. Those CPUs, in an unpredictable order, are tested for a condition that causes setting of condition code 1, 2, or 3. Conditions are prioritized for a single CPU as if it were the only CPU addressed, but there is no prioritization across CPUs. If a condition is recognized, no further CPUs are tested, the condition code corresponding to the condition is set, and the execution of SIGNAL PROCESSOR is completed.

The status conditions are defined as follows:

**Equipment Check:** This condition exists when the CPU executing the instruction detects equipment malfunctioning that has affected only the execution of this instruction and the associated order. The order code may or may not have been transmitted and may or may not have been accepted, and the status bits provided by the addressed CPU may be in error. This condition is not detected if the invalid-parameter condition for the set-architecture or set-multithreading order is detected.

**Not Running:** This condition exists when the addressed CPU is not running. The condition, when present, is indicated only in response to the sense-running-status order. This condition is not reported as a result of a SIGNAL PROCESSOR instruction executed by a CPU addressing itself; condition code 0 is always set in this case. A CPU is running when it is assigned to a physical CPU.

**Incorrect State:** The condition exists in the following cases:

1. A set-prefix, store-status-at-address, or store-additional-status-at-address order has been rejected because the addressed CPU is not stopped.

2. A set-architecture, or set-multithreading order has been rejected because not all other CPUs are stopped or in the check-stop state.

3. A set-multithreading or a set-architecture order to set the ESA/390 architectural mode has been rejected because multithreading is currently enabled.

4. A conditional emergency-signal order has been rejected because the addressed CPU is not in a required state.

When applicable, this status is generated during execution of SIGNAL PROCESSOR and is indicated concurrently with other indications of conditions which preclude execution of the order, except that this status is not generated if an invalid-parameter condition exists for a set-architecture order.

**Invalid Parameter:** This condition exists in the following cases:

1. The parameter value supplied with a set-prefix, store-status-at-address, or store-additional-status-at-address order designates a storage location which is not available in the configuration. When applicable, this status is generated during execution of SIGNAL PROCESSOR, except that it is not necessarily generated when another condition precluding execution of the order also exists.

2. The parameter value supplied with a set-architecture order either is not 0 or 1 or specifies the current architectural mode. When applicable, this status is generated during execution of SIGNAL PROCESSOR, and no other status is generated.

3. The parameter value supplied with a set-multithreading order specifies a value not supported by the model.
4. The parameter value supplied with a store-additional-status-at-address order contains a non-zero value in bit positions 54-63 of the parameter register.

**External Call Pending:** This condition exists when an external-call interruption condition is pending in the addressed CPU because of a previously issued SIGNAL PROCESSOR order. The condition exists from the time an external-call order is accepted until the resultant external interruption has been completed or a CPU reset occurs. The condition may be due to the issuing CPU or another CPU. The condition, when present, is indicated only in response to sense and to external call.

**Stopped:** This condition exists when the addressed CPU is in the stopped state. The condition, when present, is indicated only in response to sense. This condition cannot be reported as a result of a SIGNAL PROCESSOR instruction executed by a CPU addressing itself.

**Operator Intervening:** This condition exists when the addressed CPU is executing certain operations initiated from local or remote operator facilities. The particular manually initiated operations that cause this condition to be present depend on the model and on the order specified. The operator-intervening condition may exist when the addressed CPU uses reloadable control storage to perform an order and the required licensed internal code has not been loaded by the IML function. The operator-intervening condition, when present, can be indicated in response to all orders. Operator intervening is indicated in response to sense if the condition is present and precludes the acceptance of any of the installed orders. The condition may also be indicated in response to unassigned or uninstalled orders. This condition cannot arise as a result of a SIGNAL PROCESSOR instruction executed by a CPU addressing itself.

**Check Stop:** This condition exists when the addressed CPU is in the check-stop state. The condition, when present, is indicated only in response to sense, external call, emergency signal, conditional emergency signal, start, stop, restart, set prefix, store status at address, and stop and store status. The condition may also be indicated in response to unassigned or uninstalled orders. This condition cannot be reported as a result of a SIGNAL PROCESSOR instruction executed by a CPU addressing itself.

**Inoperative:** This condition indicates that the execution of the operation specified by the order code requires the use of a service processor which is inoperative. The failure of the service processor may have been previously reported by a service-processor-damage machine-check condition. The inoperative condition cannot occur for the conditional emergency signal, emergency-signal, external-call, sense, or sense-running-status order codes.

**Invalid Order:** This condition exists during the communications associated with the execution of SIGNAL PROCESSOR when an unassigned or uninstalled order code is decoded.

**Receiver Check:** This condition exists when the addressed CPU detects malfunctioning of equipment during the communications associated with the execution of SIGNAL PROCESSOR. When this condition is indicated, the order has not been initiated, and, since the malfunction may have affected the generation of the remaining receiver status bits, these bits are not necessarily valid. A machine-check condition may or may not have been generated at the addressed CPU.

The following chart summarizes which status conditions are presented to the issuing CPU in response to each order code.

<table>
<thead>
<tr>
<th>Order</th>
<th>Status Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sense</td>
<td>0 0 0 X X X X X 0 0 X</td>
</tr>
<tr>
<td>External call</td>
<td>0 0 0 X 0 X X X 0 0 X</td>
</tr>
<tr>
<td>Emergency signal</td>
<td>0 0 0 0 0 X X X 0 0 X</td>
</tr>
<tr>
<td>Start</td>
<td>0 0 0 0 0 X X X 0 0 X</td>
</tr>
<tr>
<td>Stop</td>
<td>0 0 0 0 0 X X X 0 X</td>
</tr>
<tr>
<td>Restart</td>
<td>0 0 0 0 0 X X X 0 X</td>
</tr>
<tr>
<td>Stop and store status</td>
<td>0 0 0 0 0 X X X 0 X</td>
</tr>
<tr>
<td>Initial CPU reset</td>
<td>0 0 0 0 0 X X X 0 X</td>
</tr>
<tr>
<td>CPU reset</td>
<td>0 0 0 0 0 X X X 0 X</td>
</tr>
<tr>
<td>Set prefix</td>
<td>0 X X 0 X 0 X X X 0 X</td>
</tr>
<tr>
<td>Store status at address</td>
<td>0 X X 0 X 0 X X X 0 X</td>
</tr>
<tr>
<td>Set architecture</td>
<td>0 X X 0 X 0 X X X 0 X</td>
</tr>
<tr>
<td>Conditional emergency signal</td>
<td>0 X 0 0 X X X X 0 X</td>
</tr>
</tbody>
</table>

*Figure 4-23. Status Conditions in Response to Order Code*
If the presented status bits are all zeros, the order has been accepted, and the issuing CPU sets condition code 0. If one or more ones are presented, the order has been rejected, and the issuing CPU stores the status in the general register designated by the R<sub>i</sub> field of the SIGNAL PROCESSOR instruction and sets condition code 1.

**Programming Notes:**

1. All SIGNAL PROCESSOR orders except set architecture (which in effect is addressed to all other CPUs and affects all CPUs) can be addressed to this same CPU. The following are examples of functions obtained by a CPU addressing SIGNAL PROCESSOR to itself:
   a. **Sense** indicates whether an external-call condition is pending.
   b. **External call and emergency signal** cause the corresponding interruption conditions to be generated. **External call** can be rejected because of a previously generated external-call condition.
   c. **Start** sets condition code 0 and has no other effect.
   d. **Stop** causes the CPU to set condition code 0, take pending interruptions for which it is enabled, and enter the stopped state.
   e. **Restart** provides a means to store the current PSW.
   f. **Stop and store status** causes the machine to stop and store all current status.

2. Two CPUs can simultaneously execute SIGNAL PROCESSOR, with each CPU addressing the other. When this occurs, one CPU, but not both, can find the access path busy because of the transmission of the order code or status bits associated with SIGNAL PROCESSOR that is being executed by the other CPU. Alternatively, both CPUs can find the access path available and transmit the order codes to each other. In particular, two CPUs can simultaneously stop, restart, or reset each other.

3. To obtain status from another CPU which is in the check-stop state by means of the store-status-at-address or store-additional-status-at-address order, a CPU reset operation should first be used to bring the CPU to the stopped state. This reset order does not alter the status, and, depending on the nature of the malfunction, provides the best chance of establishing conditions in the addressed CPU which allow status to be obtained.

### Facility Indications

Facilities installed in a configuration are indicated by facility bits stored by the STORE FACILITY LIST (STFL) and STORE FACILITY LIST EXTENDED (STFLE) instructions.

STORE FACILITY LIST stores an indication of up to 32 facilities in the word at real location 200. STFL is described in Chapter 10, “Control Instructions”.

STORE FACILITY LIST EXTENDED stores a variable number of doublewords containing facility bits in a program-specified location. STFLE is described in Chapter 7, “General Instructions”.

---

**Figure 4-23. Status Conditions in Response to Order Code**

If the presented status bits are all zeros, the order has been accepted, and the issuing CPU sets condition code 0. If one or more ones are presented, the order has been rejected, and the issuing CPU stores the status in the general register designated by the R<sub>i</sub> field of the SIGNAL PROCESSOR instruction and sets condition code 1.

<table>
<thead>
<tr>
<th>Order</th>
<th>Status Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sense running status</td>
<td>X 0 0 0 0 0 0 0 X 0</td>
</tr>
<tr>
<td>Set multithreading</td>
<td>0 X X 0 0 X 0 X X X</td>
</tr>
<tr>
<td>Store additional status at address</td>
<td>0 X X 0 0 X X X X X</td>
</tr>
<tr>
<td>Unassigned order</td>
<td>0 0 0 0 0 X E X 1 0</td>
</tr>
</tbody>
</table>

**Explanation**

# The current state of the operator-intervening condition may depend on the order code that is being interpreted.
≠ If a one is presented in the receiver-check bit position, the values presented in the other bit positions are not necessarily valid.
0 A zero is presented in this bit position regardless of the current state of this condition.
1 A one is presented in this bit position.
X A zero or a one is presented in this bit position, reflecting the current state of the corresponding condition.
E Either a zero or the current state of the corresponding condition is indicated.

---

**Table:**

<table>
<thead>
<tr>
<th>Order</th>
<th>Status Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>53 – Not running</td>
<td>54 – Incorrect state</td>
</tr>
<tr>
<td>55 – Invalid parameter</td>
<td>56 – External call pending</td>
</tr>
<tr>
<td>57 – Stopped</td>
<td>58 – Operator intervening</td>
</tr>
<tr>
<td>59 – Check stop</td>
<td>60 – Inoperative</td>
</tr>
<tr>
<td>61 – Invalid order</td>
<td>62 – Receiver check</td>
</tr>
<tr>
<td>63 – Unassigned order</td>
<td></td>
</tr>
</tbody>
</table>
Figure 4-24 shows the meanings of the assigned facility bits.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning When Bit Is One</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The instructions marked “N3” in the instruction-summary figures in Chapters 7 and 10 are installed.</td>
</tr>
<tr>
<td>1</td>
<td>The z/Architecture architectural mode is installed.</td>
</tr>
<tr>
<td>2</td>
<td>The z/Architecture architectural mode is active. When this bit is zero, the ESA/390 architectural mode is active.</td>
</tr>
<tr>
<td>3</td>
<td>The DAT-enhancement facility is installed in the z/Architecture architectural mode. The DAT-enhancement facility includes the INVALIDATE DAT TABLE ENTRY (IDTE) and COMPARE AND SWAP AND PURGE (CSPG) instructions.</td>
</tr>
<tr>
<td>4</td>
<td>INVALIDATE DAT TABLE ENTRY (IDTE) performs the invalidation-and-clearing operation by selectively clearing TLB segment-table entries when a segment-table entry or entries are invalidated. IDTE also performs the clearing-by-ASCE operation. Unless bit 4 is one, IDTE simply purges all TLBs. Bit 3 is one if bit 4 is one.</td>
</tr>
<tr>
<td>5</td>
<td>INVALIDATE DAT TABLE ENTRY (IDTE) performs the invalidation-and-clearing operation by selectively clearing TLB region-table entries when a region-table entry or entries are invalidated. Bits 3 and 4 are ones if bit 5 is one.</td>
</tr>
<tr>
<td>6</td>
<td>The ASN-and-LX reuse facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>7</td>
<td>The store-facility-list-extended facility is installed.</td>
</tr>
<tr>
<td>8</td>
<td>The enhanced-DAT facility 1 is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>9</td>
<td>The sense-running-status facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>10</td>
<td>The conditional-SSKE facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>11</td>
<td>The configuration-topology facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>12</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>13</td>
<td>The IPTE-range facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>14</td>
<td>The nonquiescing key-setting facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>15</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>16</td>
<td>The extended-translation facility 2 is installed.</td>
</tr>
<tr>
<td>17</td>
<td>The message-security assist is installed.</td>
</tr>
<tr>
<td>18</td>
<td>The long-displacement facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>19</td>
<td>The long-displacement facility has high performance. Bit 18 is one if bit 19 is one.</td>
</tr>
<tr>
<td>20</td>
<td>The HFP-multiply-and-add/subtract facility is installed.</td>
</tr>
<tr>
<td>21</td>
<td>The extended-immediate facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>22</td>
<td>The extended-translation facility 3 is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>23</td>
<td>The HFP-unnormalized-extension facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>24</td>
<td>The ETF2-enhancement facility is installed.</td>
</tr>
<tr>
<td>25</td>
<td>The store-clock-fast facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>26</td>
<td>The parsing-enhancement facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>27</td>
<td>The move-with-optional-specifications facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>28</td>
<td>The TOD-clock-steering facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>30</td>
<td>The ETF3-enhancement facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>31</td>
<td>The extract-CPU-time facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>32</td>
<td>The compare-and-swap-and-store facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>33</td>
<td>The compare-and-swap-and-store facility 2 is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>34</td>
<td>The general-instructions-extension facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>Bit</td>
<td>Meaning When Bit Is One</td>
</tr>
<tr>
<td>-----</td>
<td>-----------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>35</td>
<td>The execute-extensions facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>36</td>
<td>The enhanced-monitor facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>37</td>
<td>The floating-point extension facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>39</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>40</td>
<td>The set-program-parameters facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>41</td>
<td>The floating-point-support-enhancement facilities (DFP-rounding, FPR-GR-transfer, FPS-sign-handling, and IEEE-exception-simulation) are installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>42</td>
<td>The DFP (decimal-floating-point) facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>43</td>
<td>The DFP (decimal-floating-point) facility has high performance. Bit 42 is one if bit 43 is one.</td>
</tr>
<tr>
<td>44</td>
<td>The PFPO instruction is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>45</td>
<td>The distinct-operands, fast-BCR-serialization, high-word, and population-count facilities, the interlocked-access facility 1, and the load/store-on-condition facility 1 are installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>46</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>47</td>
<td>The CMPSC-enhancement facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>48</td>
<td>The decimal-floating-point zoned-conversion facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>49</td>
<td>The execution-hint, load-and-trap, miscellaneous-instruction-extensions and processor-assist facilities, are installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>50</td>
<td>The constrained transactional-execution facility is installed in the z/Architecture architectural mode. This bit is meaningful only when bit 73 is one.</td>
</tr>
<tr>
<td>51</td>
<td>The local-TLB-clearing facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>52</td>
<td>The interlocked-access facility 2 is installed.</td>
</tr>
</tbody>
</table>

**Figure 4-24. Assigned Facility Bits (Part 3 of 5)**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning When Bit Is One</th>
</tr>
</thead>
<tbody>
<tr>
<td>53</td>
<td>The load/store-on-condition facility 2 and load-and-zero-rightmost-byte facility are installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>55</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>57</td>
<td>The message-security-assist-extension-5 facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>62</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>63</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>65</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>66</td>
<td>The reset-reference-bits-multiple facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>67</td>
<td>The CPU-measurement counter facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>68</td>
<td>The CPU-measurement sampling facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>69</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>70</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>71</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>72</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>73</td>
<td>The transactional-execution facility is installed in the z/Architecture architectural mode. Bit 49 is one when bit 73 is one.</td>
</tr>
<tr>
<td>74</td>
<td>The store-hypervisor-information facility is installed in the z/Architecture architectural mode (see Reference [10.] on page xxviii).</td>
</tr>
<tr>
<td>75</td>
<td>The access-exception-fetch/store-indication facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>76</td>
<td>The message-security-assist-extension-3 facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>77</td>
<td>The message-security-assist-extension-4 facility is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>78</td>
<td>The enhanced-DAT facility 2 is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>80</td>
<td>The decimal-floating-point packed-conversion facility is installed in the z/Architecture architectural mode.</td>
</tr>
</tbody>
</table>

**Figure 4-24. Assigned Facility Bits (Part 4 of 5)**
<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning When Bit Is One</th>
</tr>
</thead>
<tbody>
<tr>
<td>128</td>
<td>Assigned to IBM internal use.</td>
</tr>
<tr>
<td>129</td>
<td>The vector facility for z/Architecture is installed in the z/Architecture architectural mode.</td>
</tr>
<tr>
<td>142</td>
<td>The store-CPU-counter-multiple facility is installed (see Reference [9.] on page xxvii).</td>
</tr>
<tr>
<td>143</td>
<td>Assigned to IBM internal use.</td>
</tr>
</tbody>
</table>

Figure 4-24. Assigned Facility Bits (Part 5 of 5)

A bit is set to one regardless of the current architectural mode if its meaning is true. A meaning applies to the current architectural mode unless it is said to apply to a specific architectural mode.

Unassigned bits are reserved for indication of new facilities; these bits may be stored as ones in the future.

STORE FACILITY LIST and STORE FACILITY LIST EXTENDED may report the absence of a facility, even though the execution of the facility’s instructions may appear to indicate that the facility is installed. The under-reporting of facility indications may occur because one or more systems in the computing environment (to which the application may be relocated) do not have the facility installed.

Programming Note: Prior to the introduction of z/Architecture, determination of the presence of a facility was often accomplished by means of a trial execution of an instruction. If an operation exception was not recognized during the trial execution, then it could be assumed that the facility was present.

Similarly, certain instructions provide a query function to determine the availability of other functions of the instruction or related instructions. However, a program might attempt to determine the availability of a particular function by trial execution of the function.

With the advent of facility and function indications in z/Architecture, the technique of trial execution should be avoided — particularly if a workload may be relocated to another system in which a facility’s instructions may not be present. In such an environment, STORE FACILITY LIST EXTENDED (STFLE) or an instruction’s query or test function may provide a more accurate indication of facilities and functions that are available on all systems in the computing environment.
Chapter 5. Program Execution

Instructions .......................... 5-3
Operands ............................... 5-3
Instruction Formats .................. 5-3
Register Operands .................... 5-7
Immediate Operands ................. 5-8
Storage Operands .................... 5-9
Address Generation .................. 5-10
Trimodal Addressing ................. 5-10
Sequential Instruction-Address Generation . 5-10
Operand-Address Generation ........ 5-10
Formation of the Intermediate Value . 5-10
Formation of the Operand Address .... 5-12
Branch-Address Generation ........ 5-12
Formation of the Intermediate Value . 5-12
Formation of the Branch Address .... 5-13
Instruction Execution and Sequencing 5-13
Decision Making ...................... 5-14
Loop Control .......................... 5-14
Subroutine Linkage without the Linkage Stack 5-14
Simple Branch Instructions .......... 5-14
Other Linkage Instructions .......... 5-16
Interruptions ......................... 5-22
Types of Instruction Ending .......... 5-22
Completion ............................ 5-22
Suppression .......................... 5-22
Nullification .......................... 5-23
Termination ........................... 5-23
Interruptible Instructions .......... 5-24
Point of Interruption ................. 5-24
Unit of Operation ..................... 5-24
Execution of Interruptible Instructions 5-24
Condition-Code Alternative to Interruptibility 5-25
Exceptions to Nullification and Suppression 5-26
Storage Change and Restoration for DAT-Associated Access Exceptions 5-27
Modification of DAT-Table Entries 5-27
Trial Execution for Editing Instructions and Translate Instruction 5-27
Authorization Mechanisms .......... 5-28
Mode Requirements ................... 5-28
Extra-Power-Authority Control ....... 5-29
PSW-Key Mask ......................... 5-29
Secondary-Space Control ............. 5-29
Subsystem-Linkage Control .......... 5-29
ASN-Translation Control ............. 5-29
Authorization Index ................. 5-30
Instructions and Controls Related to ASN-and-LX Reuse 5-30
PC-Number Translation ............... 5-34
PC-Number Translation Control ...... 5-35
Control Register 0 .................... 5-35
Control Register 5 .................... 5-35
PC-Number Translation Tables ...... 5-36
Linkage-Table Entries ............... 5-36
Linkage-First-Table Entries ......... 5-37
Linkage-Second-Table Entries ...... 5-37
Entry-Table Entries ................. 5-37
Table Summary ....................... 5-39
PC-Number-Translation Process ...... 5-39
Obtaining the Linkage-Table or Linkage-First-Table Designation 5-43
Linkage-Table Lookup ............... 5-43
Linkage-First-Table Lookup .......... 5-43
Linkage-Second-Table Lookup ......... 5-44
Linkage-Second-Table-Entry-SequenceNumber Comparison 5-44
Entry-Table Lookup ................... 5-44
Recall of Exceptions during PC-Number Translation 5-45
Home Address Space ................ 5-45
Access-Register Introduction ....... 5-46
Summary .............................. 5-46
Access-Register Functions .......... 5-47
Access-Register-Specified Address Spaces 5-47
Access-Register Instructions ........ 5-53
Access-Register Translation .......... 5-54
Access-Register-Translation Control 5-54
Control Register 2 .................... 5-54
Control Register 5 .................... 5-55
Control Register 8 .................... 5-55
Access Registers ..................... 5-55
Access-Register-Translation Tables 5-56
Dispatchable-Unit Control Table and
Access-List Designations .......... 5-56
Access-List Entries ................. 5-57
ASN-Second-Table Entries .......... 5-58
Access-Register-Translation Process 5-60
Selecting the Access-List-Entry Token 5-63
Obtaining the Primary or Secondary
Address-Space-Control Element .... 5-63
Checking the First Byte of the ALET 5-63
Obtaining the Effective Access-List
Designation .......................... 5-63
Access-List Lookup ................... 5-63
Locating the ASN-Second-Table Entry 5-64
Authorizing the Use of the Access-List
Entry .................. 5-64

© Copyright IBM Corp. 1990-2015 5-1
Normally, operation of the CPU is controlled by instructions in storage that are executed sequentially, one at a time, left to right in an ascending sequence of storage addresses. A change in the sequential operation may be caused by branching, LOAD PSW, interruptions, SIGNAL PROCESSOR orders, or manual intervention.

Instructions

Each instruction consists of two major parts:

- An operation code (op code), which specifies the operation to be performed
- The designation of the operands that participate.

Operands

Operands can be grouped in three classes: operands located in registers, immediate operands, and operands in storage. Operands may be either explicitly or implicitly designated.

Register operands can be located in general, floating-point, vector, access, or control registers, with the type of register identified by the op code. The register containing the operand is specified by identifying the register in a four-bit field, called the R field, in the instruction. For some instructions, an operand is located in an implicitly designated register, the register being implied by the op code. For vector registers, the register containing the operand is specified using a four-bit field with the addition of a register extension bit as the most significant bit.

Immediate operands are contained within the instruction, and the 8-bit, 16-bit, or 32-bit field containing the immediate operand is called the I field.

Operands in storage may have an implied length; be specified by a bitmask; be specified by a four-bit or eight-bit length specification, called the L field, in the instruction; or have a length specified by the contents of a general register. The addresses of operands in storage are specified by means of a format that uses the contents of a general register as part of the address. This makes it possible to:

1. Specify a complete address by using an abbreviated notation
2. Perform address manipulation using instructions which employ general registers for operands
3. Modify addresses by program means without alteration of the instruction stream
4. Operate independent of the location of data areas by directly using addresses received from other programs

The address used to refer to storage either is contained in a register designated by the R field in the instruction or is calculated from a base address, index, and displacement, specified by the B, X, and D fields, respectively, in the instruction.

When the CPU is in the access-register mode, a B or R field may designate an access register in addition to being used to specify an address.

To describe the execution of instructions, operands are designated as first and second operands and, in some cases, third, fourth, fifth, and sixth operands.

In general, two operands participate in an instruction execution, and the result replaces the first operand. However, CONVERT TO DECIMAL, TEST BLOCK, and instructions with “store” in the instruction name (other than STORE THEN AND SYSTEM MASK and STORE THEN OR SYSTEM MASK) use the second-operand address to designate a location in which to store. TEST AND SET, COMPARE AND SWAP, COMPARE AND SWAP AND STORE, and COMPARE DOUBLE AND SWAP may perform an update on the second operand. Except when otherwise stated, the contents of all registers and storage locations participating in the addressing or execution part of an operation remain unchanged.

Instruction Formats

An instruction is one, two, or three halfwords in length and must be located in storage on a halfword boundary. Each instruction is in one of the following basic formats: E, I, IE, MII, RI, RIE, RIL, RIS, RR, RRD, RRE, RRF, RSS, RS, RSI, RSL, RSY, RX, RXE, RXF, RXY, S, SI, SIL, SIY, SMI, SS, SSE, SSF, VRI, VRR, VRS, VRV, VRX, with two variations of RRF, RS, RSL, RSY, RX, and RXY, three of RI, RIL, and VRR, five of VRI, six of SS and VRR, and seven of RIE. Figure 5-1 illustrates the various instruction formats and variations. Where a letter appears to the left of a format variant, it represents one of the variations in assembler syntax as illu-
trated in the description of the instructions in chapters 7-10, 14, and 18-24.

<table>
<thead>
<tr>
<th>E Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>0 15</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>I Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>0 8 15</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>IE Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>0 15</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>MII Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>M1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 24 28 31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RI Formats</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>a. Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 31</td>
</tr>
<tr>
<td>b. Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 31</td>
</tr>
<tr>
<td>c. Op Code</td>
<td>M1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RIE Formats</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 8 12 16 32 36 40 47</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 32 36 40 47</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 32 40 47</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 32 36 40 47</td>
</tr>
<tr>
<td>e. Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 32 40 47</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 24 32 40 47</td>
</tr>
<tr>
<td>g. Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 32 40 47</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RIL Formats</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 8 12 16 47</td>
</tr>
<tr>
<td>b. Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 47</td>
</tr>
<tr>
<td>c. Op Code</td>
<td>M1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 47</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RIS Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 8 12 16 20 32 40 47</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RR Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 15</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RRD Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 16 20 24 28 31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RRE Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 15</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RRF Formats</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>a,b Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 16 20 24 28 31</td>
</tr>
<tr>
<td>c-e Op Code</td>
<td>M3</td>
</tr>
<tr>
<td></td>
<td>0 16 20 24 28 31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RRS Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 20 32 36 40 47</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RS Formats</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>a. Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 20 31</td>
</tr>
<tr>
<td>b. Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RSI Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RSL Format</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>a. Op Code</td>
<td>L1</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 20 32 40 47</td>
</tr>
<tr>
<td>b. Op Code</td>
<td>L2</td>
</tr>
<tr>
<td></td>
<td>0 8 12 16 20 32 40 47</td>
</tr>
</tbody>
</table>

Figure 5-1. Basic Instruction Formats (Part 1 of 5)

Figure 5-1. Basic Instruction Formats (Part 2 of 5)
<table>
<thead>
<tr>
<th>Formats</th>
<th>Op Code</th>
<th>RL1</th>
<th>RL2</th>
<th>DL2</th>
<th>DH2</th>
<th>Op Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>RSY Formats</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>a.</td>
<td>R1</td>
<td>R3</td>
<td>B2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>b.</td>
<td>R1</td>
<td>M3</td>
<td>B2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RX Formats</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>a.</td>
<td>R1</td>
<td>X2</td>
<td>B2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>b.</td>
<td>M1</td>
<td>X2</td>
<td>B2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RXE Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>R1</td>
<td>X2</td>
<td>B2</td>
<td>D2</td>
<td>M4</td>
<td></td>
</tr>
<tr>
<td>RXF Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>R3</td>
<td>X2</td>
<td>B2</td>
<td>D2</td>
<td>R1</td>
<td></td>
</tr>
<tr>
<td>RXY Formats</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>a.</td>
<td>R1</td>
<td>X2</td>
<td>B2</td>
<td>DL2</td>
<td>DH2</td>
<td></td>
</tr>
<tr>
<td>b.</td>
<td>M1</td>
<td>X2</td>
<td>B2</td>
<td>DL2</td>
<td>DH2</td>
<td></td>
</tr>
<tr>
<td>S Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>B2</td>
<td></td>
<td>D2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SI Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>I2</td>
<td>B1</td>
<td>D1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SIL Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>B1</td>
<td>D1</td>
<td>I2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SIY Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>I2</td>
<td>B1</td>
<td>DL1</td>
<td>DH1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SMI Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>M1</td>
<td></td>
<td>B3</td>
<td></td>
<td>R1</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Formats</th>
<th>Op Code</th>
<th>RL1</th>
<th>RL2</th>
<th>DL2</th>
<th>DH2</th>
<th>Op Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>SS Formats</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>a.</td>
<td>L or L1</td>
<td>B1</td>
<td>D1</td>
<td>B2</td>
<td>D2</td>
<td></td>
</tr>
<tr>
<td>b.</td>
<td>L1</td>
<td>L2</td>
<td>B1</td>
<td>D1</td>
<td>B2</td>
<td>D2</td>
</tr>
<tr>
<td>c.</td>
<td>L1</td>
<td>I3</td>
<td>B1</td>
<td>D1</td>
<td>B2</td>
<td>D2</td>
</tr>
<tr>
<td>d.</td>
<td>R1</td>
<td>R3</td>
<td>B1</td>
<td>D1</td>
<td>B2</td>
<td>D2</td>
</tr>
<tr>
<td>e.</td>
<td>R1</td>
<td>R3</td>
<td>B2</td>
<td>D2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>f.</td>
<td>L2</td>
<td>B1</td>
<td>D1</td>
<td>B2</td>
<td>D2</td>
<td></td>
</tr>
<tr>
<td>SSE Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>B1</td>
<td>D1</td>
<td>B2</td>
<td>D2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SSF Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>R3</td>
<td>B1</td>
<td>D1</td>
<td>B2</td>
<td>D2</td>
<td></td>
</tr>
<tr>
<td>RXE Format</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>R1</td>
<td>X2</td>
<td>B2</td>
<td>D2</td>
<td>M4</td>
<td></td>
</tr>
<tr>
<td>VRI Formats</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>a.</td>
<td>V1</td>
<td>I2</td>
<td></td>
<td>M4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>b.</td>
<td>V1</td>
<td>I2</td>
<td>I3</td>
<td>M4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>c.</td>
<td>V1</td>
<td>V2</td>
<td>I2</td>
<td>M4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>d.</td>
<td>V1</td>
<td>V2</td>
<td>V3</td>
<td>I4</td>
<td>M4</td>
<td></td>
</tr>
<tr>
<td>e.</td>
<td>V1</td>
<td>V2</td>
<td>I3</td>
<td>M4</td>
<td>M4</td>
<td>RXB</td>
</tr>
</tbody>
</table>

Figure 5-1. Basic Instruction Formats (Part 3 of 5)
The format names indicate, in general terms, the classes of operands which participate in the operation and some details about fields:

- **E** denotes an operation using implied operands and an extended op-code field.
- **I** denotes an immediate operation.
- **IE** denotes an immediate-and-immediate operation.
- **MII** denotes a masked immediate-and-immediate operation.
- **RI** denotes a register-and-immediate operation and an extended op-code field.
- **RIE** denotes a register-and-immediate operation and a longer extended op-code field.
- **RIL** denotes a register-and-immediate operation, an extended op-code field, and a longer immediate field.
- **RIS** denotes a register-and-immediate operation and a storage operation.
- **RR** denotes a register-and-register operation.
- **RRD** denotes a register-and-register operation, an extended op-code field, and an additional R field.
- **RRE** denotes a register-and-register operation and an extended op-code field.
- **RRF** denotes a register-and-register operation, an extended op-code field, and an additional R field, M field, or both.
- **RRS** denotes a register-and-register operation and a storage operation.
- **RS** denotes a register-and-storage operation.
- **RSI** denotes a register-and-immediate operation.
- **RSL** denotes a storage operation (with an instruction format derived from the ESA/390 RSE format).
- **RSY** denotes a register-and-storage operation, an extended op-code field, and a long displacement field.
- **RX** denotes a register-and-indexed-storage operation.
- **RXE** denotes a register-and-indexed-storage operation and an extended op-code field.
- **RXF** denotes a register-and-indexed-storage operation, an extended op-code field, and an additional R field.
- **RXY** denotes a register-and-indexed-storage operation, an extended op-code field, and a long displacement field.
- **S** denotes an operation using an implied operand and storage.
- **SI** denotes a storage-and-immediate operation.
- **SIL** denotes a storage-and-immediate operation, with a 16-bit immediate field.
SIY denotes a storage-and-immediate operation and a long displacement field.
SMI denotes a masked storage-and-immediate operation.
SS denotes a storage-and-storage operation.
SSE denotes a storage-and-storage operation and an extended op-code field.
SSF denotes a storage-and-storage operation and an extended op-code field.
VRI denotes a vector register-and-immediate operation and an extended op-code field.
VRR denotes a vector register-and-register operation and an extended op-code field.
VRS denotes a vector register-and-storage operation and an extended op-code field.
VRV denotes a vector register-and-vector-index-storage operation and an extended op-code field.
VRX denotes a vector register-and-index-storage operation and an extended op-code field.

In the I, RR, RS, RSI, RX, SI, and SS formats, the first byte of an instruction contains the op code. In the E, RRE, RRF, S, SI, and SSE formats, the first two bytes of an instruction contain the op code, except that for some instructions in the S format, the op code is in only the first byte. In the RI, RIL, and SSF formats, the op code is in the first byte and bit positions 12-15 of an instruction. In the RIE, RIS, RRS, RSL, RSY, RXE, RXF, RXY, SIY, VRI, VRR, VRS, and VRX formats, the op code is in the first byte and the sixth byte of an instruction.

The first two bits of the first or only byte of the op code specify the length and format of the instruction, as follows:

<table>
<thead>
<tr>
<th>Bit Positions 0-1</th>
<th>Instruction Length (in Halfwords)</th>
<th>Instruction Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>One</td>
<td>I / E / RR</td>
</tr>
<tr>
<td>01</td>
<td>Two</td>
<td>RX</td>
</tr>
<tr>
<td>10</td>
<td>Two</td>
<td>RI / RRD / RRE / RRF / RS / RSI / RX / S / SI</td>
</tr>
</tbody>
</table>

In the format illustration for each individual instruction description, the op-code field or fields show the op code as hexadecimal digits within single quotes. The hexadecimal representation uses 0-9 for the binary codes 0000-1001 and A-F for the binary codes 1010-1111.

The remaining fields in the format illustration for each instruction are designated by code names, consisting of one or two letters and possibly a subscript number. The subscript number denotes the operand to which the field applies.

Operation code 00 hex will never be assigned to an instruction implemented in the CPU.

Register Operands
In the RR, RRD, RRE, RRF, RX, RXE, RXF, RXY, RS, RSY, RSI, RI, RIE, and RIL formats, the contents of the register designated by the R1 field are called the first operand. The register containing the first operand is sometimes referred to as the “first-operand location,” and sometimes as “register R1.” In the RR, RRD, RRE, and RRF formats, the R2 field designates the register containing the second operand, and the R3 field may designate the same register as R1. In the RRD, RRF, RXF, RS, RSY, RSI, and RIE formats, the use of the R3 field depends on the instruction. In the RRF, RS, and RSY formats, the R3 field may instead be an M3 field specifying a mask. Certain forms of the RRF format include an M4 field specifying a mask.

The R field designates a general or access register in the general instructions, a general register in the control instructions, and a floating-point register or a general register in the floating-point instructions. However, in the instructions EXTRACT STACKED REGISTERS and LOAD ADDRESS EXTENDED, the R field designates both a general register and an access register, and, in the instructions LOAD CONTROL and STORE CONTROL, the R field designates a control register. (This paragraph refers only to register operands, not to the use of access registers in addressing storage operands.)

For access, floating-point, and vector registers, unless otherwise indicated in the individual instruction description, the register operand is one register in length (32 bits for an access register, 64 bits for a floating-point register, and 128 bits for a vector register), and the second operand is the same length as the first. For general and control registers, the register operand is in bit positions 32-63 of the 64-bit register or occupies the entire register, depending on the instruction.
The V field in VRI, VRR, VRS, VRV, and VRX formats, along with an extra bit designates a vector register operand. In the instructions VECTOR LOAD GR FROM VR ELEMENT, VECTOR LOAD VR ELEMENT FROM GR, VECTOR LOAD VR FROM GRS DISJOINT, VECTOR LOAD WITH LENGTH, and VECTOR STORE WITH LENGTH one or more of the V fields might specify a general register as described in the instruction description.

All vector instructions have a field in bits 36-39 of the instruction labeled as RXB. This field contains the most significant bits for all of the vector register designated operands. Bits for register designations not specified by the instruction are reserved and should be set to zero; otherwise, the program may not operate compatibly in the future. The most significant bit is concatenated to the left of the four-bit register designation to create the five-bit vector register designation.

The bits of the RXB field are defined as follows:

0. Most significant bit for the vector register designation in bits 8-11 of the instruction.
1. Most significant bit for the vector register designation in bits 12-15 of the instruction.
2. Most significant bit for the vector register designation in bits 16-19 of the instruction.
3. Most significant bit for the vector register designation in bits 32-35 of the instruction.

**Programming Note:** Although only two RRF formats are shown in Figure 5-1, five variations are noted. This is because there are five variations in assembler-language syntax for the RRF-format instructions, as shown below.

<table>
<thead>
<tr>
<th>Variation</th>
<th>Assembler Syntax</th>
</tr>
</thead>
<tbody>
<tr>
<td>a</td>
<td>mnemonic R_i,R_j[,R_k,M_l]</td>
</tr>
<tr>
<td>b</td>
<td>mnemonic R_i,R_j[,M_l]</td>
</tr>
<tr>
<td>c</td>
<td>mnemonic R_i,R_j[M_l]</td>
</tr>
<tr>
<td>d</td>
<td>mnemonic R_i,M_j</td>
</tr>
<tr>
<td>e</td>
<td>mnemonic R_i,M_j,R_k[M_l]</td>
</tr>
</tbody>
</table>

**Immediate Operands**

In the I format, the contents of the eight-bit immediate-data field, the I field of the instruction, are directly used as the operand.

In the SI format, the contents of the eight-bit immediate-data field, the I_2 field of the instruction, are used directly as the second operand. The I_1 and D_1 fields specify the first operand, which is one byte in length. In the SIY format, the operation is the same except that DH_1 and DL_1 fields are used instead of a D_1 field.

In the RI format for the instructions ADD HALFWORD IMMEDIATE, COMPARE HALFWORD IMMEDIATE, LOAD HALFWORD IMMEDIATE, and MULTIPLY HALFWORD IMMEDIATE, the contents of the 16-bit I_2 field of the instruction are used directly as a signed binary integer, and the R_1 field specifies the first operand, which is 32 or 64 bits in length, depending on the instruction. For the instruction TEST UNDER MASK (TMHH, TMHL, TMLH, TMLL), the contents of the I_2 field are used as a mask, and the R_1 field specifies the first operand, which is 64 bits in length.

For the instructions INSERT IMMEDIATE, AND IMMEDIATE, OR IMMEDIATE, and LOAD LOGICAL IMMEDIATE, the contents of the I_2 field are used as an unsigned binary integer or a logical value, and the R_1 field specifies the first operand, which is 64 bits in length.

For instructions in the RI, RIE, and RSI formats having an RI_2 field, or for instructions in the RIE format having an RI_4 field, the contents of the 16-bit RI_2 or RI_4 field are used as a signed binary integer designating a number of halfwords that are added to the address of the instruction to form the operand address. For instructions in the RIL format, the RI_2 field is 32 bits and is used in the same way.

For instructions in the MII format, the contents of the 12-bit RI_2 field and the 24-bit RI_3 field are used as signed binary integers designating a number of halfwords that are added to the address of the instruction to form the respective operand addresses.

For instructions in the SMI format, the contents of the 16-bit RI_2 field is used as signed binary integer designating a number of halfwords that are added to the address of the instruction to form the operand address.
For the RIE-format instructions COMPARE IMMEDIATE AND BRANCH RELATIVE and COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE, the contents of the 8-bit I2 field are used directly as the second operand. For the RIE-format instructions COMPARE IMMEDIATE AND BRANCH, COMPARE IMMEDIATE AND TRAP, COMPARE LOGICAL IMMEDIATE AND BRANCH, and COMPARE LOGICAL IMMEDIATE AND TRAP, the contents of the 16-bit I2 field are used directly as the second operand. For the RIE-format instructions COMPARE AND BRANCH RELATIVE, COMPARE IMMEDIATE AND BRANCH RELATIVE, COMPARE LOGICAL AND BRANCH RELATIVE, and COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE, the contents of the 16-bit I4 field are used as a signed binary integer designating a number of halfwords that are added to the address of the instruction to form the branch address.

For the RIL-format instructions ADD IMMEDIATE, ADD LOGICAL IMMEDIATE, ADD LOGICAL WITH SIGNED IMMEDIATE, COMPARE IMMEDIATE, COMPARE LOGICAL IMMEDIATE, LOAD IMMEDIATE, and MULTIPLY SINGLE IMMEDIATE, the contents of the 32-bit I2 field are used directly as the second operand.

For the RIS-format instructions, the contents of the 8-bit I2 field are used directly as the second operand.

In the SIL format, the contents of the 16-bit I2 field are used directly as the second operand. The B1 and D1 fields specify the first operand, as described below.

In the VRI-a format, the contents of the 16-bit I2 field are used as a signed binary integer, except for VECTOR GENERATE BYTE MASK where the contents of the I2 field are used as a bitmask. In the VRI-b format, the contents of the 8-bit I2 and I0 fields contain unsigned binary integers. In the VRI-c format, the I2 field contains a 16-bit unsigned binary integer. In the VRI-d format, the contents of the 8-bit I2 field contain an unsigned binary integer. In the VRI-e format the 12-bit I3 field contains a bitmask.

Storage Operands
The use of B and R fields to designate access registers to refer to storage operands is described in “Access-Register-Specified Address Spaces” on page 5-47.

In the RSL, SI, SIL, SSE, and most SS formats, the contents of the general register designated by the B1 field are added to the contents of the D1 field to form the first-operand address. In the RS, RSY, S, SIY, SS, SSE, SSF, and VRS formats, the contents of the general register designated by the B2 field are added to the contents of the D2 field or DH2 and DL2 fields to form the second-operand address. In the RX, RXE, RXF, RXY, and VRX formats, the contents of the general registers designated by the X2 and B2 fields are added to the contents of the D2 field or DH2 and DL2 fields to form the second-operand address. In the SMI format, the contents of the general register designated by the B3 field are added to the contents of the D4 field to form the third-operand address. In the RIS and RRS formats, and in one SS format, the contents of the general register designated by the B4 field are added to the contents of the D4 field to form the fourth-operand address.

The VRV format has a vector-element-specified index field.

When a general register contains a 24-bit or 32-bit length of a storage operand, the length is an unsigned binary integer, except that it is signed for COMPARE UNTIL SUBSTRING EQUAL, with a negative value treated as zero. Similarly, the contents of an L, L1, or L2 field of an instruction are an unsigned binary integer. For VRS format instructions which contain a length in a general register the length is an unsigned integer that specifies the number of additional operand bytes to the right of the byte designated by the second operand address.

In the SS format with a single, eight-bit length field, for the instructions AND (NC), EXCLUSIVE OR (XC), MOVE (MVC), MOVE NUMERICS, MOVE ZONES, and OR (OC), L specifies the number of additional operand bytes to the right of the byte designated by the first-operand address. Therefore, the length in bytes of the first operand is 1-256, corresponding to a length code in L of 0-255. Storage results replace the first operand and are never stored outside the field specified by the address and length. In this format, the second operand has the same length as the first operand. There are variations of the preceding definition that apply to EDIT, EDIT AND MARK, PACK ASCII, PACK UNICODE, TRANSLATE, TRANSLATE AND TEST, UNPACK ASCII, and UNPACK UNICODE.

In the SS format with two length fields, and in the RSL format, L1 specifies the number of additional
operand bytes to the right of the byte designated by the first-operand address. Therefore, the length in bytes of the first operand is 1-16, corresponding to a length code in \( L_1 \) of 0-15. Similarly, \( L_2 \), specifies the number of additional operand bytes to the right of the location designated by the second-operand address. Results replace the first operand and are never stored outside the field specified by the address and length. If the first operand is longer than the second, the second operand is extended on the left with zeros up to the length of the first operand. This extension does not modify the second operand in storage.

In the SS format with two R fields, as used by the MOVE TO PRIMARY, MOVE TO SECONDARY, and MOVE WITH KEY instructions, the contents of the general register specified by the \( R_n \) field are a 32-bit unsigned value called the true length. The operands are both of a length called the effective length. The effective length is equal to the true length or 256, whichever is less. The instructions set the condition code to facilitate programming a loop to move the total number of bytes specified by the true length. The SS format with two R fields is also used to specify a range of registers and two storage operands for the LOAD MULTIPLE DISJOINT instruction and to specify one or two registers and one or two storage operands for the PERFORM LOCKED OPERATION instruction.

Address Generation

Trimodal Addressing

Bits 31 and 32 of the current PSW are the addressing-mode bits. Bit 31 is the extended-addressing-mode bit, and bit 32 is the basic-addressing-mode bit. These bits control the size of the effective address produced by address generation. When bits 31 and 32 of the current PSW both are zeros, the CPU is in the 24-bit addressing mode, and 24-bit instruction and operand effective addresses are generated. When bit 31 of the current PSW is zero and bit 32 is one, the CPU is in the 31-bit addressing mode, and 31-bit instruction and operand effective addresses are generated. When bits 31 and 32 of the current PSW are both one, the CPU is in the 64-bit addressing mode, and 64-bit instruction and operand effective addresses are generated.

Execution of instructions by the CPU involves generation of the addresses of instructions and operands. This section describes address generation as it applies to most instructions. In some instructions, the operation performed does not follow the general rules stated in this section. All of these exceptions are explicitly identified in the individual instruction descriptions.

Sequential Instruction-Address Generation

When an instruction is fetched from the location designated by the current PSW, the instruction address is increased by the number of bytes in the instruction, and the instruction is executed. The same steps are then repeated by using the new value of the instruction address to fetch the next instruction in the sequence.

In the 24-bit addressing mode, instruction addresses wrap around, with the halfword at instruction address \( 2^{24} - 2 \) being followed by the halfword at instruction address 0. Thus, in the 24-bit addressing mode, any carry out of PSW bit position 104, as a result of updating the instruction address, is lost. In the 31-bit or 64-bit addressing mode, instruction addresses similarly wrap around, with the halfword at instruction address \( 2^{31} - 2 \) or \( 2^{64} - 2 \), respectively, followed by the halfword at instruction address 0. A carry out of PSW bit position 97 or 64, respectively, is lost.

Operand-Address Generation

Formation of the Intermediate Value

An operand address that refers to storage is derived from an intermediate value determined in one of the following ways:

- The intermediate value is calculated from the sum of two or three binary numbers: base address, index (when applicable), and displacement.
- The intermediate value is calculated from the sum of three binary numbers: base address, displacement, and vector element.
- The intermediate value is calculated from the sum of two binary numbers: the address of the instruction and an immediate (\( R_{12} \)) field in the instruction specifying a number of halfwords.
The intermediate value is contained in a register designated by an R field in the instruction.

**Intermediate Value Designated by Base Address, Index, and Displacement:** The base address (B) is a 64-bit number contained in a general register specified by the program in a four-bit field, called the B field, in the instruction. Base addresses can be used as a means of independently addressing each program and data area. In array-type calculations, it can designate the location of an array, and, in record-type processing, it can identify the record. The base address provides for addressing the entire storage. The base address may also be used for indexing.

For instructions having the RX, RXE, RXF, RXY, and VRX-formats, the index (X) is a 64-bit number contained in a general register designated by the program in a four-bit field, called the X field, in the instruction. These instructions permit double indexing; that is, the index can be used to provide the address of an element within an array. For other instruction formats which do not include an X field, the index is not applicable.

The displacement (D) is a 12-bit or 20-bit number contained in a field, called the D field, in the instruction. A 12-bit displacement is unsigned and provides for relative addressing of up to 4,095 bytes beyond the location designated by the base address. A 20-bit displacement is signed and provides for relative addressing of up to 524,287 bytes beyond the base-address location or of up to 524,288 bytes before it. In array-type calculations, the displacement can be used to specify one of many items associated with an element. In the processing of records, the displacement can be used to identify items within a record.

A 12-bit displacement is in bit positions 20-31 of instructions of certain formats (see Figure 5-1 on page 5-4). In instructions of some formats, a second 12-bit displacement also is in the instruction, in bit positions 36-47.

A 20-bit displacement is in instructions of only the RSY, RXY, or SIY format. In these instructions, the D field consists of a DL (low) field in bit positions 20-31 and of a DH (high) field in bit positions 32-39. When the long-displacement facility is installed, the numeric value of the displacement is formed by appending the contents of the DH field on the left of the contents of the DL field. When the long-displacement facility is not installed, the numeric value of the displacement is formed by appending eight zero bits on the left of the contents of the DL field, and the contents of the DH field are ignored.

In forming the intermediate sum, the base address and index are treated as 64-bit binary integers. A 12-bit displacement is treated as a 12-bit unsigned binary integer, and 52 zero bits are appended on the left. A 20-bit displacement is treated as a 20-bit signed binary integer, and 44 bits equal to the sign bit are appended on the left. The three are added as 64-bit binary numbers, ignoring overflow. The sum is always 64 bits long and is used as an intermediate value to form the generated address. The bits of the intermediate value are numbered 0-63.

A zero in any of the B1, B2, X2, B3, or B4 fields indicates the absence of the corresponding address component. For the absent component, a zero is used in forming the intermediate sum, regardless of the contents of general register 0. A displacement of zero has no special significance.

**Intermediate Value Designated by Base Address, Displacement, and Vector Element:** For VRV format instructions, a vector element is used in the formation of the intermediate value. This vector element is an unsigned binary integer value that is added to the base address and 12-bit displacement to form a 64-bit intermediate sum. The vector element is designated by a vector register and an element index. A zero V field accesses the element in vector register zero and does not imply a zero value.

**Intermediate Value Designated by an Immediate Field:** For the following instructions, the intermediate value is determined using an immediate (RIi) field in the instruction:

- BRANCH PREDICTION PRELOAD
- BRANCH PREDICTION RELATIVE PRELOAD
- COMPARE HALFWORD RELATIVE LONG
- COMPARE LOGICAL RELATIVE LONG
- COMPARE RELATIVE LONG
- EXECUTE RELATIVE LONG
- LOAD ADDRESS RELATIVE LONG
- LOAD HALFWORD RELATIVE LONG
- LOAD LOGICAL HALFWORD RELATIVE LONG
- LOAD LOGICAL RELATIVE LONG
- LOAD RELATIVE LONG
- PREFETCH DATA RELATIVE LONG
- STORE HALFWORD RELATIVE LONG
- STORE RELATIVE LONG
For BRANCH PREDICTION PRELOAD, the RI2 field contains a 16-bit signed binary integer; for BRANCH PREDICTION RELATIVE PRELOAD, the RI2 field contains a 12-bit signed binary integer; and for each of the other instructions listed, the RI2 field contains a 32-bit signed binary integer. The signed binary integer specifies the number of halfwords that is added to the address of the current instruction to form the intermediate value.

When DAT is on, and the intermediate value is designated by an immediate field, the resulting operand address is in the same address space as that used to fetch instructions.

**Intermediate Value in a Register Designated by an R Field:** When an instruction description specifies that the contents of a general register designated by an R field are used to address an operand in storage, the register contents are used as the 64-bit intermediate value.

An instruction can designate the same general register both for address computation and as the location of an operand. Address computation is completed before registers, if any, are changed by the operation.

**Formation of the Operand Address**

Unless otherwise indicated in an individual instruction definition, the generated operand address designates the leftmost byte of an operand in storage.

The generated operand address is always 64 bits long, and the bits are numbered 0-63. The manner in which the generated address is obtained from the intermediate value depends on the current addressing mode. In the 24-bit addressing mode, bits 0-39 of the intermediate value are ignored, bits 0-39 of the generated address are forced to be zeros, and bits 40-63 of the intermediate value become bits 40-63 of the generated address. In the 31-bit addressing mode, bits 0-32 of the intermediate value are ignored, bits 0-32 of the generated address are forced to be zero, and bits 33-63 of the intermediate value become bits 33-63 of the generated address. In the 64-bit addressing mode, bits 0-63 of the intermediate value become bits 0-63 of the generated address.

**Programming Note:** Since a carry out of the most-significant address bit is ignored, negative values may be used in index and base-address registers. Bits 0-32 of these values are ignored in the 31-bit addressing mode, and bits 0-39 are ignored in the 24-bit addressing mode.

For instructions having the RSY, RXY, or SIY format, a negative value may be used for the displacement.

When the intermediate value is designated by an immediate field in the instruction, the immediate field may contain a negative value.

**Branch-Address Generation**

**Formation of the Intermediate Value**

For branch instructions, the address of the next instruction to be executed when the branch is taken is called the branch address. Depending on the branch instruction, the instruction format may be RR, RRE, RX, RXY, RS, RSY, RSI, RI, RIE, or RIL.

In the RS, RSY, RX, and RXY formats, the branch address is specified by a base address, a displacement, and, in the RX and RXY formats, an index. In these formats, the generation of the intermediate value follows the same rules as for the generation of the operand-address intermediate value.

In the RR and RRE formats, the contents of the general register designated by the R2 field are used as the intermediate value from which the branch address is formed. Unless otherwise specified, general register 0 cannot be designated as containing a branch address, and a value of zero in the R2 field causes the instruction to be executed without branching.

The relative-branch instructions are in the RSI, RI, RIE, and RIL formats. In the RSI, RI, and RIE formats for the relative-branch instructions, the contents of the I2 field are treated as a 16-bit signed binary integer designating a number of halfwords. In the RIL format, the contents of the I2 field are treated as a 32-bit signed binary integer designating a number of halfwords. The branch address is the number of halfwords designated by the I2 field added to the address of the relative-branch instruction.

The 64-bit intermediate value for a relative branch instruction in the RSI, RI, RIE, or RIL format is the sum of two addends, with overflow from bit position 0 ignored. In the RSI, RI, or RIE format, the first addend is the contents of the I2 field with one zero bit appended on the right and 47 bits equal to the sign bit of the contents appended on the left, except that...
for COMPARE AND BRANCH RELATIVE, COMPARE IMMEDIATE AND BRANCH RELATIVE, COMPARE LOGICAL AND BRANCH RELATIVE and COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE, the first addend is the contents of the I$_4$ field, with bits appended as described above for the I$_2$ field. In the RIL format, the first addend is the contents of the I$_2$ field with one zero bit appended on the right and 31 bits equal to the sign bit of the contents appended on the left. In all formats, the second addend is the 64-bit address of the branch instruction. The address of the branch instruction is the instruction address in the PSW before that address is updated to address the next sequential instruction, or it is the address of the target of the execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG) if an execute-type instruction is used. If an execute-type instruction is used in the 24-bit or 31-bit addressing mode, the address of the branch instruction is the target address with 40 or 33 zeros, respectively, appended on the left.

Formation of the Branch Address

The branch address is always 64 bits long, with the bits numbered 0-63. The branch address replaces bits 64-127 of the current PSW.

The manner in which the branch address is obtained from the intermediate value depends on the addressing mode. For those branch instructions which change the addressing mode, the new addressing mode is used. In the 24-bit addressing mode, bits 0-39 of the intermediate value are ignored, bits 0-39 of the branch address are made zeros, and bits 40-63 of the intermediate value become bits 40-63 of the branch address. In the 31-bit addressing mode, bits 0-32 of the intermediate value are ignored, bits 0-32 of the branch address are made zeros, and bits 33-63 of the intermediate value become bits 33-63 of the branch address. In the 64-bit addressing mode, bits 0-63 of the intermediate value become bits 0-63 of the branch address.

For several branch instructions, branching depends on satisfying a specified condition. When the condition is not satisfied, the branch is not taken, normal sequential instruction execution continues, and the branch address is not used. When a branch is taken, bits 0-63 of the branch address replace bits 64-127 of the current PSW. The branch address is not used to access storage as part of the branch operation.

A specification exception due to an odd branch address and access exceptions due to fetching of the instruction at the branch location are not recognized as part of the branch operation but instead are recognized as exceptions associated with the execution of the instruction at the branch location.

A branch instruction, such as BRANCH AND SAVE, can designate the same general register for branch-address computation and as the location of an operand. Branch-address computation is completed before the remainder of the operation is performed.

Some models may maintain information in internal tables about branch instructions and branch addresses for internal branch-prediction logic. Additionally, since the formation of branch addresses is similar to the formation of the target addresses of execute-type instructions, some models may also maintain information about execute-type instructions and their execute targets in the same or similar internal tables. A model may also provide the BRANCH PREDICTION PRELOAD and BRANCH PREDICTION RELATIVE PRELOAD instructions which allow the program to identify branch instructions and associated branch addresses, and to identify execute-type instructions and associated execute targets, thereby affecting the preloading of such branch-prediction and execute-prediction information into such internal tables.

Instruction Execution and Sequencing

The program-status word (PSW), described in Chapter 4 “Control” contains information required for proper program execution. The PSW is used to control instruction sequencing and to hold and indicate the status of the CPU in relation to the program currently being executed. The active or controlling PSW is called the current PSW.

Branch instructions perform the functions of decision making, loop control, and subroutine linkage. A branch instruction affects instruction sequencing by introducing a new instruction address into the current PSW. The relative-branch instructions with a 16-bit I$_2$ field allow branching to a location at an offset of up to plus 64K - 2 bytes or minus 64K bytes relative to the location of the branch instruction, without the use of a base register. The relative-branch instructions with a
32-bit $I_2$ field allow branching to a location at an offset of up to plus 4G - 2 bytes or minus 4G bytes relative to the location of the branch instruction, without the use of a base register.

**Decision Making**

Facilities for decision making are provided by the BRANCH ON CONDITION, BRANCH RELATIVE ON CONDITION, and BRANCH RELATIVE ON CONDITION LONG instructions. These instructions inspect a condition code that reflects the result of a majority of the arithmetic, logical, and I/O operations. The condition code, which consists of two bits, provides for four possible condition-code settings: 0, 1, 2, and 3.

The specific meaning of any setting depends on the operation that sets the condition code. For example, the condition code reflects such conditions as zero, nonzero, first operand high, equal, overflow, and subchannel busy. Once set, the condition code remains unchanged until modified by an instruction that causes a different condition code to be set. See Appendix C, “Condition-Code Settings” for a summary of the instructions which set the condition code.

**Loop Control**

Loop control can be performed by the use of BRANCH ON CONDITION, BRANCH RELATIVE ON CONDITION, and BRANCH RELATIVE ON CONDITION LONG to test the outcome of address arithmetic and counting operations. For some particularly frequent combinations of arithmetic and tests, BRANCH ON COUNT, BRANCH ON INDEX HIGH, and BRANCH ON INDEX LOW OR EQUAL are provided, and relative-branch equivalents of these instructions are also provided. These branches, being specialized, provide increased performance for these tasks.

**Subroutine Linkage without the Linkage Stack**

This section describes only the methods for subroutine linkage that do not use the linkage stack. For the linkage extensions provided by the linkage stack, see “Linkage-Stack Introduction” on page 5-71. (Those extensions include a different method of operation of the PROGRAM CALL instruction and also the BRANCH AND STACK and PROGRAM RETURN instructions.)

**Simple Branch Instructions**

Subroutine linkage when a change of the addressing mode is not required is provided by the BRANCH AND LINK and BRANCH AND SAVE instructions. (This discussion of BRANCH AND SAVE applies also to BRANCH RELATIVE AND SAVE and BRANCH RELATIVE AND SAVE LONG.) Both of these instructions permit not only the introduction of a new instruction address but also the preservation of a return address and associated information. The return address is the address of the instruction following the branch instruction in storage, except that it is the address of the instruction following an execute-type instruction that has the branch instruction as its target.

Both BRANCH AND LINK and BRANCH AND SAVE have an $R_1$ field. They form a branch address by means of fields that depend on the instruction. The operations of the instructions are summarized as follows:

- In the 24-bit addressing mode, both instructions place the return address in bit positions 40-63 of general register $R_1$, and leave bits 0-31 of that register unchanged. BRANCH AND LINK places the instruction-length code for the instruction and also the condition code and program mask from the current PSW in bit positions 32-39 of general register $R_1$. BRANCH AND SAVE places zeros in those bit positions.

- In the 31-bit addressing mode, both instructions place the return address in bit positions 33-63 and a one in bit position 32 of general register $R_1$, and they leave bits 0-31 of the register unchanged.

- In the 64-bit addressing mode, both instructions place the return address in bit positions 0-63 of general register $R_1$.

- In any addressing mode, both instructions generate the branch address under the control of the current addressing mode. The instructions place bits 0-63 of the branch address in bit positions 64-127 of the PSW. In the RR format, both instructions do not perform branching if the $R_2$ field of the instruction is zero.
It can be seen that, in the 24-bit or 31-bit addressing mode, BRANCH AND SAVE places the basic-addressing-mode bit, bit 32 of the PSW, in bit position 32 of general register R1. BRANCH AND LINK does so in the 31-bit addressing mode.

The instructions BRANCH AND SAVE AND SET MODE and BRANCH AND SET MODE are for use when a change of the addressing mode is required during linkage. These instructions have R1 and R2 fields. The operations of the instructions are summarized as follows:

- BRANCH AND SAVE AND SET MODE sets the contents of general register R1 the same as BRANCH AND SAVE. In addition, the instruction places the extended-addressing-mode bit, bit 31 of the PSW, in bit position 63 of the register.

- BRANCH AND SET MODE, if R1 is nonzero, performs as follows. In the 24- or 31-bit mode, it places bit 32 of the PSW in bit position 32 of general register R1, and it leaves bits 0-31 and 33-63 of the register unchanged. Note that bit 63 of the register should be zero if the register contains an instruction address. In the 64-bit mode, the instruction places bit 31 of the PSW (a one) in bit position 63 of general register R1, and it leaves bits 0-62 of the register unchanged.

- When R2 is nonzero, both instructions set the addressing mode and perform branching as follows. Bit 63 of general register R2 is placed in bit position 31 of the PSW. If bit 63 is zero, bit 32 of the register is placed in bit position 32 of the PSW. If bit 63 is one, PSW bit 32 is set to one. Then the branch address is generated from the contents of the register, except with bit 63 of the register treated as a zero, under the control of the new addressing mode. The instructions place bits 0-63 of the branch address in bit positions 64-127 of the PSW. Bit 63 of general register R2 remains unchanged and, therefore, may be one upon entry to the called program. If R2 is the same as R1, the results in the designated general register are as specified for the R1 register.

The operations of the simple branch instructions are summarized in Figure 5-2 on page 5-16. For contrast, the figure also shows the BRANCH ON COUNT instruction, which is not for use in linkage, and the LOAD ADDRESS and LOAD ADDRESS EXTENDED instructions.

Programming Notes:

1. A called program that is entered in the 64-bit addressing mode can use bit 63 of the entry-point register to determine the instruction used to perform the call and, thus, the instruction that must be used to perform the return linkage. If bit 63 is zero, BRANCH AND SAVE (BAS or BASR) (or possibly BAL, BALR, BRAS, or BRASL) was used, the addressing mode of the caller is not indicated in the return register, and BRANCH ON CONDITION (BCR) must be used to return without changing the addressing mode during the return. If bit 63 of the entry-point register is one, BASSM or BSM was used, the addressing mode of the caller is indicated in the return register (or at least can be, in the case of BSM), and BSM must be used to return and restore the addressing mode of the caller.

2. When BSM is executed in the 24-bit or 31-bit addressing mode and used in a forward linkage to set the 64-bit mode, and the R1 and R2 of the instruction are the same value, bit 63 of the designated general register does not, upon entry to the called program, correctly indicate the mode of the calling program. (The bit is one, instead of zero, because the program set bit 63 of the R2 register to one and the instruction does not change bit 63 of the R1 register in the 24- or 31-bit mode.) BASSM always correctly indicates the addressing mode of the calling program.

3. If an entry point can be branched to in the 64-bit addressing mode either by BAS or BASR or by BASSM or BSM, and a USING statement provides addressability to the entry point, bit 63 of the entry-point register must be zeroed to ensure compatible operation regardless of whether the linkage instruction changes the addressing mode. For example, if general register 15 is the entry-point register, the following may be used to set bit 63 to zero.

\[\text{NILL 15,X'FFFFE'}\]

If the entry point can be branched to in the 64-bit addressing mode only by BASSM or BSM, the entry-point USING statement can accommodate bit 63 being one – without having to zero the bit – as shown below.

\[\text{USING } ^{+1,15} \]
### Other Linkage Instructions

**Note:** The discussion in this section of PROGRAM TRANSFER applies equally to PROGRAM TRANSFER WITH INSTANCE, which differs from PROGRAM TRANSFER only as described in “ASN-Second-Table-Entry Instance Number and ASN Reuse” on page 3-22.
PROGRAM TRANSFER WITH INSTANCE is not further referred to in this section.

Linkage between a problem-state program and the supervisor or monitoring program is provided by means of the SUPERVISOR CALL and MONITOR CALL instructions.

The instructions PROGRAM CALL and PROGRAM TRANSFER provide the facility for linkage between programs of different authority and in different address spaces. PROGRAM CALL permits linkage to a number of preassigned programs that may be in either the problem or the supervisor state and may be in either the same address space or an address space different from that of the caller. It permits a change between the 24-bit and 31-bit addressing modes, and it permits an increase of PSW-key-mask authority, which authorizes the execution of the SET PSW KEY FROM ADDRESS instruction and also other functions. In general, PROGRAM CALL is used to transfer control to a program of higher authority.

PROGRAM TRANSFER permits a change of the instruction address and address space and a change between the 24-bit and 31-bit addressing modes. PROGRAM TRANSFER also permits a reduction of PSW-key-mask authority and a change from the supervisor to the problem state. In general, it is used to transfer control from one program to another of equal or lower authority.

When a calling linkage is to increase authority, the calling linkage can be performed by PROGRAM CALL and the return linkage by PROGRAM TRANSFER. Alternatively, when the calling linkage is to decrease authority, the calling linkage can be performed by PROGRAM TRANSFER and the return linkage by PROGRAM CALL.

The operation of PROGRAM CALL is controlled by means of an entry-table entry, which is located as part of a table-lookup process during the execution of the instruction. The entry-table entry specifies either a basic (nonstacking) operation or the stacking operation described in "Linkage-Stack Introduction" on page 5-71. The instruction causes the primary address space to be changed only when the ASN in the entry-table entry is nonzero. When the primary address space is changed, the operation is called PROGRAM CALL with space switching (PC-ss). When the primary address space is not changed, the operation is called PROGRAM CALL to current primary (PC-cp).

PROGRAM TRANSFER specifies the address space which is to become the new primary address space. When the primary address space is changed, the operation is called PROGRAM TRANSFER with space switching (PT-ss). When the primary address space is not changed, the operation is called PROGRAM TRANSFER to current primary (PT-cp).

Basic PROGRAM CALL, and PROGRAM TRANSFER, can be executed successfully in either a basic (24-bit or 31-bit) addressing mode or the extended (64-bit) addressing mode. They do not provide a change between a basic addressing mode and the extended addressing mode.

The BRANCH AND SET AUTHORITY instruction can improve performance by replacing a PT-cp instruction used to perform a calling linkage in which PSW-key-mask authority is reduced, and by replacing a PC-cp instruction used to perform the associated return linkage in which PSW-key-mask authority is restored. BRANCH AND SET AUTHORITY also permits changes between the supervisor and problem states, and it can replace SET PSW KEY FROM ADDRESS by changing the PSW key during the linkage. The calling-linkage operation is called BRANCH AND SET AUTHORITY in the base-authority state (BSA-ba), and the return-linkage operation is called BRANCH AND SET AUTHORITY in the reduced-authority state (BSA-ra).

The BRANCH IN SUBSPACE GROUP instruction allows linkage within a group of address spaces called a subspace group, where one address space in the group is called the base space and the others are called subspaces. It is intended that each subspace contain a different subset of the storage in the base space, that the base space and each subspace contain a subsystem control program, such as CICS, and application programs, and that each subspace contain the data for a single transaction being processed under the subsystem control program. The placement of the data for each transaction in a different subspace prevents a program that is being executed to process one particular transaction from erroneously damaging the data of other transactions. It is intended that the primary address space be the base space when the control program is being executed, and that it be the subspace for a transaction when an application program is being executed to process that transaction. BRANCH IN SUBSPACE GROUP changes not only the instruction address in the PSW but also the primary address-space-control element in control register 1. BRANCH IN SUB-
SPACE GROUP does not change the primary ASN in control register 4 or the primary-ASN-second-table-entry origin in control register 5, and, therefore, the base space and the subspaces all are associated with the same ASN, and the programs in those address spaces all are of equal authority.

Although a subspace is intended to be a subset of the base space as described above, BRANCH IN SUBSPACE GROUP does not require this, and the instruction may be useful in ways other than as described above.

BRANCH IN SUBSPACE GROUP uses an access-list-entry token (ALET) in an access register as an identifier of the address space that is to receive control. The instruction saves the updated instruction address to permit a return linkage, but it does not save an identifier of the address space from which control was transferred. However, an ALET equal to 00000000 hex, called ALET 0, can be used to return from a subspace to the base space, and an ALET equal to 00000001 hex, called ALET 1, can be used to return from the base space to the subspace that last had control.

The SET ADDRESSING MODE (SAM24, SAM31, SAM64) instruction can assist in linkage by setting the 24-bit, 31-bit, or 64-bit addressing mode either before or after a linkage operation.

The RESUME PROGRAM instruction is intended for use by a problem-state interruption-handling program to return to the interrupted program. The interruption-handling program can use LOAD ACCESS MULTIPLE and LOAD MULTIPLE instructions to restore the contents of the interrupted program's access and general registers from a save area, except for the contents of one access-and-general register pair. The interruption-handling program then can use RESUME PROGRAM to restore the contents of certain PSW fields, including the instruction address, and also the contents of the remaining access-and-general pair from the save area, with that pair first being used by RESUME PROGRAM to address the save area.

The TRAP instruction (TRAP2, TRAP4) can overlay instructions in an application program and give control to a trap program for performing fix-ups of data used by the application program. The RESUME PROGRAM instruction can be used to return control from the trap program to the application program.

The linkage instructions provided and the functions performed by each are summarized in Figure 5-3 on page 5-19.

Programming Note: This note describes the simple branch-type linkage instructions that were included in 370-XA and carried forward to ESA/370, ESA/390, and z/Architecture. To give the reader a better understanding of the utility and intended usage of these linkage instructions, the following paragraphs in this note describe various program linkages and conventions and the use of the linkage instructions in these situations.

The linkage instructions were originally provided to permit System/370 programs to operate with no modification or only slight modification on 370/XA (and successor) systems and also to provide additional function for those programs which were designed to take advantage of the 31-bit addressing of 370/XA. The instructions provided the capability for both old and new programs to coexist in storage and to communicate with each other. The instructions now have been enhanced to permit usage of the 64-bit addressing of z/Architecture.

With respect to System/370 programs, it is assumed that old, unmodified programs operate in the 24-bit addressing mode and call, or directly communicate with, other programs operating in the 24-bit addressing mode only. Modified programs normally operate in the 24-bit addressing mode but may have called programs which operate in either the 24-bit or 31-bit addressing mode. They and also modified 370-XA, ESA/370, and ESA/390 programs now may call programs that operate in the 24-bit, 31-bit, or 64-bit addressing mode. New programs may be written to operate in any addressing mode, and, in some cases, a program may be written such that it can be invoked in any addressing mode.

BRANCH AND SAVE AND SET MODE (BASSM) is intended to be the principal calling instruction to subroutines outside of an assembler/linkage-editor control section (CSECT), for use by all new programs and particularly by programs that must change the
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Format</th>
<th>Instruction Address PSW Bits 64-127</th>
<th>Basic Addr. Mode PSW Bit 32</th>
<th>Extended Addr. Mode PSW Bit 31</th>
<th>Problem State PSW Bit 15</th>
<th>PASN CR4 Bits 48-63</th>
<th>PSW-Key Mask Changed in CR3</th>
<th>Trace</th>
</tr>
</thead>
<tbody>
<tr>
<td>BALR</td>
<td>RR</td>
<td>Yes* R₂¹ BAM31</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>R₂¹</td>
</tr>
<tr>
<td>BAL</td>
<td>RX</td>
<td>Yes* Yes* BAM31</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>BASR</td>
<td>RR</td>
<td>Yes R₂¹ BAM</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>R₂¹</td>
</tr>
<tr>
<td>BAS</td>
<td>RX</td>
<td>Yes Yes BAM</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>BASSM</td>
<td>RR</td>
<td>Yes R₂¹ BAM R₂¹ Yes R₂¹</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>BRAS</td>
<td>R</td>
<td>Yes Yes BAM</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>BRASL</td>
<td>RIL</td>
<td>Yes Yes BAM</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>BSA-ba</td>
<td>RRE</td>
<td>Yes Yes BAM BAM</td>
<td>-</td>
<td>Yes</td>
<td>Yes⁴</td>
<td>-</td>
<td>“AND” R₁⁵ Yes</td>
<td></td>
</tr>
<tr>
<td>BSA-ra</td>
<td>RRE</td>
<td>R₁¹ Yes R₁¹ BAM</td>
<td>-</td>
<td>Yes</td>
<td>-</td>
<td>Yes</td>
<td>Yes</td>
<td></td>
</tr>
<tr>
<td>BSG</td>
<td>RRE</td>
<td>Yes Yes R₁¹ BAM</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>Yes</td>
</tr>
<tr>
<td>BSM</td>
<td>RR</td>
<td>- R₂¹ R₂¹ R₂¹ EAM64</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>MCI#²</td>
<td>SI</td>
<td>Yes Yes Yes Yes Yes Yes Yes Yes</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>PC-cp</td>
<td>S</td>
<td>Yes Yes BAM BAM</td>
<td>-</td>
<td>Yes</td>
<td>Yes Yes</td>
<td>“OR” EKM Yes</td>
<td>Yes</td>
<td></td>
</tr>
<tr>
<td>PC-ss</td>
<td>S</td>
<td>Yes Yes BAM BAM</td>
<td>-</td>
<td>Yes</td>
<td>Yes Yes</td>
<td>“OR” EKM Yes</td>
<td>Yes</td>
<td></td>
</tr>
<tr>
<td>PT-cp or PTI-cp</td>
<td>RRE</td>
<td>- R₂¹ - R₂¹ - R₂¹ **</td>
<td>-</td>
<td>-</td>
<td>R₂¹ **</td>
<td>-</td>
<td>“AND” R₁⁵ Yes</td>
<td></td>
</tr>
<tr>
<td>PT-ss or PTI-ss</td>
<td>RRE</td>
<td>- R₂¹ - R₂¹ - R₂¹ **</td>
<td>-</td>
<td>-</td>
<td>R₂¹ **</td>
<td>-</td>
<td>“AND” R₁⁵ Yes</td>
<td></td>
</tr>
<tr>
<td>RP</td>
<td>S</td>
<td>- Yes - Yes</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>Yes</td>
</tr>
<tr>
<td>SAM24</td>
<td>E</td>
<td>- - Yes 0</td>
<td>-</td>
<td>Yes</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>Yes</td>
</tr>
<tr>
<td>SAM31</td>
<td>E</td>
<td>- - Yes 1</td>
<td>-</td>
<td>Yes</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>Yes</td>
</tr>
<tr>
<td>SAM64</td>
<td>E</td>
<td>- - Yes 1</td>
<td>-</td>
<td>Yes</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>Yes</td>
</tr>
<tr>
<td>SVC2</td>
<td>RR</td>
<td>Yes Yes Yes Yes Yes Yes Yes Yes</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>TRAP2</td>
<td>E</td>
<td>Yes Yes Yes Yes Yes Yes Yes Yes</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>TRAP4</td>
<td>S</td>
<td>Yes Yes Yes Yes Yes Yes Yes Yes</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Figure 5-3. Summary of Linkage Instructions without the Linkage Stack
addressing mode during the linkage. The calling sequence has normally been:

\[ \text{L 15,ACON} \]
\[ \text{BASSM 14,15} \]
\[ \ldots \]
\[ \text{EXTRN SUB} \]
\[ \text{ACONE DC A(X'80000000'+SUB)} \]

The return from such a routine would normally be:

\[ \text{BSM 0,14} \]

where ACON is an A-type address constant, and the X'80000000' should be present to give control in the 31-bit addressing mode or should be omitted to give control in the 24-bit addressing mode.

The return from such a routine normally is:

\[ \text{BSM 0,14} \]

It is assumed that the A-type address constant will be extended so it may be an eight-byte field containing a 64-bit entry-point address, with bit 63 of the address indicating, when one, that the entry is in the 64-bit addressing mode. This extended constant is shown here as “ACONE”. The calling sequence would normally be:

\[ \text{LG 15,ACONE} \]

When a change of the addressing mode is not required, BRANCH AND LINK or BRANCH AND SAVE should be used instead of BASSM.

The BRANCH AND LINK (BAL, BALR) instruction is provided primarily for compatibility with System/370. It is defined to operate in the 31-bit and 64-bit addressing modes to increase the probability that an old, straightforward program can be modified to operate in those addressing modes with minimal or no change. It is recommended, however, that BRANCH AND SAVE (BAS and BASR) be used instead and that BRANCH AND LINK be avoided since it places nonzero information in bit positions 32-39 of the general register in the 24-bit addressing mode, which may lead to problems and may decrease performance.
BRANCH RELATIVE AND SAVE and BRANCH RELATIVE AND SAVE LONG may be used instead of BRANCH AND SAVE.

It is assumed that the normal return from a subroutine called in the 24-bit or 31-bit addressing mode by BRANCH AND LINK (BAL or BALR) will be:

BCR 15,14

However, the standard “return instruction”:

BSM 0,14

operates correctly for all cases except for a calling BAL executed in the 24-bit addressing mode. In the 24-bit addressing mode, BAL causes an ILC of 10 to be placed in bit positions 32 and 33 of the link register. Thus, a BSM would return in the 31-bit addressing mode. Note that an EXECUTE of BALR in the 24-bit addressing mode also causes the same ILC effect; an EXECUTE RELATIVE LONG of BALR in the 24-bit addressing mode causes a similar ILC effect (the ILC is 11 binary).

The BRANCH AND SAVE (BAS, BASR) instruction is provided to be used for subroutine linkage to any program either within the same CSECT or known to be in the same addressing mode. BASR with the R2 field 0 is also useful for obtaining addressability to the instruction stream by getting a 31-bit address, uncluttered by leftmost fields, in the 24-bit addressing mode.

The instruction for returning from a routine called in the 24-bit or 31-bit addressing mode by BRANCH AND SAVE (BAS or BASR) may be either:

BCR 15,14

or:

BSM 0,14

The instruction for returning from a routine called in the 64-bit addressing mode by BAS or BASR must be BCR; BSM would set the 24-bit or 31-bit addressing mode, depending on bit 32 of the link register (an address bit), because bit 63 of the link register (the rightmost bit of an instruction address) is zero. BSM can always be used as the return instruction if BASSM is used as the calling instruction.

In some cases, it may be desirable to rewrite a program that is called by an old program which has not been rewritten. In such a case, the old program, which operates in the 24-bit or 31-bit addressing mode, will be given the address of an intermediate program that will set up the correct entry and return modes and then call the rewritten program. Such an intermediate program is sometimes referred to as a glue module. The instruction BRANCH AND SET MODE (BSM) with a nonzero R1 field provides the function necessary to perform this operation efficiently. This is shown in Figure 5-4 on page 5-22 for a linkage from a 24-bit-mode program to a 31-bit-mode program.

Note that the “BSM 14,15” in the glue module causes either an indication of the 64-bit addressing mode to be saved in bit position 63 of general register 14 or an indication of one of the 24-bit and 31-bit addressing modes to be saved in bit position 32 of the register, and that the other bits of the register are unchanged. Thus, when “BSM 0,14” is executed in the new program, control passes directly back to the old program without passing through the glue module again. The glue module could give control to a program in the 64-bit addressing mode and possibly above the 2G-byte boundary by loading an eight-byte
A-type address constant, with bit 63 set to one, instead of a four-byte A-type address constant.

Interruptions permit the CPU to change state as a result of conditions external to the system, in sub-channels or input/output (I/O) devices, in other CPUs, or in the CPU itself. Details are to be found in Chapter 6, “Interruptions”.

Six classes of interruption conditions are provided: external, I/O, machine check, program, restart, and supervisor call. Each class has two related PSWs, called old and new, in permanently assigned real storage locations. In all classes, an interruption involves storing information identifying the cause of the interruption, storing the current PSW at the old-PSW location, and fetching the PSW at the new-PSW location, which becomes the current PSW.

The old PSW contains CPU-status information necessary for resumption of the interrupted program. At the conclusion of the program invoked by the interruption, the instruction LOAD PSW EXTENDED may be used to restore the current PSW to the value of the old PSW.

### Interruptions

<table>
<thead>
<tr>
<th>Old Program</th>
<th>Glue Module</th>
<th>New Program</th>
</tr>
</thead>
<tbody>
<tr>
<td>L 15,OLDACON</td>
<td>GLUE CSECT USING *,15</td>
<td>NEW CSECT USING *,15</td>
</tr>
<tr>
<td>BALR 14,15</td>
<td>L 15,NEWACON</td>
<td>BSM 0,14</td>
</tr>
<tr>
<td>‐‐‐‐‐‐‐‐‐‐‐‐</td>
<td>‐‐‐‐‐‐‐‐‐‐‐‐</td>
<td>‐‐‐‐‐‐‐‐‐‐‐‐</td>
</tr>
<tr>
<td>EXTRN GLUE</td>
<td>EXTRN NEW</td>
<td>‐‐‐‐‐‐‐‐‐‐‐‐</td>
</tr>
<tr>
<td>OLDACON DC A(GLUE)</td>
<td>NEWACON DC A(NEW)</td>
<td>‐‐‐‐‐‐‐‐‐‐‐‐</td>
</tr>
</tbody>
</table>

*Figure 5-4. Glue Module for Linkage from the 24-Bit Mode to the 31-Bit Mode*

#### Types of Instruction Ending

Instruction execution ends in one of five ways: completion, nullification, suppression, termination, and partial completion.

Partial completion of instruction execution occurs only for interruptible instructions; it is described in "Interruptible Instructions" on page 5-24.

#### Completion

Completion of instruction execution provides results as called for in the definition of the instruction. When an interruption occurs after the completion of the execution of an instruction, the instruction address in the old PSW designates the next sequential instruction.

#### Suppression

Except as noted below, suppression of instruction execution causes the instruction to be executed as if it specified “no operation.” The contents of any result fields, including the condition code, are not changed. The instruction address in the old PSW on an interruption after suppression designates the next sequential instruction.
When (a) the AFP-register (additional floating-point register) control bit, bit 45 of control register 0, is one, (b) either an IEEE-invalid-operation condition or an IEEE-division-by-zero condition is recognized, and (c) the respective IEEE mask bit in the floating-point-control (FPC) register is one, then the resulting data-exception program interruption is considered to be suppressing, even though the FPC is altered. See “Data-Exception Code (DXC)” on page 6-16 for details.

When (a) the additional floating-point register (AFP-register) control bit, bit 45 of control register 0, is one, (b) the vector enablement control, bit 46 of control register 0, is one, and (c) a vector-processing exception is recognized, then the resulting vector-processing exception program interruption is considered to be suppressing, even though the FPC is altered. See “Vector-Exception Code” on page 6-19 for details.

In the access-register mode, if an access exception defined to be suppressing is recognized for an operand of PERFORM LOCKED OPERATION whose address is in the parameter list, the ALET associated with the address is placed into the access register designated by the R₃ field of the instruction.

### Nullification

Except as noted below, nullification of instruction execution has the same effect as suppression, except that when an interruption occurs after the execution of an instruction has been nullified, the instruction address in the old PSW designates the instruction whose execution was nullified (or an execute-type instruction, as appropriate) instead of the next sequential instruction.

In the access-register mode, if an access exception defined to be nullifying is recognized for an operand of PERFORM LOCKED OPERATION whose address is in the parameter list, the ALET associated with the address is placed into the access register designated by the R₃ field of the instruction.

### Termination

Termination of instruction execution causes the contents of any fields due to be changed by the instruction to be unpredictable. The operation may replace all, part, or none of the contents of the designated result fields and may change the condition code if such change is called for by the instruction. Unless the interruption is caused by a machine-check condition, the validity of the instruction address in the PSW, the interruption code, and the ILC are not affected, and the state or the operation of the machine is not affected in any other way. The instruction address in the old PSW on an interruption after termination designates the next sequential instruction.

The terms completion, nullification, partial completion, suppression, and termination, and their corresponding effects, apply to the ending of individual instructions. When a transaction aborts, all transactional stores made by instructions while the CPU was in the transactional-execution mode are discarded, nontransactional stores are committed, and general registers designated by the general-register-save mask (GRSM) of the outermost TRANSACTION BEGIN instruction are restored to their contents prior to transactional execution. Any other general registers (not designated by the GRSM), access registers, vector registers, and floating-point registers (including the floating-point control register) that were altered while the CPU was in the transactional-execution mode retain their contents.

When a transaction is aborted, the program-status word is replaced with the transaction-abort PSW, except that the condition code is set to indicate the severity of the abort condition. In the case of a transaction that is aborted due to conditions that result in an interruption, this PSW becomes the old PSW stored as a result of the interruption. See “Transaction-Abort PSW (TAPSW)” on page 5-94 for further details.

If a transaction is aborted due to any cause except a program-interruption condition, the instruction address that is placed into the aborted-transaction-instruction-address field of the transaction diagnostic block is that of the instruction that would have been executed next in the absence of the abort. If a transaction is aborted due to a program-interruption condition, the instruction address that is placed into the aborted-transaction-instruction-address field is that of either the instruction at which the exception condition was detected or the instruction that would have been executed next in the absence of the abort, depending on whether the program-interruption condition was or was not nullifying, respectively. See “Aborted-Transaction Instruction Address (ATIA)” on page 5-96 for additional details.

**Programming Note:** Although the execution of an instruction is treated as a no-operation when suppression or nullification occurs, stores may be per-
formed as the result of the implicit tracing action associated with some instructions. See “Tracing” on page 4-10.

Interruptible Instructions

Point of Interruption
For most instructions, the entire execution of an instruction is one operation. An interruption is permitted between operations; that is, an interruption can occur after the performance of one operation and before the start of a subsequent operation.

For the following instructions, referred to as interruptible instructions, an interruption is permitted also after partial completion of the instruction:

- COMPARE AND FORM CODEWORD
- COMPARE LOGICAL LONG
- COMPARE UNTIL SUBSTRING EQUAL
- COMPRESSION CALL
- INVALIDATE PAGE TABLE ENTRY (when the IPTE-range facility is installed, and the R₃ field is nonzero)
- MOVE LONG
- PERFORM FRAME MANAGEMENT FUNCTION when the EDAT-1 facility is installed and the frame-size code designates a 1 M-byte frame, or when the EDAT-2 facility is installed and the frame-size code designates a 2 G-byte frame
- SET STORAGE KEY EXTENDED (when the enhanced-DAT facility is installed, and the multiple-block control is one)
- TEST BLOCK
- UPDATE TREE

Unit of Operation
Whenever points of interruption that include those occurring within the execution of an interruptible instruction are discussed, the term “unit of operation” is used. For a noninterruptible instruction, the entire execution consists, in effect, in the execution of one unit of operation.

The execution of an interruptible instruction is considered to consist in the execution of a number of units of operation, and an interruption is permitted between units of operation. The amount of data processed in a unit of operation depends on the particular instruction and may depend on the model and on the particular condition that causes the execution of the instruction to be interrupted.

When an instruction execution consists of a number of units of operation and an interruption occurs after some, but not all, units of operation have been completed, the instruction is said to be partially completed. In this case, the type of ending (completion, nullification, or suppression) is associated with the unit of operation. In the case of termination, the entire instruction is terminated, not just the unit of operation.

An exception may exist that causes the first unit of operation of an interruptible instruction not to be completed. In this case when the ending is nullification or suppression, all operand parameters and result locations remain unchanged, except that the condition code is unpredictable if the instruction is defined to set the condition code.

When a storage-alteration PER event is recognized, fewer than 4K additional bytes are stored before the event is indicated by an interruption. When a zero-address-detection PER event is recognized, the event is indicated by an interruption that may occur on completion of a unit of operation.

Execution of Interruptible Instructions
The execution of an interruptible instruction is completed when all units of operation associated with that instruction are completed. When an interruption occurs after completion, nullification, or suppression of a unit of operation, all preceding units of operation have been completed, and subsequent units of operation and instructions have not been started. The main difference between these types of ending is the handling of the current unit of operation and whether the instruction address stored in the old PSW identifies the current instruction or the next sequential instruction.

At the time of an interruption, changes to storage locations or register contents which are due to be made by instructions following the interrupted instruction have not yet been made.

Completion: On completion of the last unit of operation of an interruptible instruction, the instruction address in the old PSW designates the next sequential instruction. The result location for the current unit of operation has been updated. It depends on the particular instruction how the operand parameters are adjusted. On completion of a unit of operation other than the last one, the instruction address in the old PSW designates the interrupted instruction or an
execute-type instruction, as appropriate. The result location for the current unit of operation has been updated. The operand parameters are adjusted such that the execution of the interrupted instruction is resumed from the point of interruption when the old PSW stored during the interruption is made the current PSW.

**Nullification:** When a unit of operation is nullified, the instruction address in the old PSW designates the interrupted instruction or an execute-type instruction, as appropriate. The result location for the current unit of operation remains unchanged. The operand parameters are adjusted such that, if the instruction is reexecuted, execution of the interrupted instruction is resumed with the current unit of operation.

**Suppression:** When a unit of operation is suppressed, the instruction address in the old PSW designates the next sequential instruction. The operand parameters, however, are adjusted so as to indicate the extent to which instruction execution has been completed. If the instruction is reexecuted after the conditions causing the suppression have been removed, the execution is resumed with the current unit of operation.

**Termination:** When an exception which causes termination occurs as part of a unit of operation of an interruptible instruction, the entire operation is terminated, and the contents, in general, of any fields due to be changed by the instruction are unpredictable. On such an interruption, the instruction address in the old PSW designates the next sequential instruction.

The differences among the four types of ending for a unit of operation are summarized in Figure 5-5 on page 5-25.

If an instruction is defined to set the condition code, the execution of the instruction makes the condition code unpredictable except when the last unit of operation has been completed.

**Condition-Code Alternative to Interruptibility**

The following instructions are not interruptible instructions but instead may be completed after performing a CPU-determined subportion of the processing specified by the parameters of the instructions:

- CHECKSUM
- CIPHER MESSAGE
- CIPHER MESSAGE WITH CIPHER FEEDBACK
- CIPHER MESSAGE WITH CHAINING
- CIPHER MESSAGE WITH COUNTER
- CIPHER MESSAGE WITH OUTPUT FEEDBACK
- COMPARE LOGICAL LONG EXTENDED
- COMPARE LOGICAL LONG UNICODE
- COMPARE LOGICAL STRING
- COMPUTE INTERMEDIATE MESSAGE DIGEST
- COMPUTE LAST MESSAGE DIGEST
- COMPUTE MESSAGE AUTHENTICATION CODE
- CONVERT UTF-16 TO UTF-32
- CONVERT UTF-16 TO UTF-8
- CONVERT UTF-32 TO UTF-16
- CONVERT UTF-8 TO UTF-16
- CONVERT UTF-8 TO UTF-32
- MOVE LONG EXTENDED
- MOVE LONG UNICODE
- MOVE STRING
- PERFORM CRYPTOGRAPHIC COMPUTATION
- PERFORM PSEUDORANDOM NUMBER OPERATION (generate operation only)
- SEARCH STRING
- SEARCH STRING UNICODE
- TRANSLATE AND TEST EXTENDED

---

<table>
<thead>
<tr>
<th>Unit of Operation Is</th>
<th>Instruction Address</th>
<th>Operand Parameters</th>
<th>Current Result Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>Completed</td>
<td>Next instruction</td>
<td>Depends on the instruction</td>
<td>Changed</td>
</tr>
<tr>
<td>Last unit of operation</td>
<td>Current instruction</td>
<td>Next unit of operation</td>
<td>Changed</td>
</tr>
<tr>
<td>Any other unit of operation</td>
<td>Current instruction</td>
<td>Current unit of operation</td>
<td>Unchanged</td>
</tr>
<tr>
<td>Nullified</td>
<td>Current instruction</td>
<td>Current unit of operation</td>
<td>Unchanged</td>
</tr>
<tr>
<td>Suppressed</td>
<td>Next Instruction</td>
<td>Current unit of operation</td>
<td>Unchanged</td>
</tr>
<tr>
<td>Terminated</td>
<td>Next instruction</td>
<td>Unpredictable</td>
<td>Unpredictable</td>
</tr>
</tbody>
</table>

Figure 5-5. Types of Ending for a Unit of Operation
When any of the above instructions is completed after performing only a CPU-determined amount of processing instead of all specified processing, the instruction sets condition code 3. On such completion, the instruction address in the PSW designates the next sequential instruction, and the operand parameters of the instruction have been adjusted so that the processing of the instruction can be resumed simply by branching back to the instruction to execute it again. When the instruction has performed all specified processing, it sets a condition code other than 3.

The points at which any of the above instructions may set condition code 3 are comparable to the points of interruption of an interruptible instruction, and the amount of processing between adjacent points is comparable to a unit of operation of an interruptible instruction. However, since the instruction is not interruptible, each execution is considered the execution of one unit of operation.

Completion with the setting of condition code 3 permits interruptions to occur. Depending on the model and the instruction, condition code 3 may or may not be set when there is not a need for an interruption.

When a storage-alteration PER event is recognized, fewer than 4K additional bytes are stored before the instruction is completed (with condition code 3, if no other condition takes precedence), and the event is indicated by an interruption. When a zero-address-detection PER event is recognized, the instruction is completed (with condition code 3, if no other condition takes precedence), and the event is indicated by an interruption.

The COMPARE UNTIL SUBSTRING EQUAL and COMPRESSION CALL instructions both are interruptible instructions and ones that may set condition code 3 after performing a CPU-determined amount of processing.

Programming Notes:

1. Any interruption, other than supervisor call and some program interruptions, can occur after a partial execution of an interruptible instruction. In particular, interruptions for external, I/O, machine-check, restart, and program interruptions for access exceptions and PER events can occur between units of operation.

2. The amount of data processed in a unit of operation of an interruptible instruction depends on the model and may depend on the type of condition which causes the execution of the instruction to be interrupted or stopped. Thus, when an interruption occurs at the end of the current unit of operation, the length of the unit of operation may be different for different types of interruptions. Also, when the stop function is requested during the execution of an interruptible instruction, the CPU enters the stopped state at the completion of the execution of the current unit of operation. Similarly, in the instruction-step mode, only a single unit of operation is performed, but the unit of operation for the various cases of stopping may be different.

Exceptions to Nullification and Suppression

In certain unusual situations, the result fields of an instruction having a store-type operand are changed in spite of the occurrence of an exception which would normally result in nullification or suppression. These situations are exceptions to the general rule that the operation is treated as a no-operation when an exception requiring nullification or suppression is recognized. Each of these situations may result in the turning on of the change bit associated with the store-type operand, even though the final result in storage may appear unchanged. Depending on the particular situation, additional effects may be observable. The extent of these effects is described along with each of the situations.

All of these situations are limited to the extent that a store access does not occur and the change bit is not set when the store access is prohibited. For the CPU, a store access is prohibited whenever an access exception exists for that access, or whenever an exception exists which is of higher priority than the priority of an access exception for that access.
When, in these situations, an interruption for an exception requiring suppression occurs, the instruction address in the old PSW designates the next sequential instruction. When an interruption for an exception requiring nullification occurs, the instruction address in the old PSW designates the instruction causing the exception even though partial results may have been stored.

Storage Change and Restoration for DAT-Associated Access Exceptions

In this section, the term “DAT-associated access exceptions” is used to refer to those exceptions which may occur as part of the dynamic-address-translation process. These exceptions are ASCE-type, region-first translation, region-second translation, region-third translation, segment translation, page translation, translation specification, and addressing due to a DAT-table entry being designated at a location that is not available in the configuration. The first six of these exceptions normally cause nullification, and the last two normally cause suppression. Protection exceptions, including those due to DAT protection, are not considered to be DAT-associated access exceptions.

For DAT-associated access exceptions, on some models, channel programs may observe the effects on storage as described in the following case.

When, for an instruction having a store-type operand, a DAT-associated access exception is recognized for any operand of the instruction, that portion, if any, of the store-type operand which would not cause an exception may be changed to an intermediate value but is then restored to the original value.

The accesses associated with storage change and restoration for DAT-associated access exceptions are only observable by channel programs and are not observable by other CPUs in a multiprocessing configuration. Except for instructions which are defined to have multiple-access operands, the intermediate value, if any, is always equal to what would have been the final value if the DAT-associated access exception had not occurred.

Programming Notes:

1. Storage change and restoration for DAT-associated access exceptions occur in two main situations:
   a. The exception is recognized for a portion of a store-type operand which crosses a page boundary, and the other portion has no access exception.
   b. The exception is recognized for one operand of an instruction having two storage operands (for example, an SS-format instruction or MOVE LONG), and the other operand, which is a store-type operand, has no access exception.

2. To avoid letting a channel program observe intermediate operand values due to storage change and restoration for DAT-associated access exceptions (especially when a CCW chain is modified), the CPU program should do one of the following:
   a. Operate on one storage page at a time
   b. Perform preliminary testing to ensure that no exceptions occur for any of the required pages
   c. Operate with DAT off

Modification of DAT-Table Entries

When a valid and attached DAT-table entry is changed to a value which would cause an exception, and when, before the TLB is cleared of entries which qualify for substitution for that entry, an attempt is made to refer to storage by using a virtual address requiring that entry for translation, the contents of any fields due to be changed by the instruction are unpredictable. Results, if any, associated with the virtual address whose DAT-table entry was changed may be placed in those real locations originally associated with the address. Furthermore, it is unpredictable whether or not an interruption occurs for an access exception that was not initially applicable. On some machines, this situation may be reported by means of an instruction-processing-damage machine check with the delayed-access-exception bit also indicated.

Trial Execution for Editing Instructions and Translate Instruction

For the instructions EDIT, EDIT AND MARK, and TRANSLATE, the portions of the operands that are actually used in the operation may be established in a trial execution for operand accessibility that is performed before the execution of the instruction is started. This trial execution consists in an execution of the instruction in which results are not stored. If
the first operand of TRANSLATE or either operand of EDIT or EDIT AND MARK is changed by another CPU or by a channel program, after the initial trial execution but before completion of execution, the contents of any fields due to be changed by the instruction are unpredictable.

**Authorization Mechanisms**

Most of the authorization mechanisms that are described in this section permit the control program to establish the degree of function provided to a particular semiprivileged program. These authorization mechanisms are intended for use by programs considered to be semiprivileged, that is, programs that are executed in the problem state but which may be authorized to use additional capabilities. With these authorization controls, a hierarchy of programs may be established, with programs at a higher level having a greater degree of privilege or authority than programs at a lower level. The range of functions available at each level, and the ability to transfer control from a lower to a higher level, are specified in tables which are managed by the control program. When the linkage stack is used, a nonhierarchical transfer of control also can be specified.

A semiprivileged instruction is one which can be executed in the problem state, but which is subject to the control of one or more of the authorization mechanisms described in this section. There are 25 semiprivileged instructions and also the privileged LOAD ADDRESS SPACE PARAMETERS instruction that are controlled by the authorization mechanisms. All of these semiprivileged and privileged instructions are described in Chapter 10, “Control Instructions”.

This section also describes, or refers to descriptions of, authorization mechanisms that are available when the ASN-and-LX-reuse facility is installed. These mechanisms do not apply to particular programs or provide for a hierarchy of programs.

The instructions controlled by the authorization mechanisms are listed in Figure 5-6 on page 5-31. The figure also shows additional authorization mechanisms that do not control specifically semiprivileged instructions; they control implicit access-register translation (access-register translation as part of an instruction making a storage reference) and also access-register translation in the LOAD PAGE-ENTRY ADDRESS, LOAD REAL ADDRESS, STORE REAL ADDRESS, TEST ACCESS, and TEST PROTECTION instructions and a special form of access-register translation in the BRANCH IN SUBSPACE GROUP instruction. These additional mechanisms (the extended authorization index, ALE sequence number, and ASTE sequence number) index and ALE sequence number) are described in “Access-Register-Specified Address Spaces” on page 5-47, and the ASTE instance number is further described in “ASN-Second-Table-Entry Sequence Number” on page 3-21. The figure also shows the LSTE sequence number, which may be used in P-number translation in the PROGRAM CALL instruction and is described in “ASN-and-LX-Reuse Control (R)” on page 5-35.

**Mode Requirements**

Most of the semiprivileged instructions can be executed only with DAT on. Basic PROGRAM CALL, PROGRAM TRANSFER, and PROGRAM TRANSFER WITH INSTANCE, are valid only in the primary-space mode. (Basic PROGRAM CALL is the PROGRAM CALL operation when the linkage stack is not used. When the linkage stack is used, the PROGRAM CALL operation is called stacking PROGRAM CALL). MOVE TO PRIMARY and MOVE TO SECONDARY are valid only in the primary-space and secondary-space modes. BRANCH AND STACK, stacking PROGRAM CALL, and PROGRAM RETURN are valid only in the primary-space and access-register modes. EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, and MODIFY STACKED STATE are valid only in the primary-space, access-register, and home-space modes. When a semiprivileged instruction is executed in an invalid translation mode, a special-operation exception is recognized.

PROGRAM TRANSFER and PROGRAM TRANSFER WITH INSTANCE specify a new value for the problem-state bit in the PSW. If a program in the problem state attempts to execute PROGRAM TRANSFER or PROGRAM TRANSFER WITH INSTANCE and set the supervisor state, a privileged-operation exception is recognized. A privileged-operation exception is also recognized on an attempt to use RESUME PROGRAM, SET ADDRESS SPACE CONTROL, or SET ADDRESS SPACE CONTROL FAST to set the home-space mode in the problem state.
Extraction-Authority Control
The extraction-authority-control bit is located in bit position 36 of control register 0. In the problem state, bit 36 must be one to allow completion of these instructions:

- EXTRACT PRIMARY ASN
- EXTRACT PRIMARY ASN AND INSTANCE
- EXTRACT SECONDARY ASN
- EXTRACT SECONDARY ASN AND INSTANCE
- INSERT ADDRESS SPACE CONTROL
- INSERT PSW KEY
- INSERT VIRTUAL STORAGE KEY

Otherwise, a privileged-operation exception is recognized. The extraction-authority control is not examined in the supervisor state.

PSW-Key Mask
The PSW-key mask consists of bits 32-47 in control register 3, with the bits corresponding to the values 0-15, respectively, of the PSW key. These bits are used in the problem state to control which keys and entry points are authorized for the program. The PSW-key mask is modified by PROGRAM TRANSFER, and PROGRAM TRANSFER WITH INSTANCE, is modified or loaded by BRANCH AND SET AUTHORITY and PROGRAM CALL, and is loaded by LOAD ADDRESS SPACE PARAMETERS and PROGRAM RETURN. The PSW-key mask is used in the problem state to control the following:

- The PSW-key values that can be set by means of the instruction SET PSW KEY FROM ADDRESS.
- The PSW-key values that are valid for the six move instructions that specify a second access key: MOVE PAGE, MOVE TO PRIMARY, MOVE TO SECONDARY, MOVE WITH DESTINATION KEY, MOVE WITH KEY, and MOVE WITH SOURCE KEY.
- The PSW-key values that are valid for the MOVE WITH OPTIONAL SPECIFICATIONS instruction when a key is explicitly specified for the first, second, or both operands.
- The entry points which can be called by means of PROGRAM CALL. In this case, the PSW-key mask is ANDed with the authorization key mask in the entry-table entry, and, if the result is zero, the program is not authorized.

When an instruction in the problem state attempts to use a key not authorized by the PSW-key mask, a privileged-operation exception is recognized. The same action is taken when an instruction in the problem state attempts to call an entry not authorized by the PSW-key mask. The PSW-key mask is not examined in the supervisor state, all keys and entry points being valid.

Secondary-Space Control
Bit 37 of control register 0 is the secondary-space-control bit. This bit provides a mechanism whereby the control program can indicate whether or not the secondary region-first table, region-second table, region-third table or segment table has been established. Bit 37 may be required to be one to allow completion of SET ADDRESS SPACE CONTROL FAST and MOVE WITH OPTIONAL SPECIFICATIONS, and it must be one to allow completion of these instructions:

- MOVE TO PRIMARY
- MOVE TO SECONDARY
- MOVE WITH OPTIONAL SPECIFICATIONS, when either operand-access control designates the secondary space
- SET ADDRESS SPACE CONTROL

Otherwise, a special-operation exception is recognized. The secondary-space control is examined in both the problem and supervisor states.

Subsystem-Linkage Control
Bit 192 of the primary ASN-second-table entry is the subsystem-linkage-control bit. The subsystem-linkage control must be one to allow completion of these instructions:

- PROGRAM CALL
- PROGRAM TRANSFER
- PROGRAM TRANSFER WITH INSTANCE

Otherwise, a special-operation exception is recognized. The subsystem-linkage control is examined in both the problem and supervisor states and controls both the space-switching and current-primary versions of the instructions.

ASN-Translation Control
Bit 44 of control register 14 is the ASN-translation-control bit. This bit provides a mechanism whereby the control program can indicate whether ASN translation may occur while a particular program is being
executed. Bit 44 must be one to allow completion of these instructions:

- LOAD ADDRESS SPACE PARAMETERS
- SET SECONDARY ASN
- SET SECONDARY ASN WITH INSTANCE
- PROGRAM CALL with space switching
- PROGRAM RETURN with space switching and also when the restored secondary ASN is not equal to the restored primary ASN
- PROGRAM TRANSFER with space switching
- PROGRAM TRANSFER WITH INSTANCE with space switching

Otherwise, a special-operation exception is recognized. The ASN-translation control is examined in both the problem and supervisor states. The ASN-translation control is examined by PROGRAM CALL even though PROGRAM CALL obtains the address of the ASN-second-table entry directly from the entry-table entry instead of by performing ASN translation.

Authorization Index

The authorization index is contained in bit positions 32-47 of control register 4. The authorization index is associated with the primary address space and is loaded along with the PASN when PROGRAM CALL with space switching, PROGRAM RETURN with space switching, PROGRAM TRANSFER with space switching, or LOAD ADDRESS SPACE PARAMETERS is executed. The authorization index is used to determine whether a program is authorized to establish a particular address space. A program may be authorized to establish the address space as a secondary-address space, as a primary-address space, or both. The authorization index is examined in both the problem and supervisor states.

Associated with each address space is an authority table. The authorization index is used to select an entry in the authority table. Each entry contains two bits, which indicate whether the program with that authorization index is permitted to establish the address space as a primary address space, as a secondary address space, or both.

The instructions SET SECONDARY ASN with space switching, and SET SECONDARY ASN WITH INSTANCE with space switching, and the instruction PROGRAM RETURN when the restored secondary ASN is not equal to the restored primary ASN, use the authorization index to test the secondary-authority bit in the authority-table entry to determine if the address space can be established as a secondary address space. The tested bit must be one; otherwise, a secondary-authority exception is recognized.

The instructions PROGRAM TRANSFER with space switching and PROGRAM TRANSFER WITH INSTANCE with space switching use the authorization index to test the primary-authority bit in the authority-table entry to determine if the address space can be established as a primary address space. The tested bit must be one; otherwise, a primary-authority exception is recognized.

The instruction PROGRAM CALL with space switching causes a new authorization index to be loaded from the ASN-second-table entry. This permits the program which is called to be given an authorization index which authorizes it to access more or different address spaces than those authorized for the calling program. The instructions PROGRAM RETURN with space switching, PROGRAM TRANSFER with space switching, and PROGRAM TRANSFER WITH INSTANCE with space switching restore the authorization index that is associated with the returned-to address space.

The secondary-authority bit in the authority-table entry may also be used, along with the extended authorization index, to determine if the program is authorized to use an access-list entry in access-register translation. This is described in “Access-Register-Specified Address Spaces” on page 5-47.

Instructions and Controls Related to ASN-and-LX Reuse

This section describes instructions and controls that are provided when the ASN-and-LX-reuse facility is installed. The controls apply in both the problem and the supervisor states.

Instructions: The ASN-and-LX-reuse facility provides the following instructions:

- EXTRACT PRIMARY ASN AND INSTANCE
- EXTRACT SECONDARY ASN AND INSTANCE
- PROGRAM TRANSFER WITH INSTANCE
- SET SECONDARY ASN WITH INSTANCE

PROGRAM TRANSFER WITH INSTANCE and SET SECONDARY ASN WITH INSTANCE are similar to PROGRAM TRANSFER and SET SECONDARY
ASN, respectively. The space-switching forms of PROGRAM TRANSFER WITH INSTANCE and SET SECONDARY ASN WITH INSTANCE compare an ASTE instance number (ASTEIN) specified by the program in general register 1 to the ASTEIN in the ASN-second-table entry for the address space to which the space switch is to occur. An ASTE-instance exception is recognized if the two ASTEINs are not equal.

**ASN-and-LX-Reuse Control:** Bit 44 of control register 0 is the ASN-and-LX-reuse control. This bit is used to control both ASN reuse and LX reuse, as described below.

**ASN Reuse:** When the ASN-and-LX-reuse control is one, PROGRAM RETURN and LOAD ADDRESS SPACE PARAMETERS, when they perform ASN translation of either a primary ASN or a secondary ASN, compare a specified ASTEIN to the ASTEIN in the ASN-second-table entry located by the ASN translation. The two ASTEINs must be equal; otherwise, PROGRAM RETURN recognizes an ASTE-instance exception, and LOAD ADDRESS SPACE PARAMETERS sets condition code 1 or 2. For PROGRAM RETURN, the specified ASTEIN is in the linkage-stack program-call state entry being unstacked. For LOAD ADDRESS SPACE PARAMETERS, the specified ASTEIN is in the first operand of the instruction.

Bit 31 of word 1 of the ASN-second-table entry is the reusable-ASN bit. When the ASN-and-LX-reuse control is one, the space-switching forms of PROGRAM TRANSFER and SET SECONDARY ASN recognize a special-operation exception if the reusable-ASN bit is one in the ASN-second-table entry located by ASN translation. These instructions do not make a comparison to the ASTEIN in the ASN-second-table entry.

Bit 30 of word 1 of the ASN-second-table entry is the controlled-ASN bit. Regardless of the value of the ASN-and-LX-reuse control, PROGRAM TRANSFER WITH INSTANCE and SET SECONDARY ASN WITH INSTANCE recognize a special-operation exception if the controlled-ASN bit is one in the ASN-second-table entry located by ASN translation and the CPU is in the problem state at the beginning of the operation.

A more detailed description of ASN reuse is given in “ASN-Second-Table-Entry Instance Number and ASN Reuse” on page 3-22.

**LX Reuse:** When the ASN-and-LX-reuse control is one, the linkage table is replaced by a linkage first table and, for each valid linkage-first-table entry, a linkage second table.

The second word of the linkage-second-table entry used contains an LSTE sequence number (LSTESN), and PROGRAM CALL recognizes an LSTE-sequence exception if this LSTESN is nonzero and not equal to an LSTESN specified by the program in general register 15.

A more detailed description of LX reuse is given in “ASN-and-LX-Reuse Control (R):” on page 5-35.

<table>
<thead>
<tr>
<th>Function or Instruction</th>
<th>Function Requirement</th>
<th>Mode Requirement</th>
<th>Authorization Mechanism</th>
<th>Space Switch Event Ctl.</th>
</tr>
</thead>
<tbody>
<tr>
<td>Implicit AR translation</td>
<td></td>
<td>A</td>
<td>SO-PA</td>
<td>(0.37)</td>
</tr>
<tr>
<td>BAKR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BSA-ba</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BSA-ra</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BSG</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>EPAR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>EPAIR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>EREG</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>EREGG</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 5-6. Summary of Authorization Mechanisms (Part 1 of 2)
### Explanation for Summary of Authorization Mechanisms:

The PSW-key mask is ANDed with the authorization key mask in the entry-table entry.

---

**Table 5-6:** Summary of Authorization Mechanisms  (Part 2 of 2)

<table>
<thead>
<tr>
<th>Function or Instruction</th>
<th>Mode Requirement</th>
<th>Authorization Mechanism</th>
<th>Space Switch Event Ctl.</th>
</tr>
</thead>
<tbody>
<tr>
<td>ESAR</td>
<td>P</td>
<td>SO-PSAH</td>
<td>Q</td>
</tr>
<tr>
<td>ESIAR</td>
<td>P</td>
<td>SO-PSAH</td>
<td>Q</td>
</tr>
<tr>
<td>ESTA</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>IAC</td>
<td>P</td>
<td>SO-PSAH</td>
<td>Q</td>
</tr>
<tr>
<td>IPK</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>IVSK</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>LASP</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>LPTEA</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>LRA</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>LHAG</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>MSTA</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>MVCOS</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>MVCP</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>MVCS</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>MVCSK</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>bPC-cp</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>sPC-cp</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>bPC-ss</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>sPC-ss</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>PR-ss</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>PT-cp</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>PTI-cp</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>PTI-ss</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>RP</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>SAC</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>SACF</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>SPKA</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>SSAR-cp</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>SSAR-ss</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>SSAIR-cp</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
<tr>
<td>SSAIR-ss</td>
<td>P</td>
<td>SO-PAH</td>
<td>Q</td>
</tr>
</tbody>
</table>

---

1 Explanation for Summary of Authorization Mechanisms: The PSW-key mask is ANDed with the authorization key mask in the entry-table entry.
The exception is recognized on an attempt to set the supervisor state when in the problem state.

The exception is recognized on an attempt to set the home-space mode when in the problem state.

ASN translation is performed for the new SASN, and the exception may be recognized, only when the new SASN is not equal to the new PASN.

Secondary authority is checked for the new SASN, and the exception may be recognized, only when the new SASN is not equal to the new PASN.

Subsystem-linkage control is bit 92 of the primary ASN-second-table entry.

ALE sequence number is bits 8-15 of the access-list entry.

ASTE sequence number is bits 160-191 of the ASN-second-table entry.

ASTE instance number is bits 352-383 of the ASN-second-table entry.

LSTE sequence number is bits 32-63 of the linkage-second-table entry.

Special-operation exception is recognized if ASN-and-LX-reuse control, bit 44 of control register 0, is one and reusable-ASN bit, bit 31 of word 1 of the ASN-second-table entry, is one.

Special-operation exception is recognized if controlled-ASN bit, bit 30 of word 1 of the ASN-second-table entry, is one and the CPU is in the problem state at the beginning of the operation.

Whether the exception is recognized is unpredictable.

Access-register translation occurs only in the access-register mode.

ASTE-instance exception.

ASTE-sequence exception.

ASTE-sequence exception

Basic (nonstacking) PROGRAM CALL.

Test results in setting a condition code.

Test results in setting a condition code. The test occurs only in the access-register mode.

Control register x, bit position y.

Extended-authority exception.

LSTE-sequence exception.

Privileged-operation exception for privileged instruction.

Primary-authority exception.

Primary-authority exception or secondary-authority exception.

Privileged-operation exception for semi-privileged instruction. Authority checked only in the problem state.

Secondary-authority exception.

Special-operation exception.

The secondary-space control, bit 37 of control register 0, must be one when either operand of MOVE WITH OPTIONAL SPECIFICATIONS is accessed in the secondary-space mode; otherwise, a special-operation exception is recognized.

CPU must be in the primary-space mode; special-operation exception if the CPU is in the secondary-space, access-register, home-space, or real mode.

CPU must be in the primary-space or access-register mode; special-operation exception if the CPU is in the secondary-space, home-space, or real mode.

CPU must be in the primary-space, access-register, or home-space mode; special-operation exception if the CPU is in the secondary-space or real mode.

CPU must be in the primary-space or secondary-space mode; special-operation exception if the CPU is in the home-space, access-register, or real mode.

CPU must be in the primary-space, secondary-space, access-register, or home-space mode; special-operation exception if the CPU is in the secondary-space or real mode.
space mode; special-operation exception if the CPU is in the real mode.

sPC Stacking PROGRAM CALL.

X1 When bit 57 of control register 1 is one, a space-switch event is recognized. The operation is completed.

X2 When bit 57 of control register 1 or 13 is one and the instruction space is changed to or from the home address space, a space-switch event is recognized. The operation is completed.

---

**PC-Number Translation**

PC-number translation is the process of translating PC number to locate an entry-table entry as part of the execution of the PROGRAM CALL instruction. When the ASN-and-LX-reuse facility is not installed or is not enabled, the PC number is 20 bits in bit positions 44-63 of the effective address used by PROGRAM CALL. When the ASN-and-LX-reuse facility is installed and enabled, the PC number is 20 bits in bit positions 44-63 of the effective address if bit 44 of the address is zero, or it is 32 bits in bit positions 32-63 of the address if bit 44 of the address is one. The facility is enabled if the ASN-and-LX-reuse control, bit 44 of control register 0, is one. The case when the facility is installed and enabled is referred to simply by saying that ASN-and-LX reuse is enabled.

To perform the translation of a PC number to locate an entry-table entry, the PC number is divided into two fields: a linkage index (LX) and an entry index (EX). The entry index is always the rightmost eight bits of the PC number. When ASN-and-LX reuse is not enabled, the leftmost 12 bits of the 20-bit PC number are the linkage index. In this case, the effective address has the following format:

```
<table>
<thead>
<tr>
<th>31</th>
<th>LX</th>
<th>EX</th>
</tr>
</thead>
</table>
```

Bit 44 of the effective address has no special meaning and may be zero or one.

When ASN-and-LX reuse is enabled, the linkage index is further divided into a linkage first index (LFX) and a linkage second index (LSX). The linkage second index is always the five bits immediately on the left of the entry index. The size and format of the linkage first index depend on whether the PC number is 20 bits or 32 bits, which in turn depends on whether bit 44 of the effective address is zero or one, respectively. In these cases, the effective address has the following formats:

**Effective Address when ASN-and-LX Reuse Is Enabled and Bit 44 Is Zero**

```
<table>
<thead>
<tr>
<th>63</th>
<th>LFX</th>
<th>LSX</th>
<th>EX</th>
</tr>
</thead>
</table>
```

**Effective Address when ASN-and-LX Reuse Is Enabled and Bit 44 Is One**

```
<table>
<thead>
<tr>
<th>63</th>
<th>LFX</th>
<th>LSX</th>
<th>EX</th>
</tr>
</thead>
</table>
```

When ASN-and-LX reuse is enabled and bit 44 of the effective address is zero, the linkage first index is bits 44-50, or bits 45-50 (LFX2) with a zero appended on the left. Thus, the linkage first index is seven bits of which the leftmost bit is always zero. When bit 44 is one, the linkage first index is bits 45-50 (LFX2) with bits 32-43 (LFX1) appended on the left, or 18 bits. However, a linkage first table can contain at most 16,384 entries, and, therefore, the leftmost four bits of the linkage first index, bits 32-35 of the effective address, must always be zeros; otherwise, an LFX-translation exception is recognized.

When ASN-and-LX reuse is not enabled, the translation of a PC number is performed by means of two tables: a linkage table and an entry table. When ASN-and-LX reuse is enabled, the translation is performed by means of three tables: a linkage first table,
a linkage second table, and an entry table. All of these tables reside in real storage. The linkage-table designation or linkage-first-table designation resides in another area in storage, called the primary ASN-second-table entry (primary ASTE), whose origin is in control register 5. When there are two levels of tables, the entry table is designated by means of a linkage-table entry. When there are three levels of tables, the linkage second table is designated by means of a linkage-first-table entry, and the entry table is designated by means of a linkage-second-table entry.

Programming Notes:

1. Bit 44 of a PROGRAM CALL effective address specifying a 32-bit PC number is not a numeric part of the PC number.

2. The effective address from which a PC number is derived is subject to the addressing mode in the current PSW. Therefore, bits 0-39 of the effective address in the 24-bit addressing mode, and bits 0-32 in the 31-bit addressing mode, are treated as containing zeros.

PC-Number Translation Control

PC-number translation is controlled by means of the ASN-and-LX-reuse control in control register 0 and a linkage-table designation or linkage-first-table designation in the primary ASN-second-table entry designated by the contents of control register 5.

Control Register 0

ASN-and-LX-Reuse Control (R): Bit 44 of control register 0 is the ASN-and-LX-reuse-control bit and is assigned if the ASN-and-LX-reuse facility is installed. When the bit is one, (1) the PC number is 20 bits if bit 44 of the effective address is zero or 32 bits if bit 44 is one, (2) the PC number is divided into a seven-bit (bit 44 is zero) or 18-bit (bit 44 is one) linkage first index, five-bit linkage second index, and eight-bit entry index, (3) the primary ASN-second-table entry contains a linkage-first-table designation instead of a linkage-table designation, and (4) the PC number is translated by means of a linkage first table, linkage second table, and entry table.

Also when the ASN-and-LX-reuse-control bit is one, if the linkage-second-table entry used during PC-number translation performed by PROGRAM CALL contains a nonzero linkage-second-table-entry sequence number (LSTESN), this LSTESN must be equal to an LSTESN specified in bit positions 0-31 of general register 15; otherwise, the PROGRAM CALL instruction cannot be completed, and an LSTE-sequence exception is recognized.

The ASN-and-LX-reuse control in control register 0 is examined in both the problem and the supervisor states. Other uses of this control, related to the ASN-second-table-entry instance number, are summarized in "ASN-Second-Table-Entry Instance Number and ASN Reuse" on page 3-22.

This use of the LSTESN allows a linkage index associated with a particular LSTESN to be made unusable when the linkage index is reassigned to specify a different (different origin) or conceptually different (different contents, or containing ASNs that designate conceptually different address spaces) entry table. The LX-and-LSTESN combination can be made unusable by changing the LSTESN in the linkage-second-table entry.

Control Register 5

Control register 5 specifies the location of the primary ASN-second-table entry. The register has the following format:

```
| 0 | 1 | 25 | 31 |
```

Primary-ASTE Origin (PASTEO): Bits 33-57 of control register 5, with six zeros appended on the right, form a 31-bit real address that designates the beginning of the primary ASTE. Bytes 24-27 of the primary ASTE contain the linkage-table designation if the ASN-and-LX-reuse facility is not installed or is not enabled by a one value of the ASN-and-LX-reuse control in control register 0, or they contain the linkage-first-table designation if the facility is installed and enabled.

The linkage-table designation has the following format:

```
| 0 | 1 |
```

5-35
Subsystem-Linkage Control (V): Bit 0 of the linkage-table designation is the subsystem-linkage-control bit. Bit 0 must be one to allow completion of these instructions:

- PROGRAM CALL
- PROGRAM TRANSFER
- PROGRAM TRANSFER WITH INSTANCE

Otherwise, a special-operation exception is recognized. The subsystem-linkage control is examined in both the problem and the supervisor states and controls both the space-switching and current-primary versions of the instructions.

Linkage-Table Origin: Bits 1-24 of the linkage-table designation, with seven zeros appended on the right, form a 31-bit real address that designates the beginning of the linkage table.

Linkage-Table Length (LTL): Bits 25-31 of the linkage-table designation specify the length of the linkage table in units of 128 bytes, thus making the length of the linkage table variable in multiples of 32 four-byte entries. The length of the linkage table, in units of 128 bytes, is one more than the value in bit positions 25-31. The linkage-table length is compared against the leftmost seven bits of the linkage-index portion of the PC number to determine whether the linkage index designates an entry within the linkage table.

The linkage-first-table designation has the following format:

<table>
<thead>
<tr>
<th>V</th>
<th>Linkage-First-Table Origin</th>
<th>LFTL</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Subsystem-Linkage Control (V): Bit 0 of the linkage-first-table designation has the same definition as bit 0 of the linkage-table designation.

Linkage-First-Table Origin: Bits 1-23 of the linkage-first-table designation, with eight zeros appended on the right, form a 31-bit real address that designates the beginning of the linkage first table.

Linkage-First-Table Length (LFTL): Bits 24-31 of the linkage-first-table designation specify the length of the linkage first table in units of 256 bytes, thus making the length of the linkage first table variable in multiples of 64 four-byte entries. The length of the linkage first table, in units of 256 bytes, is one more than the value in bit positions 24-31. When bit 44 of the effective address specifying the PC number is one, the linkage-first-table length is compared against the leftmost 12 bits of the linkage-first-index portion of the PC number, bits 32-43 of the effective address, to determine whether the linkage first index designates an entry within the linkage first table. When bit 44 of the effective address is zero, the linkage-first-table length is ignored.

PC-Number Translation Tables

If the ASN-and-LX-reuse facility is not installed or is not enabled by a one value of the ASN-and-LX-reuse control in control register 0, the PC-number translation process consists in a two-level lookup using two tables: a linkage table and an entry table. If the facility is installed and enabled, the PC-number translation process consists in a three-level lookup using three tables: a linkage first table, a linkage second table, and an entry table. All of these tables reside in real storage.

Linkage-Table Entries

The entry fetched from the linkage table has the following format:

<table>
<thead>
<tr>
<th>1</th>
<th>Entry-Table Origin</th>
<th>ETL</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The fields in the linkage-table entry are allocated as follows:

LX-Invalid Bit (I): Bit 0 controls whether the entry table associated with the linkage-table entry is available.

When the bit is zero, PC-number translation proceeds by using the linkage-table entry. When the bit is one, an LX-translation exception is recognized.

Entry-Table Origin: Bits 1-25, with six zeros appended on the right, form a 31-bit real address that designates the beginning of the entry table.

Entry-Table Length (ETL): Bits 26-31 specify the length of the entry table in units of 128 bytes, thus making the table variable in multiples of four 32-byte entries. The length of the entry table, in units of 128 bytes, is one more than the value in bit positions 26-31. The entry-table length is compared against the leftmost six bits of the entry index to determine...
whether the entry index designates an entry within the entry table.

**Linkage-First-Table Entries**
The entry fetched from the linkage first table has the following format:

<table>
<thead>
<tr>
<th>Bit 0</th>
<th>1</th>
<th>24</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>Linage-Second-Table Origin</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The fields in the linkage-first-table entry are allocated as follows:

**LFX-Invalid Bit (I):** Bit 0 controls whether the linkage second table associated with the linkage-first-table entry is available.

When the bit is zero, PC-number translation proceeds by using the linkage-first-table entry. When the bit is one, an LFX-translation exception is recognized.

**Linkage-Second-Table Origin:** Bits 1-23, with eight zeros appended on the right, form a 31-bit real address that designates the beginning of the linkage second table.

**Programming Note:** The unused field in the linkage-first-table entry, bits 24-31, should be set to zeros. This field is reserved for future extensions, and programs which place nonzero values in this field may not operate compatibly on future machines.

**Linkage-Second-Table Entries**
The entry fetched from the linkage second table has the following format:

<table>
<thead>
<tr>
<th>Bit 0</th>
<th>1</th>
<th>25</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>Entry-Table Origin</td>
<td>ETL</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The fields in the linkage-second-table entry are allocated as follows:

**LSX-Invalid Bit (I):** Bit 0 controls whether the entry table associated with the linkage-second-table entry is available.

When the bit is zero, PC-number translation proceeds by using the linkage-second-table entry. When the bit is one, an LSX-translation exception is recognized.

**Entry-Table Origin:** Bits 1-25, with six zeros appended on the right, form a 31-bit real address that designates the beginning of the entry table.

**Entry-Table Length (ETL):** Bits 26-31 specify the length of the entry table in units of 128 bytes, thus making the table variable in multiples of four 32-byte entries. The length of the entry table, in units of 128 bytes, is one more than the value in bit positions 26-31. The entry-table length is compared against the leftmost six bits of the entry index to determine whether the entry index designates an entry within the entry table.

**Linkage-Second-Table-Entry Sequence Number (LSTESN):** During PC-number translation in PROGRAM CALL when bits 32-63 are not all zeros, bits 32-63 are compared to an LSTESN specified in bit positions 0-31 of general register 15. The comparison must give an equal result; otherwise, an LSTE-sequence exception is recognized. When bits 32-63 are all zeros, bits 0-31 of general register 15 are ignored.

**Programming Note:** The format of bits 0-31 of the linkage-second-table entry is the same as the format of the linkage-table entry.

**Entry-Table Entries**
The format of bits 0-63 of the entry-table entry depends on whether the addressing-mode in effect after the PROGRAM CALL operation is the extended (64-bit) addressing mode or a basic (24-bit or 31-bit) addressing mode. This in turn depends on bits 128 and 129 of the entry-table entry.

Bit 128 of the entry-table entry (T) is the PC-type bit. When bit 128 is zero, PROGRAM CALL is to perform the basic (nonstacking) operation. When bit 128 is one, PROGRAM CALL is to perform the stacking operation.

Bit 129 of the entry-table entry (G) is the entry-extended-addressing-mode bit. In the basic extended-addressing-mode bit, must equal bit 129; otherwise, a special-operation exception is recognized. In the stacking operation when bit 129 is zero, bit 31 of the current PSW is set to zero, and bit 32 of the PSW, the basic-addressing-mode bit, is set with the value of bit 32 of the entry-table entry (A), the entry-basic-addressing-mode bit. In the stacking operation when bit 129 is one, bits 31 and 32 of the
current PSW both are set to one. Thus, the basic PROGRAM CALL operation does not switch between the extended and a basic addressing mode but can switch between the 24-bit and 31-bit modes, and the stacking operation can set any addressing mode.

The 32-byte entry-table entry has the following format:

<table>
<thead>
<tr>
<th>If Bit 129 is Zero</th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>31</td>
<td>A</td>
<td>Entry Instruction Address</td>
<td>P</td>
</tr>
<tr>
<td>32</td>
<td>33</td>
<td>63</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>If Bit 129 is One</th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>31</td>
<td>Entry Instruction Address (Part 1)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>63</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

If Bit 129 is Zero

<table>
<thead>
<tr>
<th>If Bit 129 is One</th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>31</td>
<td>Entry Instruction Address (Part 2)</td>
<td>P</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>63</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Remaining fields (independent of bit 129)

<table>
<thead>
<tr>
<th>Authorization Key Mask</th>
<th>ASN</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
<td>80</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Entry Key Mask</th>
</tr>
</thead>
<tbody>
<tr>
<td>96</td>
</tr>
</tbody>
</table>

If Bit 129 is Zero

<table>
<thead>
<tr>
<th>Linkage-Stack Fields</th>
</tr>
</thead>
<tbody>
<tr>
<td>128</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ASTE Origin</th>
</tr>
</thead>
<tbody>
<tr>
<td>160</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Entry Parameter (Part 1)</th>
</tr>
</thead>
<tbody>
<tr>
<td>192</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Entry Parameter (Part 2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>224</td>
</tr>
</tbody>
</table>

The fields in the entry-table entry are allocated as follows:

**Entry Basic Addressing Mode (A):** When bit 129 is zero, bit 32 replaces the basic-addressing-mode bit, bit 32 of the current PSW, as part of the PROGRAM CALL operation. In this case if bit 32 is zero, bits 33-39 must also be zeros; otherwise, a PC-translation-specification exception is recognized. When bit 129 is one, bit 32 is a bit of the entry instruction address, and bit 32 of the PSW remains or is set to one.

**Entry Instruction Address:** When bit 129 is zero, bits 33-62, with 33 zeros appended on the left and a zero appended on the right, form the instruction address which replaces the instruction address in the PSW as part of the PROGRAM CALL operation. When bit 129 is one, bits 0-62, with a zero appended on the right, form the instruction address.

**Entry Problem State (P):** Bit 63 replaces the problem-state bit, bit 15 of the current PSW, as part of the PROGRAM CALL operation.

**Authorization Key Mask:** Bits 64-79 are used to verify whether the program issuing the PROGRAM CALL instruction, when in the problem state, is authorized to call this entry point. The authorization key mask and the current PSW-key mask in control register 3 are ANDed, and the result is checked for all zeros. If the result is all zeros, a privileged-operation exception is recognized. The test is not performed in the supervisor state.

**ASN:** Bits 80-95 specify whether a space-switching (PC-ss) operation or a to-current-primary (PC-cp) operation is to occur. When bits 80-95 are zeros, PC-cp is specified. When bits 80-95 are not all zeros, PC-ss is specified, and the bits are the ASN that replaces the primary ASN.

**Entry Key Mask:** Bits 96-111 may be ORed into or may replace the PSW-key mask in control register 3 as part of the PROGRAM CALL operation, as determined by a bit in bit positions 130-159.

**PC-Type Bit (T):** Bit 128 specifies the basic PROGRAM CALL operation when the bit is zero or the stacking PROGRAM CALL operation when the bit is one.

**Entry Extended Addressing Mode (G):** In the basic PROGRAM CALL operation, bit 129 must match the extended-addressing-mode bit, bit 31 of the current PSW; otherwise, a special-operation exception is recognized. In the stacking operation, bit 129 replaces bit 31 of the PSW.

**ASTE Origin:** When bits 80-95 are not all zeros, bits 161-185, with six zeros appended on the right, form the 31-bit real ASN-second-table-entry address that should result from applying the ASN-translation process to bits 80-95.

**Entry Parameter:** When bit 129 is zero, bits 224-255 are placed in bit positions 32-63 of general register 4, and bits 0-31 of the register remain unchanged, as part of the PC operation. When bit
129 is one, bits 192-255 are placed in general register 4 as part of the PC operation.

Bits 130-159 are used in connection with the linkage stack and are described in "Linkage-Stack Entry-Table Entries" on page 5-76.

Bits 112-127, 160, and 186-191 are reserved for possible future extensions and should be zeros.

**Programming Note:** The entry parameter is intended to provide the called program with an address which can be depended upon and used as the basis of addressability in locating necessary information which may be environment dependent. The parameter may be appropriately changed for each environment by setting up different entry tables. The alternative — obtaining this information from the calling program — may require extensive validity checking or may present an integrity exposure.

**Table Summary**

Figure 5-7 on page 5-39 presents a summary of information about the tables used in PC-number translation, except for the primary ASN second table.

**PC-Number-Translation Process**

When the ASN-and-LX-reuse facility is not installed or is not enabled, the translation of the PC number is performed by means of a linkage table and entry table. When the ASN-and-LX-reuse facility is installed and enabled, referred to by saying that ASN-and-LX reuse is enabled, the translation of the PC number is performed by means of a linkage first table, linkage second table and entry table. All of these tables reside in real storage. The translation also requires the use of the primary ASN-second-table entry, which also resides in real storage.

For the purposes of PC-number translation, the PC number is divided into two parts: the leftmost part is called the linkage index (LX), and the rightmost eight bits are called the entry index (EX). When ASN-and-LX reuse is not enabled, the PC number is 20 bits, and the linkage index is 12 bits. When ASN-and-LX reuse is enabled, the linkage index also is divided into two parts: the leftmost part is called the linkage first index (LFX), and the rightmost five bits are called the linkage second index (LSX). When ASN-and-LX reuse is enabled and bit 44 of the effective address specifying the PC number is zero, the PC number is 20 bits, and the linkage first index is seven bits, or, when bit 44 is one, the PC number is 32 bits, and the linkage first index is 18 bits.

When ASN-and-LX reuse is not enabled, the LX is used to select an entry from the linkage table, the starting address and length of which are specified by the linkage-table designation in the primary ASTE. This entry designates the entry table to be used. The EX field of the PC number is used to select an entry from the entry table.

When ASN-and-LX reuse is enabled, the LFX is used to select an entry from the linkage first table, the starting address and length of which are specified by the linkage-first-table designation in the primary ASTE. This entry designates the linkage second table to be used. The LSX is then used to select an entry from the linkage second table, which entry designates the entry table to be used. The EX field of the PC number is used to select an entry from the entry table.

**Table**

<table>
<thead>
<tr>
<th>Table</th>
<th>Boundary (Bytes)</th>
<th>Entry Size (Bytes)</th>
<th>Unit Size</th>
<th>Maximum Number of Units</th>
<th>Maximum Size</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>Bytes</td>
<td>Entries</td>
<td></td>
</tr>
<tr>
<td>Linkage Table</td>
<td>12</td>
<td>4</td>
<td>128</td>
<td>32</td>
<td>128</td>
</tr>
<tr>
<td>Linkage First Table</td>
<td>256</td>
<td>4</td>
<td>256</td>
<td>64</td>
<td>256</td>
</tr>
<tr>
<td>Linkage Second Table</td>
<td>256</td>
<td>8</td>
<td>256</td>
<td>32</td>
<td>1</td>
</tr>
<tr>
<td>Entry Table</td>
<td>64</td>
<td>32</td>
<td>128</td>
<td>4</td>
<td>64</td>
</tr>
</tbody>
</table>

**Explanation:**

1. A 20-bit PC number can specify an entry only within the first unit. Bits 0-3 of a 32-bit PC number specify entries beyond the end of the largest possible table.

Figure 5-7. Summary of PC-Number-Translation Tables

5-39
PC number is then used to select an entry from the entry table.

When ASN-and-LX reuse is enabled, a linkage-second-table-entry sequence number (LSTESN) in general register 15 is compared to the LSTESN in the linkage-second-table entry if the LSTESN in the entry is nonzero.

When, for the purposes of PC-number translation, accesses are made to main storage to fetch entries from the primary ASTE, linkage table, linkage first table, linkage second table, and entry table, key-controlled protection does not apply.

The PC-number-translation process is shown in Figure 5-8 on page 5-41 for when ASN-and-LX-reuse is not enabled and in Figure 5-9 on page 5-42 for when it is enabled.
R: Address is real.
**: First word and A of ETE are bits 0-32 of entry-instruction address (EIA) if G is one.

Figure 5-8. PC-Number Translation when ASN-and-LX Reuse Is Not Enabled
Figure 5-9. PC-Number Translation when ASN-and-LX Reuse Is Enabled

- **R**: Address is real.
- ****: PC Number is 32 bits if bit 44 of the effective address is one. Bit 44 is not shown in this case.
- ****: First word and A of ETE are bits 0-32 of entry-instruction address (EIA) if G is one.

---

IBM z/Architecture Principles of Operation
Obtaining the Linkage-Table or Linkage-First-Table Designation

The linkage-table or linkage-first-table designation is obtained from bytes 24-27 of the primary ASN-second-table entry, the starting address of which is specified by the contents of control register 5.

The 31-bit real address of the linkage-table or linkage-first-table designation is obtained by appending six zeros on the right to the primary-ASTE origin, bits 33-57 of control register 5, and adding 24. The addition cannot cause a carry into bit position 0. The 31-bit address is formed and used regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

All four bytes of the linkage-table or linkage-first-table designation appear to be fetched concurrently from the primary ASTE as observed by other CPUs. The fetch access is not subject to protection. When the storage address which is generated for fetching the linkage-table or linkage-first-table designation designates a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed. Besides the linkage-table or linkage-first-table designation, no other field in the primary ASTE is examined.

Linkage-Table Lookup

When the ASN-and-LX-reuse facility is not installed or the ASN-and-LX-reuse-control bit, bit 44 of control register 0, is zero, the field fetched from the primary ASTE is a linkage-table designation. The linkage-index (LX) portion of the PC number, in conjunction with the linkage-table origin, is used to select an entry from the linkage table.

The 31-bit real address of the linkage-table entry is obtained by appending seven zeros on the right to the contents of bit positions 1-24 of the linkage-table designation and adding the linkage index, with two rightmost and 17 leftmost zeros appended. When a carry into bit position 0 occurs during the addition, an addressing exception may be recognized, or the carry may be ignored, causing the table to wrap from $2^{31} - 1$ to 0. The 31-bit address is formed and used regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

As part of the linkage-table-lookup process, the leftmost seven bits of the linkage index are compared against the linkage-table length, bits 25-31 of the linkage-table designation, to establish whether the addressed entry is within the linkage table. If the value in the linkage-table-length field is less than the value of the seven leftmost bits of the linkage index, an LX-translation exception is recognized.

All four bytes of the linkage-table entry appear to be fetched concurrently as observed by other CPUs. The fetch access is not subject to protection. When the storage address which is generated for fetching the linkage-table entry designates a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

Bit 0 of the linkage-table entry specifies whether the entry table corresponding to the linkage index is available. This bit is inspected, and, if it is one, an LX-translation exception is recognized.

When no exceptions are recognized in the process of linkage-table lookup, the entry fetched from the linkage table designates the origin and length of the corresponding entry table.

Linkage-First-Table Lookup

When the ASN-and-LX-reuse facility is installed and the ASN-and-LX-reuse-control bit, bit 44 of control register 0, is one, the field fetched from the primary ASTE is a linkage-first-table designation. The linkage-first-index (LFX) portion of the PC number, in conjunction with the linkage-first-table origin, is used to select an entry from the linkage first table.

When bit 44 of the effective address of PROGRAM CALL is zero, the PC number is 20 bits, the linkage first index is bits 44-50 of the effective address, and the 31-bit real address of the linkage-first-table entry is obtained by appending eight zeros on the right to the contents of bit positions 1-23 of the linkage-first-table designation and adding the linkage first index, with two rightmost and 22 leftmost zeros appended.

When bit 44 of the effective address of PROGRAM CALL is one, the PC number is 32 bits, the linkage first index is bits 32-43 of the effective address appended on the left of bits 45-50 of the effective address, and the 31-bit real address of the linkage-first-table entry is obtained by appending eight zeros on the right to the contents of bit positions 1-23 of the linkage-first-table designation and adding the linkage first index, with two rightmost and 11 leftmost zeros appended.

When bit 44 of the effective address of PROGRAM CALL is one, the PC number is 32 bits, the linkage first index is bits 32-43 of the effective address appended on the left of bits 45-50 of the effective address, and the 31-bit real address of the linkage-first-table entry is obtained by appending eight zeros on the right to the contents of bit positions 1-23 of the linkage-first-table designation and adding the linkage first index, with two rightmost and 11 leftmost zeros appended.
When bit 44 of the effective address is one and a carry into bit position 0 occurs during the addition to form the address of a linkage-first-table entry, an addressing exception may be recognized, or the carry may be ignored, causing the table to wrap from \(2^{31} - 1\) to 0.

When bit 44 of the effective address is either zero or one, the 31-bit address of the linkage-first-table entry is formed and used regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

As part of the linkage-first-table-lookup process when bit 44 of the effective address is one, the leftmost 12 bits of the linkage first index are compared against the linkage-first-table length, bits 24-31 of the linkage-first-table designation, to establish whether the addressed entry is within the linkage first table. For this comparison, the linkage-first-table length is extended with four zero bits on the left. If the value of the extended linkage-first-table length is less than the value of the 12 leftmost bits of the linkage first index, an LFX-translation exception is recognized.

All four bytes of the linkage-first-table entry appear to be fetched concurrently as observed by other CPUs. The fetch access is not subject to protection. When the storage address which is generated for fetching the linkage-first-table entry designates a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

Bit 0 of the linkage-first-table entry specifies whether the entry table corresponding to the linkage first index is available. This bit is inspected, and, if it is one, an LFX-translation exception is recognized.

When no exceptions are recognized in the process of linkage-first-table lookup, the entry fetched from the linkage first table designates the origin of the corresponding linkage second table. The 31-bit real address of the linkage-second-table entry is obtained by appending eight zeros on the right to the linkage-second-table origin, bits 1-23 of the linkage-first-table entry, and adding the linkage second index, with three rightmost and 23 leftmost zeros appended. A carry into bit position 0 cannot occur during this addition. The 31-bit address is formed and used regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

All eight bytes of the linkage-second-table entry appear to be fetched concurrently as observed by other CPUs. The fetch access is not subject to protection. When the storage address which is generated for fetching the linkage-second-table entry designates a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

Bit 0 of the linkage-second-table entry specifies whether the entry table corresponding to the linkage second index is available. This bit is inspected, and, if it is one, an LSX-translation exception is recognized.

When no exceptions are recognized in the process of linkage-second-table lookup, the entry fetched from the linkage second table designates the origin of the corresponding entry table. The linkage-second-table entry contains a linkage-second-table-entry sequence number that may be used to test the correctness of the use of the linkage index.

**Linkage-Second-Table-Entry-Sequence-Number Comparison**

The linkage-second-table entry contains a linkage-second-table-entry sequence number (LSTESN) in bit positions 32-63. If this LSTESN is nonzero, it is compared to an LSTESN in bit positions 0-31 of general register 15, and an LSTE-sequence exception is recognized if the two LSTESNs are not equal.

**Entry-Table Lookup**

When the ASN-and-LX-reuse facility is not installed or is not enabled, the entry-table entry is located from a linkage-table entry. When the ASN-and-LX-reuse facility is installed and enabled, the entry-table entry is located from a linkage-second-table entry.

The entry-index (EX) portion of the PC number, in conjunction with the entry-table origin contained in the linkage-table or linkage-second-table entry, is used to select an entry from the entry table.
The 31-bit real address of the entry-table entry is obtained by appending six zeros on the right to the entry-table origin bits 1-25 of the linkage-table or linkage-second-table entry, and adding the entry index, with five rightmost and 18 leftmost zeros appended. When a carry into bit position 0 occurs during the addition, an addressing exception may be recognized, or the carry may be ignored, causing the table to wrap from $2^{31} - 1$ to 0. The 31-bit address is formed and used regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

As part of the entry-table-lookup process, the six leftmost bits of the entry index are compared against the entry-table length, bits 26-31 of the linkage-table or linkage-second-table entry, to establish whether the addressed entry is within the table. If the value in the entry-table length field is less than the value of the six leftmost bits of the entry index, an EX-translation exception is recognized.

The 32-byte entry-table entry is fetched by using the real address. The fetch of the entry appears to be word concurrent, as observed by other CPUs, with the leftmost word fetched first. The order in which the remaining seven words are fetched is unpredictable. The fetch access is not subject to protection. When the storage address which is generated for fetching the entry-table entry designates a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

The use that is made of the information fetched from the entry-table entry is described in the definition of the PROGRAM CALL instruction.

**Recognition of Exceptions during PC-Number Translation**

The exceptions which can be encountered during the PC-number-translation process and their priority are described in the definition of the PROGRAM CALL instruction.

**Programming Note:** The linkage-table or linkage-first-table designation is fetched successfully from the primary ASN-second-table entry regardless of the value of bit 0, the ASX-invalid bit, in the primary ASTE. A one value of this bit may cause an exception to be recognized in other circumstances.

---

**Home Address Space**

Facilities are provided which a privileged program, such as the control program, can use to obtain control in and access the home address space of a dispatchable unit (for example, a task).

Each dispatchable unit normally has an address space associated with it in which the control program keeps the principal control blocks that represent the dispatchable unit. This address space is called the home address space of the dispatchable unit. Different dispatchable units may have the same or different home address spaces. When the control program initiates a dispatchable unit, it may set the primary and secondary address spaces equal to the home address space of the dispatchable unit. Thereafter, because of the dispatchable unit's possible use of the PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, or SET SECONDARY ASN instruction, the control program normally cannot depend on either the primary address space or the secondary address space being the home address space when the home address space must be accessed, for example, during the processing by the control program of an interruption. Therefore, the control program normally must take some special action to ensure that the home address space is addressed when it must be accessed. The home-address-space facilities provide an efficient means to take this action.

The home-address-space facilities include:

- The home address-space-control element (HASCE) in control register 13. The HASCE is used by DAT in the same way as the primary address-space-control element (PASCE) in control register 1 and the secondary address-space-control element (SASCE) in control register 7.
- Home-space mode, which results when DAT is on and the address-space control, PSW bits 16 and 17, has the value 11 binary. When the CPU is in the home-space mode, instruction and logical addresses are home virtual addresses and are translated by DAT by means of the HASCE.
- The ability of the RESUME PROGRAM, SET ADDRESS SPACE CONTROL, and SET ADDRESS SPACE CONTROL FAST instructions to set the home-space mode in the supervisor state, and the ability of the INSERT ADDRESS
SPACE CONTROL instruction to return an indication of the home-space mode.

- The home space-switch-event control, bit 57 of control register 13.

- Recognition of a space-switch event upon completion of a RESUME PROGRAM, SET ADDRESS SPACE CONTROL, or SET ADDRESS SPACE CONTROL FAST instruction if the CPU was in the home-space mode before or after the operation but not both before and after the operation, if any of the following is true: (1) the primary space-switch-event control, bit 57 of control register 1, is one, (2) the home space-switch-event control is one, or (3) a PER event is to be indicated.

The space-switch event can be used to enable or disable PER or tracing when fetching of instructions begins or ends in particular address spaces.

**Access-Register Introduction**

Many of the functions related to access registers are described in this section and in “Subroutine Linkage without the Linkage Stack” on page 5-14, “Access-Register Translation” on page 5-54, and “Sequence of Storage References” on page 5-111. Additionally, translation modes and access-list-controlled protection are described in Chapter 3, “Storage”; the PER means of restricting storage-alteration events to designated address spaces and the handling of access registers during resets and during the store-status operation are described in Chapter 4, “Control”; interruptions are described in Chapter 6, “Interruptions”; instructions are described in Chapter 7, “General Instructions”, and Chapter 10, “Control Instructions”; the handling of access registers during a machine-check interruption and the programmed validation of the access registers are described in Chapter 11, “Machine-Check Handling”; and the alter-and-display controls for access registers are described in Chapter 12, “Operator Facilities.”

**Summary**

These major functions are provided:

- A maximum of 16 address spaces, including the instruction space, for immediate and simultaneous use by a semiprivileged program; the address spaces are specified by 16 registers called access registers.
- Instructions for examining and changing the contents of the access registers.

In addition, control and authority mechanisms are incorporated to control these functions.

Access registers allow a sequence of instructions, or even a single instruction such as MOVE (MVC) or MOVE LONG (MVCL), to operate on storage operands in multiple address spaces, without the requirement of changing either the translation mode or other control information. Thus, a program residing in one address space can use the complete instruction set to operate on data in that address space and in up to 15 other address spaces, and it can move data between any and all pairs of these address spaces.

Furthermore, the program can change the contents of the access registers in order to access still other address spaces.

The instructions for examining and changing access-register contents are unprivileged and are described in Chapter 7, “General Instructions.” They are:

- COPY ACCESS
- EXTRACT ACCESS
- LOAD ACCESS MULTIPLE
- LOAD ADDRESS EXTENDED
- SET ACCESS
- STORE ACCESS MULTIPLE

The privileged PURGE ALB instruction and COMPARE AND SWAP AND PURGE instruction are used in connection with access registers and are described in Chapter 10, “Control Instructions.”

Access registers specify address spaces when the CPU is in the access-register mode. The SET ADDRESS SPACE CONTROL and SET ADDRESS SPACE CONTROL FAST instructions allow setting of the access-register mode, and the INSERT ADDRESS SPACE CONTROL instruction provides an indication of the access-register mode. The stacking PROGRAM CALL, PROGRAM RETURN, and RESUME PROGRAM instructions also allow setting of the access-register mode. All of these instructions are described in Chapter 10, “Control Instructions.”

Access registers are used in a special way by the BRANCH IN SUBSPACE GROUP instruction. The use of access registers by that instruction is
described in detail only in the definition of the instruction in Chapter 10, “Control Instructions.” However, “Subspace-Group Tables” on page 5-67 describes the use of the dispatchable-unit control table and the extended ASN-second-table entry by BRANCH IN SUBSPACE GROUP.

Access-Register Functions

Access-Register-Specified Address Spaces

The CPU includes sixteen 32-bit access registers numbered 0-15. In the access-register mode, which results when DAT is on and PSW bits 16 and 17 are 01 binary, an instruction B or R field that is used to specify the logical address of a storage operand designates not only a general register but also an access register. The designated general register is used in the ordinary way to form the logical address of the storage operand. The designated access register is used to specify the address space to which the logical address is relative. The access register specifies the address space by specifying an address-space-control element for the address space, and this address-space-control element is used by DAT to translate the logical address. An access register specifies an address-space-control element in an indirect way, not by containing the address-space-control element.

An access register may specify the primary or secondary address-space-control element in control register 1 or 7, respectively, or it may specify an address-space-control element contained in an ASN-second-table entry. In the latter case, the access register designates an entry in a table called an access list, and the designated access-list entry in turn designates the ASN-second-table entry.

The process of using the contents of an access register to obtain an address-space-control element for use by DAT is called access-register translation (ART). This is depicted in Figure 5-10.

An access register is said to specify an AR-specified address space by means of an AR-specified address-space-control element. The virtual addresses in an AR-specified address space are called AR-specified virtual addresses.

In the access-register mode, whereas all storage-operand addresses are AR-specified virtual, instruction addresses are primary virtual.

Designating Access Registers: In the access-register mode, an instruction B or R field designates an access register, for use in access-register translation, under the following conditions:

- The field is a B field which designates a general register containing a base address. The base address is used, along with a displacement (D) and possibly an index (X), to form the logical address of a storage operand.
- The field is an R field which designates a general register containing the logical address of a storage operand.
For example, consider the following instruction:

\[ \text{MVC 0(L,1),0(2)} \]

The second operand, of length \( L \), is to be moved to the first-operand location. The logical address of the second operand is in general register 2, and that of the first-operand location in general register 1. The address space containing the second operand is specified by access register 2, and that containing the first-operand location by access register 1. These two address spaces may be different address spaces, and each may be different from the current instruction address space (the primary address space).

When PSW bits 16 and 17 are 01, the \( B_2 \) field of the LOAD REAL ADDRESS and STORE REAL ADDRESS instructions designates an access register, for use in access-register translation, regardless of whether DAT is on or off. When the \( M_4 \) field of the LOAD PAGE-TABLE-ENTRY ADDRESS instruction is 0001 binary, or when the \( M_4 \) field is 0100 binary and bits 16-17 of the PSW are 01 binary, then the \( R_2 \) field designates an access register, for use in access-register translation, regardless of whether DAT is on or off. The \( B_1 \) field of TEST ACCESS designates an access register regardless of whether DAT is on or off and regardless of PSW bits 16-17.

The COMPARE AND FORM CODEWORD and UPDATE TREE instructions specify storage operands by means of implicitly designated general registers and access registers.

The MOVE TO PRIMARY and MOVE TO SECONDARY instructions specify storage operands by means of primary virtual and secondary virtual addresses, and access registers do not apply to these instructions. An exception is recognized when either of these instructions is executed in the access-register mode. The MOVE WITH KEY instruction can be used in place of MOVE TO PRIMARY and MOVE TO SECONDARY in the access-register mode. The MOVE WITH SOURCE KEY and MOVE WITH DESTINATION KEY instructions also can be used. The MOVE WITH OPTIONAL SPECIFICATIONS instruction can be used in place of MOVE TO PRIMARY, MOVE TO SECONDARY, MOVE WITH KEY, or MOVE WITH SOURCE KEY in the access-register mode.

An instruction \( R \) field may designate an access register for other than the purpose of access-register translation.

The fields which may designate access registers, whether or not for access-register translation, are indicated in the summary figure at the beginning of each instruction chapter.

**Obtaining the Address-Space-Control Element:**
This section and the following ones introduce the access-register-translation process and present the concepts related to access lists.

The address-space-control element specified by an access register is obtained by access-register translation as follows:

- If the access register contains 00000000 hex, the specified address-space-control element is the primary address-space-control element (PASCE), obtained from control register 1.
- If the access register contains 00000001 hex, the specified address-space-control element is the secondary address-space-control element (SASCE), obtained from control register 7.
- If the access register contains any other value, the specified address-space-control element is obtained from an ASN-second-table entry. The contents of the access register designate an access-list entry that contains the real origin of the ASN-second-table entry.

Access register 0 is treated in a special way by access-register translation; it is treated as containing 00000000 hex, and its actual contents are not examined. Thus, a logical address specified by means of a zero \( B \) or \( R \) field in the access-register mode is always relative to the primary address space, regardless of the contents of access register 0. However, there is one exception to how access register 0 is treated: the TEST ACCESS instruction uses the actual contents of access register 0, instead of treating access register 0 as containing 00000000 hex.

The treatment of an access register containing the value 00000000 hex as designating the current primary address space allows that address space to be addressed, in the access-register mode, without
requiring the use of an access-list entry. This is useful when the primary address space is changed by a space-switching PROGRAM CALL (PC-ss), PROGRAM RETURN (PR-ss), or PROGRAM TRANSFER (PT-ss) instruction. Similarly, the treatment of an access register containing the value 00000001 hex as designating the secondary address space allows that space to be addressed after a space-switching operation, again without requiring the use of an access-list entry.

The contents of the access registers are not changed by the PROGRAM CALL and PROGRAM TRANSFER instructions. Therefore, an access register containing 00000000 or 00000001 hex may specify a different address space after the execution of PROGRAM CALL or PROGRAM TRANSFER than before the execution. For example, if a space-switching PROGRAM CALL instruction is executed, an access register containing 00000000 hex specifies the old primary address space before the execution and the new primary address space after the execution.

**Access Lists:** The access-list entry that is designated by the contents of an access register can be located in either one of two access lists, the dispatchable-unit access list or the primary-space access list. A bit in the access register specifies which of the two access lists contains the designated entry. Both of the access lists reside in real or absolute storage. The locations of the access lists are specified by means of control registers 2 and 5.

Control register 2 contains the origin of a real-storage area called the dispatchable-unit control table. The dispatchable-unit control table contains the designation — the real or absolute origin, and length — of the dispatchable-unit access list.

Control register 5 contains the origin of a real-storage area called the primary ASN-second-table entry. The primary ASN-second-table entry contains the designation of the primary-space access list.

An access list, either the dispatchable-unit access list or the primary-space access list, contains some multiple of eight 16-byte entries, up to a maximum of 1,024 entries.

**Programs and Dispatchable Units:** When discussing access lists, it is necessary to distinguish between the terms “program” and “dispatchable unit.” A program is a sequence of instructions and may be referred to as a program module. A program may be a sequence of calling and called programs. A dispatchable unit, which is sometimes called a process or a task, is a unit of work that is performed through the execution of a program by one CPU at a time. The dispatchable-unit access list is intended to be associated with a dispatchable unit; that is, it is intended that a dispatchable unit have the same dispatchable-unit access list regardless of which program is currently being executed to perform the dispatchable unit. There is no mechanism, except for the LOAD CONTROL instruction, that changes the dispatchable-unit-control-table origin in control register 2.

The primary-space access list is associated with the primary address space that is specified by the primary ASN in control register 4 and the primary address-space-control element in control register 1. The primary-space access list that is available for use by a dispatchable unit changes as the primary address space of the dispatchable unit changes, that is, whenever a program in a different primary address space begins to be executed to perform the dispatchable unit. Whenever a LOAD ADDRESS SPACE PARAMETERS, PROGRAM CALL, PROGRAM RETURN, or PROGRAM TRANSFER instruction replaces the primary ASN in control register 4 and the primary address-space-control element in control register 1, it also replaces the primary-ASN-second-table-entry origin in control register 5.

Thus, for a dispatchable unit, the dispatchable-unit access list is intended to be constant (although its entries may be changed, as will be described), and the primary-space access list is a function of which program is being executed, through being a function of the primary address space of the program. Also, all dispatchable units and programs in the same primary address space have the same primary-space access list.

**Access-List-Entry Token:** The contents of an access register are called an access-list-entry token (ALET) since, in the general case, they designate an entry in an access list. An ALET has the following format:

```
0 0 0 0 0 0 0 P  ALESN  ALEN
```

The ALET contains a primary-list bit (P) that specifies which access list contains the designated access-list entry: the dispatchable-unit access list if the bit is
zero, or the primary-space access list if the bit is one.
The specified access list is called the effective access list.

The ALET also contains an access-list-entry number (ALEN) which, when multiplied by 16, is the number of bytes from the beginning of the effective access list to the designated access-list entry. During access-register translation, an exception is recognized if the ALEN designates an entry that is outside the effective access list or if the leftmost seven bits in the ALET are not all zeros.

The access-list-entry sequence number (ALESN) in the ALET is described in the next section.

The above format of the ALET does not apply when the ALET is 00000000 or 00000001 hex.

An ALET can exist in an access register, in a general register, or in storage, and it has no special protection from manipulation by the problem program. Any program can transfer ALETs back and forth among access registers, general registers, and storage. A called program can save the contents of the access registers in any storage area available to it, load and use the access registers for its own purposes, and then restore the original contents of the access registers before returning to its caller.

**Allocating and Invalidating Access-List Entries:** It is intended that access lists be provided by the control program and that they be protected from direct manipulation by any problem program. This protection may be obtained by means of key-controlled protection or by placing the access lists in real storage not accessible by any problem program by means of DAT.

As determined by a bit in the entry, an access-list entry is either valid or invalid. A valid access-list entry specifies an address space and can be used by a suitably authorized program to access that space. An invalid access-list entry is available for allocation as a valid entry. It is intended that the control program provide services that allocate valid access-list entries and that invalidate previously allocated entries.

Allocation of an access-list entry may consist in the following steps. A problem program passes some kind of identification of an address space to the control program, and it passes a specification of either the dispatchable-unit access list or the primary-space access list. The control program checks, by some means, the authority of the problem program to access the address space. If the problem program is authorized, the control program selects an invalid entry in the specified access list, changes it to a valid entry specifying the subject address space, and returns to the problem program an access-list-entry token (ALET) that designates the allocated entry. The problem program can subsequently place the ALET in an access register in order to access the address space. Later, through the use of the invalidation service of the control program, the access-list entry that was allocated may be made invalid. An exception is recognized during access-register translation if an ALET is used that designates an invalid access-list entry.

It may be that a particular access-list entry is allocated, then invalidated, and then allocated again, this time specifying a different address space than the first time. To guard against erroneous use of an ALET that designates a conceptually wrong address space, an access-list-entry sequence number (ALESN) is provided in both the ALET and the access-list entry. When the control program allocates an access-list entry, it should place the same ALESN in the entry and in the designating ALET that it returns to the problem program. When the control program reallocates an access-list entry, it should change the value of the ALESN. An exception is recognized during access-register translation if the ALESN in the ALET used is not equal to the ALESN in the designated access-list entry.

The ALESN check is a reliability mechanism, not an authority mechanism, because the ALET is not protected from the problem program, and the problem program can change the ALESN in the ALET to any value. Also, this is not a fail-proof reliability mechanism because the ALESN is one byte and its value wraps around after 256 reallocations, assuming that the value is incremented by one for each reallocation.

**Authorizing the Use of Access-List Entries:** Although an access list is intended to be associated with either a dispatchable unit or a primary address space, the valid entries in the list are intended to be associated with the different programs that are executed, in some order, to perform the work of the dispatchable unit. It is intended that each program be able to have a particular authority that permits the use of only those access-list entries that are associated with the program. The authority being referred to here is represented by a 16-bit extended authorization index (EAX) in control register 8.
Other elements used in the related authorization mechanism are: (1) a private bit in the access-list entry, (2) an access-list-entry authorization index (ALEAX) in the access-list entry, and (3) the authority table.

A program is authorized to use an access-list entry, in access-register translation, if any of the following conditions is met:

1. The private bit in the access-list entry is zero. This condition provides a high-performance means to authorize any and all programs that are executed to perform the dispatchable unit.

2. The ALEAX in the access-list entry is equal to the EAX in control register 8. This condition provides a high-performance means to authorize only particular programs.

3. The EAX selects a secondary bit that is one in the authority table associated with the address space that is specified by the access-list entry. The authority table is locatable in that the access-list entry contains the real origin of the ASN-second-table entry (ASTE) for the address space, and the ASTE contains the real origin of the authority table. This condition provides another means, less well-performing than condition 2, for authorizing only particular programs. However, providing for condition 3 to be met instead of condition 2 can be advantageous because it permits several programs, each executed with a different EAX, all to use a single access-list entry to access a particular address space.

Access-register translation tests for the three conditions in the order indicated by their numbers, and a higher-numbered condition is not tested for if a lower-numbered condition is met. An exception is recognized if none of the conditions is met.

Figure 5-11 shows an example of how the authorization mechanism can be used. In the figure, “PB=0” means that the private bit is zero, and “PB=1” means that the private bit is one.

The figure shows an access list — assume it is a dispatchable-unit access list — in which the entries of interest are entries 4, 7, 9, and 12. Each access-list entry contains a private bit, an ALEAX, and the real origin of the ASTE for an address space. The private bit in entry 4 is zero, and, therefore, the value of the ALEAX in entry 4 is immaterial and is not shown. The private bits in entries 7, 9, and 12 are ones, and the ALEAX values in these entries are as shown. The numbers used to identify the address spaces (36, 25, 62, and 17) are arbitrary. They may be the ASNs of the address spaces; however, ASNs are in no way
used in access-register translation. Only the authority table for address space 17 is shown. In it, the secondary bit selected by EAX 10 is one. Assume that no secondary bits are ones in the authority tables for the other spaces.

The figure also shows a sequence of three programs, named A, B, and C, that is executed to perform the work of the dispatchable unit associated with the access list. These programs may be in the same or different address spaces. The EAX in control register 8 when each of these programs is executed is 0, 5, and 10, respectively.

Each of programs A, B, and C can use access-list entry (ALE) 4 to access address space 36 since the private bit in ALE 4 is zero. Program B can use ALE 7 to access space 25 because the ALEAX in the ALE equals the EAX for the program, and no other program can use this ALE. Similarly, only program C can use ALE 9. Program B can use ALE 12 because the ALEAX and EAX are equal, and program C can use it because A's EAX selects a secondary bit that is one in the authority table for space 17.

The example would be the same if programs A, B, and C were all in the same address space and the access list were the primary-space access list for that space.

An ALE in which the private bit is zero may be called public because the ALE can be used by any program, regardless of the value of the current EAX. An ALE in which the private bit is one may be called private because the ability of a program to use the ALE depends on the current EAX.

Notes on the Authorization Mechanism: An access list is a kind of capability list, in the sense in which the word “capability” is used in computer science. It is up to the control program to formulate the policies that are used to allocate entries in an access list, and the programmed authorization checking required during allocation may be very complex and lengthy. After a valid entry has been made in an access list, the access-register-translation process enforces the control-program policies in a well-performing way by means of the authorization mechanism described above.

Using access lists has an advantage over using only ASNs and authority tables. For example, assume that an access register could contain an ASN and that access-register translation would do ASN translation of the ASN and then use the EAX to test the authority table. This would make the EAX relevant to all existing address spaces, and, therefore, it would make the management of EAXs and their assignment to programs more difficult. With the actual definitions of the ALET and access-register translation, an EAX is relevant to only the address spaces that are represented in the current dispatchable-unit and primary-space access lists. Also, since ASN translation is not done as a part of access-register translation, the number of concurrently existing address spaces, as represented by ASN-second-table entries, can be greater than the number of available ASNs (64K).

The entry-table entry and linkage stack can be used to assign EAXs to programs and to change the EAX in control register 8 during program linkages. These components are introduced in “Linkage-Stack Introduction” on page 5-71. The privileged EXTRACT AND SET EXTENDED AUTHORITY instruction also is available for saving and changing the EAX in control register 8.

The SET SECONDARY ASN instruction and the authorization index (AX), bits 32-47 of control register 4, can play a role in the use of access registers. The space-switching form of SET SECONDARY ASN (SSAR-ss) establishes a new secondary address space if the secondary bit selected by the AX is one in the authority table associated with the new secondary space. The secondary space can be addressed by means of an ALET having the value 00000001 hex.

Revoking Accessing Capability: Another mechanism, which is a combined authority and integrity mechanism, is part of access-register translation, and it is described in this section.

An access-list entry (ALE) contains an ASN-second-table-entry sequence number (ASTESN), and so does the ASTE designated by the ALE. During access-register translation, the ASTESN in the ALE must equal the ASTESN in the designated ASTE; otherwise, an exception is recognized.

When the control program allocates an ALE, it should copy the ASTESN from the designated ASTE into the ALE. Subsequently, the control program can, in effect, revoke the addressing capability represented by the ALE by changing the ASTESN in the ASTE. Changing the ASTESN in the ASTE makes all previously usable ALEs that designate the ASTE unusable.
Making an ALE unusable may be required in either of two cases:

1. Some element of the control-program policy for determining the authority of a program to have access to the address space specified by the ASTE has changed. This may mean that some or all of the programs that were authorized to the address space, and for which ALEs have been allocated, are no longer authorized. Changing the ASTESN in the ASTE ends the usability of all ALEs that designate the ASTE. If this revocation of capability is to be selective, then, when an exception is recognized because of unequal ASTESNs, the control program can reapply its programmed procedures for determining authorization, and an ALE which should have remained usable can be made usable again by copying the new ASTESN into it. When the usability of an ALE is restored, the control program normally should cause reexecution of the instruction that encountered the exception.

2. The ASTE has been reassigned to specify a conceptually different address space, and ALEs which specified the old address space must not be allowed to specify the new one. (Bit 0 of the ASTE, the ASX-invalid bit, can be set to one to delete the assignment of the ASTE to an address space, and this prevents the use of the ASTE in access-register translation. But after reassignment, bit 0 normally is set back to zero.)

The ASTESN mechanism may be regarded as an authority mechanism in the first case above and as an integrity mechanism in the second.

The ASTESN mechanism is especially valuable because it avoids the need of the control program to keep track of the access lists that contain the ALEs that designate each ASTE. Furthermore, it avoids the need of searching through these access lists in order to find the ALEs and set them invalid, to prevent the use of the ALEs in access-register translation. The latter activity could be particularly time-consuming, or could present a particularly difficult management problem, because the access lists could be in auxiliary storage, such as a direct-access storage device, when the need arises to invalidate the ALEs.

The ASTESN is a four-byte field. Assuming a reasonable frequency of authorization-policy changes or address-space reassignments, the approximately four billion possible values of the ASTESN provide a fail-proof authority or integrity mechanism over the lifetime of the system.

**Programming Note:** Refer to “Modification of ART Tables” on page 5-67 for a discussion of ALB maintenance required when modifying any of the tables used in access-register translation.

**Preventing Store References:** The access-list entry contains a fetch-only bit which, when one, specifies that the access-list entry cannot be used to perform storage-operand store references. The principal description of the effect of the fetch-only bit is in “Access-List-Controlled Protection” on page 3-13.

**Improving Translation Performance:** Access-register translation (ART) conceptually occurs each time a logical address is used to reference a storage operand in the access-register mode. To improve performance, ART normally is implemented such that some or all of the information contained in the ART tables (access-list-designation sources, access lists, ASN second tables, and authority tables) is maintained in a special buffer referred to as the ART-loosaside buffer (ALB). The CPU necessarily refers to an ART-table entry in real storage only for the initial access to that entry. The information in the entry may be placed in the ALB, and subsequent translations may be performed using the information in the ALB.

The PURGE ALB instruction and the COMPARE AND SWAP AND PURGE instruction can be used to clear all information from the ALB after a change has been made to an ART-table entry in real storage.

**Access-Register Instructions**

The following instructions are provided for examining and changing the contents of access registers:

- COPY ACCESS
- EXTRACT ACCESS
- LOAD ACCESS MULTIPLE
- LOAD ADDRESS EXTENDED
- SET ACCESS
- STORE ACCESS MULTIPLE

The SET ACCESS instruction replaces the contents of a specified access register with the contents of bit positions 32-63 of the specified general register. Conversely, the EXTRACT ACCESS instruction moves the contents of an access register to bit positions 32-63 of a general register. The COPY
ACCESS instruction moves the contents of one access register to another.

The LOAD ACCESS MULTIPLE instruction loads a specified set of consecutively numbered access registers from a specified storage location whose length in words equals the number of access registers loaded. Conversely, the STORE ACCESS MULTIPLE instruction function stores the contents of a set of access registers at a storage location.

The LOAD ADDRESS EXTENDED instruction is similar to the LOAD ADDRESS instruction in that it loads a specified general register with an effective address specified by means of the B, X, and D fields of the instruction. In addition, LOAD ADDRESS EXTENDED operates on the access register having the same number as the general register loaded. When the address-space control, PSW bits 16 and 17, is 00, 10, or 11 binary, LOAD ADDRESS EXTENDED loads the access register with 00000000, 00000001, or 00000002 hex, respectively. When the address space control is 01 binary, LOAD ADDRESS EXTENDED loads the target access register with a value that depends on the B field of the instruction. If the B field is zero, LOAD ADDRESS EXTENDED loads the target access register with 00000000 hex. If the B field is nonzero, LOAD ADDRESS EXTENDED loads the target access register with the contents of the access register designated by the B field. However, in the last case when bits 0-6 of the access register designated by the B field are not all zeros, the results in the target general register and access register are unpredictable.

The address-space-control values 00, 01, 10, and 11 binary specify primary-space, access-register, secondary-space, and home-space mode, respectively, when DAT is on. LOAD ADDRESS EXTENDED functions the same regardless of whether DAT is on or off.

When used in access-register translation, the access-register values 00000000 and 00000001 hex specify the primary and secondary address spaces, respectively, and the value 00000002 hex designates entry 2 in the dispatchable-unit access list. Loading the target access register with 00000002 hex when the address-space control is 11 binary is intended to support assignment, by the control program, of entry 2 in the dispatchable-unit access list as specifying the home address space.
Control Register 5
The location of the primary ASN-second-table entry is specified in control register 5. The register has the following format:

<table>
<thead>
<tr>
<th>32</th>
<th>33</th>
<th>34</th>
<th>35</th>
<th>36</th>
<th>37</th>
<th>38</th>
<th>39</th>
<th>40</th>
<th>41</th>
<th>42</th>
<th>43</th>
<th>44</th>
<th>45</th>
<th>46</th>
<th>47</th>
<th>48</th>
<th>49</th>
<th>50</th>
<th>51</th>
<th>52</th>
<th>53</th>
<th>54</th>
<th>55</th>
<th>56</th>
<th>57</th>
<th>58</th>
<th>59</th>
<th>60</th>
<th>61</th>
<th>62</th>
<th>63</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Primary-ASTE Origin (PASTE0): Bits 33-57 of control register 5, with six zeros appended on the right, form a 31-bit real address that designates the beginning of the primary ASN-second-table entry. Access-register translation may obtain the primary-space access-list designation from the primary ASTE. The primary-ASTE origin is implicitly set by LOAD ADDRESS SPACE PARAMETERS when it performs PASN translation and by the space-switching forms of PROGRAM CALL, PROGRAM RETURN, and PROGRAM TRANSFER. When any of these instructions places the primary-ASTE origin in control register 5, it also places zeros in bit positions 32 and 58-63 of the register and leaves bits 0-31 of the register unchanged. Bits 0-32 and 58-63 of control register 5 are subject to possible future assignment, and they should not be depended upon to be zeros.

Control Register 8
The extended authorization index is in control register 8. The register has the following format:

<table>
<thead>
<tr>
<th>32</th>
<th>33</th>
<th>34</th>
<th>35</th>
<th>36</th>
<th>37</th>
<th>38</th>
<th>39</th>
<th>40</th>
<th>41</th>
<th>42</th>
<th>43</th>
<th>44</th>
<th>45</th>
<th>46</th>
<th>47</th>
<th>48</th>
<th>49</th>
<th>50</th>
<th>51</th>
<th>52</th>
<th>53</th>
<th>54</th>
<th>55</th>
<th>56</th>
<th>57</th>
<th>58</th>
<th>59</th>
<th>60</th>
<th>61</th>
<th>62</th>
<th>63</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Extended Authorization Index (EAX): Bits 32-47 of control register 8 are the extended authorization index. During access-register translation, the EAX may be compared against the access-list-entry authorization index (ALEAX) in an access-list entry, and it may be used as an index to locate a secondary bit in an authority table. The EAX may be set by a stacking PROGRAM CALL operation, and it is restored by PROGRAM RETURN. The EAX can also be saved and set by the privileged instruction EXTRACT AND SET EXTENDED AUTHORITY.

Access Registers
There are sixteen 32-bit access registers numbered 0-15. The contents of an access register are called an access-list-entry token (ALET). An ALET has the following format:

<table>
<thead>
<tr>
<th>32</th>
<th>33</th>
<th>34</th>
<th>35</th>
<th>36</th>
<th>37</th>
<th>38</th>
<th>39</th>
<th>40</th>
<th>41</th>
<th>42</th>
<th>43</th>
<th>44</th>
<th>45</th>
<th>46</th>
<th>47</th>
<th>48</th>
<th>49</th>
<th>50</th>
<th>51</th>
<th>52</th>
<th>53</th>
<th>54</th>
<th>55</th>
<th>56</th>
<th>57</th>
<th>58</th>
<th>59</th>
<th>60</th>
<th>61</th>
<th>62</th>
<th>63</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

The fields in the ALET are allocated as follows:

Primary-List Bit (P): When the ALET is not 00000000 or 00000001 hex, bit 7 specifies the access list to be used by access-register translation. When bit 7 is zero, the dispatchable-unit access list is used; this is specified by the dispatchable-unit access-list designation in the dispatchable-unit control table designated by the contents of control register 2. When bit 7 is one, the primary-space access list is used; this is specified by the primary-space access-list designation in the primary ASTE designated by the contents of control register 5.

Access-List-Entry Sequence Number (ALESN): Bits 8-15 may be used as a check on whether the access-list entry designated by the ALET has been invalidated and reallocated since the ALET was obtained. During access-register translation when the ALET is not 00000000 or 00000001 hex, bits 8-15 of the ALET are compared against the access-list-entry sequence number (ALESN) in the designated access-list entry.

Access-List-Entry Number (ALEN): When the ALET is not 00000000 or 00000001 hex, bits 16-31 of the ALET designate an entry in either the dispatchable-unit access list or the primary-space access list, as determined by bit 7. The access-list designation that is used is called the effective access-list designation; it consists of the effective access-list origin and the effective access-list length.

During access-register translation, the ALEN, with four zeros appended on the right, is added to the 31-bit real or absolute address specified by the effective access-list origin, and the result is the real or absolute address of the designated access-list entry. The ALEN is compared against the effective access-list length to determine whether the designated access-list entry is within the list, and an ALEN-translation exception is recognized if the entry is outside the list. Although the largest possible value of the
ALEN is 65,535, an access list can contain at most 1,024 entries.

Bits 0-6 must be zeros during access-register translation; otherwise, an ALET-specification exception is recognized.

When the ALET is 00000000 or 00000001 hex, it specifies the primary or secondary address space, respectively, and the above format does not apply.

Access register 0 usually is treated in access-register translation as containing 00000000 hex, and its actual contents are not examined; the access-register translation done as part of TEST ACCESS is the only exception. Access register 0 is also treated as containing 00000000 hex when it is designated by the B field of LOAD ADDRESS EXTENDED when PSW bits 16 and 17 are 01 binary. When access register 0 is specified for TEST ACCESS or as a source for COPY ACCESS, EXTRACT ACCESS, or STORE ACCESS MULTIPLE, the actual contents of the access register are used. Access register 0, like any other access register, can be loaded by COPY ACCESS, LOAD ACCESS MULTIPLE, LOAD ADDRESS EXTENDED, and SET ACCESS.

Another definition of ALETs 00000000 and 00000001 hex is given in “BRANCH IN SUBSPACE GROUP” on page 10-12.

Access-Register-Translation Tables

When the ALET being translated is not 00000000 or 00000001 hex, access-register translation performs a two-level lookup to locate first the effective access-list designation and then an entry in the effective access list. The effective access-list designation resides in real storage. The effective access list resides in real or absolute storage.

Access-register translation uses an origin in the access-list entry to locate an ASN-second-table entry, and it may perform a one-level lookup to locate an entry in an authority table. The ASN-second-table entry resides in real storage. The authority table resides in real or absolute storage.

Authority-table entries are described in “Authority-Table Entries” on page 3-33. Access-list designations, access-list entries, and ASN-second-table entries are described in the following sections.

Dispatchable-Unit Control Table and Access-List Designations

When the ALET being translated is not 00000000 or 00000001 hex, access-register translation obtains the dispatchable-unit access-list designation if bit 7 of the ALET is zero, or it obtains the primary-space access-list designation if bit 7 is one. The obtained access-list designation is called the effective access-list designation.

The dispatchable-unit access-list designation (DUALD) is located in bytes 16-19 of a 64-byte area called the dispatchable-unit control table (DUCT). The DUCT resides in real storage, and its location is specified by the DUCT origin in control register 2.

The dispatchable-unit control table has the following format:

```
<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>BASTEO</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td>SSASTEO</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>SSASTESN</td>
</tr>
<tr>
<td>12</td>
<td>12</td>
<td>DUALD (see below)</td>
</tr>
<tr>
<td>16</td>
<td>20</td>
<td>PSW-Key Mask</td>
</tr>
<tr>
<td>20</td>
<td>24</td>
<td>PSW-Key Mask</td>
</tr>
<tr>
<td>1C</td>
<td>28</td>
<td></td>
</tr>
</tbody>
</table>

In the 24-Bit or 31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>32</td>
<td>Bits 0-31 of Return Address</td>
</tr>
<tr>
<td>24</td>
<td>36</td>
<td>Bits 32-63 of Return Address</td>
</tr>
</tbody>
</table>

In the 64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>28</td>
<td>40</td>
<td>Trap-Control-Block Address</td>
</tr>
<tr>
<td>2C</td>
<td>44</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>48</td>
<td></td>
</tr>
<tr>
<td>34</td>
<td>52</td>
<td></td>
</tr>
<tr>
<td>38</td>
<td>56</td>
<td></td>
</tr>
<tr>
<td>3C</td>
<td>60</td>
<td></td>
</tr>
</tbody>
</table>
```

Bytes 0-7 (BASTEO, SA, and SSASTEO) and 12-15 (SSASTESN) of the DUCT are described in “Sub-
space-Group Dispatchable-Unit Control Table” on page 5-67. Bytes 20-23 (PSW key mask, PSW key, RA, and P) and 32-39 (BA and return address) are described in “BRANCH AND SET AUTHORITY” on page 10-6. Bytes 44-47 (trap-control-block address and E) are described in “TRAP” on page 10-167. Bytes 8-11, 24-27, 40-43, and 48-63 are reserved for possible future extensions and should contain all zeros. Bytes 28-31 are available for use by programming.

The primary-space access-list designation (PSALD) is located in bytes 16-19 of a 64-byte area called the primary ASN-second-table entry. The primary ASTE resides in real storage, and its location is specified by the primary-ASTE origin in control register 5. The format of the primary ASTE is described in “ASN-Second-Table Entries” on page 5-58.

The dispatchable-unit and primary-space access-list designations both have the same format, which is as follows:

<table>
<thead>
<tr>
<th>Access-List Designation</th>
</tr>
</thead>
<tbody>
<tr>
<td>Access-List Origin</td>
</tr>
<tr>
<td>ALL</td>
</tr>
</tbody>
</table>

The fields in the access-list designation are allocated as follows:

**Access-List Origin:** Bits 1-24 of the access-list designation, with seven zeros appended on the right, form a 31-bit address that designates the beginning of the access list. This address is treated unpredictably as either a real address or an absolute address.

**Access-List Length (ALL):** Bits 25-31 of the access-list designation specify the length of the access list in units of 128 bytes, thus making the length of the access list variable in multiples of eight 16-byte entries. The length of the access list, in units of 128 bytes, is one more than the value in bit positions 25-31. The access-list length, with six zeros appended on the left, is compared against bits 0-12 of an access-list-entry number (bits 16-28 of an access-list-entry token) to determine whether the access-list-entry number designates an entry in the access list.

Bit 0 is reserved for a possible future extension and should be zero.

**Programming Note:** The maximum number of access-list entries allowed by an access-list designation is 1,024. There are two access lists available for use at any time. Therefore, a maximum of 2,048 sixteen-exabyte (16E) address spaces can be addressable without control-program intervention, which is a total of $2^{75}$ bytes.

**Access-List Entries**

The effective access list is the dispatchable-unit access list if bit 7 of the ALET being translated is zero, or it is the primary-space access list if bit 7 is one. The entry fetched from the effective access list is 16 bytes in length and has the following format:

<table>
<thead>
<tr>
<th>I</th>
<th>P</th>
<th>F</th>
<th>O</th>
<th>ALESN</th>
<th>ALEAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>6</td>
<td>7</td>
<td>8</td>
<td>16</td>
<td>31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>32</th>
<th>63</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
<td>65</td>
</tr>
<tr>
<td>90</td>
<td>95</td>
</tr>
<tr>
<td>96</td>
<td>127</td>
</tr>
</tbody>
</table>

The fields in the access-list entry are allocated as follows:

**ALEN-Invalid Bit (I):** Bit 0, when zero, indicates that the access-list entry specifies an address space. When bit 0 is one during access-register translation, an ALEN-translation exception is recognized.

**Fetch-Only Bit (FO):** Bit 6 controls which types of operand references are permitted to the address space specified by the access-list entry. When bit 6 is zero, both fetch-type and store-type references are permitted. When bit 6 is one, only fetch-type references are permitted, and an attempt to store causes a protection exception for access-list-controlled protection to be recognized and the operation to be suppressed.

**Private Bit (P):** Bit 7, when zero, specifies that any program is authorized to use the access-list entry in access-register translation. When bit 7 is one, authorization is determined as described for bits 16-31.

**Access-List-Entry Sequence Number (ALESN):** Bits 8-15 are compared against the ALESN in the ALET during access-register translation. Inequality causes an ALE-sequence exception to be recog-
organized. It is intended that the control program change bits 8-15 each time it reallocates the access-list entry.

**Access-List-Entry Authorization Index (ALEAX):** Bits 16-31 may be used to determine whether the program for which access-register translation is being performed is authorized to use the access-list entry. The program is authorized if any of the following conditions is met:

1. Bit 7 is zero.
2. Bits 16-31 are equal to the extended authorization index (EAX) in control register 8.
3. The EAX selects a secondary bit that is one in the authority table for the specified address space.

**ASN-Second-Table-Entry Origin (ASTEo):** Bits 65-89, with six zeros appended on the right, form the 31-bit real address of the ASTE for the specified address space. Access-register translation obtains the address-space-control element for the address space from the ASTE.

**ASTE Sequence Number (ASTEsn):** Bits 96-127 may be used to revoke the addressing capability represented by the access-list entry. Bits 96-127 are compared against an ASTE sequence number (ASTEsn) in the designated ASTE during access-register translation.

Bits 1-5, 32-64, and 90-95 are reserved for possible future extensions and should be zeros.

In both the dispatchable-unit access list and the primary-space access list, access-list entries 0 and 1 are not used in access-register translation. Bits 1-127 of access-list entry 0 and bits 1-63 of access-list entry 1 are reserved for possible future extensions and should be zeros. Bit 0 of access-list entries 0 and 1, and bits 64-127 of access-list entry 1, are available for use by programming. The control program should set bit 0 of access-list entries 0 and 1 to one in order to prevent the use of these entries by means of ALETs in which the ALEN is 0 or 1.

**ASN-Second-Table Entries**

The first 48 bytes of the 64-byte ASN-second-table entry have the following format:

```
<table>
<thead>
<tr>
<th>1</th>
<th>ATO</th>
<th>B</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>30 31</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>AX</th>
<th>ATL</th>
<th>CR</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>48</td>
<td>60 62 63</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>ASCE (RTD, STD, or RSD) Part 1</th>
</tr>
</thead>
<tbody>
<tr>
<td>RTO, STO, or RSTKO</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>RTO/STO (Continued)</th>
<th>GP</th>
<th>SX</th>
<th>R</th>
<th>DT</th>
<th>TL</th>
</tr>
</thead>
<tbody>
<tr>
<td>96</td>
<td>116</td>
<td>118</td>
<td>122</td>
<td>124</td>
<td>127</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>RSD Part 2</th>
</tr>
</thead>
<tbody>
<tr>
<td>RSTKO (Continued)</td>
</tr>
<tr>
<td>96</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>ALD</th>
<th>ALL</th>
</tr>
</thead>
<tbody>
<tr>
<td>128</td>
<td>153</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>ASTESN</th>
</tr>
</thead>
<tbody>
<tr>
<td>160</td>
</tr>
</tbody>
</table>
```

If ASN-and-LX Reuse Is Not Enabled

```
<table>
<thead>
<tr>
<th>LTD</th>
</tr>
</thead>
<tbody>
<tr>
<td>192</td>
</tr>
</tbody>
</table>
```

If ASN-and-LX Reuse Is Enabled

```
<table>
<thead>
<tr>
<th>LFTD</th>
</tr>
</thead>
<tbody>
<tr>
<td>192</td>
</tr>
</tbody>
</table>
```

Available for programming

```
<table>
<thead>
<tr>
<th>Available for programming</th>
</tr>
</thead>
<tbody>
<tr>
<td>224 255</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Available for programming</th>
</tr>
</thead>
<tbody>
<tr>
<td>256 287</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Available for programming</th>
</tr>
</thead>
<tbody>
<tr>
<td>288 319</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>ASTEIN</th>
</tr>
</thead>
<tbody>
<tr>
<td>320</td>
</tr>
</tbody>
</table>
```

The fields in bytes 0-47 of the ASN-second-table entry (ASTE) are defined with respect to certain
mechanisms and instructions in “ASN-Second-Table Entries” on page 3-28. The fields in the ASTE are defined with respect to the BRANCH IN SUBSPACE GROUP instruction in “Subspace-Group ASN-Second-Table Entries” on page 5-69. With respect to access-register translation only, and only for an instruction other than BRANCH IN SUBSPACE GROUP, the fields in the ASTE are allocated as follows:

**ASX-Invalid Bit (I):** Bit 0 controls whether the address space associated with the ASTE is available. When bit 0 is zero, access-register translation proceeds. When the bit is one, an ASTE-validity exception is recognized. When the primary-space ALD is fetched, the ASX-invalid bit in the primary ASTE is ignored.

**Authority-Table Origin (ATO):** Bits 1-29, with two zeros appended on the right, form a 31-bit address that designates the beginning of the authority table. This address is treated unpredictably as either a real address or an absolute address, although it is treated as a real address for ASN authorization. The authority table is accessed in access-register translation only if the private bit in the access-list entry is one and the access-list-entry authorization index (ALEAX) in the access-list entry is not equal to the extended authorization index (EAX) in control register 8.

**Base-Space Bit (B):** Bit 31 is ignored during access-register translation. Bit 31 is further described in “Subspace-Group ASN-Second-Table Entries” on page 5-69.

**Authorization Index (AX):** Bits 32-47 are not used in access-register translation.

**Authority-Table Length (ATL):** Bits 48-59 specify the length of the authority table in units of four bytes, thus making the authority table variable in multiples of 16 entries. The length of the authority table, in units of four bytes, is one more than the ATL value. The contents of the ATL field are used to establish whether the entry designated by a particular EAX is within the authority table. An extended-authority exception is recognized if the entry is not within the table.

**Controlled-ASN Bit (CA):** Bit 62 is not used in access-register translation.

**Reusable-ASN Bit (RA):** Bit 63 is not used in access-register translation.

**Address-Space-Control Element (ASCE):** Bits 64-127 are an eight-byte address-space-control element (ASCE) that may be a segment-table designation (STD), a region-table designation (RTD), or a real-space designation (RSD). (The term region-table designation is used to mean a region-first-table designation, region-second-table designation, or region-third-table designation.) The ASCE field is obtained as the result of access-register translation and is used by DAT to translate the logical address for the storage-operand reference being made. Bit 121, the space-switch-event control, is not used in or as a result of access-register translation. The other fields in the ASCE (RTO, STO, RSTKO, G, P, S, R, DT, and TL) are described in “Control Register 1” on page 3-39.

**Access-List Designation (ALD):** When this ASTE is designated by the primary-ASTE origin in control register 5, bits 128-159 are the primary-space access-list designation (PSALD). See the description of the access-list designation in “Dispatchable-Unit Control Table and Access-List Designations” on page 5-56. During access-register translation when the primary-list bit, bit 7, in the ALET being translated is one, the PSALD is the effective access-list designation.

**ASN-Second-Table-Entry Sequence Number (ASTESN):** Bits 160-191 are used to control reversion of the accessing capability represented by access-list entries that designate the ASTE. During access-register translation, bits 160-191 are compared against the ASTESN in the access-list entry, and inequality causes an ASTE-sequence exception to be recognized. It is intended that the control program change the value of bits 160-191 when the authorization policies for the address space specified by the ASTE change or when the ASTE is reassigned to specify another address space.

**Linkage-Table Designation (LTD) or Linkage-First-Table Designation (LFTD):** Bits 192-223 are not used in access-register translation.

**ASN-Second-Table-Entry Instance Number (ASTEIN):** Bits 352-383 are not used in access-register translation.

Bits 224-319 in the ASTE are available for use by programming.
Programming Note: All unused fields in the ASTE, including the unused fields in bytes 0-31, bytes 40-43, and bytes 48-63, should be set to zeros. These fields are reserved for future extensions, and programs which place nonzero values in these fields may not operate compatibly on future machines.

Access-Register-Translation Process

This section describes the access-register-translation process as it is performed during a storage-operand reference in the access-register mode. The following instructions perform access-register translation as described in this section, but with the exceptions noted below.

- LOAD PAGE-TABLE-ENTRY ADDRESS when the M4 field is 0001 binary, or when the M4 field is 0100 binary and bits 16-17 of the PSW are 01 binary
- LOAD REAL ADDRESS and STORE REAL ADDRESS when PSW bits 16 and 17 are 01 binary
- TEST ACCESS in any translation mode
- TEST PROTECTION in the access-register mode

For LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, TEST ACCESS, and TEST PROTECTION, the following exceptions cause a setting of the condition code instead of being treated as program-interruption conditions:

- ALET specification
- ALEN translation
- ALE sequence
- ASTE validity
- ASTE sequence
- Extended authority

BRANCH IN SUBSPACE GROUP performs access-register translation as described in “BRANCH IN SUBSPACE GROUP” on page 10-12.

Access-register translation operates on the access register designated in a storage-operand reference in order to obtain an address-space-control element for use by DAT. When one of access-registers 1-15 is designated, an ALET having the value 00000000 hex is used, except that TEST ACCESS uses the actual contents of access register 0.

When the ALET is 00000000 or 00000001 hex, the primary or secondary address-space-control element, respectively, is obtained.

When the ALET is other than 00000000 or 00000001 hex, the leftmost seven bits of the ALET are checked for zeros, the primary-list bit in the ALET and the contents of control register 2 or 5 are used to obtain the effective access-list designation, and the access-list entry number (ALEN) in the ALET is used to select an entry in the effective access list.

The access-list entry is checked for validity and for containing the correct access-list-entry sequence number (ALESN).

The ASN-second-table entry (ASTE) addressed by the access-list entry is checked for validity and for containing the correct ASN-second-table-entry sequence number (ASTESN).

Whether the program is authorized to use the access-list entry is determined through the use of one or more of: (1) the private bit and access-list-entry authorization index (ALEAX) in the access-list entry, (2) the extended authorization index (EAX) in control register 8, and (3) an entry in the authority table addressed by the ASN-second-table entry.

If a store-type reference is to be performed, the fetch-only bit in the access-list entry is checked for being zero.

When no exceptions are recognized, the address-space-control element in the ASN-second-table entry is obtained.

In order to avoid the delay associated with references to real or absolute storage, the information fetched from real or absolute storage normally may also be placed in a special buffer, the ART-lookaside buffer (ALB), and subsequent translations involving the same information may be performed by using the contents of the ALB. The operation of the ALB is described in “ART-Lookaside Buffer” on page 5-65.

Whenever access to real or absolute storage is made during access-register translation for the purpose of fetching an entry from an access-list-designation source (DUCT or PASTE), access list, ASN second
table, or authority table, key-controlled protection does not apply.

The principal features of access-register translation, including the effect of the ALB, are shown in Figure 5-12 on page 5-62.
**Explanation:**

1. The appropriate ALD is obtained:
   - When \( P \) in the ALET is zero (and the ALET is not zero or one), the DUALD in the DUCT is obtained.
   - When \( P \) in the ALET is one, the PSALD in the primary ASTE is obtained.

2. Information, which may include the ALD-source origin, ALET, ALO, and EAX, is used to search the ALB. This information, along with information from the ALE, ASTE, and ATE, may be placed in the ALB.

3. The appropriate ASCE is obtained:
   - When the AR number is zero (except for TAR) or when the ALET is zero, the PASCE in CR 1 is obtained. When the ALET is one, the SASCE in CR 7 is obtained.
   - When the ALET is larger than one:
     - If a match exists, the ASCE from the ALB is used.
     - If no match exists, tables from real or absolute storage are fetched. The resulting ASCE from the ASTE is obtained, and entries may be formed in the ALB.

**Figure 5-12. Access-Register Translation**
Selecting the Access-List-Entry Token
When one of access registers 1-15 is designated, or for the access register designated by the R1 field of TEST ACCESS, access-register translation uses the access-list-entry token (ALET) that is in the access register. When access register 0 is designated, except for TEST ACCESS, an ALET having the value 00000000 hex is used, and the contents of access register 0 are not examined.

Obtaining the Primary or Secondary Address-Space-Control Element
When the ALET being translated is 00000000 hex, the primary address-space-control element in control register 1 is obtained. When the ALET is 00000001 hex, the secondary address-space-control element in control register 7 is obtained. In each of these two cases, access-register translation is completed.

Checking the First Byte of the ALET
When the ALET being translated is other than 00000000 or 00000001 hex, bits 0-6 of the ALET are checked for being all zeros. If bits 0-6 are not all zeros, an ALET-specification exception is recognized, and the operation is suppressed.

Obtaining the Effective Access-List Designation
The primary-list bit, bit 7, in the ALET is used to perform a lookup to obtain the effective access-list designation. When bit 7 is zero, the effective ALD is the dispatchable-unit ALD located in bytes 16-19 of the dispatchable-unit control table (DUCT). When bit 7 is one, the effective ALD is the primary-space ALD located in bytes 16-19 of the primary ASN-second-table entry (primary ASTE).

When bit 7 is zero, the 31-bit real address of the dispatchable-unit ALD is obtained by appending six zeros on the right to the DUCT origin, bits 33-57 of control register 2, and adding 16. The addition cannot cause a carry into bit position 0.

When bit 7 is one, the 31-bit real address of the primary-space ALD is obtained by appending six zeros on the right to the primary-ASTE origin, bits 33-57 of control register 5, and adding 16. The addition cannot cause a carry into bit position 0.

The obtained 31-bit real address is used to fetch the effective ALD — either the dispatchable-unit ALD or the primary-space ALD, depending on bit 7 of the ALET. The fetch of the effective ALD appears to be word concurrent, as observed by other CPUs, and is not subject to protection. When the storage address that is generated for fetching the effective ALD refers to a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed. When the primary-space ALD is fetched, bit 0, the ASX-invalid bit, in the primary ASTE is ignored.

Access-List Lookup
A lookup in the effective access list is performed. The effective access list is the dispatchable-unit access list if bit 7 of the ALET is zero, or it is the primary-space access list if bit 7 is one. The effective access list is treated unpredictably as being in either real or absolute storage.

The access-list-entry-number (ALEN) portion of the ALET is used to select an entry in the effective access list. The 31-bit real or absolute address of the access-list entry is obtained by appending seven zeros on the right to bits 1-24 of the effective ALD and adding the ALEN, with four rightmost and 11 leftmost zeros appended. When a carry into bit position 0 occurs during the addition, an addressing exception may be recognized, or the carry may be ignored, causing the access list to wrap from $2^{31} - 1$ to 0. The 31-bit address is formed and used regardless of whether the current PSW specifies the 24-bit, 31-bit, or 64-bit addressing mode.

As part of the access-list-lookup process, the leftmost 13 bits of the ALEN are compared against the effective access-list length, bits 25-31 of the effective ALD, to establish whether the addressed entry is within the access list. For this comparison, the access-list length is extended with six leftmost zeros. If the value formed from the access-list length is less than the value in the 13 leftmost bits of the ALEN, an ALEN-translation exception is recognized, and the operation is nullified.

The 16-byte access-list entry is fetched by using the real or absolute address. The fetch of the entry appears to be word concurrent as observed by other CPUs, with the leftmost word fetched first. The order in which the remaining three words are fetched is unpredictable. The fetch access is not subject to protection. When the storage address that is generated for fetching the access-list entry refers to a location which is not available in the configuration, an
addressing exception is recognized, and the operation is suppressed.

Bit 0 of the access-list entry indicates whether the access-list entry specifies an address space by designating an ASN-second-table entry. This bit is inspected, and, if it is one, an ALEN-translation exception is recognized, and the operation is nullified.

When bit 0 is zero, the access-list-entry sequence number (ALESN) in bit positions 8-15 of the access-list entry is compared against the ALESN in the ALET to determine whether the ALET designates the conceptually correct access-list entry. Inequality causes an ALE-sequence exception to be recognized and the operation to be nullified.

Locating the ASN-Second-Table Entry
The ASN-second-table-entry (ASTE) origin in the access-list entry is used to locate the ASTE. Bits 65-89 of the access-list entry, with six zeros appended on the right, form the 31-bit real address of the ASTE.

The 64-byte ASTE is fetched by using the real address. The fetch of the entry appears to be word concurrent as observed by other CPUs, with the leftmost word fetched first, except that the fetch of the address-space-control element in the entry appears to be doubleword concurrent as observed by other CPUs. After the first word is fetched, the order in which the ASCE and the remaining words are fetched is unpredictable. The fetch access is not subject to protection. When the storage address that is generated for fetching the ASTE refers to a location which is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

Bit 0 of the ASTE indicates whether the ASTE specifies an address space. This bit is inspected, and, if it is one, an ASTE-validity exception is recognized, and the operation is nullified.

When bit 0 is zero, the ASTE sequence number (ASTESN) in bit positions 160-191 of the ASTE is compared against the ASTESN in bit positions 96-127 of the access-list entry to determine whether the addressing capability represented by the access-list entry has been revoked. Inequality causes an ASTE-sequence exception to be recognized and the operation to be nullified.

Authorizing the Use of the Access-List Entry
The private bit, bit 7, in the access-list entry is used to determine whether the program is authorized to use the access-list entry. The access-list-entry authorization index (ALEAX) in bit positions 16-31 of the access-list entry, the extended authorization index (EAX) in bit positions 32-47 of control register 8, and the authority table designated by the ASTE may also be used.

When the private bit is zero, the program is authorized, and the authorization step of access-register translation is completed.

When the private bit is one but the ALEAX is equal to the EAX, the program is authorized, and the authorization step of access-register translation is completed.

When the private bit is one and the ALEAX is not equal to the EAX, a process called the extended-authorization process is performed. Extended authorization uses the EAX to select an entry in the authority table designated by the ASTE, and it tests the secondary-authority bit in the selected entry for being one. The program is authorized if the tested bit is one.

Extended authorization is the same as the secondary-ASN-authorization process described in “ASN Authorization” on page 3-32, except as follows:

- The authority-table origin is treated as a real or absolute address instead of as a real address.
- The EAX in control register 8 is used instead of the authorization index (AX) in control register 4.
- When the value in bit positions 0-11 of the EAX is greater than the authority-table length (ATL) in the ASTE, an extended-authority exception is recognized instead of a secondary-authority exception. The operation is nullified if the extended-authority exception is recognized.

When the private bit is one, the ALEAX is not equal to the EAX, and the secondary bit in the authority-table entry selected by the EAX is not one, an extended-authority exception is recognized, and the operation is nullified.
Checking for Access-List-Controlled Protection
If a store-type reference is to be performed and the fetch-only bit, bit 6, in the access-list entry is one, a protection exception is recognized, and the operation is suppressed.

Obtaining the Address-Space-Control Element from the ASN-Second-Table Entry
When the ALET being translated is other than 00000000 or 00000001 hex and no exception is recognized in the steps described above, access-register translation obtains the address-space-control element from bit positions 64-127 of the ASTE.

Recognition of Exceptions during Access-Register Translation
The exceptions which can be encountered during the access-register-translation process and their priority are shown in the section “Access Exceptions” in Chapter 6, “Interruptions.”

Programming Note: When updating an access-list entry or ASN-second-table entry, the program should change the entry from invalid to valid (set bit 0 of the entry to zero) as the last step of the updating. This ensures, because the leftmost word is fetched first, that words of a partially updated entry will not be fetched.

ART-Lookaside Buffer
To enhance performance, the access-register-translation (ART) mechanism normally is implemented such that access-list designations and information specified in access lists, ASN second tables, and authority tables are maintained in a special buffer, referred to as the ART-lookaside buffer (ALB). Access-list designations, access-list entries, ASN-second-table entries, and authority-table entries are collectively referred to as ART-table entries. The CPU necessarily refers to an ART-table entry in real or absolute storage only for the initial access to that entry. The information in the entry may be placed in the ALB, and subsequent ART operations may be performed using the information in the ALB. The presence of the ALB affects the ART process to the extent that (1) a modification of an ART-table entry in real or absolute storage does not necessarily have an immediate effect, if any, on the translation, (2) the comparison against the access-list length in an access-list designation that is in storage and used in a translation may be omitted if an ALB access-list entry is used, and (3) the comparison against the authority-table length in an ASN-second-table entry that is in storage and used in a translation may be omitted if an ALB authority-table entry is used. In a multiple-CPU configuration, each CPU has its own ALB.

Entries within the ALB are not explicitly addressable by the program.

Information is not necessarily retained in the ALB under all conditions for which such retention is possible. Furthermore, information in the ALB may be cleared under conditions additional to those for which clearing is mandatory.

ALB Structure
The description of the logical structure of the ALB covers the implementation by all systems operating as defined by z/Architecture. The ALB entries are considered as being of four types: ALB access-list designations (ALB ALDs), ALB access-list entries (ALB ALEs), ALB ASN-second-table entries (ALB ASTEs), and ALB authority-table entries (ALB ATEs). An ALB entry is considered as containing within it both the information obtained from the ART-table entry in real or absolute storage and the attributes used to fetch the ART-table entry from real or absolute storage.

There is not an indication in an ALB ALD of whether the ALD-source origin used to select the ALD in real storage was the dispatchable-unit-control-table origin or the primary-ASTE origin.

Note: The following sections describe the conditions under which information may be placed in the ALB, the conditions under which information from the ALB may be used for access-register translation, and how changes to the tables affect the ART process.

Formation of ALB Entries
The formation of ALB entries and the effect of any manipulation of the contents of an ART-table entry in real or absolute storage by the program depend on whether the entry is attached to a particular CPU and on whether the entry is valid.
The *attached* state of an ART-table entry denotes that the CPU to which the entry is attached can attempt to use the entry for access-register translation. The ART-table entry may be attached to more than one CPU at a time.

An access-list entry or ASN-second-table entry is *valid* when the invalid bit associated with the entry is zero. Access-list designations and authority-table entries have no invalid bit and are always valid. The primary-space access-list designation is valid regardless of the value of the invalid bit in the primary ASTE.

An ART-table entry may be placed in the ALB whenever the entry is attached and valid.

An access-list designation is attached to a CPU when the designation is within the dispatchable-unit control table designated by the dispatchable-unit-control-table origin in control register 2 or is within the primary ASTE designated by the primary-ASTE origin in control register 5.

An access-list entry is attached to a CPU when the entry is within the access list specified by either an attached access-list designation (ALD) or a usable ALB ALD. A usable ALB ALD is explained in the next section.

An ASN-second-table entry is attached to a CPU when it is designated by the ASTE origin in either an attached and valid access-list entry (ALE) or a usable ALB ALE. A usable ALB ALE is explained in the next section.

An authority-table entry is attached to a CPU when it is within the authority table designated by either an attached and valid ASN-second-table entry (ASTE) or a usable ALB ASTE. A usable ALB ASTE is explained in the next section.

Subject to the attached and valid constraints defined above, the CPU may form ALB entries in anticipation of future storage references or as a result of the speculative execution of instructions. Such ALB entries may be formed independent of the content of the access registers. See “Overlapped Operation of Instruction Execution” on page 5-112 for additional details.

An ALB ATE may be used for a particular instance of access-register translation when both of the following conditions are met:

### Use of ALB Entries

The *usable* state of an ALB entry denotes that the CPU can attempt to use the ALB entry for access-register translation. A usable ALB entry attaches the next-lower-level table, if any, and may be usable for a particular instance of access-register translation.

An ALB ALD is in the usable state when the ALDSO field in the ALB ALD matches the current dispatchable-unit-control-table origin or the current primary-ASTE origin.

An ALB ALD may be used for a particular instance of access-register translation when either of the following conditions is met:

1. The primary-list bit in the ALET to be translated is zero, and the ALDSO field in the ALB ALD matches the current dispatchable-unit-control-table origin.
2. The primary-list bit in the ALET to be translated is one, and the ALDSO field in the ALB ALD matches the current primary-ASTE origin.

An ALB ALE is in the usable state when the ALO field in the ALB ALE matches the ALO field in an attached ALD or a usable ALB ALD.

An ALB ALE may be used for a particular instance of access-register translation when all of the following conditions are met:

1. The ALET to be translated has a value larger than 1. (If the ALET is 0 or 1, the contents of CR 1 or CR 7 are used.)
2. The ALO field in the ALB ALE matches the ALO field in the ALD or ALB ALD being used in the translation.
3. The ALEN field in the ALB ALE matches the ALEN field in the ALET to be translated.

An ALB ASTE is in the usable state when the ASTEO field in the ALB ASTE matches the ASTEO field in an attached and valid ALE or a usable ALB ALE.

An ALB ASTE may be used for a particular instance of access-register translation when the ASTEO field in the ALB ASTE matches the ASTEO field in the ALE or ALB ALE being used in the translation.
1. The ATO field in the ALB ATE matches the ATO field in the ASTE or ALB ASTE being used in the translation.

2. The EAX field in the ALB ATE matches the current EAX.

Modification of ART Tables
When an attached but invalid ART-table entry is made valid, or when an unattached but valid ART-table entry is made attached, and no entry formed from the ART-table entry is already in the ALB, the change takes effect no later than the end of the current instruction.

When an attached and valid ART-table entry is changed, and when, before the ALB is cleared of copies of that entry, an attempt is made to perform ART requiring that entry, unpredictable results may occur, to the following extent. The use of the new value may begin between instructions or during the execution of an instruction, including the instruction that caused the change. Moreover, until the ALB is cleared of copies of the entry, the ALB may contain both the old and the new values, and it is unpredictable whether the old or new value is selected for a particular ART operation. If the old and new values are used as representations of effective space designations, failure to recognize that the effective space designations are the same may occur, with the result that operand overlap may not be recognized. Effective space designations and operand overlap are discussed in “Interlocks within a Single Instruction” on page 5-114.

When LOAD ACCESS MULTIPLE or LOAD CONTROL changes the parameters associated with ART, the values of these parameters at the start of the operation are in effect for the duration of the operation.

All entries are cleared from the ALB by the execution of PURGE ALB, a COMPARE AND SWAP AND PURGE instruction that purges the ALB, and SET PREFIX, and by CPU reset.

Subspace Groups
The subspace-group facility includes the BRANCH IN SUBSPACE GROUP instruction, allocations of fields in the address-space-control element, dispatchable-unit control table, and ASN-second-table entry, and subspace-replacement operations of the PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, SET SECONDARY ASN WITH INSTANCE, and LOAD ADDRESS SPACE PARAMETERS instructions. BRANCH IN SUBSPACE GROUP is introduced in “Subroutine Linkage without the Linkage Stack” on page 5-14 and described in detail in “BRANCH IN SUBSPACE GROUP” on page 10-12.

Subspace-Group Tables
This section describes the use of the dispatchable-unit control table and ASN-second-table entry by the subspace-group facility.

Subspace-Group Dispatchable-Unit Control Table
The dispatchable-unit control table has the following format:

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>BASTEO</th>
<th>SSASTEO</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>C</td>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>20</td>
<td>PSW-Key Mask</td>
<td>PSW Key</td>
</tr>
<tr>
<td>18</td>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1C</td>
<td>28</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

In the 24-Bit or 31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Bits 33-63 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>32</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>36</td>
<td></td>
</tr>
</tbody>
</table>

In the 64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Bits 0-31 of Return Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>32</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>36</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Trap-Control-Block Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>2C</td>
<td>44</td>
<td>E</td>
</tr>
<tr>
<td>30</td>
<td>48</td>
<td></td>
</tr>
<tr>
<td>34</td>
<td>52</td>
<td></td>
</tr>
<tr>
<td>38</td>
<td>56</td>
<td></td>
</tr>
<tr>
<td>3C</td>
<td>60</td>
<td></td>
</tr>
</tbody>
</table>
The fields in the dispatchable-unit control table that are used by the subspace-group facility are allocated as follows:

**Base-ASTE Origin (BASTEO):** Bits 1-25 of bytes 0-3, with six zeros appended on the right, form a 31-bit real address that designates the beginning of the ASN-second-table entry that specifies the base space of a subspace group associated with the dispatchable unit. A comparison of bits 1-25 of bytes 0-3 to the primary-ASTE origin (PASTEO) in bit positions 33-57 of control register 5 is made by BRANCH IN SUBSPACE GROUP to determine whether the current primary address space is in the subspace group for the current dispatchable unit. For this comparison, either bits 1-25 may be compared to the PASTEO or the entire contents of bytes 0-3 may be compared to the contents of bit positions 33-63 of control register 5. A comparison of bits 1-25 of bytes 0-3 to the destination-ASTE origin (DASTEO) obtained from an access-list entry by access-register translation of an ALET other than ALETs 0 and 1 is made by BRANCH IN SUBSPACE GROUP to determine if the destination ASTE is the base-space ASTE. For this comparison, either bits 1-25 may be compared to the DASTEO or the entire contents of bytes 0-3 may be compared to the DASTEO with one leftmost and six rightmost zeros appended. A comparison of bits 1-25 of bytes 0-3 to an ASTE origin (ASTEO) obtained by ASN translation may be made by PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, SET SECONDARY ASN WITH INSTANCE, and LOAD ADDRESS SPACE PARAMETERS. For this comparison, either bits 1-25 may be compared to the ASTEO or the entire contents of bytes 0-3 may be compared to the ASTEO with one leftmost and six rightmost zeros appended. When BRANCH IN SUBSPACE GROUP uses ALET 0, bits 1-25 of bytes 0-3, with six zeros appended on the right, designate the destination ASTE.

**Subspace-Active Bit (SA):** Bit 0 of bytes 4-7 indicates, when one, that the last BRANCH IN SUBSPACE GROUP instruction executed for the dispatchable unit transferred control to a subspace of the subspace group associated with the dispatchable unit. Bit 0 being zero indicates any one of the following: the last BRANCH IN SUBSPACE GROUP instruction executed for the dispatchable unit transferred control to the base space of the subspace group, BRANCH IN SUBSPACE GROUP has not yet been executed for the dispatchable unit, or the dispatchable unit is not associated with a subspace group. BRANCH IN SUBSPACE GROUP sets bit 0 of bytes 4-7 to one when it transfers control to a subspace of the subspace group associated with the dispatchable unit, and it sets bit 0 to zero when it transfers control to the base space of the subspace group.

**Subspace-ASTE Origin (SSASTEO):** Bits 1-25 of bytes 4-7, with six zeros appended on the right, form a 31-bit real address that designates the beginning of the ASN-second-table entry that specifies the subspace last given control by a BRANCH IN SUBSPACE GROUP instruction executed for the dispatchable unit. When BRANCH IN SUBSPACE GROUP transfers control to a subspace by means of an ALET other than ALET 1, it places the ASTEO for the subspace (the destination ASTE) in bit positions 1-25 of bytes 4-7, places zeros in bit positions 26-31 of bytes 4-7, and sets the subspace-active bit, bit 0 of bytes 4-7, to one. When BRANCH IN SUBSPACE GROUP uses ALET 1 to transfer control to a subspace, bits 1-25 of bytes 4-7, with six zeros appended on the right, designate the destination ASTE, and BRANCH IN SUBSPACE GROUP sets the subspace-active bit to one and either sets bits 26-31 of bytes 4-7 to zeros or leaves those bits unchanged. However, if bits 1-25 are all zeros, a special-operation exception is recognized. When BRANCH IN SUBSPACE GROUP transfers control to the base space of the subspace group, it sets the subspace-active bit to zero, and bits 1-31 of bytes 4-7 remain unchanged. Bits 1-25 of bytes 4-7 may be used by PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, SET SECONDARY ASN WITH INSTANCE, and LOAD ADDRESS SPACE PARAMETERS to set bits 0-55 and 57-63 of the primary ASCE in control register 1 or the secondary ASCE in control register 7 from the same bits of the ASCE in the subspace ASTE.

**Subspace-ASTE Sequence Number (SS-ASTESN):** Bytes 12-15 may be used to revoke the linkage capability represented by the SSASTEO, bits 1-25 of bytes 4-7, in the DUCT. When BRANCH IN SUBSPACE GROUP transfers control to a subspace by means of an ALET other than ALET 1, it obtains the ASTESN in the subspace ASTE and places it in bytes 12-15. When BRANCH IN SUBSPACE GROUP uses ALET 1 to transfer control to a subspace, it compares bytes 12-15 to the ASTESN in the subspace ASTE, and it recognizes an ASTE-sequence exception if they are unequal. When the SSASTEO is used by PROGRAM CALL, PROGRAM...
RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, SET SECONDARY ASN WITH INSTANCE, and LOAD ADDRESS SPACE PARAMETERS to set bits 0-55 and 57-63 of the primary ASCE in control register 1 or the secondary ASCE in control register 7 from the same bits of the ASCE in the subspace ASTE, those instructions first compare bytes 12-15 to the ASTESN in the subspace ASTE, and they recognize an ASTE-sequence exception if the two fields are unequal.

Bytes 16-19 are described in “Dispatchable-Unit Control Table and Access-List Designations” on page 5-56. Bytes 20-23 are described in “BRANCH AND SET AUTHORITY” on page 10-6. Bytes 32-39 and 44-47 are described in “TRAP” on page 10-167. Bytes 24-27, 40-43, and 48-63 are reserved for possible future extensions and should contain all zeros. Bytes 28-31 are available for use by programming.

### Subspace-Group ASN-Second-Table Entries

The first 48 bytes of the 64-byte ASN-second-table entry have the following format:

<table>
<thead>
<tr>
<th>I</th>
<th>ATO</th>
<th>30 31</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 1</td>
<td>AX</td>
<td>ATL</td>
</tr>
<tr>
<td>32 48 60 62 63</td>
<td>ASCE (RTD, STD, or RSD) Part 1</td>
<td></td>
</tr>
<tr>
<td>64</td>
<td>RTO, STO, or RSTKO</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RTO/STO (Continued)</th>
<th>GP</th>
<th>S</th>
<th>K</th>
<th>R</th>
<th>DT</th>
<th>TL</th>
<th>R=0</th>
</tr>
</thead>
<tbody>
<tr>
<td>96 116 118 122 124 127</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RTO/STO (Continued)</th>
<th>GP</th>
<th>S</th>
<th>K</th>
<th>R</th>
<th>DT</th>
<th>TL</th>
<th>R=1</th>
</tr>
</thead>
<tbody>
<tr>
<td>96 116 118 123 127</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RSTKO (Continued)</th>
<th>GP</th>
<th>S</th>
<th>K</th>
<th>R</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>96 116 118 128 153 159</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ASTEIN</th>
</tr>
</thead>
<tbody>
<tr>
<td>352 353</td>
</tr>
</tbody>
</table>

For BRANCH IN SUBSPACE GROUP, the fields in bytes 0-47 of the ASTE are allocated as follows:

#### ASX-Invalid Bit (I): Bit 0 controls whether the address space associated with the ASTE is available. When bit 0 is zero during access-register translation of ALET 1 or an ALET other than 0 and 1 for BRANCH IN SUBSPACE GROUP, the translation proceeds. When the bit is one, an ASTE-validity exception is recognized. The bit is ignored during access-register translation of ALET 0. When the ASTE is designated by a subspace-ASTE origin (SSASTE) in a dispatchable-unit control table, bit 0 is also used as described in the definition of bits 160-191 (ASTESN).

#### Authority-Table Origin (ATO): Bits 1-29 are not used by BRANCH IN SUBSPACE GROUP.

#### Base-Space Bit (B): Bit 31 specifies, when one, that the address space associated with the ASTE is the base space of a subspace group. When BRANCH IN SUBSPACE GROUP uses an ALET other than ALETs 0 and 1 to locate a destination ASTE, it recognizes a special-operation exception if the destination-ASTE origin does not equal the base-ASTE origin in the dispatchable-unit control table and bit 31 is one in the destination ASTE.
Authorization Index (AX): Bits 32-47 are not used by BRANCH IN SUBSPACE GROUP.

Authority-Table Length (ATL): Bits 48-59 are not used by BRANCH IN SUBSPACE GROUP.

Controlled-ASN Bit (CA): Bit 62 is not used by BRANCH IN SUBSPACE GROUP.

Reusable-ASN Bit (RA): Bit 63 is not used by BRANCH IN SUBSPACE GROUP.

Address-Space-Control Element (ASCE): Bits 64-127 are an eight-byte address-space-control element (ASCE) that may be a segment-space designation (STD), a region-table designation (RTD), or a real-space designation (RSD). (The term "region-table designation" is used to mean a region-first-table designation, region-second-table designation, or region-third-table designation.) The ASCE field is obtained as the result of access-register translation done for BRANCH IN SUBSPACE GROUP. When BRANCH IN SUBSPACE GROUP uses an ALET other than ALETs 0 and 1 to locate a destination ASTE, it recognizes a special-operation exception if the destination-ASTE origin does not equal the base-ASTE origin in the dispatchable-unit control table and the subspace-group-control bit, bit 118 (G), in the destination ASTE is zero. When BRANCH IN SUBSPACE GROUP transfers control to the base space of a subspace group associated with the current dispatchable unit, it places bits 64-127 in control register 1; otherwise, when BRANCH IN SUBSPACE GROUP transfers control to a subspace of the subspace group, it places bits 64-119 and 121-127 in bit positions 0-55 and 57-63, respectively, of control register 1. Bits 64-127 are used after ASN translation by PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, SET SECONDARY ASN, and LOAD ADDRESS SPACE PARAMETERS as described in "ASN-Second-Table Entries" on page 3-28.

Access-List Designation (ALD): When this ASTE is designated by the primary-ASTE origin in control register 5, bits 128-159 are the primary-space access-list designation (PSALD). During access-register translation when the primary-list bit, bit 7, in the ALET being translated is one, the PSALD is the effective access-list designation.

ASN-Second-Table-Entry Sequence Number (ASTESEN): Bits 160-191 are used to control revocation of the accessing capability represented by access-list entries that designate the ASTE. During access-register translation, bits 160-191 are compared against the ASTESEN in the access-list entry, and inequality causes an ASTE-sequence exception to be recognized.

Linkage-Table Designation (LTD) or Linkage-First-Table Designation (LFTD): Bits 192-223 are not used by BRANCH IN SUBSPACE GROUP.

ASN-Second-Table-Entry Instance Number (ASTEIN): Bits 352-383 are not used by BRANCH IN SUBSPACE GROUP.

Bits 224-319 in the ASTE are available for use by programming.

When the ASTE is designated by a subspace-ASTE origin (SSASTEO) in a dispatchable-unit control table, bits 160-191 are also used to control revocation of the linkage capability represented by that SSASTEO. When BRANCH IN SUBSPACE GROUP uses ALET 1 to transfer control to the subspace specified by the SSASTEO, or when PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, SET SECONDARY ASN, or LOAD ADDRESS SPACE PARAMETERS uses the SSASTEO to set bits 0-55 and 57-63 of the primary ASCE in control register 1 or the secondary ASCE in control register 7 from the same bits of the ASCE in the subspace ASTE, those instructions first test bit 0 of the subspace ASTE for being zero and recognize an ASTE-validity exception if it is not, and they then compare bits 160-191 to the subspace-ASTE sequence number (SSASTESEN) in the dispatchable-unit control table and recognize an ASTE-sequence exception if there is an inequality. However, when either of the two named exception conditions exists for LOAD ADDRESS SPACE PARAMETERS, the instruction sets condition code 1 or 2 instead of recognizing the exception.

Programming Note: All unused fields in the ASTE, including the unused fields in bytes 0-31 and all of bytes 32-63, should be set to zeros. These fields are reserved for future extensions, and programs which place nonzero values in these fields may not operate compatibly on future machines.
Subspace-Replacement Operations

The subspace-group facility includes subspace-replacement operations of PROGRAM CALL, PROGRAM TRANSFER, PROGRAM RETURN, SET SECONDARY ASN, and LOAD ADDRESS SPACE PARAMETERS. The operations apply when the dispatchable unit for which any of the five named instructions is executed is in a state called subspace active. A dispatchable unit is subspace active if it has used BRANCH IN SUBSPACE GROUP to transfer control to a subspace of its subspace group and has not subsequently used BRANCH IN SUBSPACE GROUP to return control to the base space of the group.

The definitions of the subspace-replacement operations are included in the definitions of the five named instructions in Chapter 10, “Control Instructions.” The operations are described in a general way as follows. Whenever (1) an address space is established as the primary or secondary address space as a result of ASN translation or (2) PROGRAM CALL obtains the origin of the ASN-second-table entry specifying a new primary address space from the entry-table entry used, then, if that address space is in a subspace group, as indicated by the subspace-group-control bit, bit 54 (G), being one in the address-space-control element (ASCE) for the address space (the new PASCE in control register 1 or SASCE in control register 7), and if the dispatchable unit is subspace-active, as indicated by the subspace-active bit, bit 0 (SA) of word 1, in the dispatchable-unit control table (DUCT) being one, the ASN-second-table-entry (ASTE) origin (ASTEO) for the address space, which was obtained by ASN translation or from the entry-table entry, is compared to the base-ASTE origin (BASTEO), bits 1-25 of word 0, in the DUCT. If that ASTE and the BASTE are equal, the following occurs. An ASTE-validity exception is recognized if bit 0 in the ASTE for the last subspace entered by the dispatchable unit, which ASTE is designated by the subspace-ASTE origin (SSASTEO) in the DUCT, is one. An ASTE-sequence exception is recognized if the ASTE-sequence number (ASTESN) in word 5 of the subspace ASTE does not equal the subspace ASTESN (SSASTESN) in word 3 of the DUCT. However, LOAD ADDRESS SPACE PARAMETERS sets a nonzero condition code instead of recognizing the ASTE-validity or ASTE-sequence exception. If no exception exists, bits 0-55 and 57-63 of the ASCE for the address space (the PASCE in control register 1 or SASCE in control register 7) are replaced by the same bits of the ASCE in word 2 of the subspace ASTE.

If an addressing exception is recognized when attempting to access the DUCT or subspace ASTE, the instruction execution is suppressed. If an ASTE-validity or ASTE-sequence exception is recognized, the instruction execution is nullified. Such nullification or suppression causes all control register contents to remain unchanged from what they were at the beginning of the instruction execution.

Key-controlled protection does not apply to any accesses to the DUCT or subspace ASTE.

For comparing the ASTEO obtained by ASN translation to the BASTEO, either the ASTEO may be compared to the BASTEO or the ASTEO, with one leftmost and six rightmost zeros appended, may be compared to the entire contents of word 0 of the DUCT.

When the SSASTEO in the DUCT is used to access the subspace ASTE, no check is made for whether the SSASTEO is all zeros.

The references to the DUCT and subspace ASTE are single-access references and appear to be word concurrent as observed by other CPUs. The words of the DUCT are accessed in no particular order. The words of the subspace ASTE are accessed in no particular order except that word 0 is accessed first.

The exceptions that can be recognized during a subspace-replacement operation are referred to collectively as the subspace-replacement exceptions and are listed in priority order in “Subspace-Replacement Exceptions” on page 6-54.

Linkage-Stack Introduction

Many of the functions related to the linkage stack are described in this section and in “Linkage-Stack Operations” on page 5-77. Additionally, tracing of the stacking PROGRAM CALL instruction and of the PROGRAM RETURN instruction is described in Chapter 5, “Program Execution”; interruptions in Chapter 6, “Interruptions”; and the instructions are described in Chapter 10, “Control Instructions.”
Summary

These major functions are provided:

1. A table-based subroutine-linkage mechanism that provides PSW and control-register status changing and which saves and restores this status and the contents of general registers and access registers through the use of an entry in a linkage stack.

2. A branch-type linkage mechanism that uses the linkage stack.

3. Instructions for placing an additional two words of status in the current linkage-stack entry and for retrieving all of the status and the general-register and access-register contents that are in the entry.

4. An instruction for determining whether a program is authorized to use a particular access-list-entry token.

5. Aids for program-problem analysis.

In addition, control and authority mechanisms are incorporated to control these functions.

It is intended that a separate linkage stack be associated with and used by each dispatchable unit. The linkage stack for a dispatchable unit resides in the home address space of the dispatchable unit.

It is intended that a dispatchable unit's linkage stack be protected from the dispatchable unit by means of key-controlled protection. Key-controlled protection does not apply to the linkage-stack instructions that place information in or retrieve information from the linkage stack.

The linkage-stack functions are for use by programs considered to be semi privileged, that is, programs which are executed in the problem state but which are authorized to use additional functions. With these authorization controls, a nonhierarchical organization of programs may be established, with each program in a sequence of calling and called programs having a degree of authority that is arbitrarily different from those of programs before or after it in the sequence. The range of functions available to each program, and the ability to transfer control from one program to another, are prescribed in tables that are managed by the control program.

The linkage-stack instructions, which are semiprивileged, are described in Chapter 10, “Control Instructions.” They are:

- BRANCH AND STACK
- EXTRACT STACKED REGISTERS
- EXTRACT STACKED STATE
- MODIFY STACKED STATE
- PROGRAM RETURN
- TEST ACCESS

In addition, the PROGRAM CALL instruction optionally forms an entry in the linkage stack. A PROGRAM CALL instruction that operates on the linkage stack is called stacking PROGRAM CALL. Recognition of PROGRAM CALL as stacking PROGRAM CALL is under the control of a bit in the entry-table entry.

Linkage-Stack Functions

Transferring Program Control

The use of the linkage stack permits programs operating at arbitrarily different levels of authority to be linked directly without the intervention of the control program. The degree of authority of each program in a sequence of calling and called programs may be arbitrarily different, thus allowing a nonhierarchical organization of programs to be established. Modular authorization control can be obtained principally by associating an extended authorization index with each program module. This allows program modules with different authorities to coexist in the same address space. On the other hand, the extended authorization index in effect during the execution of a called program module can be the one that is associated with the calling program module, thus allowing the called module to be executed with different authorities on behalf of different dispatchable units. Options concerning the PSW-key mask and the secondary ASN are other means of associating different authorities with different programs or with the same called program. The authority of each program is prescribed in tables that are managed by the control program. By setting up the tables so that the same program can be called by means of different PC numbers, the program can be assigned different authorities depending on which PC number is used to call it. The tables also allow control over which PC numbers can be used by a program to call other programs.

The stacking PROGRAM CALL and PROGRAM RETURN linkage operations can link programs residing in different address spaces and having different...
levels of authority. The execution state and the contents of the general registers and access registers are saved during the execution of stacking PROGRAM CALL and are partially restored during the execution of PROGRAM RETURN. A linkage stack provides an efficient means of saving and restoring both the execution state and the contents of registers during linkage operations.

During the execution of a PROGRAM CALL instruction, the PC-number-translation process is performed to locate a 32-byte entry-table entry. When the PC-type bit in the entry-table entry is one, the stacking PROGRAM CALL operation is specified; otherwise, the basic PROGRAM CALL operation is specified.

In addition to the information applying to both basic PROGRAM CALL and stacking PROGRAM CALL (described in “PC-Number Translation” on page 5-34 and consisting of an authorization key mask and specifications of the new ASN, addressing mode, instruction address, problem state, PSW-key mask, primary-ASTE address, and entry parameter), the entry-table entry contains information that specifies options concerning the address-space control and PSW key in the PSW, and the PSW-key mask, extended authorization index, and secondary ASN in the control registers.

During the stacking PROGRAM CALL operation and by means of the additional information in the entry-table entry, the address-space control in the PSW can be set to specify either the primary-space mode or the access-register mode. The PSW key can be either left unchanged or replaced from the entry-table entry. The PSW-key mask in control register 3 can be either ORed to or replaced from the entry-table entry. The extended authorization index in control register 8 can be either left unchanged or replaced from the entry-table entry. The secondary ASN in control register 7 can be set equal to the primary ASN of either the calling program or the called program; thus, the ability of the called program to have access to the primary address space of the calling program can be controlled.

The stacking PROGRAM CALL operation always forms an entry, called a state entry, in the linkage stack to save the execution state and the contents of general registers 0-15 and access registers 0-15. The saved execution state includes a called-space identification, the numeric part of the PC number used, the updated PSW before any changes are made due to the entry-table entry, the extended authorization index, PSW-key mask, primary ASN, and secondary ASN existing before the operation, and the extended-addressing-mode bit existing after the operation. However, the value of the PER mask in the saved updated PSW is unpredictable. The linkage-stack state entry also contains an entry-type code that identifies the entry as one that was formed by PROGRAM CALL. If the ASN-and-LX-reuse facility is installed and enabled, the state entry also contains the primary ASN-second-table-entry instance number (primary ASTEIN) and secondary ASTEIN existing before the operation.

A space-switching operation occurs when the address-space number (ASN) specified in the entry-table entry is nonzero. When space switching occurs, the operation is called PROGRAM CALL with space switching (PC-ss), and the ASN in the entry-table entry is placed in control register 4 as a new primary ASN. When no space switching occurs, the operation is called PROGRAM CALL to current primary (PC-cp), and there is no change to the primary ASN in control register 4.

PROGRAM CALL with space switching obtains the new ASN from the entry-table entry and places it in control register 4 as the primary ASN. It obtains a new primary-ASTE origin from the entry-table entry and new primary address-space-control element from the new primary ASTE, and it places them in control registers 5 and 1, respectively. It sets the secondary address-space-control element in control register 7 equal to either the old primary address-space-control element, or the new one, depending on whether it sets the secondary ASN in control register 3 equal to the old primary ASN or the new one, respectively. PROGRAM CALL to current primary sets the secondary ASN equal to the primary ASN and the secondary address-space-control element equal to the primary address-space-control element.

If the ASN-and-LX-reuse facility is installed and enabled, PROGRAM CALL with space switching obtains the ASN-second-table-entry instance number (ASTEIN) from the new primary ASTE and places it in control register 4 as the new primary ASTEIN. It sets the secondary ASTEIN in control register 3 equal to either the old primary ASTEIN or the new one, depending on whether it set the secondary ASN equal to the old primary ASN or the new one, respectively. PROGRAM CALL to current primary sets the secondary ASTEIN equal to the primary ASTEIN.
The instruction PROGRAM RETURN restores most of the information saved in the linkage stack by the stacking PROGRAM CALL operation. It restores the PSW, extended authorization index, PSW-key mask, primary ASN, secondary ASN, and the contents of general registers 2-14 and access-registers 2-14. However, the PER mask in the current PSW remains unchanged. If the ASN-and-LX-reuse facility is installed and enabled, PROGRAM RETURN restores the primary ASTEIN and secondary ASTEIN. The operation of PROGRAM RETURN is referred to by saying that PROGRAM RETURN unstacks a state entry.

For PROGRAM RETURN, a space-switching operation occurs when the restored primary ASN is not equal to the primary ASN existing before the operation. When space switching occurs, the operation is called PROGRAM RETURN with space switching (PR-ss). When no space switching occurs, the operation is called PROGRAM RETURN to current primary (PR-cp).

PROGRAM RETURN with space switching performs ASN translation of the restored primary ASN to obtain a new primary-ASTE origin and a new primary address-space-control element, which it places in control registers 5 and 1, respectively. For PROGRAM RETURN with space switching or to current primary, (1) if the restored secondary ASN is the same as the restored primary ASN, the secondary address-space-control element in control register 7 is set equal to the new primary address-space-control element in control register 1, or (2) if the restored secondary ASN is not the same as the restored primary ASN, ASN translation and ASN authorization of the restored secondary ASN are performed to obtain a new secondary address-space-control element, which is placed in control register 7.

If the ASN-and-LX-reuse facility is installed and enabled, PROGRAM RETURN with space switching requires that the ASN-second-table-entry instance number (ASTEIN) in the new primary ASTE be equal to the primary ASTEIN saved in the state entry being unstacked. PROGRAM RETURN with space switching or to current primary, if the restored secondary ASN is not the same as the restored primary ASN, requires that the ASTEIN in the new secondary ASTE be equal to the saved ASTEIN. An exception is recognized if either of these requirements is not met.

The stacking PROGRAM CALL operation and the PROGRAM RETURN operation each can be performed successfully only in the primary-space mode or access-register mode. An exception is recognized when the CPU is in the real mode, secondary-space mode, or home-space mode.

A bit, named the unstack-suppression bit, can be set to one in a linkage-stack state entry to cause an exception if an attempt is made by PROGRAM RETURN to unstack the entry. When the bit is one, the entry still can be operated on by the instructions that add information to or retrieve information from the entry. The unstack-suppression bit is intended to allow the control program to gain control when an attempt is made to unstack a state entry in which the bit is one.

**Branching Using the Linkage Stack**

The execution state and the contents of the general registers and access registers can also be saved in the linkage stack by means of the instruction BRANCH AND STACK. BRANCH AND STACK uses a branch address as do the other branching instructions, instead of using a PC number. BRANCH AND STACK, along with PROGRAM RETURN, can link programs residing in the same address space and having the same level of authority; that is, BRANCH AND STACK does not change the execution state except for the instruction address.

BRANCH AND STACK forms a linkage-stack state entry that is almost the same as one formed by PROGRAM CALL. When it is necessary to distinguish between these two types of state entry, an entry formed by PROGRAM CALL is called a program-call state entry, and one formed by BRANCH AND STACK is called a branch state entry. A branch state entry differs from a program-call state entry in two ways: (1) it contains a different entry-type code, which identifies it as a branch state entry, and (2) it contains the basic-addressing-mode bit and instruction address existing after the operation instead of a called-space identification and the numeric part of the PC number used. These new values of PSW bits 32 and 64-127 are in addition to the complete PSW that is saved in the state entry.

For BRANCH AND STACK, the basic- and extended addressing mode bits and the instruction address that are part of the complete PSW saved in the state entry can be the current (at the beginning of the operation) addressing-mode bits and the updated instruction address (the address of the next sequential instruction), or they can be specified in a register.
This register can be one that had link information placed in it by a BRANCH AND LINK (BALR only), BRANCH AND SAVE, BRANCH AND SAVE AND SET MODE, or BRANCH AND SET MODE instruction. Thus, BRANCH AND STACK can be used either in a calling program or at (or near) the entry point of a called program, and, in either case, a PROGRAM RETURN instruction located at the end of the called program will return correctly to the calling program. The ability to use BRANCH AND STACK at an entry point allows the linkage stack to be used without changing old calling programs.

When the R₃ field of BRANCH AND STACK is zero, the instruction is executed without causing branching.

When PROGRAM RETURN unstacks a branch state entry, it ignores the extended authorization index, PSW-key mask, primary ASN, secondary ASN, primary ASTEIN, and secondary ASTEIN in the entry. The PROGRAM RETURN instruction restores the PSW and the contents of general registers 2-14 and access registers 2-14 that were saved in the entry. However, the PER mask in the current PSW remains unchanged.

BRANCH AND STACK can be executed successfully only in the primary-space mode or access-register mode. An exception is recognized when the CPU is in the real mode, secondary-space mode, or home-space mode. The unstack-suppression bit has the same effect in a branch state entry as it does in a program-call state entry.

Adding and Retrieving Information

The instruction MODIFY STACKED STATE can be used by a program to place two words of information, contained in a designated general-register pair, in an area, called the modifiable area, of the current linkage-stack state entry (a branch state entry or a program-call state entry). This is intended to allow a called program to establish a recovery routine that will be given control by the control program, if necessary.

The instructions EXTRACT STACKED REGISTERS and EXTRACT STACKED STATE can be used by a program to obtain any of the information saved in the current state entry by BRANCH AND STACK or PROGRAM CALL or placed there by MODIFY STACKED STATE. EXTRACT STACKED REGISTERS (EREGG) places the contents of a specified range of general registers and access registers back in the registers from which the contents were saved. EXTRACT STACKED REGISTERS (EREG) does the same except that it restores only bits 32-63 of the general registers and leaves bits 0-31 unchanged. EXTRACT STACKED STATE obtains pairs of words of the nonregister information saved or placed in a state entry and places them in bit positions 32-63 of a designated general-register pair. Alternatively, EXTRACT STACKED STATE obtains two double-words containing a PSW saved in the state entry and places them in bit positions 0-63 of a designated general-register pair. If the ASN-and-LX-reuse facility is installed, EXTRACT STACKED STATE can place the contents of two words of the state entry in bit positions 0-31 of a designated general-register pair. These contents are the saved secondary ASTEIN and primary ASTEIN if the ASN-and-LX-reuse facility is enabled. EXTRACT STACKED STATE sets the condition code to indicate whether the current state entry is a branch state entry or a program-call state entry.

Testing Authorization

The instruction TEST ACCESS has as operands an access-list-entry token (ALET) in a designated access register and an extended authorization index (EAX) in a designated general register. TEST ACCESS applies the access-register-translation process, which uses the specified EAX instead of the current EAX in control register 8, to the ALET, and it sets the condition code to indicate the result. The condition code may indicate: (1) the ALET is 00000000 hex, (2) the ALET designates an entry in the dispatchable-unit access list and can be translated without exceptions in access-register translation, (3) the ALET designates an entry in the primary-space access list and can be translated without exceptions in access-register translation, or (4) the ALET is 00000001 hex or causes exceptions in access-register translation.

The principal purpose of TEST ACCESS is to allow a called program to determine whether an ALET passed to it by the calling program is authorized for use by the calling program by means of the calling program's EAX. This is in support of a possible programming convention in which a called program will not operate on an AR-specified address space by means of its own EAX unless the calling program is authorized to operate on that space by means of the calling program's EAX. The called program can obtain the calling program's EAX, for use by TEST
ACCESS, from the current linkage-stack state entry by means of the EXTRACT STACKED STATE instruction.

Another purpose of TEST ACCESS is to indicate the special cases in which the ALET is 00000000 hex, designating the primary address space, or 00000001 hex, designating the secondary address space. Because PROGRAM CALL may change the primary and secondary address spaces, ALETs 00000000 hex and 00000001 hex may designate different address spaces when used by the called program than when used by the calling program.

Still another purpose of TEST ACCESS is to indicate whether the ALET designates an entry in the primary-space access list since such a designation after the primary address space was changed by a space-switching program-linkage operation may be an error.

Program-Problem Analysis
To aid program-problem analysis, the option is provided of having a trace entry made implicitly for three additional linkage operations when the linkage stack is used. When branch tracing is on, a trace entry is made each time a BRANCH AND STACK instruction is executed and causes branching. When ASN tracing is on, a trace entry is made each time the stacking PROGRAM CALL operation is performed and each time PROGRAM RETURN unstacks a linkage-stack state entry formed by PROGRAM CALL. When mode tracing is on, a trace entry is made each time the stacking PROGRAM CALL operation or PROGRAM RETURN operation is performed and changes PSW bit 31, except that, for PROGRAM RETURN, a trace entry for mode tracing is not made if one due to ASN tracing is made. A detailed definition of tracing is contained in “Tracing” on page 4-10.

As a further analysis aid, BRANCH AND STACK when it causes branching, stacking PROGRAM CALL, and PROGRAM RETURN are also recognized as PER successful-branching events. For PROGRAM RETURN, the unstacked state entry may have been formed by BRANCH AND STACK or PROGRAM CALL.

The execution of a space-switching stacking PROGRAM CALL or PROGRAM RETURN instruction causes a space-switch-event control if the primary space-switch-event control is one before or after the operation or if a PER event is to be indicated.

Linkage-Stack Entry-Table Entries

All of the fields in the entry-table entry except bits 130-159 are described in “Entry-Table Entries” on page 5-37. This section describes only bits 130-159.

The entry-table entry has the following format:

<table>
<thead>
<tr>
<th>If Bit 129 is Zero</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>31</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>entry Instruction Address (Part 1)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>31</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>If Bit 129 is One</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>31</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Entry Instruction Address (Part 2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>63</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
<tr>
<td>⎯</td>
</tr>
</tbody>
</table>

Remaining fields (independent of bit 129)

<table>
<thead>
<tr>
<th>Authorization Key Mask</th>
<th>ASN</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
<td>80</td>
</tr>
<tr>
<td>95</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Entry Key Mask</th>
</tr>
</thead>
<tbody>
<tr>
<td>96</td>
</tr>
<tr>
<td>112</td>
</tr>
<tr>
<td>127</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Entry Extended Authorization Index</th>
</tr>
</thead>
<tbody>
<tr>
<td>128</td>
</tr>
<tr>
<td>136</td>
</tr>
<tr>
<td>140</td>
</tr>
<tr>
<td>144</td>
</tr>
<tr>
<td>159</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ASTE Origin</th>
</tr>
</thead>
<tbody>
<tr>
<td>160</td>
</tr>
<tr>
<td>186</td>
</tr>
<tr>
<td>191</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Entry Parameter (Part 1)</th>
</tr>
</thead>
<tbody>
<tr>
<td>192</td>
</tr>
<tr>
<td>223</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Entry Parameter (Part 2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>224</td>
</tr>
<tr>
<td>255</td>
</tr>
</tbody>
</table>

The fields in bit positions 130-159 are allocated as follows:

Reserved (RI): Bit 130 is reserved for IBM use.

PSW-Key Control (K): Bit 131, when one, specifies that bits 136-139 are to replace the PSW key in the PSW as part of the stacking PROGRAM CALL operation. When this bit is zero, the PSW key remains unchanged. Bit 131 is ignored during the basic PROGRAM CALL operation.

PSW-Key-Mask Control (M): Bit 132, when one, specifies that bits 96-111 are to replace the PSW-key
mask in control register 3 as part of the stacking PROGRAM CALL operation. When this bit is zero, bits 96-111 are ORed into the PSW-key mask in control register 3 as part of the stacking PROGRAM CALL operation. Bit 132 is ignored during the basic PROGRAM CALL operation.

Extended-Authorization-Index Control (E): Bit 133, when one, specifies that bits 144-159 are to replace the current extended authorization index in control register 8 as part of the stacking PROGRAM CALL operation. When this bit is zero, the current extended authorization index remains unchanged. Bit 133 is ignored during the basic PROGRAM CALL operation.

Address-Space-Control Control (C): Bit 134, when one, specifies that bit 17 of the current PSW is to be set to one as part of the stacking PROGRAM CALL operation. When this bit is zero, bit 17 is set to zero. Because the CPU must be in either the primary-space mode or the access-register mode when a stacking PROGRAM CALL instruction is issued, the result is that the CPU is placed in the access-register mode if bit 134 is one or the primary-space mode if bit 134 is zero. Bit 134 is ignored during the basic PROGRAM CALL operation.

Secondary-ASN Control (S): Bit 135, when one, specifies that bits 80-95 are to become the new secondary ASN, and the new SASCE is to be set equal to the new PASCE, as part of the stacking PROGRAM CALL with-space-switching (PC-ss) operation. When this bit is zero, the new SASN and SASCE are set equal to the PASN and PASCE, respectively, of the calling program. When the ASN-and-LX-reuse facility is installed and enabled, bit 135 similarly specifies, when one, that the new SASTEIN is to be set equal to the new PASTEIN or, when zero, that the new SASTEIN is to be set equal to the PASTEIN of the calling program. Bit 135 is ignored during the basic PROGRAM CALL operation and the stacking PROGRAM CALL to-current-primary (PC-cp) operation.

Entry Key (EK): Bits 136-139 replace the PSW key in the PSW as part of the stacking PROGRAM CALL operation if the PSW-key control, bit 131, is one. Bits 136-139 are ignored, and the current PSW key remains unchanged, if bit 131 is zero. Bits 136-139 are ignored during the basic PROGRAM CALL operation.

Entry Extended Authorization Index: Bits 144-159 replace the current extended authorization index, bits 32-47 of control register 8, as part of the stacking PROGRAM CALL operation if the extended-authorization-index control, bit 133, is one. Bits 144-159 are ignored, and the current extended authorization index remains unchanged, if bit 133 is zero. Bits 144-159 are ignored during the basic PROGRAM CALL operation.

Bits 130 and 140-143 are reserved for possible future extensions and should be zeros.

Linkage-Stack Operations

A linkage stack may be formed by the control program for each dispatchable unit. The linkage stack is used to save the execution state and the contents of the general registers and access registers during the BRANCH AND STACK and stacking PROGRAM CALL operations. The linkage stack is also used to restore a portion of the execution state and general-register and access-register contents during the PROGRAM RETURN operation.

A linkage stack resides in virtual storage. The linkage stack for a dispatchable unit is in the home address space for that dispatchable unit. The home address space is designated by the home address-space-control element in control register 13.

The linkage stack is intended to be protected from problem-state programs so that these programs cannot examine or modify the information saved in the linkage stack, except by means of the EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, and MODIFY STACKED STATE instructions. This protection can be obtained by means of key-controlled protection.

A linkage stack may consist of a number of linkage-stack sections chained together. A linkage-stack section is variable in length. The maximum length of each linkage-stack section is 65,560 bytes.

There are three types of entry in the linkage stack: header entry, trailer entry, and state entry. A header entry and a trailer entry are at the beginning and end, respectively, of a linkage-stack section, and they are used to chain linkage-stack sections together. Header entries and trailer entries are formed by the control program. A state entry is used to contain the
execution state and register contents that are saved during the BRANCH AND STACK or stacking PROGRAM CALL operation, and it is formed during the operation. A state entry is further distinguished as being a branch state entry if it was formed by BRANCH AND STACK or as being a program-call state entry if it was formed by PROGRAM CALL.

The actions of forming a state entry and saving information in it during the BRANCH AND STACK and stacking PROGRAM CALL operations are called the stacking process. The actions of restoring information from a state entry and logically deleting the entry during the PROGRAM RETURN operation are called the unstacking process. The part of the unstacking process that locates a state entry is also performed during the EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, and MODIFY STACKED STATE operations.

Each type of linkage-stack entry has a length that is a multiple of eight bytes. A header entry and trailer entry each has a length of 16 bytes. A state entry has a length of 296 bytes.

Each of the header entry, trailer entry, and state entry has a common eight-byte area at its end, called the entry descriptor. The linkage-stack-entry address in control register 15 designates the leftmost byte of the entry descriptor of the last linkage-stack entry, other than the trailer entry, in a linkage-stack section. This entry is called the current linkage-stack entry, and the section is called the current linkage-stack section.

Each entry descriptor in a linkage-stack section, except the one in the trailer entry of the section, includes a field that specifies the amount of space existing between the end of the entry descriptor and the beginning of the trailer entry. This field is named the remaining-free-space field. The remaining-free-space field in a trailer entry is unused.

When a new state entry is to be formed in the linkage stack during the stacking process, the new entry is placed immediately after the entry descriptor of the current linkage-stack entry, provided that there is enough remaining free space in the current linkage-stack section to contain the new entry. If there is not enough remaining free space in the current section, and if the trailer entry in the current section indicates that another section follows the current section, the new entry is placed immediately after the entry descriptor of the header entry of that following section, provided that there is enough remaining free space in that section. If the trailer entry indicates that there is not a following section, an exception is recognized, and a program interruption occurs. It is then the responsibility of the control program to allocate another section, chain it to the current section, and cause the BRANCH AND STACK or stacking PROGRAM CALL instruction to be reexecuted. If there is a following section but there is not enough remaining free space in it, an exception is recognized.

If the remaining-free-space value that is used to locate a trailer entry is not a multiple of 8, an exception is recognized. The remaining-free-space value in the header entry of a linkage-stack section must be set to a multiple of 8 to ensure that the remaining-free-space value that may be used to locate the trailer entry of the section will be a multiple of 8.

When the stacking process is successful in forming a new state entry, it updates the linkage-stack-entry address in control register 15 so that the address designates the leftmost byte of the entry descriptor of the new entry, which thus becomes the new current linkage-stack entry.

When, during the unstacking process in PROGRAM RETURN, the current linkage-stack entry is a state entry, the process operates on that entry and then updates the linkage-stack-entry address so that it designates the entry descriptor of the preceding entry in the same linkage-stack section. The preceding entry thus becomes the current entry. The new current entry may be another state entry, or it may be a header entry.

The header entry of a linkage-stack section indicates whether there is a preceding section. If there is a preceding section, the header entry contains the address of the last linkage-stack entry, other than the trailer entry, in the preceding section. That last entry should be a state entry (not another header entry), unless there is an error in the linkage stack.

If the unstacking process is performed when the current linkage-stack entry is a header entry, and if the header entry indicates that a preceding linkage-stack section exists, the unstacking process proceeds by treating the entry designated in the preceding section as if it were the current entry, provided that this entry is a state entry. If the header entry does not indicate a preceding section, or if the entry designated in the preceding section is not a state entry, an exception is recognized.
When the unstacking process is performed in EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, or MODIFY STACKED STATE, the process locates a state entry but does not change the linkage-stack-entry address in control register 15.

Each entry descriptor in a linkage-stack section includes a field that specifies the length of the next linkage-stack entry, other than the trailer entry, in the section. When a state entry is created during the stacking process, zeros are placed in this field in the created entry, and the length of the state entry is placed in this field in the preceding entry. When a state entry is logically deleted during the unstacking process in PROGRAM RETURN, zeros are placed in this field in the preceding entry. This field is named the next-entry-size field.

When the stacking or unstacking process operates on the linkage stack, key-controlled protection does not apply, but low-address and DAT protection do apply.

### Linkage-Stack-Operations Control

The use of the linkage stack is controlled by the ASN-and-LX-reuse control in control register 0, the home address-space-control element in control register 13 and the linkage-stack-entry address in control register 15. The home address-space-control element is described in “Dynamic Address Translation” on page 3-35.

The ASN-and-LX-reuse control and the linkage-stack-entry address are

#### Control Register 0

**ASN-and-LX-Reuse Control (R):** Bit 44 of control register 0 is the ASN-and-LX-reuse-control bit (R) and is assigned if the ASN-and-LX-reuse facility is installed. The effects of a one value of the bit specifically on the linkage stack are as follows:

- BRANCH AND STACK and stacking PROGRAM CALL save the secondary ASN-second-table-entry instance number (ASTEIN), bits 0-31 of control register 3, and the primary ASTEIN, bits 0-31 of control register 4, in bytes 176-179 and 180-183, respectively, of the linkage-stack state entry that either of the instructions forms.

- PROGRAM RETURN with space switching, after it has used the PASN in bytes 134 and 135 of the state entry to locate an ASN-second-table entry, compares the primary ASTEIN in bytes 180-183 of the state entry to the ASTEIN in the ASN-second-table entry. PROGRAM RETURN to current primary or with space switching, if it uses the SASN in bytes 130 and 131 of the state entry to locate an ASN-second-table entry (because the new SASN is not equal to the new PASN), compares the secondary ASTEIN in bytes 176-179 of the state entry to the ASTEIN in the ASN-second-table entry. The one or two comparisons of ASTEINs must each give equal results; otherwise, an ASTE-instance exception is recognized. The comparisons occur regardless of the reusable-ASN bits in the ASN-second-table entries. PROGRAM RETURN to current primary or with space switching restores the secondary and primary ASTEINs saved in the state entry to bit positions 0-31 of control registers 3 and 4, respectively (if no exception is recognized). When unstacking a state entry formed by BRANCH AND STACK, PROGRAM RETURN does not compare or restore ASTEINs.

The effect of the ASN-and-LX-reuse control on PC-number translation is described in “ASN-and-LX-Reuse Control (R)” on page 5-35. Other effects of the control are described in “ASN-Second-Table-Entry Instance Number and ASN Reuse” on page 3-22.

#### Control Register 15

The location of the entry descriptor of the current linkage-stack entry is specified in control register 15. The register has the following format:

**Linkage-Stack-Entry Address:** Bits 0-60 of control register 15, with three zeros appended on the right, form the 64-bit home virtual address of the
entry descriptor of the current linkage-stack entry in the current linkage-stack section. Bits 0-60 are changed during the stacking process in BRANCH AND STACK and stacking PROGRAM CALL and during the unstacking process in PROGRAM RETURN. Bits 61-63 of control register 15 are set to zeros when bits 0-60 are changed.

**Linkage Stack**

The linkage stack consists of one or more linkage-stack sections containing linkage-stack entries. There are three principal types of linkage-stack entry: header entry, trailer entry, and state entry. A state entry is further distinguished as being either a branch state entry or a program-call state entry.

Each type of linkage-stack entry has an entry descriptor at its end. The leftmost byte of the entry descriptor of the current linkage-stack entry in the current linkage-stack section is designated by the linkage-stack-entry address in control register 15.

The linkage stack resides in the home address space, designated by the home address-space-control element in control register 13.

**Entry Descriptors**

An entry descriptor is at the end of each linkage-stack entry. The entry descriptor is eight bytes in length and has the following format:

```
+-------+-------+-------+-------+
| U     | ET    | SI    | RFS   |
+-------+-------+-------+-------+
| 0     | 1     | 8     | 16    |
| 16    | 31    |
+-------+-------+-------+-------+
| NES   |
+-------+-------+-------+-------+
| 32    | 48    | 63    |
```

The fields in the entry descriptor are allocated as follows:

**Unstack-Suppression Bit (U):** When bit 0 is one in the entry descriptor of a header entry or state entry encountered during the unstacking process in PROGRAM RETURN, a stack-operation exception is recognized. Bit 0 is ignored in a trailer entry and during the unstacking process in EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, and MODIFY STACKED STATE. The control program can temporarily set bit 0 to one in the current linkage-stack entry (a header entry or state entry) to prevent PROGRAM RETURN from being executed successfully while still allowing EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, and MODIFY STACKED STATE to be executed successfully. Bit 0 is set to zero in the entry descriptor of a state entry when the entry is formed during the stacking process.

**Entry Type (ET):** Bits 1-7 are a code that specifies the type of the linkage-stack entry containing the entry descriptor. The assigned codes are:

<table>
<thead>
<tr>
<th>Code (in Binary)</th>
<th>Entry Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>0001001</td>
<td>Header entry</td>
</tr>
<tr>
<td>0001010</td>
<td>Trailer entry</td>
</tr>
<tr>
<td>0001100</td>
<td>Branch State entry</td>
</tr>
<tr>
<td>0001101</td>
<td>Program-call state entry</td>
</tr>
</tbody>
</table>

Codes 00000000-0001000, 0001011, and 0001110 through 0111111 binary are reserved for possible future assignments. Codes 1000000 through 1111111 binary are available for use by programming.

Bits 1-7 are set to 0001100 or 0001101 binary in the entry descriptor of a state entry when the entry is formed during the stacking process.

A stack-type exception is recognized during the unstacking process in EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, MODIFY STACKED STATE, or PROGRAM RETURN if bits 1-7 in the current linkage-stack entry do not indicate that the entry is a state entry or a header entry; or, when the current entry is a header entry, if bits 1-7 in the entry designated by the backward stack-entry address in the header entry do not indicate that the designated entry is a state entry. However, a stack-specification exception is recognized, instead of a stack-type exception, if both the current entry and the designated entry are header entries.

**Section Identification (SI):** Bits 8-15 are an identification, provided by the control program, of the linkage-stack section containing the entry descriptor. In the state entry formed by a stacking process, the process sets bits 8-15 equal to the contents of the section-identification field in the preceding linkage-stack entry.

**Remaining Free Space (RFS):** Bits 16-31 specify the number of bytes between the end of this entry descriptor and the beginning of the trailer entry in the same linkage-stack section, except that this field in a trailer entry has no meaning. Thus, in the last state
entry in a section, or in the header entry if there is no state entry, bits 16-31 specify the number of bytes available in the section for performance of the stacking process. In the state entry formed by a stacking process, the process sets bits 16-31 equal to the contents of the remaining-free-space field in the preceding linkage-stack entry minus the size, in bytes, of the new entry. Bits 16-31 must be a multiple of 8 (bits 29-31 must be zeros) in the entry descriptor of the header entry in a linkage-stack section; otherwise, a value that is not a multiple of 8 will be propagated to bits 16-31 in the entry descriptor of each state entry in the section, and a stack-specification exception will be recognized if the stacking process attempts to locate the trailer entry in the section in order to proceed to the next section.

Next-Entry Size (NES): Bits 32-47 specify the size in bytes of the next linkage-stack entry, other than a trailer entry, in the same linkage-stack section. This field in the current linkage-stack entry contains all zeros. This field in a trailer entry has no meaning. When the stacking process forms a state entry, it places zeros in the next-entry-size field of the new entry, and it places the size of the new entry in the next-entry-size field of the preceding entry. When the unstacking process logically deletes a state entry, it places zeros in the next-entry-size field of the preceding entry, which entry becomes the current entry.

Bits 48-63 are set to zeros in a state entry when the entry is formed during the stacking process. In a header entry, trailer entry, or state entry, bits 48-63 are reserved for possible future extensions and should always be zeros.

Programming Note: No entry-type code will be assigned in which the leftmost bit of the code is one. The control program can temporarily set the leftmost bit to one in the entry-type code of the current linkage-stack entry (a header entry or a state entry) to prevent the successful execution of EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, MODIFY STACKED STATE, or PROGRAM RETURN.

Header Entries
A header entry is at the beginning of each linkage-stack section. The header entry is 16 bytes in length and has the following format:

<table>
<thead>
<tr>
<th>Backward Stack-Entry Address (Part 1)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 31</td>
</tr>
<tr>
<td>Backward Stack-Entry Address (Part 2)</td>
</tr>
<tr>
<td>--------------------------------------</td>
</tr>
<tr>
<td>32 61 63</td>
</tr>
<tr>
<td>Entry Descriptor (Part 1)</td>
</tr>
<tr>
<td>--------------------------------------</td>
</tr>
<tr>
<td>64 95</td>
</tr>
<tr>
<td>Entry Descriptor (Part 2)</td>
</tr>
<tr>
<td>--------------------------------------</td>
</tr>
<tr>
<td>96 127</td>
</tr>
</tbody>
</table>

The fields in the first eight bytes of the header entry are allocated as follows:

Backward Stack-Entry Validity Bit (B): Bit 63 when one, specifies that the preceding linkage-stack section is available and that the backward stack-entry address, bits 0-60 is valid. Bit 63 is set to one during the stacking process when the process proceeds to this section from the preceding one because there is not enough space available in the preceding section to perform the process. During the unstacking process when this header entry is the current linkage-stack entry, a stack-empty exception is recognized if bit 63 is zero.

Backward Stack-Entry Address (BSEA): When bit 63 is one, bits 0-60 with three zeros appended on the right, form the 64-bit home virtual address of the entry descriptor of the last linkage-stack entry, other than the trailer entry, in the preceding linkage-stack section. However, if the current linkage-stack entry is in the preceding or an earlier linkage-stack section, bits 0-60 may have no meaning because the entry they designate, and earlier entries, may have been logically deleted. Bits 0-60 are set during the stacking process when the process proceeds to this section from the preceding one because there is not enough space available in the preceding section to perform the process. During the unstacking process when this header entry is the current linkage-stack entry and bit 63 is one, the entry designated by bits 0-60 is treated as the current entry.

Bits 61 and 62 are set to zeros when bits 0-60 are set during the stacking process. Bits 61 and 62 are reserved for possible future extensions.
Trailer Entries
A trailer entry is at the end of each linkage-stack section. The trailer entry begins immediately after the area specified by the remaining-free-space field in the entry descriptors of the header entry and each state entry in the same linkage-stack section. The trailer entry is 16 bytes in length and has the following format:

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Contents</th>
<th>Bytes</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Contents of General Registers 0 - 15</td>
<td>128</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>:</td>
<td></td>
</tr>
<tr>
<td>70</td>
<td>112</td>
<td></td>
<td></td>
</tr>
<tr>
<td>78</td>
<td>120</td>
<td></td>
<td></td>
</tr>
<tr>
<td>80</td>
<td>128</td>
<td>Other Status Information</td>
<td>96</td>
</tr>
<tr>
<td>88</td>
<td>136</td>
<td>:</td>
<td></td>
</tr>
<tr>
<td>D0</td>
<td>208</td>
<td></td>
<td></td>
</tr>
<tr>
<td>D8</td>
<td>216</td>
<td></td>
<td></td>
</tr>
<tr>
<td>E0</td>
<td>224</td>
<td></td>
<td></td>
</tr>
<tr>
<td>E8</td>
<td>232</td>
<td></td>
<td></td>
</tr>
<tr>
<td>110</td>
<td>272</td>
<td>Contents of Access Registers 0 - 15</td>
<td>64</td>
</tr>
<tr>
<td>118</td>
<td>280</td>
<td></td>
<td></td>
</tr>
<tr>
<td>120</td>
<td>288</td>
<td>Entry Descriptor</td>
<td>8</td>
</tr>
</tbody>
</table>

Bytes 0-127 of the state entry contain the contents of general registers 0-15 in the ascending order of the register numbers. Bytes 224-287 contain the contents of access registers 0-15 in the ascending order of the register numbers. The contents of these fields are moved from the registers to the state entry during the BRANCH AND STACK and stacking PROGRAM CALL operations. The contents of general registers 2-14 and access registers 2-14 are restored from the state entry to the registers during the PROGRAM RETURN operation. The contents of a specified range of general registers and access registers can be restored from the state entry to the registers by EXTRACT STACKED REGISTERS.

Bytes 128-223 of the state entry contain the other status information that is placed in the entry by BRANCH AND STACK, stacking PROGRAM CALL, and MODIFY STACKED STATE. A portion of this status information is restored to the PSW and control registers by PROGRAM RETURN, and all of the information can be examined by means of EXTRACT STACKED STATE. Bytes 288-295 contain the entry descriptor. EXTRACT STACKED STATE sets the condition code to indicate whether the entry-type code in the entry descriptor specifies a branch state entry or a program-call state entry.

Forward-Section Validity Bit (F): Bit 63 when one, specifies that the next linkage-stack section is available and that the forward-section-header address, bits is valid. During the stacking process when there is not enough space available in the current linkage-stack section to perform the process, a stack-full exception is recognized if bit 63 in the trailer entry of the current section is zero.

Forward-Section-Header Address (FSHA): When bit 63 is one, bits 0-60, with three zeros appended on the right, form the 64-bit home virtual address of the entry descriptor of the header entry in the next linkage-stack section. During the stacking process when there is not enough space available in the current section to perform the process and bit 63 is one, the header entry designated by bits 0-60 becomes the current linkage-stack entry.

Bits 61 and 62 are reserved for possible future extensions.

Programming Note: All of the fields in the trailer entry are set only by the control program.

State Entries
Zero, one, or more state entries may follow the header entry in each linkage-stack section. A state entry may be a branch state entry, formed by a BRANCH AND STACK instruction, or a program-call state entry, formed by a stacking PROGRAM CALL instruction. The state entry is 296 bytes in length and has the following format:
Bytes 128-223 of the state entry have the following detailed format:

<table>
<thead>
<tr>
<th>PKM</th>
<th>SASN</th>
<th>EAX</th>
<th>PASN</th>
</tr>
</thead>
<tbody>
<tr>
<td>128</td>
<td>130</td>
<td>132</td>
<td>134</td>
</tr>
<tr>
<td>136</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

- **PSW-**Key Mask (PKM): Bytes 128-129 contain the PSW-key mask, bits 32-47 of control register 3, of the calling program. The PSW-key mask is saved in the state entry by BRANCH AND STACK or stacking PROGRAM CALL, and it is restored to the control register by a PROGRAM RETURN instruction that unstacks an entry formed by stacking PROGRAM CALL.

- **Secondary ASN (SASN):** Bytes 130-131 contain the secondary ASN, bits 48-63 of control register 3, of the calling program. The ASN is saved in the state entry by BRANCH AND STACK or stacking PROGRAM CALL, and it is restored to the control register by a PROGRAM RETURN instruction that unstacks an entry formed by stacking PROGRAM CALL.

- **Extended Authorization Index (EAX):** Bytes 132-133 contain the extended authorization index, bits 32-47 of control register 8, of the calling program. The EAX is saved in the state entry by BRANCH AND STACK or stacking PROGRAM CALL, and it is restored to the control register by a PROGRAM RETURN instruction that unstacks an entry formed by stacking PROGRAM CALL.

- **Primary ASN (PASN):** Bytes 134-135 contain the primary ASN, bits 48-63 of control register 4, of the calling program. The PASN is saved in the state entry by BRANCH AND STACK or stacking PROGRAM CALL, and it is restored to the control register by a PROGRAM RETURN instruction that unstacks an entry formed by stacking PROGRAM CALL.

- **Program-Status Word (PSW):** In a branch state entry formed by a BRANCH AND STACK instruction in which the R1 field is zero, and in a program-call state entry, bytes 136-143 and 168-175 contain the updated PSW of the calling program. Bytes 136-143 contain bits 0-63 of the PSW, and bytes 168-175 contain bits 64-127 of the PSW. Thus, the basic and extended addressing-mode bits in this PSW specify the addressing mode of the calling program, and the instruction address designates the next sequential instruction following the BRANCH AND STACK or stacking PROGRAM CALL instruction that formed the state entry, or following an execute-type instruction that had the BRANCH AND STACK or stacking PROGRAM CALL instruction as its target instruction. In a branch state entry formed by a BRANCH AND STACK instruction in which the R1 field is nonzero, bytes 136-143 and 168-175 contain the PSW of the calling program, except that the extended-address-
ing-mode bit in bit position 31 of bytes 136-139, the basic-addressing-mode bit in bit position 0 of byte 140, and the instruction address in bytes 168-175 are as specified by the contents of the general register designated by the \( R_1 \) field. See the definition of BRANCH AND STACK in Chapter 10, “Control Instructions” for how the basic- and extended-addressing-mode bits and instruction address are specified. The value of the PER mask in bytes 136-143 is always unpredictable. The PSW is saved in the state entry by BRANCH AND STACK or stacking PROGRAM CALL and is restored as the current PSW by PROGRAM RETURN, except that the PER mask is not restored. PROGRAM RETURN does not change the PER mask in the current PSW.

**Basic Addressing Mode (A):** In a branch state entry made in the 24-bit or 31-bit addressing mode, bit position 0 of bytes 148-151 contains the basic-addressing-mode bit, bit 32 of the PSW, at the end of the execution of the BRANCH AND STACK instruction that formed the state entry. The basic-addressing-mode bit is saved in bit position 0 of bytes 148-151 by BRANCH AND STACK. BRANCH AND STACK does not change the basic-addressing-mode bit in the PSW.

**Branch Address:** In a branch state entry made in the 24-bit or 31-bit addressing mode, bit positions 1-31 of bytes 148-151 contain the instruction address in the PSW at the end of the execution of the BRANCH AND STACK instruction that formed the state entry. The basic-addressing-mode bit is saved in bit position 0 of bytes 148-151 by BRANCH AND STACK. BRANCH AND STACK does not change the basic-addressing-mode bit in the PSW.

**Called-Space Identification:** In a program-call state entry, bytes 144-147 contain the called-space identification (CSI). The CSI is saved in the state entry by stacking PROGRAM CALL.

If the PROGRAM CALL operation was space switching, bytes 0 and 1 of the CSI (bytes 144 and 145 of the state entry) contain the new primary ASN that was placed in control register 4 by the PROGRAM CALL instruction. When the ASN-and-LX-reuse facility is not enabled, bytes 2 and 3 of the CSI (bytes 146 and 147 of the state entry) contain the rightmost two bytes of the ASTE sequence number (ASTE SN) in the new primary ASTE whose address was placed in control register 5 by the PROGRAM CALL instruction. When the ASN-and-LX-reuse facility is installed and enabled, bytes 2 and 3 of the CSI (bytes 146 and 147 of the state entry) contain the rightmost two bytes of the ASTE instance number (ASTE IN) in the new primary ASTE whose address was placed in control register 5 by the PROGRAM CALL instruction.

If the PROGRAM CALL operation was the to-current-primary operation, the CSI is all zeros.

**Numeric Part of PC Number:** In a program-call state entry, bit positions 1-31 of bytes 148-151 contain the numeric part of the PC number used by the stacking PROGRAM CALL instruction that formed the entry. When ASN-and-LX reuse is not enabled, or when it is and bit 44 of the effective address used by stacking PROGRAM CALL is zero, stacking PROGRAM CALL places bits 44-63 of the effective address, with 11 zeros appended on the left, in bit positions 1-31 of bytes 148-151. When ASN-and-LX reuse is enabled and bit 44 of the effective address is one, stacking PROGRAM CALL places bits 45-63 of the effective address, with bits 32-43 of the effective address appended on the left, in bit positions 1-31 of bytes 148-151. In any case, stacking PROGRAM CALL places a zero in bit position 0 of the bytes if the resulting addressing mode is the 24-bit or 31-bit mode or a one in bit position 0 if the resulting addressing mode is the 64-bit mode.

**Modifiable Area:** Bytes 152-159 are the field that is set by MODIFY STACKED STATE. BRANCH AND STACK and stacking PROGRAM CALL place all zeros in bytes 152-159.

**Secondary ASTEIN (SASTEIN):** If the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control in control register 0, bytes 176-179 contain the secondary ASTEIN, bits 0-31 of control register 3, of the calling
program. The SASTEIN is saved in the state entry by BRANCH AND STACK or stacking PROGRAM CALL. When PROGRAM RETURN unstacks a program-call state entry, it compares the SASTEIN in the state entry to the ASTEIN in the ASN-second-table entry if SASN translation occurs, and it always restores the SASTEIN to control register 3.

**Primary ASTEIN (PASTEIN):** If the ASN-and-LX-reuse facility is installed and is enabled by the ASN-and-LX-reuse control in control register 0, bytes 180-183 contain the primary ASTEIN, bits 0-31 of control register 4, of the calling program. The PASTEIN is saved in the state entry by BRANCH AND STACK or stacking PROGRAM CALL. When PROGRAM RETURN unstacks a program-call state entry, it compares the PASTEIN in the state entry to the ASTEIN in the ASN-second-table entry if PASN translation occurs, and it always restores the PASTEIN to control register 4.

All zeros are placed in bytes 160-167 by BRANCH AND STACK and stacking PROGRAM CALL.

The contents of bytes 184-223 are unpredictable.

**Stacking Process**

The stacking process is performed as part of a BRANCH AND STACK or stacking PROGRAM CALL operation. The process locates space for a new linkage-stack state entry, forms the entry, updates the next-entry-size field in the preceding entry, and updates the linkage-stack-entry address in control register 15 so that the new entry becomes the current linkage-stack entry.

For the stacking process to be performed successfully, DAT must be on and the CPU must be in the primary-space mode or access-register mode; otherwise, a special-operation exception is recognized, and the operation is suppressed.

Except as just mentioned, the stacking process is performed independent of the current addressing mode and translation mode, as specified by bits 31, 32, 16, and 17 of the current PSW. All addresses used during the stacking process are always 64-bit home virtual addresses.

During the stacking process when any address is formed through the addition or subtraction of a value to or from another address, a carry out of, or a borrow into, bit position 0 of the address, if any, is ignored.

When the stacking process fetches or stores by using an address that designates, after translation, a location that is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

Key-controlled protection does not apply to the accesses made during the stacking process, but DAT protection and low-address protection do apply. A protection exception causes the operation to be suppressed.

**Locating Space for a New Entry**

The linkage-stack-entry address in control register 15 is used to locate the current linkage-stack entry. Bits 0-60 of control register 15, with three zeros appended on the right, form the 64-bit home virtual address of the leftmost byte of the entry descriptor of the current linkage-stack entry.

The first word of the entry descriptor of the current linkage-stack entry is fetched by using the 64-bit home virtual address. This fetch is for the purpose of obtaining the section-identification and remaining-free-space fields in the word; the unstack-suppression bit and entry-type field in the word are not examined.

The 16-bit unsigned binary value in the remaining-free-space field, bits 16-31 of the entry descriptor, is compared against the size in bytes of the linkage-stack entry to be formed. The size of a state entry is 296 bytes. If the value in the field is equal to or greater than the size of the entry to be formed, processing continues as described in “Forming the New Entry” on page 5-86; otherwise, processing continues as described below.

When the remaining-free-space field in the current linkage-stack entry indicates that there is not enough space available in the current linkage-stack section to form the new entry, the first doubleword of the trailer entry of the current section is fetched. The address for fetching this doubleword is determined as follows: to the address formed from the contents of control register 15, add 8 to address the first byte after the entry descriptor of the current entry, and then add the contents of the remaining-free-space field of the current entry to address the first byte of the trailer entry. The remaining-free-space value used in the addition
must be a multiple of 8; otherwise, a stack-specifica-
tion exception is recognized, and the operation is nul-
lified.

If the forward-section-validity bit, bit 63 of the trailer
entry is zero, a stack-full exception is recognized, and
the operation is nullified; otherwise, the forward-
section-header address in the trailer entry is used to
locate the header entry in the next linkage-stack sec-
tion. Bits 0-60 of the trailer entry, with three zeros
appended on the right, form the 64-bit home virtual
address of the leftmost byte of the entry descriptor of
the header entry in the next section.

The first word of the entry descriptor of the header
entry in the next linkage-stack section is fetched. This
fetch is for the purpose of obtaining the section-iden-
tification and remaining-free-space fields in the word;
the unstack-suppression bit and entry-type field in
the word are not examined.

The value in the remaining-free-space field of the
header entry in the next linkage-stack section is com-
pared against the size in bytes of the entry to be
formed. If the value in the field is equal to or greater
than the size of the entry to be formed, the following
occurs:

- The linkage-stack-entry address, bits 0-60 of
  control register 15, is placed, as the back-
  ward stack-entry address, in bit positions
  0-60 of the header entry in the next linkage-
  stack section, and zeros are placed in bit
  positions 61 and 62.

- The backward stack-entry validity bit, bit 63,
  in the header entry in the next section is set
to one.

- Bits 0-60 of the 64-bit home virtual address
  of the entry descriptor of the header entry in
  the next section are placed in bit positions
  0-60 of control register 15, and zeros are
  placed in bit positions 61-63 of control regis-
  ter 15. Thus, the header entry in the next
  section becomes the current linkage-stack
  entry, and the next section becomes the cur-
  rent linkage-stack section.

- Processing continues as described in “Form-
ing the New Entry”.

If the value in the remaining-free-space field of the
header entry in the next section (before the next sec-
tion becomes the current section) is less than the

Forming the New Entry
When the remaining-free-space field in the current
linkage-stack entry indicates that there is enough
space available in the current linkage-stack section to
form the new entry, the new entry is formed begin-
ing immediately after the entry descriptor of the cur-
rent entry.

The new entry is a state entry. The contents of gen-
eral registers 0-15 are stored in bytes 0-127 of the
new entry, in the ascending order of the register num-
bers. The contents of access registers 0-15 are
stored in bytes 224-287 of the new entry, in the
ascending order of the register numbers. The PSW-
key mask, bits 32-47 of control register 3; secondary
ASN, bits 48-63 of control register 3; extended autho-
rization index, bits 32-47 of control register 8; and pri-
mary ASN, bits 48-63 of control register 4, are stored
in bytes 128-129, 130-131, 132-133, and 134-135,
respectively, of the new entry. The current PSW, in
which the instruction address has been updated, is
stored in bytes 136-143 and 168-175 of the new
entry. Bytes 136-143 contain bits 0-63 of the PSW,
and bytes 168-175 contain bits 64-127 of the PSW.
However, the value of the PER mask, bit 1 in the
PSW stored, is unpredictable. Also, if the instruction
being executed is a BRANCH AND STACK instruc-
tion in which the R1 field is nonzero, the extended-
and basic-addressing-mode bits stored in bytes 139
and 140, respectively, of the new entry, and the
instruction address stored in bytes 168-175 of the
new entry, are as specified by the contents of the
general register designated by the R1 field.

If the ASN-and-LX-reuse facility is installed and is
enabled by a one value of the ASN-and-LX-reuse
control, bit 44 of control register 0, the secondary
ASTEIN, bits 0-31 of control register 3, and the pri-
mary ASTEIN, bits 0-31 of control register 4, are
stored in bytes 176-179 and 180-183, respectively, of
the new entry.

When the instruction is PROGRAM CALL, the called-
space identification is stored in bytes 144-147 of the
new entry. When the instruction is performing the
space-switching PROGRAM CALL operation and the
ASN-and-LX-reuse facility is not enabled, the called-
space identification is the two-byte ASN, bytes 10
and 11 in the entry-table entry used by the instruc-
tion, followed by bytes 2 and 3 of the ASTE sequence number, bytes 2 and 3 being bits 176-191, in the ASN-second-table entry specified by the ASN. When the instruction is performing the space-switching PROGRAM CALL operation and the ASN-and-LX-reuse facility is installed and enabled, the called-space identification is the two-byte ASN, bytes 10 and 11 in the entry-table entry used by the instruction, followed by bytes 2 and 3 of the ASTE instance number, bytes 2 and 3 being bits 368-383, in the ASN-second-table entry specified by the ASN. When the instruction is performing the to-current-primary PROGRAM CALL operation, the called-space identification is all zeros.

When the instruction is BRANCH AND STACK in the 24-bit or 31-bit addressing mode, the basic-addressing-mode bit from the current PSW is stored in bit position 0 of byte 148 in the state entry, bits 33-63 of the branch address, or of the updated instruction address if the operation is performed without branching, are stored in bit positions 1-31 of bytes 148-151, and the contents of bytes 144-147 are unpredictable. In the 64-bit addressing mode, bits 0-62 of the branch address or updated instruction address, with a one appended on the right, are stored in bytes 144-151 of the state entry.

When the instruction is PROGRAM CALL, the numeric part of the PC number used, with 11 zeros appended on the left if the number is 20 bits, is stored in bit positions 1-31 of bytes 148-151. If the resulting addressing mode after the execution of PROGRAM CALL is the 24-bit or 31-bit addressing mode, a zero is stored in bit position 0 of byte 148. If the resulting addressing mode is the 64-bit addressing mode, a one instead of a zero is stored in bit position 0 of byte 148.

Zeros are stored in bytes 152-167 of the new entry. The contents of bytes 176-223 are unpredictable, or the contents of bytes 184-223 are unpredictable if the secondary ASTEIN and primary ASTEIN were stored.

Bytes 288-295 of the new entry are its entry descriptor. The unstack-suppression bit, bit 0, of this entry descriptor is set to zero. The code 0001100 binary is stored in the entry-type field, bits 1-7, of this entry descriptor if the instruction being executed is BRANCH AND STACK. The code 0001101 binary is stored if the instruction is PROGRAM CALL. The value in the section-identification field of the current linkage-stack entry is stored in the section-identification field, bits 8-15, of this entry descriptor. The value in the remaining-free-space field of the current entry, minus the size in bytes of the new entry, is stored in the remaining-free-space field of this entry descriptor. Zeros are stored in the next-entry-size field, bits 32-47, and in bit positions 48-63 of this entry descriptor.

The stores into the new entry appear to be word concurrent as observed by other CPUs. The order in which the stores occur is unpredictable.

**Updating the Current Entry**

The size in bytes of the new linkage-stack entry is stored in the next-entry-size field of the current entry. The remainder of the current entry remains unchanged.

The order of the stores into the current entry and the new entry is unpredictable.

**Updating Control Register 15**

Bits 0-60 of the 64-bit home virtual address of the entry descriptor of the new linkage-stack entry are placed in bit positions 0-60 of control register 15, the linkage-stack-entry address. Zeros are placed in bit positions 61-63 of control register 15. Thus, the new entry becomes the current linkage-stack-entry.

**Recognition of Exceptions during the Stacking Process**

The exceptions which can be encountered during the stacking process and their priority are described in the definitions of the BRANCH AND STACK and PROGRAM CALL instructions.

**Programming Note:** Any exception recognized during the execution of BRANCH AND STACK and PROGRAM CALL causes either nullification or suppression. Therefore, if an exception is recognized, the stacking process does not store into any linkage-stack entry or change the contents of control register 15.

**Unstacking Process**

The unstacking process is performed as part of the PROGRAM RETURN operation. The process locates the last state entry in the linkage stack, restores a portion of the information in the entry to the CPU registers, updates the next-entry-size field in the preceding entry, and updates the linkage-stack-entry...
address in control register 15 so that the preceding entry becomes the current linkage-stack entry. The part of the unstacking process that locates the last state entry is also performed as part of the EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, and MODIFY STACKED-state operations.

For the unstacking process to be performed successfully, DAT must be on and the CPU must be in the primary-space mode or access-register mode; otherwise, a special-operation exception is recognized, and the operation is suppressed. However, when the unstacking process is performed as part of EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, or MODIFY STACKED STATE, the CPU may be in the primary-space, access-register, or home-space mode.

Except as just mentioned, the unstacking process is performed independent of the current addressing mode and translation mode, as specified by bits 31, 32, 16, and 17 of the current PSW. All addresses used during the unstacking process are always 64-bit home virtual addresses.

During the unstacking process when any address is formed through the addition or subtraction of a value to or from another address, a carry out of, or a borrow into, bit position 0 of the address, if any, is ignored.

When the unstacking process fetches or stores by using an address that designates, after translation, a location that is not available in the configuration, an addressing exception is recognized, and the operation is suppressed.

Key-controlled protection does not apply to the accesses made during the unstacking process, but DAT protection and low-address protection do apply. A protection exception causes the operation to be suppressed.

**Locating the Current Entry and Processing a Header Entry**

The linkage-stack-entry address in control register 15 is used to locate the current linkage-stack entry. Bits 0-60 of control register 15, with three zeros appended on the right, form the 64-bit home virtual address of the leftmost byte of the entry descriptor of the current linkage-stack entry.

The first word of the entry descriptor of the current linkage-stack entry is fetched by using the 64-bit home virtual address. If the entry-type code in bits 1-7 of the entry descriptor is not 0001001 binary, indicating that the entry is not a header entry, processing continues as described in “Checking for a State Entry”; otherwise, processing continues as described below.

When the entry-type code in the current linkage-stack entry is 0001001 binary, indicating a header entry, the next processing depends on which instruction is being executed. When the unstacking process is performed as part of the PROGRAM RETURN operation and the unstack-suppression bit, bit 0, in the entry descriptor of the current entry is one, a stack-operation exception is recognized, and the operation is nullified. When the unstacking process is performed as part of EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, or MODIFY STACKED STATE, the unstack-suppression bit is ignored.

When there is not an exception due to the unstack-suppression bit, the first doubleword of the current linkage-stack entry (a header entry) is fetched. The address of this doubleword is determined by subtracting 8 from the address of the entry descriptor of the current entry.

If the backward stack-entry validity bit, bit 63, of the current entry is zero, a stack-empty exception is recognized, and the operation is nullified; otherwise, the backward stack-entry address in the current entry is used to locate a linkage-stack entry referred to here as the designated entry. Bits 0-60 of the current entry, with three zeros appended on the right, form the 64-bit home virtual address of the leftmost byte of the entry descriptor of the designated entry.

It is assumed in this definition of the unstacking process that the designated linkage-stack entry is the last entry, other than the trailer entry, in the preceding linkage-stack section. This assumption does not imply any processing that is not explicitly described.

The first word of the entry descriptor of the designated entry is fetched. If the entry-type code in this entry descriptor is not 0001001 binary, indicating that the entry is not a header entry, the following occurs:

- When the unstacking process is performed as part of the PROGRAM RETURN operation, bits 0-60 of the 64-bit home virtual address of the
entry descriptor of the designated entry are placed in bit positions 0-60 of control register 15, and zeros are placed in bit positions 61-63 of control register 15. Thus, the designated entry becomes the current linkage-stack entry, and the preceding section (based on the assumption) becomes the current linkage-stack section. When the unstacking process is performed as part of EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, or MODIFY STACKED STATE, the contents of control register 15 remain unchanged, but the designated entry is temporarily, during the remainder of the definition of the instruction, referred to as the current linkage-stack entry.

- Processing continues as described in “Checking for a State Entry”.

If the entry-type code in the designated entry is 0001001 binary, indicating a header entry, a stack-specification exception is recognized, and the operation is nullified.

**Checking for a State Entry**

When the entry-type code in the current linkage-stack entry indicates that the entry is not a header entry, the code is checked for being 0001100 or 0001101 binary, which are the codes assigned to a state entry.

If the current linkage-stack entry is a state entry, the next processing depends on which instruction is being executed. When the unstacking process is performed as part of the PROGRAM RETURN operation, processing continues as described in “Restoring Information” on page 5-89. When the process is performed as part of EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, or MODIFY STACKED STATE, the process is completed; that is, no additional processing occurs as a part of the unstacking process.

If the current linkage-stack entry is not a state entry (and necessarily not a header entry either), a stack-type exception is recognized, and the operation is nullified.

**Restoring Information**

The remaining parts of the unstacking process occur only in the PROGRAM RETURN operation. The current linkage-stack entry is a state entry. If the unstack-suppression bit in the entry is one, a stack-operation exception is recognized, and the operation is nullified.

When there is not an exception due to the unstack-suppression bit, a portion of the contents of the current linkage-stack entry are restored to the CPU registers. The contents of general registers 2-14 and access registers 2-14 are restored to those registers from where they were saved in the current entry by the stacking process. When the entry-type code in the current entry is 0001101 binary, indicating a program-call state entry, the PSW-key mask and secondary ASN in control register 3, extended authorization index in control register 8, and primary ASN in control register 4 are similarly restored. During this restoration, the authorization index in control register 4 and the monitor masks and enhanced-monitor masks in control register 8 remain unchanged. (The authorization index may be changed by the part of the PROGRAM RETURN execution that occurs after the unstacking process.)

When the state entry is a program-call state entry, and if the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control in control register 0, the secondary ASTEIN in control register 3 and the primary ASTEIN in control register 4 are restored from where they were saved in the state entry. However, the primary ASTEIN and secondary ASTEIN may be subject to certain tests, as described in the PROGRAM RETURN definition.

When the entry-type code is 0001100 binary, indicating a branch state entry, the PSW-key mask, secondary ASN, extended authorization index, primary ASN, secondary ASTEIN, and primary ASTEIN in the current entry are ignored, and all contents of the control registers remain unchanged.

When the current entry is either a branch state entry or a program-call state entry, bits 0-63 and 64-127 of the current PSW are restored from bytes 136-143 and bytes 168-175, respectively, of the entry, except that the PER mask is not restored. The PER mask in the current PSW remains unchanged. Bytes 144-159 and bytes 160-167 of the current entry are ignored.

The fetches from the current entry appear to be word concurrent as observed by other CPUs. The order in which the fetches occur is unpredictable.
Updating the Preceding Entry
Zeros are stored in the next-entry-size field, bits 32-47, of the entry descriptor of the preceding linkage-stack entry. The remainder of the preceding entry remains unchanged. The address of the entry descriptor of the preceding entry is determined by subtracting the size in bytes of the current entry from the address of the entry descriptor of the current entry.

The order of the store into the preceding entry and the fetches from the current entry is unpredictable.

Updating Control Register 15
Bits 0-60 of the 64-bit home virtual address of the entry descriptor of the preceding linkage-stack entry are placed in bit positions 0-60 of control register 15, the linkage-stack-entry address. Zeros are placed in bit positions 61-63 of control register 15. Thus, the preceding entry becomes the current linkage-stack entry.

Recognition of Exceptions during the Unstacking Process
The exceptions which can be encountered during the unstacking process and their priority are described in the definition of the PROGRAM RETURN instruction. The exceptions which apply to EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, and MODIFY STACKED STATE are described in the definitions of those instructions.

Programming Notes:

1. Any exceptions recognized during the execution of EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, MODIFY STACKED STATE, or PROGRAM RETURN cause either nullification or suppression. Therefore, if an exception is recognized, the unstacking process does not change the contents of any CPU register (except for updating the instruction address in the PSW in the case of suppression) or store into any linkage-stack entry.

2. The unstacking process in PROGRAM RETURN does not restore the PER mask in the PSW so that an act of turning PER on or off after the execution of the related BRANCH AND STACK or PROGRAM CALL instruction but before the execution of the PROGRAM RETURN instruction will not be counteracted. When PROGRAM CALL or PROGRAM RETURN is space switch-

Transitional-Execution Facility

This section describes the registers, instructions, controls, and operation of the transactional-execution facility. The transactional-execution facility provides the means by which a program can issue multiple instructions, the storage-operand accesses of which appear to occur as a single concurrent operation as observed by other CPUs and by the channel subsystem.

Three special-purpose controls (the transaction-abort PSW, the transaction diagnostic-block address, and the transaction nesting depth), five control register bits, and six general instructions are used to control the transactional-execution facility. When the facility is installed, it is installed in all CPUs in the configuration. Facility indication 73, when one, indicates that the transactional-execution facility is installed.

When the transactional-execution facility is installed, the configuration may also provide the constrained transactional-execution facility. See “Constrained Transaction” (below) for details on constrained transactions. When facility indications 50 and 73 are both one, the constrained transactional-execution facility is installed.

Note: In the following discussion of the transactional-execution facility, the instruction name TRANSACTION BEGIN refers to the instructions having the mnemonics TBEGIN and TBEGINC. Discussions pertaining to a specific instruction are indicated by the instruction name followed by the mnemonic in parentheses or brackets, or simply by the mnemonic.

Transaction-Execution Terminology

The following terms are used pervasively in the description of the transactional-execution facility.

Note: Of necessity, some of these terms are cross-referential. They appear in alphabetical order only for convenience.

Abort: A transaction is said to abort when it is ended prior to a TRANSACTION END instruction.
that results in a transaction nesting depth of zero. When a transaction aborts, the following occurs:

- Transactional store accesses made by any and all levels of the transaction are discarded (that is, not committed).
- Nontransactional store accesses made by any and all levels of the transaction are committed.
- Registers designated by the general-register-save mask of the outermost TRANSACTION BEGIN instruction are restored to their contents prior to transactional execution (that is, to their contents at execution of the outermost TRANSACTION BEGIN instruction). General registers not designated by the general-register-save mask of the outermost TRANSACTION BEGIN instruction are not restored.
- Access registers, vector registers, floating-point registers, and the floating-point control register are not restored. Any changes made to these registers during transactional execution are retained when the transaction aborts.

A transaction may be aborted due to a variety of reasons, including attempted execution of a restricted instruction, attempted modification of a restricted resource, transactional conflict, exceeding various CPU resources, any interruption, a TRANSACTION ABORT instruction, and other reasons. “Transaction Abort Code (TAC)” on page 5-96 provides specific reasons why a transaction may be aborted.

**Commit:** At the completion of the outermost TRANSACTION END instruction, the CPU is said to commit the store accesses made by the transaction such that they are visible to other CPUs and the channel subsystem. As observed by other CPUs and by the channel subsystem, all fetch and store accesses made by all nested levels of the transaction appear to occur as a single concurrent operation when the commit occurs.

The contents of the general registers, access registers, vector registers, floating-point registers, and the floating-point control register are not modified by the commit process. Any changes made to these registers during transactional execution are retained when the transaction's stores are committed.

**Conflict:** A transactional access made by one CPU is said to conflict with either (a) a transactional access or nontransactional access made by another CPU, or (b) a nontransactional access made by the channel subsystem, if both accesses are to any location within the same cache line, and one or both of the accesses is a store.

A conflict may be detected by a CPU’s speculative execution of instructions, even though the conflict may not be detected in the conceptual sequence.

**Programming Note:** Because of speculative execution by the CPU, a conflict may be detected at a storage location that would not necessarily be accessed by the conceptual execution sequence.

**Constrained Transaction:** A constrained transaction is a transaction that executes in the constrained transactional-execution mode (see below) and is subject to the following limitations:

- A subset of the general instructions are available.
- A limited number of instructions may be executed.
- A limited number of storage-operand locations may be accessed.
- The transaction is limited to a single nesting level.

In the absence of repeated interruptions or conflicts with other CPUs or the channel subsystem, a constrained transaction will eventually complete, thus an abort-handler routine is not required. Constrained transactions are described in detail in “Constrained Transaction” on page 5-108.

**Programming Note:** When the TBEGINC instruction is executed while the CPU is already in the nonconstrained transactional-execution mode, execution continues as a nested nonconstrained transaction.

**Constrained Transactional-Execution Mode:** When the transaction nesting depth is zero, and a transaction is initiated by the TRANSACTION BEGIN (TBEGINC) instruction, the CPU enters the constrained transactional-execution mode. While the CPU is in the constrained transactional-execution mode, the transaction nesting depth is always one.

**Nested Transaction:** When the TRANSACTION BEGIN instruction is issued while the CPU is in the nonconstrained transactional-execution mode, the transaction is said to be nested. See “Transaction Nesting Depth (TND)” on page 5-94 below.
The transactional-execution facility uses a model called flattened nesting. In the flattened-nesting model, stores made by an inner transaction are not observable by other CPUs and by the channel subsystem until the outermost transaction commits its stores. Similarly, if a transaction aborts, all nested transactions abort, and all transactional stores of all nested transactions are discarded.

**Nonconstrained Transaction:** A nonconstrained transaction is a transaction that executes in the nonconstrained transactional-execution mode (see below). Although a nonconstrained transaction is not limited in the manner described in “Constrained Transaction” on page 5-108, it may still be aborted due to a variety of causes as described in “Abort” on page 5-90.

**Nonconstrained Transactional-Execution Mode:** When a transaction is initiated by the TRANSACTION BEGIN (TBEGIN) instruction, the CPU enters the nonconstrained transactional-execution mode. While the CPU is in the nonconstrained transactional-execution mode, the transaction nesting depth may vary from one to the maximum transaction nesting depth.

**Nontransactional Access:** Nontransactional accesses are storage operand accesses made by the CPU when it is not in the transactional-execution mode (that is, classic storage accesses outside of a transaction). Additionally, the NONTRANSACTIONAL STORE instruction may be used to cause a nontransactional store access while the CPU is in the nonconstrained transactional-execution mode.

Accesses made by the channel subsystem are nontransactional accesses.

**Outer / Outermost Transaction:** A transaction with a lower-numbered transaction nesting depth is said to be an outer transaction. A transaction with a transaction-nesting-depth value of one is said to be the outermost transaction.

An outermost TRANSACTION BEGIN instruction is one that is executed when the transaction nesting depth is initially zero. An outermost TRANSACTION END instruction is one that causes the transaction nesting depth to transition from one to zero. A constrained transaction is always the outermost transaction.

**Program-Interruption Filtering:** When a transaction is aborted due to certain program-interruption conditions, the program can optionally prevent the interruption from occurring. This technique is called program-interruption filtering. Program-interruption filtering is subject to the transactional class of the interruption, the effective program-interruption-filtering control from the TRANSACTION BEGIN instruction, and the transactional-execution program-interruption-filtering override in control register 0.

**Transaction:** A transaction comprises the storage-operand accesses made, and selected general registers altered, while the CPU is in the transactional-execution mode. For a nonconstrained transaction, storage-operand accesses may include both transactional accesses and nontransactional accesses. For a constrained transaction, storage-operand accesses are limited to transactional accesses. As observed by other CPUs and by the channel subsystem, all storage-operand accesses made by the CPU while in the transactional-execution mode appear to occur as a single concurrent operation. If a transaction is aborted, transactional store accesses are discarded, and any registers designated by the general-register-save mask of the outermost TRANSACTION BEGIN instruction are restored to their contents prior to transactional execution.

**Transactional Accesses:** Transactional accesses are storage operand accesses made while the CPU is in the transactional-execution mode, with the exception of accesses made by the NONTRANSACTIONAL STORE instruction.

**Transactional-Execution Mode:** The term transactional-execution mode describes the common operation of both the nonconstrained and the constrained transactional-execution modes. Thus, when the transaction nesting depth is nonzero, the CPU is in the transactional-execution mode. Where specific operation is described, the terms nonconstrained and constrained are used to qualify the transactional-execution mode.

When the transaction nesting depth is zero, the CPU is not in the transactional-execution mode (also called the nontransactional-execution mode).
Transactional-Execution Facility Controls

The following section describes the controls that affect the operation of the transactional-execution facility.

Control Register Bits

The transactional-execution facility is controlled by two bits in control register zero and three bits in control register two.

Control Register 0 Bits: The bit assignments are as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>P</td>
<td>Transactional-execution control (TXC): Bit 8 of control register zero is the transactional-execution control. This bit provides a mechanism whereby the control program can indicate whether or not the transactional-execution facility is usable by the program. Bit 8 must be one to successfully enter the transactional-execution mode.</td>
</tr>
<tr>
<td>9</td>
<td>X</td>
<td>Transactional-execution program-interruption-filtering override (PIFO): Bit 9 of control register zero is the transactional-execution program-interruption-filtering override. This bit provides a mechanism by which the control program can ensure that any program-exception condition that occurs while the CPU is in the transactional-execution mode results in an interruption, regardless of the effective program-interruption-filtering control specified or implied by the TRANSACTION BEGIN instruction(s). See “Program-Interruption Filtering on a Transaction Abort” on page 5-104 for details.</td>
</tr>
</tbody>
</table>

Control Register 2 Bits: The bit assignments are as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>61</td>
<td>T</td>
<td>Transaction Diagnostic Scope (TDS): Bit 61 of control register 2 controls the applicability of the transaction diagnostic control (TDC) in bits 62-63 of the register, as follows.</td>
</tr>
<tr>
<td>62</td>
<td>D</td>
<td>0 The TDC applies regardless of whether the CPU is in the problem or supervisor state.</td>
</tr>
<tr>
<td>63</td>
<td>C</td>
<td>1 The TDC applies only when the CPU is in the problem state. When the CPU is in the supervisor state, processing is as if the TDC contained zero.</td>
</tr>
</tbody>
</table>

Transaction Diagnostic Control (TDC): Bits 62-63 of control register 2 are a 2-bit unsigned integer that may be used to cause transactions to be randomly aborted for diagnostic purposes. The encoding of the TDC is as follows:

<table>
<thead>
<tr>
<th>TDC Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Normal operation; transactions are not aborted as a result of the TDC.</td>
</tr>
<tr>
<td>1</td>
<td>Abort every transaction at a random instruction, but before execution of the outermost TRANSACTION END instruction.</td>
</tr>
<tr>
<td>2</td>
<td>Abort random transactions at a random instruction.</td>
</tr>
<tr>
<td>3</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

When a transaction is aborted due to a nonzero TDC, then either of the following may occur:

- The abort code is set to any of codes 7-11, 13-16, or 255, with the value of the code randomly chosen by the CPU; the condition code is set corresponding to the abort code, as indicated in Figure 5-14 on page 5-102.
- For a nonconstrained transaction, the condition code is set to one. In this case, the abort code is not applicable.
It is model dependent whether TDC value 1 is implemented. If not implemented, a value of 1 acts as if 2 was specified.

For a constrained transaction, a TDC value of 1 is treated as if a TDC value of 2 was specified.

If a TDC value of 3 is specified, the results are unpredictable.

**Transaction-Diagnostic-Block Address (TDBA)**

When the B1 field of an outermost TRANSACTION BEGIN (TBEGIN) instruction is nonzero, a valid transaction-diagnostic-block address (TDBA) is set from the first-operand address of the instruction. When the CPU is in the primary-space or access-register mode, the TDBA designates a location in the primary address space. When the CPU is in the secondary-space, or home-space mode, the TDBA designates a location in the secondary or home address space, respectively. When DAT is off, the TDBA designates a location in real storage.

The TDBA is used by the CPU to locate the transaction diagnostic block – called the **TBEGIN-specified TDB** – if the transaction is subsequently aborted. The rightmost three bits of the TDBA are always zero, meaning that the TBEGIN-specified TDB is on a doubleword boundary. The transaction diagnostic block is described in “Transaction Diagnostic Block (TDB)” on page 5-94.

When the B1 field of an outermost TRANSACTION BEGIN (TBEGIN) instruction is zero, the transaction-diagnostic-block address is invalid, and no TBEGIN-specified TDB is stored if the transaction is subsequently aborted.

**Programming Note:** Abort processing may be significantly slower when the TDBA is valid.

**Transaction-Abort PSW (TAPSW)**

During the execution of the TRANSACTION BEGIN (TBEGIN) instruction when the nesting depth is initially zero, the transaction-abort PSW is set to the contents of the current PSW; the instruction address of the transaction-abort PSW designates the next sequential instruction (that is, the instruction following the outermost TBEGIN). During the execution of the TRANSACTION BEGIN (TBEGINC) instruction when the nesting depth is initially zero, the transaction-abort PSW is set to the contents of the current PSW, except that the instruction address of the transaction-abort PSW designates the TBEGINC instruction (rather than the next sequential instruction following the TBEGINC).

When a transaction is aborted, the condition code in the transaction-abort PSW is replaced with a code indicating the severity of the abort condition. Subsequently, if the transaction was aborted due to causes that do not result in an interruption, the PSW is loaded from the transaction-abort PSW; if the transaction was aborted due to causes that result in an interruption, the transaction-abort PSW is stored as the interruption old PSW.

The transaction-abort PSW is not altered during the execution of any inner TRANSACTION BEGIN instruction.

**Transaction Nesting Depth (TND)**

The transaction nesting depth is a 16-bit unsigned value that is incremented each time a TRANSACTION BEGIN instruction is completed with condition code 0 and decremented each time a TRANSACTION END instruction is completed with condition code 0. The transaction nesting depth is reset to zero when a transaction is aborted or by CPU reset.

All models implement a maximum TND of 15.

**Programming Notes:**

1. When the CPU is in the constrained transactional-execution mode, the transaction nesting depth is always one.

2. Although the maximum TND can be represented as a 4-bit value, the TND is defined to be a 16-bit value to facilitate its inspection in the transaction-diagnostic block.

**Transaction Diagnostic Block (TDB)**

When a transaction is aborted, various status information is saved in a transaction diagnostic block (TDB). The CPU places status into one or two TDBs, as follows:

**TBEGIN-Specified TDB:** The 256-byte location specified by a valid transaction-diagnostic-block address. When the transaction-diagnostic-block
address is valid, the TBEGIN-specified TDB is always stored on a transaction abort. When the transaction-diagnostic-block address is not valid, a TBEGIN-specified TDB is not stored.

Access exceptions for the TBEGIN-specified TDB are recognized during the execution of the outermost TRANSACTION BEGIN (TBEGIN) instruction. If an access exception is recognized for the TBEGIN-specified TDB, the CPU does not enter the transactional-execution mode.

The recognition of PER storage-alteration events and zero-address-detection events for the TBEGIN-specified TDB is described in the section “PER Operation” on page 4-26.

**Program- Interruption TDB:** Real locations 6,144-6,399 (1800-18FF hex). The program-interruption TDB is stored when a transaction is aborted due to program interruption. When a transaction is aborted due to other causes, the contents of the program-interruption TDB are unpredictable.

The program-interruption TDB is not subject to any protection mechanism. PER storage-alteration events are not detected for the program-interruption TDB when it is stored during a program interruption.

The transaction diagnostic block has the following format:

<table>
<thead>
<tr>
<th>Field</th>
<th>Value Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>Format Flags</td>
<td>0 The remaining fields of the TDB are unpredictable.</td>
</tr>
<tr>
<td>Transaction Abort Code</td>
<td>1 A format-1 TDB, the remaining fields of which are described below.</td>
</tr>
<tr>
<td>Conflict Token</td>
<td></td>
</tr>
<tr>
<td>Aborted-Transaction Instruction Address</td>
<td></td>
</tr>
<tr>
<td>EAID¹</td>
<td></td>
</tr>
<tr>
<td>DXC/VXC¹</td>
<td></td>
</tr>
<tr>
<td>Translation-Exception Identification¹</td>
<td></td>
</tr>
<tr>
<td>Breaking-Event Address¹</td>
<td></td>
</tr>
<tr>
<td>General Registers</td>
<td></td>
</tr>
</tbody>
</table>

**Figure 5-13. Transaction Diagnostic Block (TDB)**

The fields of the transaction diagnostic block are as follows:

**Format:** Byte 0 contains a validity and format indication, as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The remaining fields of the TDB are unpredictable.</td>
</tr>
<tr>
<td>1</td>
<td>A format-1 TDB, the remaining fields of which are described below.</td>
</tr>
</tbody>
</table>
Programming Note: A TDB in which the format field is zero is referred to as a null TDB.

Flags:
Byte 1 contains various indications, as follows:

Conflict-Token Validity (CTV): When a transaction is aborted due to a fetch or store conflict (that is, abort codes 9 or 10, respectively), bit 0 of byte 1 is the conflict-token-validity indication. When the CTV indication is one, the conflict token in bytes 16-23 of the TDB contain the logical address at which the conflict was detected. When the CTV indication is zero, bytes 16-23 of the TDB are unpredictable.

When a transaction is aborted due to any reason other than a fetch or store conflict, bit 0 of byte 1 is stored as zero.

Constrained-Transaction Indication (CTI): When the CPU was in the constrained transactional-execution mode, bit 1 of byte 1 is set to one. When the CPU was in the nonconstrained transactional-execution mode, bit 1 of byte 1 is set to zero.

Reserved: Bits 2-7 of byte 1 are reserved, and stored as zeros.

Transaction Nesting Depth (TND): Bytes 6-7 contain the transaction nesting depth when the transaction was aborted.

Transaction Abort Code (TAC): Bytes 8-15 contain a 64-bit unsigned transaction abort code. Each code point indicates a reason for a transaction being aborted, as summarized in Figure 5-14 on page 5-102.

It is model dependent whether the transaction abort code is stored in the program-interruption TDB when a transaction is aborted due to conditions other than a program interruption.

Conflict Token: For transactions that are aborted due to fetch or store conflict (that is, abort codes 9 and 10, respectively), bytes 16-23 contain the logical address of the storage location at which the conflict was detected. The conflict token is meaningful only when the CTV bit, bit 0 of byte 1, is one.

When the CTV bit is zero, bytes 16-23 are unpredictable.

Programming Note: Because of speculative execution by the CPU, the conflict token may designate a storage location that would not necessarily be accessed by the transaction’s conceptual execution sequence.

Aborted-Transaction Instruction Address (ATIA): Bytes 24-31 contain an instruction address that identifies the instruction that was executing when an abort was detected. When a transaction is aborted due to abort codes 2, 5, 6, 11, 13, or 256 or higher, or when a transaction is aborted due to abort codes 4 or 12 and the program-exception condition is nullifying, the ATIA points directly to the instruction that was being executed. When a transaction is aborted due to abort codes 4 or 12, and the program-exception condition is not nullifying, the ATIA points past the instruction that was being executed (see the programming note, below).

When a transaction is aborted due to abort codes 7-10, 14-16, or 255, the ATIA does not necessarily indicate the exact instruction causing the abort, but may point to an earlier or later instruction within the transaction.

If a transaction is aborted due to an instruction that is the target of an execute-type instruction, the ATIA identifies the execute-type instruction, either pointing to the instruction or past it, depending on the abort code as described above. The ATIA does not indicate the target of the execute-type instruction.

The ATIA is subject to the addressing mode when the transaction is aborted. In the 24-bit addressing mode, bits 0-40 of the field contain zeros. In the 31-bit addressing mode, bits 0-32 of the field contain zeros.

It is model dependent whether the aborted-transaction instruction address is stored in the program-interruption TDB when a transaction is aborted due to conditions other than a program interruption.

Programming Note: When a transaction is aborted due to abort code 4 or 12, and the program-exception condition is not nullifying, the ATIA does not point to the instruction causing the abort. By subtracting the number of halfwords indicated by the interruption-length code (ILC) from the ATIA, the instruction causing the abort can be identified in conditions that are
suppressing or terminating, or for non-PER events that are completing. When a transaction is aborted due to a PER event, and no other program-exception condition is present, the ATIA is unpredictable.

When the transaction-diagnostic-block address is valid, the ILC may be examined in program-interruption identification (PIID) in bytes 36-39 of the TBEGIN-specified TDB. When filtering does not apply, the ILC may be examined in the PIID at location 140-143 in real storage.

**Exception Access Identification (EAID):** For transactions that are aborted due to certain filtered program-exception conditions, byte 32 of the TBEGIN-specified TDB contains the exception access identification. The format of the EAID, and the cases for which it is stored, are identical to those described in real location 160 when the exception condition results in an interruption. See “Exception Access Identification” on page 3-69 for details.

For transactions that are aborted for other reasons, including any exception conditions that result in a program interruption, byte 32 is unpredictable. Byte 32 is always unpredictable in the program-interruption TDB.

**Data-Exception Code (DXC) / Vector-Exception Code (VXC):** For transactions that are aborted due to filtered data-exception program-exception conditions, byte 33 of the TBEGIN-specified TDB contains the data-exception code. The format of the DXC, and the cases for which it is stored, are identical to those described in real location 147 when the exception condition results in an interruption. See “Data-Exception Code” on page 3-69 and page 6-16 for details.

For transactions that are aborted due to filtered vector-processing exception program-exception conditions, byte 33 of the TBEGIN-specified TDB contains the vector-exception code. The format of the VXC, and the cases for which it are stored, are identical to those described in real location 147 when the exception condition results in an interruption. See “Vector Processing Exception” on page 6-45 for details.

For transactions that are aborted for other reasons, including any exception conditions that result in a program interruption, byte 33 is unpredictable. Byte 33 is always unpredictable in the program-interruption TDB.

**Program Interruption Identification (PIID):** For transactions that are aborted due to filtered program-exception conditions, bytes 36-39 of the TBEGIN-specified TDB contain the program interruption identification. The format of the PIID is identical to that described in real locations 140-143 when the condition results in an interruption, except that the instruction-length code in bits 13-14 of the PIID is respective to the instruction at which the exception condition was detected. See “Program- Interruption Identification” on page 3-69 for details.

For transactions that are aborted for other reasons, including exception conditions that result in a program interruption, bytes 36-39 are unpredictable. Bytes 36-39 are always unpredictable in the program-interruption TDB.

**Translation-Exception Identification (TEID):** For transactions that are aborted due to any of the following filtered program-exception conditions, bytes 40-47 of the TBEGIN-specified TDB contain the translation-exception identification.

- Access-list-controlled or DAT protection
- ASCE-type
- Page translation
- Region-first translation
- Region-second translation
- Region-third translation
- Segment translation exception

The format of the TEID is identical to that described in real locations 168-175 when the condition results in an interruption. See “Translation-Exception Identification” on page 3-70 for details.

For transactions that are aborted for other reasons, including exception conditions that result in a program interruption, bytes 40-47 are unpredictable. Bytes 40-47 are always unpredictable in the program-interruption TDB.

**Breaking-Event Address:** For transactions that are aborted due to filtered program-exception conditions, bytes 48-55 of the TBEGIN-specified TDB contain the breaking-event address. The format of the breaking-event address is identical to that described in real locations 272-279 when the condition results in an interruption. See “Breaking-Event Address” on page 3-73 and page 4-40 for details.

For transactions that are aborted for other reasons, including exception conditions that result in a pro-
gram interruption, bytes 48-55 are unpredictable. Bytes 48-55 are always unpredictable in the program-interruption TDB.

**General Registers:** Bytes 128-255 contain the contents of general registers 0-15 at the time the transaction was aborted. The registers are stored in ascending order, beginning with general register 0 in bytes 128-135, general register 1 in bytes 136-143, and so forth.

**Reserved:** All other fields are reserved. Unless indicated otherwise, the contents of reserved fields are unpredictable.

As observed by other CPUs and the channel subsystem, storing of the TDB(s) during a transaction abort is a multiple-access reference occurring after any nontransactional stores.

**Programming Notes:**

1. A transaction may be aborted due to causes that are outside the scope of the immediate configuration in which it executes. For example, transient events recognized by a hypervisor (such as LPAR or z/VM) may cause a transaction to be aborted.

2. The information provided in the transaction-diagnostic block is intended for diagnostic purposes and is substantially correct. However, because an abort may have been caused by an event outside the scope of the immediate configuration, information such as the abort code or program interruption identification may not accurately reflect conditions within the configuration, and thus should not be used in determining program action.

3. An example of the scenario described in the above notes may occur if a configuration's first execution of an advanced-floating-point (AFP) instruction occurs within a transaction. The control program can eliminate this scenario by executing the first AFP instruction outside of a transaction.

In addition to the diagnostic information saved in the TDB, when a transaction is aborted due to any data-exception program-exception condition and both the AFP-register control, bit 45 of control register 0, and the effective allow-floating-point-operation control (F) are one, the data-exception code (DXC) is placed into byte 2 of the floating-point control register (FPCR), regardless of whether filtering applies to the program-interruption condition. When a transaction is aborted, and either or both the AFP-register control or effective allow-floating-point-operation control are zero, the DXC is not placed into the FPCR.

**Transactional-Execution Facility Instructions**

When the transactional-execution facility is installed, the following general instructions are provided:

- EXTRACT TRANSACTION NESTING DEPTH
- NONTRANSACTIONAL STORE
- TRANSACTION ABORT
- TRANSACTION BEGIN
- TRANSACTION END

**Restricted Instructions**

When the CPU is in the transactional-execution mode, attempted execution of certain instructions is restricted and causes the transaction to be aborted.

When issued in the constrained transactional-execution mode, attempted execution of restricted instructions may also result in a transaction-constraint program interruption, or may result in execution proceeding as if the transaction was not constrained. See “Constrained Transaction” on page 5-108 for further details.

Restricted instructions include all instructions that are not defined in Chapters 7-9 and 18-24 of this document and the following nonprivileged instructions:

- COMPARE AND SWAP AND STORE
- PERFORM LOCKED OPERATION
- PERFORM PROCESSOR ASSIST
- PREFETCH DATA (RELATIVE LONG), when the code in the M₁ field is 6 or 7
- STORE CHARACTERS UNDER MASK HIGH, when the M₃ field is zero and the code in the R₁ field is 6 or 7
- STORE FACILITY LIST EXTENDED
- SUPERVISOR CALL

Under the conditions listed below, the following instructions are restricted:
• BRANCH AND LINK (BALR), BRANCH AND SAVE (BASR), and BRANCH AND SAVE AND SET MODE, when the R2 field of the instruction is nonzero and branch tracing is enabled
• BRANCH AND SAVE AND SET MODE and BRANCH AND SET MODE, when the R3 field is nonzero and mode tracing is enabled; SET ADDRESSING MODE, when mode tracing is enabled
• MONITOR CALL, when a monitor-event condition is recognized

When the CPU is in the transactional-execution mode, it is model dependent whether the following instructions are restricted:

• CIPHER MESSAGE
• CIPHER MESSAGE WITH CIPHER FEEDBACK
• CIPHER MESSAGE WITH CHAINING
• CIPHER MESSAGE WITH COUNTER
• CIPHER MESSAGE WITH OUTPUT FEEDBACK
• COMPRESSION CALL
• COMPUTE INTERMEDIATE MESSAGE DIGEST
• COMPUTE LAST MESSAGE DIGEST
• COMPUTE MESSAGE AUTHENTICATION CODE
• CONVERT UNICODE-16 TO UNICODE-32
• CONVERT UNICODE-16 TO UNICODE-8
• CONVERT UNICODE-32 TO UNICODE-16
• CONVERT UNICODE-32 TO UNICODE-8
• CONVERT UNICODE-8 TO UNICODE-16
• CONVERT UNICODE-8 TO UNICODE-32
• PERFORM CRYPTOGRAPHIC COMPUTATION
• PERFORM PSEUDORANDOM NUMBER OPERATION

When the effective allow-AR-modification (A) control is zero, the following instructions are restricted:

• COPY ACCESS
• LOAD ACCESS MULTIPLE
• LOAD ADDRESS EXTENDED
• SET ACCESS

When the effective allow-floating-point-operation (F) control is zero, all floating-point and vector instructions are restricted (that is, all instructions described in Chapters 9 and 18-24).

Under certain circumstances, the following instructions may be restricted:

• EXTRACT CPU TIME
• EXTRACT PSW
• STORE CLOCK
• STORE CLOCK EXTENDED
• STORE CLOCK FAST

When a nonconstrained transaction is aborted because of the attempted execution of a restricted instruction, the transaction abort code in the transaction diagnostic block is set to 11 (restricted instruction), and the condition code is set to 3, except as follows. When a nonconstrained transaction is aborted due to the attempted execution of an instruction that would otherwise result in a privileged-operation exception, it is unpredictable whether the abort code is set to 11 (restricted instruction) or 4 (unfiltered program interruption resulting from the recognition of the privileged-operation program interruption). When a nonconstrained transaction is aborted due to the attempted execution of PREFETCH DATA (RELATIVE LONG) when the code in the M1 field is 6 or 7 or STORE CHARACTERS UNDER MASK HIGH when the M3 field is zero and the code in the R1 field is 6 or 7, it is unpredictable whether the abort code is set to 11 (restricted instruction) or 16 (cache other). When a nonconstrained transaction is aborted due to the attempted execution of MONITOR CALL, and both a monitor-event condition and a specification exception condition are present, it is unpredictable whether the abort code is set to 11 or 4, or, if the program interruption is filtered, 12.

Additional instructions may be restricted in a constrained transaction, as described in “Constrained Transaction” on page 5-108. Although these instructions are not currently defined to be restricted in a nonconstrained transaction, they may be restricted under certain circumstances in a nonconstrained transaction on future processors. See “Constrained Transaction” on page 5-108 for details on the additional restrictions and alternate results if a restricted instruction is attempted.

Programming Notes:

1. Certain restricted instructions may be allowed in the transactional-execution mode on future processors. Therefore, the program should not rely on the transaction being aborted due to the attempted execution of a restricted instruction. The TRANSACTION ABORT instruction should be used to reliably cause a transaction to be aborted.
2. In a nonconstrained transaction, the program should provide an alternative nontransactional code path to accommodate a transaction that aborts due the attempted execution of an instruction that is restricted under certain conditions.

3. The effective allow-AR-modification and effective allow-floating-point-operation controls (A and F bits, respectively) are described in “TRANSACTION BEGIN (TBEGIN)” on page 7-345.

**Transactional-Execution Facility Operation**

The transactional-execution facility is under the control of bits 8-9 of control register 0, bits 61-63 of control register 2, the transaction nesting depth, the transaction-diagnostic-block address, and the transaction-abort PSW. See “Transactional-Execution Facility Controls” on page 5-93 for details on these controls.

Following an initial CPU reset, the contents of bit positions 8-9 of control register 0, bit positions 62-63 of control register 2, and the transaction nesting depth are set to zero. When the transactional-execution control, bit 8 of control register 0, is zero, the CPU cannot be placed into the transactional-execution mode.

**Transaction Initiation**

When the transaction nesting depth is zero, execution of the TRANSACTION BEGIN (TBEGIN) instruction resulting in condition code zero causes the CPU to enter the nonconstrained transactional-execution mode. When the transaction nesting depth is zero, execution of the TRANSACTION BEGIN (TBEGINC) instruction resulting in condition code zero causes the CPU to enter the constrained transactional-execution mode.

When the CPU is in the nonconstrained transactional-execution mode, execution of the TRANSACTION BEGIN (TBEGIN) instruction resulting in condition code zero causes the CPU to remain in the nonconstrained transactional-execution mode. Details of the instructions may be found in “TRANSACTION BEGIN (TBEGIN)” on page 7-345 and “TRANSACTION BEGIN (TBEGINC)” on page 7-349.

**Execution in the Transactional-Execution Mode**

Except where explicitly noted otherwise, all rules that apply for nontransactional execution also apply to transactional execution. This section describes additional characteristics of processing while the CPU is in the transactional-execution mode.

As observed by the CPU, fetches and stores made in the transactional-execution mode are no different than those made while not in the transactional-execution mode. See “Storage-Operand Consistency” on page 5-123 and “Relation between Operand Accesses” on page 5-126 for a description of the rules of storage ordering.

As observed by other CPUs and by the channel subsystem, all storage-operand accesses made while a CPU is in the transactional-execution mode appear to be a single block-concurrent access. Storage accesses for instruction and DAT- and ART-table fetches follow the non-transactional rules.

**Normal Transaction Ending**

The CPU leaves the transactional-execution mode normally by means of a TRANSACTION END instruction that causes the transaction nesting depth to transition to zero; in this case the transaction is said to complete. See “TRANSACTION END” on page 7-351 for the details.

When the CPU leaves the transactional-execution mode by means of the completion of a TRANSACTION END instruction, all stores made while in the transactional-execution mode are committed, that is, the stores appear to occur as a single block-concurrent operation as observed by other CPUs and by the channel subsystem.

**Transaction Abort Conditions**

A transaction may be implicitly aborted for a variety of causes, or it may be explicitly aborted by the TRANSACTION ABORT instruction. The following text enumerates each possible cause of a transaction abort, the corresponding abort code, and the condition code that is placed into the transaction-abort PSW.

**External Interruption:** The transaction-abort code is set to 2, and the condition code in the transaction-abort PSW is set to 2. The transaction-abort PSW is stored as the external-old PSW as a part of external-interruption processing.
**Program Interruption (Unfiltered):** A program-exception condition that results in an interruption (that is, an unfiltered condition) causes the transaction to be aborted with code 4. The condition code in the transaction-abort PSW is set specific to the program interruption code, as described in “Transaction Abort Processing” on page 5-103 and Figure 5-15 on page 5-105. The transaction-abort PSW is stored as the program-old PSW as a part of program-interruption processing.

An instruction that would otherwise result in a transaction being aborted due to an operation exception may yield alternate results: For a nonconstrained transaction, the transaction may instead aborted with abort code 11 (restricted instruction); for a constrained transaction, a transaction-constraint program interruption may be recognized instead of the operation exception.

When a PER event is recognized in conjunction with any other unfiltered program-exception condition, the condition code is set to 3.

**Machine-Check Interruption:** The transaction-abort code is set to 5, and the condition code in the transaction-abort PSW is set to 2. The transaction-abort PSW is stored as the machine-check-old PSW as a part of machine-check interruption processing.

**I/O Interruption:** The transaction-abort code is set to 6, and the condition code in the transaction-abort PSW is set to 2. The transaction-abort PSW is stored as the I/O-old PSW as a part of I/O interruption processing.

**Fetch Overflow:** A fetch-overflow condition is detected when the transaction attempts to fetch from more locations than the CPU supports. The transaction-abort code is set to 7, and the condition code is set to either 2 or 3.

**Store Overflow:** A store-overflow condition is detected when the transaction attempts to store to more locations than the CPU supports. The transaction-abort code is set to 8, and the condition code is set to either 2 or 3.

**Fetch Conflict:** A fetch-conflict condition is detected when another CPU or the channel subsystem attempts to store into a location that has been transactionally fetched by this CPU. The transaction-abort code is set to 9, and the condition code is set to 2.

**Store Conflict:** A store-conflict condition is detected when another CPU or the channel subsystem attempts to access a location that has been stored during transactional execution by this CPU. The transaction-abort code is set to 10, and the condition code is set to 2.

**Restricted Instruction:** When the CPU is in the transactional-execution mode, attempted execution of a restricted instruction causes the transaction to be aborted. The transaction-abort code is set to 11, and the condition code is set to 3.

Restricted instructions, and the conditions under which they are restricted is described in “Restricted Instructions” on page 5-98.

**Program- Interruption Condition (Filtered):** A program-interruption condition that does not result in an interruption (that is, a filtered condition) causes the transaction to be aborted with a transaction-abort code of 12. The condition code is set to 3. See “Program-Interruption Filtering on a Transaction Abort” on page 5-104 for details on program-interruption filtering.

**Nesting Depth Exceeded:** The nesting-depth-exceeded condition is detected when the transaction nesting depth is at the maximum allowable value for the configuration, and a TRANSACTION BEGIN instruction is executed. The transaction is aborted with a transaction-abort code of 13, and the condition code is set to 3.

**Cache Fetch-Related Condition:** A condition related to storage locations fetched by the transaction is detected by the CPU's cache circuitry. The transaction is aborted with a transaction-abort code of 14, and the condition code is set to either 2 or 3.

**Cache Store-Related Condition:** A condition related to storage locations stored by the transaction is detected by the CPU's cache circuitry. The transaction is aborted with a transaction-abort code of 15, and the condition code is set to either 2 or 3.

**Cache Other Condition:** A cache other condition is detected by the CPU's cache circuitry. The transaction is aborted with a transaction-abort code of 16, and the condition code is set to 2 or 3.

During transactional execution, if the CPU accesses instructions or storage operands using different logical addresses that are mapped to the same absolute
address, it is model dependent whether the transaction is aborted. If the transaction is aborted due to accesses using different logical addresses mapped to the same absolute address, abort code 14, 15, or 16 is set, depending on the condition.

**Miscellaneous Condition:** A miscellaneous condition is any other condition recognized by the CPU that causes the transaction to abort. The transaction-abort code is set to 255, and the condition code is set to either 2 or 3.

When multiple configurations are executing in the same machine (for example, logical partitions or virtual machines), a transaction may be aborted due to an external, machine-check, or I/O interruption that occurred in a different configuration.

**Programming Notes:**

1. The miscellaneous condition may result from any of the following:
   - COMPARE AND REPLACE DAT TABLE ENTRY, COMPARE AND SWAP AND PURGE, INVALIDATE DAT TABLE ENTRY, INVALIDATE PAGE TABLE ENTRY, PERFORM FRAME MANAGEMENT FUNCTION in which the NQ control is zero and SK control is one, SET STORAGE KEY EXTENDED in which the NQ control is zero, performed by another CPU in the configuration; the condition code is set to 2.
   - An operator function (such as reset, restart, or stop) or the equivalent SIGNAL PROCESSOR order is performed on the CPU. The condition code is set to 2.
   - Any other condition not enumerated above; the condition code is set to 2 or 3.

2. The location at which fetch and store conflicts are detected may be anywhere within the same cache line.

3. Under certain conditions, the CPU may not be able to distinguish between similar abort conditions. For example, a fetch or store overflow may be indistinguishable from a respective fetch or store conflict.

4. Speculative execution of multiple instruction paths by the CPU may result in a transaction being aborted due to conflict or overflow conditions, even if such conditions do not occur in the conceptual sequence. While in the constrained transactional-execution mode, the CPU may temporarily inhibit speculative execution, allowing the transaction to attempt to complete without detecting such conflicts or overflows speculatively.

When multiple abort conditions apply, it is unpredictable which abort code is reported by the CPU.

**TABORT Instruction:** Execution of the TRANSACTION ABORT instruction causes the transaction to abort. The transaction-abort code is set from the second-operand address. The condition code is set to either 2 or 3, depending on whether bit 63 of the second-operand address is zero or one, respectively.

Figure 5-14 summarizes the abort codes stored in the transaction diagnostic block, and the corresponding condition code.

<table>
<thead>
<tr>
<th>Code</th>
<th>Reason for Abort</th>
<th>CC Set</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>External interruption</td>
<td>2</td>
</tr>
<tr>
<td>4</td>
<td>Program interruption (unfiltered)</td>
<td>2 or 3†</td>
</tr>
<tr>
<td>5</td>
<td>Machine-check interruption</td>
<td>2</td>
</tr>
<tr>
<td>6</td>
<td>I/O interruption</td>
<td>2</td>
</tr>
<tr>
<td>7</td>
<td>Fetch overflow</td>
<td>2 or 3</td>
</tr>
<tr>
<td>8</td>
<td>Store overflow</td>
<td>2 or 3</td>
</tr>
<tr>
<td>9</td>
<td>Fetch conflict</td>
<td>2</td>
</tr>
<tr>
<td>10</td>
<td>Store conflict</td>
<td>2</td>
</tr>
<tr>
<td>11</td>
<td>Restricted instruction</td>
<td>3</td>
</tr>
<tr>
<td>12</td>
<td>Program-interruption condition (filtered)</td>
<td>3</td>
</tr>
<tr>
<td>13</td>
<td>Nesting depth exceeded</td>
<td>3</td>
</tr>
<tr>
<td>14</td>
<td>Cache fetch-related</td>
<td>2 or 3</td>
</tr>
<tr>
<td>15</td>
<td>Cache store-related</td>
<td>2 or 3</td>
</tr>
<tr>
<td>16</td>
<td>Cache other</td>
<td>2 or 3</td>
</tr>
<tr>
<td>255</td>
<td>Miscellaneous condition</td>
<td>2 or 3</td>
</tr>
<tr>
<td>256</td>
<td>TABORT instruction</td>
<td>2 or 3</td>
</tr>
<tr>
<td>‡</td>
<td>Cannot be determined; no TDB stored</td>
<td>1</td>
</tr>
</tbody>
</table>

**Explanation:**

† See Figure 5-16 on page 5-105 to determine which condition code is set based on the interruption code.

‡ This situation occurs when a transaction aborts, but the TDB has become inaccessible subsequent to the successful execution of the outermost TRANSACTION BEGIN (TBEGIN) instruction. No TBEGIN-specified TDB is stored, and the condition code is set to 1.

Figure 5-14. Transaction Abort Codes
Programming Notes:

1. Abort codes 0-255 are reserved for use by the CPU. If the program specifies any of these codes in the TRANSACTION ABORT instruction, a specification exception is recognized, and the transaction is aborted with the resulting abort code indicating a program interruption (code 4) or program-interruption condition (code 12).

2. Abort codes 17-254 are reserved for potential enhancements. Such enhancements may result in the setting of either condition code 2 or 3.

3. Depending on the model, the CPU may not be able to distinguish between certain abort reasons. For example, a fetch/store overflow and a fetch/store conflict may not be distinguishable by the CPU in all circumstances. Therefore, the program should be able to accommodate unanticipated abort reasons.

4. Abort code 0 is reserved and will never be assigned to a meaningful abort indication.

Transaction Abort Processing

Abort processing consists of the following steps:

1. All nontransactional store accesses made while the CPU was in the transactional-execution mode are committed.

   All other (transactional) stores made while the CPU was in the transactional-execution mode are discarded.

2. The CPU leaves the transactional-execution mode. Subsequent stores occur nontransactionally.

3. The current PSW is replaced with the contents of the transaction-abort PSW, except that the condition code is set according to Figure 5-14 on page 5-102 and Figure 5-16 on page 5-105.

4. When the transaction-diagnostic-block address is valid, diagnostic information identifying the reason for the abort and the contents of the general registers are stored into the TBEGIN-specified transaction diagnostic block (TDB). The TDB fields stored and conditions under which they are stored are described in “Transaction Diagnostic Block (TDB)” on page 5-94.

   If the transaction-diagnostic-block address is valid, but the block has become inaccessible subsequent to the execution of the outermost TRANSACTION BEGIN (TBEGIN) instruction, the block is not accessed, and condition code 1 applies. If the transaction-diagnostic-block address is not valid, no TBEGIN-specified TDB is stored, and condition code 2 or 3 applies, depending on the reason for aborting.

   For transactions that are aborted due to program-exception conditions that result in an interruption, the program-interruption TDB is stored. See “Transaction Diagnostic Block (TDB)” on page 5-94 for a description of the contents of the TDB.

5. The transaction nesting depth is set to zero.

6. Any general register pairs designated to be saved by the outermost TRANSACTION BEGIN instruction are restored. General register pairs that were not designated to be saved by the outermost TRANSACTION BEGIN instruction are not restored when a transaction is aborted.

7. A serialization function is performed.

8. If the transaction is aborted due to an exception condition that results in an interruption, any and all other interruption codes or parameters associated with the interruption are stored at the assigned-storage locations corresponding to the type of interruption. The current PSW, as set in step 3, is stored into the interruption-old PSW.

Programming Notes:

1. Attempted execution of a SUPERVISOR CALL instruction while in the transactional-execution mode results in the transaction being aborted due to a restricted instruction. An SVC interruption cannot occur in this case.

2. Access registers, vector registers, floating-point registers, the floating-point-control register, and any general registers not specified by the outermost TRANSACTION BEGIN instruction's general-register-save mask are not restored when a transaction aborts.

3. When the CPU was in the nonconstrained transactional-execution mode, the instruction address of the transaction-abort PSW designates the storage location following the outermost TRANSACTION BEGIN (TBEGIN) instruction. The sequence of instructions at this location should be able to accommodate all four condition codes,
even though a failing transaction only causes codes 1, 2, and 3 to be set. A summary of the condition code meanings is as follows:

<table>
<thead>
<tr>
<th>CC</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The transaction was successfully initiated.</td>
</tr>
<tr>
<td>1</td>
<td>The transaction was aborted due to an indeterminate condition. The transaction diagnostic block could not be stored. Reexecution of the transaction is unlikely to be productive.</td>
</tr>
<tr>
<td>2</td>
<td>The transaction was aborted due to a transient condition. Reexecution of the transaction may be productive.</td>
</tr>
<tr>
<td>3</td>
<td>The transaction was aborted due to a persistent condition. Reexecution of the transaction under current conditions is unlikely to be productive. If conditions change, for example, data that is manipulated transactionally is rearranged, then reexecution may be more productive.</td>
</tr>
</tbody>
</table>

When the CPU was in the constrained transactional-execution mode, the instruction address of the transaction-abort PSW designated the TRANSACTION BEGIN (TBEGINC) instruction. By definition, a constrained transaction does not provide an abort-handler routine.

4. When using nested transactions, an inner transaction may cause abort conditions to occur that may not otherwise occur in the outermost transaction. Examples of such conditions include the following:

- The inner transaction may issue the TRANSACTION ABORT instruction, specifying an unanticipated abort code.
- The inner transaction may result in an unanticipated program-interruption condition.
- The inner transaction may filter program-interruption conditions that are not filtered by the outermost transaction, thus resulting in a different abort code.

Any transaction abort-handler routine must be able to accommodate unanticipated abort and exception conditions that occur within inner transactions, even if they never occur in the outermost transaction.

### Program-Interruption Filtering on a Transaction Abort

A program-exception condition that is recognized while in the transactional-execution mode always results in the transaction being aborted. For a non-constrained transaction, the program can optionally specify that certain program-exception conditions not result in an interruption. This action is called program-interruption filtering. Program-interruption filtering is subject to the following controls:

- The transactional-execution program-interruption-filtering override, bit 9 of control register 0
- The effective program-interruption-filtering control (PIFC)
- The program-interruption code corresponding to the exception condition recognized.

When the transactional-execution program-interruption filtering override is zero, the program specifies which classes of exception conditions are to be filtered by means of the program-interruption-filtering control (PIFC), bits 14-15 of the I2 field of the TRANSACTION BEGIN (TBEGIN) instruction. The effective PIFC is the highest value of the PIFC in the TBEGIN instruction for the current nesting level and for all outer levels.

For most program-exception conditions, there is a corresponding transactional-execution class. The effective PIFC and the transactional-execution classes interact as follows:

<table>
<thead>
<tr>
<th>Effective PIFC</th>
<th>Results based on Transactional-Execution Class</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No program-interruption filtering occurs. Exception conditions having classes 1, 2, or 3 always result in an interruption.</td>
</tr>
<tr>
<td>1</td>
<td>Limited program-interruption filtering occurs. Exception conditions having classes 1 or 2 result in an interruption; conditions having class 3 do not result in an interruption.</td>
</tr>
<tr>
<td>2</td>
<td>Moderate program-interruption filtering occurs. Only exception conditions having class 1 result in an interruption; conditions having classes 2 or 3 do not result in an interruption.</td>
</tr>
</tbody>
</table>

The TRANSACTION BEGIN (TBEGINC) instruction provides no explicit program-interruption-filtering control; an implied PIFC of zero is assumed for TBEGINC. Thus, when the CPU enters the con-
strained transactional-execution mode as a result of TBEGINC, the effective PIFC is zero; when the CPU remains in the nonconstrained transactional-execution mode as a result of TBEGINC, the effective PIFC is unchanged.

Figure 5-15 summarizes the relationship of the effective PIFC, the type of program-interruption filtering, the transactional-execution class, and whether the exception condition results in an interruption.

<table>
<thead>
<tr>
<th>Effective PIFC</th>
<th>Program-Interruption Filtering</th>
<th>Result Based on Transactional-Execution (TX) Class</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>None</td>
<td>Interrupt Interrupt Interrupt</td>
</tr>
<tr>
<td>1</td>
<td>Limited</td>
<td>Interrupt Interrupt Filtered</td>
</tr>
<tr>
<td>2</td>
<td>Moderate</td>
<td>Interrupt Filtered Filtered</td>
</tr>
</tbody>
</table>

**Explanation:**

PIFC  Program-Interruption-Filtering Control (bits 14-15 of the $I_2$ field of the TBEGIN instruction; zeros for TBEGINC); the effective PIFC is the highest value specified (or implied) for the current and all outer-level TRANSACTION BEGIN instructions.

**Figure 5-15. Effective PIFC and Transactional-Execution Program-Interruption Classes**

Figure 5-16 lists the program-interruption conditions, the corresponding transactional-execution class, and the condition code that is set when the transaction is aborted due to a program-interruption condition.

<table>
<thead>
<tr>
<th>Code (Hex)</th>
<th>Exception Condition</th>
<th>TX Class</th>
<th>CC Set</th>
</tr>
</thead>
<tbody>
<tr>
<td>0001</td>
<td>Operation</td>
<td>1</td>
<td>3</td>
</tr>
<tr>
<td>0002</td>
<td>Privileged operation</td>
<td>1</td>
<td>3</td>
</tr>
<tr>
<td>0003</td>
<td>Execute</td>
<td>1</td>
<td>3</td>
</tr>
<tr>
<td>0004</td>
<td>Protection</td>
<td>1 or 2 †</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0005</td>
<td>Addressing</td>
<td>1 or 2 †</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0006</td>
<td>Specification</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0007</td>
<td>Data (DXC 01, 02, 03, and FE)</td>
<td>1</td>
<td>2</td>
</tr>
<tr>
<td>0007</td>
<td>Data (all other DXCs)</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0008</td>
<td>Fixed-point overflow</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0009</td>
<td>Fixed-point divide</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>000A</td>
<td>Decimal overflow</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>000B</td>
<td>Decimal divide</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>000C</td>
<td>HFP exponent overflow</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>000D</td>
<td>HFP exponent underflow</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>000E</td>
<td>HFP significance</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>000F</td>
<td>HFP divide</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0010</td>
<td>Segment translation</td>
<td>1 or 2 †</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0011</td>
<td>Page translation</td>
<td>1 or 2 †</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0012</td>
<td>Translation specification</td>
<td>1</td>
<td>3</td>
</tr>
<tr>
<td>0013</td>
<td>Special operation</td>
<td>1</td>
<td>3</td>
</tr>
<tr>
<td>0015</td>
<td>Operand</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0016</td>
<td>Trace table</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0018</td>
<td>Transaction constraint</td>
<td>1</td>
<td>3</td>
</tr>
<tr>
<td>001B</td>
<td>Vector processing</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>001C</td>
<td>Space-switch event</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>001D</td>
<td>HFP square root</td>
<td>3</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>001F</td>
<td>PC-translation specification</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0020</td>
<td>AFX translation</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0021</td>
<td>ASX translation</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0022</td>
<td>LX translation</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0023</td>
<td>EX translation</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0024</td>
<td>Primary authority</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0025</td>
<td>Secondary authority</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0026</td>
<td>LFX translation</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0027</td>
<td>LSX translation</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0028</td>
<td>ALET specification</td>
<td>2</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0029</td>
<td>ALEN translation</td>
<td>2</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>002A</td>
<td>ALE sequence</td>
<td>2</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>002B</td>
<td>ASTE validity</td>
<td>2</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>002C</td>
<td>ASTE sequence</td>
<td>2</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>002D</td>
<td>Extended authority</td>
<td>2</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>002E</td>
<td>ASTE sequence</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>002F</td>
<td>ASTE instance</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0030</td>
<td>Stack full</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0031</td>
<td>Stack empty</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0032</td>
<td>Stack specification</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0033</td>
<td>Stack type</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0034</td>
<td>Stack operation</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0038</td>
<td>ASCE type</td>
<td>1 or 2 †</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0039</td>
<td>Region-first translation</td>
<td>1 or 2 †</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>003A</td>
<td>Region-second translation</td>
<td>1 or 2 †</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>003B</td>
<td>Region-third translation</td>
<td>1 or 2 †</td>
<td>2 or 3 ‡</td>
</tr>
<tr>
<td>0040</td>
<td>Monitor event</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0080</td>
<td>PER event</td>
<td>1</td>
<td>3 †</td>
</tr>
</tbody>
</table>

**Explanation:**

— Not applicable; the exception cannot occur in the transactional-execution mode because the instruction that causes the exception is a restricted instruction.

† Access exceptions recognized during the fetching of an instruction in the transactional-execution mode are TX class 1 (that is, they cannot be filtered). Access exceptions when accessing a storage operand in the transactional-execution mode are TX class 2.

‡ When the exception condition is not filtered, the condition code is 2; when the condition is filtered, the condition code is 3.

**Figure 5-16. Transactional-Execution Classes for Various Program-Interruption Conditions (Part 1 of 3)**
When a program-interruption condition does not result in an interruption (that is, the condition is filtered), the program-new PSW is not loaded, and none of the assigned storage locations associated with a program interruption are stored; these locations include the program-interruption identification, the breaking-event address, the program-old PSW, and, when applicable, the data-exception code, PER code, PER address, exception access identification, PER access identification, operand access identification, and translation-exception identification. When a program-interruption condition results in an interruption (that is, the condition is unfiltered), most assigned storage locations associated with a program interruption are stored as is normal; however, the instruction-length code in bits 13-14 of the program-interruption identification is respective to the instruction at which the exception condition was detected, and the transaction-abort PSW is stored as the program-old PSW.

When a PER event is recognized in conjunction with any other filtered program-exception condition, the following applies:

- The transaction class and condition code for the PER event apply. In this case, the PER exception condition cannot be filtered, and the condition code is set to 3.
- The program-interruption code in the prefix area does not include the non-PER exception condition, nor are any other non-PER program-interruption parameters stored in the prefix area.

When the transactional-execution program-interruption filtering override (bit 9 of control register 0) is one, program-interruption conditions are not subject to program-interruption filtering. In this case, execution proceeds as if the effective PIFC was zero.

Access-exception conditions recognized during the fetching of an instruction are never subject to program-interruption filtering. In these cases, the exception condition results both in the transaction being aborted and in a program interruption.

In addition to the program-interruption code representing the cause of the interruption, bit 6 of the program-interruption code at real locations 142-143 is set to one, indicating that the program interruption occurred during transactional execution. The fields of the program-old PSW are set as described in step 3 of “Transaction-old PSW” on page 5-103.

### Programming Notes:

1. A MONITOR CALL instruction that would otherwise cause a monitor-event is a restricted instruction. Therefore, a monitor-event program interruption can never occur while the CPU is in the transactional-execution mode, thus the monitor code at real locations 176-183 is not stored when the transaction is aborted.

Similarly, any other program-interruption condition listed in Figure 5-16 having a not-applicable transaction class (−) and condition code cannot occur as the instructions that cause these exceptions are restricted. Thus, neither the program-interruption identification nor any of the other ancillary program-interruption information are stored in real locations in the prefix area.

2. The following example illustrates the instructions necessary to initiate and end a nonconstrained transaction. Note that if the transaction is aborted, it is retried several times before finally branching to the non-transactional fallback path at label NO_RETRY.

```assembly
LHI 15,0 Zero counter
LOOP TBEGIN TDB,X’F000’ Restore GRs 0-7 if aborted.
JNZ ABORT CC 1/3: Not worth retrying.
AHI 15,1 Increment counter.
CIJNL 15,6,NO_RETRY Give up after 6 attempts
PPA 15,0,1 Request assistance.
J LOOP And try it again.
NO_RETRY DS 0H Perform fall-back path
```

3. As shown in programming note 2, the first conditional branch instruction following a TBEGIN should be one of the following:

- A branch to the abort handler for all possible aborting conditions; that is, a conditional branch instruction having a mask of 0111

---

<table>
<thead>
<tr>
<th>Code (Hex)</th>
<th>Exception Condition</th>
<th>TX Class</th>
<th>CC Set</th>
</tr>
</thead>
<tbody>
<tr>
<td>*</td>
<td>The CPU sets condition code 3. A control program or hypervisor may change the condition code in the program-old PSW to 2.</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Figure 5-16. Transactional-Execution Classes for Various Program-Interruption Conditions (Part 3 of 3)*
binary (as shown in programming note 2). In this case, separate conditional branches in an out-of-line abort handler may be used to accommodate the three possible aborting conditions. This is the preferred sequence.

- A branch to the next instruction to be executed in the transactional-execution mode; that is, a conditional branch instruction having a mask of 1000 binary. In this case, separate conditional branches to accommodate the aborting conditions may immediately follow the first conditional branch. This is not the preferred sequence and may result in significant performance degradation.

Other branching combinations – such as having a first, second, and third conditional branch following the TBEGIN to handle the respective condition code 1, 2, and 3 cases – may result in unnecessary or repetitive aborting of the transaction.

4. Programming note 2 shows the use of the PERFORM PROCESSOR ASSIST (PPA) instruction. The program can improve the likelihood of success when redriving the transaction by invoking the PPA instruction before branching back to the label LOOP following an abort. PPA is described on page 7-298.

5. As shown in programming note 2, the loop counter in general register 15 is not subject to the general-register save mask (GRSM) in the TRANSACTION BEGIN instruction; thus, the register is not restored if the transaction aborts. Therefore, the program should not alter the contents of general register 15 within the transaction.

However, if the loop counter was changed to use a register that is subject to the GRSM, for example general register 7, then the transaction could safely alter that register within the transaction, and the program could use the same register for the loop counter. If the transaction completes successfully, any results in general register 7 are available following the TRANSACTION END instruction. However, if the transaction aborts, the original value of general register 7 (that is, the value before the TBEGIN) is restored, thus the register can also be used for the loop counter in the abort handler.

6. Program-interruption filtering may be useful in programs that, for various reasons, defer the validation of data – sometimes called speculative execution. Instead of establishing a potentially complicated recovery environment, the program simply executes nonconstrained transaction(s) in which the effective program-interruption filtering control (PIFC) is nonzero. This allows the program’s abort-handler routine to receive control for certain types of program-interruption conditions directly – without operating-system intervention.

An effective PIFC of 1 indicates that limited filtering is to be performed by the CPU; this may be useful in the recognition of unexpected data or arithmetic exceptions. An effective PIFC of 2 indicates that moderate filtering is to be performed; this may be useful in the recognition of inaccessible storage locations.

However, it should be noted that if a program is aborted due to various types of filtered access exceptions, it does not necessarily indicate that the location would be inaccessible if the program attempted nontransactional execution. For example, the program might specify a PIFC of 2, and subsequently be aborted due to a page-translation exception. This exception may indicate that the storage location is not part of the virtual address space, or it may simply indicate that the block of storage has been paged out.

Priority of Abort Conditions

During transactional execution, multiple abort conditions may be present simultaneously. Abort conditions having corresponding interruptions are honored in the order defined in “Priority of Program-Interruption Conditions” on page 6-49. Except for the restricted-instruction abort condition, abort conditions that do not correspond to interruptions may occur in any order. The priority of the restricted-instruction abort condition is equivalent to a program-interruption priority of 7.D (see “Priority of Program-
Constrained Transaction
In the absence of repeated interruptions or conflicts with other CPUs or the channel subsystem, a constrained transaction will eventually complete, thus an abort-handler routine is not required. A constrained transaction is initiated by the TRANSACTION BEGIN (TBEGINC) instruction when the transaction nesting depth is initially zero. A constrained transaction is subject to the following constraints:

1. The transaction executes no more than 32 instructions, not including the TRANSACTION BEGIN (TBEGINC) and TRANSACTION END instructions.

2. All instructions in the transaction must be within 256 contiguous bytes of storage, including the TRANSACTION BEGIN (TBEGINC) and any TRANSACTION END instructions.

3. In addition to all instructions listed in the section “Restricted Instructions” on page 5-98, the following restrictions apply to a constrained transaction.

   a. Instructions are limited to those defined in Chapter 7, “General Instructions.”

   b. Branching instructions are limited to the following:

   c. Except for TRANSACTION END and instructions which cause a specific-operand serialization, instructions which cause a serialization function are restricted.

   d. All SS- and SSE-format instructions are restricted.

   e. All of the following general instructions are restricted.

      - BRANCH RELATIVE ON CONDITION in which the \( M_1 \) field is nonzero and the \( R_{1_2} \) field contains a positive value
      - BRANCH RELATIVE ON CONDITION LONG in which the \( M_1 \) field is nonzero, and the \( R_{1_2} \) field contains a positive value that does not cause address wrap-around.
      - COMPARE AND BRANCH RELATIVE, COMPARE IMMEDIATE AND BRANCH RELATIVE, COMPARE LOGICAL AND BRANCH RELATIVE, and COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE in which the \( M_3 \) field is nonzero and the \( R_{1_4} \) field contains a positive value

      (that is, only forward branches with nonzero branch masks)

   c. Except for TRANSACTION END and instructions which cause a specific-operand serialization, instructions which cause a serialization function are restricted.

   d. All SS- and SSE-format instructions are restricted.

   e. All of the following general instructions are restricted.

      - BRANCH PREDICTION PRELOAD
      - BRANCH PREDICTION RELATIVE PRELOAD
      - CHECKSUM
      - CIPHER MESSAGE
      - CIPHER MESSAGE WITH CIPHER FEEDBACK
      - CIPHER MESSAGE WITH CHAINING
      - CIPHER MESSAGE WITH COUNTER
      - CIPHER MESSAGE WITH OUTPUT FEEDBACK
      - COMPARE AND FORM CODEWORD
      - COMPARE LOGICAL LONG, COMPARE LOGICAL LONG EXTENDED, and COMPARE LOGICAL LONG UNICODE
      - COMPARE LOGICAL STRING
      - COMPARE UNTIL SUBSTRING EQUAL
      - COMPRESSION CALL
      - COMPUTE INTERMEDIATE MESSAGE DIGEST
      - COMPUTE LAST MESSAGE DIGEST

---

Priority of Abort Condition

<table>
<thead>
<tr>
<th>Priority</th>
<th>Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>Any</td>
<td>Fetch overflow, store overflow, fetch conflict, store conflict, nesting-depth exceeded, cache fetch-related condition, cache store-related condition, cache other condition, miscellaneous condition</td>
</tr>
<tr>
<td>1</td>
<td>Exigent machine-check interruption</td>
</tr>
<tr>
<td>2</td>
<td>Program-interruption (filtered or unfiltered), restricted instruction</td>
</tr>
<tr>
<td>3</td>
<td>TRANSACTION ABORT instruction</td>
</tr>
<tr>
<td>4</td>
<td>Repressible machine check</td>
</tr>
<tr>
<td>5</td>
<td>External interruption</td>
</tr>
<tr>
<td>6</td>
<td>Input/output interruption</td>
</tr>
</tbody>
</table>

Figure 5-17. Priority of Abort Conditions
4. The transaction's storage operands access no more than four octowords. Note: LOAD ON CONDITION and STORE ON CONDITION are considered to reference storage regardless of the condition code.

5. The transaction executing on this CPU, or stores by other CPUs or the channel subsystem, do not access storage operands in any 4 K-byte blocks that contain the 256 bytes of storage beginning with the TRANSACTION BEGIN (TBEGINC) instruction.

6. The transaction does not access instructions or storage operands using different logical addresses that are mapped to the same absolute address.

7. Operand references made by each instruction in the transaction must be within a single double-word, except that for LOAD ACCESS MULTIPLE, LOAD MULTIPLE, LOAD MULTIPLE HIGH, STORE ACCESS MULTIPLE, STORE MULTIPLE, and STORE MULTIPLE HIGH, operand references must be within a single octoword.

If a constrained transaction violates any of constraints 1-7, listed above, then it is unpredictable whether a transaction-constraint program interruption is recognized. However, if a transaction-constraint program interruption is not recognized for one transaction-constraint violation, it may still be recognized for a subsequent violation within the same constrained transaction.

In the absence of constraint violations, repeated interruptions, or conflicts with other CPUs or the channel subsystem, a constrained transaction will eventually complete.

**Programming Notes:**

1. The chance of successfully completing a constrained transaction improves if the transaction meets the following criteria:

   a. The instructions issued are fewer than the maximum of 32.
b. The storage-operand references are fewer than the maximum of 4 octowords.

c. The storage-operand references are on the same cache line.

d. Storage-operand references to the same locations occur in the same order by all transactions.

2. A constrained transaction is not necessarily assured of successfully completing on its first execution. However, if a constrained transaction that does not violate any of the listed constraints is aborted, the CPU employs special circuitry to ensure that a repeated execution of the transaction is subsequently successful.

3. Within a constrained transaction, TRANSACTION BEGIN is a restricted instruction, thus a constrained transaction cannot be nested.

4. Violation of any of constraints 1-7 by a constrained transaction may result in a program loop.

---

**Monitor-Event Counting**

When the execution of a MONITOR CALL instruction causes a monitor event to occur, the enhanced-monitor facility is installed, and the enhanced-monitor-mask bit corresponding to the monitor class is one, a monitor-event counting operation is performed. See “MONITOR CALL” on page 7-243 for further details on the execution of the MONITOR CALL instruction.

The enhanced-monitor counter-array size contained in the word at real location 264, extended on the left with 32 binary zeros, is logically compared with the monitor code formed by the first-operand address. If the monitor code is greater than or equal to the enhanced-monitor counter-array size, then one is logically added to the enhanced-monitor exception count contained in the word at real location 268, and the instruction completes. Any carry as a result of this addition is ignored.

If the monitor code is less than the enhanced-monitor counter-array size (extended on the left with 32 zeros), then one is added to the enhanced-monitor counter corresponding to the monitor code. An enhanced-monitor counter comprises two discontiguous storage locations: an unsigned halfword which is incremented first, and an unsigned word which is incremented whenever a carry out of bit position 0 of the halfword addition occurs.

The enhanced-monitor counter-array origin in bits 0-60 of the doubleword at real location 256, appended on the right with three binary zeros, forms the 64-bit virtual address of the enhanced-monitor counter array in the home address space.

Although the enhanced-monitor counter array is located in the home address space (as designated by control register 13), the updating of a counter occurs regardless of whether DAT is on. The access to the counters may be performed with the use of the translation-lookaside buffer (TLB), and TLB entries may be formed, regardless of whether DAT is on.

The enhanced-monitor-counter-array-size field at real location 264 specifies the number of halfword and word entries in the array; the halfword entries in the array appear first, followed immediately by the word entries.

The monitor code multiplied by two is added to the enhanced-monitor-counter-array origin to form the virtual address of a halfword to which one is logically added. If this addition results in a carry out of bit position 0 of the halfword, then one is logically added to the corresponding word. The enhanced-monitor-counter-array-size value multiplied by two is added to the monitor code multiplied by four; this value is added to the enhanced-monitor counter-array origin to form the address of the word. Any carry in the word addition is ignored.

Key-controlled protection does not apply to any accesses made in the process of incrementing the counters. Any other access exception recognized in the process of incrementing the counters results in (a) one being logically added to the enhanced-monitor exception count contained in the word at real location 268, and (b) the instruction completing. Any carry as a result of this addition is ignored.

The word portion of a counter is accessed only if the addition of the corresponding halfword portion of the counter results in an overflow. If the addition of the halfword results in an overflow, the storing of the updated halfword is performed only if both the halfword and word portions of the counter are accessible.
Locations within the enhanced-monitor counter array that are accessed by an enhanced-monitor counting operation are subject to PER storage-alteration events; however, PER storage-alteration events do not apply to updates made to the exception counter. During an enhanced-monitor counting operation, a PER storage-alteration event is recognized only if all counter-array locations updated by the event are accessible.

Figure 5-18 illustrates the structures used in the monitor-event-counting operation.

```
Prefix Area

<table>
<thead>
<tr>
<th>0</th>
<th>64</th>
<th>96</th>
<th>127</th>
</tr>
</thead>
<tbody>
<tr>
<td>CAO</td>
<td>CAL</td>
<td>EC</td>
<td></td>
</tr>
</tbody>
</table>

Home Address Space

<table>
<thead>
<tr>
<th>0</th>
<th>16</th>
<th>32</th>
<th>48</th>
<th>64</th>
<th>80</th>
<th>96</th>
<th>112</th>
<th>127</th>
</tr>
</thead>
</table>

Explanation:

CAO Enhanced-monitor counter-array origin
CAL Enhanced-monitor counter-array size
EC Enhanced-monitor exception count
```

**Figure 5-18. Monitor-Event-Counting Structures**

**Programming Notes:**

1. It is recommended that the enhanced-monitor counter array be allocated on a cache-line boundary of the CPU's first-level data cache. The cache line size may be determined by the EXTRACT CPU ATTRIBUTES (ECAG) instruction.

2. The enhanced-monitor counters may be incremented using a non-interlocked update. Therefore, each enhanced-monitor counter array should be processor unique.

3. It is recommended that the enhanced-monitor counter-array be allocated in fixed storage such that dynamic-address-translation (DAT) exceptions do not occur when accessing the array.

**Sequence of Storage References**

The following sections describe the effects which can be observed in storage due to overlapped operations and piecemeal execution of a CPU program. Most of the effects described in these sections are observable only when two or more CPUs or channel programs are in simultaneous execution and access common storage locations. Thus, most of the effects need be taken into account by a program only if the program interacts with another CPU or a channel program.

Some of the effects described in the following sections are independent of interaction with another CPU or a channel program. These effects, which are therefore more readily observable, relate to prefetched instructions and overlapping operands of a single instruction. These effects are described in “Conceptual Sequence” and in “Interlocks for Virtual-Storage References” on page 5-113.

**Conceptual Sequence**

The CPU conceptually processes instructions one at a time, with the execution of one instruction preceding the execution of the following instruction. The execution of the instruction designated by a successful branch follows the execution of the branch. Similarly, an interruption takes place between instructions or, for interruptible instructions, between units of operation of such instructions.

The sequence of events implied by the processing just described is sometimes called the conceptual sequence.

Each operation of instruction execution appears to the program itself to be performed sequentially, with the current instruction being fetched after the preceding operation is completed and before the execution of the current operation is begun. This appearance is maintained even though the storage-implementation characteristics and overlap of instruction execution with storage accessing may cause actual processing to be different. The results generated are those that would have been obtained had the operations been performed in the conceptual sequence. Thus, it is
possible for an instruction to modify the next succeeding instruction in storage.

A case in which the copies of prefetched instructions are not necessarily discarded occurs when the fetch and the store are done by means of different effective addresses that map to the same real address. This case is described in more detail in “Interlocks for Virtual-Storage References” on page 5-113.

When the transactional-execution facility is installed, the CPU may appear to deviate from the conceptual sequence to the extent that when a transaction is aborted, the following may be visible by the program:

- Although transactional stores are discarded, stores made by the NONTRANSACTIONAL STORE instruction are observable by all CPUs and by the channel subsystem.
- General registers that were altered by the transaction, but not designated to be saved by the TRANSACTION BEGIN instruction, contain modified values
- Access registers, vector registers, and floating-point registers (including the floating-point-control register) that were altered by the transaction contain modified values.
- The breaking-event-address register may contain the address of a breaking-event instruction within the aborted transaction.
- While in the nonconstrained transactional-execution mode, if a CPU makes transactional and non-transactional stores to the same storage location, and the transaction then aborts, the contents of the storage location are unpredictable.

Exceptions to the conceptual-sequence ordering of instruction execution are as follows:

- The modification of ART and DAT table entries may not have immediate effect on the conceptual sequence. See “Modification of Translation Tables” on page 3-62, “Modification of DAT-Table Entries” on page 5-27, and “Modification of ART Tables” on page 5-67 for further details.
- To improve performance, a machine may speculatively execute multiple instructions — including multiple instruction paths — in parallel, discarding results from the speculatively-executed instructions that do not represent the conceptual sequence. Speculative execution may result in the formation of ALB and TLB entries, even though such entries might not be created in the conceptual sequence. However, TLB and ALB entries are not formed as a result of, or subsequent to, the execution of following instructions unless such execution occurs in the conceptual sequence:
  - BRANCH IN SUBSPACE GROUP
  - LOAD CONTROL that alters control registers 0, 1, 2, 5, 7, 8, or 13
  - LOAD PSW
  - LOAD PSW EXTENDED
  - LOAD PAGE TABLE ENTRY ADDRESS
  - LOAD REAL ADDRESS
  - MONITOR CALL that results in a monitor-counting operation
  - MOVE WITH OPTIONAL SPECIFICATIONS
  - PROGRAM CALL
  - PROGRAM RETURN
  - PROGRAM TRANSFER (WITH INSTANCE)
  - SET ADDRESS SPACE CONTROL
  - SET ADDRESS SPACE CONTROL FAST
  - SET SECONDARY ASN (WITH INSTANCE)
  - SET SYSTEM MASK
  - STORE REAL ADDRESS
  - STORE THEN AND SYSTEM MASK
  - STORE THEN OR SYSTEM MASK
  - TEST ACCESS

Overlapped Operation of Instruction Execution

In simple models in which operations are not overlapped, the conceptual and actual sequences are essentially the same. However, in more complex machines, overlapped operation, buffering of operands and results, and execution times which are comparable to the propagation delays between units can cause the actual sequence to differ considerably from the conceptual sequence. Except as noted below, these machines employ special circuitry to detect dependencies between operations and ensure that the results obtained, as observed by the CPU which generates them, are those that would have been obtained if the operations had been performed in the conceptual sequence. However, other CPUs and channel programs may, unless otherwise constrained, observe a sequence that differs from the conceptual sequence.
Divisible Instruction Execution
It can normally be assumed that the execution of each instruction occurs as an indivisible event. However, in actual operation, the execution of an instruction consists in a series of discrete steps. Depending on the instruction, operands may be fetched and stored in a piecemeal fashion, and some delay may occur between fetching operands and storing results. As a consequence, intermediate or partially completed results may be observable by other CPUs and by channel programs.

When a program interacts with the operation on another CPU, or with a channel program, the program may have to take into consideration that a single operation may consist in a series of storage references, that a storage reference may in turn consist in a series of accesses, and that the conceptual and observed sequences of these accesses may differ.

Storage references associated with instruction execution are of the following types: instruction fetches, ART-table and DAT-table fetches, and storage-operand references. For the purpose of describing the sequence of storage references, accesses to storage in order to perform ASN translation, PC-number translation, tracing, and the linkage-stack stacking and unstacking processes are considered to be storage-operand references.

Programming Note: The sequence of execution of a CPU may differ from the simple conceptual definition in the following ways:

- As observed by the CPU itself, instructions may appear to be prefetched when different effective addresses are used. (See “Interlocks for Virtual-Storage References”.)
- As observed by other CPUs and by channel programs, the execution of an instruction may appear to be performed as a sequence of piecemeal steps. This is described for each type of storage reference in the following sections.
- As observed by other CPUs and by channel programs, the storage-operand accesses associated with one instruction are not necessarily performed in the conceptual sequence. (See “Relation between Operand Accesses” on page 5-126.)
- As observed by channel programs, in certain unusual situations, the contents of storage may appear to change and then be restored to the original value. (See “Storage Change and Restoration for DAT-Associated Access Exceptions” on page 5-27.)

Interlocks for Virtual-Storage References
As described in the immediately preceding sections, CPU operation appears, with certain exceptions, to be performed sequentially as observed by the CPU itself; the stores performed by one instruction generally appear to be completed before the next instruction and its operands are fetched. This appearance is maintained in overlapped machines by means of interlock circuitry that detects accesses to a common storage location.

For those instructions which alter the contents of storage and have more than one operand, the instruction definition normally describes the results that are obtained when the operands overlap in storage, this definition being in terms of a sequence of stores and fetches. The interlock circuitry is used in determining whether operand overlap exists.

The purpose of this section is to define those cases in which the machine must appear to operate sequentially, and in which operands of a single instruction must or must not be treated as overlapping.

Proper operation is provided in part by comparing effective addresses. For the purpose of this definition, the term “effective address” means an address before translation, if any, regardless of whether the address is virtual, real, or absolute. If two effective addresses have the same value, the effective addresses are said to be the same even though one may be real or in a different address space.

The values of two virtual effective addresses do not necessarily indicate whether or not the addresses designate the same storage location. The address-translation tables may be set up so that different effective addresses map to the same real address, or so that the same effective address in different address spaces maps to different real addresses.

The interlocks for virtual-storage references are considered in two situations: storage references of one instruction as they affect storage references of
another instruction, and multiple storage references of a single instruction.

Interlocks between Instructions
Except as described below, as observed by the CPU itself, the storage accesses for operands for each instruction appear to occur in the conceptual sequence independent of the effective address used. That is, the operand stores for one instruction appear to be completed before the operand fetches for the next instruction occur. For instruction fetches, the operand stores for one instruction necessarily appear to be completed before the next instruction is fetched only when the same effective address is used for the operand store and the instruction fetch.

When an instruction changes the contents of a main-storage location in which a conceptually subsequent instruction is to be executed, either directly or by means of an execute-type instruction, and when different effective addresses are used to designate that location for storing the result and fetching the instruction, the instruction may appear to be fetched before the store occurs. If an intervening operation causes the prefetched instructions to be discarded, then the updated value is recognized. A definition of when prefetched instructions must be discarded is included in “Instruction Fetching” on page 5-116.

Any change to the storage key appears to be completed before the conceptually following reference to the associated storage block is made, regardless of whether the reference to the storage location is made by means of a virtual, real, or absolute address. Analogously, any conceptually prior references to the storage block appear to be completed when the key for that block is changed or inspected.

When the CPU is in the transactional-execution mode, and an instruction changes the contents of a main-storage location from which a conceptually subsequent instruction may be fetched, the transaction may be aborted with any of abort codes 14, 15, 16, or 255 and condition code 3.

Programming Note: Depending on the model, detection of a changed storage location may include any location within the same or adjacent cache lines as that of the store, regardless of whether the changed location is actually an instruction. Because of the characteristics described above and in the preceding paragraph, self-modifying code within a transaction is strongly discouraged.

Interlocks within a Single Instruction
For those instructions which alter the contents of storage and have more than one operand, the instruction definition normally describes the results which are obtained when the operands overlap in storage. This result is normally defined in terms of the sequence of the storage accesses; that is, a portion of the results of a store-type operand must appear to be placed in storage before some portion of the other operand is fetched. This definition applies provided that the store and fetch accesses are specified by means of the same effective addresses and the same effective space designations.

When multiple address spaces are involved in the access-register mode, the term “effective space designation” is used to denote the value used by the machine to determine whether two spaces are the same. In the access-register mode, the 32-bit access-list-entry-token (ALET) value associated with each storage_operand address is called the effective space designation. When a B field of zero is specified, a value of all zeros is used for the effective space designation. If the effective space designations are different, the spaces are considered to be different even if both ALETs map to the same address-space-control-element value.

When the store and the fetch accesses are specified by means of different effective space designations or by means of different effective addresses, the operand fetch may appear to precede the operand store.

Figure 5-19 on page 5-115 summarizes the cases of overlap and the specified results, including when
MOVE LONG (MVCL) sets condition code 3, for each case.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Yes</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td></td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>No</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>No</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td></td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
</tbody>
</table>

Explanation:
– This case cannot occur.

Figure 5-19. Virtual-Storage Interlocks within a Single Instruction

Effective space designations may be represented by ALB entries, and the test for whether two effective space designations are the same may be performed by comparing ALB entries. If the program changes an attached and valid ART-table entry without subsequently causing the execution of PURGE ALB or a COMPARE AND SWAP AND PURGE instruction that purges the ALB, two effective space designations that are the same may have different representations in the ALB, and failure to recognize operand overlap may result. The use of the ALB never causes overlap to be recognized when the effective space designations are different.

Programming Note: A single main-storage location can be accessed by means of more than one address in several ways:

1. The DAT tables may be set up such that multiple addresses in a single address space, or addresses in different address spaces, including the real address specified by a real-space designation, map to a single real address.

2. The translation of logical, instruction, and virtual addresses may be changed by loading the DAT parameters in the control registers, by changing the address-space-control bits in the PSW, or, for logical and instruction addresses, by turning DAT on or off.

3. In the access-register mode, different address spaces may be selected by means of each access register. In addition, the primary address space is selected for instruction fetching and the target of an execute-type instruction.

4. STORE USING REAL ADDRESS performs a store by means of a real address.

5. Certain other instructions also use real addresses (even when a logical address is not translated by means of a real-space designation, which is a situation covered in case 1), the instructions MOVE TO PRIMARY and MOVE TO SECONDARY access two address spaces, and the instruction MOVE WITH OPTIONAL SPECIFICATIONS may access one or two address spaces.

6. Accesses to storage for the purpose of storing and fetching information for interruptions is performed by means of real addresses, and, for the store-status function, by means of absolute addresses, whereas accesses by the program may be by means of virtual addresses.

7. The real-to-absolute mapping may be changed by means of the SET PREFIX instruction or a reset.

8. A main-storage location may be accessed by channel programs by means of an absolute address and by the CPU by means of an absolute, a real, or a virtual address.
9. A main-storage location may be accessed by another CPU by means of one type of address and by this CPU by means of a different type of address.

The primary purpose of this section on interlocks is to describe the effects caused in cases 1, 3, and 4, above.

For case 2, no effect is observable because prefetched instructions are discarded when the translation parameters are changed, and the delay of stores by a CPU is not observable by the CPU itself.

For case 5, for those instructions which fetch by using real addresses (for example, LOAD REAL ADDRESS, which fetches a segment-table entry and a page-table entry, and may fetch a region-table entry), no effect is observable because only operand accesses between instructions are involved. All instructions that store by using a real address, except STORE USING REAL ADDRESS, or that store across address spaces, except in the access-register mode, cause prefetched instructions to be discarded, and no effect is observable.

Cases 6 and 7 are situations which are defined to cause serialization, with the result that prefetched instructions are discarded. In these cases, no effect is observable.

The handling of cases 8 and 9 involves accesses as observed by other CPUs and by channel programs and is covered in the following sections in this chapter.

### Instruction Fetching

Instruction fetching consists in fetching the one, two, or three halfwords designated by the instruction address in the current PSW. The immediate field of an instruction is accessed as part of an instruction fetch. If, however, an instruction designates a storage operand at the location occupied by the instruction itself, the location is accessed both as an instruction and as a storage operand. The fetch of the target instruction of an execute-type instruction is considered to be an instruction fetch.

The bytes of an instruction may be fetched piecemeal and are not necessarily accessed in a left-to-right direction. The instruction may be fetched multiple times for a single execution; for example, it may be fetched for testing the addressability of operands or for inspection of PER events, and it may be refetched for actual execution.

Instructions are not necessarily fetched in the sequence in which they are conceptually executed and are not necessarily fetched each time they are executed. In particular, the fetching of an instruction may precede the storage-operand references for an instruction that is conceptually earlier. The instruction fetch occurs prior to all storage-operand references for all instructions that are conceptually later.

An instruction may be prefetched by using a virtual address only when the associated DAT table entries are attached and valid or when entries which qualify for substitution for the table entries exist in the TLB. An instruction that has been prefetched may be interpreted for execution only for the same virtual address for which the instruction was prefetched.

No limit is established on the number of instructions which may be prefetched, and multiple copies of the contents of a single storage location may be fetched. As a result, the instruction executed is not necessarily the most recently fetched copy. Storing caused by other CPUs and by channel programs does not necessarily change the copy of prefetched instructions. However, if a store that is conceptually earlier is made by the same CPU using the same effective address as that by which the instruction is subsequently fetched, the updated information is obtained, except as noted below. If the effective addresses are different, the updated information is not necessarily obtained. However, the updated information is obtained if either execution is in the real mode since prefetched instructions are discarded if DAT is turned on or off.

All copies of prefetched instructions are discarded when:

- A serializing function is performed. However, for PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, SET SECONDARY ASN WITH INSTANCE, and TRACE, it is unpredictable whether or not a store into a trace-table entry from which a subsequent instruction is fetched will be observed by the CPU that performed the store; for PROGRAM CALL and PROGRAM RETURN it is unpredictable whether or not a store into a trace-table entry or linkage-stack entry from which a subsequent instruction is fetched will be observed by
the CPU that performed the store. Additionally, when the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register 0 is one, it is unpredictable whether explicit tracing causes serialization to be performed.

- The CPU enters the operating state.
- DAT is turned on or off.
- A change is made to a translation parameter in control register 1 when in the primary-space, secondary-space, or access-register mode, or in control register 13 when in the home-space mode.

The SET ADDRESS SPACE CONTROL instruction can change the translation mode between any of the primary-space, secondary-space, access-register, and home-space modes, and it performs serialization. The SET ADDRESS SPACE CONTROL FAST instruction can perform the same mode changes, but it does not serialize.

Programming Notes:

1. As observed by a CPU itself, its own instruction prefetching may be apparent when different effective addresses map to a single real address. This is described in “Conceptual Sequence” on page 5-111 and “Interlocks for Virtual-Storage References” on page 5-113.

2. Any means of changing PSW bits 16 and 17, except the SET ADDRESS SPACE CONTROL FAST instruction, causes serialization to be performed and prefetched instructions to be discarded. Turning DAT on or off causes prefetched instructions to be discarded. Therefore, any change of the translation mode, except a change made by SET ADDRESS SPACE CONTROL FAST, always causes prefetched instructions to be discarded.

3. The following are some effects of instruction prefetching on one CPU as observed by other CPUs and by channel programs.

   It is possible for one CPU to prefetch the contents of a storage location, after which another CPU or a channel program can change the contents of that storage location and then set a flag to indicate that the change has been made. Subsequently, the first CPU can test and find the flag set, branch to the modified location, and execute the original prefetched contents.

   It is possible, if another CPU or a channel program concurrently modifies the instruction, for one CPU to recognize the changes to some but not all bit positions of an instruction.

   It is possible for one CPU to prefetch an instruction and subsequently, before the instruction is executed, for another CPU to change the storage key. As a result, the first CPU may appear to execute instructions from a protected storage location. However, the copy of the instructions executed is the copy prefetched before the location was protected.

4. Previous versions of both the ESA/390 Principles of Operation and the z/Architecture Principles of Operation have allowed a CPU to not recognize a store into the instruction stream when the CPU was operating in the home-space or access-register modes. To ensure that stores into the instruction stream were recognized in these modes, the program was required to insert a serializing operation following the store.

   No IBM processor has ever implemented this characteristic; stores into the instruction stream using the same effective address as that by which a subsequent instruction is fetched have always been recognized, regardless of the address-space-control mode. This characteristic is now removed from the architecture. Any serializing operations that were inserted to ensure recognition of stores into the instruction stream while in the AR or home-space modes may be safely removed from programs that execute on IBM processors.

ART-Table and DAT-Table Fetched

The access-register-translation (ART) table entries are access-list designations, access-list entries, ASN-second-table entries, and authority-table entries. The dynamic-address-translation (DAT) table entries are region-table entries, segment-table entries, and page-table entries. The fetching of these entries may occur as follows:

1. An ART-table entry may be prefetched into the ART-lookaside buffer (ALB) and used from the ALB without refetching from storage, until the entry is cleared by a COMPARE AND SWAP
AND PURGE, PURGE ALB, or SET PREFIX instruction, by CPU reset, or by a set prefix or set-architecture SIGNAL PROCESSOR order. A DAT-table entry may be prefetched into the translation-lookaside buffer (TLB) and used from the TLB without refetching from storage, until the entry is cleared by a COMPARE AND REPLACE DAT TABLE ENTRY, COMPARE AND SWAP AND PURGE, INVALIDATE DAT TABLE ENTRY, INVALIDATE PAGE TABLE ENTRY, PURGE TLB, or SET PREFIX instruction, by CPU reset, or by a set prefix or set-architecture SIGNAL PROCESSOR order. ART-table and DAT-table entries are not necessarily fetched in the sequence conceptually called for; they may be fetched at any time they are attached and valid, including during the execution of conceptually previous instructions.

2. The fetching of access-list designations, access-list entries, ASN-second-table entries, and DAT-table entries appears to be word concurrent as observed by other CPUs, except that the fetching of an address-space-control element from an ASN-second-table entry appears to be double-word concurrent as observed by other CPUs. The reference to an entry may appear to access a single byte at a time as observed by channel programs.

3. The order in which the words of an access-list entry or ASN-second-table entry are fetched is unpredictable, except that the leftmost word of an entry is fetched first. However, the leftmost word of an ASN-second-table entry is not fetched when access-list-entry token 00000000 hex is translated for BRANCH IN SUBSPACE GROUP.

4. An ART-table or DAT-table entry may be fetched even after some operand references for the instruction have already occurred. The fetch may occur as late as just prior to the actual byte access requiring the ART-table or DAT-table entry.

5. An ART-table or DAT-table entry may be fetched for each use of the address, including any trial execution, and for each reference to each byte of each operand.

6. The DAT page-table-entry fetch precedes the reference to the page. When no copy of the page-table entry is in the TLB, the fetch of the region-third-table entry, if one is required, precedes the fetch of the segment-table entry. Similarly, the fetch of a required region-second-table entry precedes the fetch of the region-first-table entry, and the fetch of a required region-first-table entry precedes the fetch of the region-second-table entry.

7. When no copy of a region-table entry or segment-table entry designated by means of an ART-obtained address-space-control element is in the TLB, the ART fetch of the ASN-second-table entry precedes the DAT region-table-entry or segment-table-entry fetch. When no copy of a required authority-table entry is in the ALB, the ART fetch of the associated ASN-second-table entry precedes the fetch of the authority-table entry. When no copy of a required ASN-second-table entry is in the ALB, the fetch of the associated access-list entry precedes the fetch of the ASN-second-table entry. When no copy of a required access-list entry is in the ALB, the fetch of the associated access-list designation precedes the fetch of the access-list entry.

Storage-Key Accesses

In the following sections, the term key-setting instruction refers either to the SET STORAGE KEY EXTENDED instruction or to the PERFORM FRAME MANAGEMENT FUNCTION instruction when the set-key control is one. When the nonquiescing key-setting facility is installed, a nonquiescing key-setting instruction refers to a SET STORAGE KEY EXTENDED instruction in which the nonquiescing control is set to one and also refers to a PERFORM FRAME MANAGEMENT FUNCTION instruction in which the set-key control is set to one. (For PFMF, it is unpredictable whether a quiescing operation is performed when the nonquiescing key-setting facility is installed; thus in the following discussion, PFMF may be considered to be either quiescing or nonquiescing.)

References to the storage key are handled as follows:

1. Whenever a reference to storage is made and key-controlled protection applies to the reference, the four access-control bits and the fetch-protection bit associated with the storage location are inspected concurrently. The inspection of
the access-control and fetch-protection bits occurs concurrently with the reference to the storage location, except that when a nonquiescing key-setting operation is performed for a storage location by one CPU, the following applies:

- The inspection of the access-control and fetch-protection bits for the storage location by any CPU may precede a store reference to the location. In the case where the inspection of the access-control and fetch-protection bits precedes the store, the inspection occurs no earlier than after the last serialization operation on the CPU, and no earlier than the last quiescing key-setting operation for the same storage location on any CPU.

- When a unit of operation or instruction execution on any other CPU causes multiple accesses to the same 4 K-byte block as that of the key-setting operation, the other CPU necessarily inspects the access-control and fetch-protection bits only for the first reference to the block. The other CPU does not necessarily inspect the access-control and fetch-protection bits for the subsequent accesses within the block by the same unit of operation.

When (a) EDAT-1 does not apply, (b) EDAT-1 applies but the storage is accessed by means of a segment-table entry in which the STE-format control is zero, (c) EDAT-1 applies, the storage is accessed by means of a segment-table entry in which the STE-format control is one, but the ACCF-validity control is zero, or (d) EDAT-2 applies, the storage is accessed by means of a region-third-table entry in which the RTTE-format control is one, but the ACCF-validity control is zero, the access-control bits and the fetch-protection bit are in bits 0-4 of the storage key for the 4K-byte block.

When EDAT-2 applies and the storage is accessed by means of a region-third-table entry in which both the RTTE-format control and ACCF-validity control are one, it is unpredictable whether bits 0-4 of the storage key or bits 48-52 of the region-third-table entry provide the access-control bits and fetch-protection bit. Furthermore, when the region-third-table entry provides the access-control bits and fetch-protection bit, a buffered copy from the translation-lookaside buffer may be used.

For accesses made by the channel subsystem, the access-control bits and fetch-protection bits are in bits 0-4 of the storage key for the 4K-byte block.

2. When storing is performed by a CPU, the change bit is set to one in the associated storage key concurrently with the completion of the store access, as observed by the CPU itself. When storing is performed by a CPU or a channel program, the change bit is set to one in the associated storage key either before or after the completion of the store access, as observed by other (if the store was performed by a CPU) or all (if the store was performed by a channel program) CPUs. As observed by other or all CPUs, the change bit is set no earlier than (1) after the last serialization function performed previously by the CPU or channel program performing the store, and (2) after the execution, by any CPU in the configuration, of a quiescing key-setting instruction that last set the associated storage key before the completion of the store. As observed by other or all CPUs, a change-bit setting necessarily occurs only when any of the following occurs subsequent to the storing operation:

- The CPU or channel program that performed the store performs a serialization function.

- The store was performed by a CPU or a channel program, and any CPU in the configuration sets the subject change bit by executing a key-setting instruction after the store access is completed. The change-bit setting due to the store access occurs before the setting by the key-setting instruction, except that when the nonquiescing key-setting facility is installed, the change bit may appear to be set following a nonquiescing key-setting instruction.

---

• The store was performed by a CPU and is or will be completed, and any CPU in the configuration executes a COMPARE AND REPLACE DAT TABLE ENTRY, COMPARE AND SWAP AND PURGE, INVALIDATE DAT TABLE ENTRY, or INVALIDATE PAGE TABLE ENTRY instruction that clears from the ALB or TLB of the storing CPU any entry used to complete the store. Completion of the clearing instruction is delayed until the subject store and change-bit setting have been completed.

• The store was performed by a CPU, and that CPU examines the subject change bit by means of an INSERT STORAGE KEY EXTENDED or RESET REFERENCE BIT EXTENDED instruction. See “Relation between Operand Accesses” on page 5-126.

3. When the conditional-SSKE facility is not installed, the SET STORAGE KEY EXTENDED instruction causes all seven bits to be set concurrently in the storage key. When the conditional-SSKE facility is installed, SET STORAGE KEY EXTENDED may be used to set all or portions of the storage key based on program-specified criteria. The access to the storage key for SET STORAGE KEY EXTENDED follows the sequence rules for storage-operand store references and is a single-access reference. When the enhanced-DAT facility is installed, SET STORAGE KEY EXTENDED or PERFORM FRAME MANAGEMENT FUNCTION may be used to set all or portions of one or more storage keys based on program-specified criteria.

4. The INSERT STORAGE KEY EXTENDED instruction provides a consistent image of bits 0-6 of the storage key for a 4K-byte block. Similarly, the instructions INSERT VIRTUAL STORAGE KEY and TEST PROTECTION provide a consistent image of the access-control bits and the fetch-protection bit. The access to the storage key for all of these instructions follows the sequence rules for storage-operand fetch references and is a single-access reference.

5. The instruction RESET REFERENCE BIT EXTENDED modifies only the reference bit. All other bits of the storage key remain unchanged. The reference bit and change bit are inspected concurrently to set the condition code. The fetch and store accesses to the storage key for RESET REFERENCE BIT EXTENDED follow the sequence rules for storage-operand fetch and store references, respectively, and are single-access references.

6. For each of the 64 storage keys accessed, the instruction RESET REFERENCE BITS MULTIPLE modifies only the reference bit. All other bits of the storage key remain unchanged. The fetch and store accesses to each of the individual storage keys for RESET REFERENCE BITS MULTIPLE follow the sequence rules for storage-operand fetch and store references, respectively, and are single-access references.

The record of references provided by the reference bit is not necessarily accurate. However, in the majority of situations, reference recording approximately coincides with the related storage reference.

The change bit may be set in cases when no storing has occurred. See “Exceptions to Nullification and Suppression” on page 5-26.

Programming Note: When a nonquiescing key-setting instruction is executed on one CPU to set the storage key of a block, the program should ensure that no other CPU or I/O subsystem is simultaneously referencing the storage block in which the key is being set. In a virtual storage environment, the program can ensure that other CPUs do not access the block using a virtual address by simply not mapping the block to any virtual address.

Failure to comply with this restriction may result in either of the following:

• An unpredictable storage key for the block may be used in the enforcement of key-controlled protection.
• An unpredictable storage key for the block may be inspected by key-inspecting instructions such as ISKE, IVSK, and RRBE.

Storage-Operand References

A storage-operand reference is the fetching or storing of the explicit operand or operands in the storage locations designated by the instruction.

During the execution of an instruction, all or some of the storage operands for that instruction may be fetched, intermediate results may be maintained for subsequent modification, and final results may be
temporarily held prior to placing them in storage. Stores caused by other CPUs and by channel programs do not necessarily affect these intermediate results.

Storage-operand references are of three types: fetches, stores, and updates.

**Storage-Operand Fetch References**

When the bytes of a storage operand participate in the instruction execution only as a source, the operand is called a fetch-type operand, and the reference to the location is called a storage-operand fetch reference. A fetch-type operand is identified in individual instruction definitions by indicating that the access exception is for fetch.

All bits within a single byte of a fetch-type operand are accessed concurrently. When an operand consists of more than one byte, the bytes may be fetched from storage piecemeal, one byte at a time. Unless otherwise specified, the bytes are not necessarily fetched in any particular sequence.

The storage-operand fetch references of one instruction occur after those of all preceding instructions and before those of subsequent instructions, as observed by other CPUs and by channel programs. The operands of any one instruction are fetched in the sequence specified for that instruction. The CPU may fetch the operands of instructions before the instructions are executed. There is no defined limit on the length of time between when an operand is fetched and when it is used. Still, as observed by the CPU itself, its storage-operand references are performed in the conceptual sequence.

For certain special instructions, the fetch references for multiple operands may appear to be interlocked against certain accesses by other CPUs and by channel programs. Such a fetch reference is called an interlocked-fetch reference. The fetch accesses associated with an interlocked-fetch reference do not necessarily occur one immediately after the other, but store accesses by other CPUs may not occur at the same locations as the interlocked-fetch reference between the fetch accesses of the interlocked-fetch reference.

The storage-operand fetch reference for the LOAD PAIR DISJOINT instruction may be an interlocked-fetch reference. Whether or not LOAD PAIR DISJOINT is able to fetch both operands by means of an interlocked fetch is indicated by the condition code.

**Storage-Operand Store References**

When the bytes of a storage operand participate in the instruction execution only as a destination, to the extent of being replaced by the result, the operand is called a store-type operand, and the reference to the location is called a storage-operand store reference.

A store-type operand is identified in individual instruction definitions by indicating that the access exception is for store.

All bits within a single byte of a store-type operand are accessed concurrently. When an operand consists of more than one byte, the bytes may be placed in storage piecemeal, one byte at a time. Unless otherwise specified, the bytes are not necessarily stored in any particular sequence.

The CPU may delay placing results in storage. There is no defined limit on the length of time that results may remain pending before they are stored. This delay does not affect the sequence in which results are placed in storage.

With the exceptions noted below, the results of one instruction are placed in storage after the results of all preceding instructions have been placed in storage and before any results of the succeeding instructions are stored, as observed by other CPUs and by the channel subsystem. However, the following exception cases exist:

- When a transaction aborts, only the results of non transactional stores are committed to storage; transactional stores are discarded.

The results of any one instruction are stored in the sequence specified for that instruction.

The CPU does not fetch operands, ART-table entries, or DAT-table entries from a storage location until all information destined for that location by the CPU has been stored. Prefetched instructions may appear to be updated before the information appears in storage.

The stores are necessarily completed only as a result of a serializing operation and before the CPU enters the stopped state.
Storage-Operand Update References

In some instructions, the storage-operand location participates both as a source and as a destination. In these cases, the reference to the location consists first in a fetch and subsequently in a store. The operand is called an update-type operand, and the combination of the two accesses is referred to as an update reference. Instructions such as MOVE ZONES, TRANSLATE, OR (OC, OI), and ADD DECIMAL cause an update to the first-operand location. An update-type operand is identified in the individual instruction definition by indicating that the access exception is for both fetch and store.

Noninterlocked-Update References: For most instructions which have update-type operands, the fetch and store accesses associated with an update reference do not necessarily occur one immediately after the other, and it is possible for other CPUs and channel programs to make fetch and store accesses to the same location during this time. Such an update reference is sometimes called a noninterlocked-update storage reference.

Interlocked-Update References: For certain special instructions, the update reference is interlocked against certain accesses by other CPUs and channel programs. Such an update reference is called an interlocked-update reference. The fetch and store accesses associated with an interlocked-update reference do not necessarily occur one immediately after the other, but all store accesses by other CPUs and channel programs and the fetch and store accesses associated with interlocked-update references by other CPUs are prevented from occurring at the same location between the fetch and the store accesses of an interlocked-update reference.

The storage-operand update reference for the following instructions appears to be an interlocked-update reference as observed by other CPUs and channel programs.

- ADD IMMEDIATE (ASI and AGSI), when the interlocked-access facility 1 is installed and the first operand is aligned on an integral boundary corresponding to its size
- ADD LOGICAL WITH SIGNED IMMEDIATE, when the interlocked-access facility 1 is installed and the first operand is aligned on an integral boundary corresponding to its size
- AND (NI and NIY), when the interlocked-access facility 2 is installed
- COMPARE AND SWAP
- COMPARE AND SWAP AND PURGE
- COMPARE AND SWAP AND STORE
- COMPARE DOUBLE AND SWAP
- EXCLUSIVE OR (XI and XIY), when the interlocked-access facility 1 is installed
- LOAD AND ADD
- LOAD AND ADD LOGICAL
- LOAD AND AND
- LOAD AND EXCLUSIVE OR
- LOAD AND OR
- OR (OI and OIY), when the interlocked-access facility 1 is installed
- STORE CHARACTERS UNDER MASK, on models in which the instruction with a mask of zero fetches and stores the byte designated by the second-operand address
- TEST AND SET

Within the limitations of the above requirements, the fetch and store accesses associated with an update reference follow the same rules as the fetches and stores described in the previous sections.

Programming Notes:

1. When two CPUs attempt to update information at a common main-storage location by means of a noninterlocked-update reference, it is possible for both CPUs to fetch the information and subsequently make the store access. The change made by the first CPU to store the result in such a case is lost. Similarly, if one CPU updates the contents of a field by means of a noninterlocked-update reference, but another CPU makes a store access to that field between the fetch and store parts of the update reference, the effect of the store is lost. If, instead of a store access, a CPU makes an interlocked-update reference to the common storage field between the fetch and store portions of a noninterlocked-update reference due to another CPU, any change in the contents produced by the interlocked-update reference is lost.

2. Except for STORE CHARACTERS UNDER MASK, the instructions listed in this section ("Interlocked-Update References") facilitate updating of a common storage field by two or more CPUs. To ensure that no changes are lost, all CPUs must use an instruction providing an interlocked-update reference.

3. Only those bytes which are included in the result field of both operations are considered to be part
of the common main-storage location. However, all bits within a common byte are considered to be common even if the bits modified by the two operations do not overlap. As an example, if (1) one CPU executes the instruction OR (OC) with a length of 1 and the value 80 hex in the second-operand location, (2) the other CPU executes AND (NC) with a length of 1 and the value FE hex in the second-operand location, and (3) the first operand of both instructions is the same byte, then the result of one of the updates can be lost. This is because the updates to the byte by both NC and OC are not interlocked-update references.

4. When the store access is part of an update reference by the CPU, the execution of the storing is not necessarily contingent on whether the information to be stored is different from the original contents of the location. In particular, the contents of all designated byte locations are replaced, and, for each byte in the field, the entire contents of the byte are replaced.

Depending on the model, an access to store information may be performed, for example, in the following cases:

a. Execution of the OR instruction (OI, OIY, or OC) with a second operand of all zeros.

b. Execution of OR (OC) with the first-and second-operand fields coinciding.

c. For those locations of the first operand of TRANSIMATE where the argument and function values are the same.

Storage-Operand Consistency

Single-Access References
A fetch reference is said to be a single-access reference if the value is fetched in a single access to each byte of the data field. In the case of overlapping operands, the location may be accessed once for each operand. A store-type reference is said to be a single-access reference if a single store access occurs to each byte location within the data field. An update reference is said to be single access if both the fetch and store accesses are each single access.

Except for the accesses associated with multiple-access references and the stores associated with storage change and restoration for DAT-associated access exceptions, all storage-operand references are single-access references.

Multiple-Access References
In some cases, multiple accesses may be made to all or some of the bytes of a storage operand. The following cases may involve multiple-access references:

1. The storage operands of the following instructions:
   - CHECKSUM
   - CIPHER MESSAGE
   - CIPHER MESSAGE WITH CIPHER FEEDBACK
   - CIPHER MESSAGE WITH CHAINING
   - CIPHER MESSAGE WITH COUNTER
   - CIPHER MESSAGE WITH OUTPUT FEEDBACK
   - COMPARE AND FORM CODEWORD
   - COMPARE UNTIL SUBSTRING EQUAL
   - COMPUTE INTERMEDIATE MESSAGE DIGEST
   - COMPUTE LAST MESSAGE DIGEST
   - COMPUTE MESSAGE AUTHENTICATION CODE
   - CONVERT FROM PACKED
   - CONVERT FROM ZONED
   - CONVERT TO BINARY
   - CONVERT TO DECIMAL
   - CONVERT TO PACKED
   - CONVERT TO ZONED
   - CONVERT UTF-16 TO UTF-32
   - CONVERT UTF-16 TO UTF-8
   - CONVERT UTF-32 TO UTF-16
   - CONVERT UTF-32 TO UTF-8
   - CONVERT UTF-8 TO UTF-16
   - CONVERT UTF-8 TO UTF-32
   - LOAD ADDRESS SPACE PARAMETERS
   - LOAD REVERSED
   - MOVE INVERSE
   - MOVE LONG UNICODE
   - MOVE PAGE
   - MOVE WITH OFFSET
   - PACK
   - PACK ASCII
   - PACK UNICODE
   - PERFORM CRYPTOGRAPHIC COMPUTATION
   - PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION
   - PERFORM FRAME MANAGEMENT FUNCTION, when the clear-frame control is one
• PERFORM PSEUDORANDOM NUMBER OPERATION
• RESUME PROGRAM
• STORE REVERSED
• STORE SYSTEM INFORMATION
• TEST BLOCK
• TRANSLATE
• TRANSLATE AND TEST
• TRANSLATE AND TEST EXTENDED
• TRANSLATE AND TEST REVERSE
• TRANSLATE AND TEST REVERSE EXTENDED
• TRANSLATE EXTENDED
• TRANSLATE ONE TO ONE
• TRANSLATE ONE TO TWO
• TRANSLATE TWO TO ONE
• TRANSLATE TWO TO TWO
• UNPACK
• UNPACK ASCII
• UNPACK UNICODE
• UPDATE TREE

2. The storage operands of MOVE LONG and MOVE LONG EXTENDED, when the padding character is not B1 hex.

3. The stores into that portion of the first operand of MOVE LONG, MOVE LONG EXTENDED, or MOVE LONG UNICODE which is filled with padding bytes.

4. The storage operands of the decimal instructions.

5. The main-storage operands of PAGE IN and PAGE OUT.

6. The storage operands of the I/O instructions.

7. The stores into a trace entry.

8. The stores associated with the stop-and-store-status and store-status-at-address SIGNAL PROCESSOR orders.

9. The trap control block and trap save area used by TRAP.

10. The operands, dictionaries, and symbol-translation table of COMPRESSION CALL.

Programming Notes:

1. When multiple fetch or store accesses are made to a single byte that is being changed by another CPU or by a channel program, the result is not necessarily limited to that which could be obtained by fetching or storing the bits individually. For example, the execution of MULTIPLY DECIMAL may consist in repetitive additions and subtractions, each of which causes the second operand to be fetched from storage and the first operand to be updated in storage.

2. When CPU instructions which make multiple-access references are used to modify storage locations being simultaneously accessed by another CPU or by a channel program, multiple store accesses to a single byte by the CPU may result in intermediate values being observed by the other CPU or by the channel program. To avoid these intermediate values (for example, when modifying a CCW chain), only instructions making single-access references should be used.

3. An instruction fetch, including the fetch of the target of an execute-type instruction, is a multiple-access reference.

Block-Concurrent References

For some references, the accesses to all bytes within a halfword, word, doubleword, or quadword are specified to appear to be block concurrent as observed by other CPUs and channel programs. The halfword, word, doubleword, or quadword is referred to in this section as a block. When a fetch-type reference is specified to appear to be concurrent within a block, no store access to the block by another CPU or channel program is permitted during the time that bytes contained in the block are being fetched. When a store-type reference is specified to appear to be concurrent within a block, no access to the block, either fetch or store, is permitted by another CPU or channel program during the time that the bytes within the block are being stored.

For all instructions in the RX, RXE, RXY, S, SIL, SIY, VRV, and VRX formats, with the exception of CONVERT TO DECIMAL, CONVERT TO BINARY, LOAD PSW EXTENDED, LOAD REVERSED, RESUME PROGRAM, STORE CLOCK EXTENDED, STORE REVERSED, STORE SYSTEM INFORMATION, TRAP, VECTOR LOAD, VECTOR LOAD TO BLOCK BOUNDARY, VECTOR STORE, and the I/O instruc-
tions, when the operand is addressed on a boundary which is integral to the size of the operand, the storage-operand references appear to be block concurrent as observed by other CPUs. For LOAD PSW EXTENDED, the accesses to each of the two double-words of the storage operand appear to be double-word concurrent as observed by other CPUs.

For the instructions VECTOR LOAD, VECTOR LOAD MULTIPLE, VECTOR LOAD TO BLOCK BOUNDARY, VECTOR STORE, and VECTOR STORE MULTIPLE, when the operand is addressed on an integral block boundary up to eight bytes, the storage-operand references appear to be block concurrent with respect to that integral block boundary. Note that integral boundaries greater than eight bytes are by definition on an integral 8 byte boundary.

For VECTOR LOAD WITH LENGTH and VECTOR STORE WITH LENGTH, when the operand is addressed on an integral boundary up to eight bytes and the number of bytes accessed is a multiple of the integral boundary, the storage-operand references appear to be block concurrent with respect to that integral block boundary. If the number of bytes accessed is less than the integral boundary, the storage-operand references appear to be block concurrent with an integral boundary that is the greatest common power of two divisor between the storage-operand address and the number of bytes accessed. For example, if the storage-operand address is on a doubleword boundary and the length is a multiple of two, the storage-operand references will appear half-word concurrent as observed by other CPUs.

For the instructions COMPARE AND SWAP, COMPARE AND SWAP AND PURGE, COMPARE DOUBLE AND SWAP, COMPARE HALFWORD RELATIVE LONG, COMPARE LOGICAL RELATIVE LONG, COMPARE RELATIVE LONG, LOAD AND ADD, LOAD AND ADD LOGICAL, LOAD AND AND, LOAD AND EXCLUSIVE OR, LOAD AND OR, LOAD HALFWORD RELATIVE LONG, LOAD LOGICAL HALFWORD RELATIVE LONG, LOAD LOGICAL RELATIVE LONG, LOAD PAIR DISJOINT, LOAD RELATIVE LONG, STORE HALFWORD RELATIVE LONG, and STORE RELATIVE LONG, all accesses to the storage operand appear to be block concurrent as observed by other CPUs. For COMPARE AND SWAP AND STORE, all accesses to the first operand and the store of the second operand appear to be block concurrent as observed by other CPUs.

For the instruction PERFORM LOCKED OPERATION, the accesses to the even-numbered storage operands appear to be word concurrent, as observed by other CPUs, for function codes that are a multiple of 4 and appear to be doubleword concurrent, as observed by other CPUs, for function codes that are one, 2, or 3 more than a multiple of 4. The accesses to the doublewords in the parameter list appear to be doubleword concurrent, as observed by other CPUs, regardless of the function code.

The instructions LOAD MULTIPLE (LM), LOAD MULTIPLE DISJOINT, LOAD MULTIPLE HIGH, STORE MULTIPLE (STM), and STORE MULTIPLE HIGH, when the operand or operands start on a word boundary; the instructions LOAD MULTIPLE (LMG) and STORE MULTIPLE (STMG), when the operand starts on a doubleword boundary; and the instructions COMPARE LOGICAL (CLC), COMPARE LOGICAL CHARACTERS UNDER MASK, INSERT CHARACTERS UNDER MASK, LOAD CONTROL (LCTLG), STORE CHARACTERS UNDER MASK, and STORE CONTROL (STCTG) access their storage operands in a left-to-right direction, and all bytes accessed within each doubleword appear to be accessed concurrently as observed by other CPUs.

The instructions VECTOR LOAD MULTIPLE and VECTOR STORE MULTIPLE, when the operands start on a quadword boundary accesses to their storage operands appear to be doubleword concurrent, as observed by other CPUs. The doublewords may be accessed in any order.

When any operand of EXTRACT CPU TIME starts on a doubleword boundary, all eight bytes within the operand appear to be accessed concurrently as observed by other CPUs.

The instructions LOAD ACCESS MULTIPLE, LOAD CONTROL (LCTL), STORE ACCESS MULTIPLE, and STORE CONTROL (STCTL) access the storage operand in a left-to-right direction, and all bytes accessed within each word appear to be accessed concurrently as observed by other CPUs.

When destructive overlap does not exist, the operands of MOVE (MVC), MOVE WITH KEY, MOVE TO PRIMARY, and MOVE TO SECONDARY are accessed as follows:

1. The first operand is accessed in a left-to-right direction, and all bytes accessed within a double-
word appear to be accessed concurrently as observed by other CPUs.

2. The second operand is accessed in a left-to-right direction, and all bytes within a doubleword in the second operand that are moved into a single doubleword in the first operand appear to be fetched concurrently as observed by other CPUs. Thus, if the first and second operands begin on the same byte offset within a doubleword, the fetch of the second operand appears to be doubleword concurrent as observed by other CPUs. If the offsets within a doubleword differ by 4, the fetch of the second operand appears to be word concurrent as observed by other CPUs.

Destructive overlap is said to exist when the result location is used as a source after the result has been stored, assuming processing to be performed one byte at a time.

The operands of MOVE WITH SOURCE KEY, MOVE WITH DESTINATION KEY, and MOVE STRING are accessed the same as those of MOVE (MVC), except that destructive overlap is assumed not to exist.

Except as noted in the individual instruction descriptions, accesses to operands of MOVE LONG, MOVE LONG EXTENDED, and MOVE LONG UNICODE do not necessarily appear to occur in a left-to-right direction as observed by other CPUs and by channel programs. The operands of these instructions do appear to be accessed doubleword concurrent, as observed by other CPUs, when all of the following are true:

- Both operands start on doubleword boundaries and are an integral number of doublewords in length.
- The operands do not overlap.
- The nonpadding part of the operation is being executed.

The operands of COMPARE LOGICAL LONG, COMPARE LOGICAL LONG EXTENDED, and COMPARE LOGICAL LONG UNICODE appear to be accessed doubleword concurrent, as observed by other CPUs, when both operands start on doubleword boundaries and are an integral number of doublewords in length.

The operands of COMPARE LOGICAL STRING appear to be accessed doubleword concurrent, as observed by other CPUs, when both operands start on doubleword boundaries. The operands of SEARCH STRING and SEARCH STRING UNICODE appear to be accessed doubleword concurrent, as observed by other CPUs, when it starts on a doubleword boundary.

For EXCLUSIVE OR (XC) the operands are processed in a left-to-right direction, and, when the first and second operands coincide, all bytes accessed within a doubleword appear to be accessed concurrently as observed by other CPUs.

**Programming Note:** In the case of EXCLUSIVE OR (XC) designating operands which coincide exactly, the bytes within the field may appear to be accessed as many as three times, by two fetches and one store: once as the fetch portion of the first operand update, once as the second-operand fetch, and then once as the store portion of the first-operand update. Each of the three accesses appears to be doubleword concurrent as observed by other CPUs, but the three accesses do not necessarily appear to occur one immediately after the other. One or both fetch accesses may be omitted since the instruction can be completed without fetching the operands.

### Relation between Operand Accesses

As observed by other CPUs and by channel programs, storage-operand fetches associated with one instruction execution appear to precede all storage-operand references for conceptually subsequent instructions. A storage-operand store specified by one instruction appears to precede all storage-operand stores specified by conceptually subsequent instructions, but it does not necessarily precede storage-operand fetches specified by conceptually subsequent instructions. However, a storage-operand store appears to precede a conceptually subsequent storage-operand fetch from the same main-storage location.

When an instruction has two storage operands both of which cause fetch references, it is unpredictable which operand is fetched first, or how much of one operand is fetched before the other operand is fetched. When the two operands overlap, the common locations may be fetched independently for each operand.
When an instruction has two storage operands the first of which causes a store and the second a fetch reference, it is unpredictable how much of the second operand is fetched before the results are stored. In the case of destructively overlapping operands, the portion of the second operand which is common to the first is not necessarily fetched from storage.

When an instruction has two storage operands the first of which causes an update reference and the second a fetch reference, it is unpredictable which operand is fetched first, or how much of one operand is fetched before the other operand is fetched. Similarly, it is unpredictable how much of the result is processed before it is returned to storage. In the case of destructively overlapping operands, the portion of the second operand which is common to the first is not necessarily fetched from storage.

The independent fetching of a single location for each of two operands may affect the program execution in the following situation. When the same storage location is designated by two operand addresses of an instruction, and another CPU or a channel program causes the contents of the location to change during execution of the instruction, the old and new values of the location may be used simultaneously. For example, comparison of a field to itself may yield a result other than equal, or EXCLUSIVE-ORing of a field with itself may yield a result other than zero.

**Storage Operand References in the Transactional-Execution Mode**

While the CPU is in the transactional-execution mode, the normal rules for instruction, ART and DAT table, and operand fetching apply, except where explicitly noted otherwise. This section describes additional rules for operand storage accesses. Instruction and ART and DAT table fetching are not impacted by transactional execution.

As observed by other CPUs and by the channel subsystem, all storage-operand fetches and stores made while a CPU is in the transactional-execution mode appear to be a single block-concurrent access. Storage accesses by other CPUs or by the channel subsystem may prevent a transaction from maintaining block-concurrent access, in which case the transaction aborts with either store or fetch conflict.

**Programming Note:** Storage accesses made while the CPU is in the transactional-execution mode are said to be block concurrent, even though the references may not represent a contiguous block of storage on an integral boundary.

**Other Storage References**

The restart, program, supervisor-call, external, input/output, and machine-check PSWs appear to be accessed doubleword concurrent as observed by other CPUs. These references appear to occur after the conceptually previous unit of operation and before the conceptually subsequent unit of operation. The relationship between the new-PSW fetch, the old-PSW store, and the interruption-code store is unpredictable.

Store accesses for interruption codes are not necessarily single-access stores. The store accesses for the external and supervisor-call-interruption codes appear to occur between the conceptually previous and conceptually subsequent operations. The store accesses for the program-interruption codes may precede the storage-operand references associated with the instruction which results in the program interruption.

**Relation between Storage-Key Accesses**

As observed by other CPUs, storage-key fetches and stores due to instructions that explicitly manipulate a storage key (INSERT STORAGE KEY EXTENDED, INSERT VIRTUAL STORAGE KEY, PERFORM FRAME MANAGEMENT FUNCTION (when SK is one), RESET REFERENCE BIT EXTENDED, and SET STORAGE KEY EXTENDED) are ordered among themselves and among storage-operand references as if the storage-key accesses were themselves storage-operand fetches and stores, respectively.
Accesses of the access-control and fetch-protection bits due to storage-operand references are concurrent with the references. When EDAT-1 applies and a storage-operand reference is made using a segment-table entry in which the STE-format and ACCF-validity controls are both one, the source of the access-control and fetch-protection bits may be any of the following: (a) the storage key for the corresponding 4K-byte block, (b) the access-control bits and the fetch-protection bit in the segment-table entry, or (c) a buffered copy of these bits in the TLB; it is unpredictable which source is used. Similarly, when EDAT-2 applies and a storage-operand reference is made using a region-third-table entry in which the RTTE-format and ACCF-validity controls are both one, the source of the access-control and fetch-protection bits may be any of the following: (a) the storage key for the corresponding 4K-byte block, (b) the access-control bits and the fetch-protection bit in the region-third-table entry, or (c) a buffered copy of these bits in the TLB; it is unpredictable which source is used.

Accesses of the reference and change bits due to storage-operand references are in no particular order within the interval in which they are defined to occur. (See the description of when the change bit is set in “Storage-Key Accesses” on page 5-118.) However, whether due to an instruction that explicitly manipulates a storage key or due to a storage-operand reference, a storage-key store appears to precede a conceptually subsequent storage-key fetch from the same storage key.

Serialization

The sequence of functions performed by a CPU is normally independent of the functions performed by other CPUs and by channel programs. Similarly, the sequence of functions performed by a channel program is normally independent of the functions performed by other channel programs and by CPUs. However, at certain points in its execution, serialization of the CPU occurs. Serialization also occurs at certain points for channel programs.

CPU Serialization

All interruptions, entering or leaving the transactional-execution mode, and the execution of certain instructions cause a serialization of CPU operations. A serialization operation consists in completing all conceptually previous storage accesses and related reference-bit and change-bit settings by the CPU, as observed by other CPUs and by the channel subsystem, before the conceptually subsequent storage accesses and related reference-bit and change-bit settings occur. Serialization affects the sequence of all CPU accesses to storage and to the storage keys, except for those associated with ART-table-entry and DAT-table-entry fetching.

As observed by all CPUs and by the channel subsystem, a serializing operation performed while a CPU is in the transactional-execution mode occurs when the CPU leaves the transactional-execution mode, as a result of any of the following: a TRANSACTION END instruction that decrements the transaction nesting depth to zero (normal ending), or a transaction-abort condition.

Serialization is performed by CPU reset, all interruptions, the entering or leaving of the transactional-execution mode, and the execution of the following instructions:

- The general instruction BRANCH ON CONDITION (BCR) with the M₁ and R₂ field containing 1111 binary and 0000 binary, respectively.
- When the fast-BCR-serialization facility is installed, the general instruction BRANCH ON CONDITION (BCR) with the M₁ and R₂ fields containing 1110 binary and 0000 binary, respectively.
- The general instructions COMPARE AND SWAP, COMPARE AND SWAP AND STORE, COMPARE DOUBLE AND SWAP, STORE CLOCK, STORE CLOCK EXTENDED, SUPERVISOR CALL, and TEST AND SET.
- COMPARE AND SWAP AND PURGE, which can also cause the ALB and the TLB to be cleared of all entries on all CPUs.
- COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE DAT TABLE ENTRY, and INVALIDATE PAGE TABLE ENTRY.
- All I/O instructions.
- LOAD PSW, LOAD PSW EXTENDED, PERFORM FRAME MANAGEMENT FUNCTION, and SET STORAGE KEY EXTENDED.
• MOVE TO PRIMARY, MOVE TO SECONDARY, and SET ADDRESS SPACE CONTROL.

• PAGE IN and PAGE OUT.

• PERFORM LOCKED OPERATION. A serialization function is performed immediately after the lock is obtained and again immediately before it is released. However, values fetched from the parameter list before the lock is obtained are not necessarily refetched.

• PROGRAM CALL, and, when the state entry to be unstacked is a program-call state entry, PROGRAM RETURN. However, it is unpredictable whether or not a store into a trace-table entry or linkage-stack entry from which a subsequent instruction is fetched will be observed by the CPU that performed the store.

• PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, and SET SECONDARY ASN WITH INSTANCE, and TRACE. However, it is unpredictable whether or not a store into a trace-table entry from which a subsequent instruction is fetched will be observed by the CPU that performed the store. Additionally, when the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register 0 is one, it is unpredictable whether explicit tracing causes a serialization function to be performed.

In the following discussion, the term serializing instruction refers to an instruction which causes one or more serialization functions to be performed. The term serializing operation refers to a unit of operation within an instruction or to a machine operation such as an interruption which causes a serialization function is performed.

The sequence of events associated with a serializing operation is as follows:

1. All conceptually previous storage accesses by the CPU are completed as observed by other CPUs and by channel programs. This includes all conceptually previous stores and changes to the storage keys.

2. The normal function associated with the serialization operation is performed. In the case of instruction execution, operands are fetched, and the storing of results is completed. The exceptions are LOAD PSW, LOAD PSW EXTENDED, and SET PREFIX, in which the operand may be fetched before previous stores have been completed, and interruptions, in which the interruption code and associated fields may be stored prior to the serialization. The fetching of the serializing instruction occurs before the execution of the instruction and may precede the execution of previous instructions, but may not precede the completion of any previous serializing operation. In the case of an interruption, the old PSW, the interruption code, and other information, if any, are stored, and the new PSW is fetched, but not necessarily in that sequence.

3. Finally, instruction fetch and operand accesses for conceptually subsequent operations may begin.

A serializing function affects the sequence of storage accesses that are under the control of the CPU in which the serializing function takes place. It does not affect the sequence of storage accesses under the control of other CPUs and of channel programs.
Programming Notes:

1. The following are some effects of a serializing operation:
   
a. When the execution of an instruction changes the contents of a storage location that is used as a source of a following instruction and when different addresses are used to designate the same absolute location for storing the result and fetching the instruction, a serializing operation following the change ensures that the modified instruction is executed.
   
b. When a serializing operation takes place, other CPUs and channel programs observe instruction and operand fetching and result storing to take place in the sequence established by the serializing operation.
   
2. Storing into a location from which a serializing instruction is fetched does not necessarily affect the execution of the serializing instruction unless a serializing function has been performed after the storing and before the execution of the serializing instruction.
   
3. Following is an example showing the effects of serialization. Location A initially contains FF hex.

<table>
<thead>
<tr>
<th>CPU 1</th>
<th>CPU 2</th>
</tr>
</thead>
<tbody>
<tr>
<td>MVI A,X'00'</td>
<td>G</td>
</tr>
<tr>
<td>BCR 15,0</td>
<td>CLI A,X'00'</td>
</tr>
<tr>
<td></td>
<td>BNE G</td>
</tr>
</tbody>
</table>

   The BCR 15,0 instruction executed by CPU 1 is a serializing instruction that ensures that the store by CPU 1 at location A is completed. However, CPU 2 may loop indefinitely, or until the next interruption on CPU 2, because CPU 2 may already have fetched from location A for every execution of the CLI instruction. A serializing instruction must be in the CPU-2 loop to ensure that CPU 2 will again fetch from location A.

Specific-Operand Serialization

Certain instructions cause specific-operand serialization to be performed for an operand of the instruction. As observed by other CPUs and by the channel subsystem, a specific-operand-serialization operation consists in completing all conceptually previous storage access to the specified operand by the CPU before a conceptually subsequent accesses to the specific storage operand of the instruction may occur.

At the completion of an instruction causing specific-operand serialization, the instruction's store is completed as observed by other CPUs and channel programs.

Specific-operand serialization is performed by the execution of the following instructions:

- ADD IMMEDIATE (ASI, AGSI) and ADD LOGICAL WITH SIGNED IMMEDIATE, for the first operand, when the interlocked-access facility 1 is installed and the first operand is aligned on a boundary which is integral to the size of the operand.
- AND (NI, NIY), when the interlocked-access facility 2 is installed
- EXCLUSIVE OR (XI, XIY), when the interlocked-access facility 2 is installed
- LOAD AND ADD, LOAD AND ADD LOGICAL, LOAD AND AND, LOAD AND EXCLUSIVE OR, LOAD AND OR, for the second operand.
- OR (OI, OIY), when the interlocked-access facility 2 is installed

Channel-Program Serialization

Serialization of a channel program occurs as follows:

1. All storage accesses and storage-key accesses by the channel program follow initiation of the execution of START SUBCHANNEL, or, if suspended, RESUME SUBCHANNEL, as observed by CPUs and by other channel programs. This includes all accesses for the CCWs, IDAWs, MIDAWs, and data.

2. All storage accesses and storage-key accesses by the channel program are completed, as observed by CPUs and by other channel programs, before the subchannel status indicating status-pending with primary status is made available to any CPU.

3. If a CCW contains a PCI flag or a suspend flag which is one, all storage accesses and storage-key accesses due to CCWs preceding it in the CCW chain are completed, as observed by CPUs and by other channel programs, before the subchannel status indicating status-pending with intermediate status (PCI or suspended) is made available to any CPU.
The serialization of a channel program does not affect the sequence of storage accesses or storage-key accesses performed by other channel programs or by a CPU.

Quiescing

Quiescing is an additional means of serialization that may be performed to ensure that updates to a configuration-wide resource are immediately visible to all CPUs. A quiescing operation initiated by one CPU causes the following to occur on all other CPUs in the configuration:

- Any instruction or unit of operation executing on the CPU is completed.
- Any transaction executing on the CPU is aborted with abort code 255; the condition code is set to 2.
- All locally-cached copies of the configuration-wide resource being updated are discarded.
- Resumption of instruction execution is delayed until the update to the configuration-wide resource is visible to all CPUs.

Quiescing may occur as a result of the execution of the following key-setting instructions:

- **PERFORM FRAME MANAGEMENT FUNCTION** (when the set-key control is one)
- **SET STORAGE KEY EXTENDED**.

When the nonquiescing key-setting facility is not installed, a quiescing operation is performed by either of the above instructions. Similarly, when the nonquiescing key-setting facility is installed, but the nonquiescing (NQ) control of the SSKE instruction is zero, a quiescing operation is performed. When the nonquiescing key-setting facility is installed and the NQ control of the SSKE instruction is one, the quiescing operation is not performed. When the nonquiescing key-setting facility is installed, it is unpredictable whether execution of PFMF with the set-key control set to 1 results in a quiescing operation.

**Programming Note:** Although quiescing is defined as an additional serialization mechanism, the term **serialization function** (used in the description of CPU instructions and channel operations) is limited to CPU serialization and channel-program serialization.
Chapter 6. Interruptions

Interrupt Action ........................................ 6-2
Interrupt Code ........................................... 6-5
Enabling and Disabling ................................ 6-5
Handling of Floating Interrupt Conditions .... 6-6
Instruction-Length Code ................................. 6-6
Zero ILC .................................................. 6-7
ILC on Instruction-Fetching Exceptions ....... 6-7
Exceptions Associated with the PSW .......... 6-9
Early Exception Recognition ....................... 6-9
Late Exception Recognition ......................... 6-9
External Interruption .................................. 6-10
Clock Comparator ....................................... 6-11
CPU Timer .............................................. 6-12
Emergency Signal ....................................... 6-12
External Call ............................................ 6-12
Interrupt Key ............................................ 6-12
Malfunction Alert ....................................... 6-13
Measurement Alert ...................................... 6-13
Service Signal ........................................... 6-13
Timing Alert ............................................. 6-13
ETR-Timing-Alert Condition ....................... 6-14
STP-Timing-Alert Condition ....................... 6-14
Warning Track .......................................... 6-14
I/O Interruption ......................................... 6-14
Machine-Check Interruption ....................... 6-15
Program Interruption ................................... 6-15
Data-Exception Code (DXC) ......................... 6-16
Priority of Program Interruptions for Data
Exceptions ................................................ 6-16
Vector-Exception Code ................................. 6-19
Program-Interruption Conditions ............... 6-19
Addressing Exception ................................. 6-19
AFX-Translation Exception ......................... 6-20
ALEN-Translation Exception ....................... 6-21
ALE-Sequence Exception .............................. 6-21
ALET-Specification Exception ..................... 6-21
ASCE-Type Exception ................................. 6-21
ASTE-Instance Exception ............................. 6-22
ASTE-Sequence Exception ............................ 6-22
ASTE-Validity Exception ............................. 6-23
ASX-Translation Exception ......................... 6-23
Crypto-Operation Exception ....................... 6-23
Data Exception .......................................... 6-24
Decimal-Divide Exception ............................ 6-25
Decimal-Overflow Exception ....................... 6-25
Execute Exception ....................................... 6-25
EX-Translation Exception ............................ 6-25
Extended-Authority Exception ..................... 6-26
Fixed-Point-Divide Exception ...................... 6-26
Fixed-Point-Overflow Exception .................. 6-26
HFP-Divide Exception .................................. 6-26
HFP-Exponent-Overflow Exception ............... 6-27
HFP-Exponent-Underflow Exception .............. 6-27
HFP-Significance Exception ......................... 6-27
HFP-Square-Root Exception ......................... 6-27
LFX-Translation Exception ......................... 6-27
LSTE-Sequence Exception ............................ 6-28
LSX-Translation Exception ........................... 6-28
Monitor Event .......................................... 6-29
Operand Exception ...................................... 6-29
Operation Exception ................................... 6-30
Page-Translation Exception ......................... 6-30
PC-Translation-Specification Exception ......... 6-31
PER Event .............................................. 6-31
Primary-Authority Exception ....................... 6-31
Privileged-Operation Exception ................... 6-32
Protection Exception ................................... 6-32
Region-First-Translation Exception .............. 6-33
Region-Second-Translation Exception ............ 6-34
Region-Third-Translation Exception .............. 6-34
Secondary-Authority Exception ..................... 6-35
Segment-Translation Exception ..................... 6-35
Space-Switch Event ..................................... 6-35
Special-Operation Exception ....................... 6-36
Specification Exception ............................. 6-38
Stack-Empty Exception ................................ 6-42
Stack-Full Exception ................................... 6-42
Stack-Operation Exception ......................... 6-42
Stack-Specification Exception ..................... 6-43
Stack-Type Exception ................................... 6-43
Trace-Table Exception ............................... 6-43
Transaction-Constraint Exception ................ 6-43
Transactional-Execution-Aborted Event ......... 6-44
Translation-Specification Exception ............. 6-44
Vector Processing Exception ....................... 6-45
Collective Program-Interruption Names ......... 6-45
Recognition of Access Exceptions ................. 6-45
Multiple Program-Interruption Conditions .... 6-48
Access Exceptions ....................................... 6-51
ASN-Translation Exceptions ......................... 6-53
Subspace-Replacement Exceptions ................. 6-54
Trace Exceptions ........................................ 6-54
Restart Interruption .................................... 6-54
Supervisor-Call Interruption ....................... 6-54
Priority of Interruptions ......................... 6-55
The interruption mechanism permits the CPU to change its state as a result of conditions external to the configuration, within the configuration, or within the CPU itself. To permit fast response to conditions of high priority and immediate recognition of the type of condition, interruption conditions are grouped into six classes: external, input/output, machine check, program, restart, and supervisor call.

### Interruption Action

An interruption consists in storing the current PSW as an old PSW, storing information identifying the cause of the interruption, and fetching a new PSW. Processing resumes as specified by the new PSW.

The old PSW stored on an interruption normally contains the address of the instruction that would have been executed next had the interruption not occurred, thus permitting resumption of the interrupted program. For program and supervisor-call interruptions, the information stored also contains a code that identifies the length of the last-executed instruction, thus permitting the program to respond to the cause of the interruption. In the case of some program conditions for which the normal response is reexecution of the instruction causing the interruption, the instruction address directly identifies the instruction last executed.

Except for restart, an interruption can occur only when the CPU is in the operating state. The restart interruption can occur with the CPU in either the stopped or operating state.

The details of source identification, location determination, and instruction execution are explained in later sections and are summarized in Figure 6-1 on page 6-2.

<table>
<thead>
<tr>
<th>Source Identification</th>
<th>Interruption Code</th>
<th>PSW-Mask Bits</th>
<th>Mask Bits in Control Registers</th>
<th>ILC Set</th>
<th>Execution of Instruction Identified by Old PSW</th>
</tr>
</thead>
<tbody>
<tr>
<td>MACHINE CHECK</td>
<td>Locations 232-2391</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Exigent condition</td>
<td></td>
<td>13</td>
<td>u</td>
<td></td>
<td>terminated or nullified¹²</td>
</tr>
<tr>
<td>Repressible condition</td>
<td></td>
<td>13 35-39</td>
<td>u</td>
<td></td>
<td>unaffected¹²</td>
</tr>
<tr>
<td>SUPERVISOR CALL</td>
<td>Locations 138-139</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Instruction bits</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PROGRAM</td>
<td>Locations 142-143</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1, 2, 3</td>
<td>completed</td>
</tr>
<tr>
<td>Operation</td>
<td>00000000 p00000001</td>
<td>0001</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Privileged operation</td>
<td>00000000 p00000010</td>
<td>0002</td>
<td></td>
<td>1, 2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>Execute</td>
<td>00000000 p00000011</td>
<td>0003</td>
<td></td>
<td>2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>Protection</td>
<td>00000000 p00000010</td>
<td>0004</td>
<td></td>
<td>1, 2, 3</td>
<td>suppressed or terminated</td>
</tr>
<tr>
<td>Addressing</td>
<td>00000000 p00001001</td>
<td>0005</td>
<td></td>
<td>1, 2, 3</td>
<td>suppressed or terminated</td>
</tr>
<tr>
<td>Specification</td>
<td>00000000 p00001100</td>
<td>0006</td>
<td></td>
<td>0, 1, 2, 3</td>
<td>supressed or completed</td>
</tr>
<tr>
<td>Data</td>
<td>00000000 p00001111</td>
<td>0007</td>
<td></td>
<td>0, 1, 2, 3</td>
<td>supressed, terminated or completed</td>
</tr>
<tr>
<td>Fixed-point overflow</td>
<td>00000000 p00010000</td>
<td>0008</td>
<td>20</td>
<td>1, 2, 3</td>
<td>completed</td>
</tr>
<tr>
<td>Fixed-point divide</td>
<td>00000000 p00010010</td>
<td>0009</td>
<td></td>
<td>1, 2, 3</td>
<td>suppressed or completed</td>
</tr>
<tr>
<td>Decimal overflow</td>
<td>00000000 p00010100</td>
<td>000A</td>
<td></td>
<td>2, 3</td>
<td>completed</td>
</tr>
<tr>
<td>Decimal divide</td>
<td>00000000 p00010111</td>
<td>000B</td>
<td></td>
<td>2, 3</td>
<td>suppressed</td>
</tr>
</tbody>
</table>

Figure 6-1. Interruption Action (Part 1 of 4)
<table>
<thead>
<tr>
<th>Source Identification</th>
<th>Interruption Code</th>
<th>PSW-Mask Bits</th>
<th>Mask Bits in Control Registers</th>
<th>ILC Set</th>
<th>Execution of Instruction Identified by Old PSW</th>
</tr>
</thead>
<tbody>
<tr>
<td>HFP exp. overflow</td>
<td>00000010 p0001100</td>
<td>000C</td>
<td></td>
<td>1, 2, 3</td>
<td>completed</td>
</tr>
<tr>
<td>HFP exp. underflow</td>
<td>00000010 p0001101</td>
<td>000D</td>
<td>22</td>
<td>1, 2, 3</td>
<td>completed</td>
</tr>
<tr>
<td>HFP significance</td>
<td>00000010 p0001110</td>
<td>000E</td>
<td>23</td>
<td>1, 2, 3</td>
<td>completed</td>
</tr>
<tr>
<td>HFP divide</td>
<td>00000010 p0001111</td>
<td>000F</td>
<td></td>
<td>1, 2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>Segment translation</td>
<td>00000000 p0010000</td>
<td>0010</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Page translation</td>
<td>00000000 p0010001</td>
<td>0011</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Translation spec</td>
<td>00000000 p0010010</td>
<td>0012</td>
<td></td>
<td>1, 2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>Special operation</td>
<td>00000000 p0010011</td>
<td>0013</td>
<td>0 33</td>
<td>1, 2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>Operand</td>
<td>00000000 p0010101</td>
<td>0015</td>
<td></td>
<td>2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>Trace table</td>
<td>00000000 p0010110</td>
<td>0016</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Transaction constraint</td>
<td>00000000 00011000</td>
<td>0018</td>
<td></td>
<td>1, 2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>Vector-processing</td>
<td>00000000 00011011</td>
<td>001B</td>
<td></td>
<td>3</td>
<td>suppressed</td>
</tr>
<tr>
<td>Space-switch event</td>
<td>00000000 00011100</td>
<td>001C</td>
<td></td>
<td>1, 2, 3</td>
<td>completed</td>
</tr>
<tr>
<td>HFP square root</td>
<td>00000000 00011101</td>
<td>001D</td>
<td></td>
<td>2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>PC-transl spec</td>
<td>00000000 00011111</td>
<td>001F</td>
<td></td>
<td>2, 3</td>
<td>suppressed</td>
</tr>
<tr>
<td>AFX translation</td>
<td>00000000 00100000</td>
<td>0020</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>ASX translation</td>
<td>00000000 00100001</td>
<td>0021</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>LX translation</td>
<td>00000000 00100010</td>
<td>0022</td>
<td></td>
<td>2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>EX translation</td>
<td>00000000 00100011</td>
<td>0023</td>
<td></td>
<td>2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Primary authority</td>
<td>00000000 00100100</td>
<td>0024</td>
<td></td>
<td>2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Secondary authority</td>
<td>00000000 00100101</td>
<td>0025</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>LFX translation</td>
<td>00000000 00100110</td>
<td>0026</td>
<td></td>
<td>2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>LSX translation</td>
<td>00000000 00100111</td>
<td>0027</td>
<td></td>
<td>2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>ALET specification</td>
<td>00000000 00101000</td>
<td>0028</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>ALEN translation</td>
<td>00000000 00101001</td>
<td>0029</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>ALE sequence</td>
<td>00000000 00101010</td>
<td>002A</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>ASTE validity</td>
<td>00000000 00101011</td>
<td>002B</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>ASTE sequence</td>
<td>00000000 00101100</td>
<td>002C</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Extended authority</td>
<td>00000000 00101101</td>
<td>002D</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>LSTE sequence</td>
<td>00000000 00101110</td>
<td>002E</td>
<td></td>
<td>2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>ASTE instance</td>
<td>00000000 00101111</td>
<td>002F</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Stack full</td>
<td>00000000 00110000</td>
<td>0030</td>
<td></td>
<td>2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Stack empty</td>
<td>00000000 00110001</td>
<td>0031</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Stack specification</td>
<td>00000000 00110010</td>
<td>0032</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Stack type</td>
<td>00000000 00110011</td>
<td>0033</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Stack operation</td>
<td>00000000 00110100</td>
<td>0034</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>ASCE type</td>
<td>00000000 00111000</td>
<td>0038</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Region first trans</td>
<td>00000000 00111001</td>
<td>0039</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Region second trans</td>
<td>00000000 00111010</td>
<td>003A</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Region third trans</td>
<td>00000000 00111011</td>
<td>003B</td>
<td></td>
<td>1, 2, 3</td>
<td>nullified</td>
</tr>
<tr>
<td>Monitor event</td>
<td>00000000 00100000</td>
<td>0040</td>
<td>8 32-47</td>
<td>2, 3</td>
<td>completed</td>
</tr>
</tbody>
</table>

Figure 6-1. Interruption Action (Part 2 of 4)
<table>
<thead>
<tr>
<th>Source Identification</th>
<th>Interruption Code</th>
<th>PSW-Mask Bits</th>
<th>Mask Bits in Control Registers Reg Bit</th>
<th>ILC Set</th>
<th>Execution of Instruction Identified by Old PSW</th>
</tr>
</thead>
<tbody>
<tr>
<td>PER basic event</td>
<td>0000001n 1nnnnnnn</td>
<td>0080</td>
<td>1 9 32-36 0, 1, 2, 3</td>
<td>completed³</td>
<td></td>
</tr>
<tr>
<td>PER nullification event</td>
<td>00000000 10000000</td>
<td>0080</td>
<td>1 9 33,39 0</td>
<td>nullified³</td>
<td></td>
</tr>
<tr>
<td>Crypto operation</td>
<td>00000001 p0011001</td>
<td>0119</td>
<td></td>
<td>nullified⁴</td>
<td></td>
</tr>
<tr>
<td>Transactional-execution aborted event</td>
<td>00000001n nnnnnnn</td>
<td>0200</td>
<td>0 8-9 1, 2, 3</td>
<td>completed⁵</td>
<td></td>
</tr>
</tbody>
</table>

| EXTERNAL                                   |                   |               |                                        |         |                                               |
| (old PSW 304, new PSW 432)                |                   | Location 134-135 |                                         |         |                                               |

| Interrupt key                              | 00000000 01000000 | 0040          | 7 0 57 u unaffected                    |         |                                               |
| Clock comparator                           | 00010000 00000100 | 1004          | 7 0 52 u unaffected                    |         |                                               |
| CPU timer                                  | 00010000 00000101 | 1005          | 7 0 53 u unaffected                    |         |                                               |
| Warning track                              | 00010000 00000111 | 1007          | 7 0 30 u unaffected                    |         |                                               |
| Malfunction alert                         | 00010010 00000000 | 1200          | 7 0 48 u unaffected                    |         |                                               |
| Emergency Signal                           | 00010010 00000001 | 1201          | 7 0 49 u unaffected                    |         |                                               |
| External call                              | 00010010 00000010 | 1202          | 7 0 50 u unaffected                    |         |                                               |
| Timing alert                               | 00010100 00000110 | 1406          | 7 0 59 u unaffected                    |         |                                               |
| Measurement alert                          | 00010100 00000111 | 1407          | 7 0 58 u unaffected                    |         |                                               |
| Service signal                             | 00100100 00000001 | 2401          | 7 0 54 u unaffected                    |         |                                               |

| INPUT/OUTPUT                               |                   |               |                                        |         |                                               |
| (old PSW 368, new PSW 496)                 |                   | Locations 184-191 |                                          |         |                                               |
| I/O-interruption subclass                  |                   | 6 6 32-39 u      | u unaffected                            |         |                                               |

| RESTART                                    |                   |               |                                        |         |                                               |
| (old PSW 288, new PSW 416)                 |                   | None          |                                        |         |                                               |

**Explanation:**

Locations for the old PSWs, new PSWs, and interruption codes are real locations.

1. A model-independent machine-check interruption code of 64 bits is stored at real locations 232-239.
2. The effect of the machine-check condition is indicated by bits in the machine-check-interruption code. The setting of these bits indicates the extent of the damage and whether the unit of operation is nullified, terminated, or unaffected.
3. The interruption code in the column labeled “Hex” is the hex code for the basic interruption; this code does not show the effects of concurrent interruption conditions represented by n or p in the column labeled “Binary.”
4. Bits 32-39 of control register 6 provide detailed masking of I/O-interruption subclasses 0-7 respectively.
5. When the interruption code indicates a PER basic event, an ILC of 0 may be stored only when bits 8-15 of the interruption code are 10000110 (PER, specification).
6. The unit of operation is completed, unless a program exception concurrently indicated causes the unit of operation to be nullified, suppressed, or terminated.
7. The unit of operation is nullified and no other program interruption is indicated when a nullifying PER event is recognized.

*Figure 6-1. Interruption Action (Part 3 of 4)*
The six classes of interruptions (external, I/O, machine check, program, restart, and supervisor call) are distinguished by the storage locations at which the old PSW is stored and from which the new PSW is fetched. For most classes, the causes are further identified by an interruption code and, for some classes, by additional information placed in permanently assigned real storage locations during the interruption. (See “Assigned Storage Locations” on page 3-68.) For external, program, and supervisor-call interruptions, the interruption code consists of 16 bits.

For external interruptions, the interruption code is stored at real locations 134-135. A parameter may be stored at real locations 128-131, or a CPU address may be stored at real locations 132-133.

For I/O interruptions, the I/O-interruption code is stored at real locations 184-195. The I/O-interruption code consists of a 32-bit subsystem-identification word, a 32-bit interruption parameter, and a 32-bit I/O-interruption identification word.

For machine-check interruptions, the interruption code consists of 64 bits and is stored at real locations 232-239. Additional information for identifying the cause of the interruption and for recovering the state of the machine may be provided by the contents of the machine-check failing-storage address and the contents of the fixed-logout and machine-check-save areas. (See Chapter 11, “Machine-Check Handling.”)

For program interruptions, the interruption code is stored at real locations 142-143, and the instruction-length code is stored in bit positions 5 and 6 of real location 141. Further information may be provided in the form of the data-exception code (DXC), monitor-class number, PER code, addressing-and-translation-mode identification, PER address, exception access identification, PER access identification, operand-access identification, translation-exception identification, and monitor code, which are stored at real locations 144-162 and 168-183.

### Enabling and Disabling

By means of mask bits in the current PSW, floating-point-control (FPC) register, and control registers, the CPU may be enabled or disabled for all external, I/O, and machine-check interruptions and for some program interruptions. When a mask bit is one, the CPU is enabled for the corresponding class of interruptions, and those interruptions can occur.

When a mask bit is zero, the CPU is disabled for the corresponding interruptions. The conditions that cause I/O interruptions remain pending. External-interruption conditions either remain pending or persist until the cause is removed. Machine-check-interruption conditions, depending on the type, are ignored, remain pending, or cause the CPU to enter the check-stop state. The disallowed program-interruption conditions are ignored, except that some causes are indicated also by the setting of the condition code, and IEEE exceptions set flags in the FPC register. The setting of the HFP-significance and HFP-exponent-underflow program-mask bits affects

---

**Figure 6-1. Interruption Action (Part 4 of 4)**

<table>
<thead>
<tr>
<th>Source Identification</th>
<th>Interruption Code</th>
<th>PSW-Mask Bits</th>
<th>Mask Bits in Control Registers</th>
<th>ILC Set</th>
<th>Execution of Instruction Identified by Old PSW</th>
</tr>
</thead>
<tbody>
<tr>
<td>f</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>A transactional-execution aborted event indication always accompanies another program-interruption indication. The completed indication refers only to the TBEGIN or TBEGINC instruction, as identified by the old PSW. The instruction identified by the aborted-execution instruction address in the TDB is either nullified, suppressed, or completed.</td>
</tr>
<tr>
<td>n</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>A possible nonzero code indicating another concurrent program-interruption condition</td>
</tr>
<tr>
<td>p</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>If one, the bit indicates a concurrent PER-event interruption condition.</td>
</tr>
<tr>
<td>s</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Bits of the I field of SUPERVISOR CALL.</td>
</tr>
<tr>
<td>t</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Transactional-execution-aborted event</td>
</tr>
<tr>
<td>u</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Not stored.</td>
</tr>
</tbody>
</table>

---
the manner in which HFP operations are completed when the corresponding condition occurs. Similarly, the setting of the IEEE mask bits in the FPC register affects the manner in which IEEE computational operations are completed when the corresponding condition occurs.

Programming Notes:

1. Mask bits in the PSW provide a means of disallowing most maskable interruptions; thus, subsequent interruptions can be disallowed by the new PSW introduced by an interruption. Furthermore, the mask bits can be used to establish a hierarchy of interruption priorities, where a condition in one class can interrupt the program handling a condition in another class but not vice versa. To prevent an interruption-handling routine from being interrupted before the necessary housekeeping steps are performed, the new PSW must disable the CPU for further interruptions within the same class or within a class of lower priority.

2. Because the mask bits in control registers are not changed as part of the interruption procedure, these masks cannot be used to prevent an interruption immediately after a previous interruption in the same class. The mask bits in control registers provide a means for selectively enabling the CPU for some sources and disabling it for others within the same class.

3. Controlling bits exist for several program interruptions, but with no mask bit in the PSW. Such bits include the IEEE mask bits in the FPC register, the monitor masks in bit positions 48-63 of control register 8, and the primary space-switch-event-control bits, bit 57 of control registers 1 and 13, respectively. A bit of this nature is somewhat arbitrarily considered to be a "mask" bit only if the polarity is such that interruption is enabled when the bit is one.

Thus, for example, the SSM-suppression-control bit, bit 33 of control register 0, is considered to be a mask bit, while the AFP-register-control bit, bit 45 of control register 0, is not. Regardless of the polarity of such control bits, to avoid another program interruption, an interruption-handling routine must avoid issuing instructions subject to these bits until they have been set appropriately.

The enhanced-monitor masks in bit positions 16-31 of control register 8 are an exception to the above definition of a mask in that they work in conjunction with the monitor masks in bit positions 48-63 of control register 8. When both a monitor mask bit and its corresponding enhanced-monitor mask bit are one, a monitor-event counting operation occurs rather than an interruption.

Handling of Floating Interruption Conditions

An interruption condition which can be presented to any CPU in the configuration is called a floating interruption condition. The condition is presented to the first CPU in the configuration which is enabled for the corresponding interruption and which can perform the interruption, and then the condition is cleared and not presented to any other CPU in the configuration. A CPU cannot perform the interruption when it is in the check-stop state, has an invalid prefix, is in a string of program interruptions due to a specification exception of the type which is recognized early or is in the stopped state. However, a CPU with the rate control set to instruction step can perform the interruption when the start key is activated.

Service signal, I/O, and certain machine-check conditions are floating interruption conditions. Additionally, when the STP-floating-interrupt facility is installed and STP timing-alert floating interruptions are enabled, STP timing-alert external-interruption conditions are floating interruption conditions.

Instruction-Length Code

The instruction-length code (ILC) occupies two bit positions and provides the length of the last instruction executed. It permits identifying the instruction causing the interruption when the instruction address in the old PSW designates the next sequential instruction. The ILC is provided also by the BRANCH AND LINK instructions in the 24-bit addressing mode.

The ILC for program and supervisor-call interruptions is stored in bit positions 5 and 6 of the bytes at real locations 141 and 137, respectively. For external, I/O, machine-check, and restart interruptions, the ILC is not stored since it cannot be related to the length of the last-executed instruction.

For supervisor-call and program interruptions, a non-zero ILC identifies in halfwords the length of the
instruction that was last executed. That instruction may be one for which a specification exception was recognized due to an odd instruction address or for which an access exception (addressing, ASCE-type, page-translation, protection, region-translation, segment-translation, or translation-specification) was recognized during the fetching of the instruction. Whenever an instruction is executed by means of EXECUTE, instruction-length code 2 is set to indicate the length of EXECUTE and not that of the target instruction. Similarly, when an instruction is executed by means of EXECUTE RELATIVE LONG, instruction length code 3 is set.

The value of a nonzero instruction-length code is related to the leftmost two bits of the instruction. The value does not depend on whether the operation code is assigned or on whether the instruction is installed. The following table summarizes the meaning of the instruction-length code:

<table>
<thead>
<tr>
<th>ILC</th>
<th>Instruction Bits 0-1</th>
<th>Instruction Length</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>00</td>
<td>Not available</td>
</tr>
<tr>
<td>1</td>
<td>01 00</td>
<td>One halfword</td>
</tr>
<tr>
<td>2</td>
<td>10 01</td>
<td>Two halfwords</td>
</tr>
<tr>
<td>2</td>
<td>10 10</td>
<td>Two halfwords</td>
</tr>
<tr>
<td>3</td>
<td>11 11</td>
<td>Three halfwords</td>
</tr>
</tbody>
</table>

When a transaction is aborted due to a program interruption, the ILC stored in bit positions 5-6 of real location 141 is respective to the instruction identified by the aborted-transaction instruction address (ATIA) in the program-interruption TDB. Similarly, when a nonconstrained transaction is aborted due to a program interruption, and the transaction-diagnostic-block address is valid, the ILC stored in bit positions 5-6 of byte 37 in the TBEGIN-specified-TDB is respective to the instruction identified by the ATIA in the TDB.

Programming Note: When a transaction is aborted due to a program interruption, the ILC is not meaningful with respect to the instruction address in the program-old PSW. If a constrained transaction is aborted due to a program interruption, the instruction address in the program-old PSW points directly to the TBEGINC instruction that initiated constrained transactional execution. If a nonconstrained transaction is aborted due to an unfiltered program interruption, the instruction address in the program-old PSW points six bytes past the outermost TBEGIN instruction that initiated nonconstrained transactional execution. The program can determine whether a constrained or nonconstrained transaction was aborted by examining the constrained-transaction indication in the program-interruption TDB (bit 1 of the flags byte, stored at real location 6,145).

Zero ILC
Instruction-length code 0, after a program interruption (other than for an instruction-fetching nullification event), indicates that the instruction address stored in the old PSW does not identify the instruction causing the interruption. In the case of a program interruption due to an instruction-fetching nullification event, the ILC is set to zero. The remainder of this section discusses zero ILC due to cases other than for instruction-fetching nullification events.

An ILC of 0 occurs when a specification exception due to a PSW-format error is recognized as part of early exception recognition and the PSW has been introduced by LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, or an interruption. (See “Exceptions Associated with the PSW” on page 6-9.) In the case of LOAD PSW, LOAD PSW EXTENDED, or PROGRAM RETURN, the instruction address of the instruction or of an execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG) has been replaced by the instruction address in the new PSW. When the invalid PSW is introduced by an interruption, the PSW-format error cannot be attributed to an instruction.

In the case of LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, and the supervisor-call interruption, a PER event may be indicated concurrently with a specification exception for which the ILC is 0.

In the case of a PROGRAM RETURN instruction that causes both a space-switch event and a PSW-format error, the space-switch event is recognized, but it is unpredictable whether the ILC is 0 or 1, or 0 or 2 if EXECUTE was used, or 0 or 3 if EXECUTE RELATIVE LONG was used.

ILC on Instruction-Fetching Exceptions
When a program interruption occurs because of an exception that prohibits access to the instruction, the instruction is considered to have been executed without being fetched, and the instruction-length code cannot be set on the basis of the first two bits of the instruction. As far as the significance of the ILC for this case is concerned, the following two situations are distinguished:
1. When an odd instruction address causes a specification exception to be recognized or when an addressing, protection, or translation-specification exception is encountered on fetching an instruction, the ILC is set to 1, 2, or 3, indicating the multiple of 2 by which the instruction address has been incremented. It is unpredictable whether the instruction address is incremented by 2, 4, or 6. By reducing the instruction address in the old PSW by the number of halfword locations indicated in the ILC, the instruction address originally appearing in the PSW may be obtained.

2. When an ASCE-type, region-translation, segment-translation, or page-translation exception is recognized while fetching an instruction, the ILC is arbitrarily set to 1, 2, or 3. In this case, the operation is nullified, and the instruction address is not updated.

The ILC is not necessarily related to the first two bits of the instruction when the first halfword of an instruction can be fetched but an access exception is recognized on fetching the second or third halfword. The ILC may be arbitrarily set to 1, 2, or 3 in these cases. The instruction address is or is not updated, as described in situations 1 and 2 above.

When any exceptions are encountered on fetching the target instruction of EXECUTE, the ILC is 2. When any exceptions are encountered on fetching the target instruction of EXECUTE RELATIVE LONG, the ILC is 3.

**Programming Notes:**

1. A nonzero instruction-length code for a program interruption indicates the number of halfword locations by which the instruction address in the program old PSW must be reduced to obtain the instruction address of the last instruction executed, unless one of the following situations exists:

   a. The interruption is caused by an exception resulting in nullification.

   b. An interruption for a PER event occurs before the execution of an interruptible instruction is completed, and no other program-interruption condition is indicated concurrently.

c. The interruption is caused by a PER event or space-switch event due to LOAD PSW, LOAD PSW EXTENDED, or a branch or linkage instruction, including SUPERVISOR CALL (but not including MONITOR CALL).

d. The interruption is caused by an addressing exception or protection exception for the storage operand of a LOAD CONTROL instruction that loads the control register (1 or 13) containing the address-space-control element that specifies the address space from which instructions are fetched.

For situations a and b above, the instruction address in the PSW is not incremented, and the instruction designated by the instruction address is the same as the last one executed. These situations are the only ones in which the instruction address in the old PSW identifies the instruction causing the exception. Situation b can be distinguished from a PER event indicated after completion of an interruptible or noninterruptible instruction in that, for situation b, the instruction address in the PSW is the same as the PER address in the doubleword at real location 152.

For situation c, the instruction address has been replaced as part of the operation, and the address of the last instruction executed cannot be calculated using the one appearing in the program old PSW.

For situation d, the effective address of the last instruction executed can be calculated, but, since the address-space-control element for the instruction address space is unpredictable, the corresponding real address is unknown.

2. The instruction-length code (ILC) is redundant when a PER event is indicated since the PER address in the doubleword at real location 152 identifies the instruction causing the interruption (or the execute-type instruction, as appropriate). Similarly, the ILC is may be unpredictable when the operation is nullified; in this case the instruction address in the PSW is not incremented. If the ILC value is required in this case, it can be derived from the operation code of the instruction identified by the old PSW.

3. The address of the last instruction executed before a program interruption is insufficient to
locate the program problem if one of the following situations exists:

a. The interruption is caused by an access exception encountered in fetching an instruction, and the instruction address was introduced into the PSW by a means other than sequential operation (by a branch or linkage instruction, LOAD PSW, LOAD PSW EXTENDED, an interruption, or conclusion of an IPL sequence).

b. The interruption is caused by a specification exception due to an odd instruction address, which necessarily also results from introduction of an instruction address into the PSW.

c. The interruption is caused by an early specification exception due to a STORE THEN OR SYSTEM MASK or SET SYSTEM MASK instruction that switches to or from the real mode while introducing invalid values in bit positions 0-7 of the PSW.

For situations a and b, the instruction address was replaced by the operation preceding the last instruction execution, and the address of the program location related to that preceding operation is unavailable.

For situation c, the address of the last instruction executed is available, but the corresponding real address is unknown.

4. The address of the last instruction executed is not available when an interruption is caused by an early specification exception due to a LOAD PSW, LOAD PSW EXTENDED, or PROGRAM RETURN instruction or an interruption.

Exceptions Associated with the PSW

Exceptions associated with erroneous information in the current PSW may be recognized as follows:

- When the information is introduced into the PSW (called early exception recognition)
- As part of the execution of the next instruction (called late exception recognition)

Errors in the PSW which are specification-exception conditions are called PSW-format errors.

Early Exception Recognition
For the following error conditions, a program interruption for a specification exception occurs immediately after the PSW becomes active:

- Any of the unassigned bits (0, 2-4, 25-30, or 33-63) is a one.
- Bit 12 is a one.
- Bit 24 is one (recognition of this condition is optional)
- Bits 31 and 32 are zero and one, respectively, and bits 64-96 are not all zeros.
- Bits 31 and 32 are both zero, and bits 64-103 are not all zeros.
- Bits 31 and 32 are one and zero, respectively.

The interruption occurs regardless of whether the wait state is specified. If the invalid PSW causes the CPU to become enabled for a pending I/O, external, or machine-check interruption, the program interruption occurs instead, and the pending interruption is subject to the mask bits of the new PSW introduced by the program interruption.

When an interruption or the execution of LOAD PSW, LOAD PSW EXTENDED, or PROGRAM RETURN introduces a PSW with one of the above error conditions, the instruction-length code is set to 0, and the newly introduced PSW is stored unmodified as the old PSW. When one of the above error conditions is introduced by execution of SET SYSTEM MASK or STORE THEN OR SYSTEM MASK, the instruction-length code is set to 2, and the instruction address is incremented by 4. The PSW containing the invalid value introduced into the system-mask field is stored as the old PSW.

Late Exception Recognition
For the following conditions, the exception is recognized as part of the execution of the next instruction:

- A specification exception is recognized due to an odd instruction address in the PSW (PSW bit 127 is one).
- An access exception (addressing, ASCE-type, page-translation, protection, region-translation, segment-translation, or translation-specification) is associated with the location designated by the instruction address or with the location of the
second or third halfword of the instruction starting at the designated instruction address.

The instruction-length code and instruction address stored in the program old PSW under these conditions are discussed in “ILC on Instruction-Fetching Exceptions” on page 6-7, and an example is given in Figure 4-9 on page 4-39.

If an I/O, external, or machine-check-interruption condition is pending and the PSW causes the CPU to be enabled for that condition, the corresponding interruption occurs, and the PSW is not inspected for exceptions which are recognized late. Similarly, a PSW specifying the wait state is not inspected for exceptions which are recognized late.

Programming Notes:

1. The execution of BRANCH AND SET AUTHORITY, LOAD ADDRESS SPACE PARAMETERS, LOAD PSW, LOAD PSW EXTENDED, PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, RESUME PROGRAM, SET PREFIX, SET SECONDARY ASN, SET SECONDARY ASN WITH INSTANCE, SET SYSTEM MASK, STORE THEN AND SYSTEM MASK, and STORE THEN OR SYSTEM MASK is suppressed on an addressing or protection exception, and hence the program old PSW provides information concerning the program causing the exception.

2. When the first halfword of an instruction can be fetched but an access exception is recognized on fetching the second or third halfword, the ILC is not necessarily related to the operation code.

3. If the new PSW introduced by an interruption contains a PSW-format error, a string of interruptions may occur. (See “Priority of Interruptions” on page 6-55.)

External Interruption

The external interruption provides a means by which the CPU responds to various signals originating from either inside or outside the configuration.

An external interruption causes the old PSW to be stored at real locations 304-319 and a new PSW to be fetched from real locations 432-447.

The source of the interruption is identified in the interruption code which is stored at real locations 134-135. The instruction-length code is not stored.

Additionally, for the malfunction-alert, emergency-signal, and external-call conditions, a 16-bit CPU address is associated with the source of the interruption and is stored at real locations 132-133. When the CPU address is stored, bit 6 of the interruption code is set to one. For all other conditions, no CPU address is stored, bit 6 of the interruption code is set to zero, and zeros are stored at real locations 132-133.

For the timing-alert and service-signal interruptions, a 32-bit parameter is associated with the interruption and is stored at real locations 128-131. Bit 5 of the external-interruption code indicates that a parameter has been stored. When bit 5 is zero, the contents of real locations 128-131 remain unchanged.

External-interruption conditions are presented as one of three types of interruption requests: pendable, direct-condition, and floating as described below:

- A pendable interruption request is preserved and remains pending in each CPU until it is honored at the CPU. The pendable interruption condition is cleared when the interruption occurs.

- A direct-condition interruption request is pending only during the time that the condition exists. If the condition is removed before the request is honored, then no interruption occurs. If the condition persists, then more than one interruption may result from a single occurrence of the condition.

- A floating interruption request is held pending external to the CPU. The interruption can be accepted by any CPU in the configuration. The information associated with the interruption is not transferred to a particular CPU until the interruption occurs. The floating interruption condition is cleared when the interruption is accepted at any CPU in the configuration.

The clock comparator and CPU timer external-interruption conditions result in direct-condition interruption requests. The interrupt-key, malfunction-alert,
emergency-signal, and external-call external-interruption conditions result in pendable interruption requests. The service-signal external-interruption condition results in a floating interruption request. The timing-alert external-interruption condition results in either a floating interruption request or a pendable interruption request. See the individual description of each of the external-interruption conditions for additional details.

When several interruption requests for a single source are generated before the interruption occurs, and the interruption condition is a pendable or floating interruption request, only one request for that source is preserved and remains pending.

An external interruption for a particular source can occur only when the CPU is enabled for interruption by that source. The external interruption occurs at the completion of a unit of operation. The external mask, PSW bit 7, and external subclass-mask bits in control register 0 control whether the CPU is enabled for a particular source. Each source for an external interruption has a subclass-mask bit assigned to it, and the source can cause an interruption only when the external-mask bit is one and the corresponding subclass-mask bit is one.

When the CPU becomes enabled for a pendable or floating external-interruption condition, the interruption occurs at the completion of the instruction execution or interruption that causes the enabling.

More than one source may present a request for an external interruption at the same time. When the CPU becomes enabled for more than one concurrently pending request, the interruption occurs for the pending condition or conditions having the highest priority.

The priorities for external-interruption requests in descending order are as follows:

- Interrupt key
- Malfunction alert
- Emergency signal
- External call
- Clock comparator
- CPU timer
- Timing alert
- Warning track
- Service signal or measurement alert

All requests are honored one at a time. When more than one emergency-signal request exists at a time or when more than one malfunction-alert request exists at a time, the request associated with the smallest CPU address is honored first.

Clock Comparator

When the TOD-clock-steering facility is not installed, an interruption request for the clock comparator exists whenever either of the following conditions is met:

1. The TOD clock is in the set or not-set state, and the value of the clock comparator is less than the value in the compared portion of the TOD clock, both compare values being considered unsigned binary integers.

2. The TOD clock is in the error or not-operational state.

When the TOD-clock-steering facility is installed, an interruption request for the clock comparator exists whenever the physical clock is in the set state and the value of the clock comparator is less than the value in the compared portion of the logical TOD clock, both compare values being considered unsigned binary integers.

When the TOD-clock-steering facility is installed and a CPU remains in the wait state for a long period of time, clock-comparator interruptions may be proportionally late by the maximum steering rate.

If the condition responsible for the request is removed before the request is honored, the request does not remain pending, and no interruption occurs. Conversely, the request is not cleared by the interruption, and, if the condition persists, more than one interruption may result from a single occurrence of the condition.

When the TOD-clock-steering facility is not installed, and the TOD clock is set or changes state, interruption conditions, if any, that are due to the clock comparator may or may not be recognized for up to 1.048576 seconds after the change.

When the TOD-clock-steering facility is installed and the physical clock is set or changes state, or the logical TOD clock is changed by PTFF-ATO or PTFF-STO, the CPUs in the configuration do not necessar-
ily recognize this change for purposes of clock comparator interruptions until one of the following instructions is issued: SET CLOCK COMPARATOR (SCKC), STORE CLOCK (STCK), or STORE CLOCK EXTENDED (STCKE). If a CPU is in the wait state when this change occurs, it may not recognize the change until it leaves the wait state and one of the aforementioned instructions is executed.

The subclass-mask bit is in bit position 52 of control register 0. This bit is initialized to zero.

The clock-comparator condition is indicated by an external-interruption code of 1004 hex.

**CPU Timer**

An interruption request for the CPU timer exists whenever the CPU-timer value is negative (bit 0 of the CPU timer is one). If the value is made positive before the request is honored, the request does not remain pending, and no interruption occurs. Conversely, the request is not cleared by the interruption, and, if the condition persists, more than one interruption may occur from a single occurrence of the condition.

When the TOD-clock-steering facility is not installed, and the TOD clock is set or changes state, interruption conditions, if any, that are due to the CPU timer may or may not be recognized for up to 1.048576 seconds after the change.

When the TOD-clock-steering facility is installed, CPU timer interruptions may or may not be recognized while the physical clock is in the stopped state. After the physical clock enters the set state, interruption conditions for the CPU timer are not necessarily recognized until SET CPU TIMER (SPT) is issued. CPU timer interruptions are not affected by changes to the logical TOD clock.

The subclass-mask bit is in bit position 53 of control register 0. This bit is initialized to zero.

The CPU-timer condition is indicated by an external-interruption code of 1005 hex.

**Emergency Signal**

An interruption request for an emergency signal is generated when the CPU accepts the emergency-signal order specified by a SIGNAL PROCESSOR instruction addressing this CPU. The instruction may have been executed by this CPU or by another CPU in the configuration. The request is preserved and remains pending in the receiving CPU until it is cleared. The pending request is cleared when it causes an interruption and by CPU reset.

Facilities are provided for holding a separate emergency-signal request pending in the receiving CPU for each CPU in the configuration, including the receiving CPU itself.

The subclass-mask bit is in bit position 49 of control register 0. This bit is initialized to zero.

The emergency-signal condition is indicated by an external-interruption code of 1201 hex. The address of the CPU that executed the SIGNAL PROCESSOR instruction is stored at real locations 132-133.

**External Call**

An interruption request for an external call is generated when the CPU accepts the external-call order specified by a SIGNAL PROCESSOR instruction addressing this CPU. The instruction may have been executed by this CPU or by another CPU in the configuration. The request is preserved and remains pending in the receiving CPU until it is cleared. The pending request is cleared when it causes an interruption and by CPU reset.

Only one external-call request, along with the processor address, may be held pending in a CPU at a time.

The subclass-mask bit is in bit position 50 of control register 0. This bit is initialized to zero.

The external-call condition is indicated by an external-interruption code of 1202 hex. The address of the CPU that executed the SIGNAL PROCESSOR instruction is stored at real locations 132-133.

**Interrupt Key**

An interruption request for the interrupt key is generated when the operator activates that key. The request is preserved and remains pending in the CPU until it is cleared. The pending request is
cleared when it causes an interruption and by CPU reset.

When the interrupt key is activated while the CPU is in the load state, it depends on the model whether an interruption request is generated or the condition is lost.

The subclass-mask bit is in bit position 57 of control register 0. This bit is initialized to one.

The interrupt-key condition is indicated by an external-interruption code of 0040 hex.

Malfunction Alert

An interruption request for a malfunction alert is generated when another CPU in the configuration enters the check-stop state or loses power. The request is preserved and remains pending in the receiving CPU until it is cleared. The pending request is cleared when it causes an interruption and by CPU reset.

Facilities are provided for holding a separate malfunction-alert request pending in the receiving CPU for each of the other CPUs in the configuration. Removal of a CPU from the configuration does not generate a malfunction-alert condition.

The subclass-mask bit is in bit position 48 of control register 0. This bit is initialized to zero.

The malfunction-alert condition is indicated by an external-interruption code of 1200 hex. The address of the CPU that generated the condition is stored at real locations 132-133.

Measurement Alert

The measurement-alert external interruption is described in the publication The Set-Program-Parameter and CPU-Measurement Facilities (SA23-2260).

The measurement-alert subclass-mask bit is in bit position 58 of control register 0. This bit is initialized to one, which enables the interruption.

The measurement-alert condition is indicated by an external interruption code of 1407 hex. The interruption parameter stored at real locations 128-131 indicate the cause or causes for the interruption.

Timing Alert

An interruption request for a timing alert is generated when an ETR-timing-alert or STP-timing-alert condition is detected.

If the same timing-alert condition occurs more than once before the interruption occurs, the request is generated only once.

When the STP-floating-interrupt facility is not installed or is not enabled for STP timing-alert floating interruptions, the timing-alert condition causes a pendable interruption request to be generated for each CPU in the configuration and to remain pending at each CPU until it is cleared. The pending request is cleared when it causes an interruption at the CPU and by CPU reset.

When the STP-floating-interrupt facility is installed and is enabled for STP timing-alert floating interruptions, an STP timing-alert condition causes a floating interruption request to be generated.

The subclass-mask bit is in bit position 59 of control register 0. This bit is initialized to zero.

The timing-alert condition is indicated by an external interruption code of 1406 hex. The interruption

Service Signal

An interruption request for a service signal is generated upon the completion of certain configuration-control and maintenance functions, such as those initiated by means of the model-dependent DIAGNOSE instruction. A 32-bit parameter is provided with the interruption to assist the program in determining the operation for which the interruption is reported.

Service signal is a floating interruption condition and is presented to the first CPU in the configuration which can perform the interruption. The interruption condition is cleared when it causes an interruption in any one of the CPUs and also by subsystem reset.

The subclass-mask bit is in bit position 54 of control register 0. This bit is initialized to zero.

The service-signal condition is indicated by an external-interruption code of 2401 hex. A 32-bit parameter is stored at real locations 128-131.
parameter stored at real locations 128-131 indicate the reason or reasons for the signal.

**ETR-Timing-Alert Condition**
An ETR-timing-alert condition is detected when a port-availability change occurs at any port in the current CPC-port group or when an ETR alert occurs. The terms specific to the ETR are not defined in this publication.

**STP-Timing-Alert Condition**
An STP-timing-alert condition is detected when any of the following occur:

* **Timing Status Change:** A timing-status-change condition is detected when a timing-status change has occurred for the configuration. Timing status for a configuration includes the timing mode, timing state, the STP-clock-source state, and certain external time source conditions.

A timing-state change from the synchronized state to the unsynchronized or stopped state is reported as an ETR- or STP-sync-check machine-check condition rather than a timing-alert external interruption condition.

An STP-clock-source-state change from the usable state to the not-usable is reported as a clock-source-error machine-check condition rather than a timing-alert external interruption condition.

* **Link Availability Change:** A link-availability-change condition is detected when the availability of an STP link has changed. The condition is detected whenever an STP link state that was unavailable becomes available for STP communication, or when a link that was available becomes unavailable for STP communication.

A timing-alert condition is not generated by a link-availability-change condition if a CTN configuration-change machine check condition is detected concurrently with the link-availability change.

* **Time Control Parameter Change:** The time control-parameter-change condition is detected when any of the time-control parameters change for the configuration, including when a time-control-parameter change is scheduled. Time-control parameters for a configuration include the following:
  - Total-time offset (the combination of time-zone offset and DST offset)
  - Leap seconds offset
  - Time-zone offset
  - Daylight-savings-time (DST) offset
  - Scheduled changes to any of the above

A 32-bit parameter is associated with the interruption and is stored at real locations 128-131. The field is defined as shown below:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-13</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Timing-status change</td>
</tr>
<tr>
<td>15</td>
<td>Link-availability change</td>
</tr>
<tr>
<td>16</td>
<td>Time-control-parameter change</td>
</tr>
<tr>
<td>17-31</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Multiple alert conditions may be indicated concurrently in the external-interruption parameter field.

**Warning Track**
An interruption request for a warning-track event may be generated to inform the control program it is nearing the end of the current execution interval on a shared CPU. The interruption request is a pending-condition type which may be generated when the configuration is registered and is enabled for warning-track interruptions.

When the configuration is enabled for multithreading, a warning-track interruption may be made pending for each CPU of a core.

The subclass-mask bit is in bit position 30 of control register 0. This bit is initialized to zero.

The warning-track condition is indicated by an external-interruption code of 1007 hex.

**I/O Interruption**
The input/output (I/O) interruption provides a means by which the CPU responds to conditions originating in I/O devices and the channel subsystem.

A request for an I/O interruption may occur at any time, and more than one request may occur at the
same time. The requests are preserved and remain pending until accepted by a CPU, or until cleared by some other means, such as subsystem reset.

The I/O interruption occurs at the completion of a unit of operation. Priority is established among requests so that in each CPU only one interruption request is processed at a time. Priority among requests for interruptions of differing I/O-interruption subclasses is according to the numerical value of the I/O-interruption subclass (with zero having the highest priority), in conjunction with the I/O-interruption subclass-mask settings in control register 6. For more details, see “I/O Interruptions” on page 16-1.

When a CPU becomes enabled for I/O interruptions and the channel subsystem has established priority for a pending I/O-interruption condition, the interruption occurs at the completion of the instruction execution or interruption that causes the enabling.

An I/O interruption causes the old PSW to be stored at real locations 368-383 and a new PSW to be fetched from real locations 496-511. Additional information, in the form of an eight-byte I/O-interruption code, is stored at real locations 184-195. The I/O-interruption code consists of a 32-bit subsystem-identification word, a 32-bit interruption parameter, and a 32-bit I/O-interruption identification word.

An I/O interruption can occur only while a CPU is enabled for the interruption subclass presenting the request. The I/O-mask bit, bit 6 of the PSW, and the I/O-interruption subclass mask in control register 6 determine whether the CPU is enabled for a particular I/O interruption.

I/O interruptions are grouped into eight I/O-interruption subclasses, numbered from 0-7. Each I/O-interruption subclass has an associated I/O-interruption subclass-mask bit in bit positions 32-39 of control register 6. Each subchannel has an I/O-interruption subclass value associated with it. The CPU is enabled for I/O interruptions of a particular I/O-interruption subclass only when PSW bit 6 is one and the associated I/O-interruption subclass-mask bit in control register 6 is also one. If the corresponding I/O-interruption subclass-mask bit is zero, then the CPU is disabled for I/O interruptions with that subclass value. I/O interruptions for all subclasses are disallowed when PSW bit 6 is zero.

### Machine-Check Interruption

The machine-check interruption is a means for reporting to the program the occurrence of equipment malfunctions. Information is provided to assist the program in determining the source of the fault and extent of the damage.

A machine-check interruption causes the old PSW to be stored at real locations 352-367 and a new PSW to be fetched from real locations 480-495.

The cause and severity of the malfunction are identified by a 64-bit machine-check-interruption code stored at real locations 232-239. Further information identifying the cause of the interruption and the location of the fault may be stored at real locations 244-255 and 4608-5119.

The interruption action and the storing of the associated information are under the control of PSW bit 13 and bits in control register 14. See Chapter 11, “Machine-Check Handling” for more detailed information.

### Program Interruption

Program interruptions are used to report exceptions and events which occur during execution of the program.

A program interruption causes the old PSW to be stored at real locations 336-351 and a new PSW to be fetched from real locations 464-479.

The cause of the interruption is identified by the interruption code. The interruption code is placed at real locations 142-143, the instruction-length code is placed in bit positions 5 and 6 of the byte at real location 141 with the rest of the bits set to zeros, and zeros are stored at real location 140. When a transaction is aborted due to a program interruption, the instruction-length code is respective to the instruction at which the exception condition was detected. For some causes, additional information identifying the reason for the interruption is stored at real locations 144-183.

If the PER-3 facility is installed, then, as part of the program interruption action, the contents of the
breaking-event-address register are placed in real storage locations 272-279.

Except for PER events and the crypto-operation exception, the condition causing the interruption is indicated by a coded value placed in the rightmost seven bit positions of the interruption code. Only one condition at a time can be indicated. Bits 0-7 of the interruption code are set to zeros.

PER events are indicated by setting bit 8 of the interruption code to one. When this is the only condition, bits 0-7 and 9-15 are also set to zeros. When a PER event is indicated concurrently with another program-interruption condition, bit 8 is one, and bits 0-7 and 9-15 are set as for the other condition.

The crypto-operation exception is indicated by an interruption code of 0119 hex, or 0199 hex if a PER event is also indicated.

When there is a corresponding mask bit, a program interruption can occur only when that mask bit is one. The program mask in the PSW controls four of the exceptions, the IEEE masks in the FPC register control the IEEE exceptions, bit 33 in control register 0 controls whether SET SYSTEM MASK causes a special-operation exception, bits 48-63 in control register 8 control interruptions due to monitor events, and a hierarchy of masks control interruptions due to PER events. When any controlling mask bit is zero, the condition is ignored; the condition does not remain pending.

Programming Notes:

1. When the new PSW for a program interruption has a PSW-format error or causes an exception to be recognized in the process of instruction fetching, a string of program interruptions may occur. See “Priority of Interruptions” on page 6-55 for a description of how such strings are terminated.

2. Some of the conditions indicated as program exceptions may be recognized also by the channel subsystem, in which case the exception is indicated in the subchannel-status word or extended-status word.

Data-Exception Code (DXC)

When a data exception causes a program interruption, a data-exception code (DXC) is stored at location 147, and zeros are stored at locations 144-146. The DXC distinguishes between the various types of data-exception conditions. When the AFP-register (additional floating-point register) control bit, bit 45 of control register 0, is one, the DXC is also placed in the D XC field of the floating-point-control (FPC) register. The D XC field in the FPC register remains unchanged when any other program exception is reported. The D XC is an 8-bit code indicating the specific cause of a data exception. The data exceptions and data-exception codes are shown in Figure 6-2 and Figure 6-3 on page 6-17.

Priority of Program Interruptions for Data Exceptions

D XC 2 and 3 are mutually exclusive and are of higher priority than any other D XC. Thus, for example, D XC 2 (BFP instruction) takes precedence over any IEEE exception; and D XC 3 (DFP instruction) takes precedence over any IEEE exception or simulated IEEE exception. As another example, if the conditions for both D XC 3 (DFP instruction) and D XC 1 (AFP register) exist, D XC 3 is reported.

When both a specification exception and an AFP-register data exception or a vector-instruction data exception apply, it is unpredictable which one is reported.

<table>
<thead>
<tr>
<th>D XC (Hex)</th>
<th>Data Exception</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>General operand</td>
</tr>
<tr>
<td>01</td>
<td>AFP register</td>
</tr>
<tr>
<td>02</td>
<td>BFP instruction</td>
</tr>
<tr>
<td>03</td>
<td>DFP instruction</td>
</tr>
<tr>
<td>04</td>
<td>Quantum Exception</td>
</tr>
<tr>
<td>07</td>
<td>Simulated Quantum Exception</td>
</tr>
<tr>
<td>08</td>
<td>IEEE inexact and truncated</td>
</tr>
<tr>
<td>08</td>
<td>Simulated IEEE inexact</td>
</tr>
<tr>
<td>0C</td>
<td>IEEE inexact and incremented</td>
</tr>
<tr>
<td>10</td>
<td>IEEE underflow, exact</td>
</tr>
<tr>
<td>13</td>
<td>Simulated IEEE underflow, exact</td>
</tr>
<tr>
<td>18</td>
<td>IEEE underflow, inexact and truncated</td>
</tr>
</tbody>
</table>

Figure 6-2. Data-exception codes (D XC)
<table>
<thead>
<tr>
<th>DXC (Hex)</th>
<th>Data Exception</th>
</tr>
</thead>
<tbody>
<tr>
<td>1B</td>
<td>Simulated IEEE underflow, inexact</td>
</tr>
<tr>
<td>1C</td>
<td>IEEE underflow, inexact and incremented</td>
</tr>
<tr>
<td>20</td>
<td>IEEE overflow, exact</td>
</tr>
<tr>
<td>23</td>
<td>Simulated IEEE overflow, exact</td>
</tr>
<tr>
<td>28</td>
<td>IEEE overflow, inexact and truncated</td>
</tr>
<tr>
<td>2B</td>
<td>Simulated IEEE overflow, inexact</td>
</tr>
<tr>
<td>2C</td>
<td>IEEE overflow, inexact and incremented</td>
</tr>
<tr>
<td>40</td>
<td>IEEE division by zero</td>
</tr>
<tr>
<td>43</td>
<td>Simulated IEEE division by zero</td>
</tr>
<tr>
<td>80</td>
<td>IEEE invalid operation</td>
</tr>
<tr>
<td>83</td>
<td>Simulated IEEE invalid operation</td>
</tr>
</tbody>
</table>

**FE** Vector instruction

**FF** Compare-and-trap instruction

*Figure 6-2. Data-exception codes (DXC) (Continued)*

<table>
<thead>
<tr>
<th>Exception</th>
<th>Applicable Instruction Types</th>
<th>CR0.45</th>
<th>FPC Mask</th>
<th>FPC Flag</th>
<th>DXC (Binary)</th>
<th>Instruction Action</th>
<th>DXC Placed in Real Loc. 147</th>
<th>DXC Placed in FPC Byte 2</th>
</tr>
</thead>
<tbody>
<tr>
<td>General operand</td>
<td>Various†</td>
<td>0</td>
<td>none</td>
<td>none</td>
<td>0000 0000</td>
<td>Suppress or Terminate</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AFP register</td>
<td>FPS &amp; HFP</td>
<td>0*</td>
<td>none</td>
<td>none</td>
<td>0000 0001</td>
<td>Suppress</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>BFP instruction</td>
<td>BFP</td>
<td>0*</td>
<td>none</td>
<td>none</td>
<td>0000 0010</td>
<td>Suppress</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>DFP instruction</td>
<td>DFP</td>
<td>0*</td>
<td>none</td>
<td>none</td>
<td>0000 0011</td>
<td>Suppress</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>IEEE invalid operation</td>
<td>ICMP</td>
<td>1*</td>
<td>0.0</td>
<td>1.0</td>
<td>1000 0000</td>
<td>Suppress²</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>IEEE division by zero</td>
<td>ICMP</td>
<td>1*</td>
<td>0.1</td>
<td>1.1</td>
<td>0100 0000</td>
<td>Suppress²</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>IEEE overflow</td>
<td>ICMP</td>
<td>1*</td>
<td>0.2</td>
<td>1.2</td>
<td>0010 xy00</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>IEEE underflow</td>
<td>ICMP</td>
<td>1*</td>
<td>0.3</td>
<td>1.3</td>
<td>0001 xy00</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>IEEE inexact</td>
<td>ICMP</td>
<td>1*</td>
<td>0.4</td>
<td>1.4</td>
<td>0000 1y00</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Quantum Exception</td>
<td>ICMP</td>
<td>1*</td>
<td>0.5</td>
<td>1.5</td>
<td>0000 0100</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Simulated IEEE invalid operation</td>
<td>IXS</td>
<td>1*</td>
<td>0.0</td>
<td>1.0</td>
<td>1000 0011</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Simulated IEEE division by zero</td>
<td>IXS</td>
<td>1*</td>
<td>0.1</td>
<td>1.1</td>
<td>0100 0011</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Simulated IEEE overflow</td>
<td>IXS</td>
<td>1*</td>
<td>0.2</td>
<td>1.2</td>
<td>0010 w011</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Simulated IEEE underflow</td>
<td>IXS</td>
<td>1*</td>
<td>0.3</td>
<td>1.3</td>
<td>0001 w011</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Simulated IEEE inexact</td>
<td>IXS</td>
<td>1*</td>
<td>0.4</td>
<td>1.4</td>
<td>0000 1011</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Simulated Quantum Exception</td>
<td>IXS</td>
<td>1*</td>
<td>0.5</td>
<td>1.5</td>
<td>0000 0111</td>
<td>Complete</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Vector instruction</td>
<td>VEC</td>
<td>0†</td>
<td>none</td>
<td>none</td>
<td>1111 1110</td>
<td>Suppress</td>
<td>Yes</td>
<td>Unp</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1‡</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Figure 6-3. Data Exceptions*
Data-exception code (DXC) in bits 16-23 of the floating-point control register (FPCR) is primarily intended for use by floating-point applications that rely on the enablement of the advanced-floating-point (AFP) control, bit 45 of control register 0. When a data-exception program interruption occurs as a result of the execution of a compare-and-trap or a load-and-trap facility instruction (DXC 255), the DXC in the FPCR may contain an unpredictable value under the following conditions:

1. For a control program, an instruction examining the FPCR (for example, EXTRACT FPC) is the first instruction that is subject to the AFP control to be executed since the last initial-CPU reset.
2. For a task running under a control program such as z/OS, an instruction examining the FPCR is the first instruction that is subject to the AFP control to be executed by the task.

This unpredictability is the result of the control program or task being dispatched with the AFP control initially set to zero, and only applies to DXC 255 in the FPCR. Subsequent inspections of the DXC in the FPCR will yield predictable values.

If the program always needs to observe a predictable compare-and-trap DXC value in the FPCR, it should first issue any instruction that is subject to the AFP control (for example EXTRACT FPC) before issuing an instruction that causes the data-exception program interruption for the compare-and-trap condition. Alternatively, the program can inspect the DXC stored in real location 147, as copied into a control-program-supplied diagnostic work area; the DXC stored at location 147 is predictable in all cases.
Vector-Exception Code

When a vector-processing exception causes a program interruption, a vector-exception code (VXC) is stored at location 147, and zeros are stored at locations 144-146. The VXC is also placed in the DXC field of the floating-point-control (FPC) register if bit 45 of control register 0 is one. When bit 45 of control register 0 is zero and bit 46 of control register 0 is one, the DXC field of the FPC register and the contents of storage at location 147 are unpredictable. The VXC distinguishes between various types of vector floating point exceptions and which element caused the exception.

The VXC has the following format:

<table>
<thead>
<tr>
<th>VIX</th>
<th>VIC</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-3</td>
<td>4-7</td>
</tr>
</tbody>
</table>

Bits 0-3 of the VXC are the vector index (VIX). This is the index to the leftmost element that recognized the exception.

Bits 4-7 of the VXC are the vector interrupt code (VIC). This field can have the following values:

- 0001 - IEEE invalid operation
- 0010 - IEEE division by zero
- 0011 - IEEE overflow
- 0100 - IEEE underflow
- 0101 - IEEE inexact

Program-Interruption Conditions

The following is a detailed description of each program-interruption condition.

Addressing Exception

An addressing exception is recognized when the CPU attempts to reference a main-storage location that is not available in the configuration. A main-storage location is not available in the configuration when the location is not installed, when the storage unit is not in the configuration, or when power is off in the storage unit. An address designating a storage location that is not available in the configuration is referred to as invalid.

The operation is suppressed when the address of the instruction is invalid. Similarly, the operation is suppressed when the address of the target instruction of an execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG) is invalid. Also, the unit of operation is suppressed when an addressing exception is encountered in accessing a table or table entry. The tables and table entries to which the rule applies are the dispatchable-unit-control table, the primary ASN-second-table entry, and entries in the access list, region first table, region second table, region third table, segment table, page table, linkage table, linkage-first table, linkage-second table, entry table, ASN first table, ASN second table, authority table, linkage stack, and trace table. Addressing exceptions result in suppression when they are encountered for references to the region first table, region second table, region third table, segment table, and page table, in both implicit references for dynamic address translation and references associated with the execution of LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, STORE REAL ADDRESS, and TEST PROTECTION. Similarly, addressing exceptions for accesses to the dispatchable-unit-control table, primary ASN-second-table entry, access list, ASN second table, or authority table result in suppression when they are encountered in access-register translation done either implicitly or as part of LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, STORE REAL ADDRESS, TEST ACCESS, or TEST PROTECTION.

Except for some specific instructions whose execution is suppressed, the operation is terminated for an operand address that can be translated but designates an unavailable location. See Figure 6-4 on page 6-20.

For termination, changes may occur only to result fields. In this context, the term “result field” includes the condition code, registers, and any storage locations that are provided and that are designated to be changed by the instruction. Therefore, if an instruction is due to change only the contents of a field in storage, and every byte of the field is in a location that is not available in the configuration, the operation is suppressed. When part of an operand location is available in the configuration and part is not, storing may be performed in the part that is available in the configuration.

When an addressing exception occurs during the fetching of an instruction or during the fetching of a DAT table entry associated with an instruction fetch, it is unpredictable whether the ILC is 1, 2, or 3. When the exception is associated with fetching the target of EXECUTE, the ILC is 2. When the exception is asso-
Associated with fetching the target of EXECUTE RELATIVE LONG, the ILC is 3.

In all cases of addressing exceptions not associated with instruction fetching, the ILC is 1, 2, or 3, indicating the length of the instruction that caused the reference.

<table>
<thead>
<tr>
<th>Exception</th>
<th>Table-Entry Fetch</th>
<th>Table-Entry Store</th>
<th>Instruction Fetch</th>
<th>Operand Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>Addressing exception</td>
<td>Suppress</td>
<td>Suppress</td>
<td>Suppress</td>
<td>Suppress for IPTE, LASP, LPSW, LPSWE, MSCH, PLO, RP, SCKC, SPT, SPX, SSCH, SSM, STCRW, STNSM, STOSM, TPI, and TPROT</td>
</tr>
<tr>
<td>Protection exception for key-controlled protection</td>
<td>--</td>
<td>--</td>
<td>Suppress</td>
<td>Suppress for IPTE, LASP, LPSW, LPSWE, MSCH, PLO, RP, SCKC, SPT, SPX, SSCH, SSM, STCRW, STNSM, STOSM, and TPI</td>
</tr>
<tr>
<td>Protection exception for access-list-controlled protection</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>Suppress</td>
</tr>
<tr>
<td>Protection exception for DAT protection</td>
<td>--</td>
<td>Suppress 3</td>
<td>--</td>
<td>Suppress 5</td>
</tr>
<tr>
<td>Protection exception for low-address protection</td>
<td>--</td>
<td>Suppress 5</td>
<td>--</td>
<td>Suppress for IPTE, PLO, STCRW, STNSM, STOSM, and TPI</td>
</tr>
</tbody>
</table>

Explanation:
-- Not applicable
1 Table entries include region table, segment table, page table, linkage table, linkage-first table, linkage-second table, entry table, ASN first table, ASN second table, authority table, dispatchable-unit-control table, primary ASN-second-table entry, access list, and linkage stack.
2 Table entries include linkage stack and trace table.
3 DAT protection applies to the linkage stack but not the trace table.
4 For termination, changes may occur only to result fields. In this context, “result field” includes condition code, registers, and storage locations, if any, which are designated to be changed by the instruction. However, no change is made to a storage location or a storage key when the reference causes an access exception. Therefore, if an instruction is due to change only the contents of a field in main storage, and every byte of that field would cause an access exception, the result is the same as if the operation had been suppressed. The action may be, for key-controlled protection and low-address protection, suppression instead of termination; see “Suppression on Protection” in Chapter 3, “Storage.”
5 When the effective address of TPI is zero, the store access is to implicit real locations 184-191, and key-controlled protection, DAT protection, and low-address protection do not apply.
6 Suppression occurs only for the compare-and-load and compare-and-swap operations.

Figure 6-4. Summary of Action for Addressing and Protection Exceptions

**AFX-Translation Exception**

An AFX-translation exception is recognized when, during ASN translation in the space-switching form of PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, or SET SECONDARY ASN WITH INSTANCE, or during ASN translation in PROGRAM RETURN when the restored SASN does not equal the restored PASN, bit 0 of the ASN-first-table entry used is not zero.
The ASN being translated is stored at real locations 174 and 175, and real locations 172 and 173 are set with zeros.

The operation is nullified.

The instruction-length code is 1 or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The AFX-translation exception is indicated by a program-interruption code of 0020 hex (or 00A0 hex if a concurrent PER event is indicated).

ALEN-Translation Exception

An ALEN-translation exception is recognized during access-register translation when either:

1. The access register used contains an access-list-entry number that designates an access-list entry which is beyond the end of the access list designated by the effective access-list designation.

2. Bit 0 of the access-list entry is not zero.

The number of the access register is stored in bit positions 4-7 of real location 160, and bits 0-3 of the location are set to zeros.

The operation is nullified.

The instruction-length code is 1, 2, or 3.

The ALEN-translation exception is indicated by a program-interruption code of 0029 hex (or 00A9, 0229, or 02A9 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

ALE-Sequence Exception

An ALE-sequence exception is recognized during access-register translation when the access register used contains an access-list-entry sequence number (ALESN) which is not equal to the ALESN in the access-list entry that is designated by the access register.

The number of the access register is stored in bit positions 4-7 at real location 160, and bits 0-3 are set to zeros.

The operation is nullified.

The instruction-length code is 1, 2, or 3.

The ALE-sequence exception is indicated by a program-interruption code of 0028 hex (or 00A8, 0228, or 02A8 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

ASCE-Type Exception

An ASCE-type exception is recognized when any of the following is true during dynamic address translation:

1. The address-space-control element being used is a region-second-table designation, and bits 0-10 of the virtual address being translated are not all zeros.

2. The address-space-control element being used is a region-third-table designation, and bits 0-21 of the virtual address being translated are not all zeros.

3. The address-space-control element being used is a segment-table designation, and bits 0-32 of the virtual address being translated are not all zeros.

The exception is recognized as part of the execution of the instruction that needs the translation of an instruction or operand address, except for the operand address in LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS, and TEST
PROTECTION, in which case the condition is indicated by the setting of the condition code.

When an interruption occurs, information about the virtual address causing the exception is stored at real locations 168-175 and conditionally at real locations 160 and 162. See “Assigned Storage Locations” on page 3-68 for a detailed description of this information.

The unit of operation is nullified.

When the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. When the exception occurs during a reference to the target of EXECUTE, the ILC is 2. When the exception occurs during a reference to the target of EXECUTE RELATIVE LONG, the ILC is 3.

When the exception occurs during a reference to an operand location, the instruction-length code (ILC) is 1, 2, or 3 and indicates the length of the instruction causing the exception.

The ASCE-type exception is indicated by a program-interruption code of 0038 hex (or 00B8, 0238, or 02B8 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

ASTE-Instance Exception

An ASTE-instance exception is recognized when the ASN-and-LX-reuse facility is installed, and any of the following is true:

1. During ASN translation in PROGRAM TRANSFER WITH INSTANCE with space switching, the ASTEIN in bit positions 0-31 of general register R1 is not equal to the ASTEIN in the located ASTE.

2. During PASN translation in PROGRAM RETURN with space switching, the ASN-and-LX-reuse control in control register 0 is one and the PASTEIN in the linkage-stack state entry is not equal to the ASTEIN in the located ASTE.

3. During ASN translation in SET SECONDARY ASN WITH INSTANCE with space switching, the ASTEIN in bit positions 0-31 of general register R1 is not equal to the ASTEIN in the located ASTE.

4. During SASN translation in PROGRAM RETURN to current primary or with space switching, the ASN-and-LX-reuse control in control register 0 is one, and the SASTEIN in the linkage-stack state entry is not equal to the ASTEIN in the located ASTE.

Information is stored as follows:

- In cases 1 and 2, bit 2 of real location 160 is set to one, and bits 0, 1, and 3-7 are set to zeros.
- In cases 3 and 4, bit 3 of real location 160 is set to one, and bits 0-2 and 4-7 are set to zeros.

The operation is nullified.

The instruction-length code is 1, 2, or 3.

The ASTE-instance exception is indicated by a program-interruption code of 002F hex (or 00AF hex if a concurrent PER event is indicated).

ASTE-Sequence Exception

An ASTE-sequence exception is recognized when any of the following is true:

1. During access-register translation, except as in 2, the access-list entry used contains an ASN-second-table-entry sequence number (ASTESN) which is not equal to the ASTESN in the ASN-second-table entry that is designated by the access-list entry. The access-list entry is the one designated by the access register used.

2. During access-register translation of ALET 1 by BRANCH IN SUBSPACE GROUP, the subspace ASTESN (SSASTESPN) in the dispatchable-unit control table (DUCT) is not equal to the ASTESN in the subspace ASTE designated by the subspace-ASTE origin (SSASTEO) in the DUCT.

3. During a subspace-replacement operation, the subspace ASTESN (SSASTESPN) in the dispatchable-unit control table (DUCT) is not equal to the ASTESN in the subspace ASTE designated by the subspace-ASTE origin (SSASTEO) in the DUCT.

In the first and second cases, the number of the access register is stored in bit positions 4-7 at real location 160, and bits 0-3 are set to zeros. In the third case, all zeros are stored at real location 160.

The operation is nullified.

The instruction-length code is 1, 2, or 3.
The ASTE-sequence exception is indicated by a program-interruption code of 002C hex (or 00AC, 022C, or 02AC hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Programming Note:** The storing of zeros at real location 160 in the case of an ASTE-sequence exception recognized during a subspace-replacement operation is a unique indication since the use of access register 0 in access-register translation cannot result in the exception.

**ASTE-Validity Exception**

An ASTE-validity exception is recognized when any of the following is true:

1. During access-register translation, except as in 2, the access-list entry used designates an ASN-second-table entry in which bit 0 is not zero. The access-list entry is the one designated by the access register used.

2. During access-register translation of ALET 1 by BRANCH IN SUBSPACE GROUP, the subspace-ASTE origin (SSASTEO) in the dispatchable-unit control table designates an ASN-second-table entry in which bit 0 is not zero.

3. During a subspace-replacement operation, the subspace-ASTE origin (SSASTEO) in the dispatchable-unit control table designates an ASN-second-table entry in which bit 0 is not zero.

In the first and second cases, the number of the access register is stored in bit positions 4-7 at real location 160, and bits 0-3 are set to zeros. In the third case, all zeros are stored at real location 160.

The operation is nullified.

The instruction-length code is 1, 2, or 3.

The ASTE-validity exception is indicated by a program-interruption code of 002B hex (or 00AB, 022B, or 02AB hex, if a concurrent PER event is indicated, respectively).

**ASX-Translation Exception**

An ASX-translation exception is recognized when, during execution of the space-switching form of PROGRAM CALL, during ASN translation in the space-switching form of PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, or SET SECONDARY ASN WITH INSTANCE, or during ASN translation in PROGRAM RETURN when the restored SASN does not equal the restored PASN, bit 0 of the ASN-second-table entry used is not zero.

The ASN being translated is stored at real locations 174 and 175, and real locations 172 and 173 are set with zeros.

The operation is nullified.

The instruction-length code is 1 or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The ASX-translation exception is indicated by a program-interruption code of 0021 hex (or 00A1 hex if a concurrent PER event is indicated).

**Crypto-Operation Exception**

A crypto-operation exception is recognized when a crypto-facility instruction is executed while bit 61 of control register 0 is zero on a CPU which has the crypto facility installed and available. The crypto-operation exception is also recognized when a crypto-facility instruction is executed and the crypto facility is not installed or available on this CPU, but the facility can be made available to the program either on this CPU or another CPU in the configuration.

When a crypto-facility instruction is executed and the crypto facility is not installed on any CPU which is or can be placed in the configuration, it depends on the model whether a crypto-operation exception or an operation exception is recognized.

The operation is nullified when the crypto-operation exception is recognized.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.
The crypto-operation exception is indicated by a program-interruption code of 0119 hex (or 0199, 0319, or 0399 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

Data Exception
The data exceptions are shown in Figure 6-3 on page 6-17. A mask bit may or may not control whether an interruption occurs, as noted for each exception.

When a non-maskable data exception is recognized, a program interruption for a data exception always occurs.

Each of the IEEE exceptions is controlled by a mask bit in the floating-point-control (FPC) register. The handling of these exceptions is described in the section “IEEE Exceptions” on page 9-18.

A data exception is recognized for the following cases:

- **General-operand** data exception is recognized when an instruction which operates on decimal operands encounters invalid decimal digit or sign codes or has its operands specified improperly. The operation is suppressed, except that, for EDIT and EDIT AND MARK, it is model dependent whether the operation is suppressed or terminated. See the section “General-Operand Data Exception” on page 8-4 for details. A general-operand data exception is also recognized when COMPRESSION CALL encounters errors in its dictionaries, in which case it is model dependent whether the operation is suppressed or terminated. A general-operand data exception is also recognized when the reseed counter is zero for a PERFORM PSEUDORANDOM NUMBER OPERATION generate operation, in which case the operation is suppressed. The general-operand data exception is reported with DXC 0.

  **Note:** In earlier versions of the architecture, the general-operand data exception was known as the decimal-operand data exception.

- **AFP-register** data exception is recognized when bit 45 of control register 0 is zero, and a floating-point-support (FPS) instruction or a hexadecimal-floating-point (HFP) instruction specifies a floating-point register other than 0, 2, 4, or 6. AFP-register data exception is also recognized when bit 45 of control register 0 is zero and a PFPO instruction is executed. The operation is suppressed and is reported with DXC 1.

- **BFP-instruction** data exception is recognized when bit 45 of control register 0 is zero and a BFP instruction is executed. The operation is suppressed and is reported with DXC 2.

- **Compare-and-trap-instruction** data exception is recognized when the operands compared by COMPARE AND TRAP, COMPARE IMMEDIATE AND TRAP, COMPARE LOGICAL AND TRAP, or COMPARE LOGICAL IMMEDIATE AND TRAP match the conditions specified by the M3 field of the instruction. The operation is completed and is reported with DXC FF hex.

  When the load-and-trap facility is installed, compare-and-trap-instruction data exception is recognized when all zeros are loaded into the first operand of LOAD AND TRAP, LOAD HIGH AND TRAP, LOAD LOGICAL AND TRAP, and LOAD LOGICAL THIRTY ONE BITS AND TRAP. The operation is completed and is reported with DXC FF hex.

- **DFP-instruction** data exception is recognized when bit 45 of control register 0 is zero and a DFP instruction is executed. The operation is suppressed and is reported with DXC 3.

- **IEEE-exception** data exceptions are recognized when an IEEE computational instruction encounters an enabled exceptional condition. The operation is suppressed or completed, depending on the type of exception. See the section “IEEE Exceptions” on page 19-7 for details.

- **Simulated IEEE-exception** data exceptions are recognized when an IEEE-exception-simulation instruction (LOAD FPC AND SIGNAL or SET FPC AND SIGNAL) encounters an enabled signaling flag. The operation is completed. See the section “IEEE Exceptions” on page 19-7 for details.

- **Vector-instruction** data exceptions are recognized when bit 46 of control register 0 is zero and a vector instruction is executed. It is unpredictable if a data exception is recognized if bit 45 of control register 0 is zero, bit 46 of control register 0 is one, and a vector instruction is executed.
The operation is suppressed and is reported with DXC FE hex.

The instruction-length code is 1, 2, or 3.

The data exception is indicated by a program-interruption code of 0007 hex (or 0087, 0207, or 0287 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Decimal-Divide Exception**
A decimal-divide exception is recognized when in decimal division the divisor is zero or the quotient exceeds the specified data-field size.

The decimal-divide exception is indicated only if the sign codes of both the divisor and dividend are valid and only if the digit or digits used in establishing the exception are valid.

The operation is suppressed.

The instruction-length code is 2 or 3.

The decimal-divide exception is indicated by a program-interruption code of 000B hex (or 008B, 020B, or 028B hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Decimal-Overflow Exception**
A decimal-overflow exception is recognized when one or more nonzero digits are lost because the destination field in a decimal operation is too short to contain the result.

The interruption may be disallowed by the decimal-overflow mask (PSW bit 21).

The operation is completed. The result is obtained by ignoring the overflow digits, and condition code 3 is set.

The instruction-length code is 2 or 3.

The decimal-overflow exception is indicated by a program-interruption code of 000A hex (or 008A, 020A, or 028A hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Execute Exception**
The execute exception is recognized when the target instruction of an execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG) is one of the following instructions:

- Another execute-type instruction
- TRANSACTION ABORT
- TRANSACTION BEGIN
- TRANSACTION END

The operation is suppressed.

The instruction-length code is 2 or 3 and indicates the length of the execute-type instruction that attempted to execute the target instruction.

The execute exception is indicated by a program-interruption code of 0003 hex (or 0083, 0203, or 0283 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**EX-Translation Exception**
An EX-translation exception is recognized during PC-number translation in PROGRAM CALL when the entry-table entry designated by the entry-index part of the PC number is beyond the end of the entry table as designated by the linkage-table or linkage-second-table entry used.

When ASN-and-LX reuse is not installed or is not enabled by a one value of the ASN-and-LX-reuse control in control register 0, or if it is installed and enabled and bit 44 of the second-operand address used by PROGRAM CALL is zero, bits 44-63 of the address (a 20-bit PC number), with 12 zeros appended on the left, are stored in the word at real location 172. When ASN-and-LX reuse is installed and enabled and bit 44 of the second-operand address is one, bits 32-63 of the address (a 32-bit PC) are stored in the word at real location 172.

The operation is nullified.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The EX-translation exception is indicated by a program-interruption code of 0023 hex (or 00A3 hex if a concurrent PER event is indicated).
**Extended-Authority Exception**

An extended-authority exception is recognized during access-register translation when all of the following are true:

1. The private bit in the access-list entry used is one.
2. The access-list-entry authorization index (ALEAX) in the access-list entry is not equal to the extended authorization index (EAX) in control register 8.
3. Either of the following is true:
   a. The authority-table entry designated by the EAX is beyond the length of the authority table used. The authority table is the one designated by the ASN-second-table entry that is designated by the access-list entry used.
   b. The secondary-authority bit designated by the EAX is zero.

The access-list entry is the one designated by the access register used.

The number of the access register is stored in bit positions 4-7 at real location 160, and bits 0-3 are set to zeros.

The operation is nullified.

The instruction-length code is 1, 2, or 3.

The extended-authority exception is indicated by a program-interruption code of 002D hex (or 00AD, 022D, or 02AD hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Fixed-Point-Divide Exception**

A fixed-point-divide exception is recognized when any of the following is true:

1. In signed or unsigned binary division when the result is defined to be 32 bits, the divisor is zero, or the quotient cannot be expressed as a 32-bit signed or unsigned, respectively, binary integer.
2. In signed or unsigned binary division when the result is defined to be 64 bits, the divisor is zero, or the quotient cannot be expressed as a 64-bit signed or unsigned, respectively, binary integer.

3. The result of CONVERT TO BINARY cannot be expressed as a 32-bit signed binary integer for a 32-bit result or as a 64-bit signed binary integer for a 64-bit result.

In the case of division, the operation is suppressed. The execution of CONVERT TO BINARY (CVB, CVBY) is completed by ignoring the leftmost bits that cannot be placed in the register. The execution of CONVERT TO BINARY (CVBG) is suppressed.

The instruction-length code is 1, 2, or 3.

The fixed-point-divide exception is indicated by a program-interruption code of 0009 hex (or 0089, 0209, or 0289 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Fixed-Point-Overflow Exception**

A fixed-point-overflow exception is recognized when an overflow occurs during signed binary arithmetic or signed left-shift operations.

The interruption may be disallowed by the fixed-point-overflow mask (PSW bit 20).

The operation is completed. The result is obtained by ignoring the overflow information, and condition code 3 is set.

The instruction-length code is 1, 2, or 3.

The fixed-point-overflow exception is indicated by a program-interruption code of 0008 hex (or 0088, 0208, or 0288 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**HFP-Divide Exception**

An HFP-divide exception is recognized when in HFP division the divisor has a zero fraction.

The operation is suppressed.

The instruction-length code is 1 or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The HFP-divide exception is indicated by a program-interruption code of 000F hex (or 008F, 020F, or 028F hex, if a concurrent PER event, a concurrent transac-
tional-execution-aborted event, or both are indicated, respectively).

**HFP-Exponent-Overflow Exception**

An HFP-exponent-overflow exception is recognized when the result characteristic of an HFP operation exceeds 127 and the result fraction is not zero.

The operation is completed. The fraction is normalized, and the sign and fraction of the result remain correct. The result characteristic is made 128 smaller than the correct characteristic.

The instruction-length code is 1, 2, or 3.

The HFP-exponent-overflow exception is indicated by a program-interruption code of 000C hex (or 008C, 020C, or 028C hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**HFP-Exponent-Underflow Exception**

An HFP-exponent-underflow exception is recognized when the result characteristic of an HFP operation is less than zero and the result fraction is not zero. For an extended-format HFP result, HFP-exponent underflow is indicated only when the high-order characteristic underflows.

The interruption may be disallowed by the HFP-exponent-underflow mask (PSW bit 22).

The operation is completed. The HFP-exponent-underflow mask also affects the result of the operation. When the mask bit is zero, the sign, characteristic, and fraction are set to zero, making the result a true zero. When the mask bit is one, the fraction is normalized, the characteristic is made 128 larger than the correct characteristic, and the sign and fraction remain correct.

The instruction-length code is 1, 2, or 3.

The HFP-exponent-underflow exception is indicated by a program-interruption code of 001D hex (or 009D, 021D, or 029D hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**HFP-Significance Exception**

An HFP-significance exception is recognized when the result fraction in HFP addition or subtraction is zero.

The operation is suppressed.

The instruction-length code is 1 or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The HFP-significance exception is indicated by a program-interruption code of 000E hex (or 008E, 020E, or 028E hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**HFP-Square-Root Exception**

An HFP-square-root exception is recognized when the second operand of an HFP SQUARE ROOT instruction is less than zero.

The operation is suppressed.

The instruction-length code is 2 or 3.

The HFP-square-root exception is indicated by a program-interruption code of 001D hex (or 009D, 021D, or 029D hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**LFX-Translation Exception**

An LFX-translation exception may be recognized only when the ASN-and-LX-reuse facility is installed and the ASN-and-LX-reuse control in control register 0 is one.

An LFX-translation exception is recognized during PC-number translation in PROGRAM CALL when either:

1. The linkage-first-table entry specified by the linkage-first-index part of the PC number is beyond the end of the linkage first table as designated by the linkage-first-table designation used.
2. Bit 0 of the linkage-first-table entry is not zero.
When bit 44 of the second-operand address used by PROGRAM CALL is zero, bits 44-63 of the address (a 20-bit PC number), with 12 zeros appended on the left, are stored in the word at real location 172. When bit 44 of the second-operand address is one, bits 32-63 of the address (a 32-bit PC number) are stored in the word at real location 172.

The operation is nullified.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The LFX-translation exception is indicated by a program-interruption code of 0026 hex (or 00A6 hex if a concurrent PER event is indicated).

**LSTE-Sequence Exception**

An LSTE-sequence exception may be recognized only when the ASN-and-LX-reuse facility is installed and the ASN-and-LX-reuse control in control register 0 is one.

An LSTE-sequence exception is recognized during PC-number translation in PROGRAM CALL when the linkage-second-table-entry sequence number (LSTESN) in the linkage-second-table entry used is nonzero and not equal to the LSTESN in bit positions 0-31 of general register 15.

When bit 44 of the second-operand address used by PROGRAM CALL is zero, bits 44-63 of the address (a 20-bit PC number), with 12 zeros appended on the left, are stored in the word at real location 172. When bit 44 of the second-operand address is one, bits 32-63 of the address (a 32-bit PC number) are stored in the word at real location 172.

The operation is nullified.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The LSTE-sequence exception is indicated by a program-interruption code of 002E hex (or 00A6 hex if a concurrent PER event is indicated).

**LSX-Translation Exception**

An LSX-translation exception may be recognized only when the ASN-and-LX-reuse facility is installed and the ASN-and-LX-reuse control in control register 0 is one.

An LSX-translation exception is recognized during PC-number translation in PROGRAM CALL when bit 0 of the linkage-second-table entry specified by the linkage-second-index part of the PC number is not zero.

When bit 44 of the second-operand address used by PROGRAM CALL is zero, bits 44-63 of the address (a 20-bit PC number), with 12 zeros appended on the left, are stored in the word at real location 172. When bit 44 of the second-operand address is one, bits 32-63 of the address (a 32-bit PC number) are stored in the word at real location 172.

The operation is nullified.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The LSX-translation exception is indicated by a program-interruption code of 0027 hex (or 00A7 hex if a concurrent PER event is indicated).

**LX-Translation Exception**

An LX-translation exception may be recognized only when the ASN-and-LX-reuse facility is not installed or the ASN-and-LX-reuse control in control register 0 is zero.

An LX-translation exception is recognized during PC-number translation in PROGRAM CALL when either:

1. The linkage-table entry designated by the linkage-index part of the PC number is beyond the end of the linkage table as designated by the linkage-table designation used.
2. Bit 0 of the linkage-table entry is not zero.

Bits 44-63 of the second-operand address used by PROGRAM CALL (a 20-bit PC number), with 12 zeros appended on the left, are stored in the word at real location 172.

The operation is nullified.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.
The LX-translation exception is indicated by a program-interruption code of 0022 hex (or 00A2 hex if a concurrent PER event is indicated).

**Monitor Event**
A monitor event is recognized when MONITOR CALL is executed and the monitor-mask bit in control register 8 corresponding to the monitor class specified by instruction bits 12-15 is one. The information in control register 8 has the following format:

<table>
<thead>
<tr>
<th>Enhanced-Monitor Mask</th>
<th>Monitor Mask</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16 31</td>
</tr>
<tr>
<td>32</td>
<td>48 63</td>
</tr>
<tr>
<td>EAX</td>
<td></td>
</tr>
</tbody>
</table>

The monitor-mask bits, bits 48-63 of control register 8, correspond to monitor classes 0-15, respectively. Any number of monitor-mask bits may be on at a time; together they specify the classes of monitor events that are monitored at that time. The mask bits are initialized to zeros.

When the enhanced-monitor facility is installed, the enhanced-monitor-mask bits, bits 16-31 of control register 8, correspond to the monitor classes 0-15, respectively. Any number of enhanced-monitor-mask bits may be on at a time; together they specify the classes of monitor events that result in monitor-call program interruptions versus monitor-event counting operations.

When a monitor event occurs and either (a) the enhanced-monitor facility is not installed, or (b) the facility is installed but the enhanced-monitor-mask bit corresponding to the monitor class specified in bits 12-15 of the MONITOR CALL instruction is zero, then a monitor-event program interruption occurs. When a monitor event occurs, the enhanced-monitor facility is installed, and the enhanced-monitor-mask bit corresponding to the monitor class is one, a monitor-event-counting operation is performed, as described in “Monitor-Event Counting” on page 5-110.

When a monitor-event program interruption occurs, additional information is stored at real locations 148-149 and 176-183. The format of the information stored at these locations is as follows:

Real Locations 148-149

<table>
<thead>
<tr>
<th>Monitor Class Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 15</td>
</tr>
</tbody>
</table>

Real Locations 176-183

<table>
<thead>
<tr>
<th>Monitor Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 31</td>
</tr>
</tbody>
</table>

The contents of bit positions 8-15 of the MONITOR CALL instruction are stored at real location 149 and constitute the monitor-class number. Zeros are stored at real location 148. The effective address specified by the B1 and D1 fields of the instruction forms the monitor code, which is stored in the doubleword at real location 176. The value of the address is under control of the addressing mode, bits 31 and 32 of the current PSW. In the 24-bit addressing mode, bits 0-39 of the address are zeros, while in the 31-bit addressing mode, bits 0-32 are zeros.

The operation is completed.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The monitor event is indicated by a program-interruption code of 0040 hex (or 00C0 hex if a concurrent PER event is indicated).

**Operand Exception**
An operand exception is recognized when any of the following is true:

1. Execution of CLEAR SUBCHANNEL, HALT SUBCHANNEL, MODIFY SUBCHANNEL, RESUME SUBCHANNEL, START SUBCHANNEL, STORE SUBCHANNEL, or TEST SUBCHANNEL is attempted and bit positions 32-47 of general register 1 do not contain 0001 hex. However, an exception due to ones in bit positions 32-39 of the register may or may not be recognized.

2. Execution of MODIFY SUBCHANNEL is attempted, and bits 1 and 6 of word 1 of the SCHIB operand are not zeros or bits 9-10 and 25-30 of word 6 of the SCHIB operand are not all zeros.

3. Execution of MODIFY SUBCHANNEL is attempted, and bits 9 and 10 of word 1 of the SCHIB operand are both one.
4. Execution of RESET CHANNEL PATH is attempted, and bits 40-55 of general register 1 are not all zeros.

5. Execution of SET ADDRESS LIMIT is attempted, and bits 32 and 48-63 of general register 1 are not all zeros.

6. Execution of SET CHANNEL MONITOR is attempted, bit 62 of general register 1 is one, and bits 59-63 of general register 2 are not all zeros.

7. Execution of SET CHANNEL MONITOR is attempted, and bits 36-61 of general register 1 are not all zeros.

8. Execution of START SUBCHANNEL is attempted, and bits 5, 13, and 25-28 of word 1 of the ORB operand are not all zeros.

9. Execution of START SUBCHANNEL is attempted, and bit 11 of word 1 of the ORB operand is not zero. This exception may or may not be recognized. The operation is suppressed.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The operand exception is indicated by a program-interruption code of 0015 hex (or 0095 hex if a concurrent PER event is indicated).

**Operation Exception**

An operation exception is recognized when the CPU attempts to execute an instruction with an invalid operation code. The operation code may be unassigned, or the instruction with that operation code may not be installed on the CPU.

The operation is suppressed.

The instruction-length code is 1, 2, or 3.

The operation exception is indicated by a program-interruption code of 0001 hex (or 0081, 0201, or 0281 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

An operation exception detected while the CPU is in the nonconstrained transactional-execution mode may result in the transaction being aborted due to a restricted instruction (abort code 11). An operation exception detected while the CPU is in the constrained transactional-execution mode may be indicated as a transaction-constraint exception (program-interruption code 0018 hex).

**Programming Notes:**

1. Some models may offer instructions not described in this publication, such as those provided for assists or as part of special or custom features. Consequently, operation codes not described in this publication do not necessarily cause an operation exception to be recognized. Furthermore, these instructions may cause modes of operation to be set up or may otherwise alter the machine so as to affect the execution of subsequent instructions. To avoid causing such an operation, an instruction with an operation code not described in this publication should be executed only when the specific function associated with the operation code is desired.

2. Operation code 00 hex will never be assigned to an instruction implemented in the CPU.

**Page-Translation Exception**

A page-translation exception is recognized when the page-invalid bit is one.

The exception is recognized as part of the execution of an instruction that needs the page-table entry in the translation of an instruction, operand, or side-effect address, except for the operand address in LOAD REAL ADDRESS and TEST PROTECTION, in which case the condition is indicated by the setting of the condition code, and except for an operand address in MOVE PAGE, in which case the condition is indicated by the setting of the condition code if the condition-code-option bit, bit 55 of general register 0, is one.

When an interruption occurs, information about the virtual address causing the exception is stored at real locations 168-175 and conditionally at real locations 160 and 162. See "Assigned Storage Locations" on page 3-68 for a detailed description of this information.

The unit of operation is nullified.

When the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. When the exception occurs during a reference
to the target of EXECUTE, the ILC is 2. When the exception occurs during a reference to the target of EXECUTE RELATIVE LONG, the ILC is 3.

When the exception occurs during a reference to an operand location, the instruction-length code (ILC) is 1, 2, or 3 and indicates the length of the instruction causing the exception.

The page-translation exception is indicated by a program-interruption code of 0011 hex (or 0091, 0211, or 0291 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**PC-Translation-Specification Exception**

A PC-translation-specification exception is recognized during PC-number translation in PROGRAM CALL when either of the following is true for the entry-table entry (ETE) used:

1. The PROGRAM CALL operation is the basic operation (bit 128 of the ETE is zero) in the 24-bit or 31-bit addressing mode (bit 31 of the PSW is zero), bit 32 of the ETE is zero (specifying the 24-bit mode), and bits 33-39 of the ETE are not all zeros.
2. The PROGRAM CALL operation is the stacking operation (bit 128 of the ETE is one), bits 32 and 129 of the ETE are zeros (specifying the 24-bit mode), and bits 33-39 of the ETE are not all zeros.

The operation is suppressed.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The PC-translation-specification exception is indicated by a program-interruption code of 001F hex (or 009F hex if a concurrent PER event is indicated).

**PER Event**

A PER event is recognized when the CPU is enabled for PER and one or more of these events occur.

The PER mask, bit 1 of the PSW, controls whether the CPU is enabled for PER. When the PER mask is zero, PER events are not recognized. When the bit is one, PER events are recognized, subject to the PER-event-mask bits in control register 9.

For a PER instruction-fetching nullification event, the unit of operation is nullified. For other PER events, the unit of operation is completed, unless another condition has caused the unit of operation to be nullified, suppressed, or terminated.

Information identifying the event is stored at real locations 150-159 and conditionally at real location 161.

The instruction-length code is 0, 1, 2, or 3. Code 0 is set for the PER instruction-fetching basic event only if a specification exception is indicated concurrently. Code 0 is always set when the PER instruction-fetching nullification event is indicated.

The PER event is indicated by setting bit 8 of the program-interruption code to one.

See “Program-Event Recording” on page 4-23 for a detailed description of the PER event and the associated interruption information.

**Primary-Authority Exception**

A primary-authority exception is recognized during ASN authorization in PROGRAM TRANSFER with space switching (PT-ss) or PROGRAM TRANSFER WITH INSTANCE with space switching (PTI-ss) when either:

1. The authority-table entry indicated by the authorization index in control register 4 is beyond the end of the authority table used. The authority table is the one designated by the ASN-second-table entry for the ASN used.
2. The primary-authority bit indicated by the authorization index is zero.

The ASN used is stored at real locations 174-175, and real locations 172-173 are set to zeros.

The operation is nullified.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The primary-authority exception is indicated by a program-interruption code of 0024 hex (or 00A4 hex if a concurrent PER event is indicated).
Privileged-Operation Exception
A privileged-operation exception is recognized when any of the following is true:

1. Execution of a privileged instruction is attempted in the problem state.
2. The value of the rightmost bit of the general register designated by the R2 field of the PROGRAM TRANSFER or PROGRAM TRANSFER WITH INSTANCE instruction is zero and would cause the PSW problem-state bit to change from the problem state (one) to the supervisor state (zero).
3. In the problem state, the key value specified by the second operand of the SET PSW KEY FROM ADDRESS instruction corresponds to a zero PSW-key-mask bit in control register 3.
4. In the problem state, the key value specified by the rightmost byte of the register designated by the R3 field of the MOVE WITH KEY instruction corresponds to a zero PSW-key-mask bit in control register 3.
5. In the problem state, the key value specified by the rightmost byte of the register designated by the R1 field for the instruction MOVE TO PRIMARY, MOVE TO SECONDARY, or MOVE WITH KEY corresponds to a zero PSW-key-mask bit in control register 3.
6. In the problem state, any of the following instructions is encountered, and the extraction-authority control, bit 4 of control register 0, is zero.
   - EXTRACT PRIMARY ASN
   - EXTRACT SECONDARY ASN
   - INSERT ADDRESS SPACE CONTROL
   - INSERT PSW KEY
   - INSERT VIRTUAL STORAGE KEY
7. In the problem state, the result of ANDing the authorization key mask (AKM) with the PSW-key mask in control register 3 during PROGRAM CALL produces a result of zero.
8. In the problem state, bits 20-23 of the second operand address of the SET ADDRESS SPACE CONTROL or SET ADDRESS SPACE CONTROL FAST instruction have the value 0011 binary.
9. In the problem state, the key value specified by the rightmost byte of general register 1 for the instruction MOVE WITH SOURCE KEY or MOVE WITH DESTINATION KEY corresponds to a zero PSW-key-mask bit in control register 3.
10. In the problem state, the key value specified by the rightmost byte of the register designated by the R1 field for the instruction BRANCH AND SET AUTHORITY corresponds to a zero PSW-key-mask bit in control register 3.
11. In the problem state, bits 16 and 17 of the PSW field in the second operand of RESUME PROGRAM have the value 11 binary.
12. Execution of MOVE WITH OPTIONAL SPECIFICATIONS is attempted in the problem state, and any of the following is true:
   - The specified-access-key control for the first operand, bit 46 of general register 0, is one; and the corresponding specified-access key, bits 32-35 of the register, designates a PSW-key-mask (PKM) bit position in control register 3 that contains zero.
   - The specified-access-key control for the second operand, bit 62 of general register 0, is one; and the corresponding specified-access key, bits 48-51 of the register, designates a PKM bit position that contains zero.
   - Either or both bits 46 and 62 of general register 0 are zero, and the PSW key, bits 8-11 of the PSW, designates a PKM bit position that contains zero.

The operation is suppressed.

The instruction-length code is 1, 2, or 3.

The privileged-operation exception is indicated by a program-interruption code of 0002 hex (or 0082, 0202, or 0282 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

Protection Exception
A protection exception is recognized when any of the following is true:

Key-Controlled Protection: The CPU attempts to access a storage location that is protected against the type of reference, and the access key does not match the storage key.
Access-List-Controlled Protection: The CPU attempts to store, in the access-register mode, by means of an access-list entry which has the fetch-only bit set to one.

Low-Address Protection: The CPU attempts a store that is subject to low-address protection, the effective address is in the range 0-511 or 4096-4607, and the low-address protection control, bit 35 of control register 0, is one.

DAT Protection: The CPU attempts to store, with DAT on, into any of the following:

- A page which has the DAT-protection bit set to one in the page-table entry used in the translation
- A segment which has the DAT-protection bit set to one in the segment-table entry used in the translation
- When EDAT-1 applies, a region which has the DAT-protection bit set to one in any region-table entry used in the translation.

The operation is suppressed when the location of the instruction is protected against fetching. Similarly, the operation is suppressed when the location of the target instruction of an execute-type instruction is protected against fetching.

For access-list-controlled protection and DAT-protection, the operation is suppressed. For the other two types of protection, except in the case of some specific instructions whose execution is suppressed, the operation is terminated when a protection exception is encountered during a reference to an operand location. See Figure 6-4 on page 6-20. However, the operation may be suppressed as described in “Suppression on Protection” on page 3-14.

For termination, changes may occur only to result fields. In this context, the term “result field” includes condition code, registers, and storage locations, if any, which are due to be changed by the instruction. However, no change is made to a storage location when a reference to that location causes a protection exception. Therefore, if an instruction is due to change only the contents of a field in storage, and every byte of that field would cause a protection exception, the operation is suppressed. When termination occurs on fetching, the protected information is not loaded into an addressable register nor moved to another storage location.

Information about the address causing the exception is stored at real locations 168-175 and conditionally at real location 160. See “Suppression on Protection” on page 3-14.

When the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. When the exception occurs during the fetching of the target of EXECUTE, the ILC is 2. When the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

For a protected operand location, the instruction-length code (ILC) is 1, 2, or 3, indicating the length of the instruction that caused the reference.

The protection exception is indicated by a program-interruption code of 0004 hex (or 0084, 0204, or 0284 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

Region-First-Translation Exception
A region-first-translation exception is recognized when a region first table is in the translation path for translation of a virtual address and either:

1. The region-first-table entry indicated by the region-first-index portion of the virtual address is outside the region first table.
2. The region-invalid bit is one.

The exception is sometimes called simply a region-translation exception, which term applies also to a region-second-translation exception and a region-third-translation exception.

The exception is recognized as part of the execution of an instruction that needs the region-first-table entry in the translation of an instruction or operand address, except for the operand address in LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS and TEST PROTECTION, in which case the condition is indicated by the setting of the condition code.

When an interruption occurs, information about the virtual address causing the exception is stored at real locations 168-175 and conditionally at real locations

---
When the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. When the exception occurs during the fetching of the target of EXECUTE, the ILC is 2. When the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

When the exception occurs during a reference to an operand location, the instruction-length code (ILC) is 1, 2, or 3 and indicates the length of the instruction causing the exception.

The region-first-translation exception is indicated by a program-interruption code of 0039 hex (or 00B9, 0239, or 02B9 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Region-Second-Translation Exception**

A region-second-translation exception is recognized when a region second table is in the translation path for translation of a virtual address and either:

1. The region-second-table entry indicated by the region-second-index portion of the virtual address is outside the region second table.
2. The region-invalid bit is one.

The exception is sometimes called simply a region-translation exception, which term applies also to a region-first-translation exception and a region-third-translation exception.

The exception is recognized as part of the execution of an instruction that needs the region-second-table entry in the translation of an instruction or operand address, except for the operand address in LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS and TEST PROTECTION, in which case the condition is indicated by the setting of the condition code.

When an interruption occurs, information about the virtual address causing the exception is stored at real locations 168-175 and conditionally at real locations 160 and 162. See “Assigned Storage Locations” on page 3-68 for a detailed description of this information.

The unit of operation is nullified.

When the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. When the exception occurs during the fetching of the target of EXECUTE, the ILC is 2. When the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

When the exception occurs during a reference to an operand location, the instruction-length code (ILC) is 1, 2, or 3 and indicates the length of the instruction causing the exception.

The region-second-translation exception is indicated by a program-interruption code of 003A hex (or 00BA, 023A, or 02BA hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Region-Third-Translation Exception**

A region-third-translation exception is recognized when a region third table is in the translation path for translation of a virtual address and either:

1. The region-third-table entry indicated by the region-third-index portion of the virtual address is outside the region third table.
2. The region-invalid bit is one.

The exception is sometimes called simply a region-translation exception, which term applies also to a region-first-translation exception and a region-second-translation exception.

The exception is recognized as part of the execution of an instruction that needs the region-third-table entry in the translation of an instruction or operand address, except for the operand address in LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS and TEST PROTECTION, in which case the condition is indicated by the setting of the condition code.

When an interruption occurs, information about the virtual address causing the exception is stored at real locations 168-175 and conditionally at real locations 160 and 162. See “Assigned Storage Locations” on page 3-68 for a detailed description of this information.
The unit of operation is nullified.

When the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. When the exception occurs during the fetching of the target of EXECUTE, the ILC is 2. When the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

When the exception occurs during a reference to an operand location, the instruction-length code (ILC) is 1, 2, or 3 and indicates the length of the instruction causing the exception.

The region-third-translation exception is indicated by a program-interruption code of 003B hex (or 00BB, 023B, or 02BB hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Secondary-Authority Exception**

A secondary-authority exception is recognized during ASN authorization in SET SECONDARY ASN with space switching, SET SECONDARY ASN WITH INSTANCE with space switching, or during ASN authorization in PROGRAM RETURN when the restored SASN does not equal the restored PASN, when either:

1. The authority-table entry indicated by the authorization index in control register 4 is beyond the end of the authority table used. The authority table is the one designated by the ASN-second-table entry for the ASN used. For PROGRAM RETURN, the ASN is the SASN being restored from the linkage-stack state entry used.

2. The secondary-authority bit indicated by the authorization index is zero.

The ASN used is stored at real locations 174-175, and real locations 172-173 are set to zeros.

The operation is nullified.

The instruction-length code is 1 or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The secondary-authority exception is indicated by a program-interruption code of 0025 hex (or 00A5 hex if a concurrent PER event is indicated).

**Segment-Translation Exception**

A segment-translation exception is recognized when either:

1. The segment-table entry indicated by the segment-index portion of a virtual address is outside the segment table.

2. The segment-invalid bit is one.

The exception is recognized as part of the execution of an instruction that needs the segment-table entry in the translation of an instruction or operand address, except for the operand address in LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS and TEST PROTECTION, in which case the condition is indicated by the setting of the condition code.

When an interruption occurs, information about the virtual address causing the exception is stored at real locations 168-175 and conditionally at real locations 160 and 162. See “Assigned Storage Locations” on page 3-68 for a detailed description of this information.

The unit of operation is nullified.

When the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. When the exception occurs during the fetching of the target of EXECUTE, the ILC is 2. When the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

When the exception occurs during a reference to an operand location, the instruction-length code (ILC) is 1, 2, or 3 and indicates the length of the instruction causing the exception.

The segment-translation exception is indicated by a program-interruption code of 0010 hex (or 0090, 0210, or 0290 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Space-Switch Event**

A space-switch event is recognized at the completion of the operation in each of the following cases:

1. The space-switching form of PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER,
or PROGRAM TRANSFER WITH INSTANCE is executed and any of the following is true:

a. The primary space-switch-event-control bit, bit 57 of control register 1, is one before the operation.

b. The primary space-switch-event-control bit is one after the operation.

c. A PER event is indicated.

2. RESUME PROGRAM, SET ADDRESS SPACE CONTROL, or SET ADDRESS SPACE CONTROL FAST is executed, the CPU is in the home-space mode either before or after the operation, but not both before and after the operation, and any of the following is true:

a. The primary space-switch-event-control bit, bit 57 of control register 1, is one.

b. The home space-switch-event-control bit, bit 57 of control register 13, is one.

c. A PER event is indicated.

For PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, and PROGRAM TRANSFER WITH INSTANCE, and for a RESUME PROGRAM, SET ADDRESS SPACE CONTROL, or SET ADDRESS SPACE CONTROL FAST instruction that changes the translation mode to the home-space mode, the old PASN, which is in bit positions 48-63 of control register 4 before the operation, is stored at real locations 174-175, and the old primary space-switch-event-control bit is placed in bit position 0 and zeros are placed in bit positions 1-15 at real locations 172-173.

For a RESUME PROGRAM, SET ADDRESS SPACE CONTROL, or SET ADDRESS SPACE CONTROL FAST instruction that changes the translation mode away from the home-space mode, zeros are stored at real locations 174-175, and the home space-switch-event-control bit is placed in bit position 0 and zeros are placed in bit positions 1-15 at real locations 172-173.

For a PROGRAM RETURN instruction that introduces a PSW-format error, it is unpredictable whether the instruction-length code is 0 or 1, or 0 or 2 if EXECUTE was used, or 0 or 3 if EXECUTE RELATIVE LONG was used.

The operation is completed.

The instruction-length code is 0, 1, or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 0 or 3.

The space-switch event is indicated by a program-interruption code of 001C hex (or 009C hex if a concurrent PER event is indicated).

Programming Notes:

1. The space-switch event permits the control program to gain control whenever a program enters or leaves a particular address space. The primary space-switch-event-control bit is loaded into control register 1, along with the remaining bits of the primary address-space-control element, whenever control register 1 is loaded.

2. The space-switch event may be useful in obtaining programmed authorization checking, in causing additional trace information to be recorded, or in enabling or disabling the CPU for PER or tracing.

3. Bit 121 of the ASN-second-table entry (ASTE) is loaded into bit position 57 of control register 1 as part of the PC-ss, PR-ss, PT-ss, and PTI-ss operations. If bit 121 of the ASTE for a particular address space is set to one, then a space-switch event is recognized when a program enters or leaves the address space by means of any of PC-ss, PR-ss, PT-ss, or PTI-ss.

4. The occurrence of a space-switch event at the completion of a PC-ss, PR-ss, PT-ss, or PTI-ss operation when any PER event is indicated, or at the completion of execution of a RESUME PROGRAM, SET ADDRESS SPACE CONTROL, or SET ADDRESS SPACE CONTROL FAST instruction that changes to or from the home-space mode when any PER event is indicated, permits the control program to determine the address space from which the instruction causing the PER event was fetched.

Special-Operation Exception

A special-operation exception is recognized when any of the following is true:

1. Execution of any of the following instructions is attempted with DAT off:

   - EXTRACT PRIMARY ASN
   - EXTRACT SECONDARY ASN
• INSERT ADDRESS SPACE CONTROL
• INSERT VIRTUAL STORAGE KEY
• MOVE WITH OPTIONAL SPECIFICATIONS
• SET ADDRESS SPACE CONTROL
• SET SECONDARY ASN

2. Execution of BRANCH AND SET AUTHORITY is attempted, and the R₂ field is zero in the base-authority state or nonzero in the reduced-authority state.

3. Execution of BRANCH AND STACK, stacking PROGRAM CALL, PROGRAM RETURN, or TRAP is attempted, and the CPU is not in the primary-space or access-register mode.

4. Execution of BRANCH IN SUBSPACE GROUP is attempted, and any of the following is true:
   • The current primary address space is not in a subspace group associated with the current dispatchable unit, that is, the primary-ASTE origin (PASTE0) in control register 5 does not equal the base-ASTE origin (BASTEO) in the dispatchable-unit control table (DUCT).
   • The access-list-entry token (ALET) in access register R₂ is ALET 1, but a subspace has not previously been entered by the dispatchable unit by means of BRANCH IN SUBSPACE GROUP, that is, the subspace-ASTE origin (SSASTE0) in the DUCT is all zeros.
   • The ALET used is other than ALET 0 and ALET 1, and the destination ASTE (DASTE) does not specify the base space or a subspace of the subspace group, that is, the DASTE origin (DASTE0) obtained from an access-list entry does not equal the BASTE0 in the DUCT, and either the subspace-group bit (G) in the address-space-control element in the DASTE is zero or the base-space bit (B) in the DASTE is one.

5. Execution of EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE or MODIFY STACKED STATE is attempted, and the CPU is not in the primary-space, access-register, or home-space mode.

6. Execution of EXTRACT TRANSACTION NESTING DEPTH, TRANSACTION BEGIN, or TRANSACTION END is attempted, and the transactional-execution control, bit 8 of control register 0, is zero.

7. Execution of LOAD ADDRESS SPACE PARAMETERS, PROGRAM CALL with space switching (PC-ss), PROGRAM TRANSFER with space switching (PT-ss), PROGRAM TRANSFER WITH INSTANCE with space switching (PT-ss), SET SECONDARY ASN, or SET SECONDARY ASN WITH INSTANCE is attempted, or execution of a PROGRAM RETURN instruction requiring PASN or SASN translation is attempted, and the ASN-translation control, bit 44 of control register 14, is zero.

8. Execution of LOAD PAGE-TABLE-ENTRY ADDRESS is attempted and the effective address-space-control element specified by the M₄ field of the instruction designates the real space.

9. Execution of LOAD REAL ADDRESS (LRA) is attempted in the 24-bit or 31-bit addressing mode, and bits 0-32 of the resulting real or absolute address are not all zeros.

10. Execution of MOVE TO PRIMARY or MOVE TO SECONDARY is attempted, and the CPU is not in the primary-space or secondary-space mode.

11. Execution of MOVE TO PRIMARY, MOVE TO SECONDARY, or SET ADDRESS SPACE CONTROL is attempted, and the secondary-space control, bit 37 of control register 0, is zero. The exception may be recognized for this reason when execution of SET ADDRESS SPACE CONTROL FAST is attempted.

12. Execution of MOVE WITH OPTIONAL SPECIFICATIONS is attempted, and either of the following conditions are true:
   • Bit 47 of general register 0 is one, bits 40-41 of the register contain 11 binary, and the problem-state bit, bit 15 of the current PSW, is one.
   • The secondary-space control, bit 37 of control register 0 is zero, and any of the following conditions are true:
     – Bit 47 of general register 0 is zero, and bits 16-17 of the current PSW are 10 binary.
     – Bit 47 of general register 0 is one, and bits 40-41 of the register are 10 binary.
- Bit 63 of general register 0 is zero, and bits 16-17 of the current PSW are 10 binary.

- Bit 63 of general register 0 is one, and bits 56-57 of the register are 10 binary.

13. Execution of basic PROGRAM CALL, PROGRAM TRANSFER, or PROGRAM TRANSFER WITH INSTANCE is attempted, and the CPU is not in the primary-space mode.

14. Execution of basic PROGRAM CALL is attempted, and the extended-addressing-mode bit, bit 31 of the current PSW, does not equal the entry-extended-addressing-mode bit, bit 129, in the entry-table entry.

15. Execution of PROGRAM CALL, PROGRAM TRANSFER, or PROGRAM TRANSFER WITH INSTANCE is attempted, and the subsystem-linkage control, bit 192 of the primary ASN-second-table entry, is zero.

16. Execution of the space-switching form of PROGRAM TRANSFER or SET SECONDARY ASN is attempted, the ASN-and-LX-reuse control in control register 0 is one, and the reusable-ASN bit in the located ASTE is one.

17. Execution of the space-switching form of PROGRAM TRANSFER WITH INSTANCE or SET SECONDARY ASN WITH INSTANCE is attempted, the controlled-ASN bit is one in the ASN-second-table entry used, and the CPU is in the problem state at the beginning of the operation.

18. Execution of SET SYSTEM MASK is attempted in the supervisor state, and the SSM-suppression control, bit 33 of control register 0, is one.

19. Execution of TRANSACTION ABORT is attempted, and the CPU is not in the transactional-execution mode at the beginning of the instruction.

20. Execution of TRAP is attempted, and either of the following is true:

   - The TRAP-enabled bit, bit 31 in bytes 44-47 of the dispatchable-unit control table, is zero.
   - The PSW control, bit 13 of bytes 0-3 of the trap control table, is zero and bit 31 of the current PSW, the extended-addressing-mode bit, is one.

   The operation is suppressed.

   The instruction-length code is 1, 2, or 3.

   The special-operation exception is indicated by a program-interruption code of 0013 hex (or 0093, 0213, or 0293 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Specification Exception**

A specification exception is recognized when any of the following is true:

1. A one is introduced into an unassigned bit position of the PSW (that is, any of bit positions 0, 2-4, 25-30, or 33-63). This is handled as an early PSW specification exception.

2. A one is introduced into bit position 12 of the PSW. This is handled as an early PSW specification exception.

3. The PSW is invalid in any of the following ways:
   a. Bit 31 of the PSW is one and bit 32 is zero.
   b. Bits 31 and 32 of the PSW are zero, indicating the 24-bit addressing mode, and bits 64-103 of the PSW are not all zeros.
   c. Bit 31 of the PSW is zero and bit 32 is one, indicating the 31-bit addressing mode, and bits 64-96 of the PSW are not all zeros.

   This is handled as an early PSW specification exception. Note, items b and c, above, do not apply to SAM24 and SAM31, respectively. See items 45 and 46 in this list for further explanation.

4. The PSW contains an odd instruction address.

5. An operand address does not designate an integral boundary in an instruction requiring such integral-boundary designation.

6. An odd-numbered general register is designated by an R field of an instruction that requires an even-numbered register designation.

7. A floating-point register other than 0, 1, 4, 5, 8, 9, 12, or 13 is designated for an extended operand.

8. The multiplier or divisor in decimal arithmetic exceeds 15 digits and sign.
9. The length of the first-operand field is less than or equal to the length of the second-operand field in decimal multiplication or division.

10. Execution of CIPHER MESSAGE, CIPHER MESSAGE WITH CIPHER FEEDBACK, CIPHER MESSAGE WITH CHAINING, CIPHER MESSAGE WITH COUNTER, CIPHER MESSAGE WITH OUTPUT FEEDBACK, COMPUTE INTERMEDIATE MESSAGE DIGEST, COMPUTE LAST MESSAGE DIGEST, COMPUTE MESSAGE AUTHENTICATION CODE, PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION, PERFORM CRYPTOGRAPHIC COMPUTATION, or PERFORM PSEUDORANDOM NUMBER OPERATION is attempted, and the function code in bits 57-63 of general register 0 contain an unassigned or uninstalled function code.

11. Execution of CIPHER MESSAGE, CIPHER MESSAGE WITH CIPHER FEEDBACK, CIPHER MESSAGE WITH CHAINING, CIPHER MESSAGE WITH OUTPUT FEEDBACK, or PERFORM PSEUDORANDOM NUMBER OPERATION is attempted, and the R1 or R2 field designates an odd-numbered register or general register 0.

12. Execution of CIPHER MESSAGE WITH COUNTER is attempted, and the R1, R2, or R3 field designates an odd-numbered register or general register 0.

13. Execution of CIPHER MESSAGE, CIPHER MESSAGE WITH CHAINING, CIPHER MESSAGE WITH COUNTER, CIPHER MESSAGE WITH OUTPUT FEEDBACK, COMPUTE INTERMEDIATE MESSAGE DIGEST or COMPUTE MESSAGE AUTHENTICATION CODE is attempted, and the second operand length is not a multiple of the data block size of the designated function. This specification-exception condition does not apply to the query functions.

14. Execution of CIPHER MESSAGE WITH CIPHER FEEDBACK is attempted, and any of the following applies:
   • The second operand length is not a multiple of the length of cipher feedback. This specification-exception condition does not apply to the query functions.
   • For DEA or TDEA functions, bits 32-39 of general register 0 specify a value that is zero or greater than 8.
   • For AES functions, bits 32-39 of general register 0 specify a value that is zero or greater than 16.

15. Execution of COMPARE AND FORM CODE-WORD is attempted, and general registers 1, 2, and 3 do not initially contain even values.

16. Execution of COMPARE AND REPLACE DAT TABLE ENTRY is attempted and either of the following conditions exist:
   • The DTT field, bit positions 59-61 of general register R2, contain 001, 010, or 011 binary.
   • Bit positions 52-63 of general register R2 + 1 contain nonzero values.

17. Execution of COMPARE AND SWAP AND STORE is attempted and any of the following conditions exist:
   • The function code specifies an unassigned value.
   • The store characteristic specifies an unassigned value.
   • The function code is 0, and the first operand is not designated on a word boundary.
   • The function code is 1, and the first operand is not designated on a doubleword boundary.
   • The function code is 2, and any of the following is true:
     – The compare-and-swap-and-store facility 2 is not installed.
     – The first operand is not designated on a quadword boundary.
     – The R3 field does not designate the even-numbered register of an even-odd register pair.
   • The second operand is not designated on an integral boundary corresponding to the size of the store value.
18. Execution of COMPARE LOGICAL LONG UNICODE or MOVE LONG UNICODE is attempted, and the contents of either general register $R_1 + 1$ or $R_3 + 1$ do not specify an even number of bytes.

19. Execution of COMPARE LOGICAL STRING, MOVE STRING or SEARCH STRING is attempted, and bits 32-55 of general register 0 are not all zeros.

20. Execution of COMPRESSION CALL is attempted, and bits 48-51 of general register 0 have any of the values 0000 and 0110-1111 binary.

21. Execution of COMPUTE INTERMEDIATE MESSAGE DIGEST, COMPUTE LAST MESSAGE DIGEST, or COMPUTE MESSAGE AUTHENTICATION CODE is attempted, and bit 56 of general register 0 is not zero.

22. Execution of COMPUTE INTERMEDIATE MESSAGE DIGEST, COMPUTE LAST MESSAGE DIGEST, or COMPUTE MESSAGE AUTHENTICATION CODE is attempted, and the $R_2$ field designates an odd-numbered register or general register 0.

23. Execution of CONVERT HFP TO BFP, CONVERT TO FIXED (BFP or HFP), or LOAD FP INTEGER (BFP) is attempted, and the $M_3$ field does not designate a valid modifier.

24. Execution of DIVIDE TO INTEGER is attempted, and the $M_4$ field does not designate a valid modifier.

25. Execution of EXTRACT STACKED STATE is attempted, and the code in bit positions 56-63 of general register $R_2$ is greater than 4 when the ASN-and-LX-reuse facility is not installed or is greater than 5 when the facility is installed.

26. Execution of INVALIDATE DAT TABLE ENTRY is attempted, and bits 44-51 of general register $R_2$ are not all zeros.

27. Execution of INVALIDATE PAGE TABLE ENTRY is attempted, the IPTE-range facility is installed, the $R_2$ field is nonzero, and the page index in general register $R_2$ plus the additional-entry count in general register $R_3$ is greater than 255.

28. Execution of LOAD COUNT TO BLOCK BOUNDARY is attempted, and the $M_3$ field specifies a reserved value.

29. Execution of LOAD FPC or LOAD FPC AND SIGNAL is attempted, and one or more bits of the second operand corresponding to unsupported bits in the FPC register are one.

30. Execution of LOAD PAGE-TABLE-ENTRY ADDRESS is attempted and the $M_4$ field of the instruction contains any value other than 0000-0100 binary.

31. Execution of LOAD PSW is attempted and bit 12 of the doubleword at the second-operand address is zero. It is model dependent whether or not this exception is recognized.

32. Execution of MONITOR CALL is attempted, and bit positions 8-11 of the instruction do not contain zeros.

33. Execution of MOVE PAGE is attempted, and bit positions 48-51 of general register 0 do not contain zeros or bits 52 and 53 of the register are both one.

34. Execution of PACK ASCII is attempted, and the $L_2$ field is greater than 31.

35. Execution of PACK UNICODE is attempted, and the $L_2$ field is greater than 63 or is even.

36. Execution of PERFORM FLOATING POINT OPERATION is attempted, bit 32 of general register 0 is zero, and one or more fields in bits 33-63 are invalid or designate an uninstalled function.

37. Execution of PERFORM FRAME MANAGEMENT FUNCTION is attempted, and either or both of the following are true:
   - Bits 32-45, 52, 55, or 63 of general register $R_1$ are not zero.
   - The frame-size code in general register $R_1$ specifies a reserved value.

38. Execution of PERFORM LOCKED OPERATION is attempted, and any of the following is true:
   - The T bit, bit 55 of general register 0 is zero, and the function code in bits 56-63 of the register is invalid.
   - Bits 32-54 of general register 0 are not all zeros.
• In the access-register mode, for function codes that cause use of a parameter list containing an ALET, the $R_1$ field is zero.

39. Execution of PERFORM PSEUDORANDOM NUMBER OPERATION is attempted, bit 56 of general register 0 is one, and the length in general register $R_2 + 1$ is greater than 512.

40. Execution of PERFORM TIMING FACILITY FUNCTION is attempted, and either of the following is true:
   • Bit 56 of general register 0 is not zero.
   • Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

41. Execution of PROGRAM TRANSFER or PROGRAM TRANSFER WITH INSTANCE is attempted, and all of the following are true:
   • The extended-addressing-mode bit in the PSW is zero.
   • The basic-addressing-mode bit, bit 32, in the general register designated by the $R_2$ field of the instruction is zero.
   • Bits 33-39 of the instruction address in the same register are not all zeros.

42. Execution of RESUME PROGRAM is attempted, and any of the following is true:
   • Bits 31, 32, and 64-127 of the PSW field in the second operand are not valid for placement in the current PSW. The exception is recognized if any of the following is true:
     - Bits 31 and 32 are both zero and bits 64-103 are not all zeros.
     - Bits 31 and 32 are zero and one, respectively, and bits 64-96 are not all zeros.
     - Bits 31 and 32 are one and zero, respectively.
     - Bit 127 is one.
   • Bits 0-12 of the parameter list are not all zeros.

43. Execution of SEARCH STRING UNICODE is attempted, and bits 32-47 of general register 0 are not all zeros.

44. Execution of SET ADDRESS SPACE CONTROL or SET ADDRESS SPACE CONTROL FAST is attempted, and bits 52 and 53 of the second-operand address are not both zeros.

45. Execution of SET ADDRESSING MODE (SAM24) is attempted, and bits 0-39 of the unupdated instruction address in the PSW, bits 64-103 of the PSW, are not all zeros.

46. Execution of SET ADDRESSING MODE (SAM31) is attempted, and bits 0-32 of the unupdated instruction address in the PSW, bits 64-96 of the PSW, are not all zeros.

47. Execution of SET CLOCK PROGRAMMABLE FIELD is attempted, and bits 32-47 of general register 0 are not all zeros.

48. Execution of SET FPC or SET FPC AND SIGNAL is attempted, and one or more bits of the first operand corresponding to unsupported bits in the FPC register are one.

49. Execution of STORE SYSTEM INFORMATION is attempted, the function code in general register 0 is valid, and bits 36-55 of general register 0 and bits 32-47 of general register 1 are not all zeros.

50. Execution of TRANSACTION ABORT is attempted, and the second-operand address is between 0 and 255

51. Execution of TRANSACTION BEGIN (TBEGIN) is attempted, and the program-interruption-filtering control, bits 14-15 of $I_2$ field of the instruction, contains the value 3.

52. Execution of TRANSACTION BEGIN (TBEGINC) is attempted, and the $B_1$ field is not zero.

53. Execution of TRANSLATE AND TEST EXTENDED or TRANSLATE AND TEST REVERSE EXTENDED is attempted, the A bit, bit 0 of the $M_3$ field, is one, and the argument-character length in general register $R_1 + 1$ is not an even number.

54. Execution of TRANSLATE TWO TO ONE or TRANSLATE TWO TO TWO is attempted, and the length in general register $R_1 + 1$ does not specify an even number of bytes.

55. Execution of UNPACK ASCII is attempted, and the $L_1$ field is greater than 31.
56. Execution of UNPACK UNICODE is attempted, and the L₁ field is greater than 63 or is even.

57. Execution of UPDATE TREE is attempted, and the initial contents of general registers 4 and 5 are not a multiple of 8 in the 24-bit or 31-bit addressing mode or are not a multiple of 16 in the 64-bit addressing mode.

58. Execution of a vector instruction is attempted, and an instruction-specified reason was recognized. See instruction descriptions in Chapters 21-24 for detailed reasons for specification exceptions.

The execution of the instruction identified by the old PSW is suppressed. However, for early PSW specification exceptions (causes 1-3) the operation that introduces the new PSW is completed, but an interruption occurs immediately thereafter.

Except as noted below, the instruction-length code (ILC) is 1, 2, or 3, indicating the length of the instruction causing the exception.

When the instruction address is odd (cause 4 on page 6-38), it is unpredictable whether the ILC is 1, 2, or 3.

When the exception is recognized because of an early PSW specification exception (causes 1-3) and the exception has been introduced by LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, or an interruption, the ILC is 0. When the exception is introduced by SET ADDRESSING MODE (SAM24, SAM31), the ILC is 1, or it is 2 if SET ADDRESSING MODE was the target of EXECUTE, or 3 if the SET ADDRESSING MODE was the target of EXECUTE RELATIVE LONG. When the exception is introduced by SET SYSTEM MASK or by STORE THEN OR SYSTEM MASK, the ILC is 2.

The specification exception is indicated by a program-interruption code of 0006 hex (or 0086, 0206, or 0286 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

Programming Note: See “Exceptions Associated with the PSW” on page 6-9 for a definition of when the exceptions associated with the PSW are recognized.

Stack-Empty Exception
A stack-empty exception is recognized during the unstacking process in EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, MODIFY STACKED STATE, or PROGRAM RETURN when the current linkage-stack entry is a header entry and the backward stack-entry validity bit in the header entry is zero.

The operation is nullified.

The instruction-length code is 1 or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The stack-empty exception is indicated by a program-interruption code of 0031 hex (or 00B1 hex if a concurrent PER event is indicated).

Stack-Full Exception
A stack-full exception is recognized during the stacking process in BRANCH AND STACK or stacking PROGRAM CALL when there is not enough remaining free space in the current linkage-stack section and the forward-section validity bit in the trailer entry of the section is zero.

The operation is nullified.

The instruction-length code is 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The stack-full exception is indicated by a program-interruption code of 0030 hex (or 00B0 hex if a concurrent PER event is indicated).

Stack-Operation Exception
A stack-operation exception is recognized during the unstacking process in PROGRAM RETURN when the unstack-suppression bit is one in any linkage-stack state entry or header entry encountered during the process.

The operation is nullified.

The instruction-length code is 1 or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The stack-operation exception is indicated by a program-interruption code of 0034 hex (or 00B4 hex if a concurrent PER event is indicated).
Stack-Specification Exception
A stack-specification exception is recognized in each of the following cases:

1. During the stacking process in BRANCH AND STACK or stacking PROGRAM CALL when there is not enough remaining free space in the current linkage-stack section and either of the following is true:
   a. The remaining-free-space value used to locate the trailer entry of the current section is not a multiple of 8.
   b. There is not enough remaining free space in the next section.

2. During the unstacking process in EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, MODIFY STACKED STATE, or PROGRAM RETURN when the current linkage-stack entry is a header entry in which the backward stack-entry address designates another header entry.

The operation is nullified.

The instruction-length code is 1 or 2, except that when the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

The stack-specification exception is indicated by a program-interruption code of 0032 hex (or 00B2 hex if a concurrent PER event is indicated).

Stack-Type Exception
A stack-type exception is recognized during the unstacking process in EXTRACT STACKED REGISTERS, EXTRACT STACKED STATE, MODIFY STACKED STATE, or PROGRAM RETURN in each of the following cases:

1. The current linkage-stack entry is not a header entry or a state entry.

2. When the current linkage-stack entry is a header entry, the preceding entry, designated by the backward stack-entry address in the header entry, is not a header entry or a state entry. (A stack-specification exception is recognized if the preceding entry is a header entry.)

The operation is nullified.

The instruction-length code is 1, 2, or 3, indicating the length of the instruction causing the exception.

The stack-type exception is indicated by a program-interruption code of 0033 hex (or 00B3 hex if a concurrent PER event is indicated).

Trace-Table Exception
A trace-table exception is recognized when the CPU attempts to store a trace-table entry which would reach or cross the next 4K-byte block boundary. For the purpose of recognizing this exception in the TRACE instruction, the explicit trace entry is treated as being 76 bytes long for TRACE (TRACE) and as 144 bytes long for TRACE (TRACG). For a PROGRAM CALL instruction that would cause storing of both a PROGRAM CALL trace entry and a mode-switch trace entry, the exception is recognized for the first entry when either the first or the second entry would reach or cross the boundary.

The operation is nullified.

The instruction-length code is 1, 2, or 3, indicating the length of the instruction causing the exception.

The trace-table exception is indicated by a program-interruption code of 0016 hex (or 0096 hex if a concurrent PER event is indicated).

Transaction-Constraint Exception
A transaction-constraint exception is recognized when a constrained transaction violates one or more of its constraints. See “Constrained Transaction” on page 5-108 for details on the constraints.

The unit of operation is suppressed.

When the exception occurs as a result of the fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. Otherwise, the instruction-length code (ILC) is 1, 2, or 3 and indicates the length of the instruction at which the exception was detected.

The transaction-constraint exception is indicated by a program-interruption code of 0218 hex (or 0298 hex if a concurrent PER event is indicated).

Programming Note: The instruction designated by the aborted-transaction instruction address is not necessarily the instruction that caused the transaction-constraint exception.
**Transactional-Execution-Aborted Event**

A transactional-execution-aborted event is recognized when a transaction is aborted due to a program-interruption condition that results in an interruption.

The instruction-length code stored in bits 5-6 of real location 141, and, when a TBEGIN-specified transaction diagnostic block (TDB) is stored, the instruction-length code stored in bits 5-6 of byte 37 of the TDB, is 1, 2, or 3, reflecting the length of the instruction that caused the abort, except that when the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3.

The transactional-execution-aborted event is indicated by setting bit 6 of the program-interruption code at real locations 142-143 to one. The remainder of the program-interruption code at real locations 142-143 identifies the program-interruption condition that caused the abort. When a TBEGIN-specified transaction diagnostic block is stored, bit 6 is not set in the program-interruption code in bytes 38-39 of the TDB.

See “Transaction Abort Processing” on page 5-103 for a detailed description of transaction abort processing due to program interruptions.

**Translation-Specification Exception**

A translation-specification exception is recognized when translation of a virtual address is attempted and any of the following is true:

1. In the lookup in the table designated by the address-space-control element used for the translation, the table-type bits in the selected table entry do not equal the designation-type bits in the address-space-control element.

2. In a lookup in a table designated by an entry in a region first table, region second table, or region third table, the value of the table-type bits in the selected table entry is not one less than the value of the same bits in the designating table entry.

3. The private-space control, bit 55 in the address-space-control element used for the translation, is one, and either of the following is true:
   - The segment-table entry used for the translation is valid, and the common-segment bit, bit 59, in the segment-table entry is one.
   - EDAT-2 applies, the region-third-table entry used for the translation is valid, and the common-region bit, bit 59, in the region-third-table entry is one.

4. The page-table entry used for the translation is valid, and bit position 52 does not contain zero.

5. The page-table entry used for the translation is valid, EDAT-1 does not apply, and bit position 55 does not contain zero.

Any of the above reasons is referred to by saying that the DAT-table entry has a format error.

The exception is recognized only as part of the execution of an instruction using address translation, that is, when DAT is on and a logical address, instruction address, or virtual address must be translated, or when LOAD PAGE-TABLE-ENTRY ADDRESS, LOAD REAL ADDRESS or STORE REAL ADDRESS is executed.

The unit of operation is suppressed.

When the exception occurs during fetching of an instruction, it is unpredictable whether the ILC is 1, 2, or 3. When the exception occurs during the fetching of the target of EXECUTE, the ILC is 2. When the exception occurs during the fetching of the target of EXECUTE RELATIVE LONG, the ILC is 3.

When the exception occurs during a reference to an operand location, the instruction-length code (ILC) is 1, 2, or 3 and indicates the length of the instruction causing the exception.

The translation-specification exception is indicated by a program-interruption code of 0012 hex (or 0092, 0212, or 0292 hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Programming Note:** When a translation-specification exception is recognized in the process of translating an instruction address, the operation is suppressed. In this case, the instruction-length code (ILC) is needed to derive the address of the instruction, as the instruction address in the old PSW has been incremented by the amount indicated by the ILC. In the case of region-first-translation, region-second-translation, region-third-translation, segment-translation, and page-translation exceptions, the operation is nullified, the instruction address in the
old PSW identifies the instruction, and the ILC may be arbitrarily set to 1, 2, or 3.

**Vector Processing Exception**

A vector-processing exception is recognized when there is an exception while executing a vector floating point instruction. See the section “IEEE Exceptions” on page 19-7 for details.

The operation is suppressed.

The instruction-length code is 3, except that when the instruction is target of EXECUTE, the ILC is 2.

Each of the IEEE exceptions is controlled by a mask bit in the floating-point-control (FPC) register. The handling of these exceptions is described in the section “IEEE Exceptions” on page 9-18.

The vector-processing exception is indicated by a program-interruption code of 001B hex (or 009B, 021B, or 029B hex, if a concurrent PER event, a concurrent transactional-execution-aborted event, or both are indicated, respectively).

**Collective Program-Interruption Names**

For the sake of convenience, certain program exceptions are grouped together under a single collective name. These collective names are used when it is necessary to refer to the complete set of exceptions, such as in instruction definitions. Four collective names are used:

- Access exceptions
- ASN-translation exceptions
- Subspace-replacement exceptions
- Trace exceptions

The individual exceptions and their priorities are listed in “Multiple Program-Interruption Conditions” on page 6-48.

**Recognition of Access Exceptions**

Figure 6-5 on page 6-45 summarizes the conditions that can cause access exceptions and the action taken when they are encountered.

---

<table>
<thead>
<tr>
<th>Condition</th>
<th>Indication</th>
<th>Action</th>
<th>Indication</th>
<th>Action</th>
<th>Indication</th>
<th>Action</th>
<th>Indication</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>Access register?</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>AS</td>
<td>Suppress</td>
</tr>
<tr>
<td>Bits 0-6 not all zeros</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Effective access-list designation</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
</tr>
<tr>
<td>Invalid address of designation</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Access-list entry?</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>AT</td>
<td>Nullify</td>
</tr>
<tr>
<td>Access-list-length violation</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
</tr>
<tr>
<td>Invalid address of entry</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>I bit on</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>AT</td>
<td>Nullify</td>
</tr>
<tr>
<td>Sequence number in access register not equal to sequence number in entry</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ASN-second-table entry?</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
</tr>
<tr>
<td>Invalid address of entry</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>I bit on</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>AV</td>
<td>Nullify</td>
</tr>
<tr>
<td>Sequence number in access-list entry not equal to sequence number in entry</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Figure 6-5. Handling of Access Exceptions (Part 1 of 4)**
<table>
<thead>
<tr>
<th>Condition</th>
<th>Indication</th>
<th>Action</th>
<th>Indication</th>
<th>Action</th>
<th>Indication</th>
<th>Action</th>
<th>Indication</th>
<th>Action</th>
<th>Indication</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>Authority-table entry</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>EA</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Authority-table-length violation</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Invalid address of entry</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>EA</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Second-authority bit not one</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Address-space-control element</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>ATY</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bits 0-10, 0-21, or 0-32 of instruction or</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>operand address not all zeros when</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>address-space-control element is a region-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>second-table designation, region-third-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>table designation, or segment-table</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>designation, respectively</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Region-table-entry designation by</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>RT</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>address-space-control element or region-</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>table-entry</td>
<td>cc2</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>RT</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Entry outside of table</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Invalid address of entry</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>I bit on</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TT in entry not equal DT in address-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>space-control element or not one less than TT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>in next-higher-level entry</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Segment-table entry designation by</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>ST</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>address-space-control element or region-</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>table-entry</td>
<td>cc2</td>
<td>Complete</td>
<td>cc1</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>ST</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Entry outside of table</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Invalid address of entry</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>I bit on (except as follows)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>I bit on (LRA in 24-bit or 31-bit mode when</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>bits 0-32 of entry address not all zeros)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>One in a bit position which is checked for</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>zero5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TT in entry not equal DT in address-</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>space-control element or not one less than TT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>in next-higher-level entry (TT not zero)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Page-table entry</td>
<td>-</td>
<td>-</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td>A</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Invalid address of entry</td>
<td>-</td>
<td>-</td>
<td>cc2</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>PT</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>I bit on (except as follow)</td>
<td>-</td>
<td>-</td>
<td>cc3</td>
<td>Complete</td>
<td>cc3</td>
<td>Complete</td>
<td>PT</td>
<td>Nullify</td>
<td></td>
<td></td>
</tr>
<tr>
<td>I bit on (LRA in 24-bit or 31-bit mode when</td>
<td>-</td>
<td>-</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>bits 0-32 of entry address not all zeros)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>One in a bit position which is checked for</td>
<td>-</td>
<td>-</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td>TS</td>
<td>Suppress</td>
<td></td>
<td></td>
</tr>
<tr>
<td>zeros5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 6-5. Handling of Access Exceptions (Part 2 of 4)
<table>
<thead>
<tr>
<th>Condition</th>
<th>Translation for Virtual Address of LPTEA</th>
<th>Translation for Virtual Address of LOAD REAL ADDRESS</th>
<th>Translation for TAR and TPROT, and Access for Logical Address of TPROT</th>
<th>Translation and Access for Any Other Address</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Indication</td>
<td>Action</td>
<td>Indication</td>
<td>Action</td>
</tr>
<tr>
<td>Access for instruction fetch</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>Location protected (key-controlled protection)</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>Invalid address</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>Access for operand</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>cc set&lt;sup&gt;6&lt;/sup&gt;</td>
</tr>
<tr>
<td>Location protected (low-address, DAT, or key-controlled protection)</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>Invalid address</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

**Explanation**

1. The condition does not apply.
2. Action is to terminate except where otherwise specified in this publication. For access-list-controlled protection and DAT protection, the action is always to suppress.
3. TAR does not have a logical address. The rows “Address-space-control element” through “Access for operands” apply only to TPROT, not to TAR.
4. Protection applies only to accesses for instruction fetch and for operands. It does not apply to the fetching of the effective access-list designation or any of the listed entries.
5. Exceptions related to an access register, effective access-list designation, access-list entry, ASN-second-table entry, or authority-table entry are recognized only in the access-register mode except that, for LOAD REAL ADDRESS and STORE REAL ADDRESS, they are recognized when PSW bits 16 and 17 are 01 binary, and, for TEST ACCESS, they are recognized regardless of the translation mode.
6. Authority table is not accessed and secondary-authority bit is not checked if the private bit in the access-list entry is zero or the access-list-entry authorization index in the access-list entry is equal to the extended authorization index in control register 8.
7. A translation-specification exception for a format error in a table entry is recognized only when the execution of an instruction requires the entry for translation of an address.
8. The condition code is set as follows:
   0 Operand location not protected.
   1 Fetches permitted, but stores not permitted.
   2 Neither fetches nor stores permitted.
A Addressing exception.
ALQ ALE-sequence exception.
AS ALET-sequence exception.
ASQ ASTE-sequence exception.
AT ALEN-translation exception.
ATY ASCE-type exception.
AV ASTE-validity exception.
cc1 Condition code 1 set.
cc2 Condition code 2 set.
cc3 Condition code 3 set.
EA Extended-authority exception.
P Protection exception.
PT Page-translation exception.

*Figure 6-5. Handling of Access Exceptions (Part 3 of 4)*
Any access exception is recognized as part of the execution of the instruction with which the exception is associated. An access exception is not recognized when the CPU attempts to prefetch from an unavailable location or detects some other access-exception condition, but a branch instruction or an interruption changes the instruction sequence such that the instruction is not executed.

Every instruction can cause an access exception to be recognized because of instruction fetch. Additionally, access exceptions associated with instruction execution may occur because of an access to an operand in storage.

An access exception due to fetching an instruction is indicated when the first instruction halfword cannot be fetched without encountering the exception. When the first halfword of the instruction has no access exceptions, access exceptions may be indicated for additional halfwords according to the instruction length specified by the first two bits of the instruction; however, when the operation can be performed without accessing the second or third halfwords of the instruction, it is unpredictable whether the access exception is indicated for the unused part. Since the indication of access exceptions for instruction fetch is common to all instructions, it is not covered in the individual instruction definitions.

Except where otherwise indicated in the individual instruction description, the following rules apply for exceptions associated with an access to an operand location. For a fetch-type operand, access exceptions are necessarily indicated only for that portion of the operand which is required for completing the operation. It is unpredictable whether access exceptions are indicated for those portions of a fetch-type operand which are not required for completing the operation. For a store-type operand, access exceptions are recognized for the entire operand even if the operation could be completed without the use of the inaccessible part of the operand. In situations where the value of a store-type operand is defined to be unpredictable, it is unpredictable whether an access exception is indicated.

Whenever an access to an operand location can cause an access exception to be recognized, the word “access” is included in the list of program exceptions in the description of the instruction. This entry also indicates which operand can cause the exception to be recognized and whether the exception is recognized on a fetch or store access to that operand location. Access exceptions are recognized only for the portion of the operand as defined for each particular instruction.

### Multiple Program-Interruption Conditions

Except for PER basic events, only one program-interruption condition is indicated with a program interruption. The existence of one condition, however, does not preclude the existence of other conditions. When more than one program-interruption condition exists, only the condition having the highest priority is identified in the interruption code.

When multiple conditions of the same priority apply, it is unpredictable which is indicated.

When multiple parts of the same storage operand are subject to separate access controls, the priority of access exceptions associated with the parts is unpredictable and is not necessarily related to the sequence specified for the access of bytes within the operand. For example, when (a) the first operand of a MOVE (MVC) instruction crosses a segment bound-
ary, (b) the invalid bit is one in the segment-table entry used to translate the leftmost part of the operand, and (c) the DAT protection bit is one in a valid page-table entry used to translate the rightmost part of the operand, then it is unpredictable whether a segment-translation exception or protection exception is recognized.

When an instruction has two storage operands and access-exception conditions exist for both operands, it is unpredictable which condition is recognized. A subsequent execution of the same instruction (with the same exception conditions) may result in the exception condition being recognized for the same operand as the first execution, or for the other operand.

The type of ending which occurs (nullification, suppression, or termination) is that which is defined for the type of exception that is indicated in the interruption code. However, if a condition is indicated which permits termination, and another condition also exists which would cause either nullification or suppression, then the unit of operation is suppressed.

Figure 6-6 on page 6-49 lists the priorities of all program-interruption conditions other than PER basic events and exceptions associated with some of the more complex control instructions. All exceptions associated with references to storage for a particular instruction halfword or a particular operand byte are grouped as a single entry called “access.” Figure 6-7 on page 6-52 lists the priority of access exceptions for a single access. Thus, the second figure specifies which of several exceptions, encountered either in the access of a particular portion of an instruction or in any particular access associated with an operand, has highest priority, and the first figure specifies the priority of this condition in relation to other conditions detected in the operation. Similarly, the priorities for exceptions occurring as part of ASN translation and tracing are covered in Figure 6-8 on page 6-53 and Figure 6-10 on page 6-54, respectively.

For some instructions, the priority is shown in the individual instruction description.

The relative priorities of any two conditions listed in the figure can be found by comparing the priority numbers, as found in the figure, from left to right until a mismatch is found. If the first inequality is between numeric characters, either the two conditions are mutually exclusive or, if both can occur, the condition with the smaller number is indicated. If the first inequality is between alphabetic characters, then the two conditions are not exclusive, and it is unpredictable which is indicated when both occur.

To understand the use of the table, consider an example involving the instruction ADD DECIMAL, which is a six-byte instruction. Assume that the first four bytes of the instruction can be accessed but that the instruction crosses a boundary so that an addressing exception exists for the last two bytes. Additionally, assume that the first operand addressed by the instruction contains invalid decimal digits and is in a location that can be fetched from, but not stored into, because of key-controlled protection. The three exceptions which could result from attempted execution of the ADD DECIMAL are:

<table>
<thead>
<tr>
<th>Priority Number</th>
<th>Exception</th>
</tr>
</thead>
<tbody>
<tr>
<td>6.2.B</td>
<td>Access exceptions for third instruction halfword</td>
</tr>
<tr>
<td>8.B</td>
<td>Access exceptions (operand 1).</td>
</tr>
<tr>
<td>8.D</td>
<td>Data exception</td>
</tr>
</tbody>
</table>

Since the first inequality (6>8) is between numeric characters, the addressing exception would be indicated. If, however, the entire ADD DECIMAL instruction can be fetched, and only the second two exceptions listed above exist, then the inequality (B>D) is between alphabetic characters, and it is unpredictable whether the protection exception or the data exception would be indicated.

<table>
<thead>
<tr>
<th>Any</th>
<th>Transaction constraint exception, except for one caused by a restricted instruction</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.</td>
<td>Specification exception due to any PSW error of the type that causes an immediate interruption.</td>
</tr>
<tr>
<td>2.</td>
<td>Specification exception due to an odd instruction address in the PSW.</td>
</tr>
<tr>
<td>3.</td>
<td>Access exceptions for first halfword of an execute-type instruction.</td>
</tr>
<tr>
<td>4.A</td>
<td>Access exceptions for second halfword of an execute-type instruction.</td>
</tr>
<tr>
<td>4.B</td>
<td>Access exceptions for third halfword of EXECUTE RELATIVE LONG.</td>
</tr>
<tr>
<td>5.1</td>
<td>PER event due to instruction-fetching nullification on an execute-type instruction. (With PER-3)</td>
</tr>
</tbody>
</table>

Figure 6-6. Priority of Program-Interruption Conditions
| 5.2 | Specification exception due to target instruction of EXECUTE not being specified on halfword boundary. |
| 6.1 | Access exceptions for first instruction halfword. |
| 6.2.A | Access exceptions for second instruction halfword. (With PER-3) |
| 6.2.B | Access exceptions for third instruction halfword. (With PER-3) |
| 6.3 | PER event due to instruction-fetching nullification. (PER-3) |
| 7.A | Access exceptions for second instruction halfword. (Without PER-3) |
| 7.B | Access exceptions for third instruction halfword. (Without PER-3) |
| 7.C | Operation exception. |
| 7.C.1 | Operation exception. |
| 7.C.2 | Privileged-operation exception for privileged instructions. |
| 7.C.3 | Execute exception. |
| 7.C.4 | Special-operation exception. |
| 7.D | Transaction-constraint exception due to any restricted instruction. |
| 8.A | Specification exception due to conditions other than those included in 1, 2, and 5.2 above. |
| 8.B | Access exceptions for an access to an operand in storage. |
| 8.C | Access exceptions for any other access to an operand in storage. |
| 8.D.1 | Data exception. |
| 8.D.2 | Vector-processing exception. |
| 8.E | Decimal-divide exception. |
| 8.F | Trace exceptions. |
| 9. | Events other than PER events, exceptions which result in completion, and the following exceptions: |
| | • Fixed-point divide, |
| | • Floating-point divide, |
| | • Operand, |
| | • Special-operation recognized by any of the following: |
| | ‒ LOAD PAGE-TABLE-ENTRY ADDRESS due to a real-space designation |
| | ‒ LOAD REAL ADDRESS |
| | See the definition of the TRAP instruction for other priorities of the special-operation exception. |
| | • Square root. |
| | Either these exceptions and events are mutually exclusive or their priority is specified in the corresponding definitions. |

**Explanation:**

Numbers indicate priority, with “1” being the highest priority; letters indicate no priority.

1. PSW errors which cause an immediate interruption may be introduced by a new PSW loaded as a result of an interruption or by the instructions BRANCH AND SET AUTHORITY, LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, SET SYSTEM MASK, and STORE THEN OR SYSTEM MASK. The priority shown in the chart is for a PSW error introduced by an interruption and may also be considered as the priority for a PSW error introduced by the previous instruction. The error is introduced only if the instruction encounters no other exceptions. The resulting interruption has a higher priority than any interruption caused by the instruction which would have been executed next; it has lower priority, however, than any interruption caused by the instruction which introduced the erroneous PSW.

2. Priorities 3, 4.A, and 5.1 are for both EXECUTE and EXECUTE RELATIVE LONG, priority 4.B is for EXECUTE RELATIVE LONG, priority 5.2 is for EXECUTE; priorities starting with 6 are for the target instruction. When no execute-type instruction is encountered, priorities 3-5 do not apply.

*Figure 6-6. Priority of Program-Interruption Conditions (Continued)*
Access Exceptions

The access exceptions consist of those exceptions which can be encountered while using an absolute, instruction, logical, real, or virtual address to access storage. Thus, in the access-register mode, the exceptions are:

1. ALET specification
2. ALEN translation
3. ALE sequence
4. ASTE validity
5. ASTE sequence
6. Extended authority
7. Addressing (the ART tables)
8. ASCE type
9. Region first translation
10. Region second translation
11. Region third translation
12. Segment translation
13. Page translation
14. Translation specification
15. Addressing (the DAT tables)
16. Addressing (the operand or instruction)
17. Protection (key-controlled, access-list-controlled, DAT, and low-address)

With DAT on but in other than the access-register mode, exceptions 8-17 in the above list, except for access-list-controlled protection, can be encountered.

With DAT off, the exceptions are:

18. Addressing (the operand or instruction)
19. Protection (key-controlled and low-address)

Additionally, even with DAT off, the instruction STORE REAL ADDRESS can encounter exceptions 1-17, the instructions LOAD PAGE-TABLE-ENTRY ADDRESS and LOAD REAL ADDRESS can encounter exceptions 7, 14, and 15, and the instructions COMPARE AND REPLACE DAT TABLE ENTRY, INVALIDATE PAGE TABLE ENTRY, and INVALIDATE PAGE TABLE ENTRY can encounter exception 15.

The access exceptions are listed in more detail in Figure 6-7 on page 6-52.

Programming Note: The priorities in Figure 6-7 on page 6-52 could be renumbered, but they are kept as they are to allow easier comparison to the corresponding ESA/390 priorities. Specifically, B.1.A.1-B.1.A.9 could be changed to B.1-B.9, but ESA/390 contains “B.1.B Translation-specification exception.
due to invalid encoding of bits 8-12 of control register 0."

<table>
<thead>
<tr>
<th>A. Protection exception (low-address protection) due to a store-type operand reference with an effective address in the range 0-511 or 4096-4607. Not recognized if DAT is on and the address-space-control element to be used in the translation cannot be obtained because of another exception.</th>
</tr>
</thead>
<tbody>
<tr>
<td>B.1.A.1 ALET-specification exception due to bits 0-6 of access register not being all zeros.</td>
</tr>
<tr>
<td>B.1.A.2 Addressing exception for access to effective access-list designation.</td>
</tr>
<tr>
<td>B.1.A.3 ALEN-translation exception due to access-list entry being outside the list.</td>
</tr>
<tr>
<td>B.1.A.4 Addressing exception for access to access-list entry.</td>
</tr>
<tr>
<td>B.1.A.5 ALEN-translation exception due to I bit in access-list entry having the value one.</td>
</tr>
<tr>
<td>B.1.A.6 ALE-sequence exception due to access-list-entry sequence number (ALESN) in access register not being equal to ALESN in access-list entry.</td>
</tr>
<tr>
<td>B.1.A.7 Addressing exception for access to ASN-second-table entry.</td>
</tr>
<tr>
<td>B.1.A.8 ASTE-validity exception due to I bit in ASN-second-table entry having the value one.</td>
</tr>
<tr>
<td>B.1.A.9 ASTE-sequence exception due to ASN-second-table-entry sequence number (ASTESN) in access-list entry not being equal to ASTESN in ASN-second-table entry.</td>
</tr>
<tr>
<td>Note: Exceptions B.1.A.10 through B.1.A.12 are recognized only when the private bit in the access-list entry is one and the ALEAX in the entry is not equal to the EAX in control register 8.</td>
</tr>
<tr>
<td>B.1.A.10 Extended-authority exception due to access-list entry being outside table.</td>
</tr>
<tr>
<td>B.1.A.11 Addressing exception for access to authority-table entry.</td>
</tr>
<tr>
<td>B.1.A.12 Extended-authority exception due to (1) private bit in access-list entry not being zero, (2) access-list-entry authorization index in access-list entry not being equal to extended authorization index in control register 8, and (3) secondary-authority bit selected by extended authorization index not being one.</td>
</tr>
<tr>
<td>B.2.A Protection exception (access-list-controlled protection) due to store-type operand reference to a virtual address which is protected against stores.</td>
</tr>
<tr>
<td>B.2.B.1 ASCE-type exception due to bits 0-10, 0-21, or 0-32 of instruction or operand address not being zeros when address-space-control element is a region-second-table designation, region-third-table designation, or segment-table designation, respectively.</td>
</tr>
<tr>
<td>B.2.B.2 Region-first-, region-second-, region-third-, or segment-translation exception due to required entry in table designated by address-space-control element being outside of table.</td>
</tr>
<tr>
<td>Note: Exceptions B.2.B.3 through B.2.B.6 are recognized for a region-first-table, region-second-table, region-third-table, and segment-table entry in the order in which the entries are used.</td>
</tr>
<tr>
<td>B.2.B.3 Addressing exception for access to table entry.</td>
</tr>
<tr>
<td>B.2.B.4 Region-first-, region-second-, region-third-, or segment-translation exception due to I bit in table entry having the value one.</td>
</tr>
<tr>
<td>B.2.B.5 Translation-specification exception due to (1) TT in table entry not equal to DT in designating address-space-control element or not one less than TT in designating next-higher-level table entry, (2) invalid one in segment-table entry if this entry is a segment-table entry (common-segment bit if private-space bit in address-space-control element is one), or (3) invalid one in region-third-table entry if EDAT-2 applies and this entry is a region-third-table entry (common-region bit if private-space bit in address-space-control element is one).</td>
</tr>
</tbody>
</table>

Figure 6-7. Priority of Access Exceptions (Part 1 of 2)
ASN-Translation Exceptions
The ASN-translation exceptions are those exceptions which are common to the process of translating an ASN in the instructions PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, and SET SECONDARY ASN WITH INSTANCE. The exceptions and the priority in which they are detected are shown in Figure 6-8.

1. Addressing exception for access to ASN- first-table entry.

---

Figure 6-8. Priority of ASN-Translation Exceptions
Subspace-Replacement Exceptions
The subspace-replacement exceptions are those exceptions which can be recognized during a subspace-replacement operation in PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, or SET SECONDARY ASN WITH INSTANCE. The exceptions and their priority are shown in Figure 6-9 on page 6-54.

1. Addressing exception for access to dispatchable-unit control table.
2. Addressing exception for access to subspace ASN-second-table entry.
3. ASTE-validity exception due to bit 0 being one in subspace ASN-second-table entry.
4. ASTE-sequence exception due to subspace ASN-second-table-entry sequence number in dispatchable-unit control table not being equal to ASN-second-table-entry sequence number in subspace ASN-second-table entry.

---

Trace Exceptions
The trace exceptions are those exceptions which can be encountered while forming a trace-table entry. The exceptions and their priority are shown in Figure 6-10 on page 6-54.

A. Protection exception (low-address protection) due to entry address being in the range 0-511 or 4096-4607.
B.1 Trace-table exception due to new entry reaching or crossing next 4K-byte boundary.
B.2 Addressing exception for access to trace-table entry.

---

Restart Interruption
The restart interruption provides a means for the operator or another CPU to invoke the execution of a specified program. The CPU cannot be disabled for this interruption.

A restart interruption causes the old PSW to be stored at real locations 288-303 and a new PSW, designating the start of the program to be executed, to be fetched from real 416-431. The instruction-length code and interruption code are not stored.

If the CPU is in the operating state, the exchange of the PSWs occurs at the completion of the current unit of operation and after all other pending interruption conditions for which the CPU is enabled have been honored. If the CPU is in the stopped state, the CPU enters the operating state and exchanges the PSWs without first honoring any other pending interruptions.

The restart interruption is initiated by activating the restart key. The operation can also be initiated at the addressed CPU by executing a SIGNAL PROCESSOR instruction which specifies the restart order.

When the rate control is set to the instruction-step position, it is unpredictable whether restart causes a unit of operation or additional interruptions to be performed after the PSWs have been exchanged.

Programming Note: To perform a restart when the CPU is in the check-stop state, the CPU has to be reset. Resetting with loss of the least amount of information can be accomplished by means of the system-reset-normal key, which does not clear the contents of program-addressable registers, including the control registers, but causes the channel subsystem to be reset. The CPU-reset SIGNAL PROCESSOR order can be used to clear the CPU without affecting the channel subsystem.

---

Supervisor-Call Interruption
The supervisor-call interruption occurs when the instruction SUPERVISOR CALL is executed. The CPU cannot be disabled for the interruption, and the interruption occurs immediately upon the execution of the instruction.
The supervisor-call interruption causes the old PSW to be stored at real locations 320-335 and a new PSW to be fetched from real locations 448-463.

The contents of bit positions 8-15 of the SUPERVISOR CALL instruction are placed in the rightmost byte of the interruption code. The leftmost byte of the interruption code is set to zero. The instruction-length code is 1, unless the instruction was executed by means of an execute-type instruction. When the SUPERVISOR CALL instruction was executed by means of EXECUTE, the instruction-length code is 2; when it is executed by means of EXECUTE RELATIVE LONG, the instruction-length code is 3.

The interruption code is placed at real locations 138-139; the instruction-length code is placed in bit positions 5 and 6 of the byte at real location 137, with the other bits set to zeros; and zeros are stored at real location 136.

### Priority of Interruptions

During the execution of an instruction, several interruption-causing events may occur simultaneously. The instruction may give rise to a program interruption, a request for an external interruption may be received, equipment malfunctioning may be detected, an I/O-interruption request may be made, and the restart key may be activated. Instead of the program interruption, a supervisor-call interruption might occur; or both can occur if PER is active. Simultaneous interruption requests are honored in a predetermined order.

An exigent machine-check condition has the highest priority. When it occurs, the current operation is terminated or nullified. Program and supervisor-call interruptions that would have occurred as a result of the current operation may be eliminated. Any pending repressible machine-check conditions may be indicated with the exigent machine-check interruption. Every reasonable attempt is made to limit the side effects of an exigent machine-check condition, and requests for external, I/O, and restart interruptions normally remain unaffected.

In the absence of an exigent machine-check condition, interruption requests existing concurrently at the end of a unit of operation are honored, in descending order of priority, as follows:

- Supervisor call
- Program
- Repressible machine check
- External
- Input/output
- Restart

The processing of multiple simultaneous interruption requests consists in storing the old PSW and fetching the new PSW belonging to the interruption first honored. This new PSW is subsequently stored without the execution of any instructions, and the new PSW associated with the next interruption is fetched. Storing and fetching of PSWs continues until no more interruptions are to be serviced. The priority is reevaluated after each new PSW is loaded. Each evaluation takes into consideration any additional interruptions which may have become pending. Additionally, external and I/O interruptions, as well as machine-check interruptions due to repressible conditions, occur only if the current PSW at the instant of evaluation indicates that the CPU is interruptible for the cause.

Instruction execution is resumed using the last-fetched PSW. The order of executing interruption subroutines is, therefore, the reverse of the order in which the PSWs are fetched.

If the new PSW for a program interruption does not specify the wait state and has an odd instruction address, or causes an access exception to be recognized, another program interruption occurs. Since this second interruption introduces the same unacceptable PSW, a string of interruptions is established. These program exceptions are recognized as part of the execution of the following instruction, and the string may be broken by an external, I/O, machine-check, or restart interruption or by the stop function.

If the new PSW for a program interruption contains a one in bit position 12 or in an unassigned bit position, if the leftmost 40 bits of the instruction address are not zeros when bit 31 and 32 indicate 24-bit addressing, or the leftmost 33 bits are not zeros when bits 31 and 32 indicate 31-bit addressing, or if bit 32 is zero when bit 31 is one, another program interruption occurs. This condition is of higher priority than restart, I/O, external, or repressible machine-check conditions, or the stop function, and CPU reset has to be used to break the string of interruptions.

A string of interruptions for other interruption classes can also exist if the new PSW allows the interruption
which has just occurred. These include machine-check interruptions, external interruptions, and I/O interruptions due to program-controlled-interruption (PCI) conditions generated because of CCWs which form a loop. Furthermore, a string of interruptions involving more than one interruption class can exist. For example, assume that the CPU timer is negative and the CPU-timer subclass mask is one. If the external new PSW has a one in an unassigned bit position, and the program new PSW is enabled for external interruptions, then a string of interruptions occurs, alternating between external and program. Even more complex strings of interruptions are possible. As long as more interruptions must be serviced, the string of interruptions cannot be broken by employing the stop function; CPU reset is required.

Similarly, CPU reset has to be invoked to terminate the condition that exists when an interruption is attempted with a prefix value designating a storage location that is not available to the CPU.

Interruptions for all requests for which the CPU is enabled occur before the CPU is placed in the stopped state. When the CPU is in the stopped state, restart has the highest priority.

**Programming Note:** The order in which concurrent interruption requests are honored can be changed to some extent by masking.
Chapter 7. General Instructions

Data Format ................................. 7-3
Binary-Integer Representation ................. 7-4
Binary Arithmetic .......................... 7-5
  Signed Binary Arithmetic ................. 7-5
    Addition and Subtraction .............. 7-5
  Fixed-Point Overflow .................... 7-5
Unsigned Binary Arithmetic .................. 7-6
Signed and Logical Comparison .............. 7-6
Instructions ............................... 7-7
  ADD .................................. 7-25
  ADD IMMEDIATE ........................ 7-26
  ADD HALFWORD .......................... 7-27
  ADD HALFWORD IMMEDIATE ............... 7-27
  ADD HIGH .............................. 7-28
  ADD IMMEDIATE HIGH ................... 7-28
  ADD LOGICAL ........................... 7-29
  ADD LOGICAL IMMEDIATE ............... 7-29
  ADD LOGICAL HIGH ........................ 7-30
  ADD LOGICAL WITH CARRY .............. 7-30
  ADD LOGICAL WITH SIGNED IMMEDIATE .... 7-31
  ADD LOGICAL WITH SIGNED IMMEDIATE HIGH .......... 7-32
  AND .................................. 7-32
  AND IMMEDIATE ........................ 7-33
  BRANCH AND LINK ...................... 7-34
  BRANCH AND SAVE ....................... 7-35
  BRANCH AND SAVE AND SET MODE ........ 7-36
  BRANCH AND SET MODE .................. 7-37
  BRANCH ON CONDITION .................. 7-37
  BRANCH ON COUNT ..................... 7-38
  BRANCH ON INDEX HIGH ................ 7-39
  BRANCH ON INDEX LOW OR EQUAL ........ 7-39
  BRANCH PREDICTION PRELOAD ............ 7-40
  BRANCH PREDICTION RELATIVE ......... 7-40
  PRELOAD ............................. 7-40
  BRANCH RELATIVE AND SAVE ............ 7-43
  BRANCH RELATIVE AND SAVE LONG ...... 7-43
  BRANCH RELATIVE ON CONDITION ....... 7-44
  BRANCH RELATIVE ON CONDITION LONG ... 7-44
  BRANCH RELATIVE ON COUNT ........... 7-45
  BRANCH RELATIVE ON COUNT HIGH ...... 7-45
  BRANCH RELATIVE ON INDEX HIGH ...... 7-45
  BRANCH RELATIVE ON INDEX LOW OR EQUAL ........ 7-46
  CHECKSUM ............................. 7-47
  CIPHER MESSAGE ....................... 7-50
  CIPHER MESSAGE WITH CHAINING .......... 7-50
  CIPHER MESSAGE WITH CIPHER ........... 7-50
  FEEDBACK .............................. 7-75
  CIPHER MESSAGE WITH COUNTER .......... 7-90
  CIPHER MESSAGE WITH OUTPUT ............ 7-103
  FEEDBACK .............................. 7-103
  COMPARE .............................. 7-117
  COMPARE IMMEDIATE ..................... 7-117
  COMPARE RELATIVE LONG ................ 7-118
  COMPARE AND BRANCH ................... 7-118
  COMPARE AND BRANCH RELATIVE .......... 7-118
  COMPARE IMMEDIATE AND BRANCH ....... 7-119
  COMPARE IMMEDIATE AND BRANCH RELATIVE .......... 7-119
  COMPARE AND FORM CODEWORD .......... 7-120
  COMPARE AND SWAP ..................... 7-127
  COMPARE DOUBLE AND SWAP ............ 7-127
  COMPARE AND SWAP AND STORE ........... 7-129
  COMPARE AND TRAP ..................... 7-132
  COMPARE IMMEDIATE AND TRAP ........... 7-132
  COMPARE HALFWORD ..................... 7-133
  COMPARE HALFWORD IMMEDIATE .......... 7-133
  COMPARE HALFWORD RELATIVE LONG ...... 7-133
  COMPARE HIGH ........................ 7-134
  COMPARE IMMEDIATE HIGH .............. 7-134
  COMPARE LOGICAL ...................... 7-135
  COMPARE LOGICAL IMMEDIATE .......... 7-135
  COMPARE LOGICAL RELATIVE LONG ...... 7-136
  COMPARE LOGICAL AND BRANCH .......... 7-137
  COMPARE LOGICAL AND BRANCH RELATIVE .......... 7-137
  COMPARE LOGICAL IMMEDIATE AND BRANCH .......... 7-137
  COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE .......... 7-137
  COMPARE LOGICAL IMMEDIATE AND TRAP .......... 7-138
  COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE .......... 7-139
  COMPARE LOGICAL CHARACTERS UNDER MASK .......... 7-140
  COMPARE LOGICAL HIGH ................ 7-140
  COMPARE LOGICAL IMMEDIATE HIGH ...... 7-141
  COMPARE LOGICAL LONG ................. 7-141
  COMPARE LOGICAL LONG EXTENDED .... 7-143
  COMPARE LOGICAL LONG UNICODE .... 7-146
  COMPARE LOGICAL STRING .............. 7-149
  COMPARE UNTIL SUBSTRING EQUAL ...... 7-150
  COMPRESS CALL ........................ 7-153
  COMPUTE INTERMEDIATE MESSAGE DIGEST ........ 7-165
  COMPUTE LAST MESSAGE DIGEST ........... 7-165
  COMPUTE MESSAGE AUTHENTICATION CODE ........ 7-178
  CONVERT TO BINARY .................... 7-188
This chapter includes most of the unprivileged instructions described in this publication. Other unprivileged instructions are described in chapters 8-9 and 18-20.

**Data Format**

The general instructions treat data as being of four types: signed binary integers, unsigned binary integers, unstructured logical data, and decimal data. Data is treated as decimal by the conversion, packing, and unpacking instructions. Decimal data is described in Chapter 8, “Decimal Instructions.”
The general instructions manipulate data which resides in general registers or in storage or is introduced from the instruction stream. Some general instructions operate on data which resides in the PSW or the TOD clock.

In a storage-and-storage operation the operand fields may be defined in such a way that they overlap. The effect of this overlap depends upon the operation. When the operands remain unchanged, as in COMPARE or TRANSLATE AND TEST, overlapping does not affect the execution of the operation. For instructions such as MOVE and TRANSLATE, one operand is replaced by new data, and the execution of the operation may be affected by the amount of overlap and the manner in which data is fetched or stored. For purposes of evaluating the effect of overlapped operands, data is considered to be handled one eight-bit byte at a time. Special rules apply to the operands of MOVE LONG and MOVE INVERSE. See “Interlocks within a Single Instruction” on page 5-114 for how overlap is detected in the access-register mode.

---

**Binary-Integer Representation**

Binary integers are treated as signed or unsigned.

In an unsigned binary integer, all bits are used to express the absolute value of the number. When two unsigned binary integers of different lengths are added, the shorter number is considered to be extended on the left with zeros.

In some operations, the result is achieved by the use of the one’s complement of the number. The one’s complement of a number is obtained by inverting each bit of the number, including the sign.

For signed binary integers, the leftmost bit represents the sign, which is followed by the numeric field. Positive numbers are represented in true binary notation with the sign bit set to zero. When the value is zero, all bits are zeros, including the sign bit. Negative numbers are represented in two’s-complement binary notation with a one in the sign-bit position.

Specifically, a negative number is represented by the two’s complement of the positive number of the same absolute value. The two’s complement of a number is obtained by forming the one’s complement of the number, adding a value of one in the rightmost bit position, allowing a carry into the sign position, and ignoring any carry out of the sign position.

This number representation can be considered the rightmost portion of an infinitely long representation of the number. When the number is positive, all bits to the left of the most significant bit of the number are zeros. When the number is negative, these bits are ones. Therefore, when a signed operand must be extended with bits on the left, the extension is achieved by setting these bits equal to the sign bit of the operand.

The notation for signed binary integers does not include a negative zero. It has a number range in which, for a given length, the set of negative nonzero numbers is one larger than the set of positive nonzero numbers. The maximum positive number consists of a sign bit of zero followed by all ones, whereas the maximum negative number (the negative number with the greatest absolute value) consists of a sign bit of one followed by all zeros.

A signed binary integer of either sign, except for zero and the maximum negative number, can be changed to a number of the same magnitude but opposite sign by forming its two’s complement. Forming the two’s complement of a number is equivalent to subtracting the number from zero. The two’s complement of zero is zero.

The two’s complement of the maximum negative number cannot be represented in the same number of bits. When an operation, such as LOAD COMPLEMENT, attempts to produce the two’s complement of the maximum negative number, the result is the maximum negative number, and a fixed-point-overflow exception is recognized. An overflow does not result, however, when the maximum negative number is complemented as an intermediate result but the final result is within the representable range. An example of this case is a subtraction of the maximum negative number from -1. The product of two maximum negative numbers of a given length is representable as a positive number of double that length.

In discussions of signed binary integers in this publication, a signed binary integer includes the sign bit. Thus, the expression “32-bit signed binary integer” denotes an integer with 31 numeric bits and a sign bit, and the expression “64-bit signed binary integer” denotes an integer with 63 numeric bits and a sign bit.
In an arithmetic operation, a carry out of the numeric field of a signed binary integer is carried into the sign bit. However, in algebraic left-shifting, the sign bit does not change even if significant numeric bits are shifted out.

Programming Notes:

1. An alternate way of forming the two's complement of a signed binary integer is to invert all bits to the left of the rightmost one bit, leaving the rightmost one bit and all zero bits to the right of it unchanged.

2. The numeric bits of a signed binary integer may be considered to represent a positive value, with the sign representing a value of either zero or the maximum negative number.

Binary Arithmetic

Many of the instructions that perform a register-and-storage or register-and-register binary-arithmetic operation are provided in sets of three instructions corresponding to three different combinations of operand lengths. These three instructions have the same name but different operation codes and mnemonics. For example, ADD (A) operates on 32-bit operands and produces a 32-bit result, ADD (AG) operates on 64-bit operands and produces a 64-bit result, and ADD (AGF) operates on a 64-bit operand and a 32-bit operand and produces a 64-bit result. The letter “G” alone in the mnemonic indicates a completely 64-bit operation, and the letters “GF” indicate a 32-to-64-bit operation.

In a 32-to-64-bit operation, the intermediate result is 64 bits. LOAD COMPLEMENT (LCGFR) forms the two’s complement of the maximum negative 32-bit number without recognizing overflow.

Signed Binary Arithmetic

Addition and Subtraction

Addition of signed binary integers is performed by adding all bits of each operand, including the sign bits. When one of the operands is shorter, the shorter operand is considered to be extended on the left to the length of the longer operand by propagating the sign-bit value.

For a 32-bit signed binary integer in a general register, the sign bit is bit 32 of the register. For a 64-bit signed binary integer in a general register, the sign bit is bit 0 of the register.

Subtraction is performed by adding the one’s complement of the second operand and a value of one to the first operand.

Fixed-Point Overflow

A fixed-point-overflow condition exists for signed binary addition or subtraction when the carry out of the sign-bit position and the carry out of the leftmost numeric bit position disagree. Detection of an overflow does not affect the result produced by the addition. In mathematical terms, signed addition and subtraction produce a fixed-point overflow when the result is outside the range of representation for signed binary integers. Specifically, for ADD (A) and SUBTRACT (S), which operate on 32-bit signed binary integers, there is an overflow when the proper result would be greater than or equal to $+2^{31}$ or less than $-2^{31}$. The actual result placed in the general register after an overflow differs from the proper result by $2^{32}$. A fixed-point overflow causes a program interruption if allowed by the program mask. Similarly, for ADD (AG) and SUBTRACT (SG), which operate on 64-bit signed binary integers, there is an overflow when the proper result would be greater than or equal to $+2^{63}$ or less than $-2^{63}$, and the actual result placed in the general register after an overflow differs from the proper result by $2^{64}$. ADD (AGF) and SUBTRACT (SGF) have the same 64-bit result and overflow rules as ADD (AG) and SUBTRACT (SG).
The instructions SHIFT LEFT SINGLE and SHIFT LEFT DOUBLE produce an overflow when the result is outside the range of representation for signed binary integers. The actual result differs from that for addition and subtraction in that the sign of the result remains the same as the original sign.

**Unsigned Binary Arithmetic**

Addition of unsigned binary integers is performed by adding all bits of each operand. Subtraction is performed by adding the one’s complement of the second operand (the subtractor) and a value of one to the first operand (the subtrahend). In any case, when one of the operands is shorter, the shorter operand is considered to be extended on the left with zeros. During subtraction, this extension applies before an operand is complemented, and it applies to the value of one.

Unsigned binary arithmetic is used in address arithmetic for adding the X, B, and D fields. (See “Address Generation” on page 5-10.) It is also used to obtain the addresses of the function bytes in TRANSLATE and TRANSLATE AND TEST. Furthermore, unsigned binary arithmetic is used on 32-bit or 64-bit unsigned binary integers by ADD LOGICAL, ADD LOGICAL WITH CARRY, DIVIDE LOGICAL, MULTIPLY LOGICAL, SUBTRACT LOGICAL, and SUBTRACT LOGICAL WITH BORROW.

Given the same length operands, ADD (A, AG, AGF) and ADD LOGICAL (AL, ALG, ALGF) produce the same 32-bit or 64-bit result. The instructions differ only in the interpretation of this result. ADD interprets the result as a signed binary integer and inspects it for sign, magnitude, and overflow to set the condition code accordingly. ADD LOGICAL interprets the result as an unsigned binary integer and sets the condition code according to whether the result is zero and whether there was a carry out of bit position 32, for a 32-bit integer, or out of bit position 0 for a 64-bit integer. Such a carry is not considered an overflow, and no program interruption for overflow can occur for ADD LOGICAL.

SUBTRACT LOGICAL differs from ADD LOGICAL in that the one’s complement of the second operand and a value of one are added to the first operand.

For ADD LOGICAL WITH CARRY, a carry from a previous operation is represented by a one value of bit 18 of the current PSW. Bit 18 is the leftmost bit of the two-bit condition code in the PSW. For SUBTRACT LOGICAL WITH BORROW, a borrow from a previous operation is represented by a zero value of bit 18. A borrow is equivalent to the absence of a carry.

For VECTOR ADD WITH CARRY, a carry from a previous operation is represented by a one in the rightmost bit of each element of a vector register. For VECTOR SUBTRACT WITH BORROW INDICATION, an indication of borrow from a previous operation is represented by a one in the rightmost bit of each element of a vector register. The indication of borrow is equivalent to a carry. The vector integer instructions may be found in Chapter 22.

**Programming Notes:**

1. Logical addition and subtraction may be used to perform arithmetic on multiple-precision binary-integer operands. Thus, for multiple-precision addition, ADD LOGICAL can be used to add the lowest-order corresponding parts of the operands, and ADD LOGICAL WITH CARRY can be used to add the other corresponding parts of the operands, moving from right to left in the operands. If the multiple-precision operands are signed, ADD should be used on the highest-order parts. The condition code then indicates any overflow or the proper sign and magnitude of the entire result; an overflow is also indicated by a program interruption for fixed-point overflow if allowed by the program mask. When ADD is used, a value of one must be added to the sum of the highest-order parts if the condition code indicated there was a carry from the addition of the next-lower parts.

2. Another use for ADD LOGICAL is to increment values representing binary counters, which are allowed to wrap around from all ones to all zeros without indicating overflow.

**Signed and Logical Comparison**

Comparison operations determine whether two operands are equal or not and, for most operations, which of two unequal operands is the greater (high). Signed-binary-comparison operations are provided which treat the operands as signed binary integers, and logical-comparison operations are provided
which treat the operands as unsigned binary integers or as unstructured data.

COMPARE (C, CG, CGF) and COMPARE HALFWORD are signed-binary-comparison operations. These instructions are equivalent to SUBTRACT (S, SG, SGF) and SUBTRACT HALFWORD without replacing either operand, the resulting difference being used only to set the condition code. The operations permit comparison of numbers of opposite sign which differ by $2^{63}$ or more. Thus, unlike SUBTRACT, COMPARE cannot cause overflow.

Logical comparison of two operands is performed byte by byte, in a left-to-right sequence. The operands are equal when all their bytes are equal. When the operands are unequal, the comparison result is determined by a left-to-right comparison of corresponding bit positions in the first unequal pair of bytes: the zero bit in the first unequal pair of bits indicates the low operand, and the one bit the high operand. Since the remaining bit and byte positions do not change the comparison, it is not necessary to continue comparing unequal operands beyond the first unequal bit pair.

### Instructions

The general instructions and their mnemonics, formats, and operation codes are listed in Figure 7-1 on page 7-12. The figure also indicates which instructions are new in z/Architecture as compared to ESA/390, when the condition code is set, the instruction fields that designate access registers, and the exceptional conditions in operand designations, data, or results that cause a program interruption.

The instructions that are new in z/Architecture are indicated in Figure 7-1 by “N.” A few of the instructions that are new in z/Architecture have also been added to ESA/390, and these are indicated by “N3.”

When the operands of an instruction are 32-bit operands, the mnemonic for the instruction normally does not include a letter indicating the operand length; however some mnemonics for instructions with 32-bit operands contain the letter “F”. If there is an instruction with the same name but with 64-bit operands, its mnemonic includes the letter “G.” If there is an instruction with the same name but with a 64-bit first operand and a 32-bit second operand, its mnemonic includes the letters “GF.” Certain instruction mnemonics indicate the length of the first and second operands with combinations of G (64-bit), F (32-bit), or H (16-bit), although the F is usually omitted for the first operand.

In Figure 7-1, when there is an instruction with 32-bit operands and other instructions with the same name but with “G” or “GF” added in their mnemonics, the first instruction has “(32)” after its name, and the other instructions have “(64)” or “(64-32),” respectively, after their names. Some 32-bit operand-length instructions do not have 64-bit operand-length counterparts, and they do not have “(32)” after their names. However, all instructions for multiplication or division are marked to show, or approximately show, operand lengths.

A detailed definition of instruction formats, operand designation and length, and address generation is contained in “Instructions” on page 5-3. Exceptions to the general rules stated in that section are explicitly identified in the individual instruction descriptions.

**Note:** In the detailed descriptions of the individual instructions, the mnemonic and the symbolic operand designations for the assembler language are shown with each instruction. For LOAD AND TEST with 32-bit operands, for example, LTR is the mnemonic and R1,R2 the operand designation.

Certain fields of various instructions are considered to be optional, as indicated by the field being contained within brackets [ ] in the assembler syntax. When an optional field is not specified, the assembler places zeros in that field of the instruction.

### Programming Notes:

1. Trimodal addressing affects the general instructions only in the manner in which logical storage addresses are handled, except as follows.

   The instructions BRANCH AND LINK (BAL, BALR), BRANCH AND SAVE (BAS, BASR), BRANCH AND SAVE AND SET MODE, BRANCH AND SET MODE, BRANCH RELATIVE AND SAVE, and BRANCH RELATIVE AND SAVE LONG place information in bit positions 32-39 of general register R, as in ESA/390 in the 24-bit or 31-bit addressing mode or place address bits in those bit positions in the 64-bit addressing mode.
The instruction BRANCH AND SAVE AND SET MODE places a zero in bit position 63 of general register R1 in the 24-bit or 31-bit addressing mode or places a one in that bit position in the 64-bit addressing mode.

The instruction BRANCH AND SET MODE leaves the contents of bit position 63 of general register R1 unchanged in the 24-bit or 31-bit addressing mode or places a one in that bit position in the 64-bit addressing mode.

The following instructions leave bits 0-31 of a general register unchanged in the 24-bit or 31-bit addressing mode but place or update address or length information in them in the 64-bit addressing mode. Also, the leftmost byte of the results in registers may be handled differently depending on whether the addressing mode is the 24-bit or the 31-bit mode.

- BRANCH AND LINK (BAL, BALR)
- BRANCH AND SAVE (BAS, BASR)
- BRANCH AND SAVE AND SET MODE
- BRANCH RELATIVE AND SAVE
- BRANCH RELATIVE AND SAVE LONG
- CHECKSUM
- COMPARE AND FORM CODEWORD
- COMPARE LOGICAL LONG
- COMPARE LOGICAL LONG EXTENDED
- COMPARE LOGICAL LONG UNICODE
- COMPARE LOGICAL STRING
- COMPARE UNTIL SUBSTRING EQUAL
- COMPRESSION CALL
- CONVERT UTF-16 TO UTF-32
- CONVERT UTF-16 TO UTF-8
- CONVERT UTF-32 TO UTF-16
- CONVERT UTF-32 TO UTF-8
- CONVERT UTF-8 TO UTF-16
- CONVERT UTF-8 TO UTF-32
- LOAD ADDRESS
- LOAD ADDRESS EXTENDED
- LOAD ADDRESS RELATIVE LONG
- MOVE LONG
- MOVE LONG EXTENDED
- MOVE LONG UNICODE
- MOVE STRING
- SEARCH STRING
- TRANSLATE EXTENDED
- TRANSLATE AND TEST
- TRANSLATE AND TEST EXTENDED
- TRANSLATE AND TEST REVERSE
- TRANSLATE AND TEST REVERSE EXTENDED
- TRANSLATE ONE TO ONE
- TRANSLATE TWO TO ONE
- TRANSLATE TWO TO TWO
- UPDATE TREE

The instructions in the preceding list are sometimes called modal instructions.

2. Bits 0-31 of general registers are changed by two types of instructions. The first type is a modal instruction, as listed in the preceding note, when the instruction is executed in the 64-bit addressing mode. The second type is an instruction having, independent of the addressing mode, either a 64-bit result operand in a single general register or a 128-bit result operand in an even-odd general-register pair.

Most of the instructions of the second type are indicated by a “G,” either alone or in “GF,” in their mnemonics. The other instructions that change or may change bits 0-31 of a general register regardless of the current addressing mode are:

- AND IMMEDIATE (NIHF, NIHH, NIHL only)
- EXCLUSIVE OR IMMEDIATE (XIHF only)
- INSERT CHARACTERS UNDER MASK (ICMH only)
- INSERT IMMEDIATE (IIHF, IIHH, IIHL only)
- LOAD LOGICAL IMMEDIATE (LLIHF, LLIHH, LLIHL only)
- LOAD MULTIPLE DISJOINT
- LOAD MULTIPLE HIGH
- LOAD PAIR FROM QUADWORD
- OR IMMEDIATE (OIHF, OIHH, OIHL only)

All of the instructions of the second type are sometimes referred to as “G-type” instructions.

If a program is not executed in the 64-bit addressing mode and does not contain a G-type instruction, it cannot change bits 0-31 of any general register.

3. It is not intended or expected that old programs not containing G-type instructions will be able to be executed successfully in the 64-bit addressing mode. However, this may be possible, particularly if, by programming convention, bits 0-31 of the general registers are always all zeros when an old program is given control.

4. The following additional general instructions are available when the extended-translation facility is installed:

- COMPARE LOGICAL LONG UNICODE
5. The long-displacement facility uses new instruction formats, named RSY, RXY, and SIY, to provide 20-bit signed displacements. In connection with the long-displacement facility, all previously existing general instructions of the RSE or RXE format are changed to be of format RSY or RXY, respectively, where the new formats differ from the old by using a previously unused byte, now named DH, in the instructions. When the long-displacement facility is installed, the displacement for an instruction operand address is formed by appending DH on the left of the previous displacement field, now named DL, of the instruction. When the long-displacement facility is not installed, eight zero bits are appended on the left of DL, and DH is ignored.

The following additional general instruction is available when the long-displacement facility is installed.

- **LOAD BYTE**

The following additional RSY-format versions of general instructions are available when the long-displacement facility is installed.

- **COMPARE AND SWAP**
- **COMPARE DOUBLE AND SWAP**
- **COMPARE LOGICAL CHARACTERS UNDER MASK**
- **LOAD ACCESS MULTIPLE**
- **LOAD MULTIPLE**
- **STORE ACCESS MULTIPLE**
- **STORE CHARACTERS UNDER MASK**
- **STORE MULTIPLE**

The following additional RXY-format versions of general instructions are available when the long-displacement facility is installed.

- **ADD**
- **ADD HALFWORD**
- **ADD LOGICAL**
- **AND**
- **COMPARE**
- **COMPARE HALFWORD**
- **COMPARE LOGICAL**
- **CONVERT TO BINARY**
- **CONVERT TO DECIMAL**
- **EXCLUSIVE OR**
- **INSERT CHARACTER**
- **INSERT CHARACTER UNDER MASK**
- **LOAD**
- **LOAD ADDRESS**
- **LOAD HALFWORD**
- **MULTIPLY SINGLE**
- **OR**
- **STORE**
- **STORE CHARACTER**
- **STORE HALFWORD**
- **SUBTRACT**
- **SUBTRACT HALFWORD**
- **SUBTRACT LOGICAL**

The following additional SIY-format versions of general instructions are available when the long-displacement facility is installed.

- **AND**
- **COMPARE LOGICAL**
- **EXCLUSIVE OR**
- **MOVE**
- **OR**
- **TEST UNDER MASK**

6. The following additional general instructions are available when the message-security assist is installed:

- **CIPHER MESSAGE**
- **CIPHER MESSAGE WITH CHAINING**
- **COMPUTE INTERMEDIATE MESSAGE DIGEST**
- **COMPUTE LAST MESSAGE DIGEST**
- **COMPUTE MESSAGE AUTHENTICATION CODE**

7. The following additional general instructions are available when the extended-translation facility is installed:

- **CONVERT UTF-16 TO UTF-32**
- **CONVERT UTF-32 TO UTF-16**
- **CONVERT UTF-32 TO UTF-8**
- **CONVERT UTF-8 TO UTF-32**
- **SEARCH STRING UNICODE**
- **TRANSFORM AND TEST REVERSE**

Additionally, **CONVERT UNICODE TO UTF-8** (CUUTF) and **CONVERT UTF-8 TO UNICODE** (CUTFU) are renamed to **CONVERT UTF-16 TO**
UTF-8 (CU21) and CONVERT UTF-8 TO UTF-16 (CU12), respectively, in order to conform to the names used by this facility. The old names continue to be recognized.

8. The following additional general instructions are available when the extended-immediate facility is installed:

- ADD IMMEDIATE (AFI, AGFI)
- ADD LOGICAL IMMEDIATE (ALFI, ALGFI)
- AND IMMEDIATE (NIHF, NILF)
- COMPARE IMMEDIATE (CFI, CGFI)
- COMPARE LOGICAL IMMEDIATE (CLFI, CLGFI)
- EXCLUSIVE OR IMMEDIATE (XIHF, XILF)
- FIND LEFTMOST ONE (FLOGR)
- INSERT IMMEDIATE (IIHF, IILF)
- LOAD AND TEST (LT, LGT)
- LOAD BYTE (LBR, LGBR)
- LOAD HALFWORD (LHR, LGHR)
- LOAD IMMEDIATE (LLGFI)
- LOAD LOGICAL CHARACTER (LLC, LLCR, LLGCR)
- LOAD LOGICAL HALFWORD (LLGHR, LLH, LLHR)
- LOAD LOGICAL IMMEDIATE (LLIH, LLILF)
- OR IMMEDIATE (OIH, OILF)
- SUBTRACT LOGICAL IMMEDIATE (SLFI, SLGFI)

The instructions that are part of the extended-immediate facility are indicated in Figure 7-1 by “EI.”

9. The STORE CLOCK FAST general instruction is available when the store-clock-fast facility is installed.

10. The STORE FACILITY LIST EXTENDED general instruction is available when the store-facility-list-extended facility is installed.

11. When the ETF2-enhancement facility is installed, new functions are provided for the TRANSLATE ONE TO ONE, TRANSLATE ONE TO TWO, TRANSLATE TWO TO ONE, and TRANSLATE TWO TO TWO instructions.

12. When the ETF3-enhancement facility is installed, improved well-formedness checking is provided for the CONVERT UTF-16 TO UTF-32, CONVERT UTF-16 TO UTF-8, CONVERT UTF-8 TO UTF-16, and CONVERT UTF-8 TO UTF-32 instructions.

13. The COMPARE AND SWAP AND STORE general instruction is available if the compare-and-swap-and-store facility is installed.

14. The EXTRACT CPU TIME general instruction is available if the extract-CPU-time facility is installed.

15. The following additional general instructions are available when the parsing-enhancement facility is installed:

- TRANSLATE AND TEST EXTENDED
- TRANSLATE AND TEST REVERSE EXTENDED

16. The EXECUTE RELATIVE LONG general instruction is available when the execute-extension facility is installed.

17. The following additional general instructions are available when the general-instructions-extension facility is installed:

- ADD IMMEDIATE (AGSI, ASI)
- ADD LOGICAL WITH SIGNED IMMEDIATE (ALGSI, ALSI)
- COMPARE AND BRANCH (CGRB, CRB)
- COMPARE AND BRANCH RELATIVE (CGRJ, CRJ)
- COMPARE AND TRAP (CGRT, CRT)
- COMPARE HALFWORD (CGH)
- COMPARE HALFWORD IMMEDIATE (CGHSI, CHHSI, CHSI)
- COMPARE HALFWORD RELATIVE LONG (CGHRL, CHRL)
- COMPARE IMMEDIATE AND BRANCH (CGB, CIB)
- COMPARE IMMEDIATE AND BRANCH RELATIVE (CGJ, CJ)
- COMPARE IMMEDIATE AND TRAP (CIT, CGIT)
- COMPARE LOGICAL AND BRANCH (CLGRB, CLRB)
- COMPARE LOGICAL AND BRANCH RELATIVE (CLGRJ, CLRJ)
- COMPARE LOGICAL AND TRAP (CLGRT, CLRT)
- COMPARE LOGICAL IMMEDIATE (CLFHSI, CLGHSI, CLHHSI)
- COMPARE LOGICAL IMMEDIATE AND BRANCH (CLIB, CLGIB)
- COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (CLGIJ, CLIJ)
- COMPARE LOGICAL IMMEDIATE AND TRAP (CLFIT, CLGIT)
- COMPARE LOGICAL RELATIVE LONG (CLGFRL, CLGHRL, CLGRL, CLHRL, CLRL)
- COMPARE RELATIVE LONG (CGFRL, CGRL, CRL)
- EXTRACT CPU ATTRIBUTE (ECAG)
- LOAD ADDRESS EXTENDED (LAEY)
- LOAD AND TEST (LTGF)
- LOAD HALFWORD RELATIVE LONG (LGHRL, LHRL)
- LOAD LOGICAL HALFWORD RELATIVE LONG (LLGHRL, LLHRL)
- LOAD LOGICAL RELATIVE LONG (LLGFRL)
- LOAD RELATIVE LONG (LGFRL, LGRL, LRL)
- MOVE (MVHI, MVGHI, MVHHI)
- MULTIPLY (MFY)
- MULTIPLY HALFWORD (MHY)
- MULTIPLY SINGLE IMMEDIATE (MSFI, MSGFI)
- PREFETCH DATA (PFD)
- PREFETCH DATA RELATIVE LONG (PFDRL)
- ROTATE THEN AND SELECTED BITS (RNSBG)
- ROTATE THEN EXCLUSIVE OR SELECTED BITS (RXSBG)
- ROTATE THEN INSERT SELECTED BITS (RISBG)
- STORE HALFWORD RELATIVE LONG (STHRL)
- STORE RELATIVE LONG (STGRL, STRL)

18. The following additional general instructions are available when the high-word facility is installed:
- ADD HIGH (AHHHR, AHHLR)
- ADD IMMEDIATE HIGH (AIH)
- ADD LOGICAL HIGH (ALHHHR, ALHHLR)
- ADD LOGICAL WITH SIGNED IMMEDIATE HIGH (ALSIH, ALSIHN)
- BRANCH RELATIVE ON COUNT HIGH (BRCTH)
- COMPARE HIGH (CHHR, CHLR, CHF)
- COMPARE IMMEDIATE HIGH (CIH)
- COMPARE LOGICAL HIGH (CLHHHR, CLHLR, CLHFL)

19. The following additional general instructions are available when the interlocked-access instructions facility 1 is installed:
- ADD AND ADD (LAA, LAAG)
- ADD AND ADD LOGICAL (LAAL, LAALG)
- ADD AND AND (LAN, LANG)
- ADD AND EXCLUSIVE OR (LAX, LAXG)
- ADD AND OR (LAO, LAOG)
- ADD PAIR DISJOINT (LPD, LPDG)

20. The following additional general instructions are available when the load/store-on-condition facility is installed:
- LOAD ON CONDITION (LOC, LOCG, LOCGR, LOCRL)
- STORE ON CONDITION (STOC, STOCG)

21. The following additional general instructions are available when the distinct-operands facility is installed:
- ADD (ARK, AGRK)
- ADD IMMEDIATE (AHIK, AHIK)
- ADD LOGICAL (ALRK, ALGRK)
- ADD LOGICAL WITH SIGNED IMMEDIATE (ALHSIK, ALGHSIK)
- AND (NRK, NGRK)
- EXCLUSIVE OR (XRK, XGRK)
- OR (ORK, OGRK)
- SHIFT LEFT SINGLE (SLAK)
- SHIFT LEFT SINGLE LOGICAL (SLLK)
- SHIFT RIGHT SINGLE (SRAK)
- SHIFT RIGHT SINGLE LOGICAL (SRLK)
- SUBTRACT (SRK, SGRK)
- SUBTRACT LOGICAL (SLRK, SLGRK)
22. The POPULATION COUNT general instruction is available when the population-count facility is installed.

23. The following additional general instructions are available when the message-security-assist extension 4 is installed:
   - CIPHER MESSAGE WITH CIPHER FEEDBACK
   - CIPHER MESSAGE WITH COUNTER
   - CIPHER MESSAGE WITH OUTPUT FEEDBACK
   - PERFORM CRYPTOGRAPHIC COMPUTATION

24. The following additional general instructions are available when the execution-hint facility is installed:
   - BRANCH PREDICTION PRELOAD (BPP)
   - BRANCH PREDICTION RELATIVE PRELOAD (BPRP)
   - NEXT INSTRUCTION ACCESS INTENT (NIAI)

25. The following additional general instructions are available when the load-and-trap facility is installed:
   - LOAD AND TRAP (LAT and LGAT)
   - LOAD HIGH AND TRAP (LFHAT)
   - LOAD LOGICAL AND TRAP (LLGFAT)
   - LOAD LOGICAL THIRTY ONE BITS AND TRAP (LLGTAT)

26. The following additional general instructions are available when the miscellaneous-instruction-extensions facility is installed:
   - COMPARE LOGICAL AND TRAP (CLT, CLGT)
   - ROTATE THEN INSERT SELECTED BITS (RISBGN)

27. The following additional general instructions are available when the load-and-zero-rightmost-byte facility is installed:
   - LOAD AND ZERO RIGHTMOST BYTE (LZRF, LZRG)
   - LOAD LOGICAL AND ZERO RIGHTMOST BYTE (LLZRGF)

28. The following additional general instructions are available when the load/store-on-condition facility 2 is installed:
   - LOAD HALFWORD HIGH IMMEDIATE ON CONDITION (LOCHHI)
   - LOAD HALFWORD IMMEDIATE ON CONDITION (LOCHI, LOCACHI)
   - LOAD HIGH ON CONDITION (LOCFH, LOCFHR)
   - STORE HIGH ON CONDITION (STOCFH)

29. The PERFORM PSEUDORANDOM NUMBER OPERATION general instruction is available when the message-security-assist extension 5 is installed:

30. The LOAD COUNT TO BLOCK BOUNDARY general instruction is available when the vector facility for z/Architecture is installed. Other instructions of the vector facility for z/Architecture are described in Chapters 21-24.

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD (32)</td>
<td>A</td>
<td>RX-a C</td>
<td>A</td>
<td>B</td>
</tr>
<tr>
<td>ADD (32)</td>
<td>AR</td>
<td>RR C</td>
<td>IF</td>
<td>1</td>
</tr>
<tr>
<td>ADD (32)</td>
<td>ARK</td>
<td>RRF-a C DO</td>
<td>IF</td>
<td>B9F8</td>
</tr>
<tr>
<td>ADD (32)</td>
<td>AY</td>
<td>RXY-a C LD</td>
<td>A</td>
<td>B</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AG</td>
<td>RXY-a C N</td>
<td>A</td>
<td>E3A5</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AGR</td>
<td>RRF-a C DO</td>
<td>IF</td>
<td>B9F8</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AGF</td>
<td>RXY-a C N</td>
<td>A</td>
<td>B</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AGFR</td>
<td>RXY-a C N</td>
<td>IF</td>
<td>B9F8</td>
</tr>
<tr>
<td>ADD HALFWORD (32→16)</td>
<td>AH</td>
<td>RX-a C</td>
<td>A</td>
<td>B</td>
</tr>
<tr>
<td>ADD HALFWORD (32→16)</td>
<td>AHY</td>
<td>RXY-a C LD</td>
<td>A</td>
<td>E37A</td>
</tr>
<tr>
<td>ADD HALFWORD IMMEDIATE (32→16)</td>
<td>AHI</td>
<td>Ri-a C</td>
<td>IF</td>
<td>A</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 1 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD HALFWORD IMMEDIATE (64&lt;–16)</td>
<td>AHGI</td>
<td>Ri-a C N</td>
<td>IF</td>
<td>A7B</td>
</tr>
<tr>
<td>ADD HIGH (32)</td>
<td>AHHHR</td>
<td>RRF-a C HW</td>
<td>IF</td>
<td>B9C8</td>
</tr>
<tr>
<td>ADD HIGH (32)</td>
<td>AHHLR</td>
<td>RRF-a C HW</td>
<td>IF</td>
<td>B9D8</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AFI</td>
<td>Ri-a C Ei</td>
<td>IF</td>
<td>C29</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32&lt;–16)</td>
<td>AHIK</td>
<td>RIE-d C DO</td>
<td>IF</td>
<td>ECD8</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32&lt;–8)</td>
<td>ASI</td>
<td>SIy C GE A</td>
<td>IF £1</td>
<td>EB6A</td>
</tr>
<tr>
<td>ADD IMMEDIATE (64&lt;–16)</td>
<td>AGHIK</td>
<td>RIE-d C DO</td>
<td>IF</td>
<td>ECD9</td>
</tr>
<tr>
<td>ADD IMMEDIATE (64&lt;–32)</td>
<td>AGFI</td>
<td>Ri-a C Ei</td>
<td>IF</td>
<td>C28</td>
</tr>
<tr>
<td>ADD IMMEDIATE (64&lt;–8)</td>
<td>AGSI</td>
<td>SIy C GE A</td>
<td>IF £1</td>
<td>EB7A</td>
</tr>
<tr>
<td>ADD IMMEDIATE HIGH (32)</td>
<td>AHI</td>
<td>Ri-a C HW</td>
<td>IF</td>
<td>CC8</td>
</tr>
<tr>
<td>ADD LOGICAL (32)</td>
<td>AL</td>
<td>RX-a C A</td>
<td>B2</td>
<td>B9A</td>
</tr>
<tr>
<td>ADD LOGICAL (32)</td>
<td>ALR</td>
<td>RR C</td>
<td></td>
<td>B9E</td>
</tr>
<tr>
<td>ADD LOGICAL (32)</td>
<td>ALRK</td>
<td>RRF-a C DO</td>
<td></td>
<td>B9FA</td>
</tr>
<tr>
<td>ADD LOGICAL (32)</td>
<td>ALY</td>
<td>RXY-a C LD A</td>
<td>B2</td>
<td>E35E</td>
</tr>
<tr>
<td>ADD LOGICAL (64)</td>
<td>ALG</td>
<td>RXY-a C N A</td>
<td>B2</td>
<td>E30A</td>
</tr>
<tr>
<td>ADD LOGICAL (64)</td>
<td>ALGR</td>
<td>RRE C N</td>
<td></td>
<td>B9A</td>
</tr>
<tr>
<td>ADD LOGICAL (64)</td>
<td>ALGRK</td>
<td>RRF-a C DO</td>
<td></td>
<td>B9EA</td>
</tr>
<tr>
<td>ADD LOGICAL (64&lt;–32)</td>
<td>ALGF</td>
<td>RXY-a C N A</td>
<td>B2</td>
<td>E31A</td>
</tr>
<tr>
<td>ADD LOGICAL (64&lt;–32)</td>
<td>ALGFR</td>
<td>RRE C N</td>
<td>B9A</td>
<td>B9A</td>
</tr>
<tr>
<td>ADD LOGICAL (64)</td>
<td>ALHHR</td>
<td>RRF-a C HW</td>
<td></td>
<td>B9A</td>
</tr>
<tr>
<td>ADD LOGICAL (64)</td>
<td>ALHHLR</td>
<td>RRF-a C HW</td>
<td></td>
<td>B9A</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE (32)</td>
<td>ALFI</td>
<td>Ri-a C Ei</td>
<td>C2B</td>
<td>C2B</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE (64&lt;–32)</td>
<td>ALGFI</td>
<td>Ri-a C Ei</td>
<td>C2A</td>
<td>C2A</td>
</tr>
<tr>
<td>ADD LOGICAL WITH CARRY (32)</td>
<td>ALC</td>
<td>RXY-a C N3 A</td>
<td>B2</td>
<td>E398</td>
</tr>
<tr>
<td>ADD LOGICAL WITH CARRY (32)</td>
<td>ALCR</td>
<td>RRE C N3 A</td>
<td>B2</td>
<td>B988</td>
</tr>
<tr>
<td>ADD LOGICAL WITH CARRY (64)</td>
<td>ALCG</td>
<td>RXY-a C N A</td>
<td>B2</td>
<td>E388</td>
</tr>
<tr>
<td>ADD LOGICAL WITH CARRY (64)</td>
<td>ALGR</td>
<td>RRE C N</td>
<td>B9A</td>
<td>B9A</td>
</tr>
<tr>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (32&lt;–16)</td>
<td>ALHSIK</td>
<td>RIE-d C DO</td>
<td></td>
<td>ECOA</td>
</tr>
<tr>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (32&lt;–8)</td>
<td>ALSI</td>
<td>SIy C GE A</td>
<td>£1</td>
<td>EB9E</td>
</tr>
<tr>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (64&lt;–16)</td>
<td>ALGHSIK</td>
<td>RIE-d C DO</td>
<td>£1</td>
<td>ECD8</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE (64&lt;–8)</td>
<td>ALGSI</td>
<td>SIy C GE A</td>
<td>£1</td>
<td>EB7E</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE HIGH (32)</td>
<td>ALSIH</td>
<td>RI-a C HW</td>
<td></td>
<td>CCA</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE IMMEDIATE (32)</td>
<td>ALSIHN</td>
<td>RI-a C HW</td>
<td></td>
<td>CCB</td>
</tr>
<tr>
<td>AND (32)</td>
<td>N</td>
<td>RX-a C A</td>
<td>B2</td>
<td>54</td>
</tr>
<tr>
<td>AND (32)</td>
<td>NR</td>
<td>RR C</td>
<td>14</td>
<td>54</td>
</tr>
<tr>
<td>AND (32)</td>
<td>NRK</td>
<td>RRF-a C DO</td>
<td>B2</td>
<td>54</td>
</tr>
<tr>
<td>AND (32)</td>
<td>NY</td>
<td>RXY-a C LD A</td>
<td>B2</td>
<td>54</td>
</tr>
<tr>
<td>AND (64)</td>
<td>NG</td>
<td>RXY-a C N A</td>
<td>B2</td>
<td>54</td>
</tr>
<tr>
<td>AND (64)</td>
<td>NGR</td>
<td>RRE C N</td>
<td>B980</td>
<td>54</td>
</tr>
<tr>
<td>AND (64)</td>
<td>NGRK</td>
<td>RRF-a C DO</td>
<td>B9E4</td>
<td>54</td>
</tr>
<tr>
<td>AND (character)</td>
<td>NC</td>
<td>Ss-a C £3 A</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>AND (immediate)</td>
<td>NI</td>
<td>SI C A £3 £3</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>AND (immediate)</td>
<td>NIY</td>
<td>SIy C LD A £3 £3</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>AND IMMEDIATE (high high)</td>
<td>NIHH</td>
<td>Ri-a C N</td>
<td>A54</td>
<td>7-33</td>
</tr>
<tr>
<td>AND IMMEDIATE (high low)</td>
<td>NIHL</td>
<td>Ri-a C N</td>
<td>A55</td>
<td>7-33</td>
</tr>
<tr>
<td>AND IMMEDIATE (high)</td>
<td>NIHF</td>
<td>Ri-a C Ei</td>
<td>C0A</td>
<td>7-33</td>
</tr>
<tr>
<td>AND IMMEDIATE (low high)</td>
<td>NILH</td>
<td>Ri-a C N</td>
<td>A56</td>
<td>7-34</td>
</tr>
<tr>
<td>AND IMMEDIATE (low low)</td>
<td>NILL</td>
<td>Ri-a C N</td>
<td>A57</td>
<td>7-34</td>
</tr>
<tr>
<td>BRANCH AND LINK</td>
<td>BAL</td>
<td>RX-a £3 £3 B</td>
<td>45</td>
<td>7-34</td>
</tr>
<tr>
<td>BRANCH AND LINK</td>
<td>BALR</td>
<td>RR £2 £3 T B</td>
<td>05</td>
<td>7-34</td>
</tr>
<tr>
<td>BRANCH AND SAVE</td>
<td>BAS</td>
<td>RX-a £3 T B</td>
<td>4D</td>
<td>7-35</td>
</tr>
<tr>
<td>BRANCH AND SAVE</td>
<td>BASR</td>
<td>RR £2 £3 T B</td>
<td>0D</td>
<td>7-35</td>
</tr>
<tr>
<td>BRANCH AND SAVE AND SET MODE</td>
<td>BASSM</td>
<td>RR £2 £3 T B</td>
<td>0C</td>
<td>7-36</td>
</tr>
<tr>
<td>BRANCH AND SET MODE</td>
<td>BSM</td>
<td>RR £3 £3 T B</td>
<td>0B</td>
<td>7-37</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 2 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-</th>
<th>Page</th>
<th>Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>BRANCH ON CONDITION</td>
<td>BC</td>
<td>RX-b</td>
<td>5</td>
<td>47</td>
<td></td>
<td>7-37</td>
</tr>
<tr>
<td>BRANCH ON CONDITION</td>
<td>BCR</td>
<td>RR</td>
<td>7</td>
<td>46</td>
<td></td>
<td>7-38</td>
</tr>
<tr>
<td>BRANCH ON COUNT (32)</td>
<td>BCT</td>
<td>RX-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BRANCH ON COUNT (32)</td>
<td>BC TR</td>
<td>RR</td>
<td></td>
<td>06</td>
<td></td>
<td>7-38</td>
</tr>
<tr>
<td>BRANCH ON COUNT (64)</td>
<td>BCTG</td>
<td>RXY-a</td>
<td></td>
<td>E346</td>
<td></td>
<td>7-38</td>
</tr>
<tr>
<td>BRANCH ON COUNT (64)</td>
<td>BCTGR</td>
<td>RRE</td>
<td></td>
<td>B946</td>
<td></td>
<td>7-38</td>
</tr>
<tr>
<td>BRANCH ON INDEX HIGH (32)</td>
<td>BXH</td>
<td>RS-a</td>
<td></td>
<td>86</td>
<td></td>
<td>7-39</td>
</tr>
<tr>
<td>BRANCH ON INDEX HIGH (64)</td>
<td>BXHG</td>
<td>RSY-a</td>
<td></td>
<td>EB44</td>
<td></td>
<td>7-39</td>
</tr>
<tr>
<td>BRANCH ON INDEX LOW OR EQUAL (32)</td>
<td>BXLE</td>
<td>RS-a</td>
<td></td>
<td>87</td>
<td></td>
<td>7-39</td>
</tr>
<tr>
<td>BRANCH ON INDEX LOW OR EQUAL (64)</td>
<td>BXLEG</td>
<td>RSY-a</td>
<td></td>
<td>EB45</td>
<td></td>
<td>7-39</td>
</tr>
<tr>
<td>BRANCH PREDICTION PRELOAD</td>
<td>BPP</td>
<td>SMI</td>
<td></td>
<td>C7</td>
<td></td>
<td>7-40</td>
</tr>
<tr>
<td>BRANCH PREDICTION RELATIVE PRELOAD</td>
<td>BPRP</td>
<td>MILL</td>
<td></td>
<td>C5</td>
<td></td>
<td>7-40</td>
</tr>
<tr>
<td>BRANCH RELATIVE AND SAVE</td>
<td>BRAS</td>
<td>Ri-b</td>
<td></td>
<td>A75</td>
<td></td>
<td>7-43</td>
</tr>
<tr>
<td>BRANCH RELATIVE AND SAVE LONG</td>
<td>BRASL</td>
<td>RiL-b</td>
<td></td>
<td>C05</td>
<td></td>
<td>7-43</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON CONDITION</td>
<td>BRC</td>
<td>Ri-c</td>
<td></td>
<td>A74</td>
<td></td>
<td>7-44</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON CONDITION LONG</td>
<td>BRCL</td>
<td>RiL-c</td>
<td></td>
<td>A76</td>
<td></td>
<td>7-45</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON COUNT (32)</td>
<td>BRCT</td>
<td>Ri-b</td>
<td></td>
<td>A76</td>
<td></td>
<td>7-45</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON COUNT (64)</td>
<td>BRCTG</td>
<td>Ri-b</td>
<td></td>
<td>A77</td>
<td></td>
<td>7-45</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON COUNT HIGH (32)</td>
<td>BRCTH</td>
<td>RiL-b</td>
<td></td>
<td>C06</td>
<td></td>
<td>7-45</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON INDEX HIGH (32)</td>
<td>BRXH</td>
<td>RSI</td>
<td></td>
<td>84</td>
<td></td>
<td>7-45</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON INDEX HIGH (64)</td>
<td>BRXHG</td>
<td>RIE-e</td>
<td></td>
<td>EC44</td>
<td></td>
<td>7-46</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON INDEX LOW OR EO. (32)</td>
<td>BRXLE</td>
<td>RSI</td>
<td></td>
<td>85</td>
<td></td>
<td>7-46</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON INDEX LOW OR EO. (64)</td>
<td>BRXLEG</td>
<td>RIE-e</td>
<td></td>
<td>EC45</td>
<td></td>
<td>7-46</td>
</tr>
<tr>
<td>CHECKSUM</td>
<td>CKSM</td>
<td>RRE</td>
<td></td>
<td>R9</td>
<td></td>
<td>7-47</td>
</tr>
<tr>
<td>CIPHER MESSAGE</td>
<td>KM</td>
<td>RRE</td>
<td></td>
<td>R9</td>
<td></td>
<td>7-50</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH CHAINING</td>
<td>KMC</td>
<td>RRE</td>
<td></td>
<td>R9</td>
<td></td>
<td>7-50</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH CIPHER FEEDBACK</td>
<td>KMF</td>
<td>RRE</td>
<td></td>
<td>R9</td>
<td></td>
<td>7-50</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH COUNTER</td>
<td>KMCTR</td>
<td>RRF</td>
<td></td>
<td>R9</td>
<td></td>
<td>7-50</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH OUTPUT FEEDBACK</td>
<td>KMO</td>
<td>RRE</td>
<td></td>
<td>R9</td>
<td></td>
<td>7-50</td>
</tr>
<tr>
<td>COMPARE (32)</td>
<td>C</td>
<td>RX-a</td>
<td></td>
<td>B928</td>
<td></td>
<td>7-103</td>
</tr>
<tr>
<td>COMPARE (32)</td>
<td>CR</td>
<td>RR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE (32)</td>
<td>CY</td>
<td>RXY-a</td>
<td></td>
<td>B922</td>
<td></td>
<td>7-103</td>
</tr>
<tr>
<td>COMPARE (64)</td>
<td>CG</td>
<td>RXY-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE (64)</td>
<td>CGR</td>
<td>RRE</td>
<td></td>
<td>B920</td>
<td></td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE (64)</td>
<td>CGF</td>
<td>RXY-a</td>
<td></td>
<td>B930</td>
<td></td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE AND BRANCH (32)</td>
<td>CRB</td>
<td>RRS</td>
<td></td>
<td>E359</td>
<td></td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE AND BRANCH (64)</td>
<td>CGRB</td>
<td>RRS</td>
<td></td>
<td>E320</td>
<td></td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE AND BRANCH RELATIVE (32)</td>
<td>CRJ</td>
<td>RIE-b</td>
<td></td>
<td>B928</td>
<td></td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE AND BRANCH RELATIVE (64)</td>
<td>CRJG</td>
<td>RIE-b</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE AND FORM CODEWORD</td>
<td>CFC</td>
<td>S</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE AND SWAP (32)</td>
<td>CS</td>
<td>RS-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE AND SWAP (32)</td>
<td>CSG</td>
<td>RSY-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE AND SWAP AND STORE</td>
<td>CSST</td>
<td>SSF</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE AND TRAP (32)</td>
<td>CRT</td>
<td>RRF-c</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE AND TRAP (64)</td>
<td>CGRT</td>
<td>RRF-c</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE DOUBLE AND SWAP (32)</td>
<td>CDS</td>
<td>RS-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE DOUBLE AND SWAP (64)</td>
<td>CDSY</td>
<td>RSY-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE DOUBLE AND SWAP AND STORE</td>
<td>CDSG</td>
<td>RSY-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HALFWORD (32−16)</td>
<td>CH</td>
<td>RX-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HALFWORD (32−16)</td>
<td>CHY</td>
<td>RXY-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HALFWORD (64−16)</td>
<td>CGH</td>
<td>RXY-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (16−16)</td>
<td>CHHISI</td>
<td>SIL</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (32−16)</td>
<td>CHI</td>
<td>Ri-a</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 3 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (32→16)</td>
<td>CHSI</td>
<td>SIL C GE A</td>
<td>B₁</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (64→16)</td>
<td>CPHI</td>
<td>RI-a C N</td>
<td>A</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (64→16)</td>
<td>CGHSI</td>
<td>SIL C GE A</td>
<td>B₁</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD RELATIVE LONG (32→16)</td>
<td>CHRL</td>
<td>RIL-b C GE A*</td>
<td>B₁</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD RELATIVE LONG (64→16)</td>
<td>CGHRRL</td>
<td>RIL-b C GE A*</td>
<td>B₁</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HIGH (32)</td>
<td>CHF</td>
<td>RXY-a C HW A</td>
<td>B₁</td>
<td>7-134</td>
</tr>
<tr>
<td>COMPARE HIGH (32)</td>
<td>CHHR</td>
<td>RRE C HW</td>
<td>B₁</td>
<td>7-134</td>
</tr>
<tr>
<td>COMPARE HIGH (32)</td>
<td>CHLR</td>
<td>RRE C HW</td>
<td>B₁</td>
<td>7-134</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE (32)</td>
<td>CFI</td>
<td>RIL-a C EI</td>
<td>B₁</td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE (64→32)</td>
<td>CGFI</td>
<td>RIL-a C EI</td>
<td>B₁</td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND BRANCH (32→8)</td>
<td>CIB</td>
<td>RIIS GE</td>
<td>B</td>
<td>7-119</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND BRANCH (64→8)</td>
<td>CGIB</td>
<td>RIIS GE</td>
<td>B</td>
<td>7-119</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (32→8)</td>
<td>CIJ</td>
<td>RIIE-c GE</td>
<td>B</td>
<td>7-119</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (64→8)</td>
<td>CGIJ</td>
<td>RIIE-c GE</td>
<td>B</td>
<td>7-119</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND TRAP (32→16)</td>
<td>CIT</td>
<td>RIIE-a GE Dc</td>
<td>E</td>
<td>7-132</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND TRAP (64→16)</td>
<td>CGIT</td>
<td>RIIE-a GE Dc</td>
<td>E</td>
<td>7-132</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE HIGH (32)</td>
<td>CIH</td>
<td>RIL-a C HW</td>
<td>E</td>
<td>7-134</td>
</tr>
<tr>
<td>COMPARE LOGICAL (32)</td>
<td>CL</td>
<td>RX-a C A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (32)</td>
<td>CLRY</td>
<td>RXY-a C LD A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64)</td>
<td>CLG</td>
<td>RXY-a C N A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64)</td>
<td>CLGR</td>
<td>RRE C N A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64→32)</td>
<td>CLGF</td>
<td>RXY-a C N A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64→32)</td>
<td>CLGRF</td>
<td>RRE C N A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64→32)</td>
<td>CLRC</td>
<td>SS-a C A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64→32)</td>
<td>CLR</td>
<td>SI C A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64→32)</td>
<td>CLY</td>
<td>SIY C LD A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND BRANCH (32)</td>
<td>CLR</td>
<td>RXS GE A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND BRANCH (32)</td>
<td>CLGRB</td>
<td>RRS GE</td>
<td>B</td>
<td>7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND BRANCH RELATIVE (32)</td>
<td>CLRJ</td>
<td>RIE-b GE</td>
<td>B</td>
<td>7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND BRANCH RELATIVE (64)</td>
<td>CLGRJ</td>
<td>RIE-b GE</td>
<td>B</td>
<td>7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND TRAP (32)</td>
<td>CLRT</td>
<td>RRF-c GE Dc</td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND TRAP (32)</td>
<td>CLT</td>
<td>RSyb Mi A Dc</td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND TRAP (64)</td>
<td>CLGRT</td>
<td>RRF-c GE Dc</td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND TRAP (64)</td>
<td>CLGB</td>
<td>RSyb Mi A Dc</td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE LOGICAL CHAR. UNDER MASK (high)</td>
<td>CLMH</td>
<td>RSyb C N A</td>
<td>B₂</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL CHAR. UNDER MASK (low)</td>
<td>CLM</td>
<td>RSb C A</td>
<td>B₂</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL CHAR. UNDER MASK (low)</td>
<td>CLMY</td>
<td>RSyb C LD A</td>
<td>B₂</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL HIGH (32)</td>
<td>CLHF</td>
<td>RXY-a C HW A</td>
<td>B₂</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL HIGH (32)</td>
<td>CLHHR</td>
<td>RRE C HW</td>
<td>B₂</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL HIGH (32)</td>
<td>CLHRL</td>
<td>RRE C HW</td>
<td>B₂</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (16→16)</td>
<td>CLHHSI</td>
<td>SIL C GE A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (32→16)</td>
<td>CLF</td>
<td>RIL-a C EI</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64→16)</td>
<td>CLFGIS</td>
<td>SIL C GE A</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64→32)</td>
<td>CLGFI</td>
<td>RIL-a C EI</td>
<td>B₁</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH (32→8)</td>
<td>CLIB</td>
<td>RIIS GE</td>
<td>B</td>
<td>7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH (64→8)</td>
<td>CLGIB</td>
<td>RIIS GE</td>
<td>B</td>
<td>7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (32→8)</td>
<td>CLJ</td>
<td>RIIE-c GE</td>
<td>B</td>
<td>7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (64→8)</td>
<td>CLGU</td>
<td>RIIE-c GE</td>
<td>B</td>
<td>7-137</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 4 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP (32-16)</td>
<td>CLFIT</td>
<td>RIE-a GE</td>
<td>Dc</td>
<td>EC73 7-139</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP (64-16)</td>
<td>CLG1T</td>
<td>RIE-a GE</td>
<td>Dc</td>
<td>EC71 7-139</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE HIGH (32)</td>
<td>CLHI</td>
<td>RIL-a C HW</td>
<td></td>
<td>CCF 7-141</td>
</tr>
<tr>
<td>COMPARE LOGICAL LONG</td>
<td>CLCL</td>
<td>RR C</td>
<td>a^1 A SP II</td>
<td>R1, R2</td>
</tr>
<tr>
<td>COMPARE LOGICAL LONG EXTENDED</td>
<td>CLCLE</td>
<td>RS-a C</td>
<td>a^2 A SP IC</td>
<td>R1, R2</td>
</tr>
<tr>
<td>COMPARE LOGICAL LONG UNICODE</td>
<td>CLCLU</td>
<td>RSY-a C E2</td>
<td>a^2 A SP IC</td>
<td>R1, R2</td>
</tr>
<tr>
<td>COMPARE LOGICAL RELATIVE LONG (32)</td>
<td>CLR1</td>
<td>RIL-b C GE</td>
<td>A' SP</td>
<td>C6F 7-136</td>
</tr>
<tr>
<td>COMPARE LOGICAL RELATIVE LONG (32-16)</td>
<td>CLHRL</td>
<td>RIL-b C GE</td>
<td>A*</td>
<td>C67 7-136</td>
</tr>
<tr>
<td>COMPARE LOGICAL RELATIVE LONG (64)</td>
<td>CLGRL</td>
<td>RIL-b C GE</td>
<td>A' SP</td>
<td>C6A 7-136</td>
</tr>
<tr>
<td>COMPARE LOGICAL RELATIVE LONG (64-32)</td>
<td>CLGHRL</td>
<td>RIL-b C GE</td>
<td>A*</td>
<td>C66 7-136</td>
</tr>
<tr>
<td>COMPARE LOGICAL RELATIVE LONG (64)</td>
<td>CLGRL</td>
<td>RIL-b C GE</td>
<td>A' SP</td>
<td>C6E 7-136</td>
</tr>
<tr>
<td>COMPARE LOGICAL RELATIVE LONG (32)</td>
<td>CLST</td>
<td>RRE C</td>
<td>a^1 A SP IC</td>
<td>Go</td>
</tr>
<tr>
<td>COMPARE RELATIVE LONG (64)</td>
<td>CLRL</td>
<td>RIL-b C GE</td>
<td>A' SP</td>
<td>2B5D 7-118</td>
</tr>
<tr>
<td>COMPARE RELATIVE LONG (64-32)</td>
<td>CLRL</td>
<td>RIL-b C GE</td>
<td>A' SP</td>
<td>2B5D 7-118</td>
</tr>
<tr>
<td>COMPARE UNTIL SUBSTRING EQUAL</td>
<td>CUSE</td>
<td>RRE C</td>
<td>a^1 A SP II</td>
<td>GM</td>
</tr>
<tr>
<td>COMPRESSION CALL</td>
<td>CMPSC</td>
<td>RRE C</td>
<td>a^1 A SP IC</td>
<td>GM</td>
</tr>
<tr>
<td>COMPUTE INTERMEDIATE MESSAGE DIGEST</td>
<td>KIMD</td>
<td>RRE C MS</td>
<td>a^1 A SP I</td>
<td>GM</td>
</tr>
<tr>
<td>COMPUTE LAST MESSAGE DIGEST</td>
<td>KLMD</td>
<td>RRE C MS</td>
<td>a^1 A SP I</td>
<td>GM</td>
</tr>
<tr>
<td>COMPUTE MESSAGE AUTHENTICATION CODE</td>
<td>KMAC</td>
<td>RRE C MS</td>
<td>a^1 A SP I</td>
<td>GM</td>
</tr>
<tr>
<td>CONVERT TO BINARY (32)</td>
<td>CVB</td>
<td>RX-a</td>
<td>a^1 A</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT TO BINARY (32)</td>
<td>CVBY</td>
<td>RX-a</td>
<td>a^1 A</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT TO BINARY (64)</td>
<td>CVBG</td>
<td>RX-a</td>
<td>a^1 A</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT TO BINARY (64)</td>
<td>CVBG</td>
<td>RX-a</td>
<td>a^1 A</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT TO DECIMAL (32)</td>
<td>CVD</td>
<td>RX-a</td>
<td>a^1 A</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT TO DECIMAL (32)</td>
<td>CVDY</td>
<td>RX-a</td>
<td>a^1 A</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT TO DECIMAL (64)</td>
<td>CVDG</td>
<td>RX-a</td>
<td>a^1 A</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT UNCODE TO UTF-8</td>
<td>CUUTF</td>
<td>RRF-c C</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT UTF-16 TO UTF-32</td>
<td>CU24</td>
<td>RRF-c C E3</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT UTF-16 TO UTF-8</td>
<td>CU21</td>
<td>RRF-c C</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT UTF-32 TO UTF-16</td>
<td>CU42</td>
<td>RRF-c C E3</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT UTF-32 TO UTF-8</td>
<td>CU41</td>
<td>RRF-c C E3</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT UTF-8 TO UNICODE</td>
<td>CUTFU</td>
<td>RRF-c C</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT UTF-8 TO UTF-16</td>
<td>CU12</td>
<td>RRF-c C E3</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>CONVERT UTF-8 TO UTF-32</td>
<td>CU14</td>
<td>RRF-c C E3</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>COPY ACCESS</td>
<td>CPY1</td>
<td>RRF-c C</td>
<td>a^1 A SP IC</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE (32-64)</td>
<td>D</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE (32-64)</td>
<td>D</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE (32-64)</td>
<td>DL</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE LOGICAL (32-64)</td>
<td>DLR</td>
<td>RRE N3</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE LOGICAL (64-128)</td>
<td>DLG</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE LOGICAL (64-128)</td>
<td>DLG</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE SINGLE (64)</td>
<td>DSG</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE SINGLE (64)</td>
<td>DSG</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE SINGLE (64-32)</td>
<td>DSG</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>DIVIDE SINGLE (64-32)</td>
<td>DSG</td>
<td>RX-a</td>
<td>a^1 A SP IK</td>
<td>ST</td>
</tr>
<tr>
<td>EXCLUSIVE OR (32)</td>
<td>X</td>
<td>RX-a</td>
<td>C A</td>
<td>R1</td>
</tr>
<tr>
<td>EXCLUSIVE OR (32)</td>
<td>XR</td>
<td>RR C</td>
<td></td>
<td>R2</td>
</tr>
<tr>
<td>EXCLUSIVE OR (32)</td>
<td>XKR</td>
<td>RR-F-a C DO</td>
<td></td>
<td>R1, R2</td>
</tr>
<tr>
<td>EXCLUSIVE OR (32)</td>
<td>XY</td>
<td>RX-a</td>
<td>C LD</td>
<td>R1</td>
</tr>
<tr>
<td>EXCLUSIVE OR (64)</td>
<td>XG</td>
<td>RX-a</td>
<td>C N A</td>
<td>R1</td>
</tr>
<tr>
<td>EXCLUSIVE OR (64)</td>
<td>XGR</td>
<td>RX-a</td>
<td>C N A</td>
<td>R1</td>
</tr>
<tr>
<td>EXCLUSIVE OR (64)</td>
<td>XGR</td>
<td>RX-a</td>
<td>C DO</td>
<td>R1</td>
</tr>
<tr>
<td>EXCLUSIVE OR (character)</td>
<td>XC</td>
<td>SS-a C</td>
<td>a^1 A</td>
<td>ST</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 5 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>EXCLUSIVE OR (immediate)</td>
<td>XI</td>
<td>C A</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>EXCLUSIVE OR (immediate)</td>
<td>XIY</td>
<td>SIY C LD A</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>EXCLUSIVE OR IMMEDIATE (high)</td>
<td>XIHF</td>
<td>RIL-a C EI</td>
<td>C06</td>
<td>7-214</td>
</tr>
<tr>
<td>EXCLUSIVE OR IMMEDIATE (low)</td>
<td>XILF</td>
<td>RIL-a C EI</td>
<td>C07</td>
<td>7-214</td>
</tr>
<tr>
<td>EXECUTE</td>
<td>EX</td>
<td>RX-a</td>
<td>44</td>
<td>7-214</td>
</tr>
<tr>
<td>EXECUTE RELATIVE LONG</td>
<td>EXRL</td>
<td>RIL-b XX</td>
<td>EX</td>
<td>C60</td>
</tr>
<tr>
<td>EXTRACT ACCESS</td>
<td>EAR</td>
<td>RRE</td>
<td>U2</td>
<td>B24F</td>
</tr>
<tr>
<td>EXTRACT CPU ATTRIBUTE</td>
<td>ECAG</td>
<td>RSY-a GE</td>
<td>GM</td>
<td>R3</td>
</tr>
<tr>
<td>EXTRACT CPU TIME</td>
<td>ECTG</td>
<td>SSF ET</td>
<td>B1</td>
<td>C81</td>
</tr>
<tr>
<td>EXTRACT PSW</td>
<td>EPSW</td>
<td>RE N3</td>
<td>B1</td>
<td>B1</td>
</tr>
<tr>
<td>EXTRACT TRANSACTION NESTING DEPTH</td>
<td>ETND</td>
<td>RRE TX A</td>
<td>SO</td>
<td>B2EC</td>
</tr>
<tr>
<td>FIND LEFTMOST ONE</td>
<td>FLOGR</td>
<td>RRE C EI SP</td>
<td>B983</td>
<td>7-219</td>
</tr>
<tr>
<td>INSERT CHARACTER</td>
<td>IC</td>
<td>RX-a A</td>
<td>B5</td>
<td>7-219</td>
</tr>
<tr>
<td>INSERT CHARACTER</td>
<td>ICY</td>
<td>RXY-a LD A</td>
<td>B5</td>
<td>E373</td>
</tr>
<tr>
<td>INSERT CHARACTERS UNDER MASK (high)</td>
<td>ICMH</td>
<td>RSY-b C N A</td>
<td>B5</td>
<td>EB80</td>
</tr>
<tr>
<td>INSERT CHARACTERS UNDER MASK (low)</td>
<td>ICMY</td>
<td>RSY-b C LD A</td>
<td>B5</td>
<td>EB81</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (high high)</td>
<td>IHHH</td>
<td>Ri-a N</td>
<td>A50</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (high low)</td>
<td>IHLH</td>
<td>Ri-a N</td>
<td>A51</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (high)</td>
<td>IHHF</td>
<td>RIL-a EI</td>
<td>A50</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (low high)</td>
<td>IIIH</td>
<td>Ri-a N</td>
<td>A52</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (low low)</td>
<td>IIII</td>
<td>Ri-a N</td>
<td>A53</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT IMMEDIATE</td>
<td>IILF</td>
<td>RIL-a EI</td>
<td>C09</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT PROGRAM MASK</td>
<td>IPM</td>
<td>RRE</td>
<td>B222</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD (32)</td>
<td>LR</td>
<td>RR</td>
<td>18</td>
<td>7-221</td>
</tr>
<tr>
<td>LOAD (32)</td>
<td>LY</td>
<td>RXY-a LD A</td>
<td>B3</td>
<td>E358</td>
</tr>
<tr>
<td>LOAD (64)</td>
<td>LG</td>
<td>RXY-a N A</td>
<td>B2</td>
<td>E304</td>
</tr>
<tr>
<td>LOAD (64)</td>
<td>LGR</td>
<td>RRE N</td>
<td>B3</td>
<td>B904</td>
</tr>
<tr>
<td>LOAD (64+32)</td>
<td>LGF</td>
<td>RXY-a N A</td>
<td>B3</td>
<td>B914</td>
</tr>
<tr>
<td>LOAD ACCESS MULTIPLE</td>
<td>LGFR</td>
<td>RRE N</td>
<td>B914</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD ACCESS MULTIPLE</td>
<td>LAM</td>
<td>RS-a</td>
<td>U9A</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD ADDRESS</td>
<td>LA</td>
<td>RX-a</td>
<td>41</td>
<td>7-223</td>
</tr>
<tr>
<td>LOAD ADDRESS</td>
<td>LAY</td>
<td>RXY-a LD</td>
<td>E371</td>
<td>7-223</td>
</tr>
<tr>
<td>LOAD ADDRESS EXTENDED</td>
<td>LAE</td>
<td>RX-a</td>
<td>U1 BP</td>
<td>7-223</td>
</tr>
<tr>
<td>LOAD ADDRESS EXTENDED</td>
<td>LAEY</td>
<td>RXY-a GE</td>
<td>U1 BP</td>
<td>E375</td>
</tr>
<tr>
<td>LOAD ADDRESS RELATIVE LONG</td>
<td>LARL</td>
<td>RIL-b N3</td>
<td>C00</td>
<td>7-224</td>
</tr>
<tr>
<td>LOAD AND ADD (32)</td>
<td>LAA</td>
<td>RSY-a C IA</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD AND ADD (64)</td>
<td>LAAG</td>
<td>RSY-a C IA A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD AND ADD LOGICAL (32)</td>
<td>LAAL</td>
<td>RSY-a C IA A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD AND ADD LOGICAL (64)</td>
<td>LAAAL</td>
<td>RSY-a C IA A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD AND OR (32)</td>
<td>LAO</td>
<td>RSY-a C IA</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD AND OR (64)</td>
<td>LAOG</td>
<td>RSY-a C IA</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD AND TEST (32)</td>
<td>LT</td>
<td>RXY-a C EI A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD AND TEST (32)</td>
<td>LTR</td>
<td>RR C</td>
<td>12</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND TEST (64)</td>
<td>LTG</td>
<td>RXY-a C EI A</td>
<td>B3</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND TRAP (32)</td>
<td>LAT</td>
<td>RXY-a LT A Dc</td>
<td>B3</td>
<td>7-228</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 6 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOAD AND TRAP (64)</td>
<td>LGAT RXY-a</td>
<td>LT A DC</td>
<td>B7</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND ZERO RIGHTMOST BYTE (32)</td>
<td>L2RF RXY-a</td>
<td>LZ A</td>
<td>B2</td>
<td>7-229</td>
</tr>
<tr>
<td>LOAD AND ZERO RIGHTMOST BYTE (64)</td>
<td>L2RG RXY-a</td>
<td>LZ A</td>
<td>B2</td>
<td>7-229</td>
</tr>
<tr>
<td>LOAD BYTE (32×8)</td>
<td>LB RXY-a</td>
<td>LD A</td>
<td>E378</td>
<td>7-229</td>
</tr>
<tr>
<td>LOAD BYTE (32×8)</td>
<td>LBR RRE</td>
<td>Ei</td>
<td>B926</td>
<td>7-229</td>
</tr>
<tr>
<td>LOAD BYTE (64×8)</td>
<td>LGB RXY-a</td>
<td>LD A</td>
<td>E377</td>
<td>7-229</td>
</tr>
<tr>
<td>LOAD BYTE (64×8)</td>
<td>LGBR RRE</td>
<td>Ei</td>
<td>B906</td>
<td>7-229</td>
</tr>
<tr>
<td>LOAD BYTE HIGH (32×8)</td>
<td>LBH RXY-a</td>
<td>HW A</td>
<td>B2</td>
<td>7-229</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (32)</td>
<td>LCR RR C</td>
<td>IF</td>
<td>13</td>
<td>7-230</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (64)</td>
<td>LCGR RRE C N</td>
<td>IF</td>
<td>B903</td>
<td>7-230</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (64×32)</td>
<td>LCGFR RRE C N</td>
<td></td>
<td>B913</td>
<td>7-230</td>
</tr>
<tr>
<td>LOAD COUNT TO BLOCK BOUNDARY</td>
<td>LCBB RXE C VF</td>
<td>SP</td>
<td>E727</td>
<td>7-230</td>
</tr>
<tr>
<td>LOAD HALFWORD (32×16)</td>
<td>LH RX-a</td>
<td>A</td>
<td>B2</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HALFWORD (32×16)</td>
<td>LHR RRE</td>
<td>Ei</td>
<td>B927</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HALFWORD (32×16)</td>
<td>LHY RXY-a</td>
<td>LD A</td>
<td>E378</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HALFWORD (64×16)</td>
<td>LGH RXY-a N</td>
<td>A</td>
<td>B2</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HALFWORD (64×16)</td>
<td>LGHR RRE Ei</td>
<td></td>
<td>B907</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HALFWORD HIGH (32×16)</td>
<td>LHH RXY-a HW</td>
<td>A</td>
<td>B2</td>
<td>7-232</td>
</tr>
<tr>
<td>LOAD HALFWORD HIGH IMMEDIATE ON CONDITION (32×16)</td>
<td>LOCHHI RIE-g L2</td>
<td></td>
<td>EC4E</td>
<td>7-232</td>
</tr>
<tr>
<td>LOAD HALFWORD IMMEDIATE (32×16)</td>
<td>LHI Ri-a</td>
<td></td>
<td>A78</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HALFWORD IMMEDIATE (64×16)</td>
<td>LGHI Ri-a N</td>
<td>L2</td>
<td>A79</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HALFWORD IMMEDIATE ON CONDITION (32×16)</td>
<td>LOCHI RIE-g L2</td>
<td></td>
<td>EC42</td>
<td>7-232</td>
</tr>
<tr>
<td>LOAD HALFWORD IMMEDIATE ON CONDITION (64×16)</td>
<td>LOCIGHI RIE-g L2</td>
<td></td>
<td>EC46</td>
<td>7-232</td>
</tr>
<tr>
<td>LOAD HALFWORD RELATIVE LONG (32×16)</td>
<td>LHRL RIL-b GE</td>
<td>A*</td>
<td>C45</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HALFWORD RELATIVE LONG (64×16)</td>
<td>LGHRL RIL-b GE A*</td>
<td></td>
<td>C44</td>
<td>7-231</td>
</tr>
<tr>
<td>LOAD HIGH (32)</td>
<td>LFH RXY-a HW</td>
<td>A</td>
<td>B2</td>
<td>7-233</td>
</tr>
<tr>
<td>LOAD HIGH AND TRAP (32)</td>
<td>LFHAT RXY-a LT</td>
<td>A DC</td>
<td>B2</td>
<td>7-233</td>
</tr>
<tr>
<td>LOAD HIGH ON CONDITION (32)</td>
<td>LOCFH RSYb L2</td>
<td>A</td>
<td>B2</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD HIGH ON CONDITION (32)</td>
<td>LOCFHR RRb-c L2</td>
<td>A</td>
<td>B9E0</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD IMMEDIATE (64×32)</td>
<td>LGFI RIL-a EI</td>
<td>A</td>
<td>C01</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD LOGICAL (64×32)</td>
<td>LLGF RXY-a N</td>
<td>A</td>
<td>B2</td>
<td>7-233</td>
</tr>
<tr>
<td>LOAD LOGICAL (64×32)</td>
<td>LLGFR RRE N</td>
<td>A</td>
<td>B916</td>
<td>7-233</td>
</tr>
<tr>
<td>LOAD LOGICAL AND TRAP (64×32)</td>
<td>LLGFAT RXY-a LT</td>
<td>A DC</td>
<td>B2</td>
<td>7-234</td>
</tr>
<tr>
<td>LOAD LOGICAL AND ZERO RIGHTMOST BYTE (64×32)</td>
<td>LLZRGF RXY-a LZ</td>
<td>A</td>
<td>E39D</td>
<td>7-234</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (32×8)</td>
<td>LLC RXY-a Ei</td>
<td>A</td>
<td>B2</td>
<td>7-234</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (32×8)</td>
<td>LLGC RXY-a N</td>
<td>A</td>
<td>B2</td>
<td>7-234</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (64×8)</td>
<td>LLGCR RRE Ei</td>
<td>A</td>
<td>B984</td>
<td>7-234</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (32×8)</td>
<td>LLCH RXY-a HW</td>
<td>A</td>
<td>B2</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (32×16)</td>
<td>LLH1 RXY-a Ei</td>
<td>A</td>
<td>B2</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (32×16)</td>
<td>LLHG RXY-a N</td>
<td>A</td>
<td>B2</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (64×16)</td>
<td>LLGH RRE Ei</td>
<td>A</td>
<td>B985</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (32×16)</td>
<td>LLHH RXY-a HW</td>
<td>A</td>
<td>B2</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (32×16)</td>
<td>LLLHRL RIL-b GE A*</td>
<td></td>
<td>C42</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (64×16)</td>
<td>LLGHRL RIL-b GE A*</td>
<td></td>
<td>C46</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (high high)</td>
<td>LLIH Ri-a N</td>
<td></td>
<td>ASC</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (high low)</td>
<td>LLIH Ri-a N</td>
<td></td>
<td>ASD</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (high)</td>
<td>LLIH Ri-a Ei</td>
<td></td>
<td>C0E</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (low high)</td>
<td>LLIH Ri-a N</td>
<td></td>
<td>A5E</td>
<td>7-236</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 7 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOAD LOGICAL IMMEDIATE (low low)</td>
<td>LLIL</td>
<td>RIL-a N</td>
<td>ASF</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (low)</td>
<td>LLILF</td>
<td>RIL-a El</td>
<td>COF</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL RELATIVE LONG (64&lt;32)</td>
<td>LLGFRL</td>
<td>RIL-b GE A* SP</td>
<td>C4E</td>
<td>7-233</td>
</tr>
<tr>
<td>LOAD LOGICAL THIRTY ONE BITS (64&lt;31)</td>
<td>LLGT</td>
<td>RXy-a N A</td>
<td>B2</td>
<td>7-237</td>
</tr>
<tr>
<td>LOAD LOGICAL THIRTY ONE BITS (64&lt;31)</td>
<td>LLGTR</td>
<td>REE N</td>
<td>B2</td>
<td>7-237</td>
</tr>
<tr>
<td>LOAD LOGICAL THIRTY ONE BITS AND TRAP</td>
<td>LLGTAT</td>
<td>RXy-a LT A Dc</td>
<td>B2</td>
<td>7-237</td>
</tr>
<tr>
<td>LOAD MULTIPLE (32)</td>
<td>LM</td>
<td>RS-a A</td>
<td>B2</td>
<td>7-237</td>
</tr>
<tr>
<td>LOAD MULTIPLE (32)</td>
<td>LMY</td>
<td>RSY-a LD A</td>
<td>B2</td>
<td>7-237</td>
</tr>
<tr>
<td>LOAD MULTIPLE (64)</td>
<td>LMG</td>
<td>RSY-a N A</td>
<td>B2</td>
<td>7-237</td>
</tr>
<tr>
<td>LOAD MULTIPLE DISJOINT (64&lt;32&amp;32)</td>
<td>LMD</td>
<td>SSy-a N</td>
<td>B2</td>
<td>7-238</td>
</tr>
<tr>
<td>LOAD MULTIPLE HIGH (32)</td>
<td>LMH</td>
<td>RSY-a N A</td>
<td>B2</td>
<td>7-238</td>
</tr>
<tr>
<td>LOAD NEGATIVE (32)</td>
<td>LNR</td>
<td>RR C</td>
<td>11</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD NEGATIVE (64)</td>
<td>LNFR</td>
<td>RRE C N</td>
<td>B2</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD NEGATIVE (64&lt;32)</td>
<td>LNFR</td>
<td>RRE C N</td>
<td>B2</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD ON CONDITION (32)</td>
<td>LOC</td>
<td>RSY-b L1 A</td>
<td>B2</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD ON CONDITION (32)</td>
<td>LOC</td>
<td>RSY-b L1 A</td>
<td>B2</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD ON CONDITION (64)</td>
<td>LOCR</td>
<td>RRF-c L1 A</td>
<td>B2</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD ON CONDITION (64)</td>
<td>LOCG</td>
<td>RSY-b L1 A</td>
<td>B2</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD ON CONDITION (64)</td>
<td>LOCR</td>
<td>RRF-c L1 A</td>
<td>B2</td>
<td>7-239</td>
</tr>
<tr>
<td>LOAD PAIR DISJOINT (64)</td>
<td>LPD</td>
<td>SSF C IA A SP</td>
<td>B2</td>
<td>7-241</td>
</tr>
<tr>
<td>LOAD PAIR DISJOINT (64)</td>
<td>LPDG</td>
<td>SSF C IA A SP</td>
<td>B2</td>
<td>7-241</td>
</tr>
<tr>
<td>LOAD PAIR FROM QUADWORD (64&amp;64&lt;128)</td>
<td>LPQ</td>
<td>RXy-a N</td>
<td>B2</td>
<td>7-244</td>
</tr>
<tr>
<td>LOAD POSITIVE (32)</td>
<td>LPR</td>
<td>RR C</td>
<td>10</td>
<td>7-244</td>
</tr>
<tr>
<td>LOAD POSITIVE (64)</td>
<td>LPGR</td>
<td>RRE C N</td>
<td>IF</td>
<td>7-244</td>
</tr>
<tr>
<td>LOAD POSITIVE (64&lt;32)</td>
<td>LPGRF</td>
<td>RRE C N</td>
<td>IF</td>
<td>7-244</td>
</tr>
<tr>
<td>LOAD RELATIVE LONG (32)</td>
<td>LRL</td>
<td>RIL-b GE A SP</td>
<td>C4D</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD RELATIVE LONG (64)</td>
<td>LGRL</td>
<td>RIL-b GE A* SP</td>
<td>C48</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD RELATIVE LONG (64&lt;32)</td>
<td>LGFR</td>
<td>RIL-b GE A* SP</td>
<td>C4C</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD REVERSED (16)</td>
<td>LRV</td>
<td>RXy-a N A</td>
<td>B2</td>
<td>7-243</td>
</tr>
<tr>
<td>LOAD REVERSED (32)</td>
<td>LRV</td>
<td>RXy-a N A</td>
<td>B2</td>
<td>7-243</td>
</tr>
<tr>
<td>LOAD REVERSED (32)</td>
<td>LRV</td>
<td>RXy-a N A</td>
<td>B2</td>
<td>7-243</td>
</tr>
<tr>
<td>LOAD REVERSED (64)</td>
<td>LRVG</td>
<td>RXy-a N A</td>
<td>B2</td>
<td>7-243</td>
</tr>
<tr>
<td>LOAD REVERSED (64)</td>
<td>LRVGR</td>
<td>RRE N</td>
<td>B2</td>
<td>7-243</td>
</tr>
<tr>
<td>LOAD REVERSED (64)</td>
<td>LRVG</td>
<td>RXy-a N A</td>
<td>B2</td>
<td>7-243</td>
</tr>
<tr>
<td>MONITOR CALL</td>
<td>MC</td>
<td>SI A SP ME</td>
<td>ST</td>
<td>7-243</td>
</tr>
<tr>
<td>MOVE (16&lt;16)</td>
<td>MHHI</td>
<td>SIL GE A</td>
<td>B1</td>
<td>7-244</td>
</tr>
<tr>
<td>MOVE (32&lt;16)</td>
<td>MHI</td>
<td>SIL GE A</td>
<td>B1</td>
<td>7-244</td>
</tr>
<tr>
<td>MOVE (64&lt;16)</td>
<td>MVGG</td>
<td>SIL GE A</td>
<td>B1</td>
<td>7-244</td>
</tr>
<tr>
<td>MOVE (character)</td>
<td>MVC</td>
<td>SS-a A</td>
<td>B1</td>
<td>7-245</td>
</tr>
<tr>
<td>MOVE (immediate)</td>
<td>MVI</td>
<td>SI A</td>
<td>B1</td>
<td>7-245</td>
</tr>
<tr>
<td>MOVE (immediate)</td>
<td>MVIY</td>
<td>SIY LD A</td>
<td>B1</td>
<td>7-245</td>
</tr>
<tr>
<td>MOVE INVERSE</td>
<td>MVCIN</td>
<td>SS-a A</td>
<td>B1</td>
<td>7-245</td>
</tr>
<tr>
<td>MOVE LONG</td>
<td>MVCL</td>
<td>RR C A SP II</td>
<td>ST</td>
<td>7-246</td>
</tr>
<tr>
<td>MOVE LONG EXTENDED</td>
<td>MVCLE</td>
<td>RS-a C A SP IC</td>
<td>ST</td>
<td>7-250</td>
</tr>
<tr>
<td>MOVE LONG UNICODE</td>
<td>MVCLU</td>
<td>RSy-a C E2 A SP</td>
<td>ST</td>
<td>7-253</td>
</tr>
<tr>
<td>MOVE NUMERICS</td>
<td>MVN</td>
<td>SS-a A</td>
<td>ST</td>
<td>7-256</td>
</tr>
<tr>
<td>MOVE STRING</td>
<td>MVST</td>
<td>REE C A SP IC G0</td>
<td>ST</td>
<td>7-257</td>
</tr>
<tr>
<td>MOVE WITH OFFSET</td>
<td>MVO</td>
<td>SS-b A</td>
<td>ST</td>
<td>7-258</td>
</tr>
<tr>
<td>MOVE ZONES</td>
<td>MWZ</td>
<td>SS-a A</td>
<td>ST</td>
<td>7-259</td>
</tr>
<tr>
<td>MULTIPLY (64&lt;32)</td>
<td>MRY</td>
<td>RXy-a A</td>
<td>B2</td>
<td>7-259</td>
</tr>
<tr>
<td>MULTIPLY (64&lt;32)</td>
<td>MFY</td>
<td>RXy-a GE A SP</td>
<td>B2</td>
<td>7-259</td>
</tr>
<tr>
<td>MULTIPLY (64&lt;32)</td>
<td>MR</td>
<td>RR SP</td>
<td>B2</td>
<td>7-259</td>
</tr>
<tr>
<td>MULTIPLY HALFWORD (32&lt;16)</td>
<td>MH</td>
<td>RXy-a A</td>
<td>B2</td>
<td>7-260</td>
</tr>
<tr>
<td>MULTIPLY HALFWORD (32&lt;16)</td>
<td>MHY</td>
<td>RXy-a GE A</td>
<td>B2</td>
<td>7-260</td>
</tr>
<tr>
<td>MULTIPLY HALFWORD IMMEDIATE (32&lt;16)</td>
<td>MHI</td>
<td>RXy-a GE A</td>
<td>B2</td>
<td>7-260</td>
</tr>
<tr>
<td>MULTIPLY HALFWORD IMMEDIATE (64&lt;16)</td>
<td>MIGH</td>
<td>RXy-a N</td>
<td>B2</td>
<td>7-260</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions  (Part 8 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>MULTIPLY LOGICAL (128×64)</td>
<td>MLG</td>
<td>RXY-a</td>
<td>B3</td>
<td>E386</td>
</tr>
<tr>
<td>MULTIPLY LOGICAL (128×64)</td>
<td>MLGR</td>
<td>RRE</td>
<td>B986</td>
<td>E586</td>
</tr>
<tr>
<td>MULTIPLY LOGICAL (64×32)</td>
<td>ML</td>
<td>RXY-a N3</td>
<td>B3</td>
<td>E396</td>
</tr>
<tr>
<td>MULTIPLY LOGICAL (64×32)</td>
<td>MLR</td>
<td>RRE N3</td>
<td>B996</td>
<td>E596</td>
</tr>
<tr>
<td>MULTIPLY SINGLE (32)</td>
<td>MS</td>
<td>RX-a</td>
<td>B3</td>
<td>71</td>
</tr>
<tr>
<td>MULTIPLY SINGLE (32)</td>
<td>MSR</td>
<td>RRE</td>
<td>B252</td>
<td>71</td>
</tr>
<tr>
<td>MULTIPLY SINGLE (32)</td>
<td>MSY</td>
<td>RXY-a LD</td>
<td>B2</td>
<td>E351</td>
</tr>
<tr>
<td>MULTIPLY SINGLE (64)</td>
<td>MSG</td>
<td>RXY-a N</td>
<td>B2</td>
<td>E30C</td>
</tr>
<tr>
<td>MULTIPLY SINGLE (64)</td>
<td>MSGR</td>
<td>RRE N</td>
<td>B90C</td>
<td>E50C</td>
</tr>
<tr>
<td>MULTIPLY SINGLE (64×32)</td>
<td>MSGF</td>
<td>RXY-a N</td>
<td>B2</td>
<td>E31C</td>
</tr>
<tr>
<td>MULTIPLY SINGLE IMMEDIATE (32)</td>
<td>MSFI</td>
<td>RIL-a GE</td>
<td>C21</td>
<td>7-262</td>
</tr>
<tr>
<td>MULTIPLY SINGLE IMMEDIATE (64×32)</td>
<td>MSFGI</td>
<td>RIL-a GE</td>
<td>C20</td>
<td>7-262</td>
</tr>
<tr>
<td>NEXT INSTRUCTION ACCESS INTENT</td>
<td>NIAI</td>
<td>IE EH</td>
<td>B2FA</td>
<td>7-262</td>
</tr>
<tr>
<td>NONTRANSACTIONAL STORE (64)</td>
<td>NTSTG</td>
<td>RXY-a TX</td>
<td>B2</td>
<td>E325</td>
</tr>
<tr>
<td>OR (32)</td>
<td>OR</td>
<td>RR C</td>
<td>16</td>
<td>7-264</td>
</tr>
<tr>
<td>OR (32)</td>
<td>ORK</td>
<td>RRF-a C DO</td>
<td>B9F6</td>
<td>7-264</td>
</tr>
<tr>
<td>OR (32)</td>
<td>ORY</td>
<td>RXY-a C LD</td>
<td>B3</td>
<td>E356</td>
</tr>
<tr>
<td>OR (64)</td>
<td>ORG</td>
<td>RX-a C N</td>
<td>B3</td>
<td>E381</td>
</tr>
<tr>
<td>OR (64)</td>
<td>OGR</td>
<td>RRE C N</td>
<td>B981</td>
<td>7-264</td>
</tr>
<tr>
<td>OR (64)</td>
<td>OR (character) OR (immediate) OR (immediate) OR IMMEDIATE (high high) OR IMMEDIATE (high low) OR IMMEDIATE (high) OR IMMEDIATE (high low) OR IMMEDIATE (low low) OR IMMEDIATE (low)</td>
<td>OR</td>
<td>RR C</td>
<td>16</td>
</tr>
<tr>
<td>OR IMMEDIATE (high low)</td>
<td>ORH</td>
<td>Ri-a C N</td>
<td>A58</td>
<td>7-265</td>
</tr>
<tr>
<td>OR IMMEDIATE (high)</td>
<td>ORH</td>
<td>Ri-a C Ei</td>
<td>C0C</td>
<td>7-265</td>
</tr>
<tr>
<td>OR IMMEDIATE (high low)</td>
<td>ORH</td>
<td>Ri-a C N</td>
<td>A5A</td>
<td>7-266</td>
</tr>
<tr>
<td>OR IMMEDIATE (low low)</td>
<td>OIL</td>
<td>Ri-a C N</td>
<td>A5B</td>
<td>7-266</td>
</tr>
<tr>
<td>OR IMMEDIATE (low)</td>
<td>OLF</td>
<td>Ri-a C Ei</td>
<td>C0D</td>
<td>7-265</td>
</tr>
<tr>
<td>PACK</td>
<td>PACK</td>
<td>SS-b c</td>
<td>F2</td>
<td>7-266</td>
</tr>
<tr>
<td>PACK ASCII</td>
<td>PKA</td>
<td>SS-f E2</td>
<td>B2</td>
<td>E5</td>
</tr>
<tr>
<td>PACK UNICODE</td>
<td>PKU</td>
<td>SS-f E2</td>
<td>B2</td>
<td>E5</td>
</tr>
<tr>
<td>PERFORM CRYPTOGRAPHIC COMPUTATION</td>
<td>PCC</td>
<td>RRE C M4 c1 c2 AS IC GM ST</td>
<td>B29C</td>
<td>7-269</td>
</tr>
<tr>
<td>PERFORM PROCESSOR ASSIST</td>
<td>PPA</td>
<td>RRF-c PA c3</td>
<td>B2EB</td>
<td>7-298</td>
</tr>
<tr>
<td>PERFORM LOCKED OPERATION</td>
<td>PLO</td>
<td>SS-e C c1 c2 AS $ GM ST</td>
<td>EE</td>
<td>7-284</td>
</tr>
<tr>
<td>PERFORM PSEUDORANDOM NUMBER</td>
<td>PPNO</td>
<td>RRE C M5 c1 c2 AS IC Dg GM ST</td>
<td>R1 R2</td>
<td>B93C</td>
</tr>
<tr>
<td>POPULATION COUNT</td>
<td>POPCNT</td>
<td>RRE C PK</td>
<td>B9E1</td>
<td>7-310</td>
</tr>
<tr>
<td>PREFETCH DATA</td>
<td>PFD</td>
<td>RX-b GE</td>
<td>B3</td>
<td>E336</td>
</tr>
<tr>
<td>PREFETCH DATA RELATIVE LONG</td>
<td>PFDR</td>
<td>Ri-c GE</td>
<td>C62</td>
<td>7-310</td>
</tr>
<tr>
<td>ROTATE LEFT SINGLE LOGICAL (32)</td>
<td>RLL</td>
<td>RS-l a N3</td>
<td>EB1D</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE LEFT SINGLE LOGICAL (64)</td>
<td>RLLG</td>
<td>RSY-a N</td>
<td>EB1C</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE THEN AND SELECTED BITS (64)</td>
<td>RNSBG</td>
<td>RIE-f C GE</td>
<td>EC54</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE THEN EXCLUSIVE OR SEL. BITS (64)</td>
<td>RXSBG</td>
<td>RIE-f C GE</td>
<td>EC57</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE THEN INSERT SELECTED BITS (64)</td>
<td>RISBG</td>
<td>RIE-f C GE</td>
<td>EC55</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE THEN INSERT SELECTED BITS (64)</td>
<td>RISBGN</td>
<td>RIE-f M1</td>
<td>EC59</td>
<td>7-314</td>
</tr>
<tr>
<td>ROTATE THEN INSERT SELECTED BITS HIGH (32)</td>
<td>RISHG</td>
<td>RIE-f HW</td>
<td>EC5D</td>
<td>7-315</td>
</tr>
<tr>
<td>ROTATE THEN INSERT SELECTED BITS LOW (32)</td>
<td>RISBLG</td>
<td>RIE-f HW</td>
<td>EC51</td>
<td>7-316</td>
</tr>
<tr>
<td>ROTATE THEN OR SELECTED BITS (64)</td>
<td>ROSBG</td>
<td>RIE-f C GE</td>
<td>EC56</td>
<td>7-313</td>
</tr>
<tr>
<td>SEARCH STRING</td>
<td>SRSTU</td>
<td>RRE C E3</td>
<td>B9BE</td>
<td>7-319</td>
</tr>
<tr>
<td>SEARCH STRING CODE</td>
<td>SAR</td>
<td>RRE c1 c2 SP</td>
<td>B24E</td>
<td>7-321</td>
</tr>
<tr>
<td>SET ACCESS</td>
<td>SAM24</td>
<td>E N3</td>
<td>010C</td>
<td>7-321</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 9 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>SET ADDRESSING MODE (31)</td>
<td>SAM31</td>
<td>E N3 d^3 SP T</td>
<td>010D</td>
<td>7-321</td>
</tr>
<tr>
<td>SET ADDRESSING MODE (64)</td>
<td>SAM64</td>
<td>E N d^3 SP T</td>
<td>010E</td>
<td>7-321</td>
</tr>
<tr>
<td>SET PROGRAM MASK</td>
<td>SPM</td>
<td>RR L</td>
<td>04</td>
<td>7-321</td>
</tr>
<tr>
<td>SHIFT LEFT DOUBLE (64)</td>
<td>SLDA</td>
<td>RS-a C SP IF</td>
<td>8F</td>
<td>7-322</td>
</tr>
<tr>
<td>SHIFT LEFT DOUBLE LOGICAL (64)</td>
<td>SLDL</td>
<td>RS-a SP</td>
<td>8D</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE (32)</td>
<td>SLA</td>
<td>RS-a C IF</td>
<td>8B</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE (32)</td>
<td>SLAK</td>
<td>RSY-a C DO IF</td>
<td>EBDD</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE (64)</td>
<td>SLAG</td>
<td>RSY-a C N IF</td>
<td>EB0B</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE LOGICAL (32)</td>
<td>SLL</td>
<td>RS-a</td>
<td>89</td>
<td>7-324</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE LOGICAL (32)</td>
<td>SLLK</td>
<td>RSY-a DO</td>
<td>EBDF</td>
<td>7-324</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE LOGICAL (64)</td>
<td>SLLG</td>
<td>RSY-a N</td>
<td>EB0D</td>
<td>7-324</td>
</tr>
<tr>
<td>SHIFT RIGHT DOUBLE (64)</td>
<td>SRDA</td>
<td>RS-a C SP</td>
<td>8E</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT RIGHT DOUBLE LOGICAL (64)</td>
<td>SRDL</td>
<td>RS-a SP</td>
<td>8C</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>SRA</td>
<td>RS-a C</td>
<td>8A</td>
<td>7-326</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>SRK</td>
<td>RSY-a C DO</td>
<td>EBDC</td>
<td>7-326</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE (64)</td>
<td>SRAK</td>
<td>RSY-a N</td>
<td>EB0A</td>
<td>7-326</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE LOGICAL (32)</td>
<td>SRL</td>
<td>RS-a</td>
<td>88</td>
<td>7-327</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE LOGICAL (32)</td>
<td>SRLK</td>
<td>RSY-a DO</td>
<td>EBDE</td>
<td>7-327</td>
</tr>
<tr>
<td>STORE (32)</td>
<td>ST</td>
<td>RX-a A</td>
<td>ST B5</td>
<td>7-327</td>
</tr>
<tr>
<td>STORE (32)</td>
<td>STY</td>
<td>RXY-a LD A</td>
<td>ST B5</td>
<td>7-327</td>
</tr>
<tr>
<td>STORE (64)</td>
<td>STG</td>
<td>RXY-a N A</td>
<td>ST B5</td>
<td>7-327</td>
</tr>
<tr>
<td>STORE ACCESS MULTIPLE</td>
<td>STAM</td>
<td>RS-a A SP</td>
<td>ST UB</td>
<td>9B</td>
</tr>
<tr>
<td>STORE ACCESS MULTIPLE</td>
<td>STAMY</td>
<td>RSY-a LD A SP</td>
<td>ST UB</td>
<td>EB9B</td>
</tr>
<tr>
<td>STORE CHARACTER</td>
<td>STC</td>
<td>RX-a A</td>
<td>ST B5</td>
<td>42</td>
</tr>
<tr>
<td>STORE CHARACTER</td>
<td>STCY</td>
<td>RXY-a LD A</td>
<td>ST B5</td>
<td>E372</td>
</tr>
<tr>
<td>STORE CHARACTER HIGH (8)</td>
<td>STCH</td>
<td>RXY-a HW A</td>
<td>ST B5</td>
<td>E324</td>
</tr>
<tr>
<td>STORE CHARACTERS UNDER MASK (high)</td>
<td>STCMH</td>
<td>RSYb N d^1 A</td>
<td>ST B5</td>
<td>EB2C</td>
</tr>
<tr>
<td>STORE CHARACTERS UNDER MASK (low)</td>
<td>STCM</td>
<td>RS-b A</td>
<td>ST B5</td>
<td>8E</td>
</tr>
<tr>
<td>STORE CHARACTERS UNDER MASK (low)</td>
<td>STCMY</td>
<td>RSYb LD A</td>
<td>ST B5</td>
<td>EB2D</td>
</tr>
<tr>
<td>STORE CLOCK</td>
<td>STCK</td>
<td>S C d^9 A $</td>
<td>ST B5</td>
<td>B205</td>
</tr>
<tr>
<td>STORE CLOCK EXTENDED</td>
<td>STOKE</td>
<td>S C d^9 A $</td>
<td>ST B5</td>
<td>B278</td>
</tr>
<tr>
<td>STORE CLOCK FAST</td>
<td>STCKF</td>
<td>S C SC d^3 A</td>
<td>ST B5</td>
<td>B73C</td>
</tr>
<tr>
<td>STORE FACILITY LIST EXTENDED</td>
<td>STFLE</td>
<td>S C FL d^1 A</td>
<td>ST B5</td>
<td>B2B0</td>
</tr>
<tr>
<td>STORE HALFWORD (16)</td>
<td>STH</td>
<td>RX-a A</td>
<td>ST B5</td>
<td>40</td>
</tr>
<tr>
<td>STORE HALFWORD (16)</td>
<td>STHY</td>
<td>RXY-a LD A</td>
<td>ST B5</td>
<td>E370</td>
</tr>
<tr>
<td>STORE HALFWORD HIGH (16)</td>
<td>STHH</td>
<td>RXY-a HW A</td>
<td>ST B5</td>
<td>E327</td>
</tr>
<tr>
<td>STORE HALFWORD RELATIVE LONG (16)</td>
<td>STHRL</td>
<td>RIL-b GE A</td>
<td>ST C47</td>
<td>7-334</td>
</tr>
<tr>
<td>STORE HIGH (32)</td>
<td>STFH</td>
<td>RXY-a HW A</td>
<td>ST B5</td>
<td>E3CB</td>
</tr>
<tr>
<td>STORE HIGH ON CONDITION</td>
<td>STOCFH</td>
<td>RSYb L2 A</td>
<td>ST B5</td>
<td>EBE1</td>
</tr>
<tr>
<td>STORE MULTIPLE (32)</td>
<td>STM</td>
<td>RS-a A</td>
<td>ST B5</td>
<td>90</td>
</tr>
<tr>
<td>STORE MULTIPLE (32)</td>
<td>STMY</td>
<td>RSY-a LD A</td>
<td>ST B5</td>
<td>EB90</td>
</tr>
<tr>
<td>STORE MULTIPLE (64)</td>
<td>STMG</td>
<td>RSY-a N A</td>
<td>ST B5</td>
<td>EB24</td>
</tr>
<tr>
<td>STORE MULTIPLE HIGH (32)</td>
<td>STMH</td>
<td>RSY-a N A</td>
<td>ST B5</td>
<td>EB26</td>
</tr>
<tr>
<td>STORE ON CONDITION (32)</td>
<td>STOC</td>
<td>RSYb L1 A</td>
<td>ST B5</td>
<td>EBFS</td>
</tr>
<tr>
<td>STORE ON CONDITION (64)</td>
<td>STOCG</td>
<td>RSYb L1 A</td>
<td>ST B5</td>
<td>EBE3</td>
</tr>
<tr>
<td>STORE PAIR TO QUADWORD (64&amp;64→128)</td>
<td>STPQ</td>
<td>RXY-a N d^3 A SP</td>
<td>ST B5</td>
<td>E38E</td>
</tr>
<tr>
<td>STORE RELATIVE LONG (32)</td>
<td>STRL</td>
<td>RIL-b GE A SP</td>
<td>ST C4F</td>
<td>7-328</td>
</tr>
<tr>
<td>STORE RELATIVE LONG (64)</td>
<td>STRGL</td>
<td>RIL-b GE A SP</td>
<td>ST C4B</td>
<td>7-328</td>
</tr>
<tr>
<td>STORE REVERSED (16)</td>
<td>STRVH</td>
<td>RXY-a N3 A</td>
<td>ST B5</td>
<td>E33F</td>
</tr>
<tr>
<td>STORE REVERSED (32)</td>
<td>STRV</td>
<td>RXY-a N3 A</td>
<td>ST B5</td>
<td>E33E</td>
</tr>
<tr>
<td>STORE REVERSED (64)</td>
<td>STRVG</td>
<td>RXY-a N A</td>
<td>ST B5</td>
<td>E32F</td>
</tr>
<tr>
<td>SUBTRACT (32)</td>
<td>S</td>
<td>RX-a C IF</td>
<td>B5</td>
<td>7-338</td>
</tr>
<tr>
<td>SUBTRACT (32)</td>
<td>SR</td>
<td>RR C IF</td>
<td>1B</td>
<td>7-338</td>
</tr>
<tr>
<td>SUBTRACT (32)</td>
<td>SRK</td>
<td>RR-a C DO IF</td>
<td>B9F9</td>
<td>7-338</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 10 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>SUBTRACT (32)</td>
<td>ST</td>
<td>RXY-a C LD A IF</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>E35B</td>
</tr>
<tr>
<td>SUBTRACT (64)</td>
<td>SG</td>
<td>RXY-a C N A IF</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E309</td>
</tr>
<tr>
<td>SUBTRACT (64)</td>
<td>SGR</td>
<td>RRE C N IF</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B909</td>
</tr>
<tr>
<td>SUBTRACT (64&lt;-&gt;32)</td>
<td>SGF</td>
<td>RXY-a C N A IF</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E319</td>
</tr>
<tr>
<td>SUBTRACT (64&lt;-&gt;32)</td>
<td>SGFR</td>
<td>RRE C N IF</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B919</td>
</tr>
<tr>
<td>SUBTRACT HALFWORD (32&lt;-&gt;16)</td>
<td>SH</td>
<td>RX-a C A IF</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>4B</td>
</tr>
<tr>
<td>SUBTRACT HALFWORD (32&lt;-&gt;16)</td>
<td>SHY</td>
<td>RXY-a C LD A IF</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>E37B</td>
</tr>
<tr>
<td>SUBTRACT HIGH (32)</td>
<td>SHHHR</td>
<td>RRF-a C HW IF</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B9C9</td>
</tr>
<tr>
<td>SUBTRACT HIGH (32)</td>
<td>SHHLR</td>
<td>RRF-a C HW IF</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B9D9</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (32)</td>
<td>SL</td>
<td>RX-a C A</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>5F</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (32)</td>
<td>SLR</td>
<td>RR C</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>1F</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (32)</td>
<td>SLRK</td>
<td>RRF-a C DO</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B9FB</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (32)</td>
<td>SLY</td>
<td>RXY-a C LD A</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E35F</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (64)</td>
<td>SLG</td>
<td>RXY-a C N A</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E30B</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (64)</td>
<td>SLGR</td>
<td>RRE C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B90B</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (64)</td>
<td>SLGRK</td>
<td>RRF-a C DO</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B9EB</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (64&lt;-&gt;32)</td>
<td>SLGF</td>
<td>RXY-a C N A</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E31B</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL (64&lt;-&gt;32)</td>
<td>SLGFR</td>
<td>RRE C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B91B</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL HIGH (32)</td>
<td>SLHHHR</td>
<td>RRF-a C HW</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B9CB</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL HIGH (32)</td>
<td>SLHHLR</td>
<td>RRF-a C HW</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B9DB</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL IMMEDIATE (32)</td>
<td>SLFI</td>
<td>RIL-a C EI</td>
<td>C24</td>
<td>7-340</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL IMMEDIATE (64&lt;-&gt;32)</td>
<td>SLGFI</td>
<td>RIL-a C EI</td>
<td>C24</td>
<td>7-340</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL WITH BORROW (32)</td>
<td>SLB</td>
<td>RXY-a C N3 A</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E399</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL WITH BORROW (32)</td>
<td>SLBR</td>
<td>RRE C N3</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B999</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL WITH BORROW (64)</td>
<td>SLBG</td>
<td>RXY-a C N A</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E389</td>
</tr>
<tr>
<td>SUBTRACT LOGICAL WITH BORROW (64)</td>
<td>SLBGR</td>
<td>RRE C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B989</td>
</tr>
<tr>
<td>SUPERVISOR CALL</td>
<td>SVC</td>
<td>I C N3 $</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>9A</td>
</tr>
<tr>
<td>TEST ADDRESSING MODE</td>
<td>TAM</td>
<td>E C N3 $</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>91</td>
</tr>
<tr>
<td>TEST AND SET</td>
<td>TS</td>
<td>S C A $</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>91</td>
</tr>
<tr>
<td>TEST UNDER MASK</td>
<td>TM</td>
<td>SI C A</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>91</td>
</tr>
<tr>
<td>TEST UNDER MASK</td>
<td>TMY</td>
<td>SIY C LD A</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>EB51</td>
</tr>
<tr>
<td>TEST UNDER MASK (high high)</td>
<td>TMHH</td>
<td>Ri-a C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>A72</td>
</tr>
<tr>
<td>TEST UNDER MASK (high low)</td>
<td>TMLH</td>
<td>Ri-a C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>A73</td>
</tr>
<tr>
<td>TEST UNDER MASK (low high)</td>
<td>TMLL</td>
<td>Ri-a C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>A70</td>
</tr>
<tr>
<td>TEST UNDER MASK (low low)</td>
<td>TMH</td>
<td>Ri-a C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>A70</td>
</tr>
<tr>
<td>TEST UNDER MASK HIGH</td>
<td>TMH</td>
<td>Ri-a C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>A70</td>
</tr>
<tr>
<td>TEST UNDER MASK LOW</td>
<td>TM</td>
<td>Ri-a C N</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>A71</td>
</tr>
<tr>
<td>TRANSACTION ABORT</td>
<td>TABORT</td>
<td>S TX $</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>B2F8</td>
</tr>
<tr>
<td>TRANSACTION BEGIN (nonconstrained)</td>
<td>TBEGIN</td>
<td>SIL C TX $</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E560</td>
</tr>
<tr>
<td>TRANSACTION BEGIN (constrained)</td>
<td>TBEGINC</td>
<td>SIL C CX $</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E561</td>
</tr>
<tr>
<td>TRANSACTION END</td>
<td>TEND</td>
<td>S C TX $</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>E561</td>
</tr>
<tr>
<td>TRANSLATE</td>
<td>TR</td>
<td>SS-a C a&lt;sup&gt;3&lt;/sup&gt; A</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE AND TEST</td>
<td>TRT</td>
<td>SS-a C a&lt;sup&gt;3&lt;/sup&gt; A GM</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE AND TEST EXTENDED</td>
<td>TRTE</td>
<td>RRF-c C PE a&lt;sup&gt;3&lt;/sup&gt; A SP IC G1</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE AND TEST REVERSE</td>
<td>TRTR</td>
<td>SS-a C E3 a&lt;sup&gt;3&lt;/sup&gt; A GM</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE AND TEST REVERSE EXTENDED</td>
<td>TRTRE</td>
<td>RRF-c C PE a&lt;sup&gt;3&lt;/sup&gt; A SP IC G1</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE EXTENDED</td>
<td>TRE</td>
<td>RRE C a&lt;sup&gt;3&lt;/sup&gt; A SP IC G0</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE ONE TO ONE</td>
<td>TROO</td>
<td>RRF-c C E2 a&lt;sup&gt;3&lt;/sup&gt; A SP IC GM</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE ONE TO TWO</td>
<td>TROT</td>
<td>RRF-c C E2 a&lt;sup&gt;3&lt;/sup&gt; A SP IC GM</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE TWO TO ONE</td>
<td>TRTO</td>
<td>RRF-c C E2 a&lt;sup&gt;3&lt;/sup&gt; A SP IC GM</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>TRANSLATE TWO TO TWO</td>
<td>TRT</td>
<td>RRF-c C E2 a&lt;sup&gt;3&lt;/sup&gt; A SP IC GM</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>UNPACK</td>
<td>UNPK</td>
<td>SS-b a&lt;sup&gt;3&lt;/sup&gt; A</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>UNPACK ASCII</td>
<td>UNPKA</td>
<td>SS-a C E2 a&lt;sup&gt;3&lt;/sup&gt; A SP</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>UNPACK UNICODE</td>
<td>UNPKU</td>
<td>SS-a C E2 a&lt;sup&gt;3&lt;/sup&gt; A SP</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions  (Part 11 of 14)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>UPDATE TREE</td>
<td>UPT</td>
<td>E</td>
<td>C</td>
<td>9 A</td>
</tr>
</tbody>
</table>

**Explanation:**

- \( e \) Causes serialization and checkpoint synchronization.
- \( e^1 \) Causes serialization and checkpoint synchronization when the \( M_1 \) and \( R_1 \) fields contain 1111 binary and 0000 binary, respectively. Causes only serialization when the fast-BCR-serialization facility is installed, and the \( M_1 \) and \( R_1 \) fields contain 1110 binary and 0000 binary, respectively.
- \( s \) Causes serialization.
- \( s^1 \) Causes specific-operand serialization.
- \( s^2 \) Causes specific-operand serialization when the interlocked-access facility 1 is installed and the storage operand is aligned on an integral boundary corresponding to its size.
- \( s^3 \) Causes specific-operand serialization when the interlocked-access facility 2 is installed.
- \( s^4 \) Restricted from transactional execution.
- \( s^5 \) Restricted from transactional execution when \( R_1 \) nonzero and branch tracing is enabled.
- \( s^6 \) Restricted from transactional execution when mode tracing is enabled.
- \( s^7 \) Restricted from transactional execution when a monitor-event condition occurs.
- \( s^8 \) Model dependent whether the instruction is restricted from transactional execution.
- \( s^9 \) Restricted from transactional execution when the effective allow-AR-modification control is zero.
- \( s^{10} \) Restricted from transactional execution when the effective allow-floating-point-operation control is zero.
- \( s^{11} \) Restricted from transactional execution depending on machine conditions.
- \( s^{12} \) Restricted in the constrained transactional-execution mode; a transaction-constraint program exception may be recognized. For PFD and PFDRL, the instruction is restricted only when the code in the \( M_1 \) field is 6 or 7; for STCMH, the instruction is restricted only when the \( M_3 \) field is zero and the code in the \( R_1 \) field is 6 or 7.
- \( s^{13} \) Restricted to forward branches in the constrained transactional-execution mode.
- \( s^{14} \) PFD and PFDRL restricted from transactional execution when the code in the \( M_1 \) field is 6 or 7; STCMH restricted when the \( M_3 \) field is zero, and the code in the \( R_1 \) field is 6 or 7.
- \( s^{15} \) PER zero-address-detection not recognized.
- \( 32H \) 32 high-order bits of a register.
- \( 32L \) 32 low-order bits of a register.
- \( A \) Access exceptions for logical addresses.
- \( AI \) Access exceptions for instruction address.
- \( B \) PER branch event.
- \( B_1 \) \( B_1 \) field designates an access register in the access-register mode.
- \( B_2 \) \( B_2 \) field designates an access register in the access-register mode.
- \( BP \) \( B_2 \) field designates an access register when PSW bits 16 and 17 have the value 01 binary.
- \( C \) Condition code is set.
- \( CS \) Compare-and-swap-and-store facility.
- \( CX \) Constrained transactional-execution facility.
- \( Dc \) Compare-and-trap data exception.
- \( Dg \) General-operand data exception.
- \( DO \) Distinct-operands facility.
- \( E \) E instruction format.
- \( EH \) Execution-hint facility.
- \( EI \) Extended-immediate facility.
- \( ET \) Extract-CPU-time facility.
- \( EX \) Execute exception.
- \( E2 \) Extended-translation facility 2.
- \( E3 \) Extended-translation facility 3.
- \( FC \) Designation of access registers depends on the function code of the instruction.

*Figure 7-1. Summary of General Instructions (Part 12 of 14)*
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>FL</td>
<td>Store-facility-list-extended facility.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>G0</td>
<td>Instruction execution includes the implied use of general register 0.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>G1</td>
<td>Instruction execution includes the implied use of general register 1.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>GE</td>
<td>General-instructions-extension facility.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>GM</td>
<td>Instruction execution includes the implied use of multiple general registers:</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>- General registers 1, 2, and 3 for COMPARE AND FORM CODEWORD.</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>- General registers 0 and 1 for CIPHER MESSAGE, CIPHER MESSAGE WITH CHAINING, CIPHER MESSAGE WITH CIPHER FEEDBACK, CIPHER MESSAGE WITH COUNTER, CIPHER MESSAGE WITH OUTPUT FEEDBACK, COMPARE UNTIL SUBSTRING EQUAL, COMPRESSION CALL, COMPUTE INTERMEDIATE MESSAGE DIGEST, COMPUTE LAST MESSAGE DIGEST, COMPUTE MESSAGE AUTHENTICATION CODE, EXTRACT CPU TIME, PERFORM CRYPTOGRAPHIC COMPUTATION, PERFORM LOCKED OPERATION, PERFORM PSEUDORANDOM NUMBER OPERATION, TRANSLATE ONE TO ONE, TRANSLATE ONE TO TWO, TRANSLATE TWO TO ONE, AND TRANSLATE TWO TO TWO</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>- General registers 1 and 2 for TRANSLATE AND TEST and TRANSLATE AND TEST REVERSE.</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>- General registers 0-5 for UPDATE TREE.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HW</td>
<td>High-word facility</td>
<td></td>
<td></td>
</tr>
<tr>
<td>I</td>
<td>1 instruction format.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>I1</td>
<td>Access register 1 is implicitly designated in the access-register mode.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>I2</td>
<td>Access register 2 is implicitly designated in the access-register mode.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>I4</td>
<td>Access register 4 is implicitly designated in the access-register mode.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>IA</td>
<td>Interlocked-access facility 1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>IC</td>
<td>Condition code alternative to interruptible instruction</td>
<td></td>
<td></td>
</tr>
<tr>
<td>IE</td>
<td>IE instruction format.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>IF</td>
<td>Fixed-point-overflow exception.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>II</td>
<td>Interruptible instruction.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>IK</td>
<td>Fixed-point-divide exception.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>L</td>
<td>New condition code is loaded.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>L1</td>
<td>Load/store-on-condition facility 1.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>L2</td>
<td>Load/store-on-condition facility 2.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LD</td>
<td>Long-displacement facility.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LT</td>
<td>Load-and-trap facility</td>
<td></td>
<td></td>
</tr>
<tr>
<td>L2</td>
<td>Load-and-zero-rightmost-byte facility.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ME</td>
<td>Monitor event.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>MI</td>
<td>Miscellaneous-instruction-extensions facility.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>MII</td>
<td>MII instruction format.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>MS</td>
<td>Message-security assist.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>M4</td>
<td>Message-security-assist extension 4.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>M5</td>
<td>Message-security-assist extension 5.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>N3</td>
<td>Instruction is new in z/Architecture and has been added to ESA/390. Any RSY or RXY instructions still use the RSE or RXE format and 12-bit displacements in ESA/390.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PA</td>
<td>Processor-assist facility.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PE</td>
<td>Parsing-enhancement facility.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PK</td>
<td>Population-count facility</td>
<td></td>
<td></td>
</tr>
<tr>
<td>R1</td>
<td>R1 field designates an access register in the access-register mode.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>R2</td>
<td>R2 field designates an access register in the access-register mode.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>R3</td>
<td>R3 field designates an access register in the access-register mode.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RI</td>
<td>RI instruction format.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RIE</td>
<td>RIE instruction format.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RIL</td>
<td>RIL instruction format.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RM</td>
<td>R1 field designates an access register in the access-register mode, and access-register 1 also is used in the access-register mode.</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 7-1. Summary of General Instructions (Part 13 of 14)
### Figure 7-1. Summary of General Instructions (Part 14 of 14)

#### ADD

**Register-and-register formats:**

- **AR**  
  \[
  \begin{array}{c|c|c|c}
  R_{1} & R_{2} & [RR] \\
  \hline
  '1A' & R_{1} & R_{2} \\
  0 & 8 & 12 15
  \end{array}
  \]

- **AGR**  
  \[
  \begin{array}{c|c|c|c}
  R_{1} & R_{2} & [RRE] \\
  \hline
  'B908' & R_{1} & R_{2} \\
  0 & 16 & 24 28 31
  \end{array}
  \]

- **AGFR**  
  \[
  \begin{array}{c|c|c|c}
  R_{1} & R_{2} & [RRE] \\
  \hline
  'B918' & R_{1} & R_{2} \\
  0 & 16 & 24 28 31
  \end{array}
  \]

- **ARK**  
  \[
  \begin{array}{c|c|c|c|c|c}
  R_{1} & R_{2} & R_{3} & [RRF-a] \\
  \hline
  'B9F8' & R_{1} & R_{2} & R_{3} \\
  0 & 16 & 20 & 24 28 31
  \end{array}
  \]

- **AGRK**  
  \[
  \begin{array}{c|c|c|c|c|c}
  R_{1} & R_{2} & R_{3} & [RRF-a] \\
  \hline
  'B9E8' & R_{1} & R_{2} & R_{3} \\
  0 & 16 & 20 & 24 28 31
  \end{array}
  \]

**Register-and-storage formats:**

- **A**  
  \[
  \begin{array}{c|c|c|c|c|c}
  R_{1} & D_{1} & X_{2} & B_{2} & \ [RX-a] \\
  \hline
  '5A' & R_{1} & X_{2} & B_{2} & D_{2} \\
  0 & 8 & 12 & 16 & 20 & 24 31
  \end{array}
  \]

- **AY**  
  \[
  \begin{array}{c|c|c|c|c|c|c|c}
  R_{1} & D_{1} & X_{2} & B_{2} & DL_{2} & DH_{2} & \ [RXY-a] \\
  \hline
  'E3' & R_{1} & X_{2} & B_{2} & DL_{2} & DH_{2} & '5A' \\
  0 & 8 & 12 & 16 & 20 & 32 & 40 47
  \end{array}
  \]

**Characteristics:**

- \(RR\) RR instruction format.
- \(RRE\) RRE instruction format.
- \(RRF\) RRF instruction format.
- \(RRS\) RRS instruction format.
- \(RS\) RS instruction format.
- \(RSI\) RSI instruction format.
- \(RSY\) RSY instruction format.
- \(RX\) RX instruction format.
- \(RXY\) RXY instruction format.
- \(S\) S instruction format.
- \(SC\) Store-clock-fast facility.
- \(SI\) SI instruction format.
- \(SIY\) SIY instruction format.
- \(SMI\) SMI instruction format.
- \(SO\) Special-operation exception.
- \(SP\) Specification exception.
- \(SS\) SS instruction format.
- \(SSF\) SSF instruction format.
- \(ST\) PERF storage-alteration event.
- \(T\) Trace exceptions (includes trace table, addressing, and low-address protection).
- \(TX\) Transactional-execution facility
- \(U_{1}\) \(R_{1}\) field designates an access register unconditionally.
- \(U_{2}\) \(R_{2}\) field designates an access register unconditionally.
- \(UB\) \(R_{1}\) and \(R_{2}\) fields designate access registers unconditionally, and \(B_{2}\) field designates an access register in the access-register mode.
- \(VF\) Vector facility for z/Architecture
- \(XX\) Execute-extension facility.
ADD IMMEDIATE

Register-and-immediate formats:

<table>
<thead>
<tr>
<th>Format</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>AFI</td>
<td>R1,I2</td>
</tr>
<tr>
<td>AGFI</td>
<td>R1,I2</td>
</tr>
<tr>
<td>AHIK</td>
<td>R1,R3,I2</td>
</tr>
<tr>
<td>AGHIK</td>
<td>R1,R3,I2</td>
</tr>
</tbody>
</table>

Storage-and-immediate formats:

<table>
<thead>
<tr>
<th>Format</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ASI</td>
<td>D1(B1),I2</td>
</tr>
<tr>
<td>AGSI</td>
<td>D1(B1),I2</td>
</tr>
</tbody>
</table>

For ADD (A, AR, ARK, and AY) and for ADD IMMEDIATE (AFI), the operands and the sum are treated as 32-bit signed binary integers. For ADD (AG, AGR, and AGRK), they are treated as 64-bit signed binary integers. For ADD (AGFR, AGF) and for ADD IMMEDIATE (AGFI), the second operand is treated as a 32-bit signed binary integer, and the first operand and the sum are treated as 64-bit signed binary integers. For ADD IMMEDIATE (ASI), the second operand is treated as an 8-bit signed binary integer, and the first operand and the sum are treated as 32-bit signed binary integers. For ADD IMMEDIATE (AGSI), the second operand is treated as an 8-bit signed binary integer, and the first operand and the sum are treated as 64-bit signed binary integers. For ADD IMMEDIATE (AHIK), the first and third operands are treated as 32-bit signed binary integers, and the second operand is treated as a 16-bit signed binary integer. For ADD IMMEDIATE (AGHIK), the first and third operands are treated as 64-bit signed binary integers, and the second operand is treated as a 16-bit signed binary integer.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

When the interlocked-access facility 1 is installed and the first operand of ADD IMMEDIATE (ASI, AGSI) is aligned on an integral boundary corresponding to its size, then the fetch and store of the first operand are performed as an interlocked update as observed by other CPUs, and a specific-operand-serialization operation is performed. When the interlocked-access facility 1 is not installed, or when the first operand of ADD IMMEDIATE (ASI, AGSI) is not aligned on an integral boundary corresponding to its size, then the fetch and store of the operand are not performed as an interlocked update.

The displacement for A is treated as a 12-bit unsigned binary integer. The displacement for AY, AG, AGF, AGSI and ASI, is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

- 0 Result zero; no overflow
- 1 Result less than zero; no overflow
- 2 Result greater than zero; no overflow
- 3 Overflow
**Program Exceptions:**

- Access (fetch and store, operand 1 of AGSI and ASI only; fetch, operand 2 of A, AY, AG, and AGF only)
- Fixed-point overflow
- Operation (AY, if the long-displacement facility is not installed; AFI and AGFI, if the extended-immediate facility is not installed; AGSI and ASI, if the general-instructions-extension facility is not installed; ARK, AGRK, AHIK, and AGHIK, if the distinct-operands facility is not installed)

**Programming Notes:**

1. Accesses to the first operand of ADD IMMEDIATE (AGSI and ASI) consist in fetching a first-operand from storage and subsequently storing the updated value.

2. When the interlocked-access facility 1 is not installed, or when the first operand is not aligned on an integral boundary corresponding to its size, the fetch and store accesses to the first operand do not necessarily occur one immediately after the other. Under such conditions, ADD IMMEDIATE (AGSI and ASI) cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown in “Multiprogramming and Multiprocessing Examples” in Appendix A, “Number Representation and Instruction-Use Examples.”

3. For certain programming languages which ignore overflow conditions on arithmetic operations, the setting of condition code 3 obscures the sign of the result. However, for ADD IMMEDIATE, the sign of the $I_2$ field (which is known at the time of code generation) may be used in setting a branch mask which will accurately determine the resulting sign, as shown below.

<table>
<thead>
<tr>
<th>$I_2$ Value</th>
<th>Positive</th>
<th>Negative</th>
<th>Zero</th>
</tr>
</thead>
<tbody>
<tr>
<td>Positive</td>
<td>0010</td>
<td>0101$^a$</td>
<td>1000</td>
</tr>
<tr>
<td>Negative</td>
<td>0011$^b$</td>
<td>0100</td>
<td>1000</td>
</tr>
<tr>
<td>Zero</td>
<td>0010</td>
<td>0100</td>
<td>1000</td>
</tr>
</tbody>
</table>

**Explanation:**

- If the first operand was positive, then a mask of 0001 covers that case (overflow). If the first operand was negative, then a mask of 0100 is appropriate. Combining the two gives a mask of 0101.
- Similarly, a mask of 0010 (first operand was positive) and mask of 0001 (first operand was negative) yields a mask of 0011 which covers both cases.
- A separate test for zero may be required when the $I_2$ field contains 80000000 hex.

The technique described above is also applicable to ADD HALFWORD IMMEDIATE.

**ADD HALFWORD**

\[
\text{ADD HALFWORD IMMEDIATE}
\]

<table>
<thead>
<tr>
<th>$I_2$ Value</th>
<th>Positive</th>
<th>Negative</th>
<th>Zero</th>
</tr>
</thead>
<tbody>
<tr>
<td>Positive</td>
<td>0010</td>
<td>0101$^a$</td>
<td>1000</td>
</tr>
<tr>
<td>Negative</td>
<td>0011$^b$</td>
<td>0100</td>
<td>1000</td>
</tr>
<tr>
<td>Zero</td>
<td>0010</td>
<td>0100</td>
<td>1000</td>
</tr>
</tbody>
</table>

**Explanation:**

- If the first operand was positive, then a mask of 0001 covers that case (overflow). If the first operand was negative, then a mask of 0100 is appropriate. Combining the two gives a mask of 0101.
- Similarly, a mask of 0010 (first operand was positive) and mask of 0001 (first operand was negative) yields a mask of 0011 which covers both cases.
- A separate test for zero may be required when the $I_2$ field contains 80000000 hex.

**ADD HALFWORD IMMEDIATE**

<table>
<thead>
<tr>
<th>$I_2$ Value</th>
<th>Positive</th>
<th>Negative</th>
<th>Zero</th>
</tr>
</thead>
<tbody>
<tr>
<td>Positive</td>
<td>0010</td>
<td>0101$^a$</td>
<td>1000</td>
</tr>
<tr>
<td>Negative</td>
<td>0011$^b$</td>
<td>0100</td>
<td>1000</td>
</tr>
<tr>
<td>Zero</td>
<td>0010</td>
<td>0100</td>
<td>1000</td>
</tr>
</tbody>
</table>
The second operand is added to the first operand, and the sum is placed at the first-operand location. The second operand is two bytes in length and is treated as a 16-bit signed binary integer. For ADD HALFWORD (AH, AHY) and ADD HALFWORD IMMEDIATE (AHI), the first operand and the sum are treated as 32-bit signed binary integers. For ADD HALFWORD IMMEDIATE (AGHI), they are treated as 64-bit signed binary integers.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

The displacement for AH is treated as a 12-bit unsigned binary integer. The displacement for AHY is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

0  Result zero; no overflow
1  Result less than zero; no overflow
2  Result greater than zero; no overflow
3  Overflow

**Program Exceptions:**

- Access (fetch, operand 2 of AH, AHY)
- Fixed-point overflow
- Operation (AHY, if the long-displacement facility is not installed)

**Programming Notes:**

1. An example of the use of the ADD HALFWORD instruction is given in Appendix A, "Number Representation and Instruction-Use Examples."

2. See programming note 3 on page 7-27 for ADD IMMEDIATE regarding the implications of ignoring overflow.

### ADD HIGH

- **AHHLR**  
  
  \[ R_{1}, R_{2}, R_{3} \]  
  
  \[ \text{[RRF-a]} \]

  
<table>
<thead>
<tr>
<th>B9D8</th>
<th>R3</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
<td>24</td>
</tr>
</tbody>
</table>

  The second operand is added to the third operand, and the sum is placed at the first-operand location. The operands and the sum are treated as 32-bit signed binary integers. The first and second operands are in bits 0-31 of general registers \(R_1\) and \(R_2\), respectively; bits 32-63 of general register \(R_1\) are unchanged, and bits 32-63 of general register \(R_2\) are ignored. For AHHHR, the third operand is in bits 0-31 of general register \(R_3\); bits 32-63 of the register are ignored. For AHHLR, the third operand is in bits 32-63 of general register \(R_3\); bits 0-31 of the register are ignored.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

**Resulting Condition Code:**

0  Result zero; no overflow
1  Result less than zero; no overflow
2  Result greater than zero; no overflow
3  Overflow

**Program Exceptions:**

- Fixed-point overflow
- Operation (if the high-word facility is not installed)

### ADD IMMEDIATE HIGH

- **AIH**  
  
  \[ R_{1}, I_2 \]  
  
  \[ \text{[RIL-a]} \]

<table>
<thead>
<tr>
<th>'CC'</th>
<th>'8'</th>
<th>I2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

  The second operand is added to the first operand, and the sum is placed at the first-operand location. The operands and the sum are treated as 32-bit signed binary integers. The first operand is in bits 0-31 of general register \(R_1\); bits 32-63 of the register are unchanged.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignor-
ing any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

**Resulting Condition Code:**

0  Result zero; no overflow
1  Result less than zero; no overflow
2  Result greater than zero; no overflow
3  Overflow

**Program Exceptions:**

- Fixed-point overflow
- Operation (if the high-word facility is not installed)

### ADD LOGICAL

**Register-and-register formats:**

\[\text{ALR } R_1, R_2 \quad [\text{RR}]\]

\[\begin{array}{lllllll}
\text{'1E'} & R_1 & R_2 & 0 & 8 & 12 & 15
\end{array}\]

\[\text{ALGR } R_1, R_2 \quad [\text{RRE}]\]

\[\begin{array}{lllllll}
\text{'B9A'} & R_1 & R_2 & 0 & 16 & 24 & 28 & 31
\end{array}\]

\[\text{ALGFR } R_1, R_2 \quad [\text{RRE}]\]

\[\begin{array}{lllllll}
\text{'B91A'} & R_1 & R_2 & 0 & 16 & 24 & 28 & 31
\end{array}\]

\[\text{ALRK } R_1, R_2, R_3 \quad [\text{RRF-a}]\]

\[\begin{array}{llllllll}
\text{'B9FA'} & R_3 & R_1 & R_2 & 0 & 16 & 20 & 24 & 28 & 31
\end{array}\]

\[\text{ALGRK } R_1, R_2, R_3 \quad [\text{RRF-a}]\]

\[\begin{array}{lllllll}
\text{'B9EA'} & R_3 & R_1 & R_2 & 0 & 16 & 20 & 24 & 28 & 31
\end{array}\]

**Register-and-storage formats:**

\[\text{AL } R_1, D_2(X_2, B_2) \quad [\text{RX-a}]\]

\[\begin{array}{llllllll}
\text{'5E'} & R_1 & X_2 & B_2 & 0 & 8 & 12 & 16 & 20 & 31
\end{array}\]

\[\text{ALY } R_1, D_2(X_2, B_2) \quad [\text{RXY-a}]\]

\[\begin{array}{llllllll}
\text{'E3'} & R_1 & X_2 & B_2 & DL_2 & DH_2 & 0 & 8 & 12 & 16 & 20 & 32 & 40 & 47
\end{array}\]

\[\text{ALG } R_1, D_2(X_2, B_2) \quad [\text{RXY-a}]\]

\[\begin{array}{llllllll}
\text{'E3'} & R_1 & X_2 & B_2 & DL_2 & DH_2 & 0 & 8 & 12 & 16 & 20 & 32 & 40 & 47
\end{array}\]

\[\text{ALGF } R_1, D_2(X_2, B_2) \quad [\text{RXY-a}]\]

\[\begin{array}{llllllll}
\text{'E3'} & R_1 & X_2 & B_2 & DL_2 & DH_2 & 0 & 8 & 12 & 16 & 20 & 32 & 40 & 47
\end{array}\]

\[\text{ADD LOGICAL IMMEDIATE}\]

\[\text{ALFI } R_1, I_2 \quad [\text{RIL-a}]\]

\[\begin{array}{llllllll}
\text{'C2'} & R_1 & 'B' & I_2 & 0 & 8 & 12 & 16 & 47
\end{array}\]

\[\text{ALGFI } R_1, I_2 \quad [\text{RIL-a}]\]

\[\begin{array}{llllllll}
\text{'C2'} & R_1 & 'A' & I_2 & 0 & 8 & 12 & 16 & 47
\end{array}\]

For ADD LOGICAL (AL, ALG, ALGF, ALGFR, ALGR, ALR, and ALY) and for ADD LOGICAL IMMEDIATE (ALGFI and ALFI), the second operand is added to the first operand, and the sum is placed at the first operand location. For ADD LOGICAL (ALGRK and ALRK), the second operand is added to the third operand, and the sum is placed at the first operand location.

For ADD LOGICAL (AL, ALG, ALR, ALRK, and ALY) and for ADD LOGICAL IMMEDIATE (ALFI), the operands and the sum are treated as 32-bit unsigned binary integers. For ADD LOGICAL (ALG, ALGR, and ALGRK), they are treated as 64-bit unsigned binary integers. For ADD LOGICAL (ALGFR, ALGF) and for ADD LOGICAL IMMEDIATE (ALGFI), the second operand is treated as a 32-bit unsigned binary integer, and the first operand and the sum are treated as 64-bit unsigned binary integers.

The displacement for AL is treated as a 12-bit unsigned binary integer. The displacement for ALY, ALG, and ALGF is treated as a 20-bit signed binary integer.
ADD LOGICAL HIGH

\begin{align*}
\text{ALHHHR} & \quad R_1, R_2, R_3 & \text{[RRF-a]} \\
\text{'B9CA'} & \quad R_3 \quad / / / / \quad R_1 \quad R_2 \\
\end{align*}

\begin{align*}
\text{ALHHLR} & \quad R_1, R_2, R_3 & \text{[RRF-a]} \\
\text{'B9DA'} & \quad R_3 \quad / / / / \quad R_1 \quad R_2 \\
\end{align*}

The second operand is added to the third operand, and the sum is placed at the first-operand location. The operands and the sum are treated as 32-bit unsigned binary integers. The first and second operands are in bits 0-31 of general registers \( R_1 \) and \( R_2 \), respectively; bits 32-63 of general register \( R_1 \) are unchanged, and bits 32-63 of general register \( R_2 \) are ignored. For ALHHHR, the third operand is in bits 0-31 of general register \( R_3 \); bits 32-63 of the register are ignored. For ALHHLR, the third operand is in bits 32-63 of general register \( R_3 \); bits 0-31 of the register are ignored.

Resulting Condition Code:

\begin{itemize}
\item 0 Result zero; no carry
\item 1 Result not zero; no carry
\item 2 Result zero; carry
\item 3 Result not zero; carry
\end{itemize}

Program Exceptions:

\begin{itemize}
\item Access (fetch, operand 2 of AL, ALY, ALG, and ALGF only)
\item Operation (ALY, if the long-displacement facility is not installed; ALFI and ALGFI, if the extended-immediate facility is not installed; ALRK and ALGRK, if the distinct-operands facility is not installed)
\end{itemize}

ADD LOGICAL WITH CARRY

\begin{align*}
\text{Register-and-register formats:} \\
\text{ALCR} & \quad R_1, R_2 & \text{[RRE]} \\
\text{ALCGR} & \quad R_1, R_2 & \text{[RRE]} \\
\end{align*}

\begin{align*}
\text{Register-and-storage formats:} \\
\text{ALC} & \quad R_1, D_2(X_2, B_2) & \text{[RXY-a]} \\
\text{ALCG} & \quad R_1, D_2(X_2, B_2) & \text{[RXY-a]} \\
\end{align*}

The second operand and the carry are added to the first operand, and the sum is placed at the first-operand location. For ADD LOGICAL WITH CARRY (ALCR, ALC), the operands, the carry, and the sum are treated as 32-bit unsigned binary integers. For ADD LOGICAL WITH CARRY (ALCGR, ALCG), they are treated as 64-bit unsigned binary integers.

Resulting Condition Code:

\begin{itemize}
\item 0 Result zero; no carry
\item 1 Result not zero; no carry
\item 2 Result zero; carry
\item 3 Result not zero; carry
\end{itemize}

Program Exceptions:

\begin{itemize}
\item Access (fetch, operand 2 of ALC and ALCG only)
\end{itemize}

Programming Notes:

\begin{itemize}
\item A carry is represented by a one value of bit 18 of the current PSW. Bit 18 is the leftmost bit of the two-bit condition code in the PSW. Bit 18 is set to one by an execution of an ADD LOGICAL or ADD LOGICAL WITH CARRY instruction that produces a carry out of bit position 0 of the result.
\end{itemize}
2. ADD and ADD LOGICAL may provide better performance than ADD LOGICAL WITH CARRY, depending on the model.

**ADD LOGICAL WITH SIGNED IMMEDIATE**

*Storage-and-immediate formats:*

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Field Description</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALSI</td>
<td>D,(B1),I2</td>
<td>[SIY]</td>
</tr>
<tr>
<td>ALGSI</td>
<td>D,(B1),I2</td>
<td>[SIY]</td>
</tr>
</tbody>
</table>

*Register-and-immediate formats:*

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Field Description</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALHSIK</td>
<td>R1,R3,I2</td>
<td>[RIE-d]</td>
</tr>
<tr>
<td>ALGHSIK</td>
<td>R1,R3,I2</td>
<td>[RIE-d]</td>
</tr>
</tbody>
</table>

For ALGSI and ALSI, the second operand is added to the first operand, and the sum is placed at the first-operand location. For ALGHSIK and ALHSIK, the second operand is added to the third operand, and the sum is placed at the first-operand location.

For ALSI, the first operand and the sum are treated as 32-bit unsigned binary integers. For ALGSI, the first operand and the sum are treated as 64-bit unsigned binary integers. For both ALSI and ALGSI, the second operand is treated as an 8-bit signed binary integer.

For ALHSIK, the first and third operands are treated as 32-bit unsigned binary integers. For ALGHSIK, the first and third operands are treated as 64-bit unsigned binary integers. For both ALGHSIK and ALHSIK, the second operand is treated as a 16-bit signed binary integer.

When the second operand contains a negative value, the condition code is set as though a SUBTRACT LOGICAL operation was performed. Condition code 0 is never set when the second operand is negative.

The displacement is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Result zero; no carry</td>
</tr>
<tr>
<td>1</td>
<td>Result not zero; no carry</td>
</tr>
<tr>
<td>2</td>
<td>Result zero; carry</td>
</tr>
<tr>
<td>3</td>
<td>Result not zero; carry</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch and store, operand 1)
- Operation (ALGSI and ALSI, if the general-instructions-extension facility is not installed; ALGHSIK, and ALHSIK, if the distinct-operands facility is not installed)

**Programming Notes:**

1. When the second operand contains a negative value, the condition-code setting can also be interpreted as indicating the presence or absence of a borrow, as follows:

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Result not zero; borrow</td>
</tr>
<tr>
<td>2</td>
<td>Result zero; no borrow</td>
</tr>
<tr>
<td>3</td>
<td>Result not zero; no borrow</td>
</tr>
</tbody>
</table>

2. Accesses to the first operand of consist in fetching a first-operand from storage and subsequently storing the updated value.

When the interlocked-access facility 1 is not installed, or when the first operand is not aligned on an integral boundary corresponding to its size, the fetch and store accesses to the first operand do not necessarily occur one immediately after the other. Under such conditions, ADD LOGICAL WITH SIGNED IMMEDIATE cannot be
safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown in “Multiprogramming and Multiprocessing Examples” in Appendix A, “Number Representation and Instruction-Use Examples.”

When the interlocked-access facility 1 is installed and the first operand is aligned on an integral boundary corresponding to its size, the operand is accessed using a block-concurrent interlocked update.

3. When the second operand is negative, the instruction effectively performs a subtraction operation.

**ADD LOGICAL WITH SIGNED IMMEDIATE HIGH**

\[
\text{ALSIH} \quad R_1, I_2 \quad [RIL-a]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|c|c|}
\hline
& 0 & 8 & 12 & 16 & 20 & 24 & 28 & 32 \\
\hline
CC' & R_1 & 'A' & I_2 & & & & & \\
\hline
\end{array}
\]

\[
\text{ALSIHN} \quad R_1, I_2 \quad [RIL-a]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|c|c|}
\hline
& 0 & 8 & 12 & 16 & 20 & 24 & 28 & 32 \\
\hline
CC' & R_1 & 'B' & I_2 & & & & & \\
\hline
\end{array}
\]

The second operand is added to the first operand, and the sum is placed at the first-operand location. The first operand and the sum are treated as 32-bit unsigned binary integers. The second operand is treated as a 32-bit signed binary integer. The first operand is in bits 0-31 of general register \( R_1 \); bits 32-63 of the register are unchanged.

**Resulting Condition Code:**

For ALSIH, the code is set as follows:

0  Result zero; no carry
1  Result not zero; no carry
2  Result zero; carry
3  Result not zero; carry

For ALSIHN, the code remains unchanged.

**Program Exceptions:**

- Operation (if the high-word facility is not installed)

**Programming Note:** See programming notes 1 and 3 for ADD LOGICAL WITH SIGNED IMMEDIATE.

**AND**

**Register-and-register formats:**

\[
\text{NR} \quad R_1, R_2 \quad [RR]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|}
\hline
& 0 & 8 & 12 & 15 \\
\hline
'14' & R_1 & R_2 & & & & \\
\hline
\end{array}
\]

\[
\text{NGR} \quad R_1, R_2 \quad [RRE]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|c|c|}
\hline
& 0 & 16 & 24 & 28 & 31 \\
\hline
'B980' & & & & & & & & \\
\hline
\end{array}
\]

\[
\text{NRK} \quad R_1, R_2, R_3 \quad [RRF-a]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|c|c|}
\hline
& 0 & 16 & 20 & 24 & 28 & 31 \\
\hline
'B9F4' & & & & & & & & \\
\hline
\end{array}
\]

\[
\text{NGR} \quad R_1, R_2, R_3 \quad [RRF-a]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|c|c|}
\hline
& 0 & 16 & 20 & 24 & 28 & 31 \\
\hline
'B9E4' & & & & & & & & \\
\hline
\end{array}
\]

**Register-and-storage formats:**

\[
\text{N} \quad R_1, D_2(X_2, B_2) \quad [RX-a]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|}
\hline
& 0 & 8 & 12 & 16 & 20 & 31 \\
\hline
'54' & R_1 & X_2 & B_2 & & & \\
\hline
\end{array}
\]

\[
\text{NY} \quad R_1, D_2(X_2, B_2) \quad [RXY-a]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline
& 0 & 8 & 12 & 16 & 20 & 24 & 28 & 32 & 40 & 47 \\
\hline
'E3' & R_1 & X_2 & B_2 & DL_2 & DH_2 & '54' \\
\hline
\end{array}
\]

\[
\text{NG} \quad R_1, D_2(X_2, B_2) \quad [RXY-a]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline
& 0 & 8 & 12 & 16 & 20 & 24 & 28 & 32 & 40 & 47 \\
\hline
'E3' & R_1 & X_2 & B_2 & DL_2 & DH_2 & '80' \\
\hline
\end{array}
\]

**Storage-and-immediate formats:**

\[
\text{NI} \quad D_1(B_1), I_2 \quad [SI]
\]

\[
\begin{array}{|c|c|c|c|c|}
\hline
& 0 & 8 & 12 & 16 & 20 \\
\hline
'94' & I_2 & B_1 & D_1 & & \\
\hline
\end{array}
\]

\[
\text{NIY} \quad D_1(B_1), I_2 \quad [SIY]
\]

\[
\begin{array}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline
& 0 & 8 & 12 & 16 & 20 & 24 & 28 & 32 & 40 & 47 \\
\hline
'EB' & I_2 & B_1 & DL_1 & DH_1 & '54' \\
\hline
\end{array}
\]
Storage-and-storage format:

\[
\begin{array}{cccc}
\text{NC} & D_1(L,B_1),D_2(B_2) & [SS-a] \\
0 & 8 & 16 & 20 & 32 & 36 & 47
\end{array}
\]

For N, NC, NG, NGR, NI, NIY, NR, and NY, the AND of the first and second operands is placed at the first-operand location. For NGRK and NRK, the AND of the second and third operands is placed at the first-operand location.

The connective AND is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the corresponding bit positions in both operands contain ones; otherwise, the result bit is set to zero.

For AND (NC), each operand is processed left to right. When the operands overlap, the result is obtained as if the operands were processed one byte at a time and each result byte were stored immediately after fetching the necessary operand bytes.

For AND (NI, NIY), the first operand is one byte in length, and only one byte is stored. When the interlocked-access facility 2 is installed, the update of the first operand appears to be an interlocked-update reference as observed by other CPUs and channel programs, and a specific-operand-serialization operation is performed.

For AND (N, NR, NRK, and NY), the operands are 32 bits, and for AND (NG, NGR, and NGRK), they are 64 bits.

The displacements for N, NI, and both operands of NC are treated as 12-bit unsigned binary integers. The displacement for NY, NIY, and NG is treated as a 20-bit signed binary integer.

Resulting Condition Code:

<table>
<thead>
<tr>
<th>0</th>
<th>Result zero</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Result not zero</td>
</tr>
<tr>
<td>2</td>
<td>--</td>
</tr>
<tr>
<td>3</td>
<td>--</td>
</tr>
</tbody>
</table>

Program Exceptions:

- Access (fetch, operand 2, N, NY, NG, and NC; fetch and store, operand 1, NI, NIY, and NC)
- Operation (NY and NIY, if the long-displacement facility is not installed; NGRK and NRK, if the distinct-operands facility is not installed)
- Transaction constraint (NC)

Programming Notes:

1. An example of the use of the AND instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. The AND instruction may be used to set a bit to zero.
3. Accesses to the first operand of AND (NC) – and, when the interlocked-access facility 2 is not installed, accesses to the first operand of AND (NI, NIY) – consist in fetching a first-operand byte from storage and subsequently storing the updated value. These fetch and store accesses to a particular byte do not necessarily occur one immediately after the other. Thus, these instructions cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown for OR (OI) in “Multiprogramming and Multiprocessing Examples” on page A-45.

When the interlocked-access facility 2 is installed, AND (NI, NIY) can be safely used to update a location in storage, even if the possibility exists that another CPU or a channel program may also be updating the location.

**AND IMMEDIATE**

<table>
<thead>
<tr>
<th>NIHF</th>
<th>R_1, l_2</th>
<th>[RIL-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C0'</td>
<td>R_1 'A'</td>
<td>l_2</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>NIHH</th>
<th>R_1, l_2</th>
<th>[RIL-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'A5'</td>
<td>R_1 '4'</td>
<td>l_2</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>NIHL</th>
<th>R_1, l_2</th>
<th>[RIL-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'A5'</td>
<td>R_1 '5'</td>
<td>l_2</td>
</tr>
</tbody>
</table>
The second operand is ANDed with bits of the first operand, and the result replaces those bits of the first operand. The remainder of the first operand remains unchanged.

For each instruction, the bits of the first operand that are ANDed with the second operand and then replaced are as follows:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Bits ANDed and Replaced</th>
</tr>
</thead>
<tbody>
<tr>
<td>NIHF</td>
<td>0-31</td>
</tr>
<tr>
<td>NIHH</td>
<td>0-15</td>
</tr>
<tr>
<td>NIHL</td>
<td>16-31</td>
</tr>
<tr>
<td>NILF</td>
<td>32-63</td>
</tr>
<tr>
<td>NILH</td>
<td>32-47</td>
</tr>
<tr>
<td>NILL</td>
<td>48-63</td>
</tr>
</tbody>
</table>

The connective AND is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the corresponding bit positions in both operands contain ones; otherwise, the result bit is set to zero.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Result is zero</td>
</tr>
<tr>
<td>1</td>
<td>Result is not zero</td>
</tr>
<tr>
<td>2</td>
<td>--</td>
</tr>
<tr>
<td>3</td>
<td>--</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Operation (NIHF, NILF, if the extended-immediate facility is not installed)

---

**Programming Note:** The setting of the condition code is based only on the bits that are ANDed and replaced.

**BRANCH AND LINK**

**Register-and-register format:**

\[
\text{BRANCH AND LINK (RR format):}
\]

\[
\text{BALR R1 R2} \quad (\text{RR})
\]

**Register-and-storage format:**

\[
\text{BRANCH AND LINK (RX format):}
\]

\[
\text{BAL R1 D2(X2 B2)} \quad (\text{RX})
\]

Information from the current PSW, including the updated instruction address, is saved as link information at the first-operand location. Subsequently, the instruction address in the PSW is replaced by the branch address.

The link information in the 24-bit addressing mode consists of the instruction-length code (ILC), the condition code (CC), the program-mask bits, and the rightmost 24 bits of the updated instruction address, arranged in bit positions 32-63 of the first-operand location in the following format:

\[
\text{ILC CC Prog Mask Instruction Address}
\]

When BRANCH AND LINK is not the target of an execute-type instruction, the ILC is set to 1 for BALR or 2 for BAL. When BRANCH AND LINK is the target of an EXECUTE instruction, the ILC is set to 2. When BRANCH AND LINK is the target of an EXECUTE RELATIVE LONG instruction, the ILC is set to 3.

The link information in the 31-bit addressing mode consists of bit 32 of the PSW, the basic-addressing-mode bit (always a one) and the rightmost 31 bits of the updated instruction address, arranged in bit positions 32-63 of the first-operand location in the following format:
In the 24-bit or 31-bit addressing mode, bits 0-31 of the first-operand location remain unchanged.

The link information in the 64-bit addressing mode consists of the updated instruction address, placed in bit positions 0-63 of the first-operand location.

In the RX format, the second-operand address is used as the branch address. In the RR format, the contents of general register R2 are used to generate the branch address; however, when the R2 field is zero, the operation is performed without branching. The branch address is computed before general register R1 is changed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Trace (R2 field nonzero, BALR only)
- Transaction constraint

**Programming Notes:**
1. An example of the use of the BRANCH AND LINK instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. When the R2 field in the RR format is zero, the link information is loaded without branching.
3. The BRANCH AND LINK instruction (BAL and BALR) is provided for compatibility purposes. It is recommended that, where possible, the BRANCH AND SAVE instruction (BAS and BASR), BRANCH RELATIVE AND SAVE, or BRANCH RELATIVE AND SAVE LONG be used and BRANCH AND LINK avoided, since the latter places nonzero information in bit positions 32-39 of the link register in the 24-bit addressing mode, which may lead to problems. Additionally, in the 24-bit addressing mode, BRANCH AND LINK may be slower than the other instructions because BRANCH AND LINK must construct the ILC, condition code, and program mask to be placed in bit positions 32-39 of the link register.
4. The condition-code and program-mask information, which is provided in the leftmost byte of the link information only in the 24-bit addressing mode, can be obtained in any addressing mode by means of the INSERT PROGRAM MASK instruction.

**BRANCH AND SAVE**

**BASR** R1,R2 [RR]

<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>12</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>'0D'</td>
<td>R1</td>
<td>R2</td>
<td></td>
</tr>
</tbody>
</table>

**BAS** R1,D2(X2,B2) [RX-a]

<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>12</th>
<th>16</th>
<th>20</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>'4D'</td>
<td>R1</td>
<td>X2</td>
<td>B2</td>
<td>D2</td>
<td></td>
</tr>
</tbody>
</table>

Information from the current PSW, including the updated instruction address, is saved as link information at the first-operand location. Subsequently, the instruction address in the PSW is replaced by the branch address.

In the 24-bit or 31-bit addressing mode, the link information is bits 32 and 97-127 of the PSW, consisting of the basic-addressing-mode bit and the rightmost 31 bits of the updated instruction address. The link information is placed in bit positions 32 and 33-63, respectively, of the first-operand location, and bits 0-31 of the location remain unchanged.

In the 64-bit addressing mode, the link information consists of the updated instruction address, placed in bit positions 0-63 of the first-operand location.

In the RX format, the second-operand address is used as the branch address. In the RR format, the contents of general register R2 are used to generate the branch address; however, when the R2 field is zero, the operation is performed without branching. The branch address is computed before general register R1 is changed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Trace (R2 field nonzero, BASR only)
- Transaction constraint

**Programming Notes:**
1. An example of the use of the BRANCH AND SAVE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. The BRANCH AND SAVE instruction (BAS and BASR) is intended to be used for linkage to pro-
BRANCH AND SAVE AND SET MODE

BASSM R1,R2 [RR]

Information from the current PSW, including the updated instruction address, is saved as link information at the first-operand location. Subsequently, if the R2 field is nonzero, the addressing-mode bits and instruction address in the PSW are replaced as specified by the second operand.

In the 24-bit or 31-bit addressing mode, the link information is bits 32 and 97-127 of the PSW, consisting of the basic-addressing-mode bit and the rightmost 31 bits of the updated instruction address. The link information is placed in bit positions 32 and 33-63, respectively, of the first-operand location, and bits 0-31 of the location remain unchanged. In the 64-bit addressing mode, the link information is bits 64-126 of the PSW with a one appended on the right, placed in bit positions 0-63 of the first-operand location.

The contents of general register R2 specify the new addressing mode and designate the branch address; however, when the R2 field is zero, the operation is performed without branching and without setting either addressing-mode bit.

When the contents of general register R2 are used and bit 63 of the register is zero, bit 31 of the current PSW, the extended-addressing-mode bit, is set to zero, bit 32 of the register specifies the new basic addressing mode and replaces bit 32 of the PSW, and the branch address is generated from the contents of the register under the control of the new addressing mode. The branch address replaces the instruction address in the PSW.

When the contents of general register R2 are used and bit 63 of the register is one, the following occurs. Bits 31 and 32 of the current PSW are set to one, the branch address is generated from the contents of the register, except with bit 63 of the register treated as a zero, under the control of the new extended addressing mode, and the branch address replaces the instruction address in the PSW. Bit 63 of the register remains one. However, if R2 is the same as R1, the results in the designated general register are as specified for the R1 register.

The new value for the PSW is computed before general register R1 is changed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Trace (R2 field nonzero)
- Transaction constraint

**Programming Notes:**

1. An example of the use of the BRANCH AND SAVE AND SET MODE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. BRANCH AND SAVE AND SET MODE is intended to be the principal calling instruction to subroutines which may operate in a different addressing mode from that of the caller. See the programming notes on pages 5-15 and 5-18 in the section “Subroutine Linkage without the Linkage Stack” for a detailed discussion of this and other linkage instructions.

3. An old 24-bit or 31-bit program can use BRANCH AND SAVE AND SET MODE to call a new 64-bit program without any change, provided that bits 0-31 of general register R2 are all zeros. The old program can load into bit positions 32-63 of general register R2 a four-byte address constant, which is provided from outside the program, in which bit 63 in the register (bit 31 of the constant in storage) either is or is not one. If the addressing mode is not changed to the 64-bit mode by the execution of the BRANCH AND SAVE AND SET MODE instruction, or even if it is, the called program can set the 64-bit mode by issuing a SET ADDRESSING MODE (SAM64) instruction.

4. See the programming notes on page 5-15 (under “Simple Branch Instructions”).
**BRANCH AND SET MODE**

BSM R1,R2 [RR]

```
0B R1 R2
```

In the 24-bit or 31-bit addressing mode, bit 32 of the current PSW, the basic-addressing-mode bit, is inserted into bit position 32 of the first operand, and bits 0-31 and 33-63 of the operand remain unchanged. In the 64-bit addressing mode, a one is inserted into bit position 63 of the first operand, and bits 0-62 of the operand remain unchanged. Subsequently, the addressing-mode bits and instruction address in the PSW are replaced as specified by the second operand. The action associated with an operand is not performed if the associated R field is zero.

The contents of general register R2 specify the new addressing mode and designate the branch address; however, when the R2 field is zero, the operation is performed without branching and without setting either addressing-mode bit.

When the contents of general register R2 are used and bit 63 of the register is zero, bit 31 of the current PSW, the extended-addressing-mode bit, is set to zero, bit 32 of the register specifies the new basic addressing mode and replaces bit 32 of the PSW, and the branch address is generated from the contents of the register under the control of the new addressing mode. The branch address replaces the instruction address in the PSW.

When the contents of general register R2 are used and bit 63 of the register is one, the following occurs. Bits 31 and 32 of the current PSW are set to one, the branch address is generated from the contents of the register, except with bit 63 of the register treated as a zero, under the control of the new extended addressing mode, and the branch address replaces the instruction address in the PSW. Bit 63 of the register remains one. However, if R2 is the same as R1, the results in the designated general register are as specified for the R1 register.

The new value for the PSW is computed before general register R1 is changed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Trace
- Transaction constraint

**Programming Notes:**

1. An example of the use of the BRANCH AND SET MODE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. BRANCH AND SET MODE with an R1 field of zero is intended to be the standard return instruction in a program entered by means of BRANCH AND SAVE AND SET MODE. It can also be the return instruction in a program entered in the 24-bit or 31-bit addressing mode by means of BRANCH AND SAVE, BRANCH RELATIVE AND SAVE, or BRANCH RELATIVE AND SAVE LONG. BRANCH AND SET MODE with a nonzero R1 field is intended to be used in a “glue module” to connect either old 24-bit programs and newer programs that are executed in the 31-bit addressing mode or old 24-bit or 31-bit programs and new programs that are executed in the 64-bit addressing mode. See the programming notes on pages 5-15 and 5-18 in the section “Subroutine Linkage without the Linkage Stack” for a detailed discussion of this and other linkage instructions.

**BRANCH ON CONDITION**

BCR M1,R2 [RR]

```
07 M1 R2
```

BC M1,D2(X2,B2) [RX-b]

```
47 M1 X2 B2 D2
```

The instruction address in the current PSW is replaced by the branch address if the condition code has one of the values specified by M1; otherwise, normal instruction sequencing proceeds with the updated instruction address.

In the RX format, the second-operand address is used as the branch address. In the RR format, the contents of general register R2 are used to generate the branch address; however, when the R2 field is zero, the operation is performed without branching.

7-37
The M1 field is used as a four-bit mask. The four condition codes (0, 1, 2, and 3) correspond, left to right, with the four bits of the mask, as follows:

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Instruction Bit Number of Mask</th>
<th>Mask Position Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>1</td>
<td>9</td>
<td>4</td>
</tr>
<tr>
<td>2</td>
<td>10</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>11</td>
<td>1</td>
</tr>
</tbody>
</table>

The current condition code is used to select the corresponding mask bit. If the mask bit selected by the condition code is one, the branch is successful. If the mask bit selected is zero, normal instruction sequencing proceeds with the next sequential instruction.

When the M1 and R2 fields of BRANCH ON CONDITION (BCR) are 1111 binary and 0000 binary, respectively, a serialization and checkpoint-synchronization function is performed. When the fast-BCR-serialization facility is installed and the M1 and R2 fields of BRANCH ON CONDITION (BCR) are 1110 binary and 0000 binary, respectively, a serialization function is performed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Transaction constraint

**Programming Notes:**

1. An example of the use of the BRANCH ON CONDITION instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. When a branch is to depend on more than one condition, the pertinent condition codes are specified in the mask as the sum of their mask position values. A mask of 12, for example, specifies that a branch is to be made when the condition code is 0 or 1.

3. When all four mask bits are zeros or when the R2 field in the RR format contains zero, the branch instruction is equivalent to a no-operation. When all four mask bits are ones, that is, the mask value is 15, the branch is unconditional unless the R2 field in the RR format is zero.

4. Execution of BCR 15,0 (that is, an instruction with a value of 07F0 hex) may result in significant performance degradation. To ensure optimum performance, the program should avoid use of BCR 15,0 except in cases when the serialization or checkpoint-synchronization function is actually required.

When the fast-BCR-serialization facility is installed, and the program only needs the serialization function (without the checkpoint synchronization function), then BCR 14,0 should be used. Depending on the model, this may be faster than BCR 15,0.

5. Note that the relation between the RR and RX formats in branch-address specification is not the same as in operand-address specification. For branch instructions in the RX format, the branch address is the address specified by X2, B2, and D2; in the RR format, the branch address is contained in the register designated by R2. For operands, the address specified by X2, B2, and D2 is the operand address, but the register designated by R2 contains the operand, not the operand address.

### BRANCH ON COUNT

**Register-and-register formats:**

\[
\text{BCTR } R_1, R_2 \quad \text{[RR]} \\
\begin{array}{c|cc|cc}
 \text{0} & \text{8} & \text{12} & \text{15} \\
\end{array}
\]

\[
\text{BCTGR } R_1, R_2 \quad \text{[RRE]} \\
\begin{array}{c|c|cccc}
 'B946' & \text{R1} & \text{R2} \\
 0 & 8 & 12 & 24 & 28 & 31 \\
\end{array}
\]

**Register-and-storage formats:**

\[
\text{BCT } R_1, D_2(X_2, B_2) \quad \text{[RX-a]} \\
\begin{array}{c|cc|c}
 '46' & \text{R1} & X_2 & B_2 \\
 0 & 8 & 12 & 20 & 31 \\
\end{array}
\]

\[
\text{BCTG } R_1, D_2(X_2, B_2) \quad \text{[RXY-a]} \\
\begin{array}{c|cc|cccc}
 'E3' & \text{R1} & X_2 & B_2 & DL_2 & DH_2 & '46' \\
 0 & 8 & 12 & 16 & 20 & 32 & 40 & 47 \\
\end{array}
\]

A one is subtracted from the first operand, and the result is placed at the first-operand location. For
BRANCH ON COUNT (BCT, BCTR), the first operand and result are treated as 32-bit binary integers, with overflow ignored. For BRANCH ON COUNT (BCTG, BCTGR), the first operand and result are treated as 64-bit binary integers, with overflow ignored. When the result is zero, normal instruction sequencing proceeds with the updated instruction address. When the result is not zero, the instruction address in the current PSW is replaced by the branch address.

In the RX or RXY format, the second-operand address is used as the branch address. In the RR or RRE format, the contents of general register $R_2$ are used to generate the branch address; however, when the $R_2$ field is zero, the operation is performed without branching. The branch address is generated before general register $R_1$ is changed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Transaction constraint

**Programming Notes:**

1. An example of the use of the BRANCH ON COUNT instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The first operand and result can be considered as either signed or unsigned binary integers since the result of a binary subtraction is the same in both cases.

3. An initial count of one results in zero, and no branching takes place; an initial count of zero results in -1 and causes branching to be performed; an initial count of -1 results in -2 and causes branching to be performed; and so on. In a loop, branching takes place each time the instruction is executed until the result is again zero. Note that for BCT or BCTR, because of the number range, an initial count of $-2^{31}$ results in a positive value of $2^{31} - 1$, or, for BCTG or BCTGR, an initial count of $-2^{63}$ results in a positive value of $2^{63} - 1$.

4. Counting is performed without branching when the $R_2$ field in the RR or RRE format contains zero.

An increment is added to the first operand, and the sum is compared with a compare value. The result of the comparison determines whether branching occurs. Subsequently, the sum is placed at the first-operand location. The second-operand address is used as a branch address. The $R_3$ field designates registers containing the increment and the compare value.

For BRANCH ON INDEX HIGH, when the sum is high, the instruction address in the current PSW is replaced by the branch address. When the sum is low or equal, normal instruction sequencing proceeds with the updated instruction address.

For BRANCH ON INDEX LOW OR EQUAL, when the sum is low or equal, the instruction address in the current PSW is replaced by the branch address. When the sum is high, normal instruction sequencing proceeds with the updated instruction address.

When the $R_3$ field is even, it designates a pair of registers; the contents of the even and odd registers of the pair are used as the increment and the compare value, respectively. When the $R_3$ field is odd, it designates a single register, the contents of which are used as both the increment and the compare value.
For purposes of the addition and comparison, all operands and results are treated as 32-bit signed binary integers for BXH and BXLE or as 64-bit signed binary integers for BXHG and BXLEG. Overflow caused by the addition is ignored.

The original contents of the compare-value register are used as the compare value even when that register is also specified to be the first-operand location. The branch address is generated before general register R1 is changed.

The sum is placed at the first-operand location, regardless of whether the branch is taken.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Transaction constraint

**Programming Notes:**

1. Several examples of the use of the BRANCH ON INDEX HIGH and BRANCH ON INDEX LOW OR EQUAL instructions are given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The word “index” in the names of these instructions indicates that one of the major purposes is the incrementing and testing of an index value. The increment, being a signed binary integer, may be used to increase or decrease the value in general register R1 by an arbitrary amount, subject to the limit of the integer size.

3. Care must be taken in the 31-bit addressing mode when a data area in storage is at the rightmost end of a 31-bit address space and a BRANCH ON INDEX HIGH (BXH) or BRANCH ON INDEX LOW OR EQUAL (BXLE) instruction is used to step upward through the data. Since the addition and comparison operations performed during the execution of these instructions treat the operands as 32-bit signed binary integers, the value following $2^{31} - 1$ is not $2^{31}$, which cannot be represented in that format, but $-2^{31}$. The instruction does not provide an indication of such overflow. Consequently, some common looping techniques based on the use of these instructions do not work when a data area ends at address $2^{31} - 1$. This problem is illustrated in a BRANCH ON INDEX LOW OR EQUAL example in Appendix A, “Number Representation and Instruction-Use Examples.” A similar caution applies in the 64-bit addressing mode when data is at the end of a 64-bit address space and BRANCH ON INDEX HIGH (BXHG) or BRANCH ON INDEX LOW OR EQUAL (BXLEG) is used.

---

**BRANCH PREDICTION PRELOAD**

BPP M1, R12, D3(B3) [SMI]

```
C7    M1  /////  B3  D3  R12
0  8  12  16  20  24  32  36  40  44  48  52  56  60  64  68  72  76  80  84  88  92  96  100 104 108 112 116
```

**BRANCH PREDICTION RELATIVE PRELOAD**

BPRP M1, R12, R13 [MII]

```
C5    M1  RI2  RI3
0  8  12  16  20  24  28  32  36  40  44  48  52  56  60  64  68  72  76  80  84  88  92  96 100 104 108 112
```

Subject to the controls in the M1 field, the CPU is provided with information about a branch or execute-type instruction designated by the second operand. The predicted target address of the designated instruction is specified by the third operand.

The contents of the R12 field are a signed binary integer specifying the number of halfwords that is added to the address of the current instruction to generate the address of a branch, or execute-type instruction. For BRANCH PREDICTION PRELOAD, the R12 field contains a signed 16-bit integer. For BRANCH PREDICTION RELATIVE PRELOAD, the R12 field contains a signed 12-bit integer.

When adding the number of halfwords specified in the R12 field to the address of the current instruction, the result is subject to the current addressing mode. That is, the result is treated as a 24-bit address in the 24-bit addressing mode, a 31-bit address in the 31-bit addressing mode, or a 64-bit address in the 64-bit addressing mode.

The M1 field contains a 4-bit unsigned binary integer that is used as a code to signal the CPU attributes of
the instruction designated by the second operand. The codes are as follows:

<table>
<thead>
<tr>
<th>Code</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The instruction is a branch instruction that is 4 bytes in length. The branch instruction is not used for calling linkage or a returning linkage and there may be multiple potential targets of this branch instruction.</td>
</tr>
<tr>
<td>1-4</td>
<td>Reserved.</td>
</tr>
<tr>
<td>5</td>
<td>The instruction is a branch instruction that is 2 bytes in length. The branch instruction is used for calling linkage and there is only one target of this branch instruction.</td>
</tr>
<tr>
<td>6</td>
<td>The instruction is a branch instruction that is 2 bytes in length. The branch instruction is used for returning linkage.</td>
</tr>
<tr>
<td>7</td>
<td>The instruction is a branch instruction that is 2 bytes in length. The branch instruction is used for calling linkage and there may be multiple potential targets of this branch instruction.</td>
</tr>
<tr>
<td>8</td>
<td>The instruction is a branch instruction that is 4 bytes in length. The branch instruction is not used for calling linkage or returning linkage and there is only one target of this branch instruction.</td>
</tr>
<tr>
<td>9</td>
<td>The instruction is a branch instruction that is 4 bytes in length. The branch instruction is used for calling linkage and there is only one target of the branch instruction.</td>
</tr>
<tr>
<td>10</td>
<td>The instruction is a branch instruction that is 4 bytes in length. The branch instruction is used for returning linkage.</td>
</tr>
<tr>
<td>11</td>
<td>The instruction is a branch instruction that is 4 bytes in length. The branch instruction is used for calling linkage and there may be multiple potential targets of this branch instruction.</td>
</tr>
<tr>
<td>12</td>
<td>The instruction is a branch instruction that is 6 bytes in length. The branch instruction is not used for calling linkage or returning linkage and there is only one target of this branch instruction.</td>
</tr>
<tr>
<td>13</td>
<td>The instruction is a branch instruction that is 6 bytes in length. The branch instruction is used for calling linkage and there is only one target of this branch instruction.</td>
</tr>
<tr>
<td>14</td>
<td>The instruction is an EXECUTE instruction.</td>
</tr>
<tr>
<td>15</td>
<td>The instruction is an EXECUTE RELATIVE LONG instruction.</td>
</tr>
</tbody>
</table>

For BRANCH PREDICTION PRELOAD when the M₁ field specifies a branch instruction, the third operand address is the predicted branch-target address of the instruction designated by the second operand. For BRANCH PREDICTION PRELOAD when the M₁ field specifies an execute-type instruction, the third operand address is the execute-target address of the instruction designated by the second operand.

For BRANCH PREDICTION RELATIVE PRELOAD, when the M₁ field specifies a branch instruction, the contents of the R₁₃ field are a 24-bit signed binary integer specifying the number of halfwords that is added to the address of the BRANCH PREDICTION RELATIVE PRELOAD instruction to generate the branch-target address of the instruction designated by the second operand. For BRANCH PREDICTION RELATIVE PRELOAD, when the M₁ field specifies an execute-type instruction, the contents of the R₁₃ field are a 24-bit signed binary integer specifying the number of halfwords that is added to the address of the BRANCH PREDICTION RELATIVE PRELOAD instruction to generate the execute-target address of the instruction designated by the second operand. When adding the number of halfwords specified by the R₁₃ field to the address of the BRANCH PREDICTION RELATIVE PRELOAD instruction, the result is subject to the current addressing mode. That is, the result is treated as a 24-bit address in the 24-bit addressing mode, a 31-bit address in the 31-bit addressing mode, or a 64-bit address in the 64-bit addressing mode.

When the boundary of the third operand of BRANCH PREDICTION PRELOAD is not on a halfword boundary, it is model dependent whether the instruction acts as a no-operation.

Depending on the model, the CPU may not implement all of the branch-attribute codes. For codes that are not recognized by the CPU, and for reserved codes, the instruction acts as a no-operation.

The second and third operand addresses are instruction or effective addresses, not logical addresses. No access exceptions are recognized for the second or third operands. For BRANCH PREDICTION PRELOAD, there is no specification exception when the third operand specifies an odd address.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
• Operation (if the execution-hint facility is not installed)

Programming Notes:

1. In the absence of any branch-history information observed during program execution or provided by BPP or BPRP, current processor models that implement branch-prediction logic assume that the following operations represent conditional branches that are taken (that is, branches that update the PSW instruction address):
   • BAL, BAS, BCT, BCTG, BRAS, BRASL, BRCT, BRCTG, BRCTH, BRXLE, BRXLG, BXLE, and BXLEG
   • BALR, BASR, BCTGR, and BCTR, when the R2 field is nonzero
   • BC, BRC, and BRCL, when the mask field is 1111 binary
   • BCR, when both the mask field is 1111 binary and the R2 field is nonzero

Similarly, for the purposes of branch prediction, the following operations are assumed to represent conditional branches that are not taken:

• BC, BRC, and BRCL, when the mask field is between 0001 and 1110 binary, inclusive
• BCR, when both the mask field is between 0001 and 1110 binary, inclusive, and the R2 field is nonzero
• BRXH, BRXHG, BXH, and BXHG
• CGIB, CGIJ, CGRB, CGRJ, CIB, CJ, CLGIB, CLGIJ, CLGRB, CLGRJ, CLIB, CLJ, CLR, CLRJ, CRB, and CRJ, when bits 0-2 of the mask field are between 001 and 110 binary

Additionally, for the purposes of branch prediction, the following operations are not considered to be branches:

• BALR, BASR, BCTGR, and BCTR, when the R2 field is zero
• BC, BRC, and BRCL, when the mask field is 0000 binary
• BCR, when either the mask field is 0000 binary or the R2 field is zero

The predictive behavior of conditional-branching operations not listed above is model dependent.

The BPP and BPRP instructions provide a means by which the program can influence the branch-history logic, informing the CPU that the branching instruction designated by the second operand is expected to be a taken branch, regardless of the assumed behavior described above.

2. BRANCH PREDICTION PRELOAD and BRANCH PREDICTION RELATIVE PRELOAD inform the CPU of a branch instruction and its predicted target, but this does not guarantee that the CPU will necessarily retain or use this branch-prediction information.

3. If a CPU retains the specified branch-prediction information, it is model dependent how long the information is retained.

4. Figure 7-3 shows the branch-prediction codes and their most-common usage. Refer to the definition of the codes on page 7-41 for a complete explanation of the codes and their respective meanings.

<table>
<thead>
<tr>
<th>M, Code Value</th>
<th>IL</th>
<th>Corresponding Branch Instruction(s) by Mnemonic</th>
<th>Usage Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 4 BC²</td>
<td></td>
<td>Branch table</td>
<td></td>
</tr>
<tr>
<td>1 (none - code is reserved)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2 (none - code is reserved)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3 (none - code is reserved)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4 (none - code is reserved)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5 2 BALR¹, BASR¹, BCR¹²</td>
<td></td>
<td>Static calling linkage</td>
<td></td>
</tr>
<tr>
<td>6 2 BCR¹²</td>
<td></td>
<td>Returning linkage</td>
<td></td>
</tr>
<tr>
<td>7 2 BALR¹, BASR¹, BCR¹²</td>
<td></td>
<td>Dynamic calling linkage</td>
<td></td>
</tr>
<tr>
<td>8 4 BC², BCT, BRXH, BRXLE, BXH, BXLE, BRC², BRCT, BRCTG, BTCGR¹</td>
<td></td>
<td>Conditional or unconditional branches</td>
<td></td>
</tr>
<tr>
<td>9 4 BAL, BAS, BRAS</td>
<td></td>
<td>Static calling linkage</td>
<td></td>
</tr>
<tr>
<td>10 4 BC²</td>
<td></td>
<td>unconditional returning linkage</td>
<td></td>
</tr>
<tr>
<td>11 4 BAL, BAS,</td>
<td></td>
<td>Dynamic calling linkage</td>
<td></td>
</tr>
<tr>
<td>12 6 BRCTH, BRCL², BCTG, BXHG, BXLEG, BRXHG, BRXLG, CGRIJ, CLGRIJ, CLJ, CLIJ, CLJ², CLIJ², CLGR², CLGR², CR², CLR², CIB², CLGIB², CIB², CLIB²</td>
<td></td>
<td>Conditional or unconditional branches</td>
<td></td>
</tr>
<tr>
<td>13 6 BRASL</td>
<td></td>
<td>Static calling linkage</td>
<td></td>
</tr>
<tr>
<td>14 4 EX</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 7-3. Branch-Prediction Codes and Most-Common Usage (Part 1 of 2)
5. Performance degradation may occur for any of the following:

- The RI2 field is zero or the second operand designates an instruction that is not a branch instruction or execute-type instruction.
- The RI2 and M1 fields designate a branch instruction and the branch is not taken.
- The M1 field designates a code specifying an incorrect length, instruction or usage type for the instruction designated by the second operand as shown by programming note 4.
- The M1 field designates a code specifying that the instruction designated by the second operand is a calling-linkage instruction, however there is no direct returning-linkage instruction. That is, the returning-linkage instruction is executed from a nested use of calling and returning subroutine linkage.
- For BRANCH PREDICTION PRELOAD, the third operand specifies an odd address or designates an incorrect branch-target for the instruction designated by the second operand. For BRANCH PREDICTION RELATIVE PRELOAD, the RI3 field designates an incorrect branch-target for the instruction designated by the RI2 field.

- BRANCH PREDICTION PRELOAD or BRANCH PREDICTION RELATIVE PRELOAD are the target of an execute-type instruction.

6. Other than the performance implications described in the preceding note, the use of BPP or BPRP in a program does not change the execution sequence from that of a program that does not use BPP or BPRP.

### BRANCH RELATIVE AND SAVE

<table>
<thead>
<tr>
<th>BRAS</th>
<th>R1, RI2</th>
<th>[RI-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'A7'</td>
<td>R1</td>
<td>'5'</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>16</td>
</tr>
</tbody>
</table>

### BRANCH RELATIVE AND SAVE LONG

<table>
<thead>
<tr>
<th>BRASL</th>
<th>R1, RI2</th>
<th>[RIL-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C0'</td>
<td>R1</td>
<td>'5'</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>16</td>
</tr>
</tbody>
</table>

Information from the current PSW, including the updated instruction address, is saved as link information at the first-operand location. Subsequently, the instruction address in the PSW is replaced by the branch address.

In the 24-bit or 31-bit addressing mode, the link information is bits 32 and 97-127 of the PSW, consisting of the basic-addressing-mode bit and the rightmost 31 bits of the updated instruction address. The link information is placed in bit positions 32 and 33-63, respectively, of the first-operand location, and bits 0-31 of the location remain unchanged.

In the 64-bit addressing mode, the link information consists of the updated instruction address, placed in bit positions 0-63 of the first-operand location.

The contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the branch address.

**Condition Code:** The code remains unchanged.
**Program Exceptions:**
- Transaction constraint

**Programming Notes:**

1. The operation is the same as that of the BRANCH AND SAVE (BAS) instruction except for the means of specifying the branch address. An example of the use of BRANCH AND SAVE is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The BRANCH RELATIVE AND SAVE and BRANCH RELATIVE AND SAVE LONG instructions, like the BRANCH AND SAVE instruction, are intended to be used for linkage to programs known to be in the same addressing mode as the caller. These instructions should be used in place of the BRANCH AND LINK instruction (BAL and BALR). See the programming notes on pages 5-15 and 5-18 in the section “Subroutine Linkage without the Linkage Stack” for a detailed discussion of these and other linkage instructions. See also the programming note under BRANCH AND LINK for a discussion of the advantages of the BRANCH RELATIVE AND SAVE, BRANCH RELATIVE AND SAVE LONG, and BRANCH AND SAVE instructions.

3. When the instruction is the target of an execute-type instruction, the branch is relative to the target address; see “Branch-Address Generation” on page 5-12.

The instruction address in the current PSW is replaced by the branch address if the condition code has one of the values specified by M1; otherwise, normal instruction sequencing proceeds with the updated instruction address.

The contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the branch address.

The M1 field is used as a four-bit mask. The four condition codes (0, 1, 2, and 3) correspond, left to right, with the four bits of the mask, as follows:

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Instruction Bit Number of Mask</th>
<th>Mask Position Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>1</td>
<td>9</td>
<td>4</td>
</tr>
<tr>
<td>2</td>
<td>10</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>11</td>
<td>1</td>
</tr>
</tbody>
</table>

The current condition code is used to select the corresponding mask bit. If the mask bit selected by the condition code is one, the branch is successful. If the mask bit selected is zero, normal instruction sequencing proceeds with the next sequential instruction.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Transaction constraint

**Programming Notes:**

1. The operation is the same as that of the BRANCH ON CONDITION instruction except for the means of specifying the branch address. An example of the use of BRANCH ON CONDITION is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. When a branch is to depend on more than one condition, the pertinent condition codes are specified in the mask as the sum of their mask position values. A mask of 12, for example, specifies that a branch is to be made when the condition code is 0 or 1.

3. When all four mask bits are zeros, the branch instruction is equivalent to a no-operation. When
all four mask bits are ones, that is, the mask value is 15, the branch is unconditional.

4. When the instruction is the target of an execute-type instruction, the branch is relative to the target address; see “Branch-Address Generation” on page 5-12.

**BRANCH RELATIVE ON COUNT**

```
<table>
<thead>
<tr>
<th>BRCT</th>
<th>R1, R12</th>
<th>[R1-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'A7'</td>
<td>R1 12 16 16 31</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>BRCTG</th>
<th>R1, R12</th>
<th>[R1-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'A7'</td>
<td>R1 7 16 16 31</td>
<td></td>
</tr>
</tbody>
</table>
```

A one is subtracted from the first operand, and the result is placed at the first-operand location. For BRANCH RELATIVE ON COUNT (BRCT), the first operand and result are treated as 32-bit binary integers in bits 32-63 of general register R1, with overflow ignored; bits 0-31 of the register are unchanged. For BRANCH RELATIVE ON COUNT HIGH (BRCTH), the first operand and result are treated as 32-bit binary integers in bits 0-31 of general register R1, with overflow ignored; bits 32-63 of the register are unchanged. For BRANCH RELATIVE ON COUNT HIGH (BRCTG), the first operand and result are treated as 64-bit binary integers, with overflow ignored. When the result is zero, normal instruction sequencing proceeds with the updated instruction address. When the result is not zero, the instruction address in the current PSW is replaced by the branch address.

The contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the branch address.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Operation (BRCTH, if the high-word facility is not installed)
- Transaction constraint

**Programming Notes:**

1. The operation is the same as that of the BRANCH ON COUNT instruction except for the means of specifying the branch address. An example of the use of BRANCH ON COUNT is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The first operand and result can be considered as either signed or unsigned binary integers since the result of a binary subtraction is the same in both cases.

3. An initial count of one results in zero, and no branching takes place; an initial count of zero results in -1 and causes branching to be executed; an initial count of -1 results in -2 and causes branching to be executed; and so on. In a loop, branching takes place each time the instruction is executed until the result is again zero. Note that for BRCT, because of the number range, an initial count of -231 results in a positive value of 231 - 1, or, for BRCTG, an initial count of -263 results in a positive value of 263 - 1.

4. When the instruction is the target of an execute-type instruction, the branch is relative to the target address; see “Branch-Address Generation” on page 5-12.

**BRANCH RELATIVE ON INDEX HIGH**

```
<table>
<thead>
<tr>
<th>BRXH</th>
<th>R1, R3, R12</th>
<th>[RIE-e]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'84'</td>
<td>R1 R3 R12</td>
<td>44</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>BRXHG</th>
<th>R1, R3, R12</th>
<th>[RIE-e]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EC'</td>
<td>R1 R3 R12</td>
<td>44</td>
</tr>
</tbody>
</table>
```

7-45
BRANCH RELATIVE ON INDEX LOW OR EQUAL

BRXLE  R1, R3, RI2  [RSI]  
\[85'  R_1, R_3, RI_2\]  

BRXLG  R1, R3, RI2  [RIE-e]  
\[EC' R_1, R_3, RI_2\]  

An increment is added to the first operand, and the sum is compared with a compare value. The result of the comparison determines whether branching occurs. Subsequently, the sum is placed at the first-operand location. The R3 field designates registers containing the increment and the compare value.

The contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the branch address.

For BRANCH RELATIVE ON INDEX HIGH, when the sum is high, the instruction address in the current PSW is replaced by the branch address. When the sum is low or equal, normal instruction sequencing proceeds with the updated instruction address.

For BRANCH RELATIVE ON INDEX LOW OR EQUAL, when the sum is low or equal, the instruction address in the current PSW is replaced by the branch address. When the sum is high, normal instruction sequencing proceeds with the updated instruction address.

When the R3 field is even, it designates a pair of registers; the contents of the even and odd registers of the pair are used as the increment and the compare value, respectively. When the R3 field is odd, it designates a single register, the contents of which are used as both the increment and the compare value.

For purposes of the addition and comparison, all operands and results are treated as 32-bit signed binary integers for BRXH and BRXLE or as 64-bit signed binary integers for BRXHG and BRXLG. Overflow caused by the addition is ignored.

The original contents of the compare-value register are used as the compare value even when that register is also specified to be the first-operand location.

The sum is placed at the first-operand location, regardless of whether the branch is taken.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Transaction constraint

**Programming Notes:**

1. The operations are the same as those of the BRANCH ON INDEX HIGH and BRANCH ON INDEX LOW OR EQUAL instructions except for the means of specifying the branch address. Several examples of the use of BRANCH ON INDEX HIGH and BRANCH ON INDEX LOW OR EQUAL are given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The word “index” in the names of these instructions indicates that one of the major purposes is the incrementing and testing of an index value. The increment, being a signed binary integer, may be used to increase or decrease the value in general register R1 by an arbitrary amount.

3. Care must be taken in the 31-bit addressing mode when a data area in storage is at the rightmost end of an address space and a BRANCH RELATIVE ON INDEX HIGH (BRXH) or BRANCH RELATIVE ON INDEX LOW OR EQUAL (BRXLE) instruction is used to step upward through the data. Since the addition and comparison operations performed during the execution of these instructions treat the operands as 32-bit signed binary integers, the value following $2^{31} - 1$ is not $2^{31}$, which cannot be represented in that format, but $-2^{31}$. The instruction does not provide an indication of such overflow. Consequently, some common looping techniques based on the use of these instructions do not work when a data area ends at address $2^{31} - 1$. This problem is illustrated in a BRANCH ON INDEX LOW OR EQUAL example in Appendix A, “Number Representation and Instruction-Use Examples.” A similar caution applies in the 64-bit addressing mode when data is at the end of a 64-bit address space and BRANCH RELATIVE ON INDEX HIGH (BRXHG)
or BRANCH RELATIVE ON INDEX LOW OR EQUAL (BRXLG) is used.

4. When the instruction is the target of an execute-type instruction, the branch is relative to the target address; see “Branch-Address Generation” on page 5-12.

CHECKSUM

<table>
<thead>
<tr>
<th>CKSM</th>
<th>R1, R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B241'</td>
<td>/ / / /</td>
<td>R1</td>
</tr>
</tbody>
</table>

Successive four-byte elements of the second operand are added to the first operand in bit positions 32-63 of general register R1 to form a 32-bit checksum in those bit positions. The first operand and the four-byte elements are treated as 32-bit unsigned binary integers. After each addition of an element, a carry out of bit position 32 of the first operand is added to bit position 63 of the first operand. Bits 0-31 of general register R1 always remain unchanged. If the second operand is not a multiple of four bytes, its last one, two, or three bytes are treated as appended on the right with the number of all-zeros bytes needed to form a four-byte element. The four-byte elements are added to the first operand until either the entire second operand or a CPU-determined amount of the second operand has been processed. The result is indicated in the condition code.

The R2 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the second operand is specified by the contents of the R2 general register. The number of bytes in the second-operand location is specified by the 32-bit or 64-bit unsigned binary integer in the R2 + 1 general register.

The handling of the address in general register R2 and the length in general register R2 + 1 is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register R2 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the register constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of the register constitute the address. In the 24-bit or 31-bit addressing mode, the length is a 32-bit unsigned binary integer in bit positions 32-63 of general register R2 + 1, and the contents of bit positions 0-31 are ignored. In the 64-bit addressing mode, the length is a 64-bit unsigned binary integer in the register.

The addition of second-operand four-byte elements to the first operand proceeds left to right, four-byte element by four-byte element, and ends as soon as (1) the entire second operand has been processed or (2) a lesser CPU-determined amount of the second operand has been processed. In either case, the result in bit positions 32-63 of general register R1 is a 32-bit checksum for the part of the second operand that has been processed. When the second operand is not a multiple of four bytes, the final second-operand bytes in excess of a multiple of four are conceptually appended on the right with an appropriate number of all-zeros bytes to form the final four-byte element.

If the operation ends because the entire second operand has been processed, the condition code is set to 0. If the operation ends because a lesser CPU-determined amount of the second operand has been processed, the condition code is set to 3. When the operation is to end with a setting of condition code 3, any carry out of bit position 32 of the first operand is added to bit position 63 of the first operand before the operation ends.

At the completion of the operation, the 32-bit or 64-bit operand-length field in the R2 + 1 register is decremented by the number of actual second-operand bytes added to the first operand (not including any conceptually appended all-zeros bytes), and the address in the R2 register is incremented by the same number. Thus, the 32-bit or 64-bit operand-length field contains a zero value if the condition code is set to 0, or it contains a nonzero value if the condition code is set to 3. In the 24-bit or 31-bit addressing mode, bits 0-31 of the R2 + 1 register always remain unchanged.

When condition code 3 is set, the general registers used by the instruction have been set so that the remainder of the second operand can be processed by simply branching back to reexecute the instruction.
The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed. The minimum amount is four bytes or the number of bytes specified in the \( R_2 + 1 \) general register, whichever is smaller.

At the completion of the operation in the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general register \( R_2 \) may be set to zeros or may remain unchanged, even when the initial length in register \( R_2 + 1 \) is zero. Bits 0-31 of general register \( R_2 \) remain unchanged.

When the \( R_1 \) register is the same register as the \( R_2 \) or \( R_2 + 1 \) register, the results are unpredictable.

Access exceptions for the portion of the second operand to the right of the last byte processed may or may not be recognized. For a second operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

Access exceptions are not recognized if the \( R_2 \) field is odd. When the length of the second operand is zero, no access exceptions are recognized.

**Resulting Condition Code:**

- 0 \( \text{Entire second operand processed} \)
- 1 \( \text{--} \)
- 2 \( \text{--} \)
- 3 \( \text{CPU-determined amount of the second operand processed} \)

**Program Exceptions:**

- Access (fetch, operand 2)
- Specification
- Transaction constraint

**Programming Notes:**

1. The initial contents of bit positions 32-63 of the \( R_i \) general register contribute to the 32-bit checksum. The program normally should set those contents to all zeros before issuing the CHECKSUM instruction.
2. A 16-bit checksum is used in, for example, the TCP/IP application. The following program can be executed after the CHECKSUM instruction to produce in bit positions 32-63 of general register \( R_2 \) a 16-bit checksum from the 32-bit checksum in bit positions 32-63 of general register \( R_1 \). The program is annotated to show the contents of bit positions 32-63 of the \( R_2 \) and \( R_2 + 1 \) registers after the execution of each instruction. The contents of bit positions 32-63 of the \( R_1 \) register are represented as \( A,B \), meaning the value \( A \) in bit positions 32-47 and the value \( B \) in bit positions 48-63. The value \( C \) is a carry from \( A + B \). Note that bit positions 32-63 of register \( R_2 + 1 \) are known to contain all zeros when CHECKSUM has set condition code 0.

<table>
<thead>
<tr>
<th>Program</th>
<th>( R_2 ) Bits</th>
<th>( R_2 + 1 ) Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>LR ( R_2,R_1 )</td>
<td>( A,B )</td>
<td>0,0</td>
</tr>
<tr>
<td>SRDL ( R_2,16 )</td>
<td>0,A</td>
<td>B,0</td>
</tr>
<tr>
<td>ALR ( R_2,R_2+1 )</td>
<td>( B,A )</td>
<td>B,0</td>
</tr>
<tr>
<td>ALR ( R_2,R_1 )</td>
<td>( A+B+C,A+B )</td>
<td>B,0</td>
</tr>
<tr>
<td>SRL ( R_2,16 )</td>
<td>0,A+B+C</td>
<td>B,0</td>
</tr>
</tbody>
</table>

3. The CHECKSUM instruction may be used in computing hash values as illustrated in the following programming example. The variable \( \text{KEY} \) contains a string to be mapped into a slot in a hash table. The variable \( \text{SIZE} \) is a prime number designating the size of the hash table. The value of \( \text{SIZE} \) is determined by (a) the number of strings to be hashed into the table divided by the acceptable number of hash collisions, and (b) a value that is not too close to a power of two. Following the DIVIDE (D) instruction, the remainder in register 0 represents the resulting hash value.

<table>
<thead>
<tr>
<th>Program</th>
<th>( R_2 ) Bits</th>
<th>( R_2 + 1 ) Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>SR 1,1</td>
<td>Zero accumulator</td>
<td></td>
</tr>
<tr>
<td>LA 2,\text{KEY}</td>
<td>Point to string</td>
<td></td>
</tr>
<tr>
<td>LA 3,\text{L\text{KEY}}</td>
<td>Load string length</td>
<td></td>
</tr>
<tr>
<td>LOOP CKSM 1,2</td>
<td>Compute checksum</td>
<td></td>
</tr>
<tr>
<td>BNZ LOOP</td>
<td>Repeat if not done</td>
<td></td>
</tr>
<tr>
<td>SR 0,0</td>
<td>Zero for divide</td>
<td></td>
</tr>
<tr>
<td>D 0,\text{SIZE}</td>
<td>Compute hash value</td>
<td></td>
</tr>
<tr>
<td>...</td>
<td></td>
<td></td>
</tr>
<tr>
<td>\text{KEY} DS CL64</td>
<td>String to be hashed</td>
<td></td>
</tr>
<tr>
<td>\text{SIZE} DS F</td>
<td>Size of hash table</td>
<td></td>
</tr>
</tbody>
</table>

4. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

5. The storage-operand references of CHECKSUM may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)
6. Figure 7-4 on page 7-49 contains a summary of the operation.

**Figure 7-4. Execution of CHECKSUM**

```
CHECKSUM ← R₁, bits 32-63
ADR ← Address in R₂
LEN ← length in R₂ + 1

INC ← LEN
ELEMENT ← INC bytes at ADR followed by 4-INC all-zero bytes

LEN ≥ 4

INC ← 4
ELEMENT ← 4 bytes at ADR

CHECKSUM ← CHECKSUM + ELEMENT

Carry from addition

Yes → CHECKSUM ← CHECKSUM + 1
No

ADR ← ADR + INC
LEN ← LEN - INC

LEN = 0 or CPU-determined reason to end operation

Yes → R₁, bits 32-63 ← CHECKSUM
R₂ ← ADR
R₂ + 1 ← LEN

LEN = 0

Yes → Set condition code 0
No → Set condition code 3

End operation

Note: All addends are unsigned binary integers
```
A function specified by the function code in general register 0 is performed.

Bits 16-23 of the instruction are ignored.

Bit positions 57-63 of general register 0 contain the function code. Figure 7-5 and 7-6 show the assigned function codes for CIPHER MESSAGE and CIPHER MESSAGE WITH CHAINING, respectively. All other function codes are unassigned. For cipher functions, bit 56 is the modifier bit which specifies whether an encryption or a decryption operation is to be performed. The modifier bit is ignored for all other functions. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.

The function codes for CIPHER MESSAGE are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>KM-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>KM-DEA</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>KM-TDEA-128</td>
<td>16</td>
<td>8</td>
</tr>
<tr>
<td>3</td>
<td>KM-TDEA-192</td>
<td>24</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>KM-Encrypted-DEA</td>
<td>32</td>
<td>8</td>
</tr>
<tr>
<td>10</td>
<td>KM-Encrypted-TDEA-128</td>
<td>40</td>
<td>8</td>
</tr>
<tr>
<td>11</td>
<td>KM-Encrypted-TDEA-192</td>
<td>48</td>
<td>8</td>
</tr>
<tr>
<td>18</td>
<td>KM-AES-128</td>
<td>16</td>
<td>16</td>
</tr>
<tr>
<td>19</td>
<td>KM-AES-192</td>
<td>24</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>KM-AES-256</td>
<td>32</td>
<td>16</td>
</tr>
<tr>
<td>26</td>
<td>KM-Encrypted-AES-128</td>
<td>48</td>
<td>16</td>
</tr>
<tr>
<td>27</td>
<td>KM-Encrypted-AES-192</td>
<td>56</td>
<td>16</td>
</tr>
<tr>
<td>28</td>
<td>KM-Encrypted-AES-256</td>
<td>64</td>
<td>16</td>
</tr>
<tr>
<td>50</td>
<td>KM-XTS-AES-128</td>
<td>32</td>
<td>16</td>
</tr>
<tr>
<td>52</td>
<td>KM-XTS-AES-256</td>
<td>48</td>
<td>16</td>
</tr>
<tr>
<td>58</td>
<td>KM-XTS-Encrypted-AES-128</td>
<td>64</td>
<td>16</td>
</tr>
<tr>
<td>60</td>
<td>KM-XTS-Encrypted-AES-256</td>
<td>80</td>
<td>16</td>
</tr>
</tbody>
</table>

Explanation:

— Not applicable

Figure 7-5. Function Codes for CIPHER MESSAGE

The function codes for CIPHER MESSAGE WITH CHAINING are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>KMC-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>KMC-DEA</td>
<td>16</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>KMC-TDEA-128</td>
<td>24</td>
<td>8</td>
</tr>
<tr>
<td>3</td>
<td>KMC-TDEA-192</td>
<td>32</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>KMC-Encrypted-DEA</td>
<td>40</td>
<td>8</td>
</tr>
<tr>
<td>10</td>
<td>KMC-Encrypted-TDEA-128</td>
<td>48</td>
<td>8</td>
</tr>
<tr>
<td>11</td>
<td>KMC-Encrypted-TDEA-192</td>
<td>56</td>
<td>8</td>
</tr>
<tr>
<td>18</td>
<td>KMC-AES-128</td>
<td>32</td>
<td>16</td>
</tr>
</tbody>
</table>

Figure 7-6. Function Codes for CIPHER MESSAGE WITH CHAINING
All other function codes are unassigned.

The query function provides the means of indicating the availability of the other functions. The contents of general registers R1, R2, and R2 + 1 are ignored for the query function.

For all other functions, the second operand is ciphered as specified by the function code using a cryptographic key in the parameter block, and the result is placed in the first-operand location. For CIPHER MESSAGE WITH CHAINING, ciphering also uses an initial chaining value in the parameter block, and the chaining value is updated as part of the operation. For XTS functions, ciphering also uses an XTS parameter in the parameter block, and the XTS parameter is updated as part of the operation.

The R1 field designates a general register and must designate an even-numbered register; otherwise, a specification exception is recognized.

The R2 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first and second operands is specified by the contents of the R1 and R2 general registers, respectively. The number of bytes in the second-operand location is specified in general register R2 + 1. The first operand is the same length as the second operand.

As part of the operation, the addresses in general registers R1 and R2 are incremented by the number of bytes processed, and the length in general register R2 + 1 is decremented by the same number. The formation and updating of the addresses and length is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R2 constitute the addresses of the first and second operands, respectively, and the contents of bit positions 0-39 are ignored; bits 40-63 of the updated addresses replace the corresponding bits in general registers R1 and R2, carries out of bit position 40 of the updated address are ignored, and the contents of bit positions 32-39 of general registers R1 and R2 are set to zeros.

In the 31-bit addressing mode, the contents of bit positions 33-63 of general registers R1 and R2 constitute the addresses of the first and second operands, respectively, and the contents of bit positions 0-32 are ignored; bits 33-63 of the updated addresses replace the corresponding bits in general registers R1 and R2, carries out of bit position 33 of the updated address are ignored, and the content of bit position 32 of general registers R1 and R2 is set to zero. In the 64-bit addressing mode, the contents of bit positions 0-63 of general registers R1 and R2 constitute the addresses of the first and second operands, respectively; bits 0-63 of the updated addresses replace the contents of general registers R1 and R2, and carries out of bit position 0 are ignored.

In both the 24-bit and the 31-bit addressing modes, the contents of bit positions 32-63 of general register R2 + 1 form a 32-bit unsigned binary integer which specifies the number of bytes in the first and second operands, and the contents of bit positions 0-31 are ignored; bits 32-63 of the updated value replace the corresponding bits in general register R2 + 1. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register R2 + 1 form a 64-bit unsigned binary integer which specifies the number of bytes in the first and second operands; and the updated value replaces the contents of general register R2 + 1.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers R1, R2, and R2 + 1, always remain unchanged.

Figure 7-7 on page 7-52 shows the contents of the general registers just described.
In the access-register mode, access registers 1, R1, and R2 specify the address spaces containing the parameter block, first, and second operands, respectively.

The result is obtained as if processing starts at the left end of both the first and second operands and proceeds to the right, block by block. The operation is ended when the number of bytes in the second operand as specified in general register R2 + 1 have been processed and placed at the first-operand location (called normal completion) or when a CPU-determined number of blocks that is less than the length of the second operand have been processed (called partial completion). The CPU-determined number of blocks depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of blocks is usually non-zero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.

The results in the first-operand location, the chaining-value field, or the XTS parameter field are unpredictable if any of the following situations occur:

1. The cryptographic-key field or the encrypted cryptographic-key field overlaps any portion of the first operand.

---

### Figure 7-7. General Register Assignment for KM and KMC

<table>
<thead>
<tr>
<th>Mode</th>
<th>GR0</th>
<th>GR1 Parameter-Block Address</th>
<th>R1 Parameter-Block Address</th>
<th>R2 Parameter-Block Address</th>
<th>R2 + 1 Second-Operand Length</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>All Addressing Modes</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>24-Bit Addressing Mode</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GR0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GR1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R2 + 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>31-Bit Addressing Mode</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GR1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R2 + 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>64-Bit Addressing Mode</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>GR1 Parameter-Block Address</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R1 Parameter-Block Address</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R1 Parameter-Block Address</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R2 Parameter-Block Address</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R2 + 1 Second-Operand Length</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
2. The XTS parameter field overlaps any portion of the first operand.

3. The chaining-value field overlaps any portion of the first operand or the second operand.

4. The first and second operands overlap destructively. Operands are said to overlap destructively when the first-operand location would be used as a source after data would have been moved into it, assuming processing to be performed from left to right and one byte at a time.

When the operation ends due to normal completion, condition code 0 is set and the resulting value in $R_2 + 1$ is zero. When the operation ends due to partial completion, condition code 3 is set and the resulting value in $R_2 + 1$ is nonzero.

A PER storage-alteration event may be recognized both for the first-operand location and for the portion of the parameter block that is stored. A PER zero-address-detection event may be recognized for the first- and second-operand locations and for the parameter block. When PER events are detected for one or more of these locations, it is unpredictable which location is identified in the PER access identification (PAID) and PER ASCE ID (AI).

When a storage-alteration PER event is recognized, fewer than 4K additional bytes are stored into the first-operand locations before the event is reported.

When the second-operand length is initially zero, the parameter block, first, and second operands are not accessed, general registers $R_1$, $R_2$, and $R_2 + 1$ are not changed, and condition code 0 is set.

When the contents of the $R_1$ and $R_2$ fields are the same, the contents of the designated registers are incremented only by the number of bytes processed, not by twice the number of bytes processed.

As observed by this CPU, other CPUs, and channel programs, references to the parameter block and storage operands may be multiple-access references, accesses to these storage locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

In certain unusual situations, instruction execution may complete by setting condition code 3 without updating the registers, the chaining value, and the XTS parameter to reflect the last unit of the first and second operands processed. The size of the unit processed in this case depends on the situation and the model, but is limited such that the portion of the first and second operands which have been processed and not reported do not overlap in storage. In all cases, change bits are set and PER storage-alteration events are reported, when applicable, for all first-operand locations processed.

For functions that perform a comparison of the encrypted cryptographic key with the wrapping-key verification-pattern register, it is unpredictable whether access exceptions and PER zero-address-detection events are recognized for the first and second operands when the comparison results in a mismatch.

Access exceptions may be reported for a larger portion of an operand than is processed in a single execution of the instruction; however, access exceptions are not recognized for locations beyond the length of an operand nor for locations more than 4K bytes beyond the current location being processed.

Symbols Used in Function Descriptions

The following symbols are used in the subsequent description of the CIPHER MESSAGE and CIPHER MESSAGE WITH CHAINING functions. For data-encryption-algorithm (DEA) functions, the DEA-key-parity bit in each byte of the DEA key is ignored, and the operation proceeds normally, regardless of the DEA-key parity of the key.

Further description of the data-encryption algorithm may be found in Reference [11.] on page xxviii. Further description of the AES standard may be found in Reference [12.] on page xxviii. The XTS multiplication operation is the same as the GCM (Galois/counter mode) multiplication operation. Further description of the GCM multiplication over $GF(2^{128})$ may be found in Reference [15.] on page xxviii.

Figure 7-8. Symbol For Bit-Wise Exclusive OR
CIPHER MESSAGE WITH CHAINING

Figure 7-9. Symbol For XTS Multiplication Operation Over $GF(2^{128})$

Symbol Explanation:
• XTS multiplication operation over $GF(2^{128})$

Z = X • Y

Figure 7-10. Symbols for DEA Encryption and Decryption

Symbol Explanation:
<n> Length of item in bytes
C Ciphertext
K Key value
P Plaintext

Figure 7-11. Symbols for AES-128 Encryption and Decryption

Symbol Explanation:
<n> Length of item in bytes
C Ciphertext
K Key value
P Plaintext

Figure 7-12. Symbols for AES-192 Encryption and Decryption

Symbol Explanation:
<n> Length of item in bytes
C Ciphertext
K Key value
P Plaintext

Figure 7-13. Symbols for AES-256 Encryption and Decryption

Symbol Explanation:
<n> Length of item in bytes
C Ciphertext
K Key value
P Plaintext

KM-Query (KM Function Code 0)
The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-7</td>
<td>Status Word</td>
</tr>
</tbody>
</table>

Figure 7-14. Parameter Block for KM-Query

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function
codes 0-127, respectively, of the CIPHER MESSAGE instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the KM-Query function completes; condition codes 1 and 3 are not applicable to this function.

**KM-DEA (KM Function Code 1)**

**KM-Encrypted-DEA (KM Function Code 9)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KM-DEA function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Cryptographic Key (K)</td>
</tr>
</tbody>
</table>
```

*Figure 7-15. Parameter Block for KM-DEA*

For the KM-DEA function, the cryptographic key is in byte offsets 0-7 of the parameter block.

The parameter block used for the KM-Encrypted-DEA function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Encrypted Cryptographic Key (WK_d(K))</td>
</tr>
<tr>
<td>8</td>
<td>DEA Wrapping-Key</td>
</tr>
<tr>
<td>16</td>
<td>Verification Pattern (WK_dVP)</td>
</tr>
</tbody>
</table>
```

*Figure 7-16. Parameter Block for KM-Encrypted-DEA*

For the KM-Encrypted-DEA function, the contents of byte offsets 8-31 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-7 of the parameter block are deciphered using the DEA wrapping key to obtain the 64-bit cryptographic key. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the DEA algorithm with the 64-bit cryptographic key. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-17.

```
```

*Figure 7-17. KM-DEA Encipher Operation Using 64-Bit Key*

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the DEA algorithm with the 64-bit cryptographic key. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The operation is shown in Figure 7-18.

```
```

*Figure 7-18. KM-DEA Decipher Operation Using 64-Bit Key*

**KM-TDEA-128 (KM Function Code 2)**

**KM-Encrypted-TDEA-128 (KM Function Code 10)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.
The parameter block used for the KM-TDEA-128 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Cryptographic Key 1 (K1)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key 2 (K2)</td>
</tr>
</tbody>
</table>

*Figure 7-19. Parameter Block for KM-TDEA-128*

For the KM-TDEA-128 function, the cryptographic key is in byte offsets 0-15 of the parameter block.

The parameter block used for the KM-Encrypted-TDEA-128 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Encrypted Cryptographic Key (WKd(K))</td>
</tr>
<tr>
<td>8</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>

*Figure 7-20. Parameter Block for KM-Encrypted-TDEA-128*

For the KM-Encrypted-TDEA-128 function, the contents of byte offsets 16-39 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-15 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key, K = K1 || K2, where K1 is the leftmost 64 bits of K and K2 is the rightmost 64 bits of K. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA (triple DEA) algorithm with the two 64-bit cryptographic keys. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-21.

*Figure 7-21. KM-TDEA Encipher Operation Using 128-Bit Key*

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the TDEA algorithm with the two 64-bit cryptographic keys. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1,
P2, …, Pn) are stored in operand 1. The operation is shown in Figure 7-22.

For the KM-TDEA-192 function, the cryptographic key is in byte offsets 0-23 of the parameter block.

The parameter block used for the KM-Encrypted-TDEA-192 function has the following format:

\[ K = K_1 \| K_2, \text{ where } \| \text{ means concatenation} \]

\[ K = K_1 \| K_2 \| K_3, \text{ where } K_1 \text{ is the leftmost 64 bits of } K, K_2 \text{ is the middle 64 bits of } K, \text{ and } K_3 \text{ is the rightmost 64 bits of } K. \]

(See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, …, Pn) in operand 2 are enciphered using the TDEA algorithm with the three 64-bit cryptographic keys. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1,
C2, …, Cn) are stored in operand 1. The operation is shown in Figure 7-25. When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte cipher-text blocks (C1, C2, …, Cn) in operand 2 are deciphered using the TDEA algorithm with the three 64-bit cryptographic keys. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1, P2, …, Pn) are stored in operand 1. The operation is shown in Figure 7-26.

**KM-AES-128 (KM Function Code 18)**

**KM-Encrypted-AES-128 (KM Function Code 26)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KM-AES-128 function has the following format:

```
0 8
0 63
```

*Figure 7-27. Parameter Block for KM-AES-128*

For the KM-AES-128 function, the cryptographic key is in byte offsets 0-15 of the parameter block.
The parameter block used for the KM-encrypted-AES-128 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Encrypted Cryptographic Key</td>
</tr>
<tr>
<td>8</td>
<td>AES Wrapping-Key Verification</td>
</tr>
<tr>
<td>16</td>
<td>Pattern (WK&lt;sub&gt;α&lt;/sub&gt;(K))</td>
</tr>
</tbody>
</table>

For the KM-Encrypted-AES-128 function, the contents of byte offsets 16-47 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-15 of the parameter block are deciphered using the AES wrapping key to obtain the 128-bit cryptographic key, K. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 128-bit cryptographic key. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-29.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES algorithm with the 128-bit cryptographic key. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The operation is shown in Figure 7-30.

**KM-AES-192 (KM Function Code 19)**

**KM-Encrypted-AES-192 (KM Function Code 27)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KM-AES-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Cryptographic Key</td>
</tr>
</tbody>
</table>

For the KM-AES-192 function, the cryptographic key is in byte offsets 0-23 of the parameter block.
The parameter block used for the KM-Encrypted-AES-192 function has the following format:

For the KM-Encrypted-AES-192 function, the contents of byte offsets 24-55 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-23 of the parameter block are deciphered using the AES wrapping key to obtain the 192-bit cryptographic key, K. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 192-bit cryptographic key. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-33.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES algorithm with the 192-bit cryptographic key. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The operation is shown Figure 7-34.

**KM-AES-256 (KM Function Code 20)**

**KM-Encrypted-AES-256 (KM Function Code 28)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KM-AES-256 function has the following format:

For the KM-AES-256 function, the cryptographic key is in byte offsets 0-31 of the parameter block.
The parameter block used for the KM-Encrypted-AES-256 function has the following format:

```
Parameter Block

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-15</td>
<td>Encrypted Cryptographic Key</td>
</tr>
<tr>
<td>16-23</td>
<td>AES Wrapping-Key Verification Pattern</td>
</tr>
</tbody>
</table>
```

Figure 7-36. Parameter Block for KM-Encrypted-AES-256

For the KM-Encrypted-AES-256 function, the contents of byte offsets 32-63 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-31 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key, K. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 256-bit cryptographic key. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-37.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES algorithm with the 256-bit cryptographic key. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The operation is shown in Figure 7-38.

**KM-XTS-AES-128 (KM Function Code 50)**

**KM-XTS-Encrypted-AES-128 (KM Function Code 58)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KM-XTS-AES-128 function has the following format:

```
Parameter Block

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-15</td>
<td>Cryptographic Key (K)</td>
</tr>
<tr>
<td>16-21</td>
<td>Initial XTS Parameter</td>
</tr>
</tbody>
</table>
```

Figure 7-39. Parameter Block for KM-XTS-AES-128

For the KM-XTS-AES-128 function, the cryptographic key is in byte offsets 0-15 of the parameter block, and the initial XTS parameter is in bytes offsets 16-31 of the parameter block.
The parameter block used for the KM-XTS-encrypted-AES-128 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-7</td>
<td>Encrypted Cryptographic Key (WKa(K))</td>
</tr>
<tr>
<td>8-15</td>
<td>AES Wrapping-Key Verification Pattern (WKaVP)</td>
</tr>
<tr>
<td>16-47</td>
<td>Initial XTS Parameter</td>
</tr>
</tbody>
</table>

For the KM-XTS-Encrypted-AES-128 function, the contents of byte offsets 16-47 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 48-63 of the parameter block contain the initial XTS parameter, and the contents of byte offsets 0-15 of the parameter block are deciphered using the AES wrapping key to obtain the 128-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES-encryption algorithm with the 128-bit cryptographic key and the 128-bit initial XTS parameter.

Except for the first block, the XTS parameter used is the XTS parameter for the previous block multiplied by the value of 2 in GF(2^{128}). To encrypt the first block of plaintext, the initial XTS parameter is used.

The XTS parameter for each block is exclusive-ORed with the corresponding plaintext block. The result of the exclusive-OR operation is then encrypted using the AES-encryption algorithm with the 128-bit cryptographic key. The result of the encryption is then exclusive-ORed with the XTS parameter to produce

The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The result of the final GCM multiplication, called the output XTS parameter (output XTSP), is stored into the initial XTS parameter field of the parameter block.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES-decryption algorithm with the 128-bit cryptographic key and the 128-bit initial XTS parameter.

Except for the first block, the XTS parameter used is the XTS parameter for the previous block multiplied by the value of 2 in GF(2^{128}). To decrypt the first block of ciphertext, the initial XTS parameter is used.

The XTS parameter for each block is exclusive-ORed with the corresponding ciphertext block. The result of the exclusive-OR operation is then decrypted using the AES-decryption algorithm with the 128-bit cryptographic key. The result of the encryption is then exclusive-ORed with the XTS parameter to produce the plaintext block. The XTS parameter for this block is multiplied by the value of 2 in GF(2^{128}) to obtain the

![Figure 7-41. KM-XTS-AES-128 Encipher Operation](image-url)
The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The result of the final GCM multiplication, called the output XTS parameter (output XTSP), is stored into the initial XTS parameter field of the parameter block.

**KM-XTS-AES-256 (KM Function Code 52)**

**KM-XTS-Encrypted-AES-256 (KM Function Code 60)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KM-XTS-AES-256 function has the following format:

The parameter block used for the KM-XTS-Encrypted-AES-256 function has the following format:

For the KM-XTS-Encrypted-AES-256 function, the contents of byte offsets 32-63 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 64-79 of the parameter block contain the initial XTS parameter, and the contents of byte offsets 0-31 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES-encryption algorithm with the 256-bit cryptographic key and the 128-bit initial XTS parameter.

Except for the first block, the XTS parameter used is the XTS parameter for the previous block multiplied by the value of 2 in GF(2^128). To encrypt the first block of plaintext, the initial XTS parameter is used.

The XTS parameter for each block is exclusive-ORed with the corresponding plaintext block. The result of the exclusive-OR operation is then encrypted using
the AES-encryption algorithm with the 256-bit cryptographic key. The result of the encryption is then exclusive-ORed with the XTS parameter to produce the ciphertext block. The XTS parameter for this block is multiplied by the value of 2 in $GF(2^{128})$ to obtain the XTS parameter for the next block. The operation is shown in Figure 7-45.

Figure 7-45. KM-XTS-AES-256 Encipher Operation

The ciphertext blocks ($C_1$, $C_2$, ..., $C_n$) are stored in operand 1. The result of the final GCM multiplication, called the output XTS parameter (output XTSP), is stored into the initial XTS parameter field of the parameter block.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks ($C_1$, $C_2$, ..., $C_n$) in operand 2 are deciphered using the AES-decryption algorithm with the 256-bit cryptographic key and the 128-bit initial XTS parameter.

Except for the first block, the XTS parameter used is the XTS parameter for the previous block multiplied by the value of 2 in $GF(2^{128})$. To decrypt the first block of ciphertext, the initial XTS parameter is used.

The XTS parameter for each block is exclusive-ORed with the corresponding ciphertext block. The result of the exclusive-OR operation is then decrypted using the AES-decryption algorithm with the 256-bit cryptographic key. The result of the encryption is then exclusive-ORed with the XTS parameter to produce the plaintext block. The XTS parameter for this block is multiplied by the value of 2 in $GF(2^{128})$ to obtain the XTS parameter for the next block. The operation is shown in Figure 7-46.

Figure 7-46. XTS-AES-256 Decipher Operation

The plaintext blocks ($P_1$, $P_2$, ..., $P_n$) are stored in operand 1. The result of the final GCM multiplication, called the output XTS parameter (output XTSP), is stored into the initial XTS parameter field of the parameter block.

**KMC-Query (KMC Function Code 0)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the function has the following format:

Figure 7-47. Parameter Block for KMC-Query

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the CIPHER MESSAGE WITH CHAINING instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the KMC-Query function completes; condition codes 1 and 3 are not applicable to this function.
KMC-DEA (KMC Function Code 1)

KMC-Encrypted-DEA (KMC Function Code 9)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMC-DEA function has the following format:

```
  0  Chaining Value (CV)
  8  Cryptographic Key (K)
```

*Figure 7-48. Parameter Block for KMC-DEA*

For the KMC-DEA function, the chaining value is in byte offsets 0-7 of the parameter block and the cryptographic key is in byte offsets 8-15 of the parameter block.

The parameter block used for the KMC-Encrypted-DEA function has the following format:

```
  0  Chaining Value (CV)
  8  Encrypted Cryptographic Key (WKd(K))
 16  DEA Wrapping-Key
 24  Verification Pattern (WKdVP)
```

*Figure 7-49. Parameter Block for KMC-Encrypted-DEA*

For the KMC-Encrypted-DEA function, the contents of byte offsets 16-39 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 8-15 of the parameter block are deciphered using the DEA wrapping key to obtain the 64-bit cryptographic key. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.) The chaining value is in byte offsets 0-7 of the parameter block.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the DEA algorithm with the 64-bit cryptographic key and the 64-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first ciphertext block is the chaining value in the parameter block; the chaining value for deriving each subsequent ciphertext block is the corresponding previous ciphertext block. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-50.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the DEA algorithm with the 64-bit cryptographic key and the 64-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first plaintext block is in the parameter block; the chaining value for deriving each subsequent plaintext block is the corresponding previous ciphertext block. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is
CIPHER MESSAGE WITH CHAINING

stored into the chaining-value field in the parameter block. The operation is shown in Figure 7-51.

The parameter block used for the KMC-Encrypted-TDEA-128 function has the following format:

![Figure 7-52. Parameter Block for KMC-TDEA-128](image)

For the KMC-TDEA-128 function, the chaining value is in byte offsets 0-7 of the parameter block and the cryptographic key is in byte offsets 8-23 of the parameter block.

For the KMC-Encrypted-TDEA-128 function, the contents of byte offsets 24-47 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 8-23 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.) The chaining value is in byte offsets 0-7 of the parameter block.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA algorithm with the two 64-bit cryptographic keys and the 64-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first ciphertext block is the chaining value in the parameter block; the chaining value for deriving each subsequent ciphertext block is the corresponding previous ciphertext block. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value

**KMC-TDEA-128 (KMC Function Code 2)**

**KMC-Encrypted-TDEA-128 (KMC Function Code 10)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMC-TDEA-128 function has the following format:

![Figure 7-51. KMC DEA Decipher Operation Using 64-Bit Key](image)

The following description applies to both functions.

For the KMC-Encrypted-TDEA-128 function, the contents of byte offsets 24-47 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 8-23 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.) The chaining value is in byte offsets 0-7 of the parameter block.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA algorithm with the two 64-bit cryptographic keys and the 64-bit chaining value.
field of the parameter block. The operation is shown in Figure 7-54.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the TDEA algorithm with the two 64-bit cryptographic keys and the 64-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first plaintext block is in the parameter block; the chaining value for deriving each subsequent plaintext block is the corresponding previous ciphertext block. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value field in the parameter block. The operation is shown in Figure 7-55.

**KMC-TDEA-192 (KMC Function Code 3)**

**KMC-Encrypted-TDEA-192 (KMC Function Code 11)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMC-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key 1 (K1)</td>
</tr>
<tr>
<td>16</td>
<td>Cryptographic Key 2 (K2)</td>
</tr>
<tr>
<td>24</td>
<td>Cryptographic Key 3 (K3)</td>
</tr>
</tbody>
</table>

For the KMC-TDEA-192 function, the chaining value is in byte offsets 0-7 of the parameter block and the cryptographic key is in byte offsets 8-31 of the parameter block.
The parameter block used for the KMC-Encrypted-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>2</td>
<td>Encrypted Cryptographic Key</td>
</tr>
<tr>
<td>24</td>
<td>(WKd(K))</td>
</tr>
<tr>
<td>32</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>

Figure 7-57. Parameter Block for KMC-Encrypted-TDEA-192

For the KMC-Encrypted-TDEA-192 function, the contents of byte offsets 32-55 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 8-31 of the parameter block are deciphered using the DEA wrapping key to obtain the 192-bit cryptographic key. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.) The chaining value is in byte offsets 0-7 of the parameter block.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA algorithm with the three 64-bit cryptographic keys and the 64-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first ciphertext block is the chaining value in the parameter block; the chaining value for deriving each subsequent ciphertext block is the corresponding previous ciphertext block. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-58.

Figure 7-58. KMC TDEA Encipher Operation Using 192-Bit Key

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the TDEA algorithm with the three 64-bit cryptographic keys and the 64-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first plaintext block is in the parameter block; the chaining value for deriving each subsequent plaintext block is the corresponding previous ciphertext block. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is
CIPHER MESSAGE WITH CHAINING

stored into the chaining-value field in the parameter block. The operation is shown in Figure 7-59.

KMC-AES-128 (KMC Function Code 18)

KMC-Encrypted-AES-128 (KMC Function Code 26)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMC-AES-128 function has the following format:

For the KMC-AES-128 function, the chaining value is in byte offsets 0-15 of the parameter block and the cryptographic key is in byte offsets 16-31 of the parameter block.

The parameter block used for the KMC-Encrypted-AES-128 function has the following format:

For the KMC-Encrypted-AES-128 function, the contents of byte offsets 32-63 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 16-31 of the parameter block are deciphered using the AES wrapping key to obtain the 128-bit cryptographic key, K. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.) The chaining value is in byte offsets 0-15 of the parameter block.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 128-bit cryptographic key and the 128-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first ciphertext block is the chaining value in the parameter block; the chaining value for deriving each subsequent ciphertext block is the corresponding previous ciphertext block. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value

Figure 7-59. KMC TDEA Decipher Operation Using 192-Bit Key

Figure 7-60. Parameter Block for KMC-AES-128

Figure 7-61. Parameter Block for KMC-Encrypted-AES-128

7-69
field of the parameter block. The operation is shown in Figure 7-62.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES algorithm with the 128-bit cryptographic key and the 128-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first plaintext block is in the parameter block; the chaining value for deriving each subsequent plaintext block is the corresponding previous ciphertext block. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value field in the parameter block. The operation is shown in Figure 7-63.

KMC-AES-192 (KMC Function Code 19)

KMC-Encrypted-AES-192 (KMC Function Code 27)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMC-AES-192 function has the following format:

For the KMC-AES-192 function, the chaining value is in byte offsets 0-15 of the parameter block and the cryptographic key is in byte offsets 16-39 of the parameter block.

The parameter block used for the KMC-Encrypted-AES-192 function has the following format:

For the KMC-Encrypted-AES-192 function, the contents of byte offsets 40-71 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 16-39 of the parameter block are deciphered using the AES wrapping key to obtain the 192-bit cryptographic key, K. (See the section, “Protection of Cryptographic Keys” on page 7-374, for
The chaining value is in byte offsets 0-15 of the parameter block.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 192-bit cryptographic key and the 128-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first ciphertext block is the chaining value in the parameter block; the chaining value for deriving each subsequent ciphertext block is the corresponding previous ciphertext block. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-66.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES algorithm with the 192-bit cryptographic key and the 128-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first plaintext block is in the parameter block; the chaining value for deriving each subsequent plaintext block is the corresponding previous ciphertext block. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-67.

**KMC-AES-256 (KMC Function Code 20)**

**KMC-Encrypted-AES-256 (KMC Function Code 28)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMC-AES-256 function has the following format:

For the KMC-AES-256 function, the chaining value is in byte offsets 0-15 of the parameter block and the cryptographic key is in byte offsets 16-47 of the parameter block.
The parameter block used for the KMC-Encrypted-AES-256 function has the following format:

For the KMC-Encrypted-AES-256 function, the contents of byte offsets 48-79 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 16-47 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key, K. (See the section, "Protection of Cryptographic Keys" on page 7-374, for details.) The chaining value is in byte offsets 0-15 of the parameter block.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 256-bit cryptographic key and the 128-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first ciphertext block is in the parameter block; the chaining value for deriving each subsequent plaintext block is the corresponding previous ciphertext block. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-70.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES algorithm with the 256-bit cryptographic key and the 128-bit chaining value.

The chaining value, called the initial chaining value (ICV), for deriving the first plaintext block is in the parameter block; the chaining value for deriving each subsequent plaintext block is the corresponding previous ciphertext block. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The last ciphertext block is the output chaining value (OCV) and is stored into the chaining-value field in the parameter block. The operation is shown in Figure 7-71.
**KMC-PRNG (KMC Function Code 67)**
The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th></th>
<th>0</th>
<th>8</th>
<th>16</th>
<th>24</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>CV</td>
<td>K1</td>
<td>K2</td>
<td>K3</td>
</tr>
<tr>
<td>Chaining Value (CV)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cryptographic Key 1 (K1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cryptographic Key 2 (K2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cryptographic Key 3 (K3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Figure 7-72. Parameter Block for KMC-PRNG*

Regardless of the value of the modifier bit in general register 0, the 8-byte plaintext blocks in operand 2 are used to generate the 8-byte ciphertext blocks in operand 1 based on a pseudo-random-number-generation algorithm. The algorithm is based on TDEA using three 64-bit cryptographic keys and a 64-bit chaining value. The output chaining value (OCV) is stored in the chaining-value field of the parameter block. The operation is shown in Figure 7-73.

*Figure 7-73. KMC-PRNG*

**Special Conditions for KM and KMC**

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.
2. The \( R_1 \) or \( R_2 \) field designates an odd-numbered register or general register 0.

3. The second operand length is not a multiple of the data block size of the designated function (see Figure 7-5 on page 7-50 to determine the data block sizes for CIPHER MESSAGE functions; see Figure 7-6 on page 7-50 to determine the data block sizes for CIPHER MESSAGE WITH CHAINING functions). This specification exception condition does not apply to the query functions.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th></th>
<th>Normal completion</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Verification-pattern mismatch</td>
</tr>
<tr>
<td>1</td>
<td>Partial completion</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operand 2, cryptographic key, and wrapping-key verification pattern; store, operand 1; fetch and store, chaining value, XTS parameter)
- Operation (if the message-security assist is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the general registers containing the operand addresses and length, and the chaining value or the XTS parameter in the parameter block, are usually updated such that the program can simply branch back to the instruction to continue the operation.

   For unusual situations, the CPU protects against endless recurrence of the no-progress case and also protects against setting condition code 3 when the portion of the first and second operands to be reprocessed overlap in storage. Thus, the program can safely branch back to the instruction whenever condition code 3 is set with no exposure to an endless loop and no exposure to incorrectly retrying the instruction.

2. If the length of the second operand is nonzero initially and condition code 0 is set, the registers are updated in the same manner as for condition code 3. For CIPHER MESSAGE WITH CHAINING, the chaining value in this case is such that additional operands can be processed as if they were part of the same chain.

3. To save storage, the first and second operands may overlap exactly or the starting point of the first operand may be to the left of the starting point of the second operand. In either case, the overlap is not destructive.

4. For XTS functions, the program must compute the initial XTS parameter by using the appropriate Compute-XTS-Parameter PCC functions before processing the first part of a message.

5. The initial XTS parameter used in the KM-XTS-AES-128 (or the KM-XTS-Encrypted-AES-128) function is computed by using the AES encryption algorithm with a 128-bit cryptographic key,
which shall be different from the 128-bit cryptographic key used in the KM-XTS-AES-128 (or the KM-XTS-Encrypted-AES-128) function.

Similarly, the initial XTS parameter used in the KM-XTS-AES-256 (or the KM-XTS-Encrypted-AES-256) function is computed by using the AES-encryption algorithm with a 256-bit cryptographic key, which shall be different from the 256-bit cryptographic key used in the KM-XTS-AES-256 (or the KM-XTS-Encrypted-AES-256) function.

6. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

**CIPHER MESSAGE WITH CIPHER FEEDBACK**

A function specified by the function code in general register 0 is performed.

Bits 16-23 of the instruction are ignored.

Bit positions 32-39 of general register 0 contain the length of cipher feedback in bytes (LCFB, also known as “s”), and bit positions 57-63 of general register 0 contain the function code. Figure 7-75 shows the assigned function codes for CIPHER MESSAGE WITH CIPHER FEEDBACK. All other function codes are unassigned. For cipher functions, bit 56 is the modifier bit which specifies whether an encryption or a decryption operation is to be performed. The modifier bit is ignored for all other functions. Bits 0-31 and 40-55 of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.

The function codes for CIPHER MESSAGE WITH CIPHER FEEDBACK are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>KMF-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>KMF-DEA</td>
<td>16</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>KMF-TDEA-128</td>
<td>24</td>
<td>8</td>
</tr>
<tr>
<td>3</td>
<td>KMF-TDEA-192</td>
<td>32</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>KMF-Encrypted-DEA</td>
<td>40</td>
<td>8</td>
</tr>
<tr>
<td>10</td>
<td>KMF-Encrypted-TDEA-128</td>
<td>48</td>
<td>8</td>
</tr>
<tr>
<td>11</td>
<td>KMF-Encrypted-TDEA-192</td>
<td>56</td>
<td>8</td>
</tr>
<tr>
<td>18</td>
<td>KMF-AES-128</td>
<td>32</td>
<td>16</td>
</tr>
<tr>
<td>19</td>
<td>KMF-AES-192</td>
<td>40</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>KMF-AES-256</td>
<td>48</td>
<td>16</td>
</tr>
<tr>
<td>26</td>
<td>KMF-Encrypted-AES-128</td>
<td>64</td>
<td>16</td>
</tr>
<tr>
<td>27</td>
<td>KMF-Encrypted-AES-192</td>
<td>72</td>
<td>16</td>
</tr>
<tr>
<td>28</td>
<td>KMF-Encrypted-AES-256</td>
<td>80</td>
<td>16</td>
</tr>
</tbody>
</table>

**Explanation:**

- The size of ciphertext and plaintext segments (s) range from 1 to the data-block size, depending on the value of the LCFB in bits 32-39 of general register 0.
- Not applicable

Figure 7-75. Function Codes for CIPHER MESSAGE WITH CIPHER FEEDBACK

All other function codes are unassigned.

The query function provides the means of indicating the availability of the other functions. The contents of general registers R1, R2, and R2 + 1 are ignored for the query function.

For all other functions, the second operand is ciphered as specified by the function code using a cryptographic key and an initial chaining value in the parameter block, and the result is placed in the first-operand location. The chaining value is updated as part of the operation.

The R1 field designates a general register and must designate an even-numbered register; otherwise, a specification exception is recognized.
The $R_2$ field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first and second operands is specified by the contents of the $R_1$ and $R_2$ general registers, respectively. The number of bytes in the second operand location is specified in general register $R_2 + 1$ and must be a multiple of the cipher-feedback length in bits 32-39 of general register 0; otherwise, a specification exception is recognized. The first operand is the same length as the second operand.

As part of the operation, the addresses in general registers $R_1$ and $R_2$ are incremented by the number of bytes processed, and the length in general register $R_2 + 1$ is decremented by the same number. The formation and updating of the addresses and length is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers $R_1$ and $R_2$ constitute the addresses of the first and second operands, respectively, and the contents of bit positions 0-39 are ignored; bits 40-63 of the updated addresses replace the corresponding bits in general registers $R_1$ and $R_2$; carries out of bit position 40 of the updated address are ignored, and the contents of bit positions 32-39 of general registers $R_1$ and $R_2$ are set to zeros. In the 31-bit addressing mode, the contents of bit positions 33-63 of general registers $R_1$ and $R_2$ constitute the addresses of the first and second operands, respectively, and the contents of bit positions 0-32 are ignored; bits 33-63 of the updated addresses replace the corresponding bits in general registers $R_1$ and $R_2$; carries out of bit position 33 of the updated address are ignored, and the content of bit position 32 of general registers $R_1$ and $R_2$ is set to zero. In the 64-bit addressing mode, the contents of bit positions 0-63 of general registers $R_1$ and $R_2$ constitute the addresses of the first and second operands, respectively; bits 0-63 of the updated addresses replace the contents of general registers $R_1$ and $R_2$, and carries out of bit position 0 are ignored.

In both the 24-bit and the 31-bit addressing modes, the contents of bit positions 32-63 of general register $R_2 + 1$ form a 32-bit unsigned binary integer which specifies the number of bytes in the first and second operands, and the contents of bit positions 0-31 are ignored; bits 32-63 of the updated value replace the corresponding bits in general register $R_2 + 1$. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register $R_2 + 1$ form a 64-bit unsigned binary integer which specifies the number of bytes in the first and second operands; and the updated value replaces the contents of general register $R_2 + 1$.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers $R_1$, $R_2$, and $R_2 + 1$ always remain unchanged.

Figure 7-76 on page 7-77 shows the contents of the general registers just described.

In the access-register mode, access registers 1, $R_1$, and $R_2$ specify the address spaces containing the parameter block, first, and second operands, respectively.

The result is obtained as if processing starts at the left end of both the first and second operands and proceeds to the right, block by block. The operation is ended when the number of bytes in the second operand as specified in general register $R_2 + 1$ have been processed and placed at the first-operand location (called normal completion) or when a CPU-determined number of blocks that is less than the length of the second operand have been processed (called partial completion). The CPU-determined number of blocks depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of blocks is usually non-zero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.

The results in the first-operand location and the chaining-value field are unpredictable if any of the following situations occur:

1. The cryptographic-key field or the encrypted cryptographic-key field overlaps any portion of the first operand.
2. The chaining-value field overlaps any portion of the first operand or the second operand.
3. The first and second operands overlap destructively. Operands are said to overlap destructively when the first-operand location would be used as a source after data would have been moved into it, assuming processing to be performed from left to right and one byte at a time.
When the operation ends due to normal completion, condition code 0 is set and the resulting value in $R_2 + 1$ is zero. When the operation ends due to partial completion, condition code 3 is set and the resulting value in $R_2 + 1$ is nonzero.

A PER storage-alteration event may be recognized both for the first-operand location and for the portion of the parameter block that is stored. A PER zero-address-detection event may be recognized for the first- and second-operand locations and for the parameter block. When PER events are detected for one or more of these locations, it is unpredictable which location is identified in the PER access identification (PAID) and PER ASCE ID (AI).

When a storage-alteration PER event is recognized, fewer than 4K additional bytes are stored into the first-operand locations before the event is reported.

When the second-operand length is initially zero, the parameter block, first, and second operands are not accessed, general registers $R_1$, $R_2$, and $R_2 + 1$ are not changed, and condition code 0 is set.

When the contents of the $R_1$ and $R_2$ fields are the same, the contents of the designated registers are incremented only by the number of bytes processed, not by twice the number of bytes processed.
As observed by this CPU, other CPUs, and channel programs, references to the parameter block and storage operands may be multiple-access references, accesses to these storage locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

In certain unusual situations, instruction execution may complete by setting condition code 3 without updating the registers and chaining value to reflect the last unit of the first and second operands processed. The size of the unit processed in this case depends on the situation and the model, but is limited such that the portion of the first and second operands which have been processed and not reported do not overlap in storage. In all cases, change bits are set and PER storage-alteration events are reported, when applicable, for all first-operand locations processed.

For functions that perform a comparison of the encrypted cryptographic key with the wrapping-key verification-pattern register, it is unpredictable whether access exceptions and PER zero-address-detection events are recognized for the first and second operands when the comparison results in a mismatch.

Access exceptions may be reported for a larger portion of an operand than is processed in a single execution of the instruction; however, access exceptions are not recognized for locations beyond the length of an operand nor for locations more than 4K bytes beyond the current location being processed.

**Symbols Used in Function Descriptions**

The following symbols are used in the subsequent description of the CIPHER MESSAGE WITH CIPHER FEEDBACK functions. For data-encryption-algorithm (DEA) functions, the DEA-key-parity bit in each byte of the DEA key is ignored, and the operation proceeds normally, regardless of the DEA-key parity of the key.

Further description of the data-encryption algorithm may be found in Reference [11.] on page xxviii. Further description of the AES standard may be found in Reference [12.] on page xxviii. Further description of the cipher-feedback mode of encryption and decryption may be found in Reference [14.] on page xxviii.

**Figure 7-77. Symbol For Bit-Wise Exclusive OR**

**Figure 7-78. Symbols for DEA Encryption and Decryption**

**Figure 7-79. Symbols for AES-128 Encryption**
KMF-Query (Function Code 0)
The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the function has the following format:

```
0 Status Word
8   Chaining Value (CV)
```

Figure 7-82. Parameter Block for KMF-Query

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the CIPHER MESSAGE WITH CIPHER FEEDBACK instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the KMF-Query function completes; condition codes 1 and 3 are not applicable to this function.

In the following function descriptions, the term input block refers to the 8- or 16-byte input to the DEA or AES algorithms, respectively. Similarly, the term output block refers to the 8- or 16-byte results from the respective algorithms. The term segment refers to the s-byte portions of the first and second operands.

KMF-DEA (Function Code 1)

KMF-Encrypted-DEA (Function Code 9)
The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMF-DEA function has the following format:

```
0 Chaining Value (CV)
8   Cryptographic Key (K)
```

Figure 7-83. Parameter Block for KMF-DEA

For the KMF-DEA function, the chaining value is in byte offset 0-7 of the parameter block and the cryptographic key is in byte offsets 8-15 of the parameter block.

The parameter block used for the KMF-Encrypted-DEA function has the following format:

```
0 Chaining Value (CV)
8   Encrypted Cryptographic Key (WK_d(K))
16  DEA Wrapping-Key
24  Verification Pattern
32  (WK_dVP)
```

Figure 7-84. Parameter Block for KMF-Encrypted-DEA

For the KMF-Encrypted-DEA function, the contents of byte offsets 16-39 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first operand and parameter-block locations remain unchanged, and the operation is completed by set-
The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The s-byte plaintext segments (P1, P2, ..., Pn) in operand 2 are enciphered using the DEA-encryption algorithm with the 64-bit cryptographic key and the 64-bit chaining value, where s is the length of cipher feedback in bytes (LCFB).

The first input block to the DEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte plaintext segment to form a s-byte ciphertext segment. The remaining (8 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (8 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a ciphertext segment is produced for every plaintext segment, or until a CPU-determined number of ciphertext segments have been produced.

The ciphertext segments (C1, C2, ..., Cn) are stored in operand 1. The final next-input block is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-50.

When the modifier bit in general register 0 is one, a decipher operation is performed. The s-byte ciphertext segments (C1, C2, ..., Cn) in operand 2 are deciphered using the DEA-encryption algorithm with the 64-bit cryptographic key and the 64-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the DEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte ciphertext segment to form a s-byte plaintext segment. The remaining (8 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (8 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a plaintext segment is produced for every ciphertext segment, or until a CPU-determined number of plaintext segments have been produced.
The plaintext segments (P1, P2, ..., Pn) are stored in operand 1. The final next-input block (OCV) is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-86.

The parameter block used for the KMF-Encrypted-TDEA-128 function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Encrypted Cryptographic Key (WKd(K))</td>
</tr>
<tr>
<td>16</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>
```

For the KMF-Encrypted-TDEA-128 function, the contents of byte offsets 24-47 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-7 of the parameter block contain the chaining value, and the contents of byte offsets 8-23 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key. (See the section, “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The s-byte plaintext segments (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA-encryption algorithm with the 128-bit cryptographic key and the 64-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the TDEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte plaintext segment to form a s-byte ciphertext segment. The remaining (8 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (8 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a ciphertext segment is produced for every plaintext segment, or until a CPU-determined number of ciphertext segments have been produced.
The ciphertext segments (C1, C2, ..., Cn) are stored in operand 1. The final next-input block is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-89.

When the modifier bit in general register 0 is one, a decipher operation is performed. The s-byte ciphertext segments (C1, C2, ..., Cn) in operand 2 are deciphered using the TDEA-encryption algorithm with the 128-bit cryptographic key and the 64-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the TDEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte ciphertext segment to form a s-byte plaintext segment. The remaining (8 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (8 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a plaintext segment is produced for every ciphertext segment, or until a CPU-determined number of plaintext segments have been produced.

The plaintext segments (P1, P2, ..., Pn) are stored in operand 1. The final next-input block (OCV) is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-90.

**KMF-TDEA-192 (Function Code 3)**

**KMF-Encrypted-TDEA-192 (Function Code 11)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.
The parameter block used for the KMF-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key 1 (K1)</td>
</tr>
<tr>
<td>16</td>
<td>Cryptographic Key 2 (K2)</td>
</tr>
<tr>
<td>24</td>
<td>Cryptographic Key 3 (K3)</td>
</tr>
</tbody>
</table>

**Figure 7-91. Parameter Block for KMF-TDEA-192**

For the KMF-TDEA-192 function, the chaining value is in byte offset 0-7 of the parameter block and the cryptographic key is in byte offsets 8-31 of the parameter block.

The parameter block used for the KMF-Encrypted-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Encrypted Cryptographic Key (WKd(K))</td>
</tr>
<tr>
<td>16</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td></td>
</tr>
<tr>
<td>40</td>
<td></td>
</tr>
<tr>
<td>48</td>
<td></td>
</tr>
</tbody>
</table>

**Figure 7-92. Parameter Block for KMF-Encrypted-TDEA-192**

For the KMF-Encrypted-TDEA-192 function, the contents of byte offsets 32-55 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-7 of the parameter block contain the chaining value, and the contents of byte offsets 8-31 of the parameter block are deciphered using the DEA wrapping key to obtain the 192-bit cryptographic key. (See the section, “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The s-byte plaintext segments (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA-encryption algorithm with the 192-bit cryptographic key and the 64-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the TDEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte plaintext segment to form a s-byte ciphertext segment. The remaining (8 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (8 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a ciphertext segment is produced for every plaintext segment, or until a CPU-determined number of ciphertext segments have been produced.

The ciphertext segments (C1, C2, ..., Cn) are stored in operand 1. The final next-input block (OCV) is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-93.

**Figure 7-93. KMF-TDEA-192 Encipher Operation**
When the modifier bit in general register 0 is one, a decipher operation is performed. The s-byte ciphertext segments (C1, C2, ..., Cn) in operand 2 are deciphered using the TDEA-encryption algorithm with the 192-bit cryptographic key and the 64-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the TDEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte ciphertext segment to form a s-byte plaintext segment. The remaining (8 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (8 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a plaintext segment is produced for every ciphertext segment, or until a CPU-determined number of plaintext segments have been produced.

The plaintext segments (P1, P2, ..., Pn) are stored in operand 1. The final next-input block is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-94.

Figure 7-93. KMF-TDEA-192 Encipher Operation

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMF-AES-128 function has the following format:

Figure 7-95. Parameter Block for KMF-AES-128
For the KMF-AES-128 function, the chaining value is in byte offset 0-15 of the parameter block and the cryptographic key is in byte offsets 16-31 of the parameter block.

The parameter block used for the KMF-Encrypted-AES-128 function has the following format:

For the KMF-Encrypted-AES-128 function, the contents of byte offsets 32-63 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-15 of the parameter block contain the chaining value, and the contents of byte offsets 16-31 of the parameter block are deciphered using the AES wrapping key to obtain the 128-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The s-byte plaintext segments (P1, P2, ..., Pn) in operand 2 are enciphered using the AES-encryption algorithm with the 128-bit cryptographic key and the 128-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte plaintext segment to form a s-byte ciphertext segment. The remaining (16 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (16 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a ciphertext segment is produced for every plaintext segment, or until a CPU-determined number of ciphertext segments have been produced.

The ciphertext segments (C1, C2, ..., Cn) are stored in operand 1. The final next-input block is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-97.

When the modifier bit in general register 0 is one, a decipher operation is performed. The s-byte ciphertext segments (C1, C2, ..., Cn) in operand 2 are deciphered using the AES-encryption algorithm with the 128-bit cryptographic key and the 128-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte ciphertext segment to form a s-byte plaintext segment. The remaining (16 - s) bytes of each output block are ignored. Each plaintext segment is concatenated to the right of the (16 - s) rightmost bytes of the previous ciphertext segment to form the next input block.

The process is repeated with the successive input blocks until a plaintext segment is produced for every ciphertext segment, or until a CPU-determined number of plaintext segments have been produced.

The plaintext segments (P1, P2, ..., Pn) are stored in operand 1. The final next-input block is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-97.
segment. The remaining (16 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (16 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a plaintext segment is produced for every ciphertext segment, or until a CPU-determined number of plaintext segments have been produced.

The plaintext segments (P1, P2, ..., Pn) are stored in operand 1. The final next-input block (OCV) is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-98.

The parameter block used for the KMF-AES-192 function has the following format:

![Figure 7-99. Parameter Block for KMF-AES-192](image)

For the KMF-AES-192 function, the chaining value is in byte offset 0-15 of the parameter block and the cryptographic key is in byte offsets 16-39 of the parameter block.

The parameter block used for the KMF-Encrypted-AES-192 function has the following format:

![Figure 7-100. Parameter Block for KMF-Encrypted-AES-192](image)

For the KMF-Encrypted-AES-192 function, the contents of byte offsets 40-71 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-15 of the parameter block contain the chaining value, and the contents of byte offsets 16-39 of the parameter block are deciphered using the AES wrapping key to obtain the 192-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The s-byte plaintext

---

**KMF-AES-192 (Function Code 19)**

**KMF-Encrypted-AES-192 (Function Code 27)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

Note: The rightmost (16-s) bytes of the output block from the AES-encipher operation are ignored.

---

**Symbol Explanation**

- ||: Concatenation
- |j: Input block j to AES
- RB(Ij): Rightmost (16-s) bytes of input block j

**Figure 7-98. KMF-AES-128 Decipher Operation**
segments (P1, P2, ..., Pn) in operand 2 are enciphered using the AES-encryption algorithm with the 192-bit cryptographic key and the 128-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte plaintext segment to form a s-byte ciphertext segment. The remaining (16 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (16 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a ciphertext segment is produced for every plaintext segment, or until a CPU-determined number of ciphertext segments have been produced.

The ciphertext segments (C1, C2, ..., Cn) are stored in operand 1. The final next-input block (OCV) is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-101.

When the modifier bit in general register 0 is one, a decipher operation is performed. The s-byte ciphertext segments (C1, C2, ..., Cn) in operand 2 are deciphered using the AES-encryption algorithm with the 192-bit cryptographic key and the 128-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte ciphertext segment to form a s-byte plaintext segment. The remaining (16 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (16 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a plaintext segment is produced for every ciphertext segment, or until a CPU-determined number of plaintext segments have been produced.

The plaintext segments (P1, P2, ..., Pn) are stored in operand 1. The final next-input block (OCV) is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-102.
CIPHER MESSAGE WITH CIPHER FEEDBACK

KMF-AES-256 (Function Code 20)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-7 on page 7-52.

The parameter block used for the KMF-AES-256 function has the following format:

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td>l</td>
<td>Concatenation</td>
</tr>
<tr>
<td>l</td>
<td>Input block l to AES</td>
</tr>
<tr>
<td>RB(l)</td>
<td>Rightmost (16-s) bytes of input block l</td>
</tr>
</tbody>
</table>

Note: The rightmost (16-s) bytes of the output block from the AES-decipher operation are ignored.

For the KMF-AES-256 function, the chaining value is in byte offset 0-15 of the parameter block and the cryptographic key is in byte offsets 16-47 of the parameter block.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The s-byte plaintext segments (P1, P2, ..., Pn) in operand 2 are enciphered using the AES-encryption algorithm with the 256-bit cryptographic key and the 128-bit chaining value, where s is the length of cipher feedback in bytes.

The parameter block used for the KMF-Encrypted-AES-256 function has the following format:

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>Cryptographic Key (K)</td>
</tr>
<tr>
<td>40</td>
<td></td>
</tr>
<tr>
<td>48</td>
<td></td>
</tr>
<tr>
<td>56</td>
<td></td>
</tr>
<tr>
<td>64</td>
<td>AES Wrapping-Key Verification Pattern (WK(VP))</td>
</tr>
<tr>
<td>72</td>
<td></td>
</tr>
<tr>
<td>80</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

For the KMF-Encrypted-AES-256 function, the contents of byte offsets 48-79 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-15 of the parameter block contain the chaining value, and the contents of byte offsets 16-47 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The process is repeated with the successive input blocks until a ciphertext segment is produced for every plaintext segment, or until a CPU-determined number of ciphertext segments have been produced.

The ciphertext segments (C1, C2, ..., Cn) are stored in operand 1. The final next-input block (OCV) is
stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-105.

When the modifier bit in general register 0 is one, a decipher operation is performed. The s-byte ciphertext segments (C1, C2, ..., Cn) in operand 2 are deciphered using the AES-encryption algorithm with the 256-bit cryptographic key and the 128-bit chaining value, where s is the length of cipher feedback in bytes.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. The s leftmost bytes of each output block are exclusive-ORed with the corresponding s-byte ciphertext segment to form a s-byte plaintext segment. The remaining (16 - s) bytes of each output block are ignored. Each ciphertext segment is concatenated to the right of the (16 - s) rightmost bytes of the previous input block to form the next input block.

The process is repeated with the successive input blocks until a plaintext segment is produced for every ciphertext segment, or until a CPU-determined number of plaintext segments have been produced.

The plaintext segments (P1, P2, ..., Pn) are stored in operand 1. The final next-input block is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-106.

### Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. For DEA or TDEA functions, bits 32-39 of general register 0 specify a value that is zero or greater than 8.
2. For AES functions, bits 32-39 of general register 0 specify a value that is zero or greater than 16.
3. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.
4. The R1 or R2 field designates an odd-numbered register or general register 0.
5. The second operand length is not a multiple of the length of cipher feedback. This specification-exception condition does not apply to the query functions.
Resulting Condition Code:

- 0  Normal completion
- 1  Verification-pattern mismatch
- 2  Partial completion

Program Exceptions:

- Access (fetch, operand 2, cryptographic key, and wrapping-key verification pattern; store, operand 1; fetch and store, chaining value)
- Operation (if the message-security-assist extension 4 is not installed)
- Specification
- Transaction constraint

Programming Notes:

1. See the programming notes for CIPHER MESSAGE WITH CHAINING.
2. In earlier versions of the architecture, CIPHER MESSAGE WITH CIPHER FEEDBACK was known as CIPHER MESSAGE WITH CFB.
3. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

CIPHER MESSAGE WITH COUNTER

KMCTR R1,R2,R3 [RRF-b]

A function specified by the function code in general register 0 is performed.

Bits 20-23 of the instruction are ignored.

Bit positions 57-63 of general register 0 contain the function code. Figure 7-108 shows the assigned function codes for CIPHER MESSAGE WITH COUNTER. All other function codes are unassigned. For cipher functions, bit 56 is the modifier bit which specifies whether an encryption or a decryption operation is to be performed. The modifier bit is ignored for all other functions. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.

Figure 7-108. Priority of Execution: KMF
The function codes for CIPHER MESSAGE WITH COUNTER are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>KMCTR-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>KMCTR-DEA</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>KMCTR-TDEA-128</td>
<td>16</td>
<td>8</td>
</tr>
<tr>
<td>3</td>
<td>KMCTR-TDEA-192</td>
<td>24</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>KMCTR-Encrypted-DEA</td>
<td>32</td>
<td>8</td>
</tr>
<tr>
<td>10</td>
<td>KMCTR-Encrypted-TDEA-128</td>
<td>40</td>
<td>8</td>
</tr>
<tr>
<td>11</td>
<td>KMCTR-Encrypted-TDEA-192</td>
<td>48</td>
<td>8</td>
</tr>
<tr>
<td>18</td>
<td>KMCTR-AES-128</td>
<td>16</td>
<td>16</td>
</tr>
<tr>
<td>19</td>
<td>KMCTR-AES-192</td>
<td>24</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>KMCTR-AES-256</td>
<td>32</td>
<td>16</td>
</tr>
<tr>
<td>26</td>
<td>KMCTR-Encrypted-AES-128</td>
<td>48</td>
<td>16</td>
</tr>
<tr>
<td>27</td>
<td>KMCTR-Encrypted-AES-192</td>
<td>56</td>
<td>16</td>
</tr>
<tr>
<td>28</td>
<td>KMCTR-Encrypted-AES-256</td>
<td>64</td>
<td>16</td>
</tr>
</tbody>
</table>

*Explanation:

— Not applicable*

*Figure 7-108. Function Codes for CIPHER MESSAGE WITH COUNTER*

All other function codes are unassigned.

The query function provides the means of indicating the availability of the other functions. The contents of general registers \(R_1, R_2, R_2 + 1\), and \(R_3\) are ignored for the query function.

For all other functions, the second operand is ciphered as specified by the function code using a cryptographic key and counter values, and the result is placed in the first-operand location.

The \(R_1\) field designates a general register and must designate an even-numbered register; otherwise, a specification exception is recognized.

The \(R_2\) field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The \(R_3\) field designates a general register and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first, second, and third operands is specified by the contents of the \(R_1, R_2, \) and \(R_3\) general registers, respectively. The number of bytes in the second-operand location is specified in general register \(R_2 + 1\). The first operand and the third operand are the same length as the second operand.

As part of the operation, the addresses in general registers \(R_1, R_2,\) and \(R_3\) are incremented by the number of bytes processed, and the length in general register \(R_2 + 1\) is decremented by the same number. The formation and updating of the addresses and length is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers \(R_1, R_2,\) and \(R_3\) constitute the addresses of the first, second, and third operands, respectively, and the contents of bit positions 0-39 are ignored; bits 40-63 of the updated addresses replace the corresponding bits in general registers \(R_1, R_2,\) and \(R_3\) carries out of bit position 40 of the updated address are ignored, and the contents of bit positions 32-39 of general registers \(R_1, R_2,\) and \(R_3\) are set to zeros. In the 31-bit addressing mode, the contents of bit positions 33-63 of general registers \(R_1, R_2,\) and \(R_3\) constitute the addresses of the first, second, and third operands, respectively, and the contents of bit positions 0-32 are ignored; bits 33-63 of the updated addresses replace the corresponding bits in general registers \(R_1, R_2,\) and \(R_3\) carries out of bit position 33 of the updated address are ignored, and the content of bit position 32 of general registers \(R_1, R_2,\) and \(R_3\) is set to zero. In the 64-bit addressing mode, the contents of bit positions 0-63 of general registers \(R_1, R_2,\) and \(R_3\) constitute the addresses of the first, second, and third operands, respectively; bits 0-63 of the updated addresses replace the contents of general registers \(R_1, R_2,\) and \(R_3,\) and carries out of bit position 0 are ignored.

In both the 24-bit and the 31-bit addressing modes, the contents of bit positions 32-63 of general register \(R_2 + 1\) form a 32-bit unsigned binary integer which specifies the number of bytes in the first, second, and third operands, and the contents of bit positions 0-31 are ignored; bits 32-63 of the updated value replace the corresponding bits in general register \(R_2 + 1\). In the 64-bit addressing mode, the contents of bit positions 0-63 of general register \(R_2 + 1\) form a 64-bit unsigned binary integer which specifies the number of bytes in the first, second, and third operands; the updated value replaces the contents of general register \(R_2 + 1\).
In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers \( R_1 \), \( R_2 \), \( R_2 +1 \), and \( R_3 \) always remain unchanged.

Figure 7-109 on page 7-92 shows the contents of the general registers just described.

### All Addressing Modes

<table>
<thead>
<tr>
<th>GR0</th>
<th>( 0 )</th>
<th>( 8 )</th>
<th>( 16 )</th>
<th>( 56 )</th>
<th>( 63 )</th>
</tr>
</thead>
</table>

### 24-Bit Addressing Mode

<table>
<thead>
<tr>
<th>GR1</th>
<th>( 0 )</th>
<th>( 40 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R1</th>
<th>( 0 )</th>
<th>( 40 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R2</th>
<th>( 0 )</th>
<th>( 40 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R2 +1</th>
<th>( 0 )</th>
<th>( 32 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R3</th>
<th>( 0 )</th>
<th>( 40 )</th>
</tr>
</thead>
</table>

### 31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>GR1</th>
<th>( 0 )</th>
<th>( 33 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R1</th>
<th>( 0 )</th>
<th>( 33 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R2</th>
<th>( 0 )</th>
<th>( 33 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R2 +1</th>
<th>( 0 )</th>
<th>( 32 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R3</th>
<th>( 0 )</th>
<th>( 33 )</th>
</tr>
</thead>
</table>

### 64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>GR1</th>
<th>( 0 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R1</th>
<th>( 0 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R2</th>
<th>( 0 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R2 +1</th>
<th>( 0 )</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>R3</th>
<th>( 0 )</th>
</tr>
</thead>
</table>

Figure 7-109. General Register Assignment for KMCTR

In the access-register mode, access registers 1, \( R_1 \), \( R_2 \), and \( R_3 \) specify the address spaces containing the parameter block, first, second, and third operands, respectively.

The result is obtained as if processing starts at the left end of the first, second, and third operands and proceeds to the right, block by block. The operation is ended when the number of bytes in the second oper-
and as specified in general register \( R_2 + 1 \) have been processed and placed at the first-operand location (called normal completion) or when a CPU-determined number of blocks that is less than the length of the second operand have been processed (called partial completion). The CPU-determined number of blocks depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of blocks is usually nonzero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.

The results in the first-operand location are unpredictable if any of the following situations occurs:

1. The cryptographic-key field or the encrypted cryptographic-key field overlaps any portion of the first operand.
2. The first and second operands overlap destructively.
3. The first and third operands overlap destructively.

Operands are said to overlap destructively when the first-operand location would be used as a source after data would have been moved into it, assuming processing to be performed from left to right and one byte at a time.

When the operation ends due to normal completion, condition code 0 is set and the resulting value in \( R_2 + 1 \) is zero. When the operation ends due to partial completion, condition code 3 is set and the resulting value in \( R_2 + 1 \) is nonzero.

A PER storage-alteration event may be recognized both for the first-operand location and for the portion of the parameter block that is stored. A PER zero-address-detection event may be recognized for the first-, second-, and third-operand locations and for the parameter block. When PER events are detected for one or more of these locations, it is unpredictable which location is identified in the PER access identification (PAID) and PER ASCE ID (AI).

When a storage-alteration PER event is recognized, fewer than 4K additional bytes are stored into the first-operand locations before the event is reported.

When the second-operand length is initially zero, the parameter block, first, second, and third operands are not accessed, general registers \( R_1, R_2, R_2 + 1, \) and \( R_3 \) are not changed, and condition code 0 is set.

When the contents of any two or all three of the \( R_1, R_2 \) and \( R_3 \) fields are the same, the contents of the designated registers are incremented only by the number of bytes processed, not by a multiple of the number of bytes processed.

As observed by this CPU, other CPUs, and channel programs, references to the parameter block and storage operands may be multiple-access references, accesses to these storage locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

In certain unusual situations, instruction execution may complete by setting condition code 3 without updating the registers to reflect the last unit of the first, second, and third operands processed. The size of the unit processed in this case depends on the situation and the model, but is limited such that the portion of the first and second operands which have been processed and not reported do not overlap in storage; and the portion of the first and third operands which have been processed and not reported do not overlap in storage. In all cases, change bits are set and PER storage-alteration events are reported, when applicable, for all first-operand locations processed.

For functions that perform a comparison of the encrypted cryptographic key with the wrapping-key verification-pattern register, it is unpredictable whether access exceptions and PER zero-address-detection events are recognized for the first, second, and third operands when the comparison results in a mismatch.

Access exceptions may be reported for a larger portion of an operand than is processed in a single execution of the instruction; however, access exceptions are not recognized for locations beyond the length of an operand nor for locations more than 4K bytes beyond the current location being processed.

Symbols Used in Function Descriptions

The following symbols are used in the subsequent description of the CIPHER MESSAGE WITH COUNTER functions. For data-encryption-algorithm (DEA) functions, the DEA-key-parity bit in each byte of the DEA key is ignored, and the operation proceeds normally, regardless of the DEA-key parity of the key.
Further description of the data-encryption algorithm may be found in Reference [11.] on page xxviii. Further description of the AES standard may be found in Reference [12.] on page xxviii. Further description of the counter mode of encryption and decryption may be found in Reference [14.] on page xxviii.

![Figure 7-110. Symbol For Bit-Wise Exclusive OR](image)

![Figure 7-111. Symbols for DEA Encryption](image)

![Figure 7-112. Symbols for AES-128 Encryption](image)

![Figure 7-113. Symbols for AES-192 Encryption](image)

![Figure 7-114. Symbols for AES-256 Encryption](image)

**KMCTR-Query (Function Code 0)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-109 on page 7-92.

The parameter block used for the function has the following format:

![Figure 7-115. Parameter Block for KMCTR-Query](image)

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the CIPHER MESSAGE WITH COUNTER instruction. When a bit is one, the
corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the KMCTR-Query function completes; condition codes 1 and 3 are not applicable to this function.

**KMCTR-DEA (Function Code 1)**

**KMCTR-Encrypted-DEA (Function Code 9)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-109 on page 7-92.

The parameter block used for the KMCTR-DEA function has the following format:

```
<table>
<thead>
<tr>
<th>0</th>
<th>63</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cryptographic Key (K)</td>
<td></td>
</tr>
</tbody>
</table>
```

*Figure 7-116. Parameter Block for KMCTR-DEA*

For the KMCTR-DEA function, the cryptographic key is in byte offsets 0-7 of the parameter block.

The parameter block used for the KMCTR-Encrypted-DEA function has the following format:

```
<table>
<thead>
<tr>
<th>0</th>
<th>63</th>
</tr>
</thead>
<tbody>
<tr>
<td>Encrypted Cryptographic Key (WKd(K))</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>63</td>
</tr>
<tr>
<td>DEA Wrapping-Key</td>
<td></td>
</tr>
<tr>
<td>Verification Pattern (WKdVP)</td>
<td></td>
</tr>
</tbody>
</table>
```

*Figure 7-117. Parameter Block for KMCTR-Encrypted-DEA*

For the KMCTR-Encrypted-DEA function, the contents of byte offsets 8-31 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-7 of the parameter block are deciphered using the DEA wrapping key to obtain the 64-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the DEA algorithm with the 64-bit cryptographic key and using 8-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-118.

```
Operand 2 in Storage
| P1 <8> | P2 <8> | P3 <8> | ... | Pn <8> |

Operand 3 in Storage
| R1 <8> | R2 <8> | R3 <8> | ... | Rn <8> |

| K <8> | DEA e | K <8> | DEA e | K <8> | DEA e | ... | K <8> | DEA e |

| P <8> | XOR | P2 <8> | XOR | P3 <8> | XOR | ... | Pn <8> | XOR |

Operand 1 in Storage
| C1 <8> | C2 <8> | C3 <8> | ... | Cn <8> |
```

*Figure 7-118. KMCTR DEA Encipher Operation Using 64-Bit Key*

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the DEA algorithm with the 64-bit cryptographic key and using 8-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The
plaintext blocks \((P_1, P_2, \ldots, P_n)\) are stored in operand 1. The operation is shown in Figure 7-119.

**Figure 7-119. KMCTR DEA Decipher Operation Using 64-Bit Key**

<table>
<thead>
<tr>
<th>Cipher Message with Counter</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Operand 1 in Storage</strong></td>
</tr>
<tr>
<td>(P_1 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(P_2 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(P_3 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(\ldots)</td>
</tr>
<tr>
<td>(P_n \langle 8 \rangle)</td>
</tr>
<tr>
<td><strong>Operand 2 in Storage</strong></td>
</tr>
<tr>
<td>(C_1 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(C_2 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(C_3 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(\ldots)</td>
</tr>
<tr>
<td>(C_n \langle 8 \rangle)</td>
</tr>
<tr>
<td><strong>Operand 3 in Storage</strong></td>
</tr>
<tr>
<td>(R_1 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(R_2 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(R_3 \langle 8 \rangle)</td>
</tr>
<tr>
<td>(\ldots)</td>
</tr>
<tr>
<td>(R_n \langle 8 \rangle)</td>
</tr>
</tbody>
</table>

The parameter block used for the KMCTR-Encrypted-TDEA-128 function has the following format:

<table>
<thead>
<tr>
<th>Encryption Cryptographic Key (WKd(K))</th>
</tr>
</thead>
<tbody>
<tr>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>

**Figure 7-121. Parameter Block for KMCTR Encrypted-TDEA-128**

For the KMCTR-Encrypted-TDEA-128 function, the contents of byte offsets 16-39 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-15 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key, \(K = K_1 || K_2\), where \(K_1\) is the leftmost 64 bits of \(K\) and \(K_2\) is the rightmost 64 bits of \(K\). (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

For the KMCTR-Encrypted-TDEA-128 function, the contents of byte offsets 0-15 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-15 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key, \(K = K_1 || K_2\), where \(K_1\) is the leftmost 64 bits of \(K\) and \(K_2\) is the rightmost 64 bits of \(K\). (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks \((P_1, P_2, \ldots, P_n)\) in operand 2 are enciphered using the TDEA (triple DEA) algorithm with the two 64-bit cryptographic keys and using 8-byte counter-value blocks \((R_1, R_2, \ldots, R_n)\) in operand 3. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining.
The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-122.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the TDEA algorithm with the two 64-bit cryptographic keys and using 8-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The operation is shown in Figure 7-123.

**KMCTR-TDEA-192 (Function Code 3)**

**KMCTR-Encrypted-TDEA-192 (Function Code 11)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-109 on page 7-92.

The parameter block used for the KMCTR-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Cryptographic Key 1 (K1)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key 2 (K2)</td>
</tr>
<tr>
<td>16</td>
<td>Cryptographic Key 3 (K3)</td>
</tr>
</tbody>
</table>

**Figure 7-124. Parameter Block for KMCTR-TDEA-192**

For the KMCTR-TDEA-192 function, the cryptographic key is in byte offsets 0-23 of the parameter block.
The parameter block used for the KMCTR-Encrypted-TDEA-192 function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-8</td>
<td>Encrypted Cryptographic Key</td>
</tr>
<tr>
<td>16</td>
<td>DEA Wrapping-Key Verif. Pattern</td>
</tr>
<tr>
<td>24-47</td>
<td></td>
</tr>
</tbody>
</table>
```

![Figure 7-125. Parameter Block for KMCTR-Encrypted-TDEA-192](image)

For the KMCTR-Encrypted-TDEA-192 function, the contents of byte offsets 24-47 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-23 of the parameter block are deciphered using the DEA wrapping key to obtain the 192-bit cryptographic key, K = K1 || K2 || K3, where K1 is the leftmost 64 bits of K, K2 is the middle 64 bits of K, and K3 is the rightmost 64 bits of K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA algorithm with the three 64-bit cryptographic keys and using 8-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each ciphertext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-126.

![Figure 7-126. KMCTR TDEA Encipher Operation Using 192-Bit Key](image)

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the TDEA algorithm with the three 64-bit cryptographic keys and using 8-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining.
The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The operation is shown in Figure 7-127.

For the KMCTR-AES-128 function, the cryptographic key is in byte offsets 0-15 of the parameter block.

The parameter block used for the KMCTR-encrypted-AES-128 function has the following format:

For the KMCTR-Encrypted-AES-128 function, the contents of byte offsets 16-47 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-15 of the parameter block are deciphered using the AES wrapping key to obtain the 128-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 128-bit cryptographic key and using 16-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The
CIPHER MESSAGE WITH COUNTER

ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-130.

KMCTR-AES-192 (Function Code 19)

KMCTR-Encrypted-AES-192 (Function Code 27)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-109 on page 7-92.

The parameter block used for the KMCTR-AES-192 function has the following format:

For the KMCTR-AES-192 function, the cryptographic key is in byte offsets 0-23 of the parameter block.

The parameter block used for the KMCTR-Encrypted-AES-192 function has the following format:

For the KMCTR-Encrypted-AES-192 function, the contents of byte offsets 24-55 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-23 of the parameter block are deciphered using the AES wrapping key to obtain the 192-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.
When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 192-bit cryptographic key and using 16-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-134.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES algorithm with the 192-bit cryptographic key and using 16-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The operation is shown Figure 7-135.

**Figure 7-134. KMCTR AES Encipher Operation Using 192-Bit Key**

**Figure 7-135. KMCTR AES Decipher Operation Using 192-Bit Key**

**KMCTR-AES-256 (Function Code 20)**

**KMCTR-Encrypted-AES-256 (Function Code 28)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-109 on page 7-92.

The parameter block used for the KMCTR-AES-256 function has the following format:

**Figure 7-136. Parameter Block for KMCTR-AES-256**

For the KMCTR-AES-256 function, the cryptographic key is in byte offsets 0-31 of the parameter block.
The parameter block used for the KMCTR-Encrypted-AES-256 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-16</td>
<td>Encrypted Cryptographic Key</td>
</tr>
<tr>
<td>16-24</td>
<td>AES Wrapping-Key Verification Pattern</td>
</tr>
<tr>
<td>24-32</td>
<td>AES Wrapping-Key Verification Pattern</td>
</tr>
</tbody>
</table>
| 32-63  | Contents of byte offsets 32-63 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-31 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

For the KMCTR-Encrypted-AES-256 function, the contents of byte offsets 32-63 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-31 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES algorithm with the 256-bit cryptographic key and using 16-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each plaintext block is independently enciphered; that is, the encipher operation is performed without chaining. The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The operation is shown in Figure 7-138.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES algorithm with the 256-bit cryptographic key and using 16-byte counter-value blocks (R1, R2, ..., Rn) in operand 3. Each ciphertext block is independently deciphered; that is, the decipher operation is performed without chaining. The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The operation is shown in Figure 7-139.

**Special Conditions for KMCTR**

A specification exception is recognized and no other action is taken if any of the following occurs:
1. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

2. The R1, R2, or R3 field designates an odd-numbered register or general register 0.

3. The second operand length is not a multiple of the data block size of the designated function (see Figure 7-108 on page 7-91 to determine the data block sizes for CIPHER MESSAGE WITH COUNTER functions). This specification-exception condition does not apply to the query functions.

**Resulting Condition Code:**

0  Normal completion
1  Verification-pattern mismatch
2  --
3  Partial completion

**Program Exceptions:**

- Access (fetch, operand 2, operand 3, cryptographic key, and wrapping-key verification pattern; store, operand 1)
- Operation (if the message-security-assist extension 4 is not installed)
- Specification
- Transaction constraint

---

**Programming Note:** As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

**CIPHER MESSAGE WITH OUTPUT FEEDBACK**

```
KMO  R1,R2 [RRE]
```

A function specified by the function code in general register 0 is performed.

Bits 16-23 of the instruction are ignored.

Bit positions 57-63 of general register 0 contain the function code. Figure 7-141 shows the assigned function codes for CIPHER MESSAGE WITH OUTPUT FEEDBACK. All other function codes are unassigned. For cipher functions, bit 56 is the modifier bit which specifies whether an encryption or a decryption operation is to be performed. The modifier bit is ignored for all other functions. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.
The function codes for CIPHER MESSAGE WITH OUTPUT FEEDBACK are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>KMO-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>KMO-DEA</td>
<td>16</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>KMO-TDEA-128</td>
<td>24</td>
<td>8</td>
</tr>
<tr>
<td>3</td>
<td>KMO-TDEA-192</td>
<td>32</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>KMO-Encrypted-DEA</td>
<td>40</td>
<td>8</td>
</tr>
<tr>
<td>10</td>
<td>KMO-Encrypted-TDEA-128</td>
<td>48</td>
<td>8</td>
</tr>
<tr>
<td>11</td>
<td>KMO-Encrypted-TDEA-192</td>
<td>56</td>
<td>8</td>
</tr>
<tr>
<td>18</td>
<td>KMO-AES-128</td>
<td>32</td>
<td>16</td>
</tr>
<tr>
<td>19</td>
<td>KMO-AES-192</td>
<td>40</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>KMO-AES-256</td>
<td>48</td>
<td>16</td>
</tr>
<tr>
<td>26</td>
<td>KMO-Encrypted-AES-128</td>
<td>64</td>
<td>16</td>
</tr>
<tr>
<td>27</td>
<td>KMO-Encrypted-AES-192</td>
<td>72</td>
<td>16</td>
</tr>
<tr>
<td>28</td>
<td>KMO-Encrypted-AES-256</td>
<td>80</td>
<td>16</td>
</tr>
</tbody>
</table>

Explanation:

— Not applicable

Figure 7-141. Function Codes for CIPHER MESSAGE WITH OUTPUT FEEDBACK

All other function codes are unassigned.

The query function provides the means of indicating the availability of the other functions. The contents of general registers R1, R2, and R2 + 1 are ignored for the query function.

For all other functions, the second operand is ciphered as specified by the function code using a cryptographic key and an initial chaining value in the parameter block, and the result is placed in the first-operand location. The chaining value is updated as part of the operation.

The R1 field designates a general register and must designate an even-numbered register; otherwise, a specification exception is recognized.

The R2 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first and second operands is specified by the contents of the R1 and R2 general registers, respectively. The number of bytes in the second-operand location is specified in general register R2 + 1. The first operand is the same length as the second operand.

As part of the operation, the addresses in general registers R1 and R2 are incremented by the number of bytes processed, and the length in general register R2 + 1 is decremented by the same number. The formation and updating of the addresses and length is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R2 constitute the addresses of the first and second operands, respectively, and the contents of bit positions 0-39 are ignored; bits 40-63 of the updated addresses replace the corresponding bits in general registers R1 and R2, carries out of bit position 40 of the updated address are ignored, and the contents of bit positions 32-39 of general registers R1 and R2 are set to zeros.

In the 31-bit addressing mode, the contents of bit positions 33-63 of general registers R1 and R2 constitute the addresses of the first and second operands, respectively, and the contents of bit positions 0-32 are ignored; bits 33-63 of the updated addresses replace the corresponding bits in general registers R1 and R2, carries out of bit position 33 of the updated address are ignored, and the content of bit position 32 of general registers R1 and R2 is set to zero.

In the 64-bit addressing mode, the contents of bit positions 0-63 of general registers R1 and R2 constitute the addresses of the first and second operands, respectively; bits 0-63 of the updated addresses replace the contents of general registers R1 and R2, and carries out of bit position 0 are ignored.

In both the 24-bit and the 31-bit addressing modes, the contents of bit positions 32-63 of general register R2 + 1 form a 32-bit unsigned binary integer which specifies the number of bytes in the first and second operands, and the contents of bit positions 0-31 are ignored; bits 32-63 of the updated value replace the corresponding bits in general register R2 + 1. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register R2 + 1 form a 64-bit unsigned binary integer which specifies the number of bytes in the first and second operands; and the updated value replaces the contents of general register R2 + 1.
In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers \( R_1 \), \( R_2 \), and \( R_2 + 1 \), always remain unchanged.

Figure 7-142 on page 7-105 shows the contents of the general registers just described.

In the access-register mode, access registers 1, \( R_1 \), and \( R_2 \) specify the address spaces containing the parameter block, first, and second operands, respectively.

The result is obtained as if processing starts at the left end of both the first and second operands and proceeds to the right, block by block. The operation is ended when the number of bytes in the second operand as specified in general register \( R_2 + 1 \) have been processed and placed at the first-operand location (called normal completion) or when a CPU-determined number of blocks that is less than the length of the second operand have been processed (called partial completion). The CPU-determined number of blocks depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of blocks is usually non-zero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.
The results in the first-operand location and the chaining-value field are unpredictable if any of the following situations occur:

1. The cryptographic-key field or the encrypted cryptographic-key field overlaps any portion of the first operand.
2. The chaining-value field overlaps any portion of the first operand or the second operand.
3. The first and second operands overlap destructively. Operands are said to overlap destructively when the first-operand location would be used as a source after data would have been moved into it, assuming processing to be performed from left to right and one byte at a time.

When the operation ends due to normal completion, condition code 0 is set and the resulting value in R2 + 1 is zero. When the operation ends due to partial completion, condition code 3 is set and the resulting value in R2 + 1 is nonzero.

A PER storage-alteration event may be recognized both for the first-operand location and for the portion of the parameter block that is stored. A PER zero-address-detection event may be recognized for the first- and second-operand locations and for the parameter block. When PER events are detected for one or more of these locations, it is unpredictable which location is identified in the PER access identification (PAID) and PER ASCE ID (AI).

When a storage-alteration PER event is recognized, fewer than 4K additional bytes are stored into the first-operand locations before the event is reported.

When the second-operand length is initially zero, the parameter block, first, and second operands are not accessed, general registers R1, R2, and R2 + 1 are not changed, and condition code 0 is set.

When the contents of the R1 and R2 fields are the same, the contents of the designated registers are incremented only by the number of bytes processed, not by twice the number of bytes processed.

For functions that perform a comparison of the encrypted cryptographic key with the wrapping-key verification-pattern register, it is unpredictable whether access exceptions and PER zero-address-detection events are recognized for the first and second operands when the comparison results in a mismatch.

Access exceptions may be reported for a larger portion of an operand than is processed in a single execution of the instruction; however, access exceptions are not recognized for locations beyond the length of an operand nor for locations more than 4K bytes beyond the current location being processed.

Symbols Used in Function Descriptions

The following symbols are used in the subsequent description of the CIPHER MESSAGE WITH OUTPUT FEEDBACK functions. For data-encryption-algorithm (DEA) functions, the DEA-key-parity bit in each byte of the DEA key is ignored, and the operation proceeds normally, regardless of the DEA-key parity of the key.

Further description of the data-encryption algorithm may be found in Reference [11.] on page xxviii. Further description of the AES standard may be found in Reference [12.] on page xxviii. Further description of the output-feedback mode of encryption and decryp-
tion may be found in Reference [14.] on page xxviii.

![Diagram](image1.png)

**Figure 7-143. Symbol For Bit-Wise Exclusive OR**

![Diagram](image2.png)

**Figure 7-144. Symbols for DEA Encryption and Decryption**

![Diagram](image3.png)

**Figure 7-145. Symbols for AES-128 Encryption**

![Diagram](image4.png)

**Figure 7-146. Symbols for AES-192 Encryption**

![Diagram](image5.png)

**Figure 7-147. Symbols for AES-256 Encryption**

**KMO-Query (Function Code 0)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-142 on page 7-105.

The parameter block used for the function has the following format:

![Diagram](image6.png)

**Figure 7-148. Parameter Block for KMO-Query**

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the CIPHER MESSAGE WITH OUTPUT FEEDBACK instruction. When a bit
is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the KMO-Query function completes; condition codes 1 and 3 are not applicable to this function.

**KMO-DEA (Function Code 1)**

**KMO-Encrypted-DEA (Function Code 9)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-142 on page 7-105.

The parameter block used for the KMO-DEA function has the following format:

```
0
8
Chaining Value (CV)
Cryptographic Key (K)
```

*Figure 7-149. Parameter Block for KMO-DEA*

For the KMO-DEA function, the chaining value is in byte offset 0-7 of the parameter block and the cryptographic key is in byte offsets 8-15 of the parameter block.

The parameter block used for the KMO-Encrypted-DEA function has the following format:

```
0
8
Chaining Value (CV)
Encrypted Cryptographic Key (WKd(K))
16
24
DEA Wrapping-Key Verification Pattern (WKdVP)
32
63
```

*Figure 7-150. Parameter Block for KMO-Encrypted-DEA*

For the KMO-Encrypted-DEA function, the contents of byte offsets 16-39 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-7 of the parameter block contain the chaining value, and the contents of byte offsets 8-15 of the parameter block are deciphered using the DEA wrapping key to obtain the 64-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the DEA-encryption algorithm with the 64-bit cryptographic key and the 64-bit chaining value.

The first input block to the DEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding plaintext block to form a ciphertext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a ciphertext block is produced for every plaintext block, or until a CPU-determined number of ciphertext blocks have been produced.

The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-151.

```
ICV <8>
K <8>
DEA e
K <8>
DEA e
...
DEA e
OCV
```

*Figure 7-151. KMO-DEA Encipher Operation*

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the DEA-encryption algorithm with the 64-bit cryptographic key and the 64-bit chaining value.

The first input block to the DEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed
with the corresponding ciphertext block to form a plaintext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a plaintext block is produced for every ciphertext block, or until a CPU-determined number of plaintext blocks have been produced.

The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-152.

The parameter block used for the KMO-Encrypted-TDEA-128 function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Encrypted Cryptographic Key 1 (K1)</td>
</tr>
<tr>
<td>16</td>
<td>Encrypted Cryptographic Key 2 (K2)</td>
</tr>
<tr>
<td>24</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>
```

For the KMO-Encrypted-TDEA-128 function, the contents of byte offsets 24-47 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-7 of the parameter block contain the chaining value, and the contents of byte offsets 8-23 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA-encryption algorithm with the 128-bit cryptographic key and the 64-bit chaining value.

The first input block to the TDEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding plaintext block to form a ciphertext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a ciphertext block is produced for every plaintext block, or until a CPU-determined number of ciphertext blocks have been produced.

The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-
value field of the parameter block. The operation is shown in Figure 7-155.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the DEA-encryption algorithm with the 128-bit cryptographic key and the 64-bit chaining value.

The first input block to the TDEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding ciphertext block to form a plaintext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a plaintext block is produced for every ciphertext block, or until a CPU-determined number of plaintext blocks have been produced.

The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-156.

KMO-TDEA-192 (Function Code 3)

KMO-Encrypted-TDEA-192 (Function Code 11)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-142 on page 7-105.

The parameter block used for the KMO-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Field Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key 1 (K1)</td>
</tr>
<tr>
<td>16</td>
<td>Cryptographic Key 2 (K2)</td>
</tr>
<tr>
<td>24</td>
<td>Cryptographic Key 3 (K3)</td>
</tr>
</tbody>
</table>

For the KMO-TDEA-192 function, the chaining value is in byte offset 0-7 of the parameter block and the cryptographic key is in byte offsets 8-31 of the parameter block.

Figure 7-155. KMO-TDEA-128 Encipher Operation

Figure 7-156. KMO-TDEA-128 Decipher Operation

Figure 7-157. Parameter Block for KMO-TDEA-192
The parameter block used for the KMO-Encrypted-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Encrypted Cryptographic Key (WK_e(K))</td>
</tr>
<tr>
<td>16</td>
<td>DEA Wrapping-Key Verification Pattern (WK_dVP)</td>
</tr>
</tbody>
</table>

For the KMO-Encrypted-TDEA-192 function, the contents of byte offsets 32-55 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-7 of the parameter block contain the chaining value, and the contents of byte offsets 8-31 of the parameter block are deciphered using the DEA wrapping key to obtain the 192-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 8-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the TDEA-encryption algorithm with the 192-bit cryptographic key and the 64-bit chaining value.

The first input block to the TDEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding plaintext block to form a ciphertext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a ciphertext block is produced for every plaintext block, or until a CPU-determined number of ciphertext blocks have been produced.

The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-159.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 8-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the DEA-encryption algorithm with the 192-bit cryptographic key and the 64-bit chaining value.

The first input block to the TDEA-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding ciphertext block to form a plaintext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a plaintext block is produced for every ciphertext block, or until a CPU-determined number of plaintext blocks have been produced.

The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-
value field of the parameter block. The operation is shown in Figure 7-160.

The parameter block used for the KMO-Encrypted-AES-128 function has the following format:

\[
\begin{array}{|c|}
\hline
0 & Chaining Value (CV) \\
8 & Encrypted Cryptographic Key (WK_a(K)) \\
16 & AES Wrapping-Key Verification-Pattern (WK_aVP) \\
24 & \\
60 & \\
\hline
\end{array}
\]

Figure 7-162. Parameter Block for KMO-Encrypted-AES-128

For the KMO-Encrypted-AES-128 function, the contents of byte offsets 32-63 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-15 of the parameter block contain the chaining value, and the contents of byte offsets 16-31 of the parameter block are deciphered using the AES wrapping key to obtain the 128-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES-encryption algorithm with the 128-bit cryptographic key and the 128-bit chaining value.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding plaintext block to form a ciphertext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a ciphertext block is produced for every plaintext block, or until a CPU-determined number of ciphertext blocks have been produced.
The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-163.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES-encryption algorithm with the 128-bit cryptographic key and the 128-bit chaining value.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding ciphertext block to form a plaintext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a plaintext block is produced for every ciphertext block, or until a CPU-determined number of plaintext blocks have been produced.

The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-164.

**KMO-AES-128 Encipher Operation**

**KMO-AES-128 Decipher Operation**

**KMO-AES-192 (Function Code 19)**

**KMO-Encrypted-AES-192 (Function Code 27)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-142 on page 7-105.

The parameter block used for the KMO-AES-192 function has the following format:

```
0 8 16 24 32 63
```

**Chaining Value (CV)**

**Cryptographic Key (K)**

For the KMO-AES-192 function, the chaining value is in byte offset 0-15 of the parameter block and the cryptographic key is in byte offsets 16-39 of the parameter block.
The parameter block used for the KMO-Encrypted-AES-192 function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-7</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8-15</td>
<td>Encrypted Cryptographic Key</td>
</tr>
<tr>
<td>16-23</td>
<td>(WK, k)</td>
</tr>
<tr>
<td>24-31</td>
<td>AES Wrapping-Key Verification Pattern (WK, VP)</td>
</tr>
</tbody>
</table>
```

The process is repeated with the successive input blocks until a ciphertext block is produced for every plaintext block, or until a CPU-determined number of ciphertext blocks have been produced.

The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-167.

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES-encryption algorithm with the 192-bit cryptographic key and the 128-bit chaining value.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding plaintext block to form a ciphertext block. Each output block is also used as the next input block.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES-encryption algorithm with the 192-bit cryptographic key and the 128-bit chaining value.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding ciphertext block to form a plaintext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a plaintext block is produced for every ciphertext block, or until a CPU-determined number of plaintext blocks have been produced.

The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-
value field of the parameter block. The operation is shown in Figure 7-168.

KMO-AES-256 (Function Code 20)

KMO-Encrypted-AES-256 (Function Code 28)
The locations of the operands and addresses used by the instruction are as shown in Figure 7-142 on page 7-105.

The parameter block used for the KMO-AES-256 function has the following format:

```
0  Chaining Value (CV)
  8
 16
 24
 32
 40
 48
 56
 64
 72
```

```
 0 63
```

```
ICV <16>
```

```
K  <24>
```

```
AES e
```

```
K  <24>
```

```
AES e
```

```
K  <24>
```

```
AES e
```

```
XOR
```

```
C1   <16>
```

```
XOR
```

```
C2   <16>
```

```
XOR
```

```
Cn   <16>
```

```
P1    <16>
```

```
P2    <16>
```

```
…
```

```
Pn    <16>
```

```
OCV
```

```
Encrypted Cryptographic Key (WKa(K))
```

```
AES Wrapping-Key Verification Pattern (WKaVP)
```

```
Figure 7-168. KMO-AES-192 Decipher Operation
```

Figure 7-169. Parameter Block for KMO-AES-256

For the KMO-AES-256 function, the chaining value is in byte offset 0-15 of the parameter block and the cryptographic key is in byte offsets 16-47 of the parameter block.

The parameter block used for the KMO-Encrypted-AES-256 function has the following format:

```
0  Chaining Value (CV)
  8
 16
 24
 32
 40
 48
 56
 64
 72
```

```
 0 63
```

```
ICV <16>
```

```
K  <24>
```

```
AES e
```

```
K  <24>
```

```
AES e
```

```
K  <24>
```

```
AES e
```

```
XOR
```

```
C1   <16>
```

```
XOR
```

```
C2   <16>
```

```
XOR
```

```
Cn   <16>
```

```
P1    <16>
```

```
P2    <16>
```

```
…
```

```
Pn    <16>
```

```
Encrypted Cryptographic Key (WKa(K))
```

```
AES Wrapping-Key Verification Pattern (WKaVP)
```

```
Figure 7-170. Parameter Block for KMO-AES-256
```

For the KMO-Encrypted-AES-256 function, the contents of byte offsets 48-79 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-15 of the parameter block contain the chaining value, and the contents of byte offsets 16-47 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The following description applies to both functions.

When the modifier bit in general register 0 is zero, an encipher operation is performed. The 16-byte plaintext blocks (P1, P2, ..., Pn) in operand 2 are enciphered using the AES-encryption algorithm with the 256-bit cryptographic key and the 128-bit chaining value.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding plaintext block to form a ciphertext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a ciphertext block is produced for every plaintext block, or until a CPU-determined number of ciphertext blocks have been produced.
The ciphertext blocks (C1, C2, ..., Cn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-171.

When the modifier bit in general register 0 is one, a decipher operation is performed. The 16-byte ciphertext blocks (C1, C2, ..., Cn) in operand 2 are deciphered using the AES-encryption algorithm with the 256-bit cryptographic key and the 128-bit chaining value.

The first input block to the AES-encryption algorithm is the initial chaining value (ICV) in the parameter block. Each input block is enciphered to produce an output block. Each output block is exclusive-ORed with the corresponding ciphertext block to form a plaintext block. Each output block is also used as the next input block.

The process is repeated with the successive input blocks until a plaintext block is produced for every ciphertext block, or until a CPU-determined number of plaintext blocks have been produced.

The plaintext blocks (P1, P2, ..., Pn) are stored in operand 1. The next input block, called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. The operation is shown in Figure 7-172.

Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.
2. The R1 or R2 field designates an odd-numbered register or general register 0.
3. The second operand length is not a multiple of the data block size of the designated function (see Figure 7-141 on page 7-104 to determine the data block sizes for CIPHER MESSAGE WITH OUTPUT FEEDBACK functions). This specification-exception condition does not apply to the query functions.

Resulting Condition Code:

0 Normal completion
1 Verification-pattern mismatch
2 --
3 Partial completion

Program Exceptions:

- Access (fetch, operand 2, cryptographic key, and wrapping-key verification pattern; store, operand 1; fetch and store, chaining value)
- Operation (if the message-security-assist extension 4 is not installed)
- Specification
- Transaction constraint

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.


7.B Operation exception.

7.C Transaction constraint

8. Specification exception due to invalid function code or invalid register number.

9. Specification exception due to invalid operand length.

10. Condition code 0 due to second-operand length originally zero.

11.A.1 Access exceptions for an access to the parameter block.

11.A.2. Condition code 1 due to verification-pattern mismatch.

11.B Access exceptions for an access to the first or second operand.

12. Condition code 0 due to normal completion (second-operand length originally nonzero, but stepped to zero).

13. Condition code 3 due to partial completion (second-operand length still nonzero).

**Figure 7-173. Priority of Execution: KMO**

**Programming Notes:**

1. See the programming notes for CIPHER MESSAGE WITH CHAINING.

2. In earlier versions of the architecture, CIPHER MESSAGE WITH OUTPUT FEEDBACK was known as CIPHER MESSAGE WITH OFB.

3. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

**COMPARE**

**Register-and-register formats:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Register Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>CR</td>
<td>R1, R2</td>
</tr>
<tr>
<td>'19'</td>
<td>R1, R2</td>
</tr>
<tr>
<td>CGR</td>
<td>R1, R2</td>
</tr>
<tr>
<td>'B920'</td>
<td>____________</td>
</tr>
<tr>
<td>CGFR</td>
<td>R1, R2</td>
</tr>
<tr>
<td>'B930'</td>
<td>____________</td>
</tr>
</tbody>
</table>

**Register-and-storage formats:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Register Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>C</td>
<td>R1, D1(X2, B2)</td>
</tr>
<tr>
<td>'S9'</td>
<td>R1, X2, B2, D2</td>
</tr>
<tr>
<td>CY</td>
<td>R1, D1(X2, B2)</td>
</tr>
<tr>
<td>'E3'</td>
<td>R1, X2, B2, DL2, DH2</td>
</tr>
<tr>
<td>'E3'</td>
<td>R1, X2, B2, DL2, DH2</td>
</tr>
<tr>
<td>CG</td>
<td>R1, D1(X2, B2)</td>
</tr>
<tr>
<td>'E3'</td>
<td>R1, X2, B2, DL2, DH2</td>
</tr>
<tr>
<td>CGF</td>
<td>R1, D1(X2, B2)</td>
</tr>
<tr>
<td>'E3'</td>
<td>R1, X2, B2, DL2, DH2</td>
</tr>
</tbody>
</table>

**COMPARE IMMEDIATE**

<table>
<thead>
<tr>
<th>Code</th>
<th>Register Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFI</td>
<td>R1, I2</td>
</tr>
<tr>
<td>'C2'</td>
<td>R1, 'D'</td>
</tr>
<tr>
<td>CFI</td>
<td>R1, I2</td>
</tr>
<tr>
<td>'C2'</td>
<td>R1, 'C'</td>
</tr>
</tbody>
</table>

7-117
COMPARE RELATIVE LONG

The first operand is compared with the second operand, and the result is indicated in the condition code.

For COMPARE (CR, C, CY), COMPARE IMMEDIATE (CFI), and COMPARE RELATIVE LONG (CRL), the operands are treated as 32-bit signed binary integers. For COMPARE (CRG, CG) and COMPARE RELATIVE LONG (CGRL), they are treated as 64-bit signed binary integers. For COMPARE (CGFR, CGF), COMPARE IMMEDIATE (CGFI), and COMPARE RELATIVE LONG (CGFRL), the second operand is treated as a 32-bit signed binary integer, and the first operand is treated as a 64-bit signed binary integer.

The displacement for C is treated as a 12-bit unsigned binary integer. The displacement for CY, CG, and CGF is treated as a 20-bit signed binary integer.

For COMPARE RELATIVE LONG, the contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand in storage. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

For COMPARE RELATIVE LONG (CRL, CGFRL), the second operand must be aligned on a word boundary, and for COMPARE RELATIVE LONG (CGRL), the second operand must be aligned on a doubleword boundary; otherwise, a specification exception is recognized.

Resulting Condition Code:

0  Operands equal
1  First operand low
2  First operand high
3  --

Program Exceptions:

- Access (operand 2 of C, CY, CG, CGF, CRL, CGRL, and CGFRL only)
- Operation (CY, if the long-displacement facility is not installed; CFI and CGFI, if the extended-immediate facility is not installed; CGFRL, CGRL, and CRL, if the general-instructions-extension facility is not installed)
- Specification (CGFRL, CGRL, and CRL only)

Programming Notes:

1. For COMPARE RELATIVE LONG, the second operand must be aligned on an integral boundary corresponding to the operand’s size.
2. When COMPARE RELATIVE LONG is the target of an execute-type instruction, the second-operand address is relative to the target address.

COMPARE AND BRANCH

For COMPARE RELATIVE LONG (CRL, CGFRL), the second operand must be aligned on a word boundary, and for COMPARE RELATIVE LONG (CGRL), the second operand must be aligned on a doubleword boundary; otherwise, a specification exception is recognized.
COMPARE IMMEDIATE AND BRANCH

CIB \( R_1, I_2, M_3, D_4 \) \([\text{RIS}]\)

\[ \begin{array}{cccccc}
\text{Comparison Result} & M_3 & \text{Bit} \\
\text{Equal} & 0 \\
\text{First operand low} & 1 \\
\text{First operand high} & 2 \\
\end{array} \]

The first operand is compared with the second operand. If the mask bit in the \( M_3 \) field corresponding to the comparison result is one, the instruction address in the current PSW is replaced by the branch address specified by the fourth operand; otherwise, normal instruction sequencing proceeds with the updated instruction address.

For COMPARE AND BRANCH (CRB), COMPARE AND BRANCH RELATIVE (CRJ), COMPARE IMMEDIATE AND BRANCH (CIB) and COMPARE IMMEDIATE AND BRANCH RELATIVE (CIJ), the first operand is treated as a 32-bit signed binary integer.

For COMPARE AND BRANCH (CGRB), COMPARE IMMEDIATE AND BRANCH (CGRJ), COMPARE IMMEDIATE AND BRANCH RELATIVE (CGIB) and COMPARE IMMEDIATE AND BRANCH RELATIVE (CGIJ), the contents of the \( RI_4 \) field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the branch address.

Condition Code: The code remains unchanged.

Program Exceptions:
- Operation (if the general-instructions-extension facility is not installed).
- Transaction constraint

Programming Notes:

1. When bit positions 0-2 of the \( M_3 \) field contain zeros, the instruction acts as a NOP, however this is not the preferred instruction with which to create a NOP. When bit positions 0-2 of the \( M_3 \) field contain 111 binary, a branch always occurs.

2. When COMPARE AND BRANCH RELATIVE or COMPARE IMMEDIATE AND BRANCH RELATIVE are the target of an execute-type instruction, the branch is relative to the target address. See “Branch-Address Generation” on page 5-12.

3. The high-level assembler (HLASM) provides extended-mnemonic formats for all of the multiple-operation instructions which perform a compare (arithmetic or logical) followed by a branch or trap. In the extended-mnemonic format, the mask field is not explicitly coded; rather the

and COMPARE IMMEDIATE AND BRANCH RELATIVE, the second operand is treated as an 8-bit signed binary integer.

Bit 3 of the \( M_3 \) field is reserved and should be zero; otherwise, the program may not operate compatibly in the future.

For COMPARE AND BRANCH IMMEDIATE AND BRANCH, the fourth operand is used as the branch address. For COMPARE AND BRANCH RELATIVE and COMPARE IMMEDIATE AND BRANCH RELATIVE, the second operand is treated as an 8-bit signed binary integer.

The first operand is treated as a 32-bit signed binary integer.
COMPARE AND FORM CODEWORD

The branch mask is implicitly indicated by the extended mnemonic.

The extended-mnemonic names are formed by concatenating the base mnemonic, followed by one of the suffix characters, as shown below.

<table>
<thead>
<tr>
<th>Suffix Chars</th>
<th>Meaning</th>
<th>Mask Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>E</td>
<td>Equal</td>
<td>8</td>
</tr>
<tr>
<td>H</td>
<td>First operand high</td>
<td>2</td>
</tr>
<tr>
<td>L</td>
<td>First operand low</td>
<td>4</td>
</tr>
<tr>
<td>NE</td>
<td>Not equal</td>
<td>6</td>
</tr>
<tr>
<td>NH</td>
<td>First operand not high</td>
<td>12</td>
</tr>
<tr>
<td>NL</td>
<td>First operand not low</td>
<td>10</td>
</tr>
</tbody>
</table>

Consider the following example of a COMPARE IMMEDIATE AND BRANCH RELATIVE (CGIJ) instruction that is coded using an extended mnemonic:

```
CGIJNE 10,-123,SKIP
```

The implied mask field corresponding to the mnemonic suffix (NE) is 6, thus the generated code is ECA60040857C hex.

General registers 1 and 3 contain the base addresses of the first and third operands. Bits 48-63 of general register 2 are used as an index for addressing both the first and third operands. General registers 1, 2, and 3 must all initially contain even values; otherwise, a specification exception is recognized.

In the access-register mode, access register 1 specifies the address space containing the first and third operands.

The size of the units by which the first and third operands are compared, the size of the resulting codeword, and the participation of bits 0-31 of general registers 1, 2, and 3 in the operation depend on the addressing mode. In the 24-bit or 31-bit addressing mode, the comparison unit is two bytes, the codeword is four bytes, and bits 0-31 are ignored and remain unchanged. In the 64-bit addressing mode, the comparison unit is six bytes, the codeword is eight bytes, and bits 0-31 are used in and may be changed by the operation.

**Operation in the 24-Bit or 31-Bit Addressing Mode**

The operation consists in comparing the first and third operands halfword by halfword and incrementing the index until an unequal pair of halfwords is found or the index exceeds the index limit. This proceeds in units of operation, between which interruptions may occur.

At the start of a unit of operation, the index, bits 48-63 of general register 2, is logically compared with the index limit. If the index is larger, the instruction is completed by placing bits 32-63 of general register 3, with bit 32 set to one, in bit positions 32-63 of general register 2, and by setting condition code 0.

If the index is less than or equal to the index limit, the index is applied to the first-operand and third-operand base addresses to locate the current pair of halfwords to be compared. The index, with 48 leftmost zeros appended, and bits 32-63 of general register 1, with 32 leftmost zeros appended, are added to form a 64-bit intermediate value. A carry out of bit position 32, if any, is ignored. The address of the current first-operand halfword is generated from the intermediate value by following the normal rules for operand address generation. The address of the current third-operand halfword is formed in the same manner by adding bits 32-63 of general register 3 and the index.
The current first-operand and third-operand half-words are logically compared. If they are equal, the contents of general register 2 are incremented by 2, and a unit of operation ends.

If the compare values are unequal, the contents of general register 2 are incremented by 2 and then shifted left logically by 16 bit positions. The shifting occurs only within bit positions 32-63. If the operand-control bit is zero, (1) the one's complement of the higher halfword is placed in bit positions 48-63 of general register 2, and (2) if operand 1 was higher, bits 32-63 of general registers 1 and 3 are interchanged. If the operand-control bit is one, (1) the lower halfword is placed in bit positions 48-63 of general register 2, and (2) if operand 1 was lower, bits 32-63 of general registers 1 and 3 are interchanged.

For the purpose of recognizing access exceptions, operand 1 and operand 3 are both considered to have a length equal to 2 more than the value of the index limit minus the index.

**Operation in the 64-bit Addressing Mode**

The operation consists in comparing the first and third operands in units of six bytes at a time and incrementing the index until an unequal pair of six-byte units is found or the index exceeds the index limit. This proceeds in units of operation, between which interruptions may occur.

At the start of a unit of operation, the index, bits 48-63 of general register 2, is logically compared with the index limit. If the index is larger, the instruction is completed by placing bits 0-63 of general register 3, with bit 0 set to one, in bit positions 0-63 of general register 2, and by setting condition code 0.

If the index is less than or equal to the index limit, the index is applied to the first-operand and third-operand base addresses to locate the current pair of six-byte units to be compared. The index, with 48 leftmost zeros appended, and bits 0-63 of general register 1 are added to form the 64-bit address of the current first-operand six-byte unit. A carry out of bit position 0, if any, is ignored. The address of the current third-operand six-byte unit is formed in the same manner by adding bits 0-63 of general register 3 and the index.

The current first-operand and third-operand six-byte units are logically compared. If they are equal, the contents of general register 2 are incremented by 6, and a unit of operation ends.

If the compare values are unequal, the contents of general register 2 are incremented by 6 and then shifted left logically by 48 bit positions. If the operand-control bit is zero, (1) the one's complement of the higher six-byte unit is placed in bit positions 16-63 of general register 2, and (2) if operand 1 was higher, bits 0-63 of general registers 1 and 3 are interchanged. If the operand-control bit is one, (1) the lower six-byte unit is placed in bit positions 16-63 of general register 2, and (2) if operand 1 was lower, bits 0-63 of general registers 1 and 3 are interchanged.

For the purpose of recognizing access exceptions, operand 1 and operand 3 are both considered to have a length equal to 6 more than the value of the index limit minus the index.

**Specifications Independent of Addressing Mode**

The condition code is unpredictable if the instruction is interrupted.

When the index is initially larger than the index limit, access exceptions are not recognized for the storage operands. For operands longer than 4K bytes, access exceptions are not recognized more than 4K bytes beyond the byte being processed. Access exceptions are not recognized when a specification-exception condition exists.

If the B2 field designates general register 2, it is unpredictable whether or not the index limit is recomputed; thus, in this case the operand length is unpredictable. However, in no case can the operands exceed $2^{15}$ bytes in length.

**Resulting Condition Code:**

0  Operands equal
1  Operand-control bit zero and operand 1 low, or operand-control bit one and operand 3 low
2  Operand-control bit zero and operand 1 high, or operand-control bit one and operand 3 high
3  --

**Program Exceptions:**

- Access (fetch, operands 1 and 3)
- Specification
- Transaction constraint
Programming Notes:

1. An example of the use of COMPARE AND FORM CODEWORD is given in “Sorting Instructions” in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The offset of the halfword or six-byte unit (depending on the addressing mode) of the first and third operands at which comparison is to begin should be placed in bit positions 48-63 of general register 2 before executing COMPARE AND FORM CODEWORD. The index limit derived from the second-operand address should be the offset of the last halfword or six-byte unit of the first and third operands for which comparison can be made. When the operands do not compare equal, the leftmost 16 bits of the codeword formed in general register 2 (bits 32-47 of the register in the 24-bit or 31-bit addressing mode, or bits 0-15 in the 64-bit addressing mode) by the execution of COMPARE AND FORM CODEWORD gives the offset of the first halfword or six-byte unit not compared. If the codewords compare equal in an UPDATE TREE operation, bit positions 32-47 of general register 2 in the 24-bit or 31-bit addressing mode, or bit positions 0-15 in the 64-bit addressing mode, will contain the offset at which another COMPARE AND FORM CODEWORD should resume comparison for breaking codeword ties. Operand-control-bit values of zero or one are used for sorting operands in ascending or descending order, respectively. Refer to “Sorting Instructions” on page A-53 for a discussion of the use of codewords in sorting.

3. The condition code indicates the results of comparing operands up to 32,768 bytes long. Equal operands result in a negative codeword in bit positions 32-63 of general register 2 in the 24-bit or 31-bit addressing mode, or in bit positions 0-63 in the 64-bit addressing mode. A negative codeword also results in the 24-bit or 31-bit mode when the index limit is 32,766 and the operands that are compared differ in only their last two bytes, or in the 64-bit mode when the limit is 32,762 and the operands differ in only their last six bytes. If this latter codeword is used by UPDATE TREE, an incorrect result may be indicated in general registers 0 and 1. Therefore, the index limit should not exceed 32,764 in the 24-bit or 31-bit mode, or 32,760 in the 64-bit mode, when the resulting codeword is to be used by UPDATE TREE.

4. Special precautions should be taken if COMPARE AND FORM CODEWORD is made the target of an execute-type instruction. See the programming note concerning interruptible instructions under EXECUTE.

5. Further programming notes concerning interruptible instructions are included in “Interruptible Instructions” in Chapter 5, “Program Execution.”

6. The storage-operand references of COMPARE AND FORM CODEWORD may be multiple-access references. (See “Storage-Operand Consistency”.)

7. Figure 7-174 on page 7-123 and Figure 7-175 on page 7-124 contain summaries of the operation in the 24-bit or 31-bit addressing mode, and Figure 7-176 on page 7-125 and Figure 7-177 on page 7-126 contain summaries of the operation in the 64-bit addressing mode.
<table>
<thead>
<tr>
<th>Operand-Control Bit</th>
<th>Relation</th>
<th>Resulting Condition Code</th>
<th>Result in GR2 (Bits 32-63)</th>
<th>Result in GR1 (Bits 32-63)</th>
<th>Result in GR3 (Bits 32-63)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>op1 = op3</td>
<td>0</td>
<td>OGR3b1</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>0</td>
<td>op1 &lt; op3</td>
<td>1</td>
<td>X, nop3</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>0</td>
<td>op1 &gt; op3</td>
<td>2</td>
<td>X, nop1</td>
<td>OGR3</td>
<td>OGR1</td>
</tr>
<tr>
<td>1</td>
<td>op1 = op3</td>
<td>0</td>
<td>OGR3b1</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>1</td>
<td>op1 &lt; op3</td>
<td>2</td>
<td>X, top1</td>
<td>OGR3</td>
<td>OGR1</td>
</tr>
<tr>
<td>1</td>
<td>op1 &gt; op3</td>
<td>1</td>
<td>X, top3</td>
<td>–</td>
<td>–</td>
</tr>
</tbody>
</table>

**Explanation:**

- The bits remain unchanged.
- OGR1 The original value of GR1 bits 32-63.
- OGR3 The original value of GR3 bits 32-63.
- OGR3b1 The original value of GR3 bits 32-63 with bit 32 set to one.
- X Bits 32-47 of GR2 are 2 more than the index of the first unequal halfword.
- nop1 Bits 48-63 of GR2 are the one's complement of the first unequal halfword in operand 1.
- nop3 Bits 48-63 of GR2 are the one's complement of the first unequal halfword in operand 3.
- top1 Bits 48-63 of GR2 are the first unequal halfword in operand 1.
- top3 Bits 48-63 of GR2 are the first unequal halfword in operand 3.

*Figure 7-174. Operation of COMPARE AND FORM CODEWORD in the 24-Bit or 31-bit Addressing Mode*
Figure 7-175. Execution of COMPARE AND FORM CODEWORD in the 24-Bit or 31-bit Addressing Mode
## COMPARE AND FORM CODEWORD

<table>
<thead>
<tr>
<th>Operand-Relation</th>
<th>Resulting Condition Code</th>
<th>Result in GR2 (Bits 0-63)</th>
<th>Result in GR1 (Bits 0-63)</th>
<th>Result in GR3 (Bits 0-63)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 op1 = op3</td>
<td>0</td>
<td>OGR3b1</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>0 op1 &lt; op3</td>
<td>1</td>
<td>X, nop3</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>0 op1 &gt; op3</td>
<td>2</td>
<td>X, nop1</td>
<td>OGR3</td>
<td>OGR1</td>
</tr>
<tr>
<td>1 op1 = op3</td>
<td>0</td>
<td>OGR3b1</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>1 op1 &lt; op3</td>
<td>2</td>
<td>X, top1</td>
<td>OGR3</td>
<td>OGR1</td>
</tr>
<tr>
<td>1 op1 &gt; op3</td>
<td>1</td>
<td>X, top3</td>
<td>–</td>
<td>–</td>
</tr>
</tbody>
</table>

**Explanation:**

- The bits remain unchanged.
- OGR1 The original value of GR1 bits 0-63.
- OGR3 The original value of GR3 bits 0-63.
- OGR3b1 The original value of GR3 bits 0-63 with bit 0 set to one.
- X Bits 0-15 of GR2 are 6 more than the index of the first unequal six-byte unit.
- nop1 Bits 16-63 of GR2 are the one’s complement of the first unequal six-byte unit in operand 1.
- nop3 Bits 16-63 of GR2 are the one’s complement of the first unequal six-byte unit in operand 3.
- top1 Bits 16-63 of GR2 are the first unequal six-byte unit in operand 1.
- top3 Bits 16-63 of GR2 are the first unequal six-byte unit in operand 3.

*Figure 7-176. Operation of COMPARE AND FORM CODEWORD in the 64-bit Addressing Mode*
Figure 7-177. Execution of COMPARE AND FORM CODEWORD in the 64-bit Addressing Mode
COMPARE DOUBLE AND SWAP

The first and second operands are compared. If they are equal, the third operand is stored at the second-operand location. If they are unequal, the second operand is loaded into the first-operand location. The result of the comparison is indicated in the condition code.

For COMPARE DOUBLE AND SWAP (CDS, CDSY), the first and third operands are 64 bits in length. The first 32 bits of an operand occupy bit positions 32-63 of an even-odd pair of general registers, and the second 32 bits occupy bit positions 32-63 of the odd-numbered register of the pair. The second operand is a doubleword in storage.

For COMPARE DOUBLE AND SWAP (CDSG), the first and third operands are 128 bits in length. The first 64 bits of an operand occupy bit positions 0-63 of an even-odd pair of general registers, and the second 64 bits occupy bit positions 0-63 of the odd-numbered register of the pair. The second operand is a quadword in storage.

When an equal comparison occurs, the third operand is stored at the second-operand location. The fetch of the second operand for purposes of comparison and the store into the second-operand location appear to be a block-concurrent interlocked-update reference as observed by other CPUs.

When the result of the comparison is unequal, the second operand is loaded at the first-operand location, and the second-operand location remains unchanged. However, on some models, the contents may be fetched and subsequently stored back unchanged at the second-operand location. This update appears to be a block-concurrent interlocked-update reference as observed by other CPUs.

A serialization function is performed before the operand is fetched and again after the operation is completed.

The displacement for CS and CDS is treated as a 12-bit unsigned binary integer. The displacement for CSY, CSG, CDSY, and CDSG is treated as a 20-bit signed binary integer.

The second operand of COMPARE AND SWAP (CS, CSY) must be designated on a word boundary. The second operand of COMPARE AND SWAP (CSG) and COMPARE DOUBLE AND SWAP (CDS, CDSY) must be designated on a doubleword boundary. The second operand of COMPARE DOUBLE AND SWAP (CDSG) must be designated on a quadword boundary. The R1 and R3 fields for COMPARE DOUBLE AND SWAP must each designate an even-numbered register. Otherwise, a specification exception is recognized.
**COMPARE DOUBLE AND SWAP**

**Resulting Condition Code:**

0  First and second operands equal, second operand replaced by third operand
1  First and second operands unequal, first operand replaced by second operand
2  --
3  --

**Program Exceptions:**

- Access (fetch and store, operand 2)
- Operation (CSY and CDSY, if the long-displacement facility is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. Several examples of the use of the COMPARE AND SWAP and COMPARE DOUBLE AND SWAP instructions are given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. Some of the following notes are worded, with respect to operand size, for CS, CSY, CDS, and CDSY. Similar notes, worded for a larger operand size, would apply to CSG and CDSG.

3. COMPARE AND SWAP can be used by CPU programs sharing common storage areas in either a multiprogramming or multiprocessing environment. Two examples are:
   a. By performing the following procedure, a CPU program can modify the contents of a storage location even though the possibility exists that the CPU program may be interrupted by another CPU program that will update the location or that another CPU program may simultaneously update the location. First, the entire word containing the byte or bytes to be updated is loaded into a general register. Next, the updated value is computed and placed in another general register. Then COMPARE AND SWAP is executed with the R1 field designating the register that contains the original value and the R3 field designating the register that contains the updated value. If the update has been successful, condition code 0 is set. If the storage location no longer contains the original value, the update has not been successful, the general register designated by the R1 field of the COMPARE AND SWAP instruction contains the new current value of the storage location, and condition code 1 is set. When condition code 1 is set, the CPU program can repeat the procedure using the new current value.
   b. COMPARE AND SWAP can be used for controlled sharing of a common storage area, including the capability of leaving a message (in a chained list of messages) when the common area is in use. To accomplish this, a word in storage can be used as a control word, with a zero value in the word indicating that the common area is not in use and that no messages exist, a negative value indicating that the area is in use and that no messages exist, and a nonzero positive value indicating that the common area is in use and that the value is the address of the most recent message added to the list. Thus, any number of CPU programs desiring to seize the area can use COMPARE AND SWAP to update the control word to indicate that the area is in use or to add messages to the list. The single CPU program which has seized the area can also safely use COMPARE AND SWAP to remove messages from the list.

4. COMPARE DOUBLE AND SWAP can be used in a manner similar to that described for COMPARE AND SWAP. In addition, it has another use. Consider a chained list, with a control word used to address the first message in the list, as described in programming note 3.b above. If multiple CPU programs are to be permitted to delete messages by using COMPARE AND SWAP (and not just the single CPU program which has seized the common area), there is a possibility the list will be incorrectly updated. This would occur if, for example, after one CPU program has fetched the address of the most recent message in order to remove the message, another CPU program removes the first two messages and then adds the first message back into the chain. The first CPU program, on continuing, cannot easily detect that the list is changed. By increasing the size of the control word to a doubleword containing both the first message address and a word with a change number that is incremented for each modification of the list, and by using COMPARE DOUBLE AND SWAP to update both fields together, the possibility of the list being
incorrectly updated is reduced to a negligible level. That is, an incorrect update can occur only if the first CPU program is delayed while changes exactly equal in number to a multiple of $2^{32}$ take place and only if the last change places the original message address in the control word.

5. To ensure successful updating of a common storage field by two or more CPUs, all updates must be done by means of an interlocked-update reference (the section “Interlocked-Update References” on page 5-122 lists the instructions that perform an interlocked-update reference). For example, in a configuration where the interlocked-access facility 2 is not installed, if one CPU executes OR IMMEDIATE and another CPU executes COMPARE AND SWAP to update the same byte, the fetch by OR IMMEDIATE may occur either before the fetch by COMPARE AND SWAP or between the fetch and the store by COMPARE AND SWAP, and then the store by OR IMMEDIATE may occur after the store by COMPARE AND SWAP, in which case the change made by COMPARE AND SWAP is lost.

6. For the case of a condition-code setting of 1, COMPARE AND SWAP and COMPARE DOUBLE AND SWAP may or may not, depending on the model, cause any of the following to occur for the second-operand location: a PER storage-alteration event may be recognized; a protection exception for storing may be recognized; and, provided no access exception exists, the change bit may be set to one. Because the contents of storage remain unchanged, the change bit may or may not be one when a PER storage-alteration event is recognized.

7. The performance of CDSG on some models may be significantly slower than that of CSG. When quadword consistency is not required by the program, alternate code sequences should be used.

**COMPARE AND SWAP AND STORE**

```
COMPARE AND SWAP AND STORE

CSST D_i(B_i), D_i(B_j), R_3 [SSF]

'C8' R_3 '2' B_1 D_1 B_2 D_2
```

The first operand is compared with the third operand. If they are equal, the replacement value is stored into the first-operand location, and subsequently, the store value is placed into the second-operand location. If they are not equal, then the first operand is loaded into the third-operand location, and the second operand is not changed. The result is indicated by the condition code.

The size of the first and third operands, the size of the replacement value, and the alignment of the first operand are determined by the contents of a function code (FC) in bits 56-63 of general register 0. The assigned function codes are as follows:

- When the function code is 0, the operands are 32 bits in length. The first operand is a word in storage, and the third operand is in bits 32-63 of general register R_3. The replacement value is in bytes 0-3 of the parameter list.

- When the function code is 1, the operands are 64 bits in length. The first operand is a doubleword in storage, and the third operand is in bits 0-63 of general register R_3. The replacement value is bytes 0-7 of the parameter list.

- When the function code is 2 and the compare-and-swap-and-store facility 2 is installed, the operands are 128 bits in length. The first operand is a quadword in storage, and the third operand is in bits 0-63 of general registers R_3 and R_3 +1. The replacement value is in bytes 0-15 of the parameter list.

The size of the store value and the alignment of the second operand are determined by a store characteristic (SC) in bits 48-55 of general register 0. The store characteristic is expressed as a power of two; the assigned store characteristics are 0, 1, 2, and 3. An SC of 0 means that one byte is stored on a byte boundary; an SC of 1 means that two bytes are stored on a halfword boundary, an SC of 2 means that four bytes are stored on a word boundary, and an SC of 3 means that eight bytes are stored on a doubleword boundary. When the CSST facility 2 is installed, an SC of 4 is also assigned; an SC of 4 means that sixteen bytes are stored on a quadword boundary. The store value begins at byte 16 of the parameter list.

Bits 0-31 of general register 0 are ignored. Bits 32-47 of general register 0 and bits 60-63 of general register 1 are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.
General register 1 contains the logical address of a parameter list that contains the replacement value and the store value. The parameter list is on a quad-word boundary. In the access-register mode, access register 1 specifies the address space containing the parameter list.

The handling of the parameter-list address is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-59 of general register 1, with four zeros appended to the right, constitute the address, and bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-59 of the register, with four zeros appended to the right, constitute the address, and bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-59 of the register, with four zeros appended to the right, constitute the address.

The contents of the registers and parameter list just described are shown below.

### All Addressing Modes

<table>
<thead>
<tr>
<th>GR0</th>
<th>Reserved</th>
<th>SC</th>
<th>FC</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>GR1</th>
<th>Parameter List Address</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>GR1</th>
<th>Parameter List Address</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>GR1</th>
<th>Parameter List Address</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>R3</th>
<th>Compare Value</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Replacement Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Replacement Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Store Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Store Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>24</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>R3</th>
<th>Compare Value</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Replacement Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Replacement Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Store Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Store Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>24</td>
<td></td>
</tr>
</tbody>
</table>

### R3 and Parameter List when FC = 0

<table>
<thead>
<tr>
<th></th>
<th>Compare Value</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Replacement Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Replacement Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Store Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Store Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>24</td>
<td></td>
</tr>
</tbody>
</table>

### R3 and Parameter List when FC = 1

<table>
<thead>
<tr>
<th></th>
<th>Compare Value</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Replacement Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Replacement Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Store Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>Store Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>24</td>
<td></td>
</tr>
</tbody>
</table>
When an equal comparison occurs, the replacement value is stored at the first-operand location, and the store value is stored at the second-operand location. The fetch of the first operand for purposes of comparison, and the store of the replacement value into the first-operand location, both appear to be a block-concurrent interlocked-update reference as observed by other CPUs. The store of the store value appears to be block-concurrent as observed by other CPUs.

When the result of the comparison is unequal, the first operand is loaded into the third-operand location, and the first operand remains unchanged. However, on some models, the contents of the first operand may be fetched and subsequently stored back unchanged at the first-operand location. This update appears to be a block-concurrent interlocked-update reference as observed by other CPUs.

As observed by this CPU and by other CPUs, all fetches appear to occur before all stores, and the store into the first operand appears to occur before the store into the second operand. Access-exception conditions are recognized for the entire 32-byte parameter list and for the second operand, regardless of whether the first and third operands are or are not equal. For the second operand, PER storage-alteration and zero-address-detection events are recognized, and a change bit is set, only if a store occurs.

A serialization function is performed before the operation begins and again after the operation is completed.

### Special Conditions

A specification exception is recognized for any of the following conditions:

- The function code specifies an unassigned value.
- The store characteristic specifies an unassigned value.
- The function code is 0, and the first operand is not designated on a word boundary.
- The function code is 1, and the first operand is not designated on a doubleword boundary.
- The function code is 2, and any of the following is true:
  - The compare-and-swap-and-store facility 2 is not installed.
  - The first operand is not designated on a quadword boundary.
  - The $R_3$ field does not designate the even-numbered register of an even-odd register pair.
- The second operand is not designated on an integral boundary corresponding to the size of the store value.

For all of the above conditions, and for all addressing and protection exceptions, the operation is suppressed.
**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Result Code</th>
<th>Condition Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>First and third operands equal; first operand replaced by replacement value, and second operand replaced by store value</td>
</tr>
<tr>
<td>1</td>
<td>First and third operands unequal; third operand replaced by first operand</td>
</tr>
<tr>
<td>2</td>
<td>---</td>
</tr>
<tr>
<td>3</td>
<td>---</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, parameter list; fetch and store, operand 1; store, operand 2)
- Operation (if the compare-and-swap-and-store facility is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. COMPARE AND SWAP AND STORE may be used in conjunction with other COMPARE AND SWAP or COMPARE DOUBLE AND SWAP instructions to manipulate locks, queue pointers, or other fields that require interlocked updates.
2. COMPARE AND SWAP AND STORE should not be used to manipulate fields that are also manipulated by PERFORM LOCKED OPERATION.
3. The store value is intended to provide a separate “footprint” of the interlocked-update operation in a location apart from the first operand in a single unit of operation.
4. The performance of COMPARE AND SWAP AND STORE may be significantly slower than the that of separate COMPARE AND SWAP, BRANCH ON CONDITION, and STORE instructions.
5. COMPARE AND SWAP AND STORE should only be used when an interruption between the compare-and-swap operation and the store operation cannot be tolerated, and other means of disabling for interruptions are not practical.

**COMPARE AND TRAP**

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>CRT</td>
<td>R1,R2,M3</td>
</tr>
<tr>
<td>CGRT</td>
<td>R1,R2,M3</td>
</tr>
</tbody>
</table>

**COMPARE IMMEDIATE AND TRAP**

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>CIT</td>
<td>R1,I2,M3</td>
</tr>
<tr>
<td>CGIT</td>
<td>R1,I2,M3</td>
</tr>
</tbody>
</table>

The first operand is compared with the second operand. If the mask bit in the M3 field corresponding to the comparison result is one, a compare-and-trap-instruction data exception is recognized, and the operation is completed; otherwise, normal instruction sequencing proceeds with the updated instruction address.

The comparison results and corresponding M3 bits are as follows:

<table>
<thead>
<tr>
<th>Comparison Result</th>
<th>M3 Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Equal</td>
<td>0</td>
</tr>
<tr>
<td>First operand low</td>
<td>1</td>
</tr>
<tr>
<td>First operand high</td>
<td>2</td>
</tr>
</tbody>
</table>

Bit 3 of the M3 field is reserved and should be zero; otherwise, the program may not operate compatibly in the future.

For COMPARE AND TRAP (CRT) and COMPARE IMMEDIATE AND TRAP (CIT), the first operand is treated as a 32-bit signed binary integer. For COMPARE AND TRAP (CGRT) and COMPARE IMMEDIATE AND TRAP (CGIT), the first operand is treated as a 64-bit signed binary integer.

For COMPARE IMMEDIATE AND TRAP, the second operand is treated as a 16-bit signed binary integer.
For COMPARE AND TRAP (CRT), the second operand is treated as a 32-bit signed binary integer. For COMPARE AND TRAP (CGRT), the second operand is treated as a 64-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data
- Operation (if the general-instructions-extension facility is not installed)

**Programming Notes:**

1. Possible uses of COMPARE AND TRAP and COMPARE IMMEDIATE AND TRAP include checking for pointers containing zero (null pointer), or array range checking.

2. On most models, when a data exception is not recognized, the performance of COMPARE AND TRAP and COMPARE IMMEDIATE AND TRAP is typically similar to other COMPARE instructions. When a data exception is recognized, the instruction may be significantly slower than an equivalent COMPARE instruction followed by a BRANCH ON CONDITION instruction.

3. When bit positions 0-2 of the M3 field contain zeros, the instruction acts as a NOP, however this is not the preferred instruction with which to create a NOP. When bit positions 0-2 of the M3 field contain 111 binary, a data exception is always recognized.

4. When a data exception is recognized, the compare-and-trap data-exception code (DXC FF hex) is stored, as described in “Data Exception” on page 6-24.

5. The discussion of extended mnemonics in programming note 3 for COMPARE AND BRANCH on page 7-119 also applies to the compare-and-trap instructions.

### COMPARE HALFWORD

**CH**  
\[ R_1, D_2(X_2, B_2) \]  
\[
\begin{array}{cccccc}
\text{R1} & X_2 & B_2 & D_2 & RL_2 \\
0 & 8 & 12 & 16 & 20 & 31
\end{array}
\]

**CHY**  
\[ R_1, D_2(X_2, B_2) \]  
\[
\begin{array}{cccccc}
\text{R1} & X_2 & B_2 & DL_2 & DH_2 & \text{X'} \\
0 & 8 & 12 & 16 & 20 & 31
\end{array}
\]

**CGH**  
\[ R_1, D_2(X_2, B_2) \]  
\[
\begin{array}{cccccc}
\text{R1} & X_2 & B_2 & DL_2 & DH_2 & \text{X'} \\
0 & 8 & 12 & 16 & 20 & 31
\end{array}
\]

### COMPARE HALFWORD IMMEDIATE

**Register-and-immediate formats:**

**CHI**  
\[ R_1, I_2 \]  
\[
\begin{array}{cccc}
\text{R1} & I_2 \\
0 & 8 & 12 & 16 & 31
\end{array}
\]

**CGHI**  
\[ R_1, I_2 \]  
\[
\begin{array}{cccc}
\text{R1} & I_2 \\
0 & 8 & 12 & 16 & 31
\end{array}
\]

**Storage-and-immediate formats:**

**CHHSI**  
\[ D_1(B_1), I_2 \]  
\[
\begin{array}{cccc}
\text{E554} & B_1 & D_1 & I_2 \\
0 & 16 & 20 & 32 & 47
\end{array}
\]

**CHSI**  
\[ D_1(B_1), I_2 \]  
\[
\begin{array}{cccc}
\text{E55C} & B_1 & D_1 & I_2 \\
0 & 16 & 20 & 32 & 47
\end{array}
\]

**CGHSI**  
\[ D_1(B_1), I_2 \]  
\[
\begin{array}{cccc}
\text{E558} & B_1 & D_1 & I_2 \\
0 & 16 & 20 & 32 & 47
\end{array}
\]

### COMPARE HALFWORD RELATIVE LONG

**CHRL**  
\[ R_1, RL_2 \]  
\[
\begin{array}{cccc}
\text{C6} & R_1 & RL_2 \\
0 & 8 & 12 & 16 & 47
\end{array}
\]

**CGHRL**  
\[ R_1, RL_2 \]  
\[
\begin{array}{cccc}
\text{C6} & R_1 & RL_2 \\
0 & 8 & 12 & 16 & 47
\end{array}
\]
The first operand is compared with the second operand, and the result is indicated in the condition code. The second operand is two bytes in length and is treated as a 16-bit signed binary integer.

For COMPARE HALFWORD IMMEDIATE (CHHSI), the first operand is treated as a 16-bit signed binary integer. For COMPARE HALFWORD (CH, CHY), COMPARE HALFWORD IMMEDIATE (CHI and CHSI), and COMPARE HALFWORD RELATIVE LONG (CHRL), the first operand is treated as a 32-bit signed binary integer. For COMPARE HALFWORD (CGH), COMPARE HALFWORD IMMEDIATE (CGHI and CGHSI), and COMPARE HALFWORD RELATIVE LONG (CGHRL), the first operand is treated as a 64-bit signed binary integer.

The displacement for COMPARE HALFWORD (CH) and for COMPARE HALFWORD IMMEDIATE (CGHSI, CHHSI, CHSI) is treated as a 12-bit unsigned binary integer. The displacement for COMPARE HALFWORD (CHY, CGH) is treated as a 20-bit signed binary integer.

For COMPARE HALFWORD RELATIVE LONG, the contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand in storage. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

**Resulting Condition Code:**

- 0 Operands equal
- 1 First operand low
- 2 First operand high
- 3 --

**Program Exceptions:**

- Access (fetch, operand 1 of CGHSI, CHHSI, and CHSI only; fetch, operand 2 of CGH, CGHRL, CH, CHRL, CHY only)
- Operation (CHY, if the long-displacement facility is not installed; CGH, CHRL, CGHRL, CGHSI, CHHSI, and CHSI, if the general-instructions-extension facility is not installed)

### COMPARE HIGH

**Register-and-register formats:**

- CHHR \( R_1, R_2 \) [RRE]
  - 'B9CD'
  - 0 1 6 24 28 31

- CHLR \( R_1, R_2 \) [RRE]
  - 'B9DD'
  - 0 1 6 24 28 31

**Register-and-storage format:**

- CHF \( R_1, D_2(X_2, B_2) \) [RXY-a]
  - 'E3' \( R_1 \) X2 B2 DL2 DH2 'CD'
  - 0 8 12 16 20 32 40 47

- CIH \( R_1, I_2 \) [RIL-a]
  - 'CC' \( R_1 \) 'D' I2
  - 0 8 12 16 47

The first operand is compared with the second operand, and the result is indicated in the condition code.

The operands are treated as 32-bit signed binary integers. The first operand is in bit positions 0-31 of general register \( R_1 \); bit positions 32-63 of the register are ignored. For COMPARE HIGH (CHHR), the second operand is in bit positions 0-31 of general register \( R_2 \); bit positions 32-63 of the register are ignored.
For COMPARE HIGH (CHLR), the second operand is in bit positions 32-63 of general register R₂; bit positions 0-31 of the register are ignored.

The displacement for CHF is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

- 0  Operands equal
- 1  First operand low
- 2  First operand high
- 3  --

**Program Exceptions:**

- Access (operand 2 of CHF only)
- Operation (if the high-word facility is not installed)

### COMPARE LOGICAL

**Register-and-register formats:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
<th>Format</th>
<th>Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLR</td>
<td>R₁, R₂</td>
<td>[RR]</td>
<td>[RIL-a]</td>
</tr>
<tr>
<td>CLGR</td>
<td>R₁, R₂</td>
<td>[RRE]</td>
<td>[RIL-a]</td>
</tr>
<tr>
<td>CLGFR</td>
<td>R₁, R₂</td>
<td>[RRE]</td>
<td>[RIL-a]</td>
</tr>
</tbody>
</table>

**Register-and-storage formats:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
<th>Format</th>
<th>Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>CL</td>
<td>R₁, Dₓ(X₂,B₂)</td>
<td>[RX-a]</td>
<td>[RIL-a]</td>
</tr>
<tr>
<td>CLY</td>
<td>R₁, Dₓ(X₂,B₂)</td>
<td>[RX-a]</td>
<td>[RIL-a]</td>
</tr>
<tr>
<td>CLG</td>
<td>R₁, Dₓ(X₂,B₂)</td>
<td>[RX-a]</td>
<td>[RIL-a]</td>
</tr>
</tbody>
</table>

**Storage-and-storage format:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
<th>Format</th>
<th>Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLC</td>
<td>Dₓ(L₁,B₁), Dₓ(B₂)</td>
<td>[SS-a]</td>
<td>[RIL-a]</td>
</tr>
</tbody>
</table>

**COMPARE LOGICAL IMMEDIATE**

**Register-and-immediate formats:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
<th>Format</th>
<th>Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLFI</td>
<td>R₁, I₂</td>
<td>[RIL-a]</td>
<td>[RIL-a]</td>
</tr>
<tr>
<td>CLGFI</td>
<td>R₁, I₂</td>
<td>[RIL-a]</td>
<td>[RIL-a]</td>
</tr>
</tbody>
</table>

**Storage-and-immediate formats:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
<th>Format</th>
<th>Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLI</td>
<td>Dₓ(B₁), I₂</td>
<td>[SI]</td>
<td>[SI]</td>
</tr>
<tr>
<td>CLY</td>
<td>Dₓ(B₁), I₂</td>
<td>[SI]</td>
<td>[SI]</td>
</tr>
<tr>
<td>CLFHSI</td>
<td>Dₓ(B₁), I₂</td>
<td>[SI]</td>
<td>[SI]</td>
</tr>
</tbody>
</table>

### Storage-and-storage format:

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
<th>Format</th>
<th>Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLC</td>
<td>Dₓ(L₁,B₁), Dₓ(B₂)</td>
<td>[SS-a]</td>
<td>[SS-a]</td>
</tr>
</tbody>
</table>
The first operand is compared with the second operand, and the result is indicated in the condition code.

The lengths of the operands are as follows:

- For COMPARE LOGICAL (CLR, CL, CLY), COMPARE LOGICAL IMMEDIATE (CLFI), and COMPARE LOGICAL RELATIVE LONG (CLRL), the operands are treated as 32 bits.

- For COMPARE LOGICAL (CLGR, CLG) and COMPARE LOGICAL RELATIVE LONG (CLGRL), the operands are treated as 64 bits.

- For COMPARE LOGICAL (CLGFR, CLGF), COMPARE LOGICAL IMMEDIATE (CLGFI), and COMPARE LOGICAL RELATIVE LONG (CLGFRL), the first operand is treated as 64 bits, and the second operand is treated as 32 bits with 32 zeros appended on the left.

- For COMPARE LOGICAL IMMEDIATE (CLI, CLIY), the operands are treated as 16 bits.

- For COMPARE LOGICAL IMMEDIATE (CLFHSI) and COMPARE LOGICAL RELATIVE LONG (CLGFRL), the second operand must be aligned on a word boundary, and for COMPARE LOGICAL RELATIVE LONG (CLGRL), the second operand must be aligned on a doubleword boundary; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Operands equal
1  First operand low
2  First operand high
3  --
Program Exceptions:

- Access (fetch, operand 2, CL, CLC, CLG, CLGF, CLGFRL, CLGHR, CLGLR, CLHRL, and CLY; fetch, operand 1, CLC, CLFHSI, CLGHSI, CLHHSI, CLI, and CLIY)
- Operation (CLY and CLIY, if the long-displacement facility is not installed; CLFI and CLGFI, if the extended-immediate facility is not installed; CLFHSI, CLGFRL, CLGHSI, CLGHR, CLGLR, CLHHSI, CLHRL, and CLRL, if the general-instructions-extension facility is not installed)
- Specification (CLRL, CLGFRL, CLGRL)
- Transaction constraint (CLC)

Programming Notes:

1. Examples of the use of the COMPARE LOGICAL instruction are given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. COMPARE LOGICAL treats all bits of each operand alike as part of a field of unstructured logical data. For COMPARE LOGICAL (CLC), the comparison may extend to field lengths of 256 bytes.
3. For COMPARE LOGICAL RELATIVE LONG, the second operand must be aligned on an integral boundary corresponding to the operand’s size.
4. When COMPARE LOGICAL RELATIVE LONG is the target of an execute-type instruction, the second-operand address is relative to the target address.

COMPARE LOGICAL AND BRANCH

<table>
<thead>
<tr>
<th>(\text{COMPARE LOGICAL AND BRANCH RELATIVE} )</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLRJ ( R_1, R_2, M_3, R_{i4} ) [R{IE-b}]</td>
</tr>
<tr>
<td>[ \text{EC}' ]</td>
</tr>
<tr>
<td>0</td>
</tr>
<tr>
<td>[ \text{EC}' ]</td>
</tr>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

The first operand is compared with the second operand. If the mask bit in the \( M_3 \) field corresponding to the comparison result is one, the instruction address in the current PSW is replaced by the branch address specified by the fourth operand; otherwise, normal instruction sequencing proceeds with the updated instruction address.

For COMPARE LOGICAL AND BRANCH (CLRJ), COMPARE LOGICAL AND BRANCH RELATIVE (CLGJ), COMPARE LOGICAL IMMEDIATE AND BRANCH (CLGB), and COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (CLGI), the first
operand is treated as a 32-bit unsigned binary integer. For COMPARE LOGICAL AND BRANCH (CLGRB), COMPARE LOGICAL AND BRANCH RELATIVE (CLGRJ), COMPARE LOGICAL IMMEDIATE AND BRANCH (CLGIB), and COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (CLGIJ), the first operand is treated as a 64-bit unsigned binary integer.

For COMPARE LOGICAL AND BRANCH (CLRB) and COMPARE LOGICAL AND BRANCH RELATIVE (CLRJ), the second operand is treated as a 32-bit unsigned binary integer. For COMPARE LOGICAL AND BRANCH (CLGRB) and COMPARE LOGICAL AND BRANCH RELATIVE (CLGRJ), the second operand is treated as a 64-bit unsigned binary integer. For COMPARE LOGICAL IMMEDIATE AND BRANCH and COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE, the second operand is treated as an 8-bit unsigned binary integer. When the size of the second operand is smaller than the size of the first operand, the second operand is extended on the left with zeros to match the size of the first operand.

The comparison results and corresponding $M_3$ bits are as follows:

<table>
<thead>
<tr>
<th>Comparison Result</th>
<th>$M_3$ Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Equal</td>
<td>0</td>
</tr>
<tr>
<td>First operand low</td>
<td>1</td>
</tr>
<tr>
<td>First operand high</td>
<td>2</td>
</tr>
</tbody>
</table>

Bit 3 of the $M_3$ field is reserved and should be zero; otherwise, the program may not operate compatibly in the future.

For COMPARE LOGICAL AND BRANCH and COMPARE LOGICAL IMMEDIATE AND BRANCH, the fourth operand is used as the branch address. For COMPARE LOGICAL AND BRANCH RELATIVE and COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE, the contents of the $Ri_4$ field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the branch address.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Operation (if the general-instructions-extension facility is not installed).
- Transaction constraint

**Programming Notes:**

1. When bit positions 0-2 of the $M_3$ field contain zeros, the instruction acts as a NOP, however this is not the preferred instruction with which to create a NOP. When bit positions 0-2 of the $M_3$ field contain 111 binary, a branch always occurs.

2. When COMPARE LOGICAL AND BRANCH RELATIVE or COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE are the target of an execute-type instruction, the branch is relative to the target address. See “Branch-Address Generation” on page 5-12.

3. The discussion of extended mnemonics in programming note 3 for COMPARE AND BRANCH on page 7-119 also applies to the compare-logical-and-branch instructions.
COMPARE LOGICAL IMMEDIATE AND TRAP

CLFIT R1, I2, M3 [RIE-a]

CLGIT R1, I2, M3 [RIE-a]

The first operand is compared with the second operand. If the mask bit in the M3 field corresponding to the comparison result is one, a compare-and-trap-instruction data exception is recognized, and the operation is completed; otherwise, normal instruction sequencing proceeds with the updated instruction address.

The comparison results and corresponding M3 bits are as follows:

<table>
<thead>
<tr>
<th>Comparison Result</th>
<th>M3 Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Equal</td>
<td>0</td>
</tr>
<tr>
<td>First operand low</td>
<td>1</td>
</tr>
<tr>
<td>First operand high</td>
<td>2</td>
</tr>
</tbody>
</table>

Bit 3 of the M3 field is reserved and should be zero; otherwise, the program may not operate compatibly in the future.

For COMPARE LOGICAL AND TRAP (CLRT, CLT) and COMPARE LOGICAL IMMEDIATE AND TRAP (CLFIT), the first operand is treated as a 32-bit unsigned binary integer. For COMPARE LOGICAL AND TRAP (CLGRT, CLGT) and COMPARE LOGICAL IMMEDIATE AND TRAP (CLGIT), the first operand is treated as a 64-bit unsigned binary integer.

For COMPARE LOGICAL IMMEDIATE AND TRAP, the second operand is treated as a 16-bit unsigned binary integer. For COMPARE LOGICAL AND TRAP (CLRT, CLT), the second operand is treated as a 32-bit unsigned binary integer. For COMPARE LOGICAL AND TRAP (CLGRT, CLGT), the second operand is treated as a 64-bit unsigned binary integer. When the size of the second operand is smaller than the size of the first operand, the second operand is extended on the left with zeros to match the size of the first operand.

For COMPARE LOGICAL AND TRAP (CLT, CLGT), when bit positions 0-2 of the M3 field contain either 000 or 111 binary, it is model dependent whether an access exception is recognized for the second-operand location; if accessible, it is model dependent whether a PER zero-address-detection event is recognized for the location.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2, CLT, CLGT)
- Data
- Operation (CLRT, CLGRT, CLFIT, CLGIT, if the general-instructions-extension facility is not installed; CLT, CLGT if the miscellaneous-instruction-extensions facility is not installed)

**Programming Notes:**

1. Possible uses of COMPARE LOGICAL AND TRAP and COMPARE LOGICAL IMMEDIATE AND TRAP include checking for pointers containing zero (null pointer), or array range checking.

2. On most models, when a data exception is not recognized, the performance of COMPARE LOGICAL AND TRAP and COMPARE LOGICAL IMMEDIATE AND TRAP is typically similar to other COMPARE LOGICAL instructions. When a data exception is recognized, the instruction may be significantly slower than an equivalent COMPARE LOGICAL instruction followed by a BRANCH ON CONDITION instruction.

3. For CLFIT, CLGIT, CLGRT, and CLRT, when bit positions 0-2 of the M3 field contain zeros, the instruction acts as a NOP, however this is not the preferred instruction with which to create a NOP. This NOP characteristic may not apply to CLGT and CLT.

When bit positions 0-2 of the M3 field contain 111 binary, a data exception is always recognized.

4. When a data exception is recognized, the compare-and-trap data-exception code (DXC FF hex) is stored, as described in “Data Exception” on page 6-24.

5. The discussion of extended mnemonics in programming note 3 for COMPARE AND BRANCH
on page 7-119 also applies to the compare-logical-and-trap instructions.

**COMPARE LOGICAL CHARACTERS UNDER MASK**

The first operand is compared with the second operand under control of a mask, and the result is indicated in the condition code.

The contents of the $M_3$ field are used as a mask. These four bits, left to right, correspond one for one with four bytes, left to right, of general register $R_1$. For COMPARE LOGICAL CHARACTERS UNDER MASK (CLM, CLMY), the four bytes to which the mask bits correspond are in bit positions 32-63 of general register $R_1$. For COMPARE LOGICAL CHARACTERS UNDER MASK (CLMH), the four bytes are in the high-order half, bit positions 0-31, of the register. The byte positions corresponding to ones in the mask are considered as a contiguous field and are compared with the second operand. The second operand is a contiguous field in storage, starting at the second-operand address and equal in length to the number of ones in the mask. The bytes in the general register corresponding to zeros in the mask do not participate in the operation.

The comparison proceeds left to right, byte by byte, and ends as soon as an inequality is found or the end of the fields is reached.

When the mask is not zero, exceptions associated with storage-operand access are recognized for no more than the number of bytes specified by the mask. Access exceptions may or may not be recognized for the portion of a storage operand to the right of the first unequal byte. When the mask is zero, access exceptions are recognized for one byte at the second-operand address.

The displacement for CLM is treated as a 12-bit unsigned binary integer. The displacement for CLMY and CLMH is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Operands equal, or mask bits all zeros</td>
</tr>
<tr>
<td>1</td>
<td>First operand low</td>
</tr>
<tr>
<td>2</td>
<td>First operand high</td>
</tr>
<tr>
<td>3</td>
<td>--</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operand 2)
- Operation (CLMY, if the long-displacement facility is not installed)

**Programming Note:** An example of the use of the COMPARE LOGICAL CHARACTERS UNDER MASK instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

**COMPARE LOGICAL HIGH**

**Register-and-register formats:**

CLHHR $R_1, R_2$ [RRE]

CLHLR $R_1, R_2$ [RRE]

**Register-and-storage format:**

CLHF $R_1, D_2(X, B)$ [RXY-a]
COMPARE LOGICAL IMMEDIATE
HIGH

CLIH  R1, I2  [RIL-a]

The first operand is compared with the second operand, and the result is indicated in the condition code.

The operands are treated as 32-bit unsigned binary integers. The first operand is in bit positions 0-31 of general register R1; bit positions 32-63 of the register are ignored. For COMPARE LOGICAL HIGH (CLHHR), the second operand is in bit positions 0-31 of general register R2; bit positions 32-63 of the register are ignored. For COMPARE LOGICAL HIGH (CLHLR), the second operand is in bit positions 32-63 of general register R2; bit positions 0-31 of the register are ignored.

The displacement for CLHF is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

0  Operands equal
1  First operand low
2  First operand high
3  --

**Program Exceptions:**

- Access (operand 2 of CLHF only)
- Operation (if the high-word facility is not installed)

COMPARE LOGICAL LONG

CLCL  R1, R2  [RR]

The first operand is compared with the second operand, and the result is indicated in the condition code. The shorter operand is considered to be extended on the right with padding bytes.

The R1 and R2 fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and second operand is designated by the contents of general registers R1 and R2, respectively. The number of bytes in the first-operand and second-operand locations is specified by unsigned binary integers in bit positions 40-63 of general registers R1 + 1 and R2 + 1, respectively. Bit positions 32-39 of general register R2 + 1 contain the padding byte. The contents of bit positions 0-39 of general register R1 + 1 and of bit positions 0-31 of general register R2 + 1 are ignored.

The handling of the addresses in general registers R1 and R2 is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R2 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The contents of the registers just described are shown in Figure 7-179 on page 7-142.

The comparison proceeds left to right, byte by byte, and ends as soon as an inequality is found or the end of the longer operand is reached. If the operands are not of the same length, the shorter operand is considered to be extended on the right with the appropriate number of padding bytes.

If both operands are of zero length, the operands are considered to be equal.

The execution of the instruction is interruptible. When an interruption occurs, other than one that follows termination, the lengths in general registers R1 + 1 and R2 + 1 are decremented by the number of bytes compared, and the addresses in general registers R1 and R2 are incremented by the same number, so that the instruction, when reexecuted, resumes at the point of interruption. In the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general registers R1 and R2 are set to zeros, and the contents of bit positions 0-31 remain unchanged. In any addressing mode, the contents of bit positions 0-39 of general registers R1 + 1 and R2 + 1 remain unchanged, and the condi-
The comparison code is unpredictable. If the operation is interrupted after the shorter operand has been exhausted, the length field pertaining to the shorter operand is zero, and its address is updated accordingly.

If the operation ends because of an inequality, the address fields in general registers R1 and R2 at completion identify the first unequal byte in each operand. The lengths in bit positions 40-63 of general registers R1 + 1 and R2 + 1 are decremented by the number of bytes that were equal, unless the inequality occurred with the padding byte, in which case the length field for the shorter operand is set to zero. The addresses in general registers R1 and R2 are incremented by the amounts by which the corresponding length fields were reduced.

If the two operands, including the padding byte, if necessary, are equal, both length fields are made zero at completion, and the addresses are incremented by the corresponding operand-length values.

At the completion of the operation, in the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general registers R1 and R2 are set to zeros, even when one or both of the initial length values are zero. In any addressing mode, the contents of bit positions 0-39 of general registers R1 + 1 and R2 + 1 remain unchanged.

Access exceptions for the portion of a storage operand to the right of the first unequal byte may or may not be recognized. For operands longer than 2K bytes, access exceptions are not recognized more than 2K bytes beyond the byte being processed.

### 24-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
<th>Address Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
<td>0-63</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
<td>40-63</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
<td>0-63</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Pad</td>
<td>0-32 40 63</td>
</tr>
</tbody>
</table>

### 31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
<th>Address Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
<td>0-63</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
<td>33-63</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
<td>0-63</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Pad</td>
<td>0-32 40 63</td>
</tr>
</tbody>
</table>

### 64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
<th>Address Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
<td>0-63</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
<td>40-63</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
<td>0-63</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Pad</td>
<td>0-32 40 63</td>
</tr>
</tbody>
</table>

Figure 7-179. Register Contents for COMPARE LOGICAL LONG
Access exceptions are not indicated for locations more than 2K bytes beyond the first unequal byte.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the R field associated with that operand is odd.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Operands equal, or both zero length</td>
</tr>
<tr>
<td>1</td>
<td>First operand low</td>
</tr>
<tr>
<td>2</td>
<td>First operand high</td>
</tr>
<tr>
<td>3</td>
<td>---</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operands 1 and 2)
- Specification
- Transaction constraint

**Programming Notes:**

1. An example of the use of the COMPARE LOGICAL LONG instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. When the R₁ and R₃ fields are the same, the operation proceeds in the same way as when two distinct pairs of registers having the same contents are specified, except that the contents of the designated registers are incremented or decremented only by the number of bytes compared, not by twice the number of bytes compared. In the absence of dynamic modification of the operand area by another CPU or by a channel program, condition code 0 is set. However, it is unpredictable whether access exceptions are recognized for the operand since the operation can be completed without storage being accessed.

3. Special precautions should be taken when COMPARE LOGICAL LONG is made the target of an execute-type instruction. See the programming note concerning interruptible instructions under EXECUTE.

4. Other programming notes concerning interruptible instructions are included in “Interruptible Instructions” in Chapter 5, “Program Execution.”

5. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

### COMPARE LOGICAL LONG EXTENDED

```
<table>
<thead>
<tr>
<th>Code</th>
<th>0</th>
<th>8</th>
<th>12</th>
<th>16</th>
<th>20</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>'A9'</td>
<td>R₁</td>
<td>R₃</td>
<td>B₂</td>
<td>D₂</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

The first operand is compared with the third operand until unequal bytes are compared, the end of the longer operand is reached, or a CPU-determined number of bytes have been compared, whichever occurs first. The shorter operand is considered to be extended on the right with padding bytes. The result is indicated in the condition code.

The R₁ and R₃ fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and third operand is designated by the contents of general registers R₁ and R₃, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and third-operand locations is specified by the contents of bit positions 32-63 of general registers R₁ + 1 and R₃ + 1, respectively, and those contents are treated as 32-bit unsigned binary integers. In the 64-bit addressing mode, the number of bytes in the first-operand and third-operand locations is specified by the entire contents of general registers R₁ + 1 and R₃ + 1, respectively, and those contents are treated as 64-bit unsigned binary integers.

The handling of the addresses in general registers R₁ and R₃ is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R₁ and R₃ constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.
The second-operand address is not used to address data; instead, the rightmost eight bits of the second-operand address, bits 56-63, are the padding byte. Bits 0-55 of the second-operand address are ignored.

The contents of the registers and address just described are shown in Figure 7-180 on page 7-144.

<table>
<thead>
<tr>
<th>24-Bit Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 40 63 First-Operand Address</td>
</tr>
<tr>
<td>R1 + 1</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 32 63 First-Operand Length</td>
</tr>
<tr>
<td>R3</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 40 63 Third-Operand Address</td>
</tr>
<tr>
<td>R3 + 1</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 32 63 Third-Operand Length</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>31-Bit Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 33 63 First-Operand Address</td>
</tr>
<tr>
<td>R1 + 1</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 32 63 First-Operand Length</td>
</tr>
<tr>
<td>R3</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 33 63 Third-Operand Address</td>
</tr>
<tr>
<td>R3 + 1</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 32 63 Third-Operand Length</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>64-Bit Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
</tr>
<tr>
<td>First-Operand Address</td>
</tr>
<tr>
<td>0 63</td>
</tr>
<tr>
<td>R1 + 1</td>
</tr>
<tr>
<td>First-Operand Length</td>
</tr>
<tr>
<td>0 63</td>
</tr>
<tr>
<td>R3</td>
</tr>
<tr>
<td>Third-Operand Address</td>
</tr>
<tr>
<td>0 63</td>
</tr>
<tr>
<td>R3 + 1</td>
</tr>
<tr>
<td>Third-Operand Length</td>
</tr>
<tr>
<td>0 63</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>All Addressing Modes</th>
</tr>
</thead>
<tbody>
<tr>
<td>2nd Op Addr.</td>
</tr>
<tr>
<td>/ / / / / / / / / / / / /</td>
</tr>
<tr>
<td>0 56 63 Pad</td>
</tr>
</tbody>
</table>

Figure 7-180. Register Contents and Second-Operand Address for COMPARE LOGICAL LONG EXTENDED

The comparison proceeds left to right, byte by byte, and ends as soon as an inequality is found, the end of the longer operand is reached, or a CPU-determined number of bytes have been compared, whichever occurs first. If the operands are not of the same length, the shorter operand is considered to be extended on the right with the appropriate number of padding bytes.

If both operands are of zero length, the operands are considered to be equal.

If the operation ends because of an inequality, the address fields in general registers R1 and R3 at completion identify the first unequal byte in each operand. The lengths in bit positions 32-63, in the 24-bit or 31-bit addressing mode, or in bit positions 0-63, in the 64-bit addressing mode, of general registers
$R_1 + 1$ and $R_3 + 1$ are decremented by the number of bytes that were equal, unless the inequality occurred with the padding byte, in which case the length field for the shorter operand is set to zero. The addresses in general registers $R_1$ and $R_3$ are incremented by the amounts by which the corresponding length fields were decremented. Condition code 1 is set if the first operand is low, or condition code 2 is set if the first operand is high.

If the two operands, including the padding byte, if necessary, are equal, both length fields are made zero at completion, and the addresses are incremented by the corresponding operand-length values. Condition code 0 is set.

If the operation is completed because a CPU-determined number of bytes have been compared without finding an inequality or reaching the end of the longer operand, the lengths in general registers $R_1 + 1$ and $R_3 + 1$ are decremented by the number of bytes compared, and the addresses in general registers $R_1$ and $R_3$ are incremented by the same number, so that the instruction, when reexecuted, resumes at the next bytes to be compared. If the operation is completed after the shorter operand has been exhausted, the length field pertaining to the shorter operand is zero, and the operand address is updated accordingly. Condition code 3 is set.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers $R_1$, $R_1 + 1$, $R_3$, and $R_3 + 1$, always remain unchanged.

The padding byte may be formed from $D_2(B_2)$ multiple times during the execution of the instruction, and the registers designated by $R_1$ and $R_3$ may be updated multiple times. Therefore, if $B_2$ equals $R_1$, $R_1 + 1$, $R_3$, or $R_3 + 1$ and is subject to change during the execution of the instruction, the results are unpredictable.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed. The maximum amount is approximately 4K bytes of either operand.

At the completion of the operation in the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general registers $R_1$ and $R_3$ may be set to zeros or may remain unchanged from their original values, even when one or both of the initial length values are zero.

Access exceptions for the portion of a storage operand to the right of the first unequal byte may or may not be recognized. For operands longer than 4K bytes, access exceptions are not recognized more than 4K bytes beyond the byte being processed. Access exceptions are not indicated for locations more than 4K bytes beyond the first unequal byte.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the $R$ field associated with that operand is odd.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>All bytes compared; operands equal, or both zero length</td>
</tr>
<tr>
<td>1</td>
<td>All bytes compared, first operand low</td>
</tr>
<tr>
<td>2</td>
<td>All bytes compared, first operand high</td>
</tr>
<tr>
<td>3</td>
<td>CPU-determined number of bytes compared without finding an inequality</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operands 1 and 3)
- Specification
- Transaction constraint

**Programming Notes:**

1. COMPARE LOGICAL LONG EXTENDED is intended for use in place of COMPARE LOGICAL LONG when the operand lengths are specified as 32-bit or 64-bit binary integers. COMPARE LOGICAL LONG EXTENDED sets condition code 3 in cases in which COMPARE LOGICAL LONG would be interrupted.

2. When condition code 3 is set, the program can simply branch back to the instruction to continue the comparison. The program need not determine the number of bytes that were compared.

3. The function of not processing more than approximately 4K bytes of either operand is intended to permit software polling of a flag that may be set by a program on another CPU during long operations.

4. When the $R_1$ and $R_3$ fields are the same, the operation proceeds in the same way as when two distinct pairs of registers having the same con-
contents are specified, except that the contents of the designated registers are incremented or decremented only by the number of bytes compared, not by twice the number of bytes compared. In the absence of dynamic modification of the operand area by another CPU or by a channel program, the condition code is finally set to 0 after possible settings to 3. However, it is unpredictable whether access exceptions are recognized for the operand since the operation can be completed without storage being accessed. If storage is not accessed, condition code 3 may or may not be set regardless of the operand length.

5. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

**COMPARE LOGICAL LONG UNICODE**

The first operand is compared with the third operand until unequal two-byte Unicode characters are compared, the end of the longer operand is reached, or a CPU-determined number of characters have been compared, whichever occurs first. The shorter operand is considered to be extended on the right with two-byte padding characters. The result is indicated in the condition code.

The R1 and R3 fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost character of the first operand and third operand is designated by the contents of general registers R1 and R3, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and third-operand locations is specified by the contents of bit positions 32-63 of general registers R1 + 1 and R3 + 1, respectively, and those contents are treated as 64-bit unsigned binary integers.

The contents of general registers R1 + 1 and R3 + 1 must specify an even number of bytes; otherwise, a specification exception is recognized.

The handling of the addresses in general registers R1 and R3 is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R3 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of the registers constitute the address.

The second-operand address is not used to address data; instead, the rightmost 16 bits of the second-operand address, bits 48-63, are the two-byte padding character. Bits 0-47 of the second-operand address are ignored.

The contents of the registers and address just described are shown in Figure 7-181 on page 7-147.

The comparison proceeds left to right, character by character, and ends as soon as an inequality is found, the end of the longer operand is reached, or a CPU-determined number of characters have been compared, whichever occurs first. If the operands are not of the same length, the shorter operand is considered to be extended on the right with the appropriate number of two-byte padding characters.

If both operands are of zero length, the operands are considered to be equal.

If the operation ends because of an inequality, the address fields in general registers R1 and R3 at completion identify the first unequal two-byte character in each operand. The lengths in bit positions 32-63, in the 24-bit or 31-bit addressing mode, or in bit positions 0-63, in the 64-bit addressing mode, of general registers R1 + 1 and R3 + 1 are decremented by 2 times the number of characters that were equal, unless the inequality occurred with the two-byte padding character, in which case the length field for the shorter operand is set to zero. The addresses in general registers R1 and R3 are incremented by the amounts by which the corresponding length fields
were decremented. Condition code 1 is set if the first operand is low, or condition code 2 is set if the first operand is high.

If the two operands, including the two-byte padding character, if necessary, are equal, both length fields are made zero at completion, and the addresses are incremented by the corresponding operand-length values. Condition code 0 is set.

If the operation is completed because a CPU-determined number of characters have been compared without finding an inequality or reaching the end of the longer operand, the lengths in general registers $R_1 + 1$ and $R_3 + 1$ are decremented by 2 times the number of characters compared, and the addresses in general registers $R_1$ and $R_3$ are incremented by the same number, so that the instruction, when reexecuted, resumes at the next characters to be compared. If the operation is completed after the shorter operand has been exhausted, the length field pertaining to the shorter operand is zero, and the operand address is updated accordingly. Condition code 3 is set.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers $R_1$, $R_1 + 1$, $R_3$, and $R_3 + 1$, always remain unchanged.

---

### 24-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Address</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$R_1$</td>
<td>0-40</td>
<td>First-Operand Address</td>
</tr>
<tr>
<td>$R_1 + 1$</td>
<td>0-32</td>
<td>First-Operand Length</td>
</tr>
<tr>
<td>$R_3$</td>
<td>0-40</td>
<td>Third-Operand Address</td>
</tr>
<tr>
<td>$R_3 + 1$</td>
<td>0-32</td>
<td>Third-Operand Length</td>
</tr>
</tbody>
</table>

### 31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Address</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$R_1$</td>
<td>0-33</td>
<td>First-Operand Address</td>
</tr>
<tr>
<td>$R_1 + 1$</td>
<td>0-32</td>
<td>First-Operand Length</td>
</tr>
<tr>
<td>$R_3$</td>
<td>0-33</td>
<td>Third-Operand Address</td>
</tr>
<tr>
<td>$R_3 + 1$</td>
<td>0-32</td>
<td>Third-Operand Length</td>
</tr>
</tbody>
</table>

### 64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Address</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$R_1$</td>
<td>0-63</td>
<td>First-Operand Address</td>
</tr>
<tr>
<td>$R_1 + 1$</td>
<td>0-63</td>
<td>First-Operand Length</td>
</tr>
<tr>
<td>$R_3$</td>
<td>0-63</td>
<td>Third-Operand Address</td>
</tr>
<tr>
<td>$R_3 + 1$</td>
<td>0-63</td>
<td>Third-Operand Length</td>
</tr>
</tbody>
</table>

### All Addressing Modes

<table>
<thead>
<tr>
<th>2nd Op Addr.</th>
<th>Pad</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-48</td>
<td>48</td>
<td>63</td>
</tr>
</tbody>
</table>

Figure 7-181. Register Contents and Second-Operand Address for COMPARE LOGICAL LONG UNICODE.
The two-byte padding character may be formed from D2(B2) multiple times during the execution of the instruction, and the registers designated by R1 and R3 may be updated multiple times. Therefore, if B2 equals R1, R1 + 1, R3, or R3 + 1 and is subject to change during the execution of the instruction, the results are unpredictable.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

At the completion of the operation in the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general registers R1 and R3 may be set to zeros or may remain unchanged from their original values, including the case when one or both of the initial length values are zero.

Access exceptions for the portion of a storage operand to the right of the first unequal character may or may not be recognized. For operands longer than 4K bytes, access exceptions are not recognized more than 4K bytes beyond the character being processed. Access exceptions are not indicated for locations more than 4K bytes beyond the first unequal character.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the R field or length associated with that operand is odd.

Resulting Condition Code:

0 All characters compared; operands equal, or both zero length
1 First operand low
2 First operand high
3 CPU-determined number of characters compared without finding an inequality

Program Exceptions:

- Access (fetch, operands 1 and 3)
- Operation (if the extended-translation facility 2 is not installed)
- Specification
- Transaction constraint

Programming Notes:

1. COMPARE LOGICAL LONG UNICODE is intended for use in place of COMPARE LOGICAL LONG or COMPARE LOGICAL LONG EXTENDED when two-byte characters are to be compared. The characters may be Unicode characters or any other double-byte characters. COMPARE LOGICAL LONG UNICODE sets condition code 3 in cases in which COMPARE LOGICAL LONG would be interrupted.

2. When condition code 3 is set, the program can simply branch back to the instruction to continue the comparison. The program need not determine the number of characters that were compared.

3. When the R1 and R3 fields are the same, the operation proceeds in the same way as when two distinct pairs of registers having the same contents are specified, except that the contents of the designated registers are incremented or decremented only by 2 times the number of characters compared, not by 4 times the number of characters compared. In the absence of dynamic modification of the operand area by another CPU or by a channel program, the condition code is finally set to 0 after possible settings to 3. However, it is unpredictable whether access exceptions are recognized for the operand since the operation can be completed without storage being accessed. If storage is not accessed, condition code 3 may or may not be set regardless of the operand length.

4. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

5. The padding character may be represented in the displacement field of the instruction. The following example illustrates padding with a Unicode space character.

   CLCLU 6,8,X'020'

When the B2 field of the instruction designates general register 0, and the long-displacement facility is not installed, the padding character is limited to a character whose representation is less than or equal to FFF hex.
The first operand is compared with the second operand until unequal bytes are compared, the end of either operand is reached, or a CPU-determined number of bytes have been compared, whichever occurs first. The CPU-determined number is at least 256. The result is indicated in the condition code.

The location of the leftmost byte of the first operand and second operand is designated by the contents of general registers $R_1$ and $R_2$, respectively.

The handling of the addresses in general registers $R_1$ and $R_2$ is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers $R_1$ and $R_2$ constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The first and second operands may be of the same or different lengths. The end of an operand is indicated by an ending character in the last byte position of the operand. The ending character to be used to determine the end of an operand is specified in bit positions 56-63 of general register 0. Bit positions 32-55 of general register 0 are reserved for possible future extensions and must contain all zeros; otherwise, a specification exception is recognized.

The operation proceeds left to right, byte by byte, and ends as soon as the ending character is encountered in either or both operands, unequal bytes which do not include an ending character are compared, or a CPU-determined number of bytes have been compared, whichever occurs first. The first operand is compared with the second operand until unequal bytes are compared, the end of either operand is reached, or a CPU-determined number of bytes have been compared, whichever occurs first. The CPU-determined number is at least 256. When the ending character is encountered in only one operand, that operand, which is the shorter operand, is considered to be low, and condition code 1 or 2 is set. Condition code 1 is set if the first operand is low, or condition code 2 is set if the second operand is low. Similarly, when unequal bytes which do not include an ending character are compared, condition code 1 is set if the lower byte is in the first operand, or condition code 2 is set if the lower byte is in the second operand. When a CPU-determined number of bytes have been compared, condition code 3 is set.

When condition code 1 or 2 is set, the address of the last byte processed in the first and second operands is placed in general registers $R_1$ and $R_2$, respectively. That is, when condition code 1 is set, the address of the ending character or first unequal byte in the first operand, whichever was encountered, is placed in general register $R_1$, and the address of the second operand byte corresponding in position to the first operand byte is placed in general register $R_2$. When condition code 2 is set, the address of the ending character or first unequal byte in the second operand, whichever was encountered, is placed in general register $R_2$, and the address of the first operand byte corresponding in position to the second operand byte is placed in general register $R_1$. When condition code 3 is set, the address of the next byte to be processed in the first and second operands is placed in general registers $R_1$ and $R_2$, respectively. Whenever an address is placed in a general register, bits 32-39 of the register, in the 24-bit addressing mode, or bit 32 in the 31-bit addressing mode, are set to zeros. Bits 0-31 of the $R_1$ and $R_2$ registers always remain unchanged in the 24-bit or 31-bit mode.

When condition code 0 is set, the contents of general registers $R_1$ and $R_2$ remain unchanged.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

Access exceptions for the first and second operands are recognized only for that portion of the operand which is necessarily examined in the operation.
**Resulting Condition Code:**

0  Entire operands equal; general registers R₁ and R₂ unchanged
1  First operand low; general registers R₁ and R₂ updated with addresses of last bytes processed
2  First operand high; general registers R₁ and R₂ updated with addresses of last bytes processed
3  CPU-determined number of bytes equal; general registers R₁ and R₂ updated with addresses of next bytes

**Program Exceptions:**

- Access (fetch, operands 1 and 2)
- Specification
- Transaction constraint

**Programming Notes:**

1. Several examples of the use of the COMPARE LOGICAL STRING instruction are given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. When condition code 0 is set, no indication is given of the position of either ending character.

3. When condition code 3 is set, the program can simply branch back to the instruction to continue the comparison. The program need not determine the number of bytes that were compared.

4. R₁ or R₂ may be zero, in which case general register 0 is treated as containing an address and also the ending character.

5. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

**COMPARE UNTIL SUBSTRING EQUAL**

CUSE   R₁,R₂
       [RRE]

 `'B257'`  
   0   16  24  28  31

The first operand is compared with the second operand until equal substrings (sequences of bytes) of a specified length are found, the end of the longer operand is reached, or a CPU-determined number of unequal bytes have been compared, whichever occurs first. The shorter operand is considered to be extended on the right with padding bytes. The CPU-determined number is at least 256. The result is indicated in the condition code.

The R₁ and R₂ fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and second operand is specified by the contents of the R₁ and R₂ general registers, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the 32-bit signed binary integer in bit positions 32-63 of general registers R₁ + 1 and R₂ + 1, respectively. In the 64-bit addressing mode, the number of bytes is specified by the 64-bit signed binary integer in bit positions 0-63 of those registers.

When an operand length is negative, it is treated as zero, and it remains unchanged upon completion of the instruction.

Bits 56-63 of general register 0 specify the unsigned substring length, a value of 0-255, in bytes. Bits 56-63 of general register 1 are the padding byte. Bits 0-55 of general registers 0 and 1 are ignored.

The handling of the addresses in general registers R₁ and R₂ is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R₁ and R₂ constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The contents of the registers just described are shown in Figure 7-182 on page 7-151.

The result is obtained as if the operands were processed from left to right. However, multiple accesses may be made to all or some of the bytes of each operand.

The comparison proceeds left to right, byte by byte, and ends as soon as (1) equal substrings of the specified length are found, (2) the end of the longer operand is reached without finding equal substrings of the specified length, or (3) the last bytes compared are unequal, and a CPU-determined number of bytes
have been compared. The CPU-determined number is at least 256. If the operands are not of the same length, the shorter operand is considered to be extended on the right with the appropriate number of padding bytes.

If the operation ends because equal substrings of the specified length were found, the condition code is set to 0. If the operation ends because the end of the longer operand was reached without finding equal substrings of the specified length, the condition code is set to 1 if equal bytes were the last bytes compared, or it is set to 2 if unequal bytes were the last bytes compared. If the operation ends because unequal bytes were compared when a CPU-determined number of bytes had been compared, the condition code is set to 3.

If the specified substring length is zero, it is considered that equal substrings of the specified length were found, and condition code 0 is set.

If both operands are of zero length but the specified substring length is not zero, it is considered that the end of the longer operand was reached when
COMPARE UNTIL SUBSTRING EQUAL

unequal bytes were the last bytes compared, and condition code 2 is set.

If equal bytes have been compared but then unequal bytes are compared, it is considered that all bytes so far compared are unequal.

At the completion of the operation, the operand-length fields in the R1 + 1 and R2 + 1 registers are decremented by the number of unequal bytes compared (including equal bytes before unequal bytes compared), and the addresses in the R1 and R2 registers are incremented by the same number. However, in the case when a byte of the longer operand is compared against the padding byte, the length field for the shorter operand is not decremented below zero, and the corresponding address is not incremented above the address of the first byte after the shorter operand. In the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the addresses in bit positions 32-63 of registers R1 and R2 are set to zeros, even if the substring length is zero or both operand lengths are initially zero.

Thus, when condition code 0 or 1 is set, the resulting addresses in the R1 and R2 registers designate the first bytes of equal substrings in the two operands, and the lengths in the R1 + 1 and R2 + 1 registers have been decremented by the number of bytes preceding the equal substrings, except when the equal substring in the shorter operand begins with the padding byte, in which case the length field for the shorter operand is zero, and the corresponding address field is incremented above the address of the first byte after the shorter operand. When condition code 2 is set, each address field designates the first byte after the corresponding operand, and both length fields are zero. When condition code 3 is set, each address field designates the first byte after the last compared byte of the corresponding operand, and both length fields have been decremented by the number of bytes compared, except that a length field is not decremented below zero.

When the contents of the R1 and R2 fields are the same, the first and second operands may be compared, or the condition code may be set to 0 or 1 without comparing the operands.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers R1, R1 + 1, R2, and R2 + 1, always remain unchanged.

The substring length and padding byte may be fetched from general registers 0 and 1 multiple times during the execution of the instruction, and the registers designated by R1 and R2 may be updated multiple times. Therefore, if R1 or R2 is zero, the results are unpredictable.

When condition code 3 is set, the general registers used by the instruction have been set so that the remainder of the operands can be processed by simply branching back and reexecuting the instruction.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

The execution of the instruction is interruptible when the last bytes compared are unequal; it is not interruptible when the last bytes compared are equal. When an interruption occurs, other than one that follows termination, the contents of the registers designated by the R1 and R2 fields are updated the same as upon normal completion of the instruction, so that the instruction, when reexecuted, resumes at the point of interruption. The condition code is unpredictable.

Access exceptions for the portion of a storage operand to the right of the last byte processed may or may not be recognized. For operands longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the R field associated with that operand is odd. Although the operand address and length fields remain unchanged when a zero substring length is specified, the recognition of access exceptions is not necessarily prevented.

**Resulting Condition Code:**

0 Equal substrings of specified length found
1 End of longer operand reached when last bytes compared are equal
2 End of longer operand reached when last bytes compared are unequal
3 Last bytes compared are unequal, and CPU-determined number of bytes compared
Program Exceptions:

- Access (fetch, operands 1 and 2)
- Specification
- Transaction constraint

Programming Notes:

1. When the R₁ and R₂ fields are the same, the operation proceeds in the same way as when two distinct pairs of registers having the same contents are specified, and, in the absence of dynamic modification of the operand area by another CPU or by a channel program, condition code 0, 1, or 2 is set (as explained in the next note). However, it is unpredictable whether access exceptions are recognized for the operand since the operation can be completed without storage being accessed.

2. If the contents of the R₁ and R₂ fields are the same and the operand length is nonzero, and provided that another CPU or a channel program is not changing an operand, condition code 0 is set if the operand length is equal to or greater than the specified substring length, or condition code 1 is set if the operand length is less than the specified substring length. Whether or not R₁ equals R₂, if both operand lengths are zero, condition code 0 is set if the specified substring length is zero, or condition code 2 is set if the specified substring length is nonzero. In all of these cases, the addresses in the R₁ and R₂ registers and the lengths in the R₁ + 1 and R₂ + 1 registers remain unchanged.

3. Special precautions should be taken when COMPARE UNTIL SUBSTRING EQUAL is made the target of an execute-type instruction. See the programming note concerning interruptible instructions under EXECUTE.

4. Other programming notes concerning interruptible instructions are included in “Interruptible Instructions” on page 5-24.

5. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

6. The storage-operand references of COMPARE UNTIL SUBSTRING EQUAL may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

This definition assumes knowledge of the introductory information and information about dictionary formats in Enterprise Systems Architecture/390 Data Compression, SA22-7208-01.

The second operand is compressed or expanded, depending on a specification in general register 0, and the results are placed at the first-operand location. The compressed-data operand normally consists of index symbols corresponding to entries in a dictionary designated by an address in general register 1. This dictionary is a compression dictionary during a compression operation or an expansion dictionary during an expansion operation. During compression when format-1 sibling descriptors are specified in general register 0, an expansion dictionary immediately follows the compression dictionary. During compression when the symbol-translation option is specified in general register 0, the index symbols resulting from compression are translated to interchange symbols by means of a symbol-translation table designated by the address and an offset in general register 1, and it is the interchange symbols that are placed at the first-operand location. The number of bits in a symbol in the compressed-data operand is specified in general register 0. The operation proceeds until the end of either operand is reached or a CPU-determined amount of data has been processed, whichever occurs first. The results are indicated in the condition code.

The R₁ and R₂ fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte containing any bit of the first operand and second operand is designated by an address in general registers R₁ and R₂, respectively. The number of bytes containing any bits of the first operand and second operand is specified by bits 32-63 of general registers R₁ + 1 and R₂ + 1, respectively, in the 24-bit or 31-bit addressing mode or by bits 0-63 of the registers in the 64-bit addressing mode. The contents of general registers R₁ + 1 and R₂ + 1 are treated as 32-bit unsigned binary integers in the 24-bit or 31-bit addressing mode or as 64-bit
unsigned binary integers in the 64-bit addressing mode.

The location of the leftmost byte of the compression dictionary during compression, or of the expansion dictionary during expansion, is designated on a 4K-byte boundary by an address in general register 1.

### 24-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
<th>Address Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
<td>0 - 63</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
<td>0 - 32</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
<td>0 - 63</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Second-Operand Length</td>
<td>0 - 32</td>
</tr>
<tr>
<td>GR1</td>
<td>Dictionary Origin</td>
<td>0, 32, 52, 63</td>
</tr>
<tr>
<td></td>
<td>STT Offset</td>
<td>0 - 61</td>
</tr>
<tr>
<td></td>
<td>CBN</td>
<td>0 - 63</td>
</tr>
</tbody>
</table>

### 31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
<th>Address Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
<td>0 - 63</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
<td>0 - 32</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
<td>0 - 63</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Second-Operand Length</td>
<td>0 - 32</td>
</tr>
<tr>
<td>GR1</td>
<td>Dictionary Origin</td>
<td>0, 32, 52, 63</td>
</tr>
<tr>
<td></td>
<td>STT Offset</td>
<td>0 - 61</td>
</tr>
<tr>
<td></td>
<td>CBN</td>
<td>0 - 63</td>
</tr>
</tbody>
</table>

### 64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
<th>Address Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
<td>0 - 63</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
<td>0 - 63</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
<td>0 - 63</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Second-Operand Length</td>
<td>0 - 63</td>
</tr>
<tr>
<td>GR1</td>
<td>Dictionary Origin</td>
<td>0, 52, 61, 63</td>
</tr>
<tr>
<td></td>
<td>STT Offset</td>
<td>0 - 61</td>
</tr>
<tr>
<td></td>
<td>CBN</td>
<td>0 - 63</td>
</tr>
</tbody>
</table>

*Figure 7-183. Register Contents for COMPRESSION CALL (Part 1 of 2)*
The handling of the addresses in general registers R1, R2, and 1 is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of registers R1 and R2 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of registers R1 and R2 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of registers R1 and R2 constitute the address. In the 24-bit addressing mode, the contents of bit positions 40-51 of register 1, with 12 rightmost zeros appended, constitute the address, and the contents of bit positions 0-39 and 52-63 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-51 of register 1, with 12 rightmost zeros appended, constitute the address, and the contents of bit positions 0-32 and 52-63 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-51 of register 1, with 12 rightmost zeros appended, constitute the address, and the contents of bit positions 52-63 are ignored.

Although the contents of bit positions 52-63 of general register 1 are ignored as just described, those contents are used as follows. The contents of bit positions 61-63 of the register are the compressed-data bit number (CBN). At the beginning of the operation, the CBN designates the leftmost bit within the leftmost byte of the compressed-data operand. The compressed-data operand is the first operand during compression, or it is the second operand during expansion. When the symbol-translation option is specified during compression, the contents of bit positions 52-60 of the register, with seven rightmost zeros appended, are the byte offset from the beginning of the compression dictionary to the leftmost byte of the symbol-translation table. Symbol translation cannot be specified during expansion, and the contents of bit positions 52-60 are ignored during expansion.

The contents of the registers just described and also of general register 0 are shown in Figure 7-183 on page 7-154.

Bit 55 (E) of general register 0 specifies the compression operation if zero or the expansion operation if one.

When the CMPSC-enhancement facility is installed, bit 46 of general register 0 is the zero-padding (ZP) control. When the ZP control is zero, zero padding of the first operand is not performed. When the ZP con-
trol is one, zero padding of the first operand may be performed, as described below. When the CMPSC-enhancement facility is not installed, bit 46 of general register 0 is ignored.

Bit 47 (ST) of general register 0 is the symbol-translation-option bit. During compression when bit 47 is zero, the operation produces indexes, called index symbols, to compression-dictionary entries that represent character strings, and the operation then places the index symbols in the compressed-data operand. During compression when bit 47 is one, the operation still produces index symbols but then translates the index symbols to other symbols, called interchange symbols, that it then places in the compressed-data operand. This symbol translation is done by using the symbol-translation table specified by the address and offset in general register 1. Bit 47 and the offset in general register 1 are ignored during expansion. During expansion, the compressed-data operand always contains index symbols that designate entries in the expansion dictionary.

Bits 48-51 (CDSS) of general register 0 specify the number of bits in the index symbols or interchange symbols in the compressed-data operand, as shown in the figure. Bits 48-51 must not have any of the values 0000 or 0110-1111 binary; otherwise, a specification exception is recognized. When symbol-translation is not specified, bits 48-51 also specify, as shown in the figure, the number of eight-byte entries in each of the compression and expansion dictionaries, and, thus, they specify the size in bytes of each of the dictionaries. When symbol translation is specified, the compression dictionary is considered to extend to the beginning of the symbol-translation table, that is, the size in bytes of the compression dictionary is the offset in bit positions 52-60 of general register 1, with seven rightmost zeros appended. The size in bytes of the symbol-translation table is considered to be one fourth of the compression dictionary. However, the offset in general register 1 must be at least as large as the size of the compression dictionary would be if symbol translation were not specified and the CDSS were one less than it actually is, and, when the CDSS is 0001 binary, the offset must be at least 2K bytes; otherwise, the results are unpredictable. For example, if the CDSS is 0101, the offset must be at least 32K bytes.

Bit 54 (F1) of general register 0 specifies that the compression dictionary contains format-0 sibling descriptors if the bit is zero or format-1 sibling descriptors if the bit is one. Sibling descriptors are used during the compression operation. A format-0 sibling descriptor is eight bytes at an index position in the compression dictionary. A format-1 sibling descriptor is 16 bytes, with the first eight bytes at an index position in the compression dictionary and the second eight bytes at the same index position in the expansion dictionary. During compression when bit 54 is one, an expansion dictionary is considered to immediately follow the compression dictionary specified by the address in general register 1. Bit 54 is ignored during expansion.

Bits 47 and 54 of general register 0 must not both be ones; otherwise, the results are unpredictable.

The unused bit positions in general register 0 are reserved for possible future extensions and should contain zeros; otherwise, the program may not operate compatibly in the future.

In the access-register mode, the contents of access register R1 are used for accessing the first operand, and the contents of access register R2 are used for accessing the second operand and the dictionaries and the symbol-translation table.

The operation starts at the left end of both operands and proceeds to the right. The operation is ended when the end of either operand is reached or when a CPU-determined amount of data has been processed, whichever occurs first.

During a compression operation, the end of the first operand is considered to be reached when the number of unused bit positions remaining in the first-operand location is not sufficient to contain additional compressed data.

During an expansion operation, the end of the first-operand location is considered to be reached when either of the following two conditions is met:

1. The number of unused byte positions remaining in the first-operand location is not sufficient to contain all the characters that would result from expansion of the next index symbol.

2. Immediately when the number of unused byte positions is zero, that is, immediately when the expansion of an index symbol completely fills the first-operand location.

During an expansion operation, the end of the second-operand location is considered to be reached
when the next index symbol does not reside entirely within the second-operand location. The second-operand location ends at the beginning of the byte designated by the sum of the address in general register R2 and the length in general register R2 + 1, regardless of the compressed-data bit number in bit positions 61-63 of general register 1.

If the operation is ended because the end of the second operand is reached, condition code 0 is set. If the operation is ended because the end of the first operand is reached, condition code 1 is set, except that condition code 0 is set if the end of the second operand is also reached. If the operation is ended because a CPU-determined amount of data has been processed, condition code 3 is set.

At the completion of the operation, the length in general register R1 + 1 is decremented by the number of complete bytes stored at the first-operand location, and the address in general register R1 is incremented by the same amount. During compression, a complete byte is considered to be stored only if all of its bit positions contain bits of compressed data. During compression when the first bit of compressed data stored is not in bit position 0 of a byte, the bits in the byte to the left of the first bit of compressed data remain unchanged. During compression if the last byte stored does not completely contain compressed data, the bits in the byte to the right of the rightmost bit of compressed data in the byte either are unchanged or are set to zeros.

The length in general register R2 + 1 is decremented by the number of complete bytes processed at the second-operand location, and the address in general register R2 is incremented by the same amount. During expansion, a complete byte is considered to be processed only if all of its bits have been used to produce expanded data.

The leftmost bits which are not part of the address in general registers R1 and R2 may be set to zeros or may remain unchanged. However, in the 24-bit or 31-bit addressing mode, bits 0-31 of these registers and also of general registers R1 + 1 and R2 + 1 always remain unchanged.

When all of the following conditions are met, zero padding may be performed, as described below.

- The CMPSC-enhancement facility is installed.
- The zero-padding (ZP) control, bit 46 of general register 0, is one.
- Any of the following is true:
  - The end of the first operand is reached (CC1).
  - The end of the second operand is reached (CC0).
  - A CPU-determined amount of data has been processed (CC3).
- The last byte of compressed or expanded data does not coincide with the rightmost byte of a model-dependent integral storage boundary.
- The remaining length in general register R1 + 1 is sufficient to store up to the model-dependent integral storage boundary.

It is model dependent whether zero padding is performed. When any of the conditions listed above are not met, zero padding is not performed.

Zero padding consists of storing zeros to the right of the last compressed or expanded byte, up to a model-dependent integral storage boundary. The address in general register R1 and the length in general register R1 + 1 are not updated to account for the zero padding. PER storage-alteration events are recognized for stores that occur as a result of zero padding. The model-dependent integral storage boundary is no larger than 4,096.

When the R1 and R2 fields do not designate general register 0, the handling of general register 1 is as follows. The bit number of the bit following the last bit of compressed data processed is placed in bit positions 61-63 of general register 1, and bits 52-60 of the register and the leftmost bits which are not part of the address in the register may be set to zeros or may remain unchanged, except that when one or both of the original length values are so small that no compressed data can be processed, all bits in the register may remain unchanged. However, when bit 47 of general register 0 is one, bits 52-60 of general register 1 always remain unchanged. Also, in the 24-bit or 31-bit addressing mode, bits 0-31 of the register always remain unchanged.

If (a) the operands overlap one another, (b) the first operand overlaps the dictionaries or the symbol-translation table in storage in any way, or (c) either
the $R_1$ or the $R_2$ field designates general register 0, the results are unpredictable.

When symbol translation is specified, the symbol-translation table consists of two-byte entries, and an entry contains an interchange symbol in the rightmost bit positions of the entry. The length of the interchange symbol is specified by bits 48-51 of general register 0. The left-hand bits that are not part of the interchange symbol in a symbol-translation-table entry must be zeros; otherwise, the results are unpredictable.

To translate an index symbol to an interchange symbol, the index symbol is multiplied by 2 and then added to the address of the beginning of the symbol-translation table to locate an entry in the table, and then the interchange symbol is obtained from the entry.

The execution of the instruction is interruptible. When an interruption occurs, other than one that follows termination, the contents of the registers designated by the $R_1$ and $R_2$ fields and of general register 1 are updated the same as upon normal completion of the instruction, so that the instruction, when reexecuted, resumes at the point of interruption. The condition code is unpredictable.

For operands longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the current location being processed. Access exceptions may be recognized for all locations in the dictionaries and symbol-translation table if those areas are specified to be used and even if the locations would not be used during the operation. Access exceptions are not recognized for an operand, the dictionaries, or the symbol-translation table if the R field associated with that operand is odd. Also, when the $R_1$ field is odd, PER storage-alteration events are not recognized, and no change bits are set.

If an access exception is due to be recognized for either of the operands or for a dictionary or the symbol-translation table, the result is that either the exception is recognized or condition code 3 is set. If condition code 3 is set, the exception will be recognized when the instruction is executed again to continue processing the same operands, assuming that the exception condition still exists.

During compression, regardless of whether the exception is recognized or condition code 3 is set, a nullifying access-exception condition or a suppressing DAT-protection exception condition is handled so that an index symbol is generated only if it is the one that would result if there were no access-exception condition.

During compression or expansion, regardless of whether the exception is recognized or condition code 3 is set, a nullifying or suppressing access-exception condition may result in data having been stored at the first-operand location at or to the right of the location designated by the final address in general register $R_1$, which result is not true nullification or suppression. The amount of data stored depends on the reason for the access-exception condition. If the condition is due to a reference to a dictionary or the symbol-translation table, up to 4K bytes of data may have been stored at or to the right of the location designated by the final address. If the condition is due to a reference to the first or second operand, part of one index or interchange symbol, during compression, or part of one character symbol, during expansion, may have been stored at or to the right of the location designated by the final address. In all cases, the storing will be repeated when the instruction is executed again to continue processing the same operands.

If the end of the first operand is reached and an access exception is due to be recognized for the second operand, it is unpredictable whether condition code 1 is set or the access exception is recognized.

During expansion when the expansion dictionary is not logically correct, unusual storing may occur as described in the section “Expansion Process” in Chapter 1 of Enterprise Systems Architecture/390 Data Compression, SA22-7208-01. The results of an access exception in this case may not be true nullification or suppression.

Special Conditions

During compression of each character symbol, either the characters in the symbol or the dictionary character entries (not sibling descriptors) representing characters of the symbol are counted, and a general-operand data exception is recognized if this count becomes too large. The count can reach at least 260 without the exception being recognized.

During compression, the number of child characters or sibling characters processed during the processing of each parent entry are counted, and a general-operand data exception is recognized if this count
becomes too large. The count can reach at least 260 without the exception being recognized. That is, a parent must not have more than 260 children; otherwise, a general-operand data exception may be recognized.

During expansion of each character symbol, either the characters in the symbol or the dictionary entries representing characters of the symbol are counted, and a general-operand data exception is recognized if this count becomes too large. If the characters in the symbol are counted, the count can reach at least 260 without the exception being recognized. If the dictionary entries representing characters of the symbol are counted, the count can reach at least 127 without the exception being recognized.

Certain error conditions in the dictionaries cause a general-operand data exception to be recognized and the operation to be either suppressed or terminated. Some of these error conditions are described in the sections “Expansion Process” and “Results of Dictionary Errors” in Chapter 1 of SA22-7208-01. The others are described in Chapter 2 of SA22-7208-01.

**Resulting Condition Code:**

0  End of second operand reached
1  End of first operand reached and end of second operand not reached
2  --
3  CPU-determined amount of data processed

**Program Exceptions:**

- Access (fetch, operand 2, dictionaries, and symbol-translation table; store, operand 1)
- Data with DXC 0, general operand
- Specification
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the program can simply branch back to the instruction to continue the operation. The program need not determine the amount of data processed.

2. During compression when a nullifying access exception is due to be recognized, an index symbol is generated only if it is the one that would result if there were no access-exception condition. The result of this is that compression of the same expanded data by means of one or more executions of the instruction and by using the same dictionary always results in the same compressed data. That is, (1) the best possible matches in the dictionary are always found for the characters in the second operand, or else the execution is ended by either setting CC3 or recognizing the exception, and (2) the results of compression are repeatable (although possibly by means of a different number of executions of the instruction) and predictable.

For example, if the next characters of the string being compressed are ABC, and dictionary entry A has a child B, which has a child C, the normal operation is to compress ABC as a single index symbol, but if the C of the string is in the first byte of an invalid page (a page-translation exception is due to be recognized), no index symbol is generated. More specifically, an index symbol corresponding to the character symbol AB is not generated because this is not the index symbol that would be generated if the access-exception condition did not exist.

In the above, “best possible match” refers only to the characters in the second operand. In the example above, if the next two characters of the second operand (the string) are AB, and these are the last two characters of the second operand, the best possible match is on AB, even though there could be a match on ABC if the second operand included one more byte containing C.

Expansion is normally always repeatable. An index symbol is always expanded to exactly the character symbol it represents unless an exception that causes termination is recognized.

3. During expansion, if at least one unused byte position remains in the first operand location, COMPRESSION CALL may completely process the next index symbol in the second operand before it determines that the first-operand location does not have sufficient unused byte positions to contain the expanded data that would result from the next index symbol. If that next index symbol causes encountering of bad dictionary entries, the result can be either a data exception or condition code 1.

COMPRESSION CALL immediately sets condition code 1 when processing of an index symbol exactly fills the first-operand location, except that
it sets condition code 0 if the end of the second-operand location also has been reached. Immediately setting condition code 1 has the advantage that data can be compressed using one dictionary and then followed immediately, possibly on a bit boundary, by a different type of data compressed using another dictionary. The compressed data can be successfully expanded if, during the expansion of the data compressed using the first dictionary, the length of the first-operand location is specified to be exactly the length of the expanded data that will be produced. Condition code 1 will then be set when the first-operand location is full, at which time the specification of the dictionary can be changed in order to expand the remainder of the compressed data using the second dictionary. If the definition allowed condition code 1 not to be set, it might be attempted to expand the next index symbol, which resulted from use of the second dictionary, by means of the first dictionary, and this might cause recognition of a general-operation data exception. For example, the next index symbol, which properly designates a character entry in the second dictionary, might designate the second half of a format-1 sibling descriptor in the first dictionary, and that second half might begin with a character, such as 0 (F0 hex), that would appear to be an invalid partial symbol length in a character entry.

4. A nullifying access-exception condition due to a reference to a dictionary or the symbol-translation table may result in the storing of data at or to the right of the location designated by the final address in general register R1. This storing and the processing needed to produce the data stored will be repeated when COMPRESSION CALL is executed again to continue processing the same operands. The repeated processing will reduce the performance of the instruction execution, and it should be avoided by ensuring that the environment in which the program is executed is one in which page-translation-exception conditions for the dictionaries and symbol-translation table are infrequent.

5. Following is an example of how the compressed-data bit number (CBN) is used and set. In this example:

- The operation is an expansion operation.
- The CDSS in general register 0 is 0010 binary. Therefore, there are 1K entries in the expansion dictionary, and the length of an index symbol is 10 bits.

- The second operand (compressed-data operand) begins at location 6000 hex and has a length of five bytes. The initial CBN is 7. Therefore, there are three index symbols to be expanded, and the final CBN will be 5.

- The compressed data beginning at location 6000 hex is 0081FF9FF8 hex. Therefore, the three index symbols are 103, 3FC, and 3FF hex.

- The first operand (expanded-data operand) begins at location 5000 hex and has a length of 64 bytes. The three index symbols are expanded to a total of 14 bytes of expanded data.

The following figure shows the initial and final contents of general registers R1, R1+1, R2, and R2+1, the contents of locations 6000-6004 hex in binary, and the way a cursor corresponding to the CBN is advanced during the expansion operation.

<table>
<thead>
<tr>
<th>Register</th>
<th>Initial Contents in Hex</th>
<th>Final Contents in Hex</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>5000</td>
<td>500E</td>
</tr>
<tr>
<td>R1+1</td>
<td>40</td>
<td>32</td>
</tr>
<tr>
<td>R2</td>
<td>6000</td>
<td>6004</td>
</tr>
<tr>
<td>R2+1</td>
<td>5</td>
<td>1</td>
</tr>
</tbody>
</table>

Contents of Locations 6000-6004 Hex in Binary

```
00000000 10000001 11111111 10011111 11111000
  ↑   ↑   ↑   ↑   ↑
Initial  CBN  CBN
    (7)      (5)
```

6. The reason for allowing a parent to have no more than 260 children is as follows. The parent can contain five identical child characters. Then, 255 different sibling characters are possible — all of these must be different from the child characters and each other, or else they may be wasted (never matched against), depending on the implementation. Thus, every possible child is permitted.

7. Symbol translation is for use by VTAM. VTAM will begin by doing compression by means of software and an adaptive dictionary. When the adap-
tive dictionary has matured such that the degree of compression becomes sufficiently good (crosses some threshold), VTAM will “freeze” (stop adapting) its dictionary, inform the other end of the session to freeze also, transform its adaptive dictionary to the dictionary form used by COMPRESSION CALL, and then use COMPRESSION CALL to continue on with the compression. The other end of the session can continue to use its frozen adaptive dictionary.

Following is clarification about the STT offset. Assume VTAM uses a 4K-entry adaptive dictionary, which is the largest size VTAM uses. All of the entries in this dictionary correspond to character symbols because there are no sibling descriptors in the VTAM dictionary. The VTAM dictionary cannot map one-to-one to a COMPRESSION CALL dictionary because the latter requires that some of the entries be sibling descriptors. Therefore, VTAM must have an 8K-entry dictionary for use in the basic compression operation. Only the first hundred or so entries in the second 4K of the 8K need to be used, and these entries compensate for (take the place of) the entries in the first 4K that must be sibling descriptors. The STT can and should, to save space, begin immediately after those hundred or so entries in the second 4K. In this example, the index symbols will be 13 bits but will be transformed to 12-bit interchange symbols.

8. A program may place the dictionaries in pages that are managed by means of chaining fields at their beginnings. In this case, either the parts of a dictionary have to be moved to be compacted into contiguous locations or there have to be holes in the dictionaries. The definition of COMPRESSION CALL contains nothing explicitly to support holes. However, assuming there is at least one character that never appears in the expanded data, that character can be used as a child character in a parent entry or as a sibling character in a sibling descriptor to specify a child or children that will never be referenced, thus creating a hole.

9. The references to the operands, dictionaries, and symbol-translation table for COMPRESSION CALL may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

10. Setting the ZP control to one may provide improved performance on models in which the CMPSC-enhancement facility is installed.

11. Zero padding is not necessarily performed in every case where it is permissible.

12. Figure 7-184 on page 7-162 and Figure 7-185 on page 7-164 show possible forms (not the only possible forms) of the compression and expansion processes. The figures do not show testing for or the results of dictionary errors.

13. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.
Figure 7-184. Compression Process  (Part 1 of 2)
Figure 7-184. Compression Process (Part 2 of 2)
Figure 7-185. Expansion Process

Notes: Fields are in current entry. SRC = source, DST = destination

1. Start

Another SRC index exists?

No

> 0 DST byte positions exist?

No

Set CC0 and endop

Yes

Yes

Next SRC index < 256?

No

Set SYMLEN = PSL + OFST

Yes

Get PSL ECs from entry and store in DST at OFST. Use PPTR as index of current entry (see note).

PSL=0?

No

Set CC1 and endop

Yes

Get CSL ECs from entry and store in DST. Advance 1 index in SRC. Advance SYMLEN bytes in DST.

CSL DST byte positions exist?

No

Set CC1 and endop

Yes

Get CSL ECs from entry and store in DST. Advance 1 index in SRC. Advance SYMLEN bytes in DST.

SYMLEN DST byte positions exist?

No

Get PSL ECs from entry and store in DST at OFST. Use PPTR as index of current entry (see note).

PSL=0?

No

Set CC1 and endop

Yes

Get PSL ECs from entry and store in DST at OFST. Use PPTR as index of current entry (see note).

Note: If PPTR>256, the action can be:

Store PPTR as char in DST. Advance 1 index in SRC. Advance SYMLEN bytes in DST.
COMPUTE INTERMEDIATE MESSAGE DIGEST

KIMD  R1,R2  [RRE]

A function specified by the function code in general register 0 is performed.

Bits 16-23 of the instruction and the R1 field are ignored.

Bit positions 57-63 of general register 0 contain the function code. Figure 7-186 and Figure 7-187 show the assigned function codes for COMPUTE INTERMEDIATE MESSAGE DIGEST and COMPUTE LAST MESSAGE DIGEST, respectively. All other function codes are unassigned. Bit 56 of general register 0 must be zero; otherwise, a specification exception is recognized. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.

The function codes for COMPUTE INTERMEDIATE MESSAGE DIGEST are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>KIMD-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>KIMD-SHA-1</td>
<td>20</td>
<td>64</td>
</tr>
<tr>
<td>2</td>
<td>KIMD-SHA-256</td>
<td>32</td>
<td>64</td>
</tr>
<tr>
<td>3</td>
<td>KIMD-SHA-512</td>
<td>64</td>
<td>128</td>
</tr>
<tr>
<td>65</td>
<td>KIMD-GHASH</td>
<td>32</td>
<td>16</td>
</tr>
</tbody>
</table>

Explanation:
— Not applicable

Figure 7-186. Function Codes for COMPUTE INTERMEDIATE MESSAGE DIGEST

COMPUTE LAST MESSAGE DIGEST

KLMD  R1,R2  [RRE]

The function codes for COMPUTE LAST MESSAGE DIGEST are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>KLMD-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>KLMD-SHA-1</td>
<td>28</td>
<td>64</td>
</tr>
<tr>
<td>2</td>
<td>KLMD-SHA-256</td>
<td>40</td>
<td>64</td>
</tr>
<tr>
<td>3</td>
<td>KLMD-SHA-512</td>
<td>80</td>
<td>128</td>
</tr>
</tbody>
</table>

Explanation:
— Not applicable

1 For all data blocks except the last block. The size of the last data block ranges from 1 to one less than the value shown.

Figure 7-187. Function Codes for COMPUTE LAST MESSAGE DIGEST

All other function codes are unassigned.

The query function provides the means of indicating the availability of the other functions. The contents of general registers R2 and R2 + 1 are ignored for the query function. For all other functions, the second operand is processed as specified by the function code using an initial chaining value in the parameter block, and the result replaces the chaining value. For COMPUTE
LAST MESSAGE DIGEST, the operation also uses a message bit length in the parameter block. The operation proceeds until the end of the second-operand location is reached or a CPU-determined number of bytes have been processed, whichever occurs first. The result is indicated in the condition code.

The R2 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the second operand is specified by the contents of the R2 general register. The number of bytes in the second-operand location is specified in general register \( R_2 + 1 \).

As part of the operation, the address in general register \( R_2 \) is incremented by the number of bytes processed from the second operand, and the length in general register \( R_2 + 1 \) is decremented by the same number. The formation and updating of the address and length is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general register \( R_2 \) constitute the address of the second operand, and the contents of bit positions 0-39 are ignored; bits 40-63 of the updated address replace the corresponding bits in general register \( R_2 \), carries out of bit position 40 of the updated address are ignored, and the contents of bit positions 32-39 of general register \( R_2 \) are set to zeros. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register \( R_2 \) constitute the address of the second operand, and the contents of bit positions 0-32 are ignored; bits 33-63 of the updated address replace the corresponding bits in general register \( R_2 \), carries out of bit position 33 of the updated address are ignored, and the content of bit position 32 of general register \( R_2 \) is set to zero. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register \( R_2 \) constitute the address of the second operand; bits 0-63 of the updated address replace the contents of general register \( R_2 \) and carries out of bit position 0 are ignored.

In both the 24-bit and the 31-bit addressing modes, the contents of bit positions 32-63 of general register \( R_2 + 1 \) form a 32-bit unsigned binary integer which specifies the number of bytes in the second operand; and the updated value replaces the contents of bit positions 32-63 of general register \( R_2 + 1 \). In the 64-bit addressing mode, the contents of bit positions 0-63 of general register \( R_2 + 1 \) form a 64-bit unsigned binary integer which specifies the number of bytes in the second operand; and the updated value replaces the contents of general register \( R_2 + 1 \).

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers \( R_2 \) and \( R_2 + 1 \), always remain unchanged.

Figure 7-188 on page 7-167 shows the contents of the general registers just described.

In the access-register mode, access registers 1 and \( R_2 \) specify the address spaces containing the parameter block and second operand, respectively.

The result is obtained as if processing starts at the left end of the second operand and proceeds to the right, block by block. The operation is ended when all source bytes in the second operand have been processed (called normal completion), or when a CPU-determined number of blocks that is less than the length of the second operand have been processed (called partial completion). The CPU-determined number of blocks depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of blocks is usually nonzero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.

When the chaining-value field overlaps any portion of the second operand, the result in the chaining-value field is unpredictable.

For COMPUTE INTERMEDIATE MESSAGE DIGEST, normal completion occurs when the number of bytes in the second operand as specified in general register \( R_2 + 1 \) have been processed. For COMPUTE LAST MESSAGE DIGEST, after all bytes in the second operand as specified in general register \( R_2 + 1 \) have been processed, the padding operation is performed, and then normal completion occurs.

When the operation ends due to normal completion, condition code 0 is set and the resulting value in \( R_2 + 1 \) is zero. When the operation ends due to partial completion, condition code 3 is set and the resulting value in \( R_2 + 1 \) is nonzero.

When the second-operand length is initially zero, the second operand is not accessed, general registers \( R_2 \) and \( R_2 + 1 \) are not changed, and condition code 0
is set. For COMPUTE INTERMEDIATE MESSAGE DIGEST, the parameter block is not accessed. However, for COMPUTE LAST MESSAGE DIGEST, the empty block \( L = 0 \) case padding operation is performed and the result is stored into the parameter block.

A PER storage-alteration event may be recognized for the portion of the parameter block that is stored. A PER zero-address-detection event may be recognized for the second-operand location and for the parameter block. When PER events are detected for one or more locations, it is unpredictable which location is identified in the PER access identification (PAID) and PER ASCE ID (AI).

As observed by this CPU, other CPUs, and channel programs, references to the parameter block and storage operands may be multiple-access references, accesses to these storage locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

Access exceptions may be reported for a larger portion of the second operand than is processed in a single execution of the instruction; however, access exceptions are not recognized for locations beyond the length of the second operand nor for locations more than 4K bytes beyond the current location being processed.

Symbols Used in Function Descriptions

The following symbols are used in the subsequent description of the COMPUTE INTERMEDIATE MESSAGE DIGEST and COMPUTE LAST MESSAGE DIGEST functions. Further description of the secure hash algorithm may be found in Reference [13.] on page xxviii. Further description of the GCM (Galois/counter mode) multiplication over \( \text{GF}(2^{128}) \)
may be found in Reference [15.] on page xxviii.

**KIMD-Query (KIMD Function Code 0)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.

The parameter block used for the function has the following format:

```
Symbol | Explanation
------ | -----------
<n>    | Length of item in bytes
bda    | Block digest algorithm
ICV    | Initial chaining value
M      | Message block
OCV    | Output chaining value
```

**Figure 7-193. Parameter Block for KIMD-Query**

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the COMPUTE INTERMEDIATE MESSAGE DIGEST instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the KIMD-Query function completes; condition code 3 is not applicable to this function.

**KIMD-SHA-1 (KIMD Function Code 1)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.
The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th></th>
<th>H0</th>
<th>H1</th>
<th>H2</th>
<th>H3</th>
<th>H4</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Figure 7-194. Parameter Block for KIMD-SHA-1*

A 20-byte intermediate message digest is generated for the 64-byte message blocks in operand 2 using the SHA-1 block digest algorithm with the 20-byte chaining value (called H fields) in the parameter block. The generated intermediate message digest, also called the output chaining value (OCV), is stored in the chaining-value field of the parameter block. The operation is shown in Figure 7-195.

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th></th>
<th>H0</th>
<th>H1</th>
<th>H2</th>
<th>H3</th>
<th>H4</th>
<th>H5</th>
<th>H6</th>
<th>H7</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Figure 7-196. Parameter Block for KIMD-SHA-256*

A 32-byte intermediate message digest is generated for the 64-byte message blocks in operand 2 using the SHA-256 block digest algorithm with the 32-byte chaining value (called H fields) in the parameter block. The generated intermediate message digest, also called the output chaining value (OCV), is stored in the chaining-value field of the parameter block. The operation is shown in Figure 7-197.

**KIMD-SHA-256 (KIMD Function Code 2)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.

**KIMD-SHA-512 (KIMD Function Code 3)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.
A 64-byte intermediate message digest is generated for the 128-byte message blocks in operand 2 using the SHA-512 block digest algorithm with the 64-byte chaining value (called H fields) in the parameter block. The generated intermediate message digest, also called the output chaining value (OCV), is stored in the chaining-value field of the parameter block. The operation is shown in Figure 7-197.

**Figure 7-198. Parameter Block for KIMD-SHA-512**

The GHASH for the 16-byte message blocks (M1, M2, ..., Mn) in operand 2 is computed using the hash subkey and the 128-bit chaining value.

The first message block is exclusive-ORed with the initial chaining value (ICV) in the parameter block. The result of the exclusive-OR operation and the hash subkey (H) are multiplied using a Galois/counter-mode (GCM) multiplication operation over a Galois field (GF(2^{128})) to produce the chaining value for the next message block. The process is repeated until all message blocks have been processed, or until a CPU-determined number of message blocks have been processed.

The GHASH, called the output chaining value (OCV), is stored into the Initial-chaining-value field of the parameter block. The operation is shown in Figure 7-201 on page 7-170.

**Figure 7-200. Parameter Block for KIMD-GHASH**

**KIMD-GHASH (Function Code 65)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.

**Figure 7-199. KIMD-SHA-512**

**Figure 7-201. KIMD-GHASH**

**KLMD-Query (KLMD Function Code 0)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.
The parameter block used for the function has the following format:

```
<table>
<thead>
<tr>
<th>Status Word</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
</tbody>
</table>
```

*Figure 7-202. Parameter Block for KLMD-Query*

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the COMPUTE LAST MESSAGE DIGEST instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the KLMD-Query function completes; condition code 3 is not applicable to this function.

**KLMD-SHA-1 (KLMD Function Code 1)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.

The parameter block used for the function has the following format:

```
 | H0 |
 | H1 |
 | H2 |
 | H3 |
 | H4 |
```

*Figure 7-203. Parameter Block for KLMD-SHA-1*

The message digest for the message (M) in operand 2 is generated using the SHA-1 algorithm with the chaining value (called H fields) and message-bit-length information in the parameter block.

If the length of the message in operand 2 is equal to or greater than 64 bytes, an intermediate message digest is generated for each 64-byte message block using the SHA-1 block digest algorithm with the 20-byte chaining value in the parameter block, and the generated intermediate message digest, also called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. This operation is shown in Figure 7-204 and repeats until the remaining message is less than 64 bytes or until a CPU-determined number of blocks have been stored.

If the length of the message or the remaining message is zero bytes, then the operation in Figure 7-205 is performed. If the length of the message or the remaining message is between one byte and 55 bytes inclusive, then the operation in Figure 7-206 is performed; if the length is between 56 bytes and 63 bytes inclusive, then the operation in Figure 7-207 is performed. The message digest, also called the output chaining value (OCV), is stored into the chaining-value field of the parameter block.

**Additional Symbols Used in KLMD Functions**

The following additional symbols are used in the description of the COMPUTE LAST MESSAGE DIGEST functions.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Explanation for KLMD Function Figures</th>
</tr>
</thead>
<tbody>
<tr>
<td>L</td>
<td>Byte length of operand 2 in storage.</td>
</tr>
<tr>
<td>p &lt;n&gt;</td>
<td>n padding bytes; leftmost byte is 80 hex; all other bytes are 00 hex.</td>
</tr>
<tr>
<td>z &lt;n&gt;</td>
<td>n padding bytes of zero.</td>
</tr>
<tr>
<td>mbl</td>
<td>an 8-byte or 16-byte value specifying the bit length of the total message.</td>
</tr>
<tr>
<td>q &lt;64&gt;</td>
<td>a padding block, consisting of 56 bytes of zero followed by an 8-byte mbl.</td>
</tr>
<tr>
<td>q &lt;128&gt;</td>
<td>a padding block, consisting of 112 bytes of zero followed by a 16-byte mbl.</td>
</tr>
</tbody>
</table>

*Figure 7-204. KLMD-SHA-1 Full Block (L ≥ 64)*
COMPUTE LAST MESSAGE DIGEST

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>Parameter Block in Storage</th>
</tr>
</thead>
<tbody>
<tr>
<td>H0  H1  H2  H3  H4  mbl</td>
</tr>
<tr>
<td>OCV &lt;20&gt;</td>
</tr>
<tr>
<td>ICV &lt;20&gt;</td>
</tr>
<tr>
<td>p &lt;56&gt;</td>
</tr>
<tr>
<td>z &lt;56&gt;</td>
</tr>
<tr>
<td>q &lt;64&gt;</td>
</tr>
<tr>
<td>SHA-1 bda</td>
</tr>
<tr>
<td>OCV &lt;20&gt;</td>
</tr>
<tr>
<td>M &lt;L&gt;</td>
</tr>
<tr>
<td>p &lt;64-L&gt;</td>
</tr>
<tr>
<td>SHA-1 bda</td>
</tr>
<tr>
<td>OCV &lt;20&gt;</td>
</tr>
</tbody>
</table>

Figure 7-205. KLMD-SHA-1 Empty Block (L = 0)

Figure 7-206. KLMD-SHA-1 Partial-Block Case 1 (1 ≤ L ≤ 55)

Figure 7-207. KLMD-SHA-1 Partial-Block Case 2 (56 ≤ L ≤ 63)

Figure 7-208. Parameter Block for KLMD-SHA-256
The message digest for the message (M) in operand 2 is generated using the SHA-256 algorithm with the chaining value (called H fields) and message-bit-length information in the parameter block.

If the message in operand 2 is equal to or greater than 64 bytes, an intermediate message digest is generated for each 64-byte message block using the SHA-256 block digest algorithm with the 32-byte chaining value in the parameter block, and the generated intermediate message digest, also called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. This operation is shown in Figure 7-209 and repeats until the remaining message is less than 64 bytes or until a CPU-determined number of blocks have been stored.

If the length of the message or the remaining message is zero bytes, then the operation in Figure 7-210 is performed. If the length of the message or the remaining message is between one byte and 55 bytes inclusive, then the operation in Figure 7-211 is performed; if the length is between 56 bytes and 63 bytes inclusive, then the operation in Figure 7-212 is performed. The message digest, also called the output chaining value (OCV), is stored into the chaining-value field of the parameter block.
The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>16</th>
<th>24</th>
<th>32</th>
<th>40</th>
<th>48</th>
<th>56</th>
<th>64</th>
</tr>
</thead>
<tbody>
<tr>
<td>H0</td>
<td>H1</td>
<td>H2</td>
<td>H3</td>
<td>H4</td>
<td>H5</td>
<td>H6</td>
<td>H7</td>
<td>mbl</td>
</tr>
<tr>
<td>ICV &lt;32&gt;</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The message digest for the message (M) in operand 2 is generated using the SHA-512 algorithm with the chaining value (called H fields) and message-bit-length information in the parameter block.

If the message in operand 2 is equal to or greater than 128 bytes, an intermediate message digest is generated for each 128-byte message block using the SHA-512 block digest algorithm with the 64-byte chaining value in the parameter block, and the generated intermediate message digest, also called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. This operation is shown in Figure 7-214 and repeats until the remaining message is less than 128 bytes or until a CPU-determined number of blocks have been stored.

If the length of the message or the remaining message is zero bytes, then the operation in Figure 7-215 is performed. If the length of the message or the remaining message is between one byte and 111 bytes inclusive, then the operation in Figure 7-216 is performed; if the length is between 112 bytes and 127 bytes inclusive, then the operation in Figure 7-217 is performed. The message digest, also called the output chaining value (OCV), is stored into the chaining-value field of the parameter block.

---

**Figure 7-212. KLMD-SHA-256 Partial-Block Case 2 (56 ≤ L ≤ 63)**

**KLMD-SHA-512 (KLMD Function Code 3)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-188 on page 7-167.

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>16</th>
<th>24</th>
<th>32</th>
<th>40</th>
<th>48</th>
<th>56</th>
<th>64</th>
</tr>
</thead>
<tbody>
<tr>
<td>H0</td>
<td>H1</td>
<td>H2</td>
<td>H3</td>
<td>H4</td>
<td>H5</td>
<td>H6</td>
<td>H7</td>
<td>mbl</td>
</tr>
<tr>
<td>ICV &lt;32&gt;</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The message digest for the message (M) in operand 2 is generated using the SHA-512 algorithm with the chaining value (called H fields) and message-bit-length information in the parameter block.

If the message in operand 2 is equal to or greater than 128 bytes, an intermediate message digest is generated for each 128-byte message block using the SHA-512 block digest algorithm with the 64-byte chaining value in the parameter block, and the generated intermediate message digest, also called the output chaining value (OCV), is stored into the chaining-value field of the parameter block. This operation is shown in Figure 7-214 and repeats until the remaining message is less than 128 bytes or until a CPU-determined number of blocks have been stored.

If the length of the message or the remaining message is zero bytes, then the operation in Figure 7-215 is performed. If the length of the message or the remaining message is between one byte and 111 bytes inclusive, then the operation in Figure 7-216 is performed; if the length is between 112 bytes and 127 bytes inclusive, then the operation in Figure 7-217 is performed. The message digest, also called the output chaining value (OCV), is stored into the chaining-value field of the parameter block.

---

**Figure 7-213. Parameter Block for KLMD-SHA-512**

**Figure 7-214. KLMD-SHA-512 Full Block (L ≥ 128)**
Special Conditions for KIMD and KLMD

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.
3. The \( R_2 \) field designates an odd-numbered register or general register 0.
4. For \texttt{COMPUTE INTERMEDIATE MESSAGE DIGEST}, the second-operand length is not a multiple of the data block size of the designated function (see Figure 7-186 on page 7-165 for \texttt{COMPUTE INTERMEDIATE MESSAGE DIGEST} functions). This specification-exception condition does not apply to the query function, nor does it apply to \texttt{COMPUTE LAST MESSAGE DIGEST}. 

---

**Figure 7-215. KLMD-SHA-512 Empty Block \((L = 0)\)**

**Figure 7-216. KLMD-SHA-512 Partial-Block Case 1 \((1 \leq L \leq 111)\)**

**Figure 7-217. KLMD-SHA-512 Partial-Block Case 2 \((112 \leq L \leq 127)\)**
**Resulting Condition Code:**

0  Normal completion  
1  --  
2  --  
3  Partial completion

**Program Exceptions:**

- Access (fetch, operand 2 and message bit length; fetch and store, chaining value)
- Operation (if the message-security assist is not installed)
- Specification
- Transaction constraint

| 1.-6. | Exceptions with the same priority as the priority of program-interruption conditions for the general case. |
| 7.B  | Operation exception. |
| 7.C  | Transaction constraint |
| 8.   | Specification exception due to invalid function code or invalid register number. |
| 9.   | Specification exception due to invalid operand length. |
| 10.  | Condition code 0 due to second-operand length originally zero. |
| 11.  | Access exceptions for an access to the parameter block or second operand. |
| 12.  | Condition code 0 due to normal completion (second-operand length originally nonzero, but stepped to zero). |
| 13.  | Condition code 3 due to partial completion (second-operand length still nonzero). |

Figure 7-218. Priority of Execution: KIMD and KLMD

**Programming Notes:**

1. Bit 56 of general register 0 is reserved for future extension and should be set to zero.
2. When condition code 3 is set, the second operand address and length in general registers $R_2$ and $R_2 + 1$, respectively, and the chaining-value in the parameter block are usually updated such that the program can simply branch back to the instruction to continue the operation.

For unusual situations, the CPU protects against endless reoccurrence for the no-progress case. Thus, the program can safely branch back to the instruction whenever condition code 3 is set with no exposure to an endless loop.

3. If the length of the second operand is nonzero initially and condition code 0 is set, the registers are updated in the same manner as for condition code 3; the chaining value in this case is such that additional operands can be processed as if they were part of the same chain.

4. The instructions COMPUTE INTERMEDIATE MESSAGE DIGEST and COMPUTE LAST MESSAGE DIGEST are designed to be used by a security service application programming interface (API). These APIs provide the program with means to compute the digest of messages of almost unlimited size, including those too large to fit in storage all at once. This is accomplished by permitting the program to pass the message to the API in parts. The following programming notes are described in terms of these APIs.

5. Before processing the first part of a message, the program must set the initial values for the chaining-value field. For SHA-1, the initial hexadecimal chaining values are listed as follows:

   \[
   \begin{align*}
   H_0 &= 67452301 \\
   H_1 &= EFCDAF89 \\
   H_2 &= 98BA5C13 \\
   H_3 &= 10325476 \\
   H_4 &= C3D25106 \\
   H_5 &= 9B05688C \\
   H_6 &= 1F83D9AB \\
   H_7 &= 5BE0CD19
   \end{align*}
   \]

For SHA-256, the initial hexadecimal chaining values are listed as follows:

   \[
   \begin{align*}
   H_0 &= 6A09E667 \\
   H_1 &= BB67AE85 \\
   H_2 &= 3C6EF372 \\
   H_3 &= A54FF53A \\
   H_4 &= 510E527F \\
   H_5 &= 9B05688C \\
   H_6 &= 1F83D9AB \\
   H_7 &= 5BE0CD19
   \end{align*}
   \]
For SHA-512, the initial hexadecimal chaining value are listed as follows:

- H0 = 6A09 E667 F3BC C908
- H1 = BB67 AE85 84CA A73B
- H2 = 3C6E F372 FE94 F82B
- H3 = A54F F53A 5F1D 36F1
- H4 = 510E 527F ADE6 82D1
- H5 = 9B05 688C 2B3E 6C1F
- H6 = 1F83 D9AB FB41 BD6B
- H7 = 5BE0 CD19 137E 2179

6. When computing a message digest, the program may not initially be aware of the total message-bit length; for example, for a message being read from an I/O device, the message-bit length may not be known until the final block is read. When computing a message digest for a message whose length is not known, or for a message where it is known that the last message block is not included in the calculation, COMPUTE INTERMEDIATE MESSAGE DIGEST may be used. When computing a message digest for a message that includes the last block, COMPUTE LAST MESSAGE DIGEST must be used.

7. When processing the last message part, the program must compute the length of the original message in bits and place this length value in the message-bit-length field of the parameter block, and use the COMPUTE LAST MESSAGE DIGEST instruction.

8. For SHA functions, the COMPUTE LAST MESSAGE DIGEST instruction does not require the second operand to be a multiple of the data block size. It first processes complete blocks, and may set condition code 3 before processing all blocks. After processing all complete blocks, it then performs the padding operation including the remaining portion of the second operand. This may require one or two iterations of the designated block digest algorithm.

9. For SHA functions, the COMPUTE LAST MESSAGE DIGEST instruction provides the SHA padding for messages that are a multiple of eight bits in length. If a SHA function is to be applied to a bit string which is not a multiple of eight bits, the program must perform the SHA padding and use the COMPUTE INTERMEDIATE MESSAGE DIGEST instruction.

10. The SHA-224 algorithm is the same as the SHA-256 algorithm, except that the initial chaining values and the final message digest lengths are different. The program may obtain the SHA-224 message digest using the SHA-256 functions with the following two actions:

   a. The following initial hexadecimal chaining values for SHA-224 are used:

      - H0 = C105 9ED8
      - H1 = 367C D507
      - H2 = 3070 DD17
      - H3 = F70E 5939
      - H4 = FFC0 0B31
      - H5 = 6858 1511
      - H6 = 64F9 8FA7
      - H7 = BEFA 4FA4

   b. The 224-bit message digest is obtained by truncating the final message digest to its leftmost 224 bits.

11. The SHA-384 algorithm is the same as the SHA-512 algorithm, except that the initial chaining values and the final message digest lengths are different. The program may obtain the SHA-384 message digest using the SHA-512 functions with the following two actions:

   a. The following initial hexadecimal chaining values for SHA-384 are used:

      - H0 = CBBB 9D5D C105 9ED8
      - H1 = 629A 292A 367C D507
      - H2 = 9159 015A 3070 DD17
      - H3 = 152F ECD8 F70E 5939
      - H4 = 6733 2667 FFC0 0B31
      - H5 = 8EB4 4A87 6858 1511
      - H6 = DB0C 2E0D 64F9 8FA7
      - H7 = 47B5 481D BEFA 4FA4

   b. The 384-bit message digest is obtained by truncating the final message digest to its leftmost 384 bits.

12. For the COMPUTE INTERMEDIATE MESSAGE DIGEST GHASH function, the hash subkey, H, is the result of encrypting a 128-bit zero using the AES encryption algorithm with a 128-bit, 192-bit, or 256-bit cryptographic key.

13. The following applies to the message-bit length (MBL) in the parameter block of COMPUTE LAST MESSAGE DIGEST:

   a. The MBL is completely independent of the second-operand length in general register R2.
b. Regardless of whether the instruction ends with condition code 0 or 3, the MBL is not decremented by the number of bytes processed.

c. In normal usage, the MBL is expected to be eight times the total size of the message in bytes. If the program supplies a MBL that is not a multiple of eight, the results will be algorithmically correct, but may not be usable in any practical application.

d. The secure-hash algorithm described in Reference [13.] on page xxviii allows for message-bit length that are not multiples of eight. COMPUTE LAST MESSAGE DIGEST requires the message-bit length to be a multiple of eight.

### COMPUTE MESSAGE AUTHENTICATION CODE

A function specified by the function code in general register 0 is performed.

Bits 16-23 of the instruction and the R₁ field are ignored.

Bit positions 57-63 of general register 0 contain the function code. Figure 7-219 shows the assigned function codes. All other function codes are unassigned. Bit 56 of general register 0 must be zero; otherwise, a specification exception is recognized. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.

The function codes for COMPUTE MESSAGE AUTHENTICATION CODE are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>KMAC-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>KMAC-DEA</td>
<td>16</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>KMAC-TDEA-128</td>
<td>24</td>
<td>8</td>
</tr>
<tr>
<td>3</td>
<td>KMAC-TDEA-192</td>
<td>32</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>KMAC-Encrypted-DEA</td>
<td>40</td>
<td>8</td>
</tr>
<tr>
<td>10</td>
<td>KMAC-Encrypted-TDEA-128</td>
<td>48</td>
<td>8</td>
</tr>
<tr>
<td>11</td>
<td>KMAC-Encrypted-TDEA-192</td>
<td>56</td>
<td>8</td>
</tr>
<tr>
<td>18</td>
<td>KMAC-AES-128</td>
<td>32</td>
<td>16</td>
</tr>
<tr>
<td>19</td>
<td>KMAC-AES-192</td>
<td>40</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>KMAC-AES-256</td>
<td>48</td>
<td>16</td>
</tr>
<tr>
<td>26</td>
<td>KMAC-Encrypted-AES-128</td>
<td>64</td>
<td>16</td>
</tr>
<tr>
<td>27</td>
<td>KMAC-Encrypted-AES-192</td>
<td>72</td>
<td>16</td>
</tr>
<tr>
<td>28</td>
<td>KMAC-Encrypted-AES-256</td>
<td>80</td>
<td>16</td>
</tr>
</tbody>
</table>

Explanation:

— Not applicable

Figure 7-219. Function Codes for COMPUTE MESSAGE AUTHENTICATION CODE

All other function codes are unassigned.

The query function provides the means of indicating the availability of the other functions. The contents of general registers R₂ and R₂ + 1 are ignored.

For all other functions, the second operand is processed as specified by the function code using an initial chaining value in the parameter block, and the result replaces the initial chaining value. The operation also uses a cryptographic key in the parameter block. The operation proceeds until the end of the second-operand location is reached or a CPU-determined number of bytes have been processed, whichever occurs first. The result is indicated in the condition code.

The R₂ field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.
The location of the leftmost byte of the second operand is specified by the contents of the \(R_2\) general register. The number of bytes in the second-operand location is specified in general register \(R_2 + 1\).

As part of the operation, the address in general register \(R_2\) is incremented by the number of bytes processed from the second operand, and the length in general register \(R_2 + 1\) is decremented by the same number. The formation and updating of the address and length is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general register \(R_2\) constitute the address of the second operand, and the contents of bit positions 0-39 are ignored; bits 40-63 of the updated address replace the corresponding bits in general register \(R_2\), carries out of bit position 40 of the updated address are ignored and, the contents of bit positions 32-39 of general register \(R_2\) are set to zeros. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register \(R_2\) constitute the address of the second operand, and the contents of bit positions 0-32 are ignored; bits 33-63 of the updated address replace the corresponding bits in general register \(R_2\), carries out of bit position 33 of the updated address are ignored, and the content of bit position 32 of general register \(R_2\) is set to zero. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register \(R_2\) constitute the address of the second operand; bits 0-63 of the updated address replace the contents of general register \(R_2\) and carries out of bit position 0 are ignored.

In both the 24-bit and the 31-bit addressing modes, the contents of bit positions 32-63 of general register \(R_2 + 1\) form a 32-bit unsigned binary integer which specifies the number of bytes in the second operand; and the updated value replaces the contents of bit positions 32-63 of general register \(R_2 + 1\). In the 64-bit addressing mode, the contents of bit positions 0-63 of general register \(R_2 + 1\) form a 64-bit unsigned binary integer which specifies the number of bytes in the second operand; and the updated value replaces the contents of general register \(R_2 + 1\).

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers \(R_2\) and \(R_2 + 1\), always remain unchanged.

Figure 7-220 on page 7-180 shows the contents of the general registers just described.

In the access-register mode, access registers 1 and \(R_2\) specify the address spaces containing the parameter block and second operand, respectively.

The result is obtained as if processing starts at the left end of the second operand and proceeds to the right, block by block. The operation is ended when all source bytes in the second operand have been processed (called normal completion), or when a CPU-determined number of blocks that is less than the length of the second operand have been processed (called partial completion). The CPU-determined number of blocks depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of blocks is usually nonzero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.

When the initial-chaining-value field overlaps any portion of the second operand, the result in the chaining-value field is unpredictable.

Normal completion occurs when the number of bytes in the second operand as specified in general register \(R_2 + 1\) have been processed.

When the operation ends due to normal completion, condition code 0 is set and the resulting value in \(R_2 + 1\) is zero. When the operation ends due to partial completion, condition code 3 is set and the resulting value in \(R_2 + 1\) is nonzero.

When the second-operand length is initially zero, the second operand and the parameter block are not accessed, general registers \(R_2\) and \(R_2 + 1\) are not changed, and condition code 0 is set.

A PER storage-alteration event may be recognized for the portion of the parameter block that is stored. A PER zero-address-detection event may be recognized for the second-operand location and for the parameter block. When PER events are detected for one or more locations, it is unpredictable which location is identified in the PER access identification (PAID) and PER ASCE ID (AI).

As observed by this CPU, other CPUs, and channel programs, references to the parameter block and storage operand may be multiple-access references,
accesses to these storage locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

For functions that perform a comparison of the encrypted cryptographic key with the wrapping-key verification-pattern register, it is unpredictable whether access exceptions and PER zero-address-detection events are recognized for the first and second operands when the comparison results in a mismatch.

Access exceptions may be reported for a larger portion of the second operand than is processed in a single execution of the instruction; however, access exceptions are not recognized for locations beyond the length of the second operand nor for locations more than 4K bytes beyond the current location being processed.

Symbols Used in Function Descriptions

The following symbols are used in the subsequent description of the COMPUTE MESSAGE AUTHENTICATION CODE functions. For data-encryption-algorithm (DEA) functions, the DEA-key-parity bit in each byte of the DEA key is ignored, and the operation proceeds normally, regardless of the DEA-key parity of the key. Further description of the data-encryption algorithm may be found in Reference [11.] on page xxviii. Further description of the AES standard may be found in Reference [12.] on page xxviii.

Figure 7-220. General Register Assignment for KMAC

Figure 7-221. Symbol For Bit-Wise Exclusive OR
**KMAC-Query (Function Code 0)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-220 on page 7-180.

The parameter block used for the function has the following format:

```
0 Status Word
```

**Figure 7-226. Parameter Block for KMAC-Query**

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the KMAC instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the KMAC-Query function completes; condition codes 1 and 3 are not applicable to this function.

**KMAC-DEA (Function Code 1)**

**KMAC-Encrypted-DEA (Function Code 9)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-220 on page 7-180.
The parameter block used for the KMAC-DEA function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key (K)</td>
</tr>
</tbody>
</table>

Figure 7-227. Parameter Block for KMAC-DEA

For the KMAC-DEA function, the initial chaining value is in byte offsets 0-7 of the parameter block and the cryptographic key is in byte offsets 8-15 of the parameter block.

The parameter block used for the KMAC-Encrypted-DEA function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>8</td>
<td>Encrypted Cryptographic Key (WK_d(K))</td>
</tr>
<tr>
<td>16</td>
<td>DEA Wrapping-Key</td>
</tr>
<tr>
<td>24</td>
<td>Verification Pattern (WK_dVP)</td>
</tr>
</tbody>
</table>

Figure 7-228. Parameter Block for KMAC-Encrypted-DEA

For the KMAC-Encrypted-DEA function, the contents of byte offsets 16-39 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-7 of the parameter block contain the initial chaining value, and the contents of byte offsets 8-15 of the parameter block are deciphered using the DEA wrapping key to obtain the 64-bit cryptographic key. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The description in the following paragraph applies to both functions.

The message authentication code for the 8-byte message blocks (M1, M2, ..., Mn) in operand 2 is computed using the DEA algorithm with the 64-bit cryptographic key and the 64-bit initial chaining value.

The message authentication code, also called the output chaining value (OCV), is stored in the initial-chaining-value field of the parameter block. The operation is shown in Figure 7-229.

![Figure 7-229. MAC Computation Using 64-bit DEA Key](image)

**KMAC-TDEA-128 (Function Code 2)**

**KMAC-Encrypted-TDEA-128 (Function Code 10)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-220 on page 7-180.

The parameter block used for the KMAC-TDEA-128 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initial Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key 1 (K1)</td>
</tr>
<tr>
<td>16</td>
<td>Cryptographic Key 2 (K2)</td>
</tr>
</tbody>
</table>

Figure 7-230. Parameter Block for KMAC-TDEA-128

For the KMAC-TDEA-128 function, the initial chaining value is in byte offsets 0-7 of the parameter block and the cryptographic key is in byte offsets 8-23 of the parameter block.
The parameter block used for the KMAC-Encrypted-TDEA-128 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>8</td>
<td>Encrypted Cryptographic Key (WKd(K))</td>
</tr>
<tr>
<td>16</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>

For the KMAC-Encrypted-TDEA-128 function, the contents of byte offsets 24-47 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-7 of the parameter block contain the initial chaining value, and the contents of byte offsets 8-23 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key, K. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The description in the following paragraph applies to both functions.

The message authentication code for the 8-byte message blocks (M1, M2, …, Mn) in operand 2 is computed using the TDEA algorithm with the two 64-bit cryptographic keys and the 64-bit initial chaining value.

The message authentication code, also called the output chaining value (OCV), is stored in the initial-chaining-value field of the parameter block. The operation is shown in Figure 7-232.

---

**KMAC-TDEA-192 (Function Code 3)**

**KMAC-Encrypted-TDEA-192 (Function Code 11)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-220 on page 7-180.

The parameter block used for the KMAC-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initial Chaining Value (CV)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key 1 (K1)</td>
</tr>
<tr>
<td>16</td>
<td>Cryptographic Key 2 (K2)</td>
</tr>
<tr>
<td>24</td>
<td>Cryptographic Key 3 (K3)</td>
</tr>
</tbody>
</table>

For the KMAC-TDEA-192 function, the initial chaining value is in byte offsets 0-7 of the parameter block and the cryptographic key is in byte offsets 8-31 of the parameter block.
The parameter block used for the KMAC-Encrypted-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Content</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>8</td>
<td>Encrypted Cryptographic Key</td>
</tr>
<tr>
<td>16</td>
<td>(WKd(K))</td>
</tr>
<tr>
<td>24</td>
<td>DEA Wrapping-Key Verification Pattern</td>
</tr>
<tr>
<td>32</td>
<td>(WKd(VP))</td>
</tr>
</tbody>
</table>

For the KMAC-Encrypted-TDEA-192 function, the contents of byte offsets 32-55 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-7 of the parameter block contain the initial chaining value, and the contents of byte offsets 8-31 of the parameter block are deciphered using the DEA wrapping key to obtain the 192-bit cryptographic key, K. (See the section, “Protection of Cryptographic Keys” on page 7-374, for details.)

The description in the following paragraph applies to both functions.

The message authentication code for the 8-byte message blocks (M1, M2, ..., Mn) in operand 2 is computed using the TDEA algorithm with the three 64-bit cryptographic keys and the 64-bit chaining value.

The message authentication code, also called the output chaining value (OCV), is stored in the initial-chaining-value field of the parameter block. The operation is shown in Figure 7-235.

KMAC-AES-128 (Function Code 18)

KMAC-Encrypted-AES-128 (Function Code 26)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-220 on page 7-180.

The parameter block used for the KMAC-AES-128 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Content</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key (K)</td>
</tr>
</tbody>
</table>

For the KMAC-AES-128 function, the initial-chaining value is in byte offsets 0-15 of the parameter block and the cryptographic key is in byte offsets 16-31 of the parameter block.
The parameter block used for the KMAC-Encrypted-AES-128 function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>8</td>
<td>Encrypted Cryptographic Key</td>
</tr>
<tr>
<td>16</td>
<td>(WK,&lt;K&gt;)</td>
</tr>
<tr>
<td>24</td>
<td>AES Wrapping-Key Verification Pattern</td>
</tr>
<tr>
<td>32</td>
<td></td>
</tr>
<tr>
<td>40</td>
<td></td>
</tr>
<tr>
<td>48</td>
<td></td>
</tr>
<tr>
<td>56</td>
<td></td>
</tr>
</tbody>
</table>
```

**Figure 7-237. Parameter Block for KMAC-Encrypted-AES-128**

For the KMAC-Encrypted-AES-128 function, the contents of byte offsets 32-63 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-15 of the parameter block contain the initial chaining value, and the contents of byte offsets 16-31 of the parameter block are deciphered using the AES wrapping key to obtain the 128-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The description in the following paragraph applies to both functions.

The message authentication code for the 16-byte message blocks (M1, M2, ..., Mn) in operand 2 is computed using the AES algorithm with the 128-bit cryptographic key and the 128-bit chaining value.

The message authentication code, also called the output chaining value (OCV), is stored in the initial-chaining-value field of the parameter block. The operation is shown in Figure 7-238.

**Figure 7-238. KMAC-AES-128**

**KMAC-AES-192 (Function Code 19)**

**KMAC-Encrypted-AES-192 (Function Code 27)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-220 on page 7-180.

The parameter block used for the KMAC-AES-192 function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>8</td>
<td>Cryptographic Key (K)</td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td></td>
</tr>
</tbody>
</table>
```

**Figure 7-239. Parameter Block for KMAC-AES-192**

For the KMAC-AES-192 function, the initial-chaining value is in byte offsets 0-15 of the parameter block and the cryptographic key is in byte offsets 16-39 of the parameter block.
The parameter block used for the KMAC-Encrypted-AES-192 function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Field Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-15</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>16-47</td>
<td>Encrypted Cryptographic Key (WKa(K))</td>
</tr>
<tr>
<td>48-57</td>
<td>AES Wrapping-Key Verification Pattern (WKaVP)</td>
</tr>
</tbody>
</table>
```

For the KMAC-Encrypted-AES-192 function, the contents of byte offsets 40-71 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-15 of the parameter block contain the initial chaining value, and the contents of byte offsets 16-39 of the parameter block are deciphered using the AES wrapping key to obtain the 192-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The description in the following paragraph applies to both functions.

The message authentication code for the 16-byte message blocks (M1, M2, ..., Mn) in operand 2 is computed using the AES algorithm with the 192-bit cryptographic key and the 128-bit chaining value.

The message authentication code, also called the output chaining value (OCV), is stored in the initial-chaining-value field of the parameter block. The operation is shown in Figure 7-241.

```
Figure 7-240. Parameter Block for KMAC-Encrypted-AES-192
```

**KMAC-AES-256 (Function Code 20)**

**KMAC-Encrypted-AES-256 (Function Code 28)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-220 on page 7-180.

The parameter block used for the KMAC-AES-256 function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Field Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-15</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>16-47</td>
<td>Cryptographic Key (K)</td>
</tr>
</tbody>
</table>
```

For the KMAC-AES-256 function, the initial-chaining value is in byte offsets 0-15 of the parameter block and the cryptographic key is in byte offsets 16-47 of the parameter block.

```
Figure 7-242. Parameter Block for KMAC-AES-256
```
The parameter block used for the KMAC-Encrypted-AES-256 function has the following format:

```
<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>16</th>
<th>24</th>
<th>32</th>
<th>40</th>
<th>48</th>
<th>56</th>
<th>64</th>
<th>72</th>
</tr>
</thead>
<tbody>
<tr>
<td>ICV</td>
<td>K</td>
<td>AES</td>
<td>XOR</td>
<td>AES</td>
<td>XOR</td>
<td>AES</td>
<td>XOR</td>
<td>AES</td>
<td>OCV</td>
</tr>
</tbody>
</table>
```

For the KMAC-Encrypted-AES-256 function, the contents of byte offsets 48-79 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the first-operand and parameter-block locations remain unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 0-15 of the parameter block contain the initial chaining value, and the contents of byte offsets 16-47 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The description in the following paragraph applies to both functions.

The message authentication code for the 16-byte message blocks (M1, M2, ..., Mn) in operand 2 is computed using the AES algorithm with the 256-bit cryptographic key and the 128-bit chaining value.

The message authentication code, also called the output chaining value (OCV), is stored in the initial-chaining-value field of the parameter block. The operation is shown in Figure 7-244.

Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unsigned or uninstalled function code.
3. The Rx field designates an odd-numbered register or general register 0.
4. The second-operand length is not a multiple of the data block size of the designated function (see Figure 7-219 on page 7-178 to determine the data block size for COMPUTE MESSAGE AUTHENTICATION CODE functions).

Resulting Condition Code:

0  Normal completion
1  Verification-pattern mismatch
2  --
3  Partial completion

Program Exceptions:

- Access (fetch, operand 2, cryptographic key, and wrapping-key verification pattern; fetch and store, chaining value)
- Operation (if the message-security assist is not installed)
- Specification
**Programming Notes:**

1. When condition code 3 is set, the second operand and address and length in general registers $R_x$ and $R_{x+1}$, respectively, and the initial-chaining value in the parameter block are usually updated such that the program can simply branch back to the instruction to continue the operation. For unusual situations, the CPU protects against endless reoccurrence for the no-progress case. Thus, the program can safely branch back to the instruction whenever condition code 3 is set with no exposure to an endless loop.

2. If the length of the second operand is nonzero initially and condition code 0 is set, the registers are updated in the same manner as for condition code 3; the initial chaining value in this case is such that additional operands can be processed as if they were part of the same chain.

3. Before processing the first part of a message, the program must set the initial values for the initial-chaining-value field. To comply with ANSI X9.9, ANSI X9.19, or Reference [15.] on page xxviii, the initial chaining value shall be set to all binary zeros.

**CONVERT TO BINARY**

For CONVERT TO BINARY (CVB, CVBY), the second operand occupies eight bytes in storage, and, for CONVERT TO BINARY (CVBG), the second operand occupies sixteen bytes in storage. The second operand has the format of signed-packed-decimal data, as described in Chapter 8, “Decimal Instructions.” It is checked for valid sign and digit codes, and a general-operand data exception is recognized when an invalid code is detected.

For CONVERT TO BINARY (CVB, CVBY), the result of the conversion is a 32-bit signed binary integer, which is placed in bit positions 32-63 of general register $R_1$. Bits 0-31 of the register remain unchanged. The maximum positive number that can be converted and still be contained in 32 bit positions is 2,147,483,647; the maximum negative number (the negative number with the greatest absolute value) that can be converted is -2,147,483,648.

For any decimal number outside this range, the operation is completed by placing the 32 rightmost bits of the binary result in the register, and a fixed-point-divide exception is recognized.
For CONVERT TO BINARY (CVBG), the result of the conversion is a 64-bit signed binary integer, which is placed in bit positions 0-63 of general register R1. The maximum positive number that can be converted and still be contained in a 64-bit register is 9,223,720,368,547,758,077; the maximum negative number (the negative number with the greatest absolute value) that can be converted is -9,223,720,368,547,758,080. For any decimal number outside this range, a fixed-point-divide exception is recognized, and the operation is suppressed.

The displacement for CVB is treated as a 12-bit unsigned binary integer. The displacement for CVBY and CVBG is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Data with DXC 0, general operand
- Fixed-point divide
- Operation (CVBY, if the long-displacement facility is not installed)
- Transaction constraint

**Programming Notes:**
1. An example of the use of the CONVERT TO BINARY instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. When the second operand is negative, the result is in two’s-complement notation.
3. The storage-operand references for CONVERT TO BINARY may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

### CONVERT TO DECIMAL

For CONVERT TO DECIMAL (CVD, CVDY), the first operand is treated as a 32-bit signed binary integer, and the result occupies eight bytes in storage. For CONVERT TO DECIMAL (CVDG), the first operand is treated as a 64-bit signed binary integer, and the result occupies sixteen bytes in storage.

The result is in the format for signed-packed-decimal data, as described in Chapter 8, “Decimal Instructions.” The rightmost four bits of the result represent the sign. A positive sign is encoded as 1100; a negative sign is encoded as 1101.

The displacement for CVD is treated as a 12-bit unsigned binary integer. The displacement for CVDY and CVDG is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Operation (CVDY, if the long-displacement facility is not installed)
- Transaction constraint

**Programming Notes:**
1. An example of the use of the CONVERT TO DECIMAL instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. For CVD and CVDY, the number to be converted is a 32-bit signed binary integer obtained from a general register. Since 15 decimal digits are available for the result, and the decimal equivalent of 31 bits requires at most 10 decimal digits, an overflow cannot occur. Similarly, for CVDG, 31 decimal digits are available, the decimal equivalent of 63 bits is at most 19 digits, and an overflow cannot occur.
3. The storage-operand references for CONVERT TO DECIMAL may be multiple-access refer-
CONVERT UTF-16 TO UTF-32

The two-byte UTF-16 (Unicode) characters of the second operand are converted to UTF-32 characters and placed at the first-operand location. The UTF-32 characters are four bytes. The operation proceeds until the end of the first or second operand is reached, a CPU-determined number of characters have been converted, or an invalid Unicode character is encountered, whichever occurs first. The result is indicated in the condition code.

The R1 and R2 fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and the second operand is designated by the contents of general registers R1 and R2, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the contents of bit positions 32-63 of general registers R1 + 1 and R2 + 1, respectively, and those contents are treated as 32-bit unsigned binary integers. In the 64-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the entire contents of general registers R1 + 1 and R2 + 1, respectively, and those contents are treated as 64-bit unsigned binary integers.

The handling of the addresses in general registers R1 and R2 is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R2 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The contents of the registers just described are shown in Figure 7-246 on page 7-191.
When the ETF3-enhancement facility is installed, the M3 field has the following format:

The bits of the M3 field are defined as follows:

- **Unassigned**: Bits 0-2 are unassigned and should contain zeros; otherwise, the program may not operate compatibly in the future.

- **Enhanced Well-Formedness-Checking (W)**: The W bit, bit 3 of the M3 field, controls whether enhanced well-formedness checking of the Unicode characters is performed. When the W bit is zero, enhanced checking is not performed. When the W bit is one, enhanced checking is performed, as described below.

When the ETF3-enhancement facility is not installed, the M3 field is ignored.

The characters of the second operand are selected one by one for conversion, proceeding left to right. The characters resulting from a conversion are placed at the first-operand location, proceeding left to right. The operation proceeds until the first-operand or second-operand location is exhausted or a CPU-determined number of second-operand characters have been converted.
To show the method of converting a UTF-16 character to a UTF-32 character, the bits of a Unicode character are identified by letters as follows:

<table>
<thead>
<tr>
<th>Unicode Character Bit Numbers</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>a</td>
<td>b</td>
<td>c</td>
<td>d</td>
<td>e</td>
<td>f</td>
<td>g</td>
<td>h</td>
<td>i</td>
<td>j</td>
<td>k</td>
<td>l</td>
<td>m</td>
<td>n</td>
<td>o</td>
<td>p</td>
</tr>
</tbody>
</table>

In the case of a Unicode surrogate pair, which is a character pair consisting of a character called a high surrogate followed by a character called a low surrogate, the bits are identified by letters as follows:

<table>
<thead>
<tr>
<th>Unicode High Surrogate Bit Numbers</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>a</td>
<td>b</td>
<td>c</td>
<td>d</td>
<td>e</td>
<td>f</td>
<td>g</td>
<td>h</td>
<td>i</td>
<td>j</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Unicode Low Surrogate Bit Numbers</th>
<th>16</th>
<th>17</th>
<th>18</th>
<th>19</th>
<th>20</th>
<th>21</th>
<th>22</th>
<th>23</th>
<th>24</th>
<th>25</th>
<th>26</th>
<th>27</th>
<th>28</th>
<th>29</th>
<th>30</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>k</td>
<td>l</td>
<td>m</td>
<td>n</td>
<td>o</td>
<td>p</td>
<td>q</td>
<td>r</td>
<td>s</td>
<td>t</td>
</tr>
</tbody>
</table>

Any Unicode character in the range 0000 to D7FF or DC00 to FFFF hex is converted to a four-byte UTF-32 character as follows:

<table>
<thead>
<tr>
<th>Unicode Character</th>
<th>abcdefghijklmnop</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-32 Character</td>
<td>0000000000000000abcdefghijklmnop</td>
</tr>
</tbody>
</table>

Any Unicode surrogate pair starting with a high surrogate in the range D800 to DBFF hex is converted to a four-byte UTF-32 character as follows:

<table>
<thead>
<tr>
<th>Unicode Characters</th>
<th>110110abcdefghijklmnop</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-32 Character</td>
<td>00000000000000000000000000000000abcdefghijklmnop</td>
</tr>
</tbody>
</table>

where $uvwxy = abcd + 1$

When the ETF3-enhancement facility is not installed, or when the W bit of the $M_3$ field is zero, the first six bits of the Unicode low surrogate are ignored. When the ETF3-enhancement facility is installed, and the W bit is one, the first six bits of the Unicode low surrogate must contain 110111 binary; otherwise, the Unicode low surrogate is invalid, and condition code 2 is set.

The second-operand location is considered exhausted when it does not contain at least two remaining bytes or at least four remaining bytes when the first two bytes are a Unicode high surrogate. The first-operand location is considered exhausted when it does not contain at least four remaining bytes.

When the second-operand location is exhausted, condition code 0 is set. When the first-operand location is exhausted, condition code 1 is set, except that condition code 0 is set if the second-operand location also is exhausted. When a CPU-determined number of characters have been converted, condition code 3 is set.

When the conditions for setting condition codes 1 and 2 are both met, condition code 2 is set.

When the operation is completed, the contents of register $R_2 + 1$ are decremented by the number of bytes converted, and the contents of general register $R_2$ are incremented by the same number. Also, the contents of general register $R_1 + 1$ are decremented by the number of bytes placed at the first-operand location, and the contents of general register $R_1$ are incremented by the same number. When general registers $R_1$ and $R_2$ are updated in the 24-bit or 31-bit addressing mode, bits 32-39 of them, in the 24-bit mode, or bit 32, in the 31-bit mode, may be set to zeros or may remain unchanged.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers $R_1$, $R_1 + 1$, $R_2$, and $R_2 + 1$, always remain unchanged.

When condition code 2 is set, general register $R_2$ contains the address of the invalid Unicode high surrogate that precedes the invalid low surrogate.

When condition code 3 is set, the registers have been updated so that the instruction, when reexecuted, resumes at the next byte locations to be processed.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

When the $R_1$ register is the same register as the $R_2$ register, the results are unpredictable.

When the second operand overlaps the first operand, the results are unpredictable.
Access exceptions for the portions of the operands to the right of the last byte processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the R field associated with that operand is odd.

**Resulting Condition Code:**
- 0  Entire second operand processed
- 1  End of first operand reached
- 2  Invalid Unicode low surrogate
- 3  CPU-determined number of characters converted

**Program Exceptions:**
- Access (fetch, operand 2; store, operand 1)
- Operation (if the extended-translation facility 3 is not installed)
- Specification
- Transaction constraint

**Programming Notes:**
1. When condition code 3 is set, the program can simply branch back to the instruction to continue the conversion. The program need not determine the number of first-operand or second-operand bytes that were processed.

2. The storage-operand references of CONVERT UTF-16 TO UTF-32 may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

3. The CONVERT UTF-16 TO UTF-32 instruction supports UTF-16 and UTF-32 characters only in the big-endian encoding.

4. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.
When the ETF3-enhancement facility is installed, the M3 field has the following format:

```
/ / / W
0 3
```

The bits of the M3 field are defined as follows:

- **Unassigned**: Bits 0-2 are unassigned and should contain zeros; otherwise, the program may not operate compatibly in the future.
- **Enhanced Well-Formedness-Checking (W)**: The W bit, bit 3 of the M3 field, controls whether enhanced well-formedness checking of the Unicode characters is performed. When the W bit is zero, enhanced checking is not performed. When the W bit is one, enhanced checking is performed, as described below.

When the ETF3-enhancement facility is not installed, the M3 field is ignored.

The characters of the second operand are selected one by one for conversion, proceeding left to right. The bytes resulting from a conversion are placed at the first-operand location, proceeding left to right. The operation proceeds until the first-operand or second-operand location is exhausted, a CPU-determined number of second-operand characters have been converted, or an invalid Unicode character is encountered in the second operand.
To show the method of converting a Unicode character to a UTF-8 character, the bits of a Unicode character are identified by letters as follows:

<table>
<thead>
<tr>
<th>Unicode Character Bit Numbers</th>
<th>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>a b c d e f g h i j k l m n o p</td>
</tr>
</tbody>
</table>

In the case of a Unicode surrogate pair, which is a character pair consisting of a character called a high surrogate followed by a character called a low surrogate, the bits are identified by letters as follows:

<table>
<thead>
<tr>
<th>Unicode High Surrogate Bit Numbers</th>
<th>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>110110a b c d e f g h i j k l m n o p t</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Unicode Low Surrogate Bit Numbers</th>
<th>16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>110111a b c d e f g h i j k l m n o p q r s t</td>
</tr>
</tbody>
</table>

Any Unicode character in the range 0000 to 007F hex is converted to a one-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>Unicode Character</th>
<th>000000000</th>
<th>j k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-8 Character</td>
<td>0 j k l m n o p</td>
<td></td>
</tr>
</tbody>
</table>

Any Unicode character in the range 0080 to 07FF hex is converted to a two-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>Unicode Character</th>
<th>00000f g h i</th>
<th>j k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-8 Character</td>
<td>110f g h i j k l m n o p</td>
<td></td>
</tr>
</tbody>
</table>

Any Unicode character in the range 0800 to D7FF or DC00 to FFFF hex is converted to a three-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>Unicode Character</th>
<th>abcdef g h i j k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-8 Character</td>
<td>1110abcd10ef g h i j k l m n o p</td>
</tr>
</tbody>
</table>

Any Unicode surrogate pair starting with a high surrogate in the range D800 to DBFF hex is converted to a four-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>Unicode Characters</th>
<th>110110abc d e f g h i 110111k l m n o p q r s t</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-8 Character</td>
<td>11110uvw10xy e f g h i j k l m n o p q r s t</td>
</tr>
</tbody>
</table>

When the ETF3-enhancement facility is not installed, or when the W bit of the M_3 field is zero, the first six bits of the Unicode low surrogate are ignored. When the ETF3-enhancement facility is installed, and the W bit is one, the first six bits of the Unicode low surrogate must contain 110111 binary; otherwise, the Unicode low surrogate is invalid, and condition code 2 is set.

The second-operand location is considered exhausted when it does not contain at least two remaining bytes or at least four remaining bytes when the first two bytes are a Unicode high surrogate. The first-operand location is considered exhausted when it does not contain at least the one, two, three, or four remaining bytes required to contain the UTF-8 character resulting from the conversion of the next second-operand character or surrogate pair.

When the second-operand location is exhausted, condition code 0 is set. When the first-operand location is exhausted, condition code 1 is set, except that condition code 0 is set if the second-operand location also is exhausted. When a CPU-determined number of characters have been converted, condition code 3 is set.

When the conditions for setting condition codes 1 and 2 are both met, condition code 2 is set.

When the operation is completed, the contents of general register R_x + 1 are decremented by the number of bytes converted, and the contents of general register R_y are incremented by the same number. Also, the contents of general register R_1 + 1 are decremented by the number of bytes placed at the first-operand location, and the contents of general register R_y are incremented by the same number. When general registers R_1 and R_2 are updated in the 24-bit or 31-bit addressing mode, bits 32-39 of them, in the 24-bit mode, or bit 32, in the 31-bit mode, may be set to zeros or may remain unchanged.
In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers \( R_1 \), \( R_1 + 1 \), \( R_2 \), and \( R_2 + 1 \) always remain unchanged.

When condition code 2 is set, general register \( R_2 \) contains the address of the invalid Unicode high surrogate that precedes the invalid low surrogate.

When condition code 3 is set, the registers have been updated so that the instruction, when reexecuted, resumes at the next byte locations to be processed.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

When the \( R_1 \) register is the same register as the \( R_2 \) register, the results are unpredictable.

When the second operand overlaps the first operand, the results are unpredictable.

Access exceptions for the portions of the operands to the right of the last byte processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the \( R \) field associated with that operand is odd.

**Resulting Condition Code:**

0  Entire second operand processed  
1  End of first operand reached  
2  Invalid Unicode low surrogate  
3  CPU-determined number of characters converted

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)  
- Specification  
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the program can simply branch back to the instruction to continue the conversion. The program need not determine the number of first-operand or second-operand bytes that were processed.

2. The storage-operand references of CONVERT UNICODE TO UTF-8 may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

3. The CONVERT UTF-16 TO UTF-8 (CONVERT UNICODE TO UTF-8) instruction supports UTF-16 characters only in the big-endian encoding.

4. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

**CONVERT UTF-32 TO UTF-16**

CU42 \( R_1, R_2 \) \( [\text{RRE}] \)

\[
\begin{array}{c|c|c|c|c}
0 & 16 & 24 & 28 & 31 \\
\hline
\text{B9B3} & / & / & / & / \\
\hline
R_1 & R_2 \\
\end{array}
\]

The four-byte UTF-32 characters of the second operand are converted to two-byte UTF-16 characters and placed at the first-operand location. The operation proceeds until the end of the first or second operand is reached, a CPU-determined number of characters have been converted, or an invalid UTF-32 character is encountered, whichever occurs first. The result is indicated in the condition code.

The \( R_1 \) and \( R_2 \) fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and the second operand is designated by the contents of general registers \( R_1 \) and \( R_2 \), respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the contents of bit positions 32-63 of general registers \( R_1 + 1 \) and \( R_2 + 1 \), respectively, and those contents are treated as 32-bit unsigned binary integers. In the 64-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the entire contents of general registers \( R_1 + 1 \) and \( R_2 + 1 \), respectively, and those contents are treated as 64-bit unsigned binary integers.
The handling of the addresses in general registers $R_1$ and $R_2$ is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers $R_1$ and $R_2$ constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The contents of the registers just described are shown in Figure 7-248 on page 7-197.

The characters of the second operand are selected one by one for conversion, proceeding left to right. The bytes resulting from a conversion are placed at the first-operand location, proceeding left to right. The operation proceeds until the first-operand or second-operand location is exhausted, a CPU-determined number of second-operand characters have been converted, or an invalid UTF-32 character is encountered in the second operand.

To show the method of converting a UTF-32 character to a UTF-16 character, the bits of a UTF-32 character in the range 00000000 to 0000D7FF or
The bits of a UTF-32 character in the range 0000 to D7FF or DC00 to FFFF hex are identified by letters as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

The bits of a UTF-32 character in the range 00010000 to 0010FFFF hex are identified by letters as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31</td>
<td>a b c d e f g h i j k l m n o p</td>
</tr>
</tbody>
</table>

When a CPU-determined number of characters have been processed, condition code 3 is set.

When the contents of the next UTF-32 character are in the range 0000D800 to 0000DBFF or 00110000 to FFFFFFFF hex, the character is invalid, and condition code 2 is set.

When the conditions for setting condition codes 1 and 2 are both met, condition code 2 is set.

When the operation is completed, the contents of general register R2 + 1 are decremented by the number of bytes converted, and the contents of general register R2 are incremented by the same number. Also, the contents of general register R1 + 1 are decremented by the number of bytes placed at the first-operand location, and the contents of general register R1 are incremented by the same number. When
general registers R₁ and R₂ are updated in the 24-bit or 31-bit addressing mode, bits 32-39 of them, in the 24-bit mode, or bit 32, in the 31-bit mode, may be set to zeros or may remain unchanged.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers R₁, R₁ + 1, R₂, and R₂ + 1, always remain unchanged.

When condition code 2 is set, general register R₂ contains the address of the invalid UTF-32 character.

When condition code 3 is set, the registers have been updated so that the instruction, when reexecuted, resumes at the next byte locations to be processed.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

When the R₁ register is the same register as the R₂ register, the results are unpredictable.

When the second operand overlaps the first operand, the results are unpredictable.

Access exceptions for the portions of the operands to the right of the last byte processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the R field associated with that operand is odd.

**Resulting Condition Code:**

0  Entire second operand processed
1  End of first operand reached
2  Invalid UTF-32 character
3  CPU-determined number of characters processed

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Operation (if the extended-translation facility 3 is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the program can simply branch back to the instruction to continue the conversion. The program need not determine the number of first-operand or second-operand bytes that were processed.

2. The storage-operand references of CONVERT UTF-32 TO UTF-16 may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

3. The CONVERT UTF-32 TO UTF-16 instruction supports UTF-16 and UTF-32 characters only in the big-endian encoding.

4. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

**CONVERT UTF-32 TO UTF-8**

CU41  R₁R₂  [RRE]

```
<table>
<thead>
<tr>
<th>0</th>
<th>16</th>
<th>24</th>
<th>28</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B9B2'</td>
<td>/ / / / / / / R₁</td>
<td>R₂</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

The four-byte UTF-32 characters of the second operand are converted to UTF-8 characters and placed at the first-operand location. The UTF-8 characters are one, two, three, or four bytes, depending on the Unicode characters that are converted. The operation proceeds until the end of the first or second operand is reached or a CPU-determined number of characters have been converted, whichever occurs first. The result is indicated in the condition code.

The R₁ and R₂ fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and the second operand is designated by the contents of general registers R₁ and R₂, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the contents of bit positions 32-63 of general registers R₁ + 1 and R₂ + 1, respec-
tively, and those contents are treated as 32-bit unsigned binary integers. In the 64-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the entire contents of general registers \( R_1 + 1 \) and \( R_2 + 1 \), respectively, and those contents are treated as 64-bit unsigned binary integers.

The handling of the addresses in general registers \( R_1 \) and \( R_2 \) is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers \( R_1 \) and \( R_2 \) constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The contents of the registers just described are shown in Figure 7-249 on page 7-200.

![Figure 7-249. Register Contents for CONVERT UTF-32 TO UTF-8](image-url)

The characters of the second operand are selected one by one for conversion, proceeding left to right. The bytes resulting from a conversion are placed at the first-operand location, proceeding left to right. The operation proceeds until the first-operand or second-operand location is exhausted or a CPU-determined number of second-operand characters have been converted.

To show the method of converting a UTF-32 character to a UTF-8 character, the bits of a UTF-32 character in the range 00000000 to 0000D7FF or...
0000DC00 to 0000FFFF hex are identified by letters as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7</td>
<td>0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

The bits of a UTF-32 character in the range 00010000 to 0010FFFF hex (UTF-16 surrogate pair) are identified by letters as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31</td>
<td>a b c d e f g h i j k l m n o p</td>
</tr>
</tbody>
</table>

Any UTF-32 character in the range 00000000 to 000007FF hex is converted to a one-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15</td>
<td>0 0 0 0 0 0 0 0 0 u v w x y</td>
</tr>
</tbody>
</table>

Any UTF-32 character in the range 00000080 to 000007FF hex is converted to a two-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31</td>
<td>e f g h i j k l m n o p q r s t</td>
</tr>
</tbody>
</table>

Any UTF-32 character in the range 00000000 to 000007FF hex is converted to a three-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7</td>
<td>0 0 0 0 0 0 0 0 0 j k l m n o p</td>
</tr>
</tbody>
</table>

Any UTF-32 character in the range 00000000 to 00000000 or 0000D7FF or 0000DC00 to 0000FFFF hex is converted to a three-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7</td>
<td>0 0 0 0 0 0 0 a b c d e f g h i j k l m n o p</td>
</tr>
</tbody>
</table>

Any UTF-32 character in the range 00001000 to 0010FFFF hex is converted to a four-byte UTF-8 character as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7</td>
<td>0 0 0 0 0 0 0 u v w x y e f g h i j k l m n o p q r s t</td>
</tr>
</tbody>
</table>

The second-operand location is considered exhausted when it does not contain at least four remaining bytes. The first-operand location is considered exhausted when it does not contain at least the one, two, three, or four remaining bytes required to contain the UTF-8 character resulting from the conversion of the next second-operand character or surrogate pair.

When the second-operand location is exhausted, condition code 0 is set. When the first-operand location is exhausted, condition code 1 is set, except that condition code 0 is set if the second-operand location also is exhausted. When a CPU-determined number of characters have been converted, condition code 3 is set.

When the contents of the next UTF-32 character are in the range 0000D800 to 0000DBFF or 00110000 to FFFFFFFF hex, the character is invalid, and condition code 2 is set.

When the conditions for setting condition codes 1 and 2 are both met, condition code 2 is set.

When the operation is completed, the contents of general register R2 + 1 are decremented by the number of bytes converted, and the contents of general register R2 are incremented by the same number. Also, the contents of general register R1 + 1 are decremented by the number of bytes placed at the first-operand location, and the contents of general register R1 are incremented by the same number. When general registers R1 and R2 are updated in the 24-bit or 31-bit addressing mode, bits 32-39 of them, in the 24-bit mode, or bit 32, in the 31-bit mode, may be set to zeros or may remain unchanged.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers R1, R1 + 1, R2, and R2 + 1, always remain unchanged.

When condition code 2 is set, general register R2 contains the address of the invalid UTF-32 character.
When condition code 3 is set, the registers have been updated so that the instruction, when reexecuted, resumes at the next byte locations to be processed.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

When the $R_1$ register is the same register as the $R_2$ register, the results are unpredictable.

When the second operand overlaps the first operand, the results are unpredictable.

Access exceptions for the portions of the operands to the right of the last byte processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the $R$ field associated with that operand is odd.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Entire second operand processed</td>
</tr>
<tr>
<td>1</td>
<td>End of first operand reached</td>
</tr>
<tr>
<td>2</td>
<td>Invalid UTF-32 character</td>
</tr>
<tr>
<td>3</td>
<td>CPU-determined number of characters converted</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Operation (if the extended-translation facility 3 is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the program can simply branch back to the instruction to continue the conversion. The program need not determine the number of first-operand or second-operand bytes that were processed.

2. The storage-operand references of CONVERT UTF-32 TO UTF-8 may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

3. The CONVERT UTF-32 TO UTF-8 instruction supports UTF-32 characters only in the big-endian encoding.

4. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

**CONVERT UTF-8 TO UTF-16**

The one-, two-, three-, or four-byte UTF-8 characters of the second operand are converted to two-byte Unicode characters and placed at the first-operand location. The operation proceeds until the end of the first or second operand is reached, a CPU-determined number of characters have been converted, or an invalid UTF-8 character is encountered, whichever occurs first. The result is indicated in the condition code.

The $R_1$ and $R_2$ fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and the second operand is designated by the contents of general registers $R_1$ and $R_2$, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the contents of bit positions 32-63 of general registers $R_1 + 1$ and $R_2 + 1$, respectively, and those contents are treated as 32-bit unsigned binary integers. In the 64-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the entire contents of general registers $R_1 + 1$ and $R_2 + 1$, respectively, and those contents are treated as 64-bit unsigned binary integers.
The handling of the addresses in general registers $R_1$ and $R_2$ is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers $R_1$ and $R_2$ constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The contents of the registers just described are shown in Figure 7-250 on page 7-203.

When the ETF3-enhancement facility is installed, the $M_3$ field has the following format:

$$
\begin{array}{c}
\text{Unassigned:} \\
\text{Bits 0-2 are unassigned and should contain zeros; otherwise, the program may not operate compatibly in the future.} \\
\text{Enhanced Well-Formedness-Checking (W):} \\
\text{The W bit, bit 3 of the $M_3$ field, controls whether enhanced well-formedness checking of the UTF-8 characters is performed. When the W bit is zero, enhanced checking is not performed. When the W bit is one, enhanced checking is performed, as described below.}
\end{array}
$$

![Figure 7-250. Register Contents for CONVERT UTF-8 TO UTF-16](image-url)
When the ETF3-enhancement facility is not installed, the M₃ field is ignored.

The characters of the second operand are selected one by one for conversion, proceeding left to right. The bytes resulting from a conversion are placed at the first-operand location, proceeding left to right. The operation proceeds until the first-operand or second-operand location is exhausted, a CPU-determined number of second-operand characters have been converted, or an invalid UTF-8 character is encountered in the second operand.

To show the method of converting a UTF-8 character to a Unicode character, the bits of a Unicode character are identified by letters as follows:

<table>
<thead>
<tr>
<th>Unicode Character Bit Numbers</th>
<th>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>a b c d e f g h i j k l m n o p</td>
</tr>
</tbody>
</table>

In the case of a Unicode surrogate pair, which is a character pair consisting of a character called a high surrogate followed by a character called a low surrogate, the bits are identified by letters as follows:

<table>
<thead>
<tr>
<th>Unicode High Surrogate Bit Numbers</th>
<th>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>1 1 0 1 1 0 a b c d e f g h i j</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Unicode Low Surrogate Bit Numbers</th>
<th>16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identifying Bit Letters</td>
<td>1 1 0 1 1 1 k l m n o p q r s t</td>
</tr>
</tbody>
</table>

Conversion of a UTF-8 character to a Unicode character is as follows:

1. When the contents of the first byte of a UTF-8 character are in the range 00 to 7F hex, the character is a one-byte character, and it is converted to a two-byte Unicode character as follows:

<table>
<thead>
<tr>
<th>UTF-8 Character</th>
<th>0 j k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>Unicode Character</td>
<td>0 0 0 0 0 0 0 0 j k l m n o p</td>
</tr>
</tbody>
</table>

2. When the contents of the first byte of the UTF-8 character are in the range 80 to BF hex, the character is invalid. When the ETF3-enhancement facility is installed, the W bit of the M₃ field is one, and the contents of the first byte of the UTF-8 character are in the range C0 to C1 hex, the character is also invalid.

3. When the ETF3-enhancement facility is not installed or the W bit of the M₃ field is zero, and the contents of the first byte of the UTF-8 character are in the range of C0 to DF hex; or when the ETF3-enhancement facility is installed, the W bit is one, and the contents of the first byte of the UTF-8 character are in the range of C2 to DF hex; the character is a two-byte character, and it is converted to a two-byte Unicode character as follows:

<table>
<thead>
<tr>
<th>UTF-8 Character</th>
<th>110 f g h i j 10 k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>Unicode Character</td>
<td>0 0 0 0 0 f g h i j k l m n o p</td>
</tr>
</tbody>
</table>

When the ETF3-enhancement facility is not installed or when the W bit of the M₃ field is zero, the first two bits in the second byte of the UTF-8 character are ignored. When the ETF3-enhancement facility is installed and the W bit of the M₃ field is one, the contents of the second byte of the UTF-8 character must be in the range 80 to BF; otherwise the character is invalid.

4. When the contents of the first byte of a UTF-8 character are in the range E0 to EF hex, the character is a three-byte character, and it is converted to a two-byte Unicode character as follows:

<table>
<thead>
<tr>
<th>UTF-8 Character</th>
<th>1110 a b c d 0 e f g h i j 10 k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>Unicode Character</td>
<td>a b c d e f g h i j k l m n o p</td>
</tr>
</tbody>
</table>

When the ETF3-enhancement facility is not installed or when the W bit of the M₃ field is zero, the first two bits in the second and third bytes of the UTF-8 character are ignored.

When the ETF3-enhancement facility is installed and the W bit of the M₃ field is one, the contents of the second and third bytes of the UTF-8 character must be as follows:

- When the first byte is E0 hex, the second and third bytes must be in the ranges A0 to BF and 80 to BF, respectively.
- When the first byte is in the range E1 to EC hex or EE to EF, the second and third bytes must both be in the range 80 to BF hex.
- When the first byte is ED hex, the second and third bytes must be in the ranges 80 to 9F and 80 to BF, respectively.
Otherwise, the character is invalid.

5. When the ETF3-enhancement facility is not installed or the W bit of the M3 field is zero, and the contents of the first byte of the UTF-8 character are in the range of F0 to F7 hex; or when the ETF3-enhancement facility is installed, the W bit is one, and the contents of the first byte of the UTF-8 character are in the range of F0 to F4 hex; the character is a four-byte character, and it is converted to two two-byte Unicode characters (a surrogate pair) as follows:

<table>
<thead>
<tr>
<th>UTF-8 Character</th>
<th>11110uvw10xyefgh10ijklmn10opqrstuvwxyz</th>
</tr>
</thead>
<tbody>
<tr>
<td>Unicode Characters</td>
<td>110110abcde f gh i j 110111k lmnopqrst</td>
</tr>
</tbody>
</table>

where zabcd = uvwxyz - 1

When the ETF3-enhancement facility is not installed or when the W bit of the M3 field is zero, the first two bits in the second, third, and fourth bytes of the UTF-8 character are ignored, and the high order bit (z) produced by the subtract operation should be zero but is ignored.

When the ETF3-enhancement facility is installed and the W bit of the M3 field is one, the contents of the second, third, and fourth bytes of the UTF-8 character must be as follows:

- When the first byte is F0 hex, the second, third, and fourth bytes must be in the ranges 90 to BF, 80 to BF, and 80 to BF, respectively.
- When the first byte is in the range F1 to F3, the second, third, and fourth bytes must all be in the range 80 to BF hex.
- When the first byte is F4 hex, the second, third, and fourth bytes must be in the ranges 80 to 8F, 80 to BF, and 80 to BF, respectively.

Otherwise, the character is invalid.

6. When the ETF3-enhancement facility is installed, the W bit of the M3 field is one, and the contents of the first byte of the UTF-8 character are in the range of F5 to F7 hex, the character is invalid.

7. When the contents of the first byte of the UTF-8 character are in the range of F8-FF, the character is invalid.

If an invalid character is encountered, condition code 2 is set, and general register R2 contains the address of the first byte of the invalid UTF-8 character.

The second-operand location is considered exhausted when it does not contain at least one remaining byte or when it does not contain at least the two, three, or four remaining bytes required to contain the two-, three-, or four-byte UTF-8 character indicated by the contents of the first remaining byte. The first-operand location is considered exhausted when it does not contain at least two remaining bytes or at least four remaining bytes in the case when a four byte UTF-8 character is to be converted.

When the second-operand location is exhausted, condition code 0 is set. When the first-operand location is exhausted, condition code 1 is set, except that condition code 0 is set if the second-operand location also is exhausted. When a CPU-determined number of characters have been processed, condition code 3 is set.

When the conditions for setting condition codes 1 and 2 are both met, condition code 2 is set.

When the operation is completed, the contents of general register R2 + 1 are decremented by the number of bytes converted, and the contents of general register R2 are incremented by the same number. Also, the contents of general register R1 + 1 are decremented by the number of bytes placed at the first-operand location, and the contents of general register R1 are incremented by the same number. When general registers R1 and R2 are updated in the 24-bit or 31-bit addressing mode, bits 32-39 of them, in the 24-bit mode, or bit 32, in the 31-bit mode, may be set to zeros or may remain unchanged.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers R1, R1 + 1, R2, and R2 + 1, always remain unchanged.

When condition code 2 is set, general register R2 contains the address of the invalid UTF-8 character.

When condition code 3 is set, the registers have been updated so that the instruction, when reexecuted, resumes at the next byte locations to be processed.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.
When the \( R_1 \) register is the same register as the \( R_2 \) register, the results are unpredictable.

When the second operand overlaps the first operand, the results are unpredictable.

Access exceptions for the portions of the operands to the right of the last byte processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the \( R \) field associated with that operand is odd.

**Resulting Condition Code:**

0  Entire second operand processed
1  End of first operand reached
2  Invalid UTF-8 character
3  CPU-determined number of characters processed

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Specification
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the program can simply branch back to the instruction to continue the conversion. The program need not determine the number of first-operand or second-operand bytes that were processed.

2. When the ETF3-enhancement facility is not installed, or when the W bit of the \( M_3 \) operand is zero, bits 0 and 1 of the continuation bytes of multiple-byte UTF-8 characters are not checked in order to improve the performance of the conversion. Therefore, invalid continuation bytes are not detected.

3. The storage-operand references of CONVERT UTF-8 TO UTF-16 may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

4. The CONVERT UTF-8 TO UTF-16 (CONVERT UTF-8 TO UNICODE) instruction supports UTF-16 characters only in the big-endian encoding.

5. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

**CONVERT UTF-8 TO UTF-32**

\[
\text{CU14} \quad R_{1\, R[3\, M_3]} \quad [\text{RRF-c}]
\]

<table>
<thead>
<tr>
<th>0</th>
<th>1</th>
<th>16</th>
<th>20</th>
<th>24</th>
<th>28</th>
<th>30</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B9B0'</td>
<td>( M_3 )</td>
<td>/ / /</td>
<td>( R_1 )</td>
<td>( R_2 )</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The one-, two-, three-, or four-byte UTF-8 characters of the second operand are converted to four-byte UTF-32 characters and placed at the first-operand location. The operation proceeds until the end of the first or second operand is reached, a CPU-determined number of characters have been converted, or an invalid UTF-8 character is encountered, whichever occurs first. The result is indicated in the condition code.

The \( R_1 \) and \( R_2 \) fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and the second operand is designated by the contents of general registers \( R_1 \) and \( R_2 \), respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the contents of bit positions 32-63 of general registers \( R_1 + 1 \) and \( R_2 + 1 \), respectively, and those contents are treated as 32-bit unsigned binary integers. In the 64-bit addressing mode, the number of bytes in the first-operand and second-operand locations is specified by the entire contents of general registers \( R_1 + 1 \) and \( R_2 + 1 \), respectively, and those contents are treated as 64-bit unsigned binary integers.

The handling of the addresses in general registers \( R_1 \) and \( R_2 \) is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers \( R_1 \) and \( R_2 \) constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions...
0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address. The contents of the registers just described are shown in Figure 7-251 on page 7-207.

24-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Second-Operand Length</td>
</tr>
</tbody>
</table>

31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Second-Operand Length</td>
</tr>
</tbody>
</table>

64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>First-Operand Address</td>
</tr>
<tr>
<td>R1 + 1</td>
<td>First-Operand Length</td>
</tr>
<tr>
<td>R2</td>
<td>Second-Operand Address</td>
</tr>
<tr>
<td>R2 + 1</td>
<td>Second-Operand Length</td>
</tr>
</tbody>
</table>

Figure 7-251. Register Contents for CONVERT UTF-8 TO UTF32

When the ETF3-enhancement facility is installed, the M3 field has the following format:

```
/ / / W
0 3
```

The bits of the M3 field are defined as follows:

- **Unassigned**: Bits 0-2 are unassigned and should contain zeros; otherwise, the program may not operate compatibly in the future.

- **Enhanced Well-Formedness-Checking (W)**: The W bit, bit 3 of the M3 field, controls whether enhanced well-formedness checking of the UTF-8 characters is performed. When the W bit is zero, enhanced checking is not performed. When the W bit is one, enhanced checking is performed, as described below.

When the ETF3-enhancement facility is not installed, the M3 field is ignored.

The characters of the second operand are selected one by one for conversion, proceeding left to right. The bytes resulting from a conversion are placed at the first-operand location, proceeding left to right. The operation proceeds until the first-operand or second-operand location is exhausted, a CPU-determined number of second-operand characters have
been converted, or an invalid UTF-8 character is encountered in the second operand.

To show the method of converting a UTF-8 character to a UTF-32 character, the bits of a UTF-32 character in the range 00000000 to 0000D7FF or 0000DC00 to 0000FFFF hex are identified by letters as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

The bits of a UTF-32 character in the range 00010000 to 00010000 hex (UTF-16 surrogate pair) are identified by letters as follows:

<table>
<thead>
<tr>
<th>UTF-32 Character</th>
<th>Bit Numbers</th>
<th>Identifying Bit Letters</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31</td>
<td>a b c d e f g h i j k l m n o p</td>
</tr>
</tbody>
</table>

Conversion of a UTF-8 character to a UTF-32 character is as follows:

1. When the contents of the first byte of a UTF-8 character are in the range 00 to 7F hex, the character is a one-byte character, and it is converted to a four-byte UTF-32 character as follows:

<table>
<thead>
<tr>
<th>UTF-8 Character</th>
<th>j k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-32 Character</td>
<td>0000000000000000</td>
</tr>
</tbody>
</table>

When the ETF3-enhancement facility is not installed or the W bit of the M3 field is zero, the first two bits in the second byte of the UTF-8 character are ignored. When the ETF3-enhancement facility is installed and the W bit of the M3 field is one, the contents of the second byte of the UTF-8 character must be in the range 80 to BF; otherwise the character is invalid.

3. When the ETF3-enhancement facility is not installed or the W bit of the M3 field is zero, and the contents of the first byte of the UTF-8 character are in the range C0 to DF hex; or when the ETF3-enhancement facility is installed, the W bit is one, and the contents of the first byte of the UTF-8 character are in the range C2 to DF hex; the character is a two-byte character, and it is converted to a four-byte UTF-32 character as follows:

<table>
<thead>
<tr>
<th>UTF-8 Character</th>
<th>110 f g h i j 10 k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-32 Character</td>
<td>000000000000000000000000000000000</td>
</tr>
</tbody>
</table>

When the ETF3-enhancement facility is not installed or when the W bit of the M3 field is zero, the first two bits in the second byte of the UTF-8 character are ignored. When the ETF3-enhancement facility is installed and the W bit of the M3 field is one, the contents of the second and third bytes of the UTF-8 character must be in the range 80 to BF; otherwise the character is invalid.

4. When the contents of the first byte of a UTF-8 character are in the range E0 to EF hex, the character is a three-byte character, and it is converted to a four-byte UTF-32 character as follows:

<table>
<thead>
<tr>
<th>UTF-8 Character</th>
<th>1110 a b c d e f g h i j k l m n o p</th>
</tr>
</thead>
<tbody>
<tr>
<td>UTF-32 Character</td>
<td>000000000000000000000000000000000</td>
</tr>
</tbody>
</table>

When the ETF3-enhancement facility is not installed or when the W bit of the M3 field is zero, the first two bits in the second and third bytes of the UTF-8 character are ignored. When the ETF3-enhancement facility is installed and the W bit of the M3 field is one, the contents of the second and third bytes of the UTF-8 character must be as follows:

- When the first byte is E0 hex, the second and third bytes must be in the ranges A0 to BF and 80 to BF, respectively.
- When the first byte is in the range E1 to EC hex or EE to EF, the second and third bytes must both be in the range 80 to BF hex.
- When the first byte is ED hex, the second and third bytes must be in the ranges 80 to 9F and 80 to BF, respectively.
Otherwise, the character is invalid.

5. When the ETF3-enhancement facility is not installed or the W bit of the M3 field is zero, and the contents of the first byte of the UTF-8 character are in the range of F0 to F7 hex; or when the ETF3-enhancement facility is installed, the W bit is one, and the contents of the first byte of the UTF-8 character are in the range of F0 to F4 hex; the character is a four-byte character, and it is converted to a four-byte UTF-32 character (a surrogate pair) as follows:

| UTF-8 Character | 11110uvw10xyefgh10ijklmn10opqrs | UTF-32 Character | 00000000000uvwxyefghijklmnopqrs |

When the ETF3-enhancement facility is not installed or when the W bit of the M3 field is zero, the first two bits in the second, third, and fourth bytes of the UTF-8 character are ignored.

When the ETF3-enhancement facility is installed and the W bit of the M3 field is one, the contents of the second, third, and fourth bytes of the UTF-8 character must be as follows:

- When the first byte is F0 hex, the second, third, and fourth bytes must be in the ranges 90 to BF, 80 to BF, and 80 to BF, respectively.
- When the first byte is in the range F1 to F3, the second, third, and fourth bytes must all be in the range 80 to BF hex.
- When the first byte is F4 hex, the second, third, and fourth bytes must be in the ranges 80 to 8F, 80 to BF, and 80 to BF, respectively.

Otherwise, the character is invalid.

6. When the ETF3-enhancement facility is installed, the W bit of the M3 field is one, and the contents of the first byte of the UTF-8 character are in the range of F5 to F7 hex, the character is invalid.

7. When the contents of the first byte of the UTF-8 character are in the range of F8-FF, the character is invalid.

If an invalid character is encountered, condition code 2 is set, and general register R2 contains the address of the first byte of the invalid UTF-8 character.

The second-operand location is considered exhausted when it does not contain at least one remaining byte or when it does not contain at least the two, three, or four remaining bytes required to contain the two-, three-, or four-byte UTF-8 character indicated by the contents of the first remaining byte. The first-operand location is considered exhausted when it does not contain at least four remaining bytes.

When the second-operand location is exhausted, condition code 0 is set. When the first-operand location is exhausted, condition code 1 is set, except that condition code 0 is set if the second-operand location also is exhausted. When a CPU-determined number of characters have been processed, condition code 3 is set.

When the conditions for setting condition codes 1 and 2 are both met, condition code 2 is set.

When the operation is completed, the contents of general register R1 + 1 are decremented by the number of bytes converted, and the contents of general register R2 are incremented by the same number. Also, the contents of general register R1 + 1 are decremented by the number of bytes placed at the first-operand location, and the contents of general register R1 are incremented by the same number. When general registers R1 and R2 are updated in the 24-bit or 31-bit addressing mode, bits 32-39 of them, in the 24-bit mode, or bit 32, in the 31-bit mode, may be set to zeros or may remain unchanged.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers R1, R1 + 1, R2, and R2 + 1, always remain unchanged.

When condition code 2 is set, general register R2 contains the address of the invalid UTF-8 character.

When condition code 3 is set, the registers have been updated so that the instruction, when reexecuted, resumes at the next byte locations to be processed.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

When the R1 register is the same register as the R2 register, the results are unpredictable.
When the second operand overlaps the first operand, the results are unpredictable.

Access exceptions for the portions of the operands to the right of the last byte processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

When the length of an operand is zero, no access exceptions are recognized for that operand. Access exceptions are not recognized for an operand if the R field associated with that operand is odd.

**Resulting Condition Code:**

0  Entire second operand processed  
1  End of first operand reached  
2  Invalid UTF-8 character  
3  CPU-determined number of characters processed

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)  
- Operation (if the extended-translation facility 3 is not installed)  
- Specification  
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the program can simply branch back to the instruction to continue the conversion. The program need not determine the number of first-operand or second-operand bytes that were processed.

2. When the ETF3-enhancement facility is not installed, or when the W bit of the M3 operand is zero, bits 0 and 1 of the continuation bytes of multiple-byte UTF-8 characters are not checked in order to improve the performance of the conversion. Therefore, invalid continuation bytes are not detected.

3. The storage-operand references of CONVERT UTF-8 TO UTF-32 may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

4. The CONVERT UTF-8 TO UTF-32 instruction supports UTF-32 characters only in the big-endian encoding.

5. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

**COPY ACCESS**

<table>
<thead>
<tr>
<th>CPYA</th>
<th>R1,R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>́B24D́</td>
<td>./././././././.</td>
<td>R1 R2</td>
</tr>
</tbody>
</table>

The contents of access register R2 are placed in access register R1.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Transaction constraint

**DIVIDE**

**Register-and-register format:**

DR  R1,R2  [RR]

```
0 8 12 15
'1D' R1 R2
```

The 64-bit first operand (the dividend) is divided by the 32-bit second operand (the divisor), and the 32-bit remainder and quotient are placed at the first-operand location.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The dividend is treated as a 64-bit signed binary integer. The leftmost 32 bits of the dividend are in bit positions 32-63 of general register R1, and the rightmost 32 bits are in bit positions 32-63 of general register R1 + 1.
The divisor, remainder, and quotient are treated as 32-bit signed binary integers. For DIVIDE (DR), the divisor is in bit positions 32-63 of general register R₂. The remainder is placed in bit positions 32-63 of general register R₁, and the quotient is placed in bit positions 32-63 of general register R₁ + 1. Bits 0-31 of the registers remain unchanged.

The sign of the quotient is determined by the rules of algebra, and the remainder has the same sign as the dividend, except that a zero quotient or a zero remainder is always positive.

When the divisor is zero, or when the magnitudes of the dividend and divisor are such that the quotient cannot be expressed by a 32-bit signed binary integer, a fixed-point-divide exception is recognized. This includes the case of division of zero by zero.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 of D only)
- Fixed-point divide
- Specification
- Transaction constraint

### DIVIDE LOGICAL

**Register-and-register formats:**

<table>
<thead>
<tr>
<th>Format</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>DLR</td>
<td>R₁,R₂ [RRE]</td>
</tr>
<tr>
<td>DLGR</td>
<td>R₁,R₂ [RRE]</td>
</tr>
</tbody>
</table>

**Register-and-storage formats:**

<table>
<thead>
<tr>
<th>Format</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>DL</td>
<td>R₁,Dₓ(X₂,B₂) [RXY-a]</td>
</tr>
<tr>
<td>DLG</td>
<td>R₁,Dₓ(X₂,B₂) [RXY-a]</td>
</tr>
</tbody>
</table>

The 64-bit or 128-bit first operand (the dividend) is divided by the 32-bit or 64-bit second operand (the divisor), and the 32-bit or 64-bit remainder and quotient are placed at the first-operand location.

The R₁ field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

For DIVIDE LOGICAL (DLR, DL), the dividend is treated as a 64-bit unsigned binary integer. The leftmost 32 bits of the dividend are in bit positions 32-63 of general register R₁, and the rightmost 32 bits are in bit positions 32-63 of general register R₁ + 1. Bits 0-31 of the registers remain unchanged.

The divisor, remainder, and quotient are treated as 32-bit unsigned binary integers. For DIVIDE LOGICAL (DLR), the divisor is in bit positions 32-63 of general register R₂. The remainder is placed in bit positions 32-63 of general register R₁, and the quotient is placed in bit positions 32-63 of general register R₁ + 1. Bits 0-31 of the registers remain unchanged.

For DIVIDE LOGICAL (DLGR, DLG), the dividend is treated as a 128-bit unsigned binary integer. The leftmost 64 bits of the dividend are in general register R₁, and the rightmost 64 bits are in general register R₁ + 1. The divisor, remainder, and quotient are treated as 64-bit unsigned binary integers. The remainder is placed in general register R₁, and the quotient is placed in general register R₁ + 1.

When the divisor is zero, or when the magnitudes of the dividend and divisor are such that the quotient cannot be expressed as a 32-bit unsigned binary integer for DIVIDE LOGICAL (DLR, DL), or a 64-bit unsigned binary integer for DIVIDE LOGICAL (DLGR, DLG), a fixed-point-divide exception is recognized. This includes the case of division of zero by zero.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 of DL or DLG only)
- Fixed-point divide
- Specification
- Transaction constraint
DIVIDE SINGLE

Register-and-register formats:

DSGR \( R_1, R_2 \) [RRE]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'B90D' & 16 & 24 & 28 & 31 \\
\end{array}
\]

DSGFR \( R_1, R_2 \) [RRE]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'B91D' & 16 & 24 & 28 & 31 \\
\end{array}
\]

Register-and-storage formats:

DSG \( R_1, D_2(X_2, B_2) \) [RXY-a]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'E3' & R_1 & X_2 & B_2 & DL_2 & DH_2 & '0D' \\
\end{array}
\]

DSGF \( R_1, D_2(X_2, B_2) \) [RXY-a]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'E3' & R_1 & X_2 & B_2 & DL_2 & DH_2 & '1D' \\
\end{array}
\]

The 64-bit contents of general register \( R_1 + 1 \) (the dividend) are divided by the 64-bit or 32-bit second operand (the divisor), the 64-bit remainder is placed in general register \( R_1 \), and the 64-bit quotient is placed in general register \( R_1 + 1 \).

The \( R_1 \) field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The dividend, quotient, and remainder are treated as 64-bit signed binary integers. For DIVIDE SINGLE (DSGR, DSG), the divisor is treated as a 64-bit signed binary integer. For DIVIDE SINGLE (DSGFR, DSGF), the divisor is treated as a 32-bit signed binary integer. For DSGFR, the divisor is in bit positions 32-63 of general register \( R_2 \).

The sign of the quotient is determined by the rules of algebra, and the remainder has the same sign as the dividend, except that a zero quotient or a zero remainder is always positive.

When the divisor is zero, or when the magnitudes of the dividend and divisor are such that the quotient cannot be expressed by a 64-bit signed binary integer, a fixed-point-divide exception is recognized. This includes the case of division of zero by zero.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of DSG and DSGF only)
- Fixed-point divide
- Specification
- Transaction constraint

EXCLUSIVE OR

Register-and-register formats:

XR \( R_1, R_2 \) [RR]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'17' & R_1 & R_2 \\
\end{array}
\]

XGR \( R_1, R_2 \) [RRE]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'B982' & 16 & 24 & 28 & 31 \\
\end{array}
\]

XRK \( R_1, R_2, R_3 \) [RRF-a]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'B9F7' & R_3 & 16 & 24 & 28 & 31 \\
\end{array}
\]

XGRK \( R_1, R_2, R_3 \) [RRF-a]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'B9E7' & R_3 & 16 & 24 & 28 & 31 \\
\end{array}
\]

Register-and-storage formats:

X \( R_1, D_2(X_2, B_2) \) [RX-a]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'57' & R_1 & X_2 & B_2 & D_2 \\
\end{array}
\]

XY \( R_1, D_2(X_2, B_2) \) [RXY-a]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'E3' & R_1 & X_2 & B_2 & DL_2 & DH_2 & '57' \\
\end{array}
\]

XG \( R_1, D_2(X_2, B_2) \) [RXY-a]

\[
\begin{array}{c|ccccc}
0 & 8 & 12 & 16 & 20 & 24 \\
\hline
'E3' & R_1 & X_2 & B_2 & DL_2 & DH_2 & '82' \\
\end{array}
\]
Storage-and-immediate formats:

\[
\begin{array}{|c|c|c|c|}
\hline
XI & D_1(B_1), & I_2 & [SI] \\
\hline
\end{array}
\]

\[
\begin{array}{|c|c|c|c|c|c|}
\hline
'B7' & I_2 & B_1 & D_1 & \ \\
\hline
0 & 8 & 16 & 20 & 31 \\
\hline
\end{array}
\]

\[
\begin{array}{|c|c|c|c|}
\hline
X_{IY} & D_1(B_1), & I_2 & [SI_{Y}] \\
\hline
\end{array}
\]

\[
\begin{array}{|c|c|c|c|c|c|}
\hline
'EB' & I_2 & B_1 & D_L & D_H & '57' \\
\hline
0 & 8 & 16 & 20 & 32 & 40 & 47 \\
\hline
\end{array}
\]

Storage-and-storage format:

\[
\begin{array}{|c|c|c|c|c|c|c|}
\hline
XC & D_1(L,B_1), & D_2(B_2) & [SS-a] \\
\hline
\end{array}
\]

\[
\begin{array}{|c|c|c|c|c|c|c|}
\hline
'D7' & L & B_1 & D_1 & B_2 & D_2 & \ \\
\hline
0 & 8 & 16 & 20 & 32 & 36 & 47 \\
\hline
\end{array}
\]

For X, XC, XG, XGR, XI, X_{IY}, XR, and XY, the EXCLUSIVE OR of the first and second operands is placed at the first-operand location. For XGRK and XRK, the EXCLUSIVE OR of the second and third operands is placed at the first-operand location.

The connective EXCLUSIVE OR is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the bits in the corresponding bit positions in the two operands are unlike; otherwise, the result bit is set to zero.

For EXCLUSIVE OR (XC), each operand is processed left to right. When the operands overlap, the result is obtained as if the operands were processed one byte at a time and each result byte were stored immediately after fetching the necessary operand bytes.

For EXCLUSIVE OR (XI, X_{IY}), the first operand is one byte in length, and only one byte is stored. When the interlocked-access facility is installed, accesses to a particular byte do not necessarily occur one immediately after the other. Thus, these instructions cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown for OR (OI) in “Multiprogramming and Multiprocessing Examples” on page A-45.

When the interlocked-access facility is installed, EXCLUSIVE OR (XI, X_{IY}) can be safely used to update a location in storage, even if the possibility exists that another CPU or a

Resulting Condition Code:

0 Result zero
1 Result not zero
2 --
3 --

Program Exceptions:

- Access (fetch, operand 2, X, XY, XG, and XC; fetch and store, operand 1, XI, X_{IY}, and XC)
- Operation (XY and X_{IY}, if the long-displacement facility is not installed; XGRK and XRK, if the distinct-operands facility is not installed)
- Transaction constraint (XC)

Programming Notes:

1. An example of the use of the EXCLUSIVE OR instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. EXCLUSIVE OR may be used to invert a bit, an operation particularly useful in testing and setting programmed binary switches.
3. A field EXCLUSIVE-ORed with itself becomes all zeros.
4. For EXCLUSIVE OR (XR or XGR), the sequence A EXCLUSIVE-OR B, B EXCLUSIVE-OR A, A EXCLUSIVE-OR B results in the exchange of the contents of A and B without the use of an additional general register.
5. Accesses to the first operand of EXCLUSIVE OR (XC) – and, when the interlocked-access facility is not installed, accesses to the first operand of EXCLUSIVE OR (XI, X_{IY}) – consist in fetching a first-operand byte from storage and subsequently storing the updated value. These fetch and store accesses to a particular byte do not necessarily occur one immediately after the other. Thus, these instructions cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown for OR (OI) in “Multiprogramming and Multiprocessing Examples” on page A-45.
channel program may also be updating the location.

**EXCLUSIVE OR IMMEDIATE**

The second operand is EXCLUSIVE ORed with bits of the first operand, and the result replaces those bits of the first operand. The remainder of the first operand remains unchanged.

For each instruction, the bits of the first operand that are EXCLUSIVE ORed with the second operand and then replaced are as follows:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Bits Exclusive ORed and Replaced</th>
</tr>
</thead>
<tbody>
<tr>
<td>XIHF</td>
<td>0-31</td>
</tr>
<tr>
<td>XILF</td>
<td>32-63</td>
</tr>
</tbody>
</table>

The connective EXCLUSIVE OR is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the bits in the corresponding bit positions in the two operands are unlike; otherwise, the result bit is set to zero.

The condition code is set based on the result of the 32-bit EXCLUSIVE OR operation.

**Resulting Condition Code:**

- 0 Result is zero
- 1 Result is not zero
- 2 --
- 3 --

**Program Exceptions:**

- Operation, if the extended-immediate facility is not installed

**Programming Note:** The setting of the condition code is based only on the bits that are exclusive ORed and replaced.

**EXECUTE**

<table>
<thead>
<tr>
<th>EX</th>
<th>R1, D2(X2, B2) [R X-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'44'</td>
<td>R1  X2  B2  D2</td>
</tr>
</tbody>
</table>

**EXECUTE RELATIVE LONG**

<table>
<thead>
<tr>
<th>EXRL</th>
<th>R1, R12 [RIL-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C6'</td>
<td>R1  0  R12</td>
</tr>
</tbody>
</table>

The single instruction at the second-operand address is modified by the contents of general register R1, and the resulting instruction, called the target instruction, is executed.

When the R1 field is not zero, bits 8-15 of the instruction designated by the second-operand address are ORed with bits 56-63 of general register R1. The ORing does not change either the contents of general register R1 or the instruction in storage, and it is effective only for the interpretation of the instruction to be executed. When the R1 field is zero, no ORing takes place.

The target instruction may be two, four, or six bytes in length. The execution and exception handling of the target instruction are exactly as if the target instruction were obtained in normal sequential operation, except for the instruction address and the instruction-length code.

The instruction address in the current PSW is increased by the length of the execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG). This updated address and the instruction-length code of the execute-type instruction are used, for example, as part of the link information when the target instruction is BRANCH AND LINK. When the target instruction is a successful branching instruction, the instruction address in the current PSW is replaced by the branch address specified by the target instruction.

When the target instruction is any of the following instructions, an execute exception is recognized:

- Another execute-type instruction
- TRANSACTION ABORT
- TRANSACTION BEGIN

---

EXCLUSIVE OR IMMEDIATE

"IBM z/Architecture Principles of Operation"
The effective address of EXECUTE must be even; otherwise, a specification exception is recognized.

When the target instruction is two or three halfwords in length but can be executed without fetching its second or third halfword, it is unpredictable whether access exceptions are recognized for the unused halfwords. Access exceptions are not recognized for the second-operand address when the address is odd.

The second-operand address of an execute-type instruction is an instruction address rather than a logical address; thus, the target instruction is fetched from the primary address space when in the primary-space, secondary-space, or access-register mode.

For EXECUTE RELATIVE LONG, the contents of the RL2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the target instruction in storage.

**Condition Code:** The code may be set by the target instruction.

**Program Exceptions:**

- Access (fetch, target instruction)
- Execute
- Operation (EXRL, when the execute-extensions facility is not installed)
- Specification (EX)
- Transaction constraint

**Programming Notes:**

1. An example of the use of the EXECUTE instruction is given in Appendix A, "Number Representation and Instruction-Use Examples."

2. The ORing of eight bits from the general register with the designated instruction permits the indirect specification of the length, index, mask, immediate-data, register, or extended-op-code field.

3. The fetching of the target instruction is considered to be an instruction fetch for purposes of program-event recording and for purposes of reporting access exceptions.

4. An access or specification exception may be caused by execute-type instructions or by the target instruction, except that EXECUTE RELATIVE LONG cannot cause a specification exception due to a misaligned target operand.

5. When an interruptible instruction is made the target of an execute-type instruction, the program normally should not designate any register updated by the interruptible instruction as the R1, X2, or B2 register for EXECUTE or R1 register for EXECUTE RELATIVE LONG. Otherwise, on resumption of execution after an interruption, or if the instruction is refetched without an interruption, the updated values of these registers will be used in the execution of the execute-type instruction. Similarly, the program should normally not let the destination field in storage of an interruptible instruction include the location of an execute-type instruction, since the new contents of the location may be interpreted when resuming execution.

6. Exception conditions that occur during the execution of EXECUTE or EXECUTE RELATIVE LONG are recognized before exception conditions for the target instruction.

**EXTRACT ACCESS**

<table>
<thead>
<tr>
<th>EAR</th>
<th>R1, R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B24F'</td>
<td>/ / / / / / /</td>
<td>R1</td>
</tr>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

The contents of access register R2 are placed in bit positions 32-63 of general register R1. Bits 0-31 of general register R1 remain unchanged.

**Condition Code:** The code remains unchanged.

**Program Exceptions:** None.

**EXTRACT CPU ATTRIBUTE**

<table>
<thead>
<tr>
<th>ECAG</th>
<th>R1, R1, D2(B2)</th>
<th>[RSY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB'</td>
<td>R1</td>
<td>R1</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

Information regarding the specified attribute of the storage subsystem is placed into the first-operand location. The first operand is 64 bits.
The second-operand address is not used to address data; rather, the rightmost 24 bits of the address are treated as a code specifying which attribute is returned in general register R1.

The rightmost 24 bits of the second-operand address are defined as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>40</td>
<td>Reserved</td>
</tr>
<tr>
<td>54</td>
<td>ASI</td>
</tr>
<tr>
<td>56</td>
<td>ASI-Dependent</td>
</tr>
</tbody>
</table>

**Attribute-Set Indication (ASI):** Bit positions 54-55 of the second-operand address contain a 2-bit unsigned binary integer indicating the set of attributes from which an attribute to be extracted is selected. The attribute-set indications are:

0 Cache attributes

All other attribute-set-indication values are reserved. If a reserved attribute-set indication is specified, model-dependent or unpredictable results may occur.

**Cache-Attribute-Set Operation**
The rightmost 24 bits of the second-operand address are defined as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>40</td>
<td>Reserved</td>
</tr>
<tr>
<td>54</td>
<td>0</td>
</tr>
<tr>
<td>56</td>
<td>0</td>
</tr>
<tr>
<td>60</td>
<td>LI</td>
</tr>
<tr>
<td>63</td>
<td>TI</td>
</tr>
</tbody>
</table>

The attribute, level, and type indications for the cache-attribute set are as follows:

**Attribute Indication (AI):** Bit positions 56-59 of the second-operand address contain a 4-bit unsigned binary integer indicating the cache attribute to be extracted, as follows:

0 Extract topology summary
1 Extract line size of the cache, in bytes
2 Extract total size of the cache, in bytes
3 Extract set-associativity level of the cache
4-15 Reserved

**Level Indication (LI):** Bit positions 60-62 of the second-operand address contain a 3-bit unsigned binary integer indicating the level of the cache for which the cache attribute is to be extracted, with 0 indicating the first-level cache, 1 indicating the second-level cache and so forth. If a cache level is not implemented on a model, its corresponding level indication is reserved.

**Type Indication (TI):** Bit 63 of the second-operand address indicates the type of cache for which the cache attribute is to be extracted, with 0 indicating the data cache and 1 indicating the instruction cache. When a cache level has a unified data and instruction cache, the same result is returned regardless of the type indication.

When the attribute indication is zero, the level indication (LI) and type indication (TI) are ignored.

**Common Operation**
Bits 0-39 of the second-operand address are ignored. Bits 40-53 of the second-operand address are reserved and should contain zeros.

Bits 0-63 of general register R1 are set to ones if any of the following apply:

- A reserved bit position in the second-operand address contains one and is otherwise not specifically designated as ignored.
- A reserved ASI, AI, or, when applicable, LI value is specified and is otherwise not specifically designated as ignored.
- The specified ASI and AI values and, when applicable, the LI value are all valid, but the model does not provide the data.

The contents of general register R3 are ignored, however the R3 field should specify register 0; otherwise, the program may not operate compatibly in the future.

**Cache-Attribute Results (ASI = 0)**
When the cache attribute indication is zero, a summary of each level of cache is returned in general register R1. Each summary field is eight bits, where bits 0-7 of the register contain the summary for the first-level cache, bits 8-15 contain the summary for the second-level cache, and so forth. The contents of an eight-bit summary field are as follows:

<table>
<thead>
<tr>
<th>Bits</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-3</td>
<td>Reserved, stored as zeros</td>
</tr>
<tr>
<td>4-5</td>
<td>Cache scope, as follows:</td>
</tr>
<tr>
<td></td>
<td>00    Cache does not exist at this level</td>
</tr>
<tr>
<td></td>
<td>01    Cache is private to the CPU</td>
</tr>
</tbody>
</table>
When the cache attribute indication is one, two, or three, the attribute value is returned in general register $R_1$, as a 64-bit unsigned integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Operation (if the general-instructions-extension facility is not installed)
- Transaction constraint

**Programming Notes:**

1. Knowledge of the cache line size is useful when determining the placement of `PREFETCH DATA` and `PREFETCH DATA RELATIVE LONG` instructions.

2. The value placed in the first-operand location is model dependent and may differ significantly from one model to another. For example, the size of the data cache on one model may be smaller or larger than the size of the data cache on another model. To ensure compatible operation across multiple models, the program should not rely on any particular value being returned in the first-operand location.

3. When the attribute-set indication is 00 binary and the attribute indication is 0000 binary, the summary indications are returned in contiguous 8-bit fields in general register $R_1$. Thus if the program scans the resulting summary-indication fields from left to right and encounters an 8-bit field containing all zeros, no further meaningful fields exist.

4. When the attribute-set indication is 00 binary and the attribute indication is 0000 binary, the summary indications are returned in contiguous 8-bit fields in general register $R_1$. Thus if the program scans the resulting summary-indication fields from left to right and encounters an 8-bit field containing all zeros, no further meaningful fields exist.

5. Cache information returned reflects the depth specified by the level indication and the cache information accessible from the issuing CPU. The total sizes and associativity do not include other, parallel cache structures accessible from other CPUs of the configuration.

**EXTRACT CPU TIME**

```
ECTG D_1(B_1),D_2(B_2),R_3 [SSF]
```

The value of the current CPU timer is subtracted from the first operand, and the difference is placed in general register 0. The second operand is placed unchanged in general register 1. The eight bytes at the third operand location replace the contents of general register $R_3$.

The first and second operands and the results in general registers 0, 1, and $R_3$ are treated as 64-bit unsigned binary integers.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general register $R_3$ constitute the address of the third operand, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the register constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address. In the access-register mode, the contents of access register $R_3$ are used for accessing the third operand.

All operands are fetched before any general register is modified. If the $R_3$ field designates general register 0, it is unpredictable whether the result placed in the register is the first operand minus the CPU timer or the third operand. If the $R_3$ field designates general register 1, it is unpredictable whether the result would be placed in the third operand.
placed in the register is the second operand or the third operand. The contents of the registers just described are shown in Figure 7-252.

### 24-Bit Addressing Mode

<table>
<thead>
<tr>
<th>R3</th>
<th></th>
<th>Third-Operand Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>/ / / / / / / / / /</td>
<td></td>
</tr>
</tbody>
</table>

### 31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>R3</th>
<th></th>
<th>Third-Operand Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>/ / / / / / / / / /</td>
<td></td>
</tr>
</tbody>
</table>

### 64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>R3</th>
<th></th>
<th>Third-Operand Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>/ / / / / / / / / /</td>
<td></td>
</tr>
</tbody>
</table>

---

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operands 1, 2, and 3)
- Operation (the extract-CPU-time facility is not installed)
- Transaction constraint

---

### EXTRACT PSW

**EPSW**  

<table>
<thead>
<tr>
<th>EPSW</th>
<th>R1, R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B98D'</td>
<td>/ / / /</td>
<td>R1, R2</td>
</tr>
</tbody>
</table>

Bits 0-63 of the current PSW are placed in bit positions 32-63 of the first operand, and bits 0-31 of the operand remain unchanged. Subsequently, bits 32-63 of the current PSW are placed in bit positions 32-63 of the second operand, and bits 0-31 of the operand remain unchanged. The action associated with the second operand is not performed if the R2 field is zero.

---

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Transaction constraint

---

### EXTRACT TRANSACTION NESTING DEPTH

**ETND**  

<table>
<thead>
<tr>
<th>ETND</th>
<th>R1</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B2EC'</td>
<td>/ /</td>
<td>R1</td>
</tr>
</tbody>
</table>

The current transaction nesting depth is placed in bits 48-63 of general register R1. Bits 0-31 of the reg-
ister remain unchanged, and bits 32-47 of the register are set to zero, as illustrated below.

A special-operation exception is recognized and the operation is suppressed if the transactional-execution control, bit 8 of control register 0, is zero.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Operation (transactional-execution facility not installed)
- Special operation
- Transaction constraint

**Programming Note:** A transaction nesting depth of zero indicates that the CPU is not in the transactional-execution mode.

**FIND LEFTMOST ONE**

FLOGR R1,R2 [RRE]

The byte at the second-operand location is inserted into bit positions 56-63 of general register R1. The remaining bits in the register remain unchanged.

The condition code indicates whether or not a one bit was found in the second operand.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

**RESULTING CONDITION CODE:**
- 0 No one bit found
- 1 --
- 2 One bit found
- 3 --

**Program Exceptions:**
- Operation (if the extended-immediate facility is not installed)
- Specification

**Programming Notes:**
1. An example of the use of the FIND LEFTMOST ONE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. When the R1 and R2 fields designate the same register, the original contents of general register R2 are replaced by the resulting bit-position value, or 64 if no one bit was found.
3. When the R2 field designates general register R1 + 1, the leftmost one bit (if any) of general register R2 is set to zero; if no one bit is found, the entire register is set to zero.
4. When the R2 field designates neither the even nor the odd registers designated by the R1 field, then general register R2 is not modified.

**INSERT CHARACTER**

IC R1,D2(X2,B2)[RXY-a]

The byte at the second-operand location is inserted into bit positions 56-63 of general register R1. The remaining bits in the register remain unchanged.

The displacement for IC is treated as a 12-bit unsigned binary integer. The displacement for ICY is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.
**Program Exceptions:**

- Access (fetch, operand 2)
- Operation (ICY, if the long-displacement facility is not installed)

**INSERT CHARACTERS UNDER MASK**

<table>
<thead>
<tr>
<th>ICM</th>
<th>R₁, M₃, D₂(B₂)</th>
<th>[RS-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>BF</td>
<td>R₁  M₃ B₂ D₂</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ICMY</th>
<th>R₁, M₃, D₂(B₂)</th>
<th>[RSY-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>EB</td>
<td>R₁  M₃ B₂ DL₂ DH₂ '81'</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ICMH</th>
<th>R₁, M₃, D₂(B₂)</th>
<th>[RSY-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>EB</td>
<td>R₁  M₃ B₂ DL₂ DH₂ '80'</td>
<td></td>
</tr>
</tbody>
</table>

Bytes from contiguous locations beginning at the second-operand address are inserted into general register R₁ under control of a mask.

The contents of the M₃ field are used as a mask. These four bits, left to right, correspond one for one with four bytes, left to right, of general register R₁. For INSERT CHARACTERS UNDER MASK (ICM, ICMY), the four bytes to which the mask bits correspond are in the low-order half, bit positions 32-63 of general register R₁. For INSERT CHARACTERS UNDER MASK (ICMH), the four bytes are in the high-order half, bit positions 0-31, of the register. The byte positions corresponding to ones in the mask are filled, left to right, with bytes from successive storage locations beginning at the second-operand address. When the mask is not zero, the length of the second operand is equal to the number of ones in the mask. The bytes in the general register corresponding to zeros in the mask remain unchanged. For ICM and ICMY, bits 0-31 of the register remain unchanged, and, for ICMH, bits 32-63 remain unchanged.

The resulting condition code is based on the mask and on the value of the bits inserted. When the mask is zero or when all inserted bits are zeros, the condition code is set to 0. When the inserted bits are not all zeros, the code is set according to the leftmost bit of the storage operand: if this bit is one, the code is set to 1; if this bit is zero, the code is set to 2.

When the mask is not zero, exceptions associated with storage-operand access are recognized only for the number of bytes specified by the mask. When the mask is zero, access exceptions are recognized for one byte at the second-operand address.

The displacement for ICM is treated as a 12-bit unsigned binary integer. The displacement for ICMY and ICMH is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

0  All inserted bits zeros, or mask bits all zeros
1  Leftmost inserted bit one
2  Leftmost inserted bit zero, and not all inserted bits zeros
3  --

**Program Exceptions:**

- Access (fetch, operand 2)
- Operation (ICMY, if the long-displacement facility is not installed)

**Programming Notes:**

1. Examples of the use of the INSERT CHARACTERS UNDER MASK instruction are given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The condition code for INSERT CHARACTERS UNDER MASK (ICM, ICMY only) is defined such that, when the mask is 1111, the instruction causes the same condition code to be set as for LOAD AND TEST (LTR only) Thus, the instruction may be used as a storage-to-register load-and-test operation.

3. INSERT CHARACTERS UNDER MASK (ICM, ICMY) with a mask of 1111 or 0001 performs a function similar to that of a LOAD (L) or INSERT CHARACTER (IC) instruction, respectively, with the exception of the condition-code setting. However, the performance of INSERT CHARACTERS UNDER MASK may be slower.
INSERT IMMEDIATE

IIHF  R1,I2  [RIL-a]

<table>
<thead>
<tr>
<th>Bit Positions</th>
<th>Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-31</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Bit Positions</th>
<th>Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>IIIH</td>
<td>0-15</td>
<td></td>
</tr>
<tr>
<td>IIIHL</td>
<td>16-31</td>
<td></td>
</tr>
<tr>
<td>IIIF</td>
<td>32-63</td>
<td></td>
</tr>
<tr>
<td>IIIH</td>
<td>32-47</td>
<td></td>
</tr>
<tr>
<td>IIIH</td>
<td>48-63</td>
<td></td>
</tr>
</tbody>
</table>

The second operand is placed in bit positions of the first operand. The remainder of the first operand remains unchanged.

For each instruction, the bit positions of the first operand that are loaded with the second operand are as follows:

Condition Code: The code remains unchanged.

Program Exceptions:
- Operation (IIHF and IILF, if the extended-immediate facility is not installed)

INSERT PROGRAM MASK

IPM  R1  [RRE]

<table>
<thead>
<tr>
<th>Bit Positions</th>
<th>Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B222'</td>
<td></td>
</tr>
</tbody>
</table>

The condition code and program mask from the current PSW are inserted into bit positions 34 and 35 and 36-39, respectively, of general register R1. Bits 32 and 33 of the register are set to zeros; bits 0-31 and 40-63 are left unchanged.

Condition Code: The code remains unchanged.

Program Exceptions: None.

LOAD

Register-and-register formats:

LR  R1,R2  [RR]

<table>
<thead>
<tr>
<th>Bit Positions</th>
<th>Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-15</td>
<td></td>
</tr>
</tbody>
</table>

Register-and-storage formats:

L  R1,D2(X2,B2)  [RX-a]

<table>
<thead>
<tr>
<th>Bit Positions</th>
<th>Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-31</td>
<td></td>
</tr>
</tbody>
</table>

LY  R1,D2(X2,B2)  [RXY-a]

<table>
<thead>
<tr>
<th>Bit Positions</th>
<th>Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-31</td>
<td></td>
</tr>
</tbody>
</table>

Condition Code: The code remains unchanged.
LOAD IMMEDIATE

The second operand is placed unchanged at the first-operand location, except that, for LOAD (LGFR, LGF), LOAD IMMEDIATE (LGFI), and LOAD RELATIVE LONG (LGRL), it is sign extended.

For LOAD (LR, L, LY) and LOAD RELATIVE LONG (LRL), the operands are 32 bits, and, for LOAD (LGR, LG, LGF), and LOAD RELATIVE LONG (LGRL), the operands are 64 bits. For LOAD (LGFR, LGF), LOAD IMMEDIATE (LGFI), and LOAD RELATIVE LONG (LGFR), the second operand is treated as a 32-bit signed binary integer, and the first operand is treated as a 64-bit signed binary integer.

The displacement for L is treated as a 12-bit unsigned binary integer. The displacement for LY, LG, and LGF is treated as a 20-bit signed binary integer.

For LOAD IMMEDIATE, the contents of the I2 field form the second operand directly.

For LOAD RELATIVE LONG, the contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand in storage. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

For LOAD RELATIVE LONG (LRL, LGFRL), the second operand must be aligned on a word boundary, and for LOAD RELATIVE LONG (LGRL), the second operand must be aligned on a doubleword boundary; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (fetch, operand 2 of L, LY, LG, LGF, LRL, LGRL, and LGFRL only)
- Operation (LY, if the long-displacement facility is not installed; LGFI, if the extended-immediate facility is not installed; LRL, LGRL, LGFRL, if the general-instructions-extension facility is not installed)
- Specification (LRL, LGFRL, LGRL only)

Programming Notes:

1. An example of the use of the LOAD instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. For LOAD RELATIVE LONG, the second operand must be aligned on an integral boundary corresponding to the operand’s size.

3. When LOAD RELATIVE LONG is the target of an execute-type instruction, the second-operand address is relative to the target address.

LOAD ACCESS MULTIPLE

The displacement for L is treated as a 12-bit unsigned binary integer. The displacement for LY, LG, and LGF is treated as a 20-bit signed binary integer.
The set of access registers starting with access register \( R_1 \) and ending with access register \( R_3 \) is loaded from the locations designated by the second-operand address.

The storage area from which the contents of the access registers are obtained starts at the location designated by the second-operand address and continues through as many storage words as the number of access registers specified. The access registers are loaded in ascending order of their register numbers, starting with access register \( R_1 \) and continuing up to and including access register \( R_{15} \), with access register 0 following access register 15.

The displacement for LAM is treated as a 12-bit unsigned binary integer. The displacement for LAMY is treated as a 20-bit signed binary integer.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2)
- Operation (LAMY, if the long-displacement facility is not installed)
- Specification
- Transaction constraint

**LOAD ADDRESS**

\[
\begin{array}{c|ccccc}
\text{LA} & R_1, D_2(X_2, B_2) & [\text{RX-a}] \\
\hline
\text{EB} & R_1 & R_3 & B_2 & DL_2 & DH_2 & 9A' \\
\end{array}
\]

The address specified by the \( X_2, B_2, \) and \( D_2 \) fields is placed in general register \( R_1 \). The address computation follows the rules for address arithmetic.

In the 24-bit addressing mode, the address is placed in bit positions 40-63, bits 32-39 are set to zeros, and bits 0-31 remain unchanged. In the 31-bit addressing mode, the address is placed in bit positions 33-63, bit 32 is set to zero, and bits 0-31 remain unchanged. In the 64-bit addressing mode, the address is placed in bit positions 0-63.

The displacement for LA is treated as a 12-bit unsigned binary integer. The displacement for LAY is treated as a 20-bit signed binary integer.

No storage references for operands take place, and the address is not inspected for access exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Operation (LAY if the long-displacement facility is not installed)

**Programming Notes:**

1. An example of the use of the LOAD ADDRESS instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. LOAD ADDRESS may be used to increment the rightmost bits of a general register, other than register 0, by the contents of the \( D_2 \) field of the instruction. LOAD ADDRESS (LAY) may also be used to decrement the rightmost bits of a register, other than register 0. The register to be incremented should be designated by \( R_i \) and by either \( X_2 \) (with \( B_2 \) set to zero) or \( B_2 \) (with \( X_2 \) set to zero). The instruction increments 24 bits in the 24-bit addressing mode, 31 bits in the 31-bit addressing mode, and 64 bits in the 64-bit addressing mode.

**LOAD ADDRESS EXTENDED**

\[
\begin{array}{c|ccccc}
\text{LAE} & R_1, D_2(X_2, B_2) & [\text{RX-a}] \\
\hline
\text{E3} & R_1 & X_2 & B_2 & DL_2 & DH_2 & 71' \\
\end{array}
\]

\[
\begin{array}{c|ccccc}
\text{LAey} & R_1, D_2(X_2, B_2) & [\text{RXY-a}] \\
\hline
\text{E3} & R_1 & X_2 & B_2 & DL_2 & DH_2 & 75' \\
\end{array}
\]
The address specified by the \text{X}_2, \text{B}_2, \text{and D}_2 \text{ fields is placed in general register } R_1. \text{ Access register } R_1 \text{ is loaded with a value that depends on the current value of the address-space-control bits, bits 16 and 17 of the PSW. If the address-space-control bits are 01 binary, the value placed in the access register also depends on whether the } \text{B}_2 \text{ field is zero or non-zero.}

The address computation follows the rules for address arithmetic. In the 24-bit addressing mode, the address is placed in bit positions 40-63 of general register \text{R}_1, \text{ bits 32-39 are set to zeros, and bits 0-31 remain unchanged. In the 31-bit addressing mode, the address is placed in bit positions 33-63, bit 32 is set to zero, and bits 0-31 remain unchanged. In the 64-bit addressing mode, the address is placed in bit positions 0-63.}

The value placed in access register \text{R}_1 \text{ is as shown in the following table:}

<table>
<thead>
<tr>
<th>PSW Bits 16 and 17</th>
<th>Value Placed in Access Register R_1</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>00000000 hex (zeros in bit positions 0-31)</td>
</tr>
<tr>
<td>10</td>
<td>00000001 hex (zeros in bit positions 0-30 and one in bit position 31)</td>
</tr>
<tr>
<td>01</td>
<td>If \text{B}_2 \text{ field is zero: 00000000 hex (zeros in bit positions 0-31)} \n</td>
</tr>
<tr>
<td>11</td>
<td>00000002 hex (zeros in bit positions 0-29 and 31, and one in bit position 30)</td>
</tr>
</tbody>
</table>

However, when PSW bits 16 and 17 \text{are 01 binary and the } \text{B}_2 \text{ field is nonzero, bit positions 0-6 of access register } \text{B}_2 \text{ must contain all zeros; otherwise, the results in general register } R_1 \text{ and access register } R_1 \text{ are unpredictable.}

The displacement for LAE \text{is treated as a 12-bit unsigned binary integer. The displacement for LAEY is treated as a 20-bit signed binary integer.}

No storage references for operands take place, and the address is not inspected for access exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Operation (LAEY; if the general-instructions-extension facility is not installed)
- Transaction constraint

**Programming Notes:**

1. When DAT \text{is on, the different values of the address-space-control bits correspond to translation modes as follows:}

<table>
<thead>
<tr>
<th>PSW Bits 16 and 17</th>
<th>Translation Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Primary-space mode</td>
</tr>
<tr>
<td>10</td>
<td>Secondary-space mode</td>
</tr>
<tr>
<td>01</td>
<td>Access-register mode</td>
</tr>
<tr>
<td>11</td>
<td>Home-space mode</td>
</tr>
</tbody>
</table>

2. In the access-register mode, the value 00000000 hex in an access register designates the primary address space, and the value 00000001 hex designates the secondary address space. The value 00000002 hex designates the home address space if the control program assigns entry 2 of the dispatchable-unit access list as designating the home address space and places a zero access-list-entry sequence number (ALESN) in that entry.

**LOAD ADDRESS RELATIVE LONG**

\text{LARL R_1,R_2} [\text{RIL-b}]

The address specified by the \text{R}_2 \text{ field is placed in general register } R_1. \text{ The address computation follows the rules for the branch address of BRANCH RELATIVE ON CONDITION LONG and BRANCH RELATIVE AND SAVE LONG.}

In the 24-bit addressing mode, the address is placed in bit positions 40-63, bits 32-39 are set to zeros, and bits 0-31 remain unchanged. In the 31-bit addressing mode, the address is placed in bit positions 33-63, bit 32 is set to zero, and bits 0-31 remain unchanged. In the 64-bit addressing mode, the address is placed in bit positions 0-63.

The contents of the \text{R}_2 \text{ field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the computed address.}
No storage references for operands take place, and the address is not inspected for access exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:** None.

**Programming Notes:**

1. Only even addresses (halfword addresses) can be generated. If an odd address is desired, LOAD ADDRESS can be used to add one to an address formed by LOAD ADDRESS RELATIVE LONG.

2. When LOAD ADDRESS RELATIVE LONG is the target of an execute-type instruction, the address produced is relative to the location of the LOAD ADDRESS RELATIVE LONG instruction, not of the execute-type instruction. This is consistent with the operation of the relative-branch instructions.

**LOAD AND ADD**

<table>
<thead>
<tr>
<th>LAA</th>
<th>R1, R3, D2(B2)</th>
<th>[RSY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB'</td>
<td>R1</td>
<td>R3</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LAAG</th>
<th>R1, R3, D2(B2)</th>
<th>[RSY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB'</td>
<td>R1</td>
<td>R3</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

The second operand of LAA must be designated on a word boundary. The second operand of LAAG must be designated on a doubleword boundary. Otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Result zero; no overflow  
1  Result less than zero; no overflow  
2  Result greater than zero; no overflow  
3  Overflow

**Program Exceptions:**

- Access (fetch and store, operand 2)  
- Fixed-point overflow  
- Operation (if the interlocked-access facility 1 is not installed)  
- Specification  
- Transaction constraint

**Programming Notes:**

1. Except for the case where the R1 and R3 fields designate the same register, general register R3 is unchanged.

2. The operation of LOAD AND ADD, LOAD AND ADD LOGICAL, LOAD AND AND, LOAD AND EXCLUSIVE OR, and LOAD AND OR may be expressed as follows.

   temp ← operand_2;  
   operand_2 ← temp OP operand_3;  
   operand_1 ← temp;

   OP represents the arithmetic or logical operation being performed by the instruction.

**LOAD AND ADD LOGICAL**

<table>
<thead>
<tr>
<th>LAAL</th>
<th>R1, R3, D2(B2)</th>
<th>[RSY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB'</td>
<td>R1</td>
<td>R3</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LAALG</th>
<th>R1, R3, D2(B2)</th>
<th>[RSY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB'</td>
<td>R1</td>
<td>R3</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

The second operand of LAAL must be designated on a word boundary. The second operand of LAALG must be designated on a doubleword boundary. Otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Result zero; no overflow  
1  Result less than zero; no overflow  
2  Result greater than zero; no overflow  
3  Overflow

**Program Exceptions:**

- Access (fetch and store, operand 2)  
- Fixed-point overflow  
- Operation (if the interlocked-access facility 1 is not installed)  
- Specification  
- Transaction constraint

**Programming Notes:**

1. Except for the case where the R1 and R3 fields designate the same register, general register R3 is unchanged.

2. The operation of LOAD AND ADD, LOAD AND ADD LOGICAL, LOAD AND AND, LOAD AND EXCLUSIVE OR, and LOAD AND OR may be expressed as follows.
ond operand (prior to the addition) are placed unchanged at the first-operand location.

For LAAL, the operands are treated as being 32-bit unsigned binary integers. For LAALG, the operands are treated as being 64-bit unsigned binary integers.

All accesses to the second-operand location appear to be a block-concurrent interlocked-update reference as observed by other CPUs and the I/O subsystem. A specific-operand-serialization operation is performed.

The displacement is treated as a 20-bit signed binary integer.

The second operand of LAAL must be designated on a word boundary. The second operand of LAALG must be designated on a doubleword boundary. Otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Result zero; no carry
1  Result not zero; no carry
2  Result zero; carry
3  Result not zero; carry

**Program Exceptions:**

- Access (fetch and store, operand 2)
- Operation (if the interlocked-access facility 1 is not installed)
- Specification
- Transaction constraint

**Programming Note:** See the programming notes for LOAD AND ADD.

### LOAD AND AND

\[
\text{LAN} \quad R_1, R_2, D_2(B_2) \quad \text{[RSY-a]} \\
\text{'EB'} \quad R_1 \quad R_3 \quad B_2 \quad DL_2 \quad DH_2 \quad 'F4' \\
0 \quad 8 \quad 12 \quad 16 \quad 20 \quad 32 \quad 40 \quad 47
\]

\[
\text{LANG} \quad R_1, R_2, D_2(B_2) \quad \text{[RSY-a]} \\
\text{'EB'} \quad R_1 \quad R_3 \quad B_2 \quad DL_2 \quad DH_2 \quad 'E4' \\
0 \quad 8 \quad 12 \quad 16 \quad 20 \quad 32 \quad 40 \quad 47
\]

The AND of the second operand and third operand is placed at the second-operand location. Subsequently, the original contents of the second operand (prior to the AND operation) are placed unchanged at the first-operand location.

For LAN, the operands are 32 bits. For LANG, the operands are 64 bits.

The connective AND is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the corresponding bit positions in both operands contain ones; otherwise, the result bit is set to zero.

All accesses to the second-operand location appear to be a block-concurrent interlocked-update reference as observed by other CPUs and the I/O subsystem. A specific-operand-serialization operation is performed.

The displacement is treated as a 20-bit signed binary integer.

The second operand of LAN must be designated on a word boundary. The second operand of LANG must be designated on a doubleword boundary. Otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Result zero
1  Result not zero
2  --
3  --

**Program Exceptions:**

- Access (fetch and store, operand 2)
- Operation (if the interlocked-access facility 1 is not installed)
- Specification
- Transaction constraint

**Programming Note:** See the programming notes for LOAD AND ADD.

### LOAD AND EXCLUSIVE OR

\[
\text{LAX} \quad R_1, R_3, D_2(B_3) \quad \text{[RSY-a]} \\
\text{'EB'} \quad R_1 \quad R_3 \quad B_2 \quad DL_2 \quad DH_2 \quad 'F7' \\
0 \quad 8 \quad 12 \quad 16 \quad 20 \quad 32 \quad 40 \quad 47
\]
The EXCLUSIVE OR of the second operand and third operand is placed at the second-operand location. Subsequently, the original contents of the second operand (prior to the EXCLUSIVE OR operation) are placed unchanged at the first-operand location.

For LAX, the operands are 32 bits. For LAXG, the operands are 64 bits.

The connective exclusive OR is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the bits in the corresponding bit positions in the two operands are unlike; otherwise, the result bit is set to zero.

All accesses to the second-operand location appear to be a block-concurrent interlocked-update reference as observed by other CPUs and the I/O subsystem. A specific-operand-serialization operation is performed.

The displacement is treated as a 20-bit signed binary integer.

The second operand of LAX must be designated on a word boundary. The second operand of LAXG must be designated on a doubleword boundary. Otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Result zero
1  Result not zero
2  --
3  --

**Program Exceptions:**

- Access (fetch and store, operand 2)
- Operation (if the interlocked-access facility 1 is not installed)
- Specification
- Transaction constraint

**Programming Note:** See the programming notes for LOAD AND ADD.

The OR of the second operand and third operand is placed at the second-operand location. Subsequently, the original contents of the second operand (prior to the OR operation) are placed unchanged at the first-operand location.

For LAO, the operands are 32 bits. For LAOG, the operands are 64 bits.

The connective OR is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the corresponding bit position in one or both operands contains a one; otherwise, the result bit is set to zero.

All accesses to the second-operand location appear to be a block-concurrent interlocked-update reference as observed by other CPUs and the I/O subsystem. A specific-operand-serialization operation is performed.

The displacement is treated as a 20-bit signed binary integer.

The second operand of LAO must be designated on a word boundary. The second operand of LAOG must be designated on a doubleword boundary. Otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Result zero
1  Result not zero
2  --
3  --

**Program Exceptions:**

- Access (fetch and store, operand 2)
- Operation (if the interlocked-access facility 1 is not installed)
- Specification
LOAD AND TEST

Register-and-register formats:

LTR  R1,R2  [RR]

LTGR  R1,R2  [RRE]

LTGF  R1,R2  [RRE]

Register-and-storage formats:

LT  R1,D2(X2,B2)  [RXY-a]

LTG  R1,D2(X2,B2)  [RXY-a]

LTGF  R1,D2(X2,B2)  [RXY-a]

The second operand is placed unchanged at the first operand location, except that, for LTGF and LTGFR, it is sign extended. The sign and magnitude of the second operand, treated as a signed binary integer, are indicated in the condition code.

For LT and LTR, the operands are 32 bits, and, for LTG and LTGR, the operands are 64 bits. For LTGF and LTGFR, the second operand is 32 bits, and the first operand is treated as a 64-bit signed binary integer.

**Resulting Condition Code:**

0  Result zero
1  Result less than zero
2  Result greater than zero
3  --

**Program Exceptions:**

- Access (fetch, operand 2 of LT, LTG, and LTGF only)
- Operation (LT and LTG, if the extended-immediate facility is not installed; LTGF, if the general-instructions-extension facility is not installed)

**Programming Note:** For LOAD AND TEST (LTR and LTGR) when the R1 and R2 fields designate the same register, the operation is equivalent to a test without data movement.

LOAD AND TRAP

LAT  R1,D2(X2,B2)  [RXY-a]

LGAT  R1,D2(X2,B2)  [RXY-a]

The second operand is placed unchanged at the first operand location. If all zeros are placed at the first operand location, a compare-and-trap-instruction data exception is recognized.

For LAT, the second operand is treated as a 32-bit signed integer and placed in bit positions 32-63 of general register R1, and bit positions 0-31 remain unchanged.

For LGAT, the second operand is treated as a 64-bit signed integer and placed in bit positions 0-63 of general register R1.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data
- Access (fetch, operand 2)
• Operation (if the load-and-trap facility is not installed)

Programming Note: Possible uses of LOAD AND TRAP include checking for pointers containing zero (null pointer).

LOAD AND ZERO RIGHTMOST BYTE

LZRF  \( R_1, D_2(X_2, B_2) \)  \( [RXY-a] \)

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 20 & 32 & 40 & 47 \\
\end{array}
\]

\[\text{‘E3’} \quad R_1 \quad X_2 \quad B_2 \quad DL_2 \quad DH_2 \quad \text{‘3B’}\]

LZRG  \( R_1, D_2(X_2, B_2) \)  \( [RXY-a] \)

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 20 & 32 & 40 & 47 \\
\end{array}
\]

\[\text{‘E3’} \quad R_1 \quad X_2 \quad B_2 \quad DL_2 \quad DH_2 \quad \text{‘2A’}\]

The second operand, with the rightmost byte set to zero, is placed at the first-operand location. For LZRF, the first and second operands are 32 bits, and for LZRG, the first and second operands are 64 bits.

The displacement is treated as a 20-bit signed binary integer.

It is unpredictable whether an access exception is recognized for the rightmost byte of the second operand.

Condition Code: The code remains unchanged.

Program Exceptions:

• Access (fetch, operand 2 of LB and LGB)
• Operation (LB and LGB, if the long-displacement facility is not installed; LBR and LGBR, if the extended-immediate facility is not installed)

LOAD BYTE

Register-and-register formats:

LBR  \( R_1, R_2 \)  \( [RRE] \)

\[
\begin{array}{cccc}
0 & 16 & 24 & 28 & 31 \\
\end{array}
\]

\[\text{‘B926’} \quad \text{‘/’/’/’/’/’/’/’/’/’} \quad R_1 \quad R_2]\n
LGBR  \( R_1, R_2 \)  \( [RRE] \)

\[
\begin{array}{cccc}
0 & 16 & 24 & 28 & 31 \\
\end{array}
\]

\[\text{‘B906’} \quad \text{‘/’/’/’/’/’/’/’/’/’} \quad R_1 \quad R_2]\n
The second operand is sign extended and placed at the first-operand location. The second operand is one byte in length and is treated as an eight-bit signed binary integer. For LOAD BYTE (LB and LGB), the second operand is a byte in storage. For LOAD BYTE (LBR and LGBR), the second operand is in bits 56-63 of general register \( R_2 \).

For LOAD BYTE (LB and LBR), the first operand is treated as a 32-bit signed binary integer. For LOAD BYTE (LGB and LGBR), the first operand is treated as a 64-bit signed binary integer.

The displacement for LB and LGB is treated as a 20-bit signed binary integer.

Condition Code: The code remains unchanged.

Program Exceptions:

• Access (fetch, operand 2 of LB and LGB)
• Operation (LB and LGB, if the long-displacement facility is not installed; LBR and LGBR, if the extended-immediate facility is not installed)

LOAD BYTE HIGH

Register-and-storage formats:

LB  \( R_1, D_2(X_2, B_2) \)  \( [RXY-a] \)

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 20 & 32 & 40 & 47 \\
\end{array}
\]

\[\text{‘E3’} \quad R_1 \quad X_2 \quad B_2 \quad DL_2 \quad DH_2 \quad \text{‘76’}\]

LGB  \( R_1, D_2(X_2, B_2) \)  \( [RXY-a] \)

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 20 & 32 & 40 & 47 \\
\end{array}
\]

\[\text{‘E3’} \quad R_1 \quad X_2 \quad B_2 \quad DL_2 \quad DH_2 \quad \text{‘77’}\]

The second operand is sign extended and placed at the first-operand location. The second operand is one byte in length and is treated as an eight-bit signed binary integer. For LOAD BYTE (LB and LGB), the second operand is a byte in storage. For LOAD BYTE (LBR and LGBR), the second operand is in bits 56-63 of general register \( R_2 \).

The first operand is treated as a 32-bit signed binary integer in bits 0-31 of general register \( R_1 \); bits 32-63 of the register are unchanged.
The displacement is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Operation (if the high-word facility is not installed)

---

**LOAD COMPLEMENT**

- **LCR** \( R_1, R_2 \) \([RR]\)
- **LCGR** \( R_1, R_2 \) \([RRE]\)
- **LCGFR** \( R_1, R_2 \) \([RRE]\)

The two's complement of the second operand is placed at the first-operand location. For LOAD COMPLEMENT (LCR), the second operand and result are treated as 32-bit signed binary integers. For LOAD COMPLEMENT (LCGR), they are treated as 64-bit signed binary integers. For LOAD COMPLEMENT (LCGFR), the second operand is treated as a 32-bit signed binary integer, and the result is treated as a 64-bit signed binary integer.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

**Resulting Condition Code:**
- 0 Result zero; no overflow
- 1 Result less than zero; no overflow
- 2 Result greater than zero; no overflow
- 3 Overflow

**Program Exceptions:**
- Fixed-point overflow (LCR and LCGR only)

**Programming Note:** The operation complements all numbers. Zero remains unchanged. For LCR or LCGR, the maximum negative 32-bit number or 64-bit number, respectively, remains unchanged, and an overflow condition occurs when the number is complemented. LCGFR complements the maximum negative 32-bit number without recognizing overflow.

---

**LOAD COUNT TO BLOCK BOUNDARY**

- **LCBB** \( R_1, D_2(X_2,B_2), M_3 \) \([RXE]\)

A 32-bit unsigned binary integer containing the number of bytes possible to load from the second operand location without crossing a specified block boundary, with a maximum of sixteen is placed in the first operand. If the number of bytes is greater than sixteen, sixteen is placed in the first operand.

The displacement is treated as a 12-bit unsigned integer.

The second operand address is not used to address data.

The \( M_3 \) field specifies a code that is used to signal the CPU as to the block boundary size to compute the number of possible bytes loaded. If a reserved value is specified then a specification exception is recognized.

<table>
<thead>
<tr>
<th>Code</th>
<th>Boundary</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>64-Byte</td>
</tr>
<tr>
<td>1</td>
<td>128-Byte</td>
</tr>
<tr>
<td>2</td>
<td>256-Byte</td>
</tr>
<tr>
<td>3</td>
<td>512-Byte</td>
</tr>
<tr>
<td>4</td>
<td>1K-Byte</td>
</tr>
<tr>
<td>5</td>
<td>2K-Byte</td>
</tr>
<tr>
<td>6</td>
<td>4K-Byte</td>
</tr>
<tr>
<td>7-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Resulting Condition Code:**
- 0 Operand one is sixteen
1. --
2. --
3. Operand one is less than sixteen

**Program Exceptions:**

- Operation (if the vector facility for z/Architecture is not installed)
- Specification

**Programming Note:** It is expected that LOAD COUNT TO BLOCK BOUNDARY will be used in conjunction with VECTOR LOAD TO BLOCK BOUNDARY to determine the number of bytes that were loaded.

**LOAD HALFWORD**

*Register-and-register formats:*

<table>
<thead>
<tr>
<th>LHRL</th>
<th>R1, Ri2</th>
<th>[RIL-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C4'</td>
<td>R1, '5'</td>
<td>Ri2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LGHRL</th>
<th>R1, Ri2</th>
<th>[RIL-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C4'</td>
<td>R1, '4'</td>
<td>Ri2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

*Register-and-storage formats:*

<table>
<thead>
<tr>
<th>LH</th>
<th>R1, Db(X2, B2)</th>
<th>[RX-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'48'</td>
<td>R1</td>
<td>X2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LHY</th>
<th>R1, Db(X2, B2)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td>R1</td>
<td>X2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LGH</th>
<th>R1, Db(X2, B2)</th>
<th>[RX-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td>R1</td>
<td>X2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

**LOAD HALFWORD IMMEDIATE**

<table>
<thead>
<tr>
<th>LHI</th>
<th>R1, I2</th>
<th>[RI-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'A7'</td>
<td>R1</td>
<td>'8'</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

The second operand is sign extended and placed at the first-operand location. The second operand is two bytes in length and is treated as a 16-bit signed binary integer. For LOAD HALFWORD (LH, LHY, and LGH) and LOAD HALFWORD RELATIVE LONG, the second operand is in storage. For LOAD HALFWORD (LHI and LGHI), the second operand is the immediate field of the instruction. For LOAD HALFWORD (LHR and LGHR), the second operand is in bits 48-63 of general register R2.

For LOAD HALFWORD (LH, LHR, and LHY), LOAD HALFWORD IMMEDIATE (LHI), and LOAD HALFWORD RELATIVE LONG (LHRL), the first operand is treated as a 32-bit signed binary integer. For LOAD HALFWORD (LGH and LGHR), LOAD HALFWORD IMMEDIATE (LGHI), and LOAD HALFWORD RELATIVE LONG (LGHRL), the first operand is treated as a 64-bit signed binary integer.

The displacement for LH is treated as a 12-bit unsigned binary integer. The displacement for LHY and LGH is treated as a 20-bit signed binary integer.

For LOAD HALFWORD RELATIVE LONG, the contents of the Ri2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand in storage. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

**Condition Code:** The code remains unchanged.
Program Exceptions:

- Access (fetch, operand 2 of LH, LHY, LGH, LHRL and LGHRL)
- Operation (LHY, if the long-displacement facility is not installed; LHR and LGHR, if the extended-immediate facility is not installed; LHRL and LGHRL, if the general-instructions-extension facility is not installed)

Programming Notes:

1. An example of the use of the LOAD HALFWORD instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. For LOAD HALFWORD RELATIVE LONG, the second operand is necessarily aligned on an integral boundary corresponding to the operand’s size.
3. When LOAD HALFWORD RELATIVE LONG is the target of an execute-type instruction, the second-operand address is relative to the target address.

LOAD HALFWORD HIGH

LHH \( R_1, D_2, (X_2, B_2) \) \[ RXY-a \]

The second operand is sign extended and placed at the first-operand location. The second operand is two bytes in length and is treated as an 16-bit signed binary integer.

The first operand is treated as a 32-bit signed binary integer in bits 0-31 of general register \( R_1 \); bits 32-63 of the register are unchanged.

The displacement is treated as a 20-bit signed binary integer.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (fetch, operand 2)
- Operation (if the high-word facility is not installed)

LOAD HALFWORD IMMEDIATE ON CONDITION

LOCHI \( R_1, I_2, M_3 \) \[ RIE-g \]

The second operand is sign extended and placed at the first-operand location if the condition code has one of the values specified by \( M_3 \); otherwise, the first operand remains unchanged.

For LOAD HALFWORD IMMEDIATE ON CONDITION (LOCHI), the first operand is treated as a 32-bit signed binary integer in bits 32-63 of general register \( R_1 \), and bits 0-31 of the register are unchanged. For LOAD HALFWORD HIGH IMMEDIATE ON CONDITION, the first operand is treated as a 32-bit signed binary integer in bits 0-31 of general register \( R_1 \), and bits 32-63 of the register are unchanged. For LOAD HALFWORD IMMEDIATE ON CONDITION (LOCGHI), the first operand is treated as a 64-bit signed binary integer in bits 0-63 of general register \( R_1 \).

The second operand is the two byte \( I_2 \) field of the instruction and is treated as a 16-bit signed binary integer.
The M³ field is used as a four-bit mask. The four condition codes (0, 1, 2, and 3) correspond, left to right, with the four bits of the mask, as follows:

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Mask Position Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
</tr>
<tr>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
</tr>
</tbody>
</table>

The current condition code is used to select the corresponding mask bit. If the mask bit selected by the condition code is one, the load is performed. If the mask bit selected is zero, the load is not performed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Operation (if the load/store-on-condition facility 2 is not installed)

**Programming Notes:** See programming note 4 on page 7-240 for details on extended mnemonics for the instructions of the load/store-on-condition facilities.

### LOAD HIGH

**Register-and-register format:**

\[
\text{LFH} \quad R_1, D_1(X_2, B_2) \quad [RXY-a]
\]

<table>
<thead>
<tr>
<th>'E3'</th>
<th>( R_1 )</th>
<th>X₂</th>
<th>B₂</th>
<th>DL₂</th>
<th>DH₂</th>
<th>'CA'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>47</td>
</tr>
</tbody>
</table>

The second operand is placed unchanged at the first operand location. The second operand is 32 bits, and the first operand is in bits 0-31 of general register \( R_1 \); bits 32-63 of the register are unchanged.

The displacement is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Operation (if the high-word facility is not installed)

### LOAD HIGH AND TRAP

**Register-and-register format:**

\[
\text{LFHAT} \quad R_1, D_1(X_2, B_2) \quad [RXY-a]
\]

<table>
<thead>
<tr>
<th>'E3'</th>
<th>( R_1 )</th>
<th>X₂</th>
<th>B₂</th>
<th>DL₂</th>
<th>DH₂</th>
<th>'C8'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>47</td>
</tr>
</tbody>
</table>

The second operand is treated as a 32-bit signed integer and placed unchanged in bit positions 0-31 of general register \( R_1 \), and bit positions 32-63 remain unchanged. If all zeros are placed at the first operand location, a compare-and-trap-instruction data exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data
- Access (fetch, operand 2)
- Operation (if the load-and-trap facility is not installed)

**Programming Note:** Possible uses of LOAD HIGH AND TRAP include checking for pointers containing zero (null pointer).

### LOAD LOGICAL

**Register-and-register format:**

\[
\text{LLGFR} \quad R_1, R_2 \quad [RRE]
\]

<table>
<thead>
<tr>
<th>'B916'</th>
<th>( ////// // R_1 )</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8 12 16 20 32 40 47</td>
</tr>
</tbody>
</table>

**Register-and-storage format:**

\[
\text{LLGF} \quad R_1, D_1(X_2, B_2) \quad [RXY-a]
\]

<table>
<thead>
<tr>
<th>'E3'</th>
<th>( R_1 )</th>
<th>X₂</th>
<th>B₂</th>
<th>DL₂</th>
<th>DH₂</th>
<th>'16'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>47</td>
</tr>
</tbody>
</table>

### LOAD LOGICAL RELATIVE LONG

**Register-and-register format:**

\[
\text{LLGFRL} \quad R_1, R_1 \quad [RIL-b]
\]

<table>
<thead>
<tr>
<th>'C4'</th>
<th>( R_1 )</th>
<th>'E'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8 12 16 20 32 40 47</td>
<td></td>
</tr>
</tbody>
</table>

The four-byte second operand is placed in bit positions 32-63 of general register \( R_1 \), and zeros are placed in bit positions 0-31 of general register \( R_1 \).
For LOAD LOGICAL (LLGF), the second operand is in bit positions 32-63 of general register R2.

For LOAD LOGICAL RELATIVE LONG, the contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand in storage. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

For LOAD LOGICAL RELATIVE LONG, the second operand must be aligned on a word boundary; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 of LLGF and LLGFRL only)
- Operation (LLGFRL, if the general-instructions-extension facility is not installed)
- Specification (LLGFRL only)

**LOAD LOGICAL AND Trap**

\[
\text{LLGFAT} \quad \text{R}_1,\text{D}_2(\text{X}_2,\text{B}_2) [\text{RXY-a}]
\]

The four-byte second operand is placed unchanged in bit positions 32-63 of general register R1, and zeros are placed in bit positions 0-31. If all zeros are placed at the first operand location, a compare-and-trap-instruction data exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data
- Access (fetch, operand 2)
- Operation (if the load-and-trap facility is not installed)

**Programming Note:** Possible uses of LOAD LOGICAL AND TRAP include checking for pointers containing zero (null pointer).

**LOAD LOGICAL AND ZERO RIGHTMOST BYTE**

\[
\text{LLZRGF} \quad \text{R}_1,\text{D}_2(\text{X}_2,\text{B}_2) [\text{RXY-a}]
\]

The four-byte second operand, with the rightmost byte set to zero, is placed in bit positions 32-63 of general register R1, and zeros are placed in bit positions 0-31 of the register.

The displacement is treated as a 20-bit signed binary integer.

It is unpredictable whether an access exception is recognized for the rightmost byte of the second operand.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Operation (if the load-and-zero-rightmost-byte facility is not installed)

**LOAD LOGICAL CHARACTER**

**Register-and-register formats:**

\[
\text{LLCR} \quad \text{R}_1,\text{R}_2 [\text{RRE}]
\]

\[
\text{LLGCR} \quad \text{R}_1,\text{D}_2(\text{X}_2,\text{B}_2) [\text{RXY-a}]
\]

**Register-and-storage formats:**

\[
\text{LLC} \quad \text{R}_1,\text{D}_2(\text{X}_2,\text{B}_2) [\text{RXY-a}]
\]

\[
\text{LLGC} \quad \text{R}_1,\text{D}_2(\text{X}_2,\text{B}_2) [\text{RXY-a}]
\]
The one-byte second operand is placed in bit positions 56-63 of general register \( R_1 \). For LOAD LOGICAL CHARACTER (LLGC, LLGCR), zeros are placed in bit positions 0-55 of general register \( R_1 \). For LOAD LOGICAL CHARACTER (LLC, LLCR), zeros are placed in bit positions 32-55 of general register \( R_1 \); bit positions 0-31 of general register \( R_1 \) are unchanged.

For LOAD LOGICAL CHARACTER (LLC, LLGC), the second operand is in storage. For LOAD LOGICAL CHARACTER (LLCR, LLGCR), the second operand is in bits 56-63 of general register \( R_2 \).

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 of LLC and LLGC)
- Operation (LLC, LLCR, and LLGCR, if the extended-immediate facility is not installed)

### LOAD LOGICAL CHARACTER HIGH

**Register-and-register formats:**

\[
\text{LLHR} \quad R_1, R_2 \quad \text{[RRE]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B995'</td>
<td></td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

**Register-and-storage formats:**

\[
\text{LLH} \quad R_1, D_2(X_2, B_2) \quad \text{[RXY-a]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td></td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

\[
\text{LLGH} \quad R_1, D_2(X_2, B_2) \quad \text{[RXY-a]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td></td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

### LOAD LOGICAL HALFWORD RELATIVE LONG

**Register-and-register formats:**

\[
\text{LLHR} \quad R_1, R_2 \quad \text{[RRE]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C4'</td>
<td></td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

\[
\text{LLGHR} \quad R_1, R_2 \quad \text{[RRE]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C4'</td>
<td></td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

### LOAD LOGICAL HALFWORD

**Register-and-register formats:**

\[
\text{LLHR} \quad R_1, R_2 \quad \text{[RRE]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B995'</td>
<td></td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

**Register-and-storage formats:**

\[
\text{LLH} \quad R_1, D_2(X_2, B_2) \quad \text{[RXY-a]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td></td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

\[
\text{LLGH} \quad R_1, D_2(X_2, B_2) \quad \text{[RXY-a]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td></td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

### LOAD LOGICAL HALFWORD RELATIVE LONG

**Register-and-register formats:**

\[
\text{LLHR} \quad R_1, R_2 \quad \text{[RRE]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C4'</td>
<td></td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

\[
\text{LLGHR} \quad R_1, R_2 \quad \text{[RRE]}
\]

<table>
<thead>
<tr>
<th>Code</th>
<th>Format</th>
<th>LI</th>
<th>SI</th>
</tr>
</thead>
<tbody>
<tr>
<td>'C4'</td>
<td></td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>
HALFWORD (LLGHR, LLHR), the second operand is in bits 48-63 of general register \( R_2 \).

For LOAD LOGICAL HALFWORD RELATIVE LONG, the contents of the \( R_{i2} \) field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand in storage. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of LLGH, LLH, LLHRL, and LLGHRL)
- Operation (LLGHR, LLH, and LLHR, if the extended-immediate facility is not installed; LLHRL and LLGHRL, if the general-instructions-extension facility is not installed)

**Programming Notes:**

1. For LOAD LOGICAL HALFWORD RELATIVE LONG, the second operand is necessarily aligned on an integral boundary corresponding to the operand’s size.
2. When LOAD LOGICAL HALFWORD RELATIVE LONG is the target of an execute-type instruction, the second-operand address is relative to the target address.

### LOAD LOGICAL HALFWORD HIGH

\[
\text{LLHH} \quad R_{i1}, D_2(X_2, B_2) \quad [\text{RXY-a}]
\]

The two-byte second operand is placed in bit positions 16-31 of general register \( R_1 \); bits positions 32-63 of general register \( R_1 \) are unchanged.

The displacement is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2)
- Operation (if the high-word facility is not installed)

### LOAD LOGICAL IMMEDIATE

\[
\begin{align*}
\text{LLIHF} & \quad R_{i1}, I_2 \quad [\text{RIL-a}] \\
\text{LLIH} & \quad R_{i1}, I_2 \quad [\text{RIL-a}] \\
\text{LHIL} & \quad R_{i1}, I_2 \quad [\text{RI-a}] \\
\text{LHILF} & \quad R_{i1}, I_2 \quad [\text{RI-a}] \\
\text{LHILF} & \quad R_{i1}, I_2 \quad [\text{RI-a}] \\
\text{LHILF} & \quad R_{i1}, I_2 \quad [\text{RI-a}] \\
\text{LLILF} & \quad R_{i1}, I_2 \quad [\text{RI-a}] \\
\end{align*}
\]

The second operand is placed in bit positions of the first operand. The remainder of the first operand is set to zeros.

For each instruction, the bit positions of the first operand that are loaded with the second operand are as follows:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Bit Positions Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>LLIHF</td>
<td>0-31</td>
</tr>
</tbody>
</table>
LOAD MULTIPLE

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Bit Positions Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>LLIHH</td>
<td>0-15</td>
</tr>
<tr>
<td>LLIHL</td>
<td>16-31</td>
</tr>
<tr>
<td>LLILF</td>
<td>32-63</td>
</tr>
<tr>
<td>LLILH</td>
<td>32-47</td>
</tr>
<tr>
<td>LLILL</td>
<td>48-63</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Operation (LLIHF and LLILF, if the extended-immediate facility is not installed)

LOAD LOGICAL THIRTY ONE BITS

**Register-and-register format:**

<table>
<thead>
<tr>
<th>LLGTR R1,R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B917'</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit Positions</th>
<th>Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>R1</td>
</tr>
<tr>
<td>16</td>
<td>R2</td>
</tr>
</tbody>
</table>

**Register-and-storage format:**

<table>
<thead>
<tr>
<th>LLGT R1,D2(X2,B2)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td>R1, X2, B2, DL2, DH2, '17'</td>
</tr>
</tbody>
</table>

For LLGTR, bits 33-63 of general register R2, with 33 zeros appended on the left, are placed in general register R1. For LLGT, bits 1-31 of the four bytes at the second-operand location, with 33 zeros appended on the left, are placed in general register R1.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)

LOAD LOGICAL THIRTY ONE BITS AND TRAP

<table>
<thead>
<tr>
<th>LLGTAT R1,D2(X2,B2)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td>R1, X2, B2, DL2, DH2, '9C'</td>
</tr>
</tbody>
</table>

For LLGTAT, bits 33-63 of general register R2, with 33 zeros appended on the left, are placed unchanged in bit positions 33-63 of general register R1, and zeros are placed in bit positions 0-32. If all zeros are placed at the first operand location, a compare-and-trap-instruction data exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data
- Access (fetch, operand 2)
- Operation (if the load-and-trap facility is not installed)

**Programming Note:** Possible uses of LOAD LOGICAL THIRTY ONE BITS AND TRAP include checking for pointers containing zero (null pointer).

LOAD MULTIPLE

<table>
<thead>
<tr>
<th>LM R1,R3,D2(B2)</th>
<th>[RS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'98' R1, R3, B2</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit Positions</th>
<th>Loaded</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>R1</td>
</tr>
<tr>
<td>8</td>
<td>R3</td>
</tr>
<tr>
<td>12</td>
<td>B2</td>
</tr>
<tr>
<td>16</td>
<td>D2</td>
</tr>
</tbody>
</table>

Bit positions of the set of general registers starting with general register R1 and ending with general register R3 are loaded from storage beginning at the location designated by the second-operand address and continuing through as many locations as needed.

For LOAD MULTIPLE (LM, LMY), bit positions 32-63 of the general registers are loaded from successive four-byte fields beginning at the second-operand address, and bits 0-31 of the registers remain unchanged. For LOAD MULTIPLE (LMG), bit positions 0-63 of the general registers are loaded from successive eight-byte fields beginning at the second-operand address.
The general registers are loaded in the ascending order of their register numbers, starting with general register R1 and continuing up to and including general register R3, with general register 0 following general register 15.

The displacement for LM is treated as a 12-bit unsigned binary integer. The displacement for LMY and LMG is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Operation (LMY, if the long-displacement facility is not installed)

**Programming Note:** All combinations of register numbers specified by R1 and R3 are valid. When the register numbers are equal, only four bytes, for LM or LMY or eight bytes, for LMG, are transmitted. When the number specified by R3 is less than the number specified by R1, the register numbers wrap around from 15 to 0.

**LOAD MULTIPLE DISJOINT**

```
LMD   R1, R3, D2(B2), D4(B4) [SS-e]
```

Bit positions 0-31 of the set of general registers starting with general register R1 and ending with general register R3 are loaded from storage beginning at the location designated by the second-operand address and continuing through as many locations as needed. Bit positions 32-63 of the same registers are similarly loaded from storage beginning at the location designated by the fourth-operand address.

The general registers are loaded in the ascending order of their register numbers, starting with general register R1 and continuing up to and including general register R3, with general register 0 following general register 15.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operands 2 and 4)
- Transaction constraint

**Programming Notes:**
1. All combinations of register numbers specified by R1 and R3 are valid. When the register numbers are equal, only eight bytes are transmitted. When the number specified by R3 is less than the number specified by R1, the register numbers wrap around from 15 to 0.
2. The second-operand and fourth-operand addresses are computed before the contents of any register are changed.
3. The combination of a LOAD MULTIPLE instruction and a LOAD MULTIPLE HIGH instruction provides equal or better performance than a LOAD MULTIPLE DISJOINT instruction for the same register range. LOAD MULTIPLE DISJOINT is for use when the second or fourth operand must be addressed by means of one of the registers loaded.

**LOAD MULTIPLE HIGH**

```
LMH   R1, R3, D2(B2) [RSY-a]
```

The high-order halves, bit positions 0-31, of the set of general registers starting with general register R1 and ending with general register R3 are loaded from storage beginning at the location designated by the second-operand address and continuing through as many locations as needed, that is, bit positions 0-31 are loaded from successive four-byte fields beginning at the second-operand address. Bits 32-63 of the registers remain unchanged.

The general registers are loaded in the ascending order of their register numbers, starting with general register R1 and continuing up to and including general register R3, with general register 0 following general register 15.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
**Programming Note:** All combinations of register numbers specified by \( R_1 \) and \( R_3 \) are valid. When the register numbers are equal, only four bytes are transmitted. When the number specified by \( R_3 \) is less than the number specified by \( R_1 \), the register numbers wrap around from 15 to 0.

**LOAD NEGATIVE**

\[
\text{LNR} \quad R_1, R_2 \quad \text{[RR]}
\]

\[
\begin{array}{c|cccc}
 & \text{‘11’} & R_1 & R_2 \\
\hline
0 & 8 & 12 & 15
\end{array}
\]

\[
\text{LNGR} \quad R_1, R_2 \quad \text{[RRE]}
\]

\[
\begin{array}{c|cccc}
 & \text{‘B901’} & 0 & 16 & 24 \\
\hline
0 & 8 & 12 & 15 & 28 & 31
\end{array}
\]

\[
\text{LNGFR} \quad R_1, R_2 \quad \text{[RRE]}
\]

\[
\begin{array}{c|cccc}
 & \text{‘B911’} & 0 & 16 & 24 \\
\hline
0 & 8 & 12 & 15 & 28 & 31
\end{array}
\]

The two’s complement of the absolute value of the second operand is placed at the first-operand location. For LOAD NEGATIVE (LNR), the second operand and result are treated as 32-bit signed binary integers, and, for LOAD NEGATIVE (LNGR), they are treated as 64-bit signed binary integers. For LOAD NEGATIVE (LNGFR), the second operand is treated as a 32-bit signed binary integer, and the result is treated as a 64-bit signed binary integer.

**Resulting Condition Code:**

- 0 Result zero
- 1 Result less than zero
- 2 --
- 3 --

**Program Exceptions:** None.

**Programming Note:** The operation complements positive numbers; negative numbers remain unchanged. The number zero remains unchanged.

**LOAD ON CONDITION**

**Register-and-register formats:**

\[
\text{LOCR} \quad R_1, R_2, M_3 \quad \text{[RRF-c]}
\]

\[
\begin{array}{c|cccc}
\text{‘B9F2’} & M_3 & \ldots & R_1 & R_2 \\
\hline
0 & 16 & 20 & 24 & 28 & 31
\end{array}
\]

\[
\text{LOCGR} \quad R_1, R_2, M_3 \quad \text{[RRF-c]}
\]

\[
\begin{array}{c|cccc}
\text{‘B9E2’} & M_3 & \ldots & R_1 & R_2 \\
\hline
0 & 16 & 20 & 24 & 28 & 31
\end{array}
\]

**Register-and-storage formats:**

\[
\text{LOC} \quad R_1, D_2(B_2), M_3 \quad \text{[RSY-b]}
\]

\[
\begin{array}{c|cccc}
\text{‘EB’} & R_1 & M_3 & B_2 & \ldots \\
\hline
0 & 8 & 12 & 16 & 20 & 32 & 40 & 47
\end{array}
\]

\[
\text{LOCG} \quad R_1, D_2(B_2), M_3 \quad \text{[RSY-b]}
\]

\[
\begin{array}{c|cccc}
\text{‘EB’} & R_1 & M_3 & B_2 & \ldots \\
\hline
0 & 8 & 12 & 16 & 20 & 32 & 40 & 47
\end{array}
\]

**LOAD HIGH ON CONDITION**

**Register-and-register formats:**

\[
\text{LOCFHR} \quad R_1, R_2, M_3 \quad \text{[RRF-c]}
\]

\[
\begin{array}{c|cccc}
\text{‘B9E0’} & M_3 & \ldots & R_1 & R_2 \\
\hline
0 & 16 & 20 & 24 & 28 & 31
\end{array}
\]

\[
\text{LOCFH} \quad R_1, D_2(B_2), M_3 \quad \text{[RSY-b]}
\]

\[
\begin{array}{c|cccc}
\text{‘EB’} & R_1 & M_3 & B_2 & \ldots \\
\hline
0 & 8 & 12 & 16 & 20 & 32 & 40 & 47
\end{array}
\]

The second operand is placed unchanged at the first-operand location if the condition code has one of the values specified by \( M_3 \); otherwise, the first operand remains unchanged.

**Program Exceptions:** None.

**Programming Note:** The operation complements positive numbers; negative numbers remain unchanged. The number zero remains unchanged.

For LOC, LOCFH, LOCFHR, and LOCR, the first and second operands are 32 bits, and for LOCG and LOCGR, the first and second operands are 64 bits.

For LOC and LOCR, the first operand is in bits 32-63 of general register \( R_1 \), and bits 0-31 of the register are unchanged. For LOCFH and LOCFHR, the first operand is in bits 0-31 of general register \( R_1 \), and bits 32-63 of the register are unchanged.

For LOCR, the second operand is in bits 32-63 of general register \( R_2 \), and bits 0-31 of the register are unchanged.
ignored. For LOCFHR, the second operand is in bits 0-31 of general register R2, and bits 32-63 of the register are ignored.

The M3 field is used as a four-bit mask. The four condition codes (0, 1, 2, and 3) correspond, left to right, with the four bits of the mask, as follows:

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Mask Position Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
</tr>
<tr>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
</tr>
</tbody>
</table>

The current condition code is used to select the corresponding mask bit. If the mask bit selected by the condition code is one, the load is performed. If the mask bit selected is zero, the load is not performed.

The displacement for LOC, LOCFH, and LOCG is treated as a 20-bit signed binary integer.

For LOC, LOCFH, and LOCG, when the condition specified by the M3 field is not met (that is, the load operation is not performed), it is model dependent whether an access exception or a PER zero-address detection event is recognized for the second operand.

**Condition Code**: The code remains unchanged.

**Program Exceptions**:  
- Access (fetch, operand 2 of LOC, LOCFH, and LOCG)
- Operation (LOC, LOCG, LOCGR, LOCIBM, if the load/store-on-condition facility 1 is not installed; LOCFH, LOCFHR, if the load/store-on-condition facility 2 is not installed)

**Programming Notes**:  
1. When the M3 field contain all zeros and no exception condition exists, the instruction acts as a NOP. When the M3 field contains all ones and no exception condition exists, the load operation is always performed. However, these are not the preferred means of implementing a NOP or unconditional load, respectively.

2. For LOC, LOCFH, and LOCG, when the condition specified by the M3 field is not met, it is model dependent whether the second operand is brought into the cache.

3. LOAD ON CONDITION provides a function similar to that of a separate BRANCH ON CONDITION instruction followed by a LOAD instruction, except that LOAD ON CONDITION does not provide an index register. For example, the following two instruction sequences are equivalent.

```
LOC 15,256(7),8 BC 7,SKIP
LG 15,256(0,7)
SKIP DS 0H
```

On models that implement predictive branching, the combination of the BRANCH ON CONDITION and LOAD instructions may perform somewhat better than the LOAD ON CONDITION instruction when the CPU is able to successfully predict the branch condition. However, on models where the CPU is not able to successfully predict the branch condition, such as when the condition is more random, the LOAD ON CONDITION instruction may provide significant performance improvement.

4. The High-Level Assembler (HLASM) provides the following extended-mnemonic suffixes for the load/store-on-condition facilities’ instructions in place of the M3 field.

<table>
<thead>
<tr>
<th>Suffix</th>
<th>Meaning</th>
<th>Effective M3 Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>E</td>
<td>Equal</td>
<td>B’1000’</td>
</tr>
<tr>
<td>L</td>
<td>Low</td>
<td>B’0100’</td>
</tr>
<tr>
<td>H</td>
<td>High</td>
<td>B’0010’</td>
</tr>
<tr>
<td>NE</td>
<td>Not equal</td>
<td>B’0110’</td>
</tr>
<tr>
<td>NL</td>
<td>Not low</td>
<td>B’1011’</td>
</tr>
<tr>
<td>NH</td>
<td>Not high</td>
<td>B’1110’</td>
</tr>
</tbody>
</table>

Later versions of HLASM provide the following extended-mnemonic suffixes for the load/store-
on-condition facilities’ instructions in place of the M₃ field.

When the extended mnemonic is coded, the M₃ field must be omitted.

**LOAD PAIR DISJOINT**

<table>
<thead>
<tr>
<th>Suffix</th>
<th>Meaning</th>
<th>Effective M₃ Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Z</td>
<td>Zero</td>
<td>B'1000'</td>
</tr>
<tr>
<td>M</td>
<td>Minus or mixed</td>
<td>B'0100'</td>
</tr>
<tr>
<td>P</td>
<td>Plus</td>
<td>B'0010'</td>
</tr>
<tr>
<td>O</td>
<td>Overflow or ones</td>
<td>B'0001'</td>
</tr>
<tr>
<td>NZ</td>
<td>Not zero</td>
<td>B'0111'</td>
</tr>
<tr>
<td>NM</td>
<td>Not minus or not mixed</td>
<td>B'1011'</td>
</tr>
<tr>
<td>NP</td>
<td>Not plus</td>
<td>B'1101'</td>
</tr>
<tr>
<td>NO</td>
<td>Not overflow or not ones</td>
<td>B'1110'</td>
</tr>
</tbody>
</table>

When the extended mnemonic is coded, the M₃ field must be omitted.

The displacement of the first and second operands is treated as a 12-bit unsigned binary integer.

The first and second operands of LPD must be designated on a word boundary. The first and second operands of LPDG must be designated on a double-word boundary. General register R₃ must designate the even numbered register. Otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Register pair loaded by means of interlocked fetch
1  --
2  --
3  Register pair not loaded by means of interlocked fetch

**Program Exceptions:**

- Access (fetch, operands 1 and 2)
- Operation (if the interlocked-access facility 1 is not installed)
- Specification

**Programming Notes:**

1. The setting of the condition code is dependent upon storage accesses by other CPUs in the configuration.
2. When the resulting condition code is 3, the program may branch back to reexecute the LOAD PAIR DISJOINT instruction. However, after repeated unsuccessful attempts to attain an interlocked fetch, the program should use an alternate means of serializing access to the storage operands. It is recommended that the program reexecute the LOAD PAIR DISJOINT no more than 10 times before branching to the alternate path.
3. The program should be able to accommodate a situation where condition code 0 is never set.
LOAD PAIR FROM QUADWORD

LOAD PAIR FROM QUADWORD

The quadword second operand is loaded into the first-operand location. The second operand appears to be fetched with quadword concurrency as observed by other CPUs. The left doubleword of the quadword is loaded into general register $R_1$, and the right doubleword is loaded into general register $R_1 + 1$.

The $R_1$ field designates an even-odd pair of general registers and must designate an even-numbered register. The second operand must be designated on a quadword boundary. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2)
- Specification
- Transaction constraint

**Programming Notes:**

1. The LOAD MULTIPLE (LM or LMG) instruction does not necessarily provide quadword-concurrent access.

2. The performance of LOAD PAIR FROM QUADWORD on some models may be significantly slower than that of LOAD MULTIPLE (LMG). Unless quadword consistency is required, LMG should be used instead of LPQ.

LOAD POSITIVE

LOAD REVERSED

The absolute value of the second operand is placed at the first-operand location. For LOAD POSITIVE (LPR), the second operand and result are treated as 32-bit signed binary integers, and, for LOAD POSITIVE (LPGR), they are treated as 64-bit signed binary integers. For LOAD POSITIVE (LPGFR), the second operand is treated as a 32-bit signed binary integer, and the result is treated as a 64-bit signed binary integer.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

**Resulting Condition Code:**

- 0 Result zero; no overflow
- 1 --
- 2 Result greater than zero; no overflow
- 3 Overflow

**Program Exceptions:**

- Fixed-point overflow (LPR and LPGR only)

**Programming Note:** The operation complements negative numbers; positive numbers and zero remain unchanged. For LPR or LPGR, an overflow condition occurs when the maximum negative 32-bit number or 64-bit number, respectively, is complemented; the number remains unchanged. LPGFR complements the maximum negative 32-bit number without recognizing overflow.

LOAD REVERSED

Register-and-register formats:
Register-and-storage formats:

<table>
<thead>
<tr>
<th>Register</th>
<th>R1, D1(X2, B2)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>LRH</td>
<td>'E1' R1 X2 B2 DL2 DH2 '1F'</td>
<td></td>
</tr>
<tr>
<td>LRV</td>
<td>'E1' R1 X2 B2 DL2 DH2 '1E'</td>
<td></td>
</tr>
<tr>
<td>LRVG</td>
<td>'E1' R1 X2 B2 DL2 DH2 '0F'</td>
<td></td>
</tr>
</tbody>
</table>

The second operand is placed at the first-operand location with the left-to-right sequence of the bytes reversed.

For LOAD REVERSED (LRVH), the second operand is two bytes, the result is placed in bit positions 48-63 of general register R1, and bits 0-47 of the register remain unchanged.

For LOAD REVERSED (LRVR, LRV), the second operand is four bytes, the result is placed in bit positions 32-63 of general register R1, and bits 0-31 of the register remain unchanged. For LOAD REVERSED (LRVR), the second operand is in bit positions 32-63 of general register R2.

For LOAD REVERSED (LRVGR, LRVG), the second operand is eight bytes.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of LRVH, LRV, LRVG only)

**Programming Notes:**

1. The instruction can be used to convert two, four, or eight bytes from a “little-endian” format to a “big-endian” format, or vice versa. In the big-endian format, the bytes in a left-to-right sequence are in the order most significant to least significant. In the little-endian format, the bytes are in the order least significant to most significant. For example, the bytes ABCD in the big-endian format are DCBA in the little-endian format.

2. LOAD REVERSED (LRVR) can be used with a two-byte value already in a register as shown in the following example. In the example, the two bytes of interest are in bit positions 48-63 of the R1 register.

   LRVR R1,R1
   SRA R1,16

   The LOAD REVERSED instruction places the two bytes of interest in bit positions 32-47 of the register, with the order of the bytes reversed. The SHIFT RIGHT SINGLE (SRA) instruction shifts the two bytes to bit positions 48-63 of the register and extends them on their left, in bit positions 32-47, with their sign bit. The instruction SHIFT RIGHT SINGLE LOGICAL (SRL) should be used, instead, if the two bytes of interest are unsigned.

3. The storage-operand references of LOAD REVERSED may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

**MONITOR CALL**

<table>
<thead>
<tr>
<th>MC</th>
<th>D1(B1), I2</th>
<th>[SI]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'AF'</td>
<td>I2 B1 D1</td>
<td></td>
</tr>
</tbody>
</table>
When the monitor-mask bit corresponding to the specified monitor class is one, a monitor event occurs. When the monitor-mask bit corresponding to the specified monitor class is zero, no monitor-event occurs, and the instruction is executed as a no-operation.

When the enhanced-monitor facility is installed, the enhanced-monitor-mask bits are in bit positions 16-31 of control register 8, which correspond to monitor classes 0-15 respectively. When a monitor event occurs and either (a) the enhanced-monitor facility is not installed, or (b) the facility is installed but the enhanced-monitor-mask bit corresponding to the monitor class is zero, then a monitor-event program interruption occurs, as described below. When a monitor event occurs and the enhanced-monitor-mask bit corresponding to the monitor class is one, a monitor-event counting operation is performed.

The first-operand address is not used to address data; instead, the address specified by the B₁ and D₁ fields forms the monitor code. Address computation follows the rules of address arithmetic; in the 24-bit addressing mode, bits 0-39 are set to zeros; in the 31-bit addressing mode, bits 0-32 are set to zeros.

**Monitor-Event Program Interruption**

When a monitor-event program interruption occurs:

- The monitor code formed by the first-operand address is placed in the doubleword at real location 176.
- The contents of the I₂ field are stored at real location 149, with zeros stored at real location 148.
- Bit 9 of the program-interruption code is set to one.

**Monitor-Event Counting Operation**

The monitor-event counting operation is described in “Monitor-Event Counting” on page 5-110.

**Special Conditions**

Bit positions 8-11 of the instruction must contain zeros; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Monitor event
- Specification
- Transaction constraint

**Programming Notes:**

1. The monitor-event program interruption provides the capability for passing control to a monitoring program when selected points are reached in the monitored program. This is accomplished by implanting MONITOR CALL instructions at the desired points in the monitored program. This function may be useful in performing various measurement functions; specifically, tracing information can be generated indicating which programs were executed, counting information can be generated indicating how often particular programs were used, and timing information can be generated indicating the amount of time a particular program required for execution.

2. The monitor masks provide a means of disallowing all monitor events or allowing monitor events for all or selected classes.

3. When used to generate a monitor-event program interruption, the monitor code provides a means of associating descriptive information, in addition to the class number, with each MONITOR CALL.

Without the use of a base register, up to 4,096 distinct monitor codes can be associated with a monitor event. With the base register designated by a nonzero value in the B₁ field, each monitoring interruption can be identified by a 24-bit, 31-bit, or 64-bit code, depending on the addressing mode.

**MOVE**

**Storage-and-storage format:**

<table>
<thead>
<tr>
<th>MVC</th>
<th>D₁(B₁),D₂(B₂)</th>
<th>[SS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>&quot;D2&quot;</td>
<td>L</td>
<td>B₁</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>16</td>
</tr>
</tbody>
</table>

**Storage-and-immediate formats:**

<table>
<thead>
<tr>
<th>MVHHI</th>
<th>D₁(B₁),I₂</th>
<th>[SIL]</th>
</tr>
</thead>
<tbody>
<tr>
<td>&quot;E544&quot;</td>
<td>B₁</td>
<td>D₁</td>
</tr>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>
MOVE INVERSE

MOVE INVERSE

MVHI D1(B1),I2 [SIL]

MVGHI D1(B1),I2 [SIL]

MVI D1(B1),I2 [SI]

MVIY D1(B1),I2 [SIY]

The second operand is placed at the first-operand location.

For MOVE (MVC), each operand is processed left to right. When the operands overlap, the result is obtained as if the operands were processed one byte at a time and each result byte were stored immediately after fetching the necessary operand byte.

For MOVE (MVI, MVIY), the first operand is one byte in length, and only one byte is stored.

For MOVE (MVGHI, MVHHI, and MVHI), the second operand is treated as a 16-bit signed integer, sign-extended as necessary, and placed in the first-operand location. The first operand is two, four, or eight bytes for MVHHI, MVHI, and MVGHI, respectively.

The displacements for MVGHI, MVHHI, MVHI, MVI and both operands of MVC are treated as 12-bit unsigned binary integers. The displacement for MVIY is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of MVC; store, operand 1, MVC, MVGHI, MVHHI, MVHI, MVI, and MVIY)
- Operation (MVIY, if the long-displacement facility is not installed; MVGHI, MVHHI, and MVHI, if the general-instructions-extension facility is not installed)

MOVCIN D1(L,B1),D2(B2) [SS-a]

The second operand is placed at the first-operand location with the left-to-right sequence of the bytes inverted.

The first-operand address designates the leftmost byte of the first operand. The second-operand address designates the rightmost byte of the second operand. Both operands have the same length.

The result is obtained as if the second operand were processed from right to left and the first operand from left to right. The second operand may wrap around from location 0 to location $2^{24} - 1$ in the 24-bit addressing mode, to location $2^{31} - 1$ in the 31-bit addressing mode, or to location $2^{64} - 1$ in the 64-bit addressing mode. The first operand may wrap around from location $2^{24} - 1$ to location 0 in the 24-bit addressing mode, from location $2^{31} - 1$ to location 0 in the 31-bit addressing mode, or from location $2^{64} - 1$ to location 0 in the 64-bit addressing mode.

When the operands overlap by more than one byte, the contents of the overlapped portion of the result field are unpredictable.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Transaction constraint
Programming Notes:

1. An example of the use of the MOVE INVERSE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The contents of each byte moved remain unchanged.

3. MOVE INVERSE is the only SS-format instruction for which the second-operand address designates the rightmost, instead of the leftmost, byte of the second operand.

4. The storage-operand references for MOVE INVERSE may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123)

MOVE LONG

MVCL R1, R2 [RR]

The second operand is placed at the first-operand location, provided overlapping of operand locations would not affect the final contents of the first-operand location. The remaining rightmost byte positions, if any, of the first-operand location are filled with padding bytes.

The R1 and R2 fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and second operand is designated by the contents of general registers R1 +1 and R2 +1, respectively. The number of bytes in the first-operand and second-operand locations is specified by unsigned binary integers in bit positions 40-63 of general registers R1 +1 and R2 +1, respectively. Bit positions 32-39 of general register R2 +1 contain the padding byte. The contents of bit positions 0-39 of general register R1 +1 and of bit positions 0-31 of general register R2 +1 are ignored.

The handling of the addresses in general registers R1 and R2 is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R2 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The contents of the registers just described are shown in Figure 7-253 on page 7-247.

The result is obtained as if the movement starts at the left end of both fields and proceeds to the right, byte by byte. The operation is ended when the number of bytes specified by bits 40-63 of general register R1 +1 have been moved into the first-operand location. If the second operand is shorter than the first operand, the remaining rightmost bytes of the first-operand location are filled with the padding byte.

As part of the execution of the instruction, the values of the two length fields are compared for the setting of the condition code, and a check is made for destructive overlap of the operands. Operands are said to overlap destructively when the first-operand location is used as a source after data has been moved into it, assuming the inspection for overlap is performed by the use of logical operand addresses. When the operands overlap destructively, no movement takes place, and condition code 3 is set.

Operands do not overlap destructively, and movement is performed, if the leftmost byte of the first operand does not coincide with any of the second-operand bytes participating in the operation other than the leftmost byte of the second operand. When an operand wraps around from location 224 -1 (or 231 -1 or 264 -1) to location 0, operand bytes in locations up to and including 224 -1 (or 231 -1 or 264 -1) are considered to be to the left of bytes in locations from 0 up.

In the 24-bit addressing mode, wraparound is from location 224 -1 to location 0; in the 31-bit addressing mode, wraparound is from location 231 -1 to location 0; in the 64-bit addressing mode, wraparound is from location 264 -1 to location 0.

In the access-register mode, the contents of access register R1 and access register R2 are compared. If the R1 or R2 field is zero, 32 zeros are used rather than the contents of access register 0. If all 32 bits of the compared values are equal, then the destructive
overlap test is made. If all 32 bits of the compared values are not equal, destructive overlap is declared not to exist. If, for this case, the operands actually overlap in real storage, it is unpredictable whether the result reflects the overlap condition.

When the length specified by bits 40-63 of general register R₁ + 1 is zero, no movement takes place, and condition code 0 or 1 is set to indicate the relative values of the lengths.

The execution of the instruction is interruptible. When an interruption occurs, other than one that follows termination, the lengths in general registers R₁ + 1 and R₂ + 1 are decremented by the number of bytes moved, and the addresses in general registers R₁ and R₂ are incremented by the same number, so that the instruction, when reexecuted, resumes at the point of interruption. In the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general registers R₁ and R₂ are set to zeros, and the contents of bit positions 0-31 remain unchanged. In any addressing mode, the contents of bit positions 0-39 of general registers R₁ + 1 and R₂ + 1 remain unchanged; and the condition code is unpredictable. If the operation is interrupted during padding, the length field in general register R₂ + 1 is 0, the address in general register R₂ is incremented by the original length in general register R₂ + 1, and general registers R₁ and R₁ + 1 reflect the extent of the padding operation.

When the first-operand location includes the location of the instruction or of an execute-type instruction, the instruction may be refetched from storage and reinterpreted even in the absence of an interruption during execution. The exact point in the execution at which such a refetch occurs is unpredictable.
Padding byte values of B0 hex and B8 hex may be used during the nonpadding part of the operation by some models, in certain cases, as an indication of whether the movement should be performed bypassing the cache or using the cache, respectively. Thus, a padding byte of B0 hex indicates no intention to reference the destination area after the move, and a padding byte of B8 hex indicates an intention to reference the destination area.

For the nonpadding part of the operation when the padding byte is not B1 hex, accesses to the operands for MOVE LONG may be multiple-access references, and these accesses do not necessarily appear to occur in a left-to-right direction as observed by other CPUs and by the channel subsystem. When the padding byte is B1 hex, accesses to the operands are single-access references, and these accesses appear to occur in a left-to-right direction as observed by other CPUs and by the channel subsystem. During the nonpadding part of the operation, operands appear to be accessed doubleword concurrent as observed by other CPUs, provided that both operands start on doubleword boundaries, are an integral number of doublewords in length, and do not overlap.

As observed by other CPUs and by the channel subsystem, that portion of the first operand which is filled with the padding byte is not necessarily stored into in a left-to-right direction and may appear to be stored into more than once. During the padding operation, stores by other CPUs or by the channel subsystem into that portion of the first operand which is filled with the padding byte may cause unpredictable results.

At the completion of the operation, the length in general register R1 + 1 is decremented by the number of bytes stored at the first-operand location, and the address in general register R1 is incremented by the same amount. The length in general register R2 + 1 is decremented by the number of bytes moved out of the second-operand location, and the address in general register R3 is incremented by the same amount. In the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general registers R1 and R2 are set to zeros, even when one or both of the original length values are zeros or when condition code 3 is set. The contents of bit positions 0-31 of the registers remain unchanged. In any addressing mode, the contents of bit positions 0-39 of general registers R1 + 1 and R2 + 1 remain unchanged.

When condition code 3 is set, no exceptions associated with operand access are recognized. When the length of an operand is zero, no access exceptions for that operand are recognized. Similarly, when the second operand is longer than the first operand, access exceptions are not recognized for the part of the second-operand field that is in excess of the first-operand field. For operands longer than 2K bytes, access exceptions are not recognized for locations more than 2K bytes beyond the current location being processed. Access exceptions are not recognized for an operand if the R field associated with that operand is odd. Also, when the R1 field is odd, PER storage-alteration events are not recognized, and no change bits are set.

**Resulting Condition Code:**

0  Operand lengths equal; no destructive overlap
1  First-operand length low; no destructive overlap
2  First-operand length high; no destructive overlap
3  No movement performed because of destructive overlap

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Specification
- Transaction constraint

**Programming Notes:**

1. An example of the use of the MOVE LONG instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. MOVE LONG may be used for clearing storage by setting the padding byte to zero and the second-operand length to zero. On most models, this is the fastest instruction for clearing storage areas in excess of 256 bytes. However, the stores associated with this clearing may be multiple-access stores and should not be used to clear an area if the possibility exists that another CPU or a channel program will attempt to access and use the area as soon as it appears to be zero. For more details, see “Storage-Operand Consistency” on page 5-123.

3. The program should avoid specification of a length for either operand which would result in an addressing exception. Addressing (and also protection) exceptions may result in termination of the entire operation, not just the current unit of
operation. The termination may be such that the contents of all result fields are unpredictable; in the case of MOVE LONG, this includes the condition code and the two even-odd general-register pairs, as well as the first-operand location in main storage. The following are situations that have actually occurred on one or more models:

a. When a protection exception occurs on a 4K-byte block of a first operand which is several blocks in length, stores to the protected block are suppressed. However, the move continues into the subsequent blocks of the first operand, which are not protected. Similarly, an addressing exception on a block does not necessarily suppress processing of subsequent blocks which are available.

b. Some models may update the general registers only when an external, I/O, repressible machine-check, or restart interruption occurs, or when a program interruption occurs for which it is required to nullify or suppress a unit of operation. Thus, if, after a move into several blocks of the first operand, an addressing or protection exception occurs, the general registers may remain unchanged.

4. When the first-operand length is zero, the operation consists in setting the condition code and, in the 24-bit or 31-bit addressing mode, of setting the leftmost bits in bit positions 32-63 of general registers R1 and R2 to zero.

5. When the contents of the R1 and R2 fields are the same, the contents of the designated registers are incremented or decremented only by the number of bytes moved, not by twice the number of bytes moved. Condition code 0 is set.

6. The following is a detailed description of those cases in which movement takes place, that is, where destructive overlap does not exist.

In the access-register mode, the contents of the access registers used are called the effective space designations. When the effective space designations are not equal, destructive overlap is declared not to exist and movement occurs. When the effective space designations are the same or when not in the access-register mode, then the following cases apply.

Depending on whether the second operand wraps around from location $2^{2k} - 1$ (or $2^{31} - 1$ or $2^{64} - 1$, depending on the addressing mode) to location 0, movement takes place in the following cases:

a. When the second operand does not wrap around, movement is performed if the leftmost byte of the first operand coincides with or is to the left of the leftmost byte of the second operand, or if the leftmost byte of the first operand is to the right of the rightmost second-operand byte participating in the operation.

b. When the second operand wraps around, movement is performed if the leftmost byte of the first operand coincides with or is to the left of the leftmost byte of the second operand, and if the leftmost byte of the first operand is to the right of the rightmost second-operand byte participating in the operation.

The rightmost second-operand byte is determined by using the smaller of the first-operand and second-operand lengths.

When the second-operand length is one or zero, destructive overlap cannot exist.

7. Special precautions should be taken if MOVE LONG is made the target of an execute-type instruction. See the programming note concerning interruptible instructions under EXECUTE.

8. Since the execution of MOVE LONG is interruptible, the instruction cannot be used for situations where the program must rely on uninterrupted execution of the instruction. Similarly, the program should normally not let the first operand of MOVE LONG include the location of the instruction or of an execute-type instruction because the new contents of the location may be interpreted for a resumption after an interruption, or the instruction may be refetched without an interruption.

9. Further programming notes concerning interruptible instructions are included in "Interruptible Instructions" in Chapter 5, "Program Execution."

10. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.
MOVE LONG EXTENDED

MVCLE R1,R3,D2(B2)[RS-a]

<table>
<thead>
<tr>
<th>A8</th>
<th>R1</th>
<th>R3</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>

All or part of the third operand is placed at the first-operand location. The remaining rightmost byte positions, if any, of the first-operand location are filled with padding bytes. The operation proceeds until the end of the first-operand location is reached or a CPU-determined number of bytes have been placed at the first-operand location, whichever occurs first. The result is indicated in the condition code.

The R1 and R3 fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and third operand is designated by the contents of general registers R1 and R3, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and third-operand locations is specified by the contents of bit positions 32-63 of general registers R1 + 1 and R3 + 1, respectively, and those contents are treated as 32-bit unsigned binary integers. In the 64-bit addressing mode, the number of bytes in the first-operand and third-operand locations is specified by the entire contents of general registers R1 + 1 and R3 + 1, respectively, and those contents are treated as 64-bit unsigned binary integers.

The handling of the addresses in general registers R1 and R3 is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R3 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The second-operand address is not used to address data; instead, the rightmost eight bits of the second-operand address, bits 56-63, are the padding byte. Bits 0-55 of the second-operand address are ignored.

The contents of the registers and address just described are shown in Figure 7-254 on page 7-251.

The result is obtained as if the movement starts at the left end of both fields and proceeds to the right, byte by byte. The operation is ended when the number of bytes specified in general register R1 + 1 have been placed at the first-operand location or when a CPU-determined number of bytes have been placed, whichever occurs first. If the third operand is shorter than the first operand, the remaining rightmost bytes of the first-operand location are filled with the padding byte.

When the operation is completed because the end of the first operand has been reached, the condition code is set to 0 if the two operand lengths are equal, it is set to 1 if the first-operand length is less than the third-operand length, or it is set to 2 if the first-operand length is greater than the third-operand length. When the operation is completed because a CPU-determined number of bytes have been moved without reaching the end of the first operand, condition code 3 is set.

No test is made for destructive overlap, and the results in the first-operand location are unpredictable when destructive overlap exists. Operands are said to overlap destructively when the first-operand location is used as a source after data has been moved into it.

Operands do not overlap destructively if the leftmost byte of the first operand does not coincide with any of the third-operand bytes participating in the operation other than the leftmost byte of the third operand. When an operand wraps around from location 2^{24} - 1 (or 2^{31} - 1 or 2^{64} - 1) to location 0, operand bytes in locations up to and including 2^{24} - 1 (or 2^{31} - 1 or 2^{64} - 1) are considered to be to the left of bytes in locations from 0 up.

In the 24-bit addressing mode, wraparound is from location 2^{24} - 1 to location 0; in the 31-bit addressing mode, wraparound is from location 2^{31} - 1 to location 0; and, in the 64-bit addressing mode, wraparound is from location 2^{64} - 1 to location 0.

When the length specified in general register R1 + 1 is zero, no movement takes place, and condition code 0 or 1 is set to indicate the relative values of the lengths.
Padding byte values of B0 hex and B8 hex may be used during the nonpadding part of the operation by some models, in certain cases, as an indication of whether the movement should be performed bypassing the cache or using the cache, respectively. Thus, a padding byte of B0 hex indicates no intention to reference the destination area after the move, and a padding byte of B8 hex indicates an intention to reference the destination area.

For the nonpadding part of the operation when the padding byte is not B1 hex, accesses to the operands for MOVE LONG EXTENDED may be multiple-access references, and these accesses do not necessarily appear to occur in a left-to-right direction as observed by other CPUs and by the channel subsystem. When the padding byte is B1 hex, accesses to the operands are single-access references, and these accesses appear to occur in a left-to-right direction as observed by other CPUs and by the channel subsystem. During the nonpadding part of the operation, operands appear to be doubleword concurrent as observed by other CPUs, provided that both operands start on doubleword boundaries, are an integral number of doublewords in length, and do not overlap.

As observed by other CPUs and by the channel subsystem, that portion of the first operand which is filled with the padding byte is not necessarily stored into in
a left-to-right direction and may appear to be stored into more than once. During the padding operation, stores by other CPUs or by the channel subsystem into that portion of the first operand which is filled with the padding byte may cause unpredictable results.

At the completion of the operation, the length in general register $R_1 + 1$ is decremented by the number of bytes stored at the first-operand location, and the address in general register $R_1$ is incremented by the same amount. The length in general register $R_3 + 1$ is decremented by the number of bytes moved out of the third-operand location, and the address in general register $R_3$ is incremented by the same amount.

If the operation is completed because a CPU-determined number of bytes have been moved without reaching the end of the first operand, the lengths in general registers $R_1 + 1$ and $R_3 + 1$ are decremented by the number of bytes moved, and the addresses in general registers $R_1$ and $R_3$ are incremented by the same number, so that the instruction, when reexecuted, resumes at the next byte to be moved. If the operation is completed during padding, the length field in general register $R_3 + 1$ is zero, the address in general register $R_3$ is incremented by the original length in general register $R_3 + 1$, and general registers $R_1$ and $R_1 + 1$ reflect the extent of the padding operation.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers $R_1$, $R_1 + 1$, $R_3$, and $R_3 + 1$, always remain unchanged.

The padding byte may be formed from $D_2(B_2)$ multiple times during the execution of the instruction, and the registers designated by $R_1$ and $R_3$ may be updated multiple times. Therefore, if $B_2$ equals $R_1$, $R_1 + 1$, $R_3$, or $R_3 + 1$ and is subject to change during the execution of the instruction, the results are unpredictable.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed. The maximum amount is approximately 4K bytes of either operand.

At the completion of the operation in the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general registers $R_1$ and $R_3$ may be set to zeros or may remain unchanged from their original values, even when one or both of the original length values are zeros.

When the length of an operand is zero, no access exceptions for that operand are recognized. Similarly, when the third operand is longer than the first operand, access exceptions are not recognized for the part of the third-operand field that is in excess of the first-operand field. For operands longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the current location being processed. Access exceptions are not recognized for an operand if the R field associated with that operand is odd. Also, when the $R_1$ field is odd, PER storage-alteration events are not recognized, and no change bits are set.

**Resulting Condition Code:**

0  All bytes moved, operand lengths equal
1  All bytes moved, first-operand length low
2  All bytes moved, first-operand length high
3  CPU-determined number of bytes moved without reaching end of first operand

**Program Exceptions:**

- Access (fetch, operand 3; store, operand 1)
- Specification
- Transaction constraint

**Programming Notes:**

1. MOVE LONG EXTENDED is intended for use in place of MOVE LONG when the operand lengths are specified as 32-bit or 64-bit binary integers and a test for destructive overlap is not required. MOVE LONG EXTENDED sets condition code 3 in cases in which MOVE LONG would be interrupted.

2. When condition code 3 is set, the program can simply branch back to the instruction to continue the movement. The program need not determine the number of bytes that were moved.

3. The function of not processing more than approximately 4K bytes of either operand is intended to permit software polling of a flag that may be set by a program on another CPU during long operations.

4. MOVE LONG EXTENDED may be used for clearing storage by setting the padding byte to
zero and the third-operand length to zero. However, the stores associated with this clearing may be multiple-access stores and should not be used to clear an area if the possibility exists that another CPU or a channel program will attempt to access and use the area as soon as it appears to be zero. For more details, see “Storage-Operand and Consistency” on page 5-123.

5. When the contents of the R1 and R3 fields are the same, the contents of the designated registers are incremented or decremented only by the number of bytes moved, not by twice the number of bytes moved. The condition code is finally set to 0 after possible settings to 3.

6. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

MOVE LONG UNICODE

```
MVCLU R1,R3,D2(B2) [RSY-a]
```

All or part of the third operand is placed at the first-operand location. The remaining rightmost positions, if any, of the first-operand location are filled with one or more padding bytes, alternating between the even padding byte and the odd padding byte. The operation proceeds until the end of the first-operand location is reached or a CPU-determined number of bytes have been placed at the first-operand location, whichever occurs first. The result is indicated in the condition code.

The R1 and R3 fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and third operand is designated by the contents of general registers R1 and R3, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand and third-operand locations is specified by the contents of bit positions 32-63 of general registers R1 + 1 and R3 + 1, respectively, and those contents are treated as 32-bit unsigned binary integers.

On some models, the contents of general registers R1 + 1 and R3 + 1 must specify an even number of bytes; otherwise, a specification exception is recognized.

The handling of the addresses in general registers R1 and R3 is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R3 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of the registers constitute the address.

The second-operand address is not used to address data; instead, the rightmost 16 bits of the second-operand address, bits 48-63, are the two padding bytes; bits 48-55 are the even padding byte, and bits 56-63 are the odd padding byte. Bits 0-47 of the second-operand address are ignored.

The contents of the registers and address just described are shown in Figure 7-255 on page 7-254.

The result is obtained as if the movement starts at the left end of both fields and proceeds to the right, byte by byte. The operation is ended when the number of bytes specified by the contents of general register R1 + 1 have been placed at the first-operand location or when a CPU-determined number of bytes have been placed, whichever occurs first.

If the third operand is shorter than the first operand, the remaining rightmost positions of the first-operand location are filled with alternating padding bytes. When the number of bytes remaining in the first-operand location is an even number, the even padding byte is placed first; when the number of bytes remaining in the first-operand location is odd, the odd padding byte is placed first.

When the operation is completed because the end of the first operand has been reached, the condition code is set to 0 if the two operand lengths are equal, it is set to 1 if the first-operand length is less than the third-operand length, or it is set to 2 if the first-oper-
and length is greater than the third-operand length. When the operation is completed because a CPU-determined number of bytes have been moved without reaching the end of the first operand, condition code 3 is set.

No test is made for destructive overlap, and the results in the first-operand location are unpredictable when destructive overlap exists. Operands are said to overlap destructively when the first-operand location is used as a source after data has been moved into it.

Operands do not overlap destructively if the leftmost byte of the first operand does not coincide with any of the third-operand bytes participating in the operation other than the leftmost byte of the third operand. When an operand wraps around from location 2^{24} - 1 (or 2^{31} - 1 or 2^{64} - 1) to location 0, operand bytes in locations up to and including 2^{24} - 1 (or 2^{31} - 1 or 2^{64} - 1) are considered to be to the left of bytes in locations from 0 up.

In the 24-bit addressing mode, wraparound is from location 2^{24} - 1 to location 0; in the 31-bit addressing mode, wraparound is from location 2^{31} - 1 to location

---

**Figure 7-255. Register Contents and Second-Operand Address for MOVE LONG UNICODE**
0; and, in the 64-bit addressing mode, wraparound is from location $2^{64} - 1$ to location 0.

When the length specified in general register $R_1 + 1$ is zero, no movement takes place, and condition code 0 or 1 is set to indicate the relative values of the lengths.

For the nonpadding part of the operation, accesses to the operands for MOVE LONG UNICODE may be multiple-access references. These accesses do not necessarily appear to occur in a left-to-right direction as observed by other CPUs and by channel programs. During the nonpadding part of the operation, operands appear to be accessed doubleword concurrent as observed by other CPUs, provided that both operands start on doubleword boundaries, are an integral number of doublewords in length, and do not overlap.

As observed by other CPUs and by the channel subsystem, that portion of the first operand which is filled with the padding bytes is not necessarily stored into in a left-to-right direction and may appear to be stored into more than once. During the padding operation, stores by other CPUs or by the channel subsystem into that portion of the first operand which is filled with the padding bytes may cause unpredictable results.

At the completion of the operation, the length in general register $R_1 + 1$ is decremented by the number of bytes stored at the first-operand location, and the address in general register $R_1$ is incremented by the same amount. The length in general register $R_3 + 1$ is decremented by the number of bytes moved out of the third-operand location, and the address in general register $R_3$ is incremented by the same amount.

If the operation is completed because a CPU-determined number of bytes have been moved without reaching the end of the first operand, the lengths in general registers $R_1 + 1$ and $R_3 + 1$ are decremented by the number of bytes moved, and the addresses in general registers $R_1$ and $R_3$ are incremented by the same number, so that the instruction, when reexecuted, resumes at the next byte to be moved. If the operation is completed during padding, the length field in general register $R_3 + 1$ is zero, the address in general register $R_3$ is incremented by the number of bytes moved from operand 3, and general registers $R_1$ and $R_1 + 1$ reflect the extent of the padding operation.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers $R_1$, $R_1 + 1$, $R_2$, and $R_2 + 1$, always remain unchanged.

The padding bytes may be formed from $D_2(B_2)$ multiple times during the execution of the instruction, and the registers designated by $R_1$ and $R_3$ may be updated multiple times. Therefore, if $B_2$ equals $R_1$, $R_1 + 1$, $R_3$, or $R_3 + 1$ and is subject to change during the execution of the instruction, the results are unpredictable.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

At the completion of the operation in the 24-bit or 31-bit addressing mode, the leftmost bits which are not part of the address in bit positions 32-63 of general registers $R_1$ and $R_3$ may be set to zeros or may remain unchanged from their original values, including the case when one or both of the original length values are zeros.

When the length of an operand is zero, no access exceptions for that operand are recognized. Similarly, when the third operand is longer than the first operand, access exceptions are not recognized for the part of the third-operand field that is in excess of the first-operand field. For operands longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the current location being processed. Access exceptions are not recognized for an operand if the R field associated with that operand is odd. Also, when the $R_1$ field is odd, PER storage-alteration events are not recognized, and no change bits are set. On models that recognize a specification exception if the length associated with an operand is odd, access exceptions and PER storage-alteration events are not recognized and no change bits are set if the length is odd.

**Resulting Condition Code:**

0  All bytes moved, operand lengths equal
1  All bytes moved, first-operand length low
2  All bytes moved, first-operand length high
3  CPU-determined number of bytes moved without reaching end of first operand

**Program Exceptions:**
• Access (fetch, operand 3; store, operand 1)
• Operation (if the extended-translation facility 2 is not installed)
• Specification
• Transaction constraint

**Programming Notes:**

1. MOVE LONG UNICODE is intended for use in place of MOVE LONG or MOVE LONG EXTENDED when padding with double-byte characters. The character may be a Unicode character or any other double-byte character. MOVE LONG UNICODE may set condition code 3 in cases in which MOVE LONG would be interrupted.

2. When condition code 3 is set, the program can simply branch back to the instruction to continue the movement. The program need not determine the number of bytes that were moved.

3. MOVE LONG UNICODE may be used for filling storage with padding bytes by placing the padding bytes in the second-operand address and setting the third-operand length to zero. However, the stores associated with this clearing may be multiple-access stores and should not be used to clear an area if the possibility exists that another CPU or a channel program will attempt to access and use the area as soon as it appears to be zero. For more details, see “Storage-Operand Consistency” on page 5-123.

4. When the contents of the R_1 and R_3 fields are the same, the contents of the designated registers are incremented or decremented only by the number of bytes moved, not by two times the number of bytes moved. The condition code is finally set to 0 after possible settings to 3.

5. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

6. The padding bytes may be represented in the displacement field of the instruction. The following example illustrates padding with a Unicode space character.

   \[ \text{MVCLU} \ 6,8,\text{x'0020'} \]

   When the B_2 field of the instruction designates general register 0, and the long-displacement facility is not installed, the padding bytes are limited to a character whose representation is less than or equal to 0FFF hex.

7. MOVE LONG UNICODE is intended to be used to move and pad pairs of bytes. Although some models allow the first- and third-operand length registers to designate an odd length, without recognizing a specification exception, the program should always be coded to provide an even length. This ensures that the program will operate compatibly in configurations that recognize a specification exception for an odd length value.

**MOVE NUMERICS**

\[
\begin{array}{cccccc}
\text{MVN} & D_1(L,B_1),D_2(B_2) & [\text{SS-a}] \\
D_2 & D_1 & B_2 & B_1 & L & D_1 \\
0 & 8 & 16 & 20 & 32 & 36 & 47
\end{array}
\]

The rightmost four bits of each byte in the second operand are placed in the rightmost bit positions of the corresponding bytes in the first operand. The leftmost four bits of each byte in the first operand remain unchanged.

Each operand is processed left to right. When the operands overlap, the result is obtained as if the operands were processed one byte at a time and each result byte were stored immediately after fetching the necessary operand bytes.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

• Access (fetch, operand 2; fetch and store, operand 1)
• Transaction constraint

**Programming Notes:**

1. An example of the use of the MOVE NUMERICS instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. MOVE NUMERICS moves the numeric portion of a decimal-data field that is in the zoned format. The zoned-decimal format is described in Chapter 8, “Decimal Instructions.” The operands are not checked for valid sign and digit codes.

3. Accesses to the first operand of MOVE NUMERICS consist in fetching the leftmost four bits of
each byte in the first operand and subsequently storing the updated value of the byte. These fetch and store accesses to a particular byte do not necessarily occur one immediately after the other. Thus, this instruction cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown for OR (OI) in “Multiprogramming and Multiprocessing Examples” in Appendix A, “Number Representation and Instruction-Use Examples.”

**MOVE STRING**

```
MVST R1, R2 [RRE]
```

All or part of the second operand is placed in the first-operand location. The operation proceeds until the end of the second operand is reached or a CPU-determined number of bytes have been moved, whichever occurs first. The CPU-determined number is at least one. The result is indicated in the condition code.

The location of the leftmost byte of the first operand and second operand is designated by the contents of general registers R1 and R2, respectively.

The handling of the addresses in general registers R1 and R2 is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R2 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The end of the second operand is indicated by an ending character in the last byte position of the operand. The ending character to be used to determine the end of the second operand is specified in bit positions 56-63 of general register 0. Bit positions 32-55 of general register 0 are reserved for possible future extensions and must contain all zeros; otherwise, a specification exception is recognized.

The operation proceeds left to right and ends as soon as the second-operand ending character has been moved or a CPU-determined number of second-operand bytes have been moved, whichever occurs first. The CPU-determined number is at least one. When the ending character is in the first byte position of the second operand, only the ending character is moved. When the ending character has been moved, condition code 1 is set. When a CPU-determined number of second-operand bytes not including an ending character have been moved, condition code 3 is set. Destructive overlap is not recognized. If the second operand is used as a source after it has been used as a destination, the results are unpredictable.

When condition code 1 is set, the address of the ending character in the first operand is placed in general register R1, and the contents of general register R2 remain unchanged. When condition code 3 is set, the address of the next byte to be processed in the first and second operands is placed in general registers R1 and R2, respectively. Whenever an address is placed in a general register, bits 32-39 of the register, in the 24-bit addressing mode, or bit 32, in the 31-bit addressing mode, are set to zeros. Bits 0-31 of the R1 and R2 registers always remain unchanged in the 24-bit or 31-bit mode.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

Access exceptions for the first and second operands are recognized only for that portion of the operand that is necessarily used in the operation.

The storage-operand-consistency rules are the same as for the MOVE (MVC) instruction, except that destructive overlap is not recognized.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>--</td>
</tr>
<tr>
<td>1</td>
<td>Entire second operand moved; general register R1 updated with address of ending character in first operand; general register R2 unchanged</td>
</tr>
<tr>
<td>2</td>
<td>--</td>
</tr>
<tr>
<td>3</td>
<td>CPU-determined number of bytes moved; general registers R1 and R2 updated with addresses of next bytes</td>
</tr>
</tbody>
</table>
**Program Exceptions:**
- Access (fetch, operand 2; store, operand 1)
- Specification
- Transaction constraint

**Programming Notes:**

1. An example of the use of the MOVE STRING instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. When condition code 3 is set, the program can simply branch back to the instruction to continue the data movement. The program need not determine the number of bytes that were moved.

3. $R_1$ or $R_2$ may be zero, in which case general register 0 is treated as containing an address and also the ending character.

4. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

5. If the second operand is used as a source after it has been used as a destination, an ending character in the second operand may not be recognized.

**MOVE WITH OFFSET**

<table>
<thead>
<tr>
<th>MOVE</th>
<th>D_{i}(L_{z},B_{z}),D_{j}(L_{z},B_{z})</th>
</tr>
</thead>
<tbody>
<tr>
<td>[SS-b]</td>
<td></td>
</tr>
</tbody>
</table>

The second operand is placed to the left of and adjacent to the rightmost four bits of the first operand.

The rightmost four bits of the first operand are attached as the rightmost bits to the second operand, the second-operand bits are offset by four bit positions, and the result is placed at the first-operand location.

The result is obtained as if the operands were processed right to left. When necessary, the second operand is considered to be extended on the left with zeros. If the first operand is too short to contain all of the second operand, the remaining leftmost portion of the second operand is ignored. Access exceptions for the unused portion of the second operand may or may not be indicated.

When the operands overlap, the result is obtained as if the operands were processed one byte at a time, as if each result byte were stored immediately after fetching the necessary operand bytes, and as if the left digit of each second-operand byte were to remain available for the next result byte and need not be refetched.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2; fetch and store, operand 1)
- Transaction constraint

**Programming Notes:**

1. An example of the use of the MOVE WITH OFFSET instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. MOVE WITH OFFSET may be used to shift packed decimal data by an odd number of digit positions. The packed-decimal format is described in Chapter 8, “Decimal Instructions.” The operands are not checked for valid sign and digit codes. In many cases, however, SHIFT AND ROUND DECIMAL may be more convenient to use.

3. Access to the rightmost byte of the first operand of MOVE WITH OFFSET consists in fetching the rightmost four bits and subsequently storing the updated value of this byte. These fetch and store accesses to the rightmost byte of the first operand do not necessarily occur one immediately after the other. Thus, this instruction cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown for OR (OI) in “Multiprogramming and Multiprocessing Examples” in Appendix A, “Number Representation and Instruction-Use Examples.”

4. The storage-operand references for MOVE WITH OFFSET may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)
MOVE ZONES

MVZ D1(L,B1) D2(B2) [SS-a]

The leftmost four bits of each byte in the second operand are placed in the leftmost four bit positions of the corresponding bytes in the first operand. The rightmost four bits of each byte in the first operand remain unchanged.

Each operand is processed left to right. When the operands overlap, the result is obtained as if the operands were processed one byte at a time and each result byte were stored immediately after the necessary operand byte is fetched.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (fetch, operand 2; fetch and store, operand 1)
- Transaction constraint

Programming Notes:

1. An example of the use of the MOVE ZONES instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. MOVE ZONES moves the zoned portion of a decimal field in the zoned format. The zoned format is described in Chapter 8, “Decimal Instructions.” The operands are not checked for valid sign and digit codes.

3. Accesses to the first operand of MOVE ZONES consist in fetching the rightmost four bits of each byte in the first operand and subsequently storing the updated value of the byte. These fetch and store accesses to a particular byte do not necessarily occur one immediately after the other. Thus, this instruction cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown for the OR (OI) instruction in “Multiprogramming and Multiprocessing Examples” in Appendix A, “Number Representation and Instruction-Use Examples.”

MULTIPLY

Register-and-register format:

MR R1,R2 [RR]

Register-and-storage formats:

M R1,D2(X2,B2) [RX-a]

MFY R1,X2 B2 D2 [RXY-a]

The 32-bit first operand (the multiplicand) is multiplied by the 32-bit second-operand (the multiplier), and the 64-bit product is placed at the first-operand location.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

Both the multiplicand and multiplier are treated as 32-bit signed binary integers. The multiplicand is in bit positions 32-63 of general register R1 + 1. For MULTIPLY (MR), the multiplier is in bit positions 32-63 of general register R2. The contents of general register R1 and of bit positions 0-31 of general register R1 + 1 and, for MR, of general register R2 are ignored.

The product is a 64-bit signed binary integer. Bits 0-31 of the product replace bits 32-63 of general register R1. Bits 32-63 of the product replace bits 32-63 of general register R1 + 1. Bits 0-31 of general registers R1 and R1 + 1 remain unchanged. An overflow cannot occur.

The sign of the product is determined by the rules of algebra from the multiplier and multiplicand sign, except that a zero result is always positive.

The displacement for M is treated as a 12-bit unsigned binary integer. The displacement for MFY is treated as a 20-bit signed binary integer.
MULTIPLY HALFWORD

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 of M and MFY only)
- Operation (MFY; if the general-instructions-extension facility is not installed)
- Specification

**Programming Notes:**
1. An example of the use of the MULTIPLY instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. The significant part of the product usually occupies 62 bit positions or fewer. Only when two maximum 32-bit negative numbers are multiplied are 63 significant product bits formed.
3. Care should be taken not to confuse the mnemonic for MULTIPLY UNNORMALIZED (MY) with the mnemonic for MULTIPLY (MFY).

For MULTIPLY HALFWORD and MULTIPLY HALFWORD IMMEDIATE (MHI), the multiplicand is treated as a 32-bit signed binary integer in bit positions 32-63 of general register R1, and it is replaced by the rightmost 32 bits of the signed-binary-integer product. The bits to the left of the 32 rightmost bits of the product are not tested for significance; no overflow indication is given. Bits 0-31 of general register R1 are ignored and remain unchanged.

For MULTIPLY HALFWORD IMMEDIATE (MGHI), the multiplicand is treated as a 64-bit signed binary integer in bit positions 0-63 of general register R1, and it is replaced by the rightmost 64 bits of the signed-binary-integer product. The bits to the left of the 64 rightmost bits of the product are not tested for significance; no overflow indication is given.

The sign of the product is determined by the rules of algebra from the multiplier and multiplicand sign, except that a zero result is always positive.

The displacement for MH is treated as a 12-bit unsigned binary integer. The displacement for MHY is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 of MH and MHY only)
- Operation (MHY; if the general-instructions-extension facility is not installed)

**Programming Notes:**
1. An example of the use of the MULTIPLY HALFWORD instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. For MH, MHY, and MHI, the significant part of the product usually occupies 46 bit positions or fewer. Only when two maximum negative numbers are multiplied are 47 significant product bits formed. Since the rightmost 32 bits of the product are placed unchanged at the first-operand location, ignoring all bits to the left, the sign bit of the result may differ from the true sign of the product in the case of overflow. For a negative product, the 32 bits placed in register R1 are the rightmost part of the product in two’s-complement notation. For MGHI, the significant part of
the product usually occupies 78 bit positions or fewer.

MULTIPLY LOGICAL

Register-and-register formats:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Format</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>MLR</strong> R1,R2</td>
<td>[RRE]</td>
<td><code>E3</code> R1 X2 B2 DL2 DH2 <code>96</code></td>
</tr>
<tr>
<td><strong>MLGR</strong> R1,R2</td>
<td>[RRE]</td>
<td><code>E3</code> R1 X2 B2 DL2 DH2 <code>96</code></td>
</tr>
</tbody>
</table>

Register-and-storage formats:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Format</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>ML</strong> R1,D2(X2,B2)</td>
<td>[RXY-a]</td>
<td><code>71</code> R1 X2 B2 D2</td>
</tr>
</tbody>
</table>

For MULTIPLY LOGICAL (MLGR, MLG), the multiplicand and the multiplier are treated as 64-bit unsigned binary integers. The multiplicand is in general register R1 + 1. The contents of general register R1 are ignored. The product is a 128-bit unsigned binary integer. Bits 0-63 of the product replace the contents of general register R1, and bits 64-127 of the product replace the contents of general register R1 + 1. An overflow cannot occur.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 of ML and MLG only)
- Specification

MULTIPLY SINGLE

Register-and-register formats:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Format</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>MSR</strong> R1,R2</td>
<td>[RRE]</td>
<td><code>B252</code> R1 R2</td>
</tr>
<tr>
<td><strong>MSGR</strong> R1,R2</td>
<td>[RRE]</td>
<td><code>B90C</code> R1 R2</td>
</tr>
<tr>
<td><strong>MSGFR</strong> R1,R2</td>
<td>[RRE]</td>
<td><code>B91C</code> R1 R2</td>
</tr>
</tbody>
</table>

Register-and-storage formats:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Format</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>MS</strong> R1,D2(X2,B2)</td>
<td>[RX-a]</td>
<td><code>71</code> R1 X2 B2</td>
</tr>
</tbody>
</table>

For MULTIPLY LOGICAL (MLGR, MLG), the multiplicand and the multiplier are treated as 64-bit unsigned binary integers. The multiplicand is in bit positions 32-63 of general register R1 + 1. For MULTIPLY LOGICAL (MLR), the multiplier is in bit positions 32-63 of general register R2. The contents of general register R1 and of bit positions 0-31 of general register R1 + 1 and, for MLR, of general register R2 are ignored. The product is a 64-bit unsigned binary integer. Bits 0-31 of the product replace bits 32-63 of general register R1, and bits 32-63 of the product replace bits 32-63 of general register R1 + 1. Bits 0-31 of general registers R1 and R1 + 1 remain unchanged. An overflow cannot occur.
MULTIPLY SINGLE IMMEDIATE

\[ \text{MSGF} \quad R_{1}, D_{2}(X_{2} B_{2}) \quad [RXY-a] \]

- The first operand (multiplicand) is multiplied by the second operand (multiplier), and the rightmost 32 or 64 bits of the product are placed at the first-operand location.

- For MULTIPLY SINGLE (MSR, MS, MSY) and for MULTIPLY SINGLE IMMEDIATE (MSFI), the multiplicand, multiplier, and product are treated as 32-bit signed binary integers. The multiplicand is taken from bit positions 32-63 of general register \( R_{1} \) and is replaced by the rightmost 32 bits of the signed-binary-integer product. Bits 0-31 of general register \( R_{1} \) remain unchanged. For MSR, the multiplier is in bit positions 32-63 of general register \( R_{2} \). For MSFI, the multiplier is in the \( I_{2} \) field of the instruction. The bits to the left of the 32 rightmost bits of the product are not tested for significance; no overflow indication is given.

- For MULTIPLY SINGLE (MSG, MSGFR, MSG, MSGF) and for MULTIPLY SINGLE IMMEDIATE (MSGFI), the multiplicand, multiplier, and product are treated as 64-bit signed binary integers, except that, for MSGF, MSGFI, and MSGFR, the multiplier is treated as a 32-bit signed binary integer. The multiplicand is taken from general register \( R_{1} \) and is replaced by the rightmost 64 bits of the signed-binary-integer product. For MSGFR, the multiplier is in bit positions 32-63 of general register \( R_{2} \). For MSGFI, the multiplier is in the \( I_{2} \) field of the instruction. The bits to the left of the 64 rightmost bits of the product are not tested for significance; no overflow indication is given.

The sign of the product is determined by the rules of algebra from the multiplier and multiplicand sign, except that a zero result is always positive.

The displacement for MS is treated as a 12-bit unsigned binary integer. The displacement for MSY, MSG, and MSGF is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 of MS, MSY, MSG, MSGF only)
- Operation (MSY, if the long-displacement facility is not installed; MSFI, MSGFI, if the general-instructions-extension facility is not installed)

NEXT INSTRUCTION ACCESS INTENT

\[ \text{NIAI} \quad I_{1}, I_{2} \quad [IE] \]

Note: In this instruction definition, the term primary-access operand means the lowest numbered storage operand of an instruction. Similarly, the term secondary-access operand means the next-lowest numbered storage operand of the instruction. These terms do not have the same meaning as the terms first operand and second operand, even though there may be some correlation. For example, for the MOVE instruction the first operand is the primary-access operand and the second operand is the secondary-access operand. However, for the LOAD MULTIPLE DISJOINT instruction, the second operand is the primary-access operand and the fourth operand is the secondary-access operand.

Subject to the controls in the \( I_{1} \) and \( I_{2} \) fields, the CPU is signalled the future access intent for either or both the primary-access and secondary-access operands of the next-sequential instruction. The \( I_{1} \) field contains a code to signal the CPU the access intent for the primary-access operand of the next-sequential instruction. The \( I_{2} \) field contains a code to signal the CPU the access intent for the secondary-access operand of the next-sequential instruction. When the next-sequential instruction has only a single storage operand, the \( I_{2} \) field is ignored.
The $I_1$ and the $I_2$ field have the following format:

```
/ / / AI
0 1 2 3
```

**Reserved:** Bits 0-1 of the $I_1$ and $I_2$ fields are reserved and should contain zeros, otherwise the program may not operate compatibly in the future.

**Access Intent (AI):** Bits 2-3 of the $I_1$ and $I_2$ fields contain an unsigned integer that is used as a code to signal the CPU the access intent for the corresponding operand of the next-sequential instruction as follows:

<table>
<thead>
<tr>
<th>Code</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The corresponding operand of the next-sequential instruction may or may not be accessed as an instruction operand by subsequent instructions.</td>
</tr>
<tr>
<td>1</td>
<td>The corresponding operand of the next-sequential instruction will be accessed by subsequent instructions for operand store access, and may also be accessed for operand fetch access.</td>
</tr>
<tr>
<td>2</td>
<td>The corresponding operand of the next-sequential instruction will be accessed by subsequent instructions for operand fetch access.</td>
</tr>
<tr>
<td>3</td>
<td>The corresponding operand of the next-sequential instruction will not be accessed as an instruction operand by subsequent instructions.</td>
</tr>
</tbody>
</table>

Depending on the model, the CPU may not recognize all of the access intents for an operand. For access intents that are not recognized by the CPU, the instruction acts as a no-operation. If the instruction has more than two storage operands, no access intent is specified for the additional operands.

Depending on the model, the CPU may not recognize access intents for a particular instruction. For such cases, the instruction acts as a no-operation.

The NEXT INSTRUCTION ACCESS INTENT instruction only affects subsequent instruction's operand accesses; it does not affect subsequent instruction fetches.

No references to storage are made.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Operation (if the execution-hint facility is not installed)

**Programming Notes:**

1. NEXT INSTRUCTION ACCESS INTENT signals the CPU of the future access intent for the storage operands of the next-sequential instruction, but it does not guarantee that the CPU will necessarily retain or use this information.

2. Specifying an incorrect access intent or an access intent for a non-existent operand may lead to performance degradation.

3. Caches are managed on a cache-line-size granularity. Therefore, when NEXT INSTRUCTION ACCESS INTENT is used to signal the CPU the intended future use of the specified storage operands, the program is actually signalling the CPU the access intent for the entire cache line of the operand. The cache line size can be determined by executing the EXTRACT CPU ATTRIBUTE instruction.

4. If a specified storage operand crosses a cache-line boundary, it is model dependent whether the CPU is signalled the access intent for one or both of the cache lines.

5. Specifying an access-intent value of three does not signal the CPU to actively release the cache line from the cache for the specified operand. Instead, it signals the CPU that it should not actively try to retain that line in the cache.

6. Specifying an access-intent value of zero to a single operand instruction is not encouraged and not necessary. However, in the case where an instruction has two operands and access intent is known for one operand, but not the other, the access intent value of zero can be used for the operand of unknown intent.

7. If an interruption occurs after the execution of NEXT INSTRUCTION ACCESS INTENT and before the execution of the next-sequential instruction, NEXT INSTRUCTION ACCESS INTENT acts as a no-operation and the specified access intent is ignored.

8. If the next sequential instruction after NEXT INSTRUCTION ACCESS INTENT is a PREFETCH DATA (RELATIVE LONG) instruction, it is unpredictable what the CPU will do with data prefetching.
NONTRANSACTIONAL STORE

The 64-bit first operand is nontransactionally placed unchanged at the second-operand location.

The displacement is treated as a 20-bit signed binary integer.

The second operand must be aligned on a double-word boundary; otherwise, a specification exception is recognized and the operation is suppressed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, second operand)
- Operation (transactional-execution facility not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. NONTRANSACTIONAL STORE provides a means by which a program executing in the non-constrained transactional-execution mode can perform stores that will be retained, even if the transaction aborts. This may facilitate debugging of the transaction if it is aborted.

2. When the CPU is not in the transactional-execution mode, the operation of NONTRANSACTIONAL STORE is identical to that of STORE (STG), except that the second operand of NONTRANSACTIONAL STORE is required to be on a doubleword boundary (regardless of transactional-execution mode) whereas the second operand of STG has no alignment requirements.

3. Depending on the model, the performance of NONTRANSACTIONAL STORE may be slower than that of STORE (STG).

4. If a CPU makes transactional and non-transactional stores to the same storage location within a transaction, and the transaction then aborts, the content of all storage locations altered by either the transactional or nontransactional store are unpredictable.

**OR**

**Register-and-register formats:**

```
   OR R1, R2 [RR]
   '16'  R1  R2
   0  8 12 15
```

```
   OGR R1, R2 [RRE]
   'B961'
   0  16 24 31
```

```
   ORK R1, R2, R3 [RRF-a]
   'B9F6'
   0  16 24 31
```

```
   OGRK R1, R2, R3 [RRF-a]
   'B9E6'
   0  16 24 31
```

**Register-and-storage formats:**

```
   OR R1, D2(X2, B2) [RXY-a]
   'E3'  R1  X2  B2  DL2  DH2  '56'
   0  8 12 16 20 31 47
```

```
   OY R1, D2(X2, B2) [RXY-a]
   'E3'  R1  X2  B2  DL2  DH2  '56'
   0  8 12 16 20 31 47
```

```
   OG R1, D2(X2, B2) [RRY-a]
   'E3'  R1  X2  B2  DL2  DH2  '81'
   0  8 12 16 20 31 47
```

**Storage-and-immediate formats:**

```
   OI D1(B1), I2 [SI]
   '96'  I2  B1  D1
   0  8 16 20 31
```

```
   OIY D1(B1), I2 [SIY]
   'EB'  I2  B1  DL1  DH1  '56'
   0  8 16 20 31 47
```
**Storage-and-storage format:**

For O, OC, OG, OGR, OI, OIY, OR, and OY, the OR of the first and second operands is placed at the first-operand location. For OGRK and ORK, the OR of the second and third operands is placed at the first-operand location.

The connective OR is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the corresponding bit position in one or both operands contains a one; otherwise, the result bit is set to zero.

For OR (OC), each operand is processed left to right. When the operands overlap, the result is obtained as if the operands were processed one byte at a time and each result byte were stored immediately after fetching the necessary operand bytes.

For OR (OI, OIY), the first operand is one byte in length, and only one byte is stored. When the interlocked-access facility 2 is installed, the update of the first operand appears to be an interlocked-update reference as observed by other CPUs and channel programs, and a specific-operand-serialization operation is performed.

For OR (O, OR, ORK, and OY), the operands are 32 bits, and for OR (OG, OGR, and OGRK), they are 64 bits.

The displacements for O, OI, and both operands of OC are treated as 12-bit unsigned binary integers. The displacement for OY, OIY, and OG is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

0  Result zero
1  Result not zero
2  --
3  --

**Program Exceptions:**

- Operation (OY and OIY, if the long-displacement facility is not installed; OGRK and ORK, if the distinct-operands facility is not installed)
- Transaction constraint (OC)

**Programming Notes:**

1. Examples of the use of the OR instruction are given in Appendix A, "Number Representation and Instruction-Use Examples."

2. OR may be used to set a bit to one.

3. Accesses to the first operand of OR (OC) – and, when the interlocked-access facility 2 is not installed, accesses to the first operand of OR (OI, OIY) – consist in fetching a first-operand byte from storage and subsequently storing the updated value. These fetch and store accesses to a particular byte do not necessarily occur one immediately after the other. Thus, these instructions cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown in “Multiprogramming and Multiprocessing Examples” on page A-45.

When the interlocked-access facility 2 is installed, OR (OI, OIY) can be safely used to update a location in storage, even if the possibility exists that another CPU or a channel program may also be updating the location.
The second operand is ORed with bits of the first operand, and the result replaces those bits of the first operand. The remainder of the first operand remains unchanged.

For each instruction, the bits of the first operand that are ORed with the second operand and then replaced are as follows:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Bits ORed and Replaced</th>
</tr>
</thead>
<tbody>
<tr>
<td>OIHF</td>
<td>0-31</td>
</tr>
<tr>
<td>OIHH</td>
<td>0-15</td>
</tr>
<tr>
<td>OIHL</td>
<td>16-31</td>
</tr>
<tr>
<td>OILF</td>
<td>32-63</td>
</tr>
<tr>
<td>OILH</td>
<td>32-47</td>
</tr>
<tr>
<td>OILL</td>
<td>48-63</td>
</tr>
</tbody>
</table>

The connective OR is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the corresponding bit position in one or both operands contains a one; otherwise, the result bit is set to zero.

**Resulting Condition Code:**

0  Result is zero
1  Result is not zero
2  --
3  --

**Program Exceptions:**

- Operation (OIHF and OILF, if the extended-immediate facility is not installed)

**Programming Note:** The setting of the condition code is based only on the bits that are ORed and replaced.

---

The format of the second operand is changed from zoned to signed-packed-decimal, and the result is placed at the first-operand location. The zoned and signed-packed-decimal formats are described in Chapter 8, “Decimal Instructions.”

The second operand is treated as having the zoned format. The numeric bits of each byte are treated as a digit. The zone bits are ignored, except the zone bits in the rightmost byte, which are treated as a sign.

The sign and digits are moved unchanged to the first operand and are not checked for valid codes. The sign is placed in the rightmost four bit positions of the rightmost byte of the result field, and the digits are placed adjacent to the sign and to each other in the remainder of the result field.

The result is obtained as if the operands were processed right to left. When necessary, the second operand is considered to be extended on the left with zeros. If the first operand is too short to contain all digits of the second operand, the remaining leftmost portion of the second operand is ignored. Access exceptions for the unused portion of the second operand may or may not be indicated.

When the operands overlap, the result is obtained as if each result byte were stored immediately after fetching the necessary operand bytes. Two second-operand bytes are needed for each result byte, except for the rightmost byte of the result field, which requires only the rightmost second-operand byte.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Transaction constraint

**Programming Notes:**

1. An example of the use of the PACK instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. PACK may be used to interchange the two hexadecimal digits in one byte by specifying a zero in the L_1 and L_2 fields and the same address for both operands.

3. To remove the zone bits of all bytes of a field, including the rightmost byte, both operands should be extended on the right with a dummy byte, which subsequently should be ignored in the result field.

4. The storage-operand references for PACK may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

PACK ASCII

The format of the second operand is changed from ASCII to signed-packed-decimal, and the result is placed at the first-operand location. The signed-packed-decimal format is described in Chapter 8, “Decimal Instructions.”

The second-operand bytes are treated as containing decimal digits, having the binary encoding 0000-1001 for 0-9, in their rightmost four bit positions. The leftmost four bit positions of a byte are ignored. The second operand is considered to be positive.

The implied positive sign (1100 binary) and the source digits are placed at the first-operand location. The source digits are moved unchanged and are not checked for valid codes. The sign is placed in the rightmost four bit positions of the rightmost byte of the result field, and the digits are placed adjacent to the sign and to each other in the remainder of the result field.

The result is obtained as if the operands were processed right to left. When necessary, the second operand is considered to be extended on the left with zeros.

The length of the first operand is 16 bytes.

The length of the second operand is designated by the contents of the L_2 field. The second-operand length must not exceed 32 bytes (L_2 must be less than or equal to 31); otherwise, a specification exception is recognized.

When the length of the second operand is 32 bytes, the leftmost byte is ignored.

The results are unpredictable if the first and second operands overlap in any way.

As observed by other CPUs and by channel programs, the first-operand location is not necessarily stored into in any particular order.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2; store, operand 1)
- Operation (if the extended-translation facility 2 is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. Although PACK ASCII is primarily intended to change the format of ASCII decimal digits, its use is not restricted to ASCII since the leftmost four bits of each byte are ignored.

2. The following example illustrates the use of the instruction to pack ASCII digits:

```
ASDIGITS DS OCL31
DC 'X3132333435'
DC 'X3637383930'
DC 'X3132333435'
DC 'X3637383930'
DC 'X31'
PKDIGITS DS PL16
PKA PKDIGITS,ASDIGITS(31)
```

3. The instruction can also be used to pack EBCDIC digits, which is especially useful when
the length of the second operand is greater than the 16-byte second-operand limit of PACK.

PACK UNICODE

The format of the second operand is changed from Unicode to signed-packed-decimal, and the result is placed at the first-operand location. The signed-packed-decimal format is described in Chapter 8, "Decimal Instructions."

The two-byte second-operand characters are treated as Unicode Basic Latin characters containing decimal digits, having the binary encoding 0000-1001 for 0-9, in their rightmost four bit positions. The leftmost 12 bit positions of a character are ignored. The second operand is considered to be positive.

The implied positive sign (1100 binary) and the source digits are placed at the first-operand location. The source digits are moved unchanged and are not checked for valid codes. The sign is placed in the rightmost four bit positions of the rightmost byte of the result field, and the digits are placed adjacent to the sign and to each other in the remainder of the result field.

The result is obtained as if the operands were processed right to left. When necessary, the second operand is considered to be extended on the left with zeros.

As observed by other CPUs and by channel programs, the first-operand location is not necessarily stored into in any particular order.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (fetch, operand 2; store, operand 1)
- Operation (if the extended-translation facility 2 is not installed)
- Specification
- Transaction constraint

Programming Notes:

1. The following example illustrates the use of PACK UNICODE to pack European numbers:

   UNDIGITS DS 0CL62
   DC X'00310032003300340035'
   DC X'00360037003800390030'
   DC X'00310032003300340035'
   DC X'00360037003800390030'
   DC X'00310032003300340035'
   DC X'00360037003800390030'
   DC X'0031'
   PKDIGITS DS PL16
   :  
   PKU PKDIGITS,UNDIGITS(62)

2. Because the leftmost 12 bits of each character are ignored, those Unicode decimal digits where the digit zero has four rightmost zero bits can
also be packed by the instruction. For example, for Thai digits:

UNDIGITS DS OCL62
DC 'X'0E510E520E530E540E55'
DC 'X'0E560E570E580E590E50'
DC 'X'0E510E520E530E540E55'
DC 'X'0E560E570E580E590E50'
DC 'X'0E510E520E530E540E55'
DC 'X'0E560E570E580E590E50'
PDKIGITS DS PL16
PKU PDKIGITS,UNDIGITS(62)

3. The storage-operand references for PACK UNICODE may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

PERFORM CRYPTOGRAPHIC COMPUTATION

PCC [RRE] 01 6 3 1

A function specified by the function code in general register 0 is performed.

Bits 16-31 of the instruction are ignored.

Bit positions 57-63 of general register 0 contain the function code. Figure 7-256 on page 7-269 shows the assigned function codes. All other function codes are unassigned. Bit 56 of general register 0 must be zero; otherwise, a specification exception is recognized. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.

The function codes for PERFORM CRYPTOGRAPHIC COMPUTATION are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>PCC-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>PCC-Compute-Last-Block-CMAC-Using-DEA</td>
<td>32</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>PCC-Compute-Last-Block-CMAC-Using-TDEA-128</td>
<td>40</td>
<td>8</td>
</tr>
<tr>
<td>3</td>
<td>PCC-Compute-Last-Block-CMAC-Using-TDEA-192</td>
<td>48</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>PCC-Compute-Last-Block-CMAC-Using-Encrypted-DEA</td>
<td>56</td>
<td>8</td>
</tr>
<tr>
<td>10</td>
<td>PCC-Compute-Last-Block-CMAC-Using-TDEA-128</td>
<td>64</td>
<td>8</td>
</tr>
<tr>
<td>11</td>
<td>PCC-Compute-Last-Block-CMAC-Using-TDEA-192</td>
<td>72</td>
<td>8</td>
</tr>
<tr>
<td>18</td>
<td>PCC-Compute-Last-Block-CMAC-Using-AES-128</td>
<td>56</td>
<td>16</td>
</tr>
<tr>
<td>19</td>
<td>PCC-Compute-Last-Block-CMAC-Using-AES-192</td>
<td>64</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>PCC-Compute-Last-Block-CMAC-Using-AES-256</td>
<td>72</td>
<td>16</td>
</tr>
<tr>
<td>26</td>
<td>PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-128</td>
<td>88</td>
<td>16</td>
</tr>
<tr>
<td>27</td>
<td>PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-192</td>
<td>96</td>
<td>16</td>
</tr>
<tr>
<td>28</td>
<td>PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-256A</td>
<td>104</td>
<td>16</td>
</tr>
<tr>
<td>50</td>
<td>PCC-Compute-XTS-Parameter-Using-AES-128</td>
<td>80</td>
<td>16</td>
</tr>
<tr>
<td>52</td>
<td>PCC-Compute-XTS-Parameter-Using-AES-256</td>
<td>96</td>
<td>16</td>
</tr>
<tr>
<td>58</td>
<td>PCC-Compute-XTS-Parameter-Using-Encrypted-AES-128</td>
<td>112</td>
<td>16</td>
</tr>
<tr>
<td>60</td>
<td>PCC-Compute-XTS-Parameter-Using-Encrypted-AES-256</td>
<td>128</td>
<td>16</td>
</tr>
</tbody>
</table>

Explanation:

Not applicable

Figure 7-256. Function Codes for PERFORM CRYPTOGRAPHIC COMPUTATION

All other function codes are unassigned.

The query function provides the means of indicating the availability of the other functions.
Figure 7-257 on page 7-270 shows the contents of general registers 0 and 1.

![Figure 7-257. General Register Assignment for PCC](image)

In the access-register mode, access register 1 specifies the address space containing the parameter block.

As observed by this CPU, other CPUs, and channel programs, reference to the parameter block may be multiple-access references, accesses to these storage locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

**Symbols Used in Function Descriptions**

The following symbols are used in the subsequent description of the PERFORM CRYPTOGRAPHIC COMPUTATION functions. Further description of the AES standard may be found in Reference [12.] on page xxviii. The XTS multiplication operation is the same as the GCM (Galois/counter mode) multiplication operation. Further description of the GCM multiplication over GF(2^{128}) may be found in Reference [15.] on page xxviii.

![Figure 7-258. Symbol For Bit-Wise Exclusive OR](image)

![Figure 7-259. Symbol For XTS Multiplication Operation Over GF(2^{128})](image)

![Figure 7-260. Symbol For XTS Power Operation Over GF(2^{128})](image)
PERFORM CRYPTOGRAPHIC COMPUTATION

PCC-Query (Function Code 0)
The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.

The parameter block used for the function has the following format:

```
<table>
<thead>
<tr>
<th>Symbol</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td>K</td>
<td>Key value</td>
</tr>
<tr>
<td>C</td>
<td>Ciphertext</td>
</tr>
<tr>
<td>P</td>
<td>Plaintext</td>
</tr>
</tbody>
</table>

```

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function
codes 0-127, respectively, of the PCC instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the PCC-Query function completes; condition codes 1, 2, and 3 are not applicable to this function.

**PCC-Compute-Last-Block-CMAC-Using-DEA (Function Code 1)**

**PCC-Compute-Last-Block-CMAC-Using-Encrypted-DEA (Function Code 9)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-DEA function has the following format:

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ML</td>
</tr>
<tr>
<td>8</td>
<td>Message</td>
</tr>
<tr>
<td>16</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>24</td>
<td>Cryptographic Key (K)</td>
</tr>
</tbody>
</table>

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-Encrypted-DEA function has the following format:

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ML</td>
</tr>
<tr>
<td>8</td>
<td>Message</td>
</tr>
<tr>
<td>16</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>24</td>
<td>Encrypted Cryptographic Key (WKd(K))</td>
</tr>
<tr>
<td>32</td>
<td>DEA Wrapping-Key</td>
</tr>
<tr>
<td>40</td>
<td>Verification Pattern</td>
</tr>
<tr>
<td>48</td>
<td>(WKdVP)</td>
</tr>
</tbody>
</table>

Figure 7-266. Parameter Block for PCC-Compute-Last-Block-CMAC-Using-DEA

For the PCC-Compute-Last-Block-CMAC-Using-DEA function, the initial-chaining value is in byte offsets 16-23 of the parameter block and the cryptographic key is in byte offsets 24-31 of the parameter block.

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-Encrypted-DEA function has the following format:

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ML</td>
</tr>
<tr>
<td>8</td>
<td>Message</td>
</tr>
<tr>
<td>16</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>24</td>
<td>Encrypted Cryptographic Key (WKd(K))</td>
</tr>
<tr>
<td>32</td>
<td>DEA Wrapping-Key</td>
</tr>
<tr>
<td>40</td>
<td>Verification Pattern</td>
</tr>
<tr>
<td>48</td>
<td>(WKdVP)</td>
</tr>
</tbody>
</table>

Figure 7-267. Parameter Block for PCC-Compute-Last-Block-CMAC-Using-Encrypted-DEA

For the PCC-Compute-Last-Block-CMAC-Using-Encrypted-DEA function, the contents of byte offsets 32-55 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the parameter-block location remains unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 16-23 of the parameter block contain the initial chaining value, and the contents of byte offsets 24-31 of the parameter block are deciphered using the DEA wrapping key to obtain the 64-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The description in the following paragraphs applies to both functions.

The bit length of the message in byte offsets 8-15 of the parameter block is specified by an 8-bit unsigned binary integer in the message-length (ML) field at byte offset 0. When the ML field contains a value greater than 64, the operation is completed by setting condition code 2. Otherwise, the ML field specifies the number of leftmost bits in byte offsets 8-15 that constitute the message. All other bits in byte offsets 8-15 are ignored.

When the ML field specifies a value of 0, a 64-bit message block is formed by setting the leftmost bit to one and all other bits to zero; when the ML field specifies a value of 64, the contents of byte offsets 8-15 form the 64-bit message block; when the ML field specifies a value of 63, the leftmost 63 bits in byte offsets 8-15 padded with a bit of one on the right form the 64-bit message block; when the ML field specifies a value in the range between 1 and 62, inclusively, the specified number of leftmost bits in byte offsets 8-15 padded on the right with a bit of one followed by the necessary number of bits of zero form a 64-bit message block.

When the ML field specifies the value of 64, a 64-bit subkey, \(K_x\), is derived using the 64-bit cryptographic key, K. When the ML field specifies a value in the range between 0 and 63, inclusively, a different subkey, \(K_y\), is derived using the 64-bit cryptographic key,
K. The subkey generation algorithm is shown in the following figure.

**Steps:**

1. \( L = \text{CIPH}_k(0) \)
2. If MSB (L) = 0, then \( K_x = L << 1 \); Else, \( K_x = (L << 1) \text{ XOR (R}_{64}) \)
3. If MSB (\( K_x \)) = 0, then \( K_y = K_x << 1 \); Else \( K_y = (K_x << 1) \text{ XOR (R}_{64}) \)

**Explanation:**

- \( \text{CIPH}_k(0) \) Encryption of the value zero using a 64-bit key and the DEA encryption algorithm.
- MSB(A) Most significant (leftmost) bit of A
- \( B<<1 \) The bit string that results from discarding the leftmost bit of B and appending a ‘0’ bit on the right.
- XOR Bit-wise exclusive OR.
- \( R_{64} \) A 64-bit value of 27.

*Figure 7-268. Subkey Generation Algorithm*

When the ML field specifies the value of 64, the 64-bit message block is exclusive-ORed with the subkey \( K_x \). The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then enciphered using the 64-bit cryptographic key, K, and the DEA encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 16-23 of the parameter block.

When the ML field specifies a value in the range between 0 and 63, inclusively, the 64-bit message block is exclusive-ORed with the subkey \( K_y \). The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then enciphered using the 64-bit cryptographic key, K, and the DEA encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 16-23 of the parameter block.

When the ML field specifies a value in the range between 0 and 64, inclusively, condition code 0 is set when execution of the function completes. Condition code 3 is not applicable to either function; condition code 1 is not applicable to the PCC-Compute-Last-Block-CMAC-Using-DEA function.

**PCC-Compute-Last-Block-CMAC-Using-TDEA-128 (Function Code 2)**

**PCC-Compute-Last-Block-CMAC-Using-Encrypted-TDEA-128 (Function Code 10)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-TDEA-128 function has the following format:

<table>
<thead>
<tr>
<th>0</th>
<th>ML</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>Message</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>Initial Chaining Value (ICV)</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Cryptographic Key (K)</td>
<td></td>
</tr>
</tbody>
</table>

*Figure 7-269. Parameter Block for PCC-Compute-Last-Block-CMAC-Using-TDEA-128*

For the PCC-Compute-Last-Block-CMAC-Using-TDEA-128 function, the initial-chaining value is in byte offsets 16-23 of the parameter block and the cryptographic key is in byte offsets 24-39 of the parameter block.

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-Encrypted-TDEA-128 function has the following format:

<table>
<thead>
<tr>
<th>0</th>
<th>ML</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>Message</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>Initial Chaining Value (ICV)</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Encrypted Cryptographic Key (WKd(K))</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
<td></td>
</tr>
</tbody>
</table>

*Figure 7-270. Parameter Block for PCC-Compute-Last-Block-CMAC-Using-Encrypted-TDEA-128*

For the PCC-Compute-Last-Block-CMAC-Using-Encrypted-TDEA-128 function, the contents of byte offsets 40-63 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the parameter-block location remains unchanged, and the operation
is completed by setting condition code 1. If they match, byte offsets 16-23 of the parameter block contain the initial chaining value, and the contents of byte offsets 24-39 of the parameter block are deciphered using the DEA wrapping key to obtain the 128-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The description in the following paragraphs applies to both functions.

The bit length of the message in byte offsets 8-15 of the parameter block is specified by an 8-bit unsigned binary integer in the message-length (ML) field at byte offset 0. When the ML field contains a value greater than 64, the operation is completed by setting condition code 2. Otherwise, the ML field specifies the number of leftmost bits in byte offsets 8-15 that constitute the message. All other bits in byte offsets 8-15 are ignored.

When the ML field specifies a value of 0, a 64-bit message block is formed by setting the leftmost bit to one and all other bits to zero; when the ML field specifies a value of 64, the contents of byte offsets 8-15 form the 64-bit message block; when the ML field specifies a value of 63, the leftmost 63 bits in byte offsets 8-15 padded with a bit of one on the right form the 64-bit message block; when the ML field specifies a value in the range between 1 and 62, inclusively, the specified number of leftmost bits in byte offsets 8-15 padded on the right with a bit of one followed by the necessary number of bits of zero form a 64-bit message block.

When the ML field specifies the value of 64, a 64-bit subkey, K_x, is derived using the 128-bit cryptographic key, K. When the ML field specifies a value in the range between 0 and 63, inclusively, a different subkey, K_y, is derived using the 128-bit cryptographic key, K. The subkey generation algorithm is shown in the following figure.

Steps:

1. \( L = \text{CIPH}_K(0) \)
2. If MSB (L) = 0, then \( K_x = L << 1 \); Else, \( K_x = (L << 1) \ XOR (R_{64}) \)
3. If MSB (K_x) = 0, then \( K_y = K_x << 1 \); Else \( K_y = (K_x << 1) \ XOR (R_{64}) \)

Figure 7-271. Subkey Generation Algorithm

Explanation:

- \( \text{CIPH}_K(0) \) Encryption of the value zero using a 128-bit key and the TDEA-128 encryption algorithm.
- MSB(A) Most significant (leftmost) bit of A
- B<<1 The bit string that results from discarding the leftmost bit of B and appending a '0' bit on the right.
- XOR Bit-wise exclusive OR.
- R_{64} A 64-bit value of 27.

When the ML field specifies the value of 64, the 64-bit message block is exclusive-ORed with the subkey K_x. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then deciphered using the 128-bit cryptographic key, K, and the TDEA-128 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 16-23 of the parameter block.

When the ML field specifies a value in the range between 0 and 63, inclusively, the 64-bit message block is exclusive-ORed with the subkey K_y. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then deciphered using the 128-bit cryptographic key, K, and the TDEA-128 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 16-23 of the parameter block.

When the ML field specifies a value in the range between 0 and 64, inclusively, condition code 0 is set when execution of the function completes. Condition code 3 is not applicable to either function; condition code 1 is not applicable to the PCC-Compute-Last-Block-CMAC-Using-TDEA-128 function.

PCC-Compute-Last-Block-CMAC-Using-TDEA-192 (Function Code 3)

PCC-Compute-Last-Block-CMAC-Using-Encrypted-TDEA-192 (Function Code 11)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.
The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ML</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Message</td>
</tr>
<tr>
<td>24</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>32</td>
<td>Cryptographic Key (K)</td>
</tr>
</tbody>
</table>

*Figure 7-272. Parameter Block for PCC-Compute-Last-Block-CMAC-Using-TDEA-192*

For the PCC-Compute-Last-Block-CMAC-Using-TDEA-192 function, the initial-chaining value is in byte offsets 16-23 of the parameter block and the cryptographic key is in byte offsets 24-47 of the parameter block.

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-Encrypted-TDEA-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ML</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Message</td>
</tr>
<tr>
<td>24</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>32</td>
<td>Encrypted Cryptographic Key (WKd(K))</td>
</tr>
<tr>
<td>40</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>

*Figure 7-273. Parameter Block for PCC-Compute-Last-Block-CMAC-Using-Encrypted-TDEA-192*

For the PCC-Compute-Last-Block-CMAC-Using-Encrypted-TDEA-192 function, the contents of byte offsets 48-71 of the parameter block are compared with the contents of the DEA wrapping-key verification-pattern register. If they mismatch, the parameter-block location remains unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 16-23 of the parameter block contain the initial chaining value, and the contents of byte offsets 24-47 of the parameter block are deciphered using the DEA wrapping key to obtain the 192-bit cryptographic key, K. (See the section "Protection of Cryptographic Keys" on page 7-374 for details.)

The description in the following paragraphs applies to both functions.

The bit length of the message in byte offsets 8-15 of the parameter block is specified by an 8-bit unsigned integer in the message-length (ML) field at byte offset 0. When the ML field contains a value greater than 64, the operation is completed by setting condition code 2. Otherwise, the ML field specifies the number of leftmost bits in byte offsets 8-15 that constitute the message. All other bits in byte offsets 8-15 are ignored.

When the ML field specifies a value of 0, a 64-bit message block is formed by setting the leftmost bit to one and all other bits to zero; when the ML field specifies a value of 64, the contents of byte offsets 8-15 form the 64-bit message block; when the ML field specifies a value of 63, the leftmost 63 bits in byte offsets 8-15 padded with a bit of one on the right form the 64-bit message block; when the ML field specifies a value in the range between 1 and 62, inclusively, the specified number of leftmost bits in byte offsets 8-15 padded on the right with a bit of one followed by the necessary number of bits of zero form a 64-bit message block.

When the ML field specifies the value of 64, a 64-bit subkey, $K_x$, is derived using the 192-bit cryptographic key, K. When the ML field specifies a value in the range between 0 and 63, inclusively, a different subkey, $K_y$, is derived using the 192-bit cryptographic key, K. The subkey generation algorithm is shown in the following figure.

**Steps:**
1. $L = \text{CIPH}_K(0)$
2. If MSB ($L$) = 0, then $K_x = L << 1$;
   Else, $K_x = (L << 1) \text{ XOR } (R_{64})$
3. If MSB ($K_y$) = 0, then $K_y = K_x << 1$;
   Else $K_y = (K_x << 1) \text{ XOR } (R_{64})$

*Figure 7-274. Subkey Generation Algorithm*
When the ML field specifies the value of 64, the 64-bit message block is exclusive-ORed with the subkey $K_x$. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then encrypted using the 192-bit cryptographic key, $K$, and the TDEA-192 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 16-23 of the parameter block.

When the ML field specifies a value in the range between 0 and 63, inclusively, the 64-bit message block is exclusive-ORed with the subkey $K_y$. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then encrypted using the 192-bit cryptographic key, $K$, and the TDEA-192 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 16-23 of the parameter block.

When the ML field specifies a value in the range between 0 and 64, inclusively, condition code 0 is set when execution of the function completes. Condition code 3 is not applicable to either function; condition code 1 is not applicable to the PCC-Compute-Last-Block-CMAC-Using-TDEA-192 function.

**PCC-Compute-Last-Block-CMAC-Using-AES-128 (Function Code 18)**

**PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-128 (Function Code 26)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.
PERFORM CRYPTOGRAPHIC COMPUTATION

phered using the AES wrapping key to obtain the 128-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The description in the following paragraphs applies to both functions.

The bit length of the message in byte offsets 8-23 of the parameter block is specified by an 8-bit unsigned binary integer in the message-length (ML) field at byte offset 0. When the ML field contains a value greater than 128, the operation is completed by setting condition code 2. Otherwise, the ML field specifies the number of leftmost bits in byte offsets 8-23 that constitute the message. All other bits in byte offsets 8-23 are ignored.

When the ML field specifies a value of 0, a 128-bit message block is formed by setting the leftmost bit to one and all other bits to zero; when the ML field specifies a value of 128, the contents of byte offsets 8-23 form the 128-bit message block; when the ML field specifies a value of 127, the leftmost 127 bits in byte offsets 8-23 padded with a bit of one on the right form the 128-bit message block; when the ML field specifies a value in the range between 1 and 126, inclusively, the specified number of leftmost bits in byte offsets 8-23 padded on the right with a bit of one followed by the necessary number of bits of zero form a 128-bit message block.

When the ML field specifies the value of 128, a 128-bit subkey, $K_x$, is derived using the 128-bit cryptographic key, K. When the ML field specifies a value in the range between 0 and 127, inclusively, a different subkey, $K_y$, is derived using the 128-bit cryptographic key, K. The subkey generation algorithm is shown in the following figure.

**Steps:**

1. $L = \text{CIPH}_K(0)$
2. If MSB (L) = 0, then $K_x = L << 1$; Else, $K_x = (L << 1) \text{ XOR } (R_{128})$
3. If MSB ($K_x$) = 0, then $K_y = K_x << 1$; Else $K_y = (K_x << 1) \text{ XOR } (R_{128})$

**Explanation:**

- $\text{CIPH}_K(0)$: Encryption of the value zero using a 128-bit key and the AES-128 encryption algorithm.
- MSB(A): Most significant (leftmost) bit of A
- $B << 1$: The bit string that results from discarding the leftmost bit of B and appending a '0' bit on the right.
- $\text{XOR}$: Bit-wise exclusive OR.
- $R_{128}$: A 128-bit value of 135.

**Figure 7-277. Subkey Generation Algorithm (Continued)**

When the ML field specifies the value of 128, the 128-bit message block is exclusive-ORed with the subkey $K_x$. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then enciphered using the 128-bit cryptographic key, K, and the AES-128 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 24-39 of the parameter block.

When the ML field specifies a value in the range between 0 and 127, inclusively, the 128-bit message block is exclusive-ORed with the subkey $K_y$. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then enciphered using the 128-bit cryptographic key, K, and the AES-128 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 24-39 of the parameter block.

When the ML field specifies a value in the range between 0 and 128, inclusively, condition code 0 is set when execution of the function completes. Condition code 3 is not applicable to either function; condition code 1 is not applicable to the PCC-Compute-Last-Block-CMAC-Using-AES-128 function.

**PCC-Compute-Last-Block-CMAC-Using-AES-192 (Function Code 19)**

**PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-192 (Function Code 27)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.
The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-AES-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ML</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Message</td>
</tr>
<tr>
<td>24</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>32</td>
<td>Cryptographic Key (K)</td>
</tr>
<tr>
<td>48</td>
<td>AES Wrapping-Key</td>
</tr>
<tr>
<td>56</td>
<td>Verification Pattern (WKaVP)</td>
</tr>
</tbody>
</table>

**Figure 7-278. Parameter Block for PCC-Compute-Last-Block-CMAC-Using-AES-192**

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-192 function has the following format:

<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ML</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Message</td>
</tr>
<tr>
<td>24</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>32</td>
<td>Encrypted Cryptographic Key (WKa(K))</td>
</tr>
<tr>
<td>40</td>
<td>AES Wrapping-Key</td>
</tr>
<tr>
<td>48</td>
<td>Verification Pattern (WKaVP)</td>
</tr>
</tbody>
</table>

**Figure 7-279. Parameter Block for PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-192**

For the PCC-Compute-Last-Block-CMAC-Using-AES-192 function, the initial chaining value is in byte offsets 24-39 of the parameter block and the cryptographic key is in byte offsets 40-63 of the parameter block.

For the PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-192 function, the contents of byte offsets 40-63 of the parameter block are deciphered using the AES wrapping key to obtain the 192-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The description in the following paragraphs applies to both functions.

The bit length of the message in byte offsets 8-23 of the parameter block is specified by an 8-bit unsigned binary integer in the message-length (ML) field at byte offset 0. When the ML field contains a value greater than 128, the operation is completed by setting condition code 2. Otherwise, the ML field specifies the number of leftmost bits in byte offsets 8-23 that constitute the message. All other bits in byte offsets 8-23 are ignored.

When the ML field specifies a value of 0, a 128-bit message block is formed by setting the leftmost bit to one and all other bits to zero; when the ML field specifies a value of 128, the contents of byte offsets 8-23 form the 128-bit message block; when the ML field specifies a value of 127, the leftmost 127 bits in byte offsets 8-23 padded with a bit of one on the right form the 128-bit message block; when the ML field specifies a value in the range between 1 and 126, inclusively, the specified number of leftmost bits in byte offsets 8-23 padded on the right with a bit of one followed by the necessary number of bits of zero form a 128-bit message block.

When the ML field specifies the value of 128, a 128-bit subkey, \( K_x \), is derived using the 192-bit cryptographic key, K. When the ML field specifies a value in the range between 0 and 127, inclusively, a different subkey, \( K_y \), is derived using the 192-bit cryptographic key, K. The subkey generation algorithm is shown in the following figure.

**Figure 7-280. Subkey Generation Algorithm**

**Steps:**

1. \( L = \text{CIPH}_k(0) \)
2. If MSB \( (L) = 0 \), then \( K_x = L \ll 1 \);
   Else, \( K_x = (L \ll 1) \text{ XOR } (R_{128}) \)
3. If MSB \( (K_y) = 0 \), then \( K_y = K_y \ll 1 \);
   Else \( K_y = (K_y \ll 1) \text{ XOR } (R_{128}) \)
When the ML field specifies the value of 128, the 128-bit message block is exclusive-ORed with the subkey $K_x$. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then enciphered using the 192-bit cryptographic key, $K$, and the AES-192 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 24-39 of the parameter block.

When the ML field specifies a value in the range between 0 and 127, inclusively, the 128-bit message block is exclusive-ORed with the subkey $K_y$. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value. The result of the second exclusive-OR operation is then enciphered using the 128-bit cryptographic key, $K_y$, and the AES-192 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 24-39 of the parameter block.

When the ML field specifies a value in the range between 0 and 128, inclusively, condition code 0 is set when execution of the function completes. Condition code 3 is not applicable to either function; condition code 1 is not applicable to the PCC-Compute-Last-Block-CMAC-Using-AES-192 function.

PCC-Compute-Last-Block-CMAC-Using-AES-256 (Function Code 20)

PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-256 (Function Code 28)
The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-AES-256 function has the following format:

```
<table>
<thead>
<tr>
<th>ML</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>Message</td>
</tr>
<tr>
<td>24</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>40</td>
<td>Cryptographic Key (K)</td>
</tr>
</tbody>
</table>
```

For the PCC-Compute-Last-Block-CMAC-Using-AES-256 function, the initial-chaining value is in byte offsets 24-39 of the parameter block and the cryptographic key is in byte offsets 40-71 of the parameter block.

The parameter block used for the PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-256 function has the following format:

```
<table>
<thead>
<tr>
<th>ML</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>Message</td>
</tr>
<tr>
<td>24</td>
<td>Initial Chaining Value (ICV)</td>
</tr>
<tr>
<td>40</td>
<td>Encrypted Cryptographic Key (WK_y(K))</td>
</tr>
<tr>
<td>56</td>
<td>AES Wrapping-Key Verification Pattern (WK_VP)</td>
</tr>
</tbody>
</table>
```

For the PCC-Compute-Last-Block-CMAC-Using-Encrypted-AES-256 function, the contents of byte offsets 72-103 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the parameter-
block location remains unchanged, and the operation is completed by setting condition code 1. If they match, byte offsets 24-39 of the parameter block contain the initial chaining value, and the contents of byte offsets 40-71 of the parameter block are deciphered using the AES wrapping key to obtain the 256-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.)

The description in the following paragraphs applies to both functions.

The bit length of the message in byte offsets 8-23 of the parameter block is specified by an 8-bit unsigned binary integer in the message-length (ML) field at byte offset 0. When the ML field contains a value greater than 128, the operation is completed by setting condition code 2. Otherwise, the ML field specifies the number of leftmost bits in byte offsets 8-23 that constitute the message. All other bits in byte offsets 8-23 are ignored.

When the ML field specifies a value of 0, a 128-bit message block is formed by setting the leftmost bit to one and all other bits to zero; when the ML field specifies a value of 128, the contents of byte offsets 8-23 form the 128-bit message block; when the ML field specifies a value of 127, the leftmost 127 bits in byte offsets 8-23 padded with a bit of one on the right form the 128-bit message block; when the ML field specifies a value in the range between 1 and 126, inclusively, the specified number of leftmost bits in byte offsets 8-23 padded on the right with a bit of one followed by the necessary number of bits of zero form a 128-bit message block.

When the ML field specifies the value of 128, a 128-bit subkey, $K_x$, is derived using the 256-bit cryptographic key, $K$. When the ML field specifies a value in the range between 0 and 127, inclusively, a different subkey, $K_y$, is derived using the 256-bit cryptographic key, $K$. The subkey generation algorithm is shown in the following figure.

**Figure 7-283. Subkey Generation Algorithm**

<table>
<thead>
<tr>
<th>Steps</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.</td>
<td>$L = \text{CIPH}_K(0)$</td>
</tr>
<tr>
<td>2.</td>
<td>If MSB ($L$) = 0, then $K_x = L &lt;&lt; 1$; Else, $K_x = (L &lt;&lt; 1) \text{ XOR } R_{128}$</td>
</tr>
<tr>
<td>3.</td>
<td>If MSB ($K_x$) = 0, then $K_y = K_x &lt;&lt; 1$; Else $K_y = (K_x &lt;&lt; 1) \text{ XOR } R_{128}$</td>
</tr>
</tbody>
</table>

When the ML field specifies the value of 128, the 128-bit message block is exclusive-ORed with the subkey $K_x$. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value.

The result of the second exclusive-OR operation is then enciphered using the 256-bit cryptographic key, $K$, and the AES-256 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 24-39 of the parameter block.

When the ML field specifies a value in the range between 0 and 127, inclusively, the 128-bit message block is exclusive-ORed with the subkey $K_y$. The result of the exclusive-OR operation is then exclusive-ORed with initial-chaining value.

The result of the second exclusive-OR operation is then enciphered using the 256-bit cryptographic key, $K$, and the AES-256 encryption algorithm. The result of the encryption operation is the CMAC and is placed in byte offsets 24-39 of the parameter block.

When the ML field specifies a value in the range between 0 and 128, inclusively, condition code 0 is set when execution of the function completes. Condition code 3 is not applicable to either function; condition code 1 is not applicable to the PCC-Compute-Last-Block-CMAC-Using-AES-256 function.

**PCC-Compute-XTS-Parameter-Using-AES-128 (Function Code 50)**

**PCC-Compute-XTS-Parameter-Using-Encrypted-AES-128 (Function Code 58)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.
The parameter block used for the PCC-Compute-XTS-Parameter-Using-AES-128 function has the following format:

For the PCC-Compute-XTS-Parameter-Using-AES-128 function, the cryptographic key is in byte offsets 0-15 of the parameter block; the 128-bit tweak value (i) and the 128-bit block sequential number (j) are in byte offsets 16-31 and 32-47, respectively, of the parameter block. When the block sequential number is zero, the contents of byte offsets 48-79 of the parameter block are ignored, the encrypted tweak value is placed in byte offsets 64-79 of the parameter block, and the operation is completed by setting condition code 0. When the block sequential number is nonzero, byte offsets 48-63 of the parameter block contain the index of the next bit in j to be processed. In this case, if the contents of byte offsets 48-63 are zero, then it is the initial execution of the computation, and the contents of byte offsets 64-79 of the parameter block are ignored; if the contents of byte offsets 48-63 are in the range between 1 and 127, inclusively, then byte offsets 64-79 contain the partial XTS parameter computed by a previous iteration; if byte offsets 48-63 of the parameter block contain a value greater than 127, the operation is completed by setting condition code 2.

The parameter block used for the PCC-Compute-XTS-Parameter-Using-Encrypted-AES-128 function has the following format:

For the PCC-Compute-XTS-Parameter-Using-Encrypted-AES-128 function, the contents of byte offsets 16-47 of the parameter block are compared with the contents of the AES wrapping-key verification-pattern register. If they mismatch, the parameter-block location remains unchanged, and the operation is completed by setting condition code 1. If they match, the contents of byte offsets 0-15 of the parameter block are deciphered using the AES wrapping key to obtain the 128-bit cryptographic key, K. (See the section “Protection of Cryptographic Keys” on page 7-374 for details.) The 128-bit tweak value (i) and the 128-bit block sequential number (j) are in byte offsets 48-63 and 64-79, respectively, of the parameter block. When the block sequential number is zero, the contents of byte offsets 80-111 of the parameter block are ignored, the encrypted tweak value is placed in byte offsets 96-111 of the parameter block, and the operation is completed by setting condition code 0. When the block sequential number is nonzero, byte offsets 80-95 of the parameter block contain the index of the next bit in j to be processed. In this case, if the contents of byte offsets 80-95 are zero, then it is the initial execution of the computation, and the contents of byte offsets 96-111 of the parameter block are ignored; if the contents of byte offsets 80-95 are in the range between 1 and 127, inclusively, then byte offsets 96-111 contain the partial XTS parameter computed by a previous iteration;
PERFORM CRYPTOGRAPHIC COMPUTATION

if byte offsets 80-95 of the parameter block contain a value greater than 127, the operation is completed by setting condition code 2.

The following description applies to both functions.

The 128-bit XTS parameter is the result of multiplying the encrypted tweak value by the value of 2 raised to the power of the block sequential number (j). Both the power and multiplication operations are performed over GF($2^{128}$). The 128-bit tweak value (i) is encrypted using the 128-bit cryptographic key and the AES encryption algorithm. The operation is shown in Figure 7-286.

The value of 2 raised to the power of j is computed as follows: For each bit in j, the value of 2 raised to the power of an exponent, that is a 128-bit unsigned binary integer with a one in that bit and zeros in all other bits, is pre-computed. To obtain the value of 2 raised to the power of j, the pre-computed values that correspond to a bit of one in j are multiplied together. The power and multiplication operations are performed over GF($2^{128}$).

For a nonzero j, bits in j are processed from left to right, with an index of 0 for the leftmost bit and an index of 127 for the rightmost bit. The operation is ended when all bits in j have been processed (called normal completion) or when a CPU-determined number of bits that is less than the total number of bits in j have been processed (called partial completion). The CPU-determined number of bits depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of bits is usually nonzero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.

When the operation ends due to normal completion, condition code 0 is set and the intermediate bit index field (t) in the parameter block is set to 128. When the operation ends due to partial completion, condition code 3 is set and the intermediate bit index field (t) in the parameter block is set to the index of the next bit in j to be processed. For the Compute-XTS-Parameter-Using-AES-128 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 64-79 of the parameter block. For the Compute-XTS-Parameter-Using-Encrypted-AES-128 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 96-111 of the parameter block.

Condition code 1 is not applicable to the PCC-Compute-XTS-Parameter-Using-AES-128 function.

PCC-Compute-XTS-Parameter-Using-AES-256 (Function Code 52)

PCC-Compute-XTS-Parameter-Using-Encrypted-AES-256 (Function Code 60)

The locations of the operands and addresses used by the instruction are as shown in Figure 7-257 on page 7-270.

The parameter block used for the PCC-Compute-XTS-Parameter-Using-AES-256 function has the following format:

For the PCC-Compute-XTS-Parameter-Using-AES-256 function, the cryptographic key is in byte offsets 0-31 of the parameter block; the 128-bit tweak value (i) and the 128-bit block sequential number (j) are in byte offsets 32-47 and 48-63, respectively, of the parameter block. When the block sequential number
is zero, the contents of byte offsets 64-95 of the parameter block are ignored, the encrypted tweak value is placed in byte offsets 80-95 of the parameter block, and the operation is completed by setting condition code 0. When the block sequential number is nonzero, byte offsets 64-79 of the parameter block contain the index of the next bit in j to be processed. In this case, if the contents of byte offsets 64-79 are zero, then it is the initial execution of the computation, and the contents of byte offsets 80-95 of the parameter block are ignored; if the contents of byte offsets 64-79 are in the range between 1 and 127, inclusively, then byte offsets 80-95 contain the partial XTS parameter computed by a previous iteration; if byte offsets 64-79 of the parameter block contain a value greater than 127, the operation is completed by setting condition code 2.

The parameter block used for the PCC-Compute-XTS-Parameter-Using-Encrypted-AES-256 function has the following format:

![Parameter Block Diagram](image)

The following description applies to both functions.

The 128-bit XTS parameter is the result of multiplying the encrypted tweak value by the value of 2 raised to the power of the block sequential number (j). Both the power and multiplication operations are performed over GF(2\(^{128}\)). The 128-bit tweak value (i) is encrypted using the 256-bit cryptographic key and the AES encryption algorithm. The operation is shown in Figure 7-289.

![AES Encryption Diagram](image)

The value of 2 raised to the power of j is computed as follows: For each bit in j, the value of 2 raised to the power of an exponent, that is a 128-bit unsigned binary integer with an one in that bit and zeros in all other bits, is pre-computed. To obtain the value of 2 raised to the power of j, the pre-computed values that correspond to a bit of one in j are multiplied together. The power and multiplication operations are performed over GF(2\(^{128}\)).
For a nonzero j, bits in j are processed from left to right, with an index of 0 for the leftmost bit and an index of 127 for the right most bit. The operation is ended when all bits in j have been processed (called normal completion) or when a CPU-determined number of bits that is less than the total number of bits in j have been processed (called partial completion). The CPU-determined number of bits depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of bits is usually nonzero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.

When the operation ends due to normal completion, condition code 0 is set and the intermediate bit index field (t) in the parameter block is set to 128. When the operation ends due to partial completion, condition code 3 is set and the intermediate bit index field (t) in the parameter block is set to the index of the next bit in j to be processed. For the Compute-XTS-Parameter-Using-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 80-95 of the parameter block. For the Compute-XTS-Parameter-Using-Encrypted-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 112-127 of the parameter block.

Condition code 1 is not applicable to the PCC-Compute-XTS-Parameter-Using-AES-256 function.

Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

Resulting Condition Code:

0 Normal completion
1 Verification-pattern mismatch
2 Invalid bit index or message length
3 Partial completion

Program Exceptions:

- Access (fetch, parameter block; fetch and store, intermediate bit index, XTS parameter, initial chaining value)
- Operation (if the message-security-assist extension 4 is not installed)
- Specification
- Transaction constraint

When the operation ends due to normal completion, condition code 0 is set and the intermediate bit index field (t) in the parameter block is set to 128. When the operation ends due to partial completion, condition code 3 is set and the intermediate bit index field (t) in the parameter block is set to the index of the next bit in j to be processed. For the Compute-XTS-Parameter-Using-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 80-95 of the parameter block. For the Compute-XTS-Parameter-Using-Encrypted-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 112-127 of the parameter block.

Condition code 1 is not applicable to the PCC-Compute-XTS-Parameter-Using-AES-256 function.

Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

Resulting Condition Code:

0 Normal completion
1 Verification-pattern mismatch
2 Invalid bit index or message length
3 Partial completion

Program Exceptions:

- Access (fetch, parameter block; fetch and store, intermediate bit index, XTS parameter, initial chaining value)
- Operation (if the message-security-assist extension 4 is not installed)
- Specification
- Transaction constraint

When the operation ends due to normal completion, condition code 0 is set and the intermediate bit index field (t) in the parameter block is set to 128. When the operation ends due to partial completion, condition code 3 is set and the intermediate bit index field (t) in the parameter block is set to the index of the next bit in j to be processed. For the Compute-XTS-Parameter-Using-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 80-95 of the parameter block. For the Compute-XTS-Parameter-Using-Encrypted-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 112-127 of the parameter block.

Condition code 1 is not applicable to the PCC-Compute-XTS-Parameter-Using-AES-256 function.

Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

Resulting Condition Code:

0 Normal completion
1 Verification-pattern mismatch
2 Invalid bit index or message length
3 Partial completion

Program Exceptions:

- Access (fetch, parameter block; fetch and store, intermediate bit index, XTS parameter, initial chaining value)
- Operation (if the message-security-assist extension 4 is not installed)
- Specification
- Transaction constraint

When the operation ends due to normal completion, condition code 0 is set and the intermediate bit index field (t) in the parameter block is set to 128. When the operation ends due to partial completion, condition code 3 is set and the intermediate bit index field (t) in the parameter block is set to the index of the next bit in j to be processed. For the Compute-XTS-Parameter-Using-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 80-95 of the parameter block. For the Compute-XTS-Parameter-Using-Encrypted-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 112-127 of the parameter block.

Condition code 1 is not applicable to the PCC-Compute-XTS-Parameter-Using-AES-256 function.

Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

Resulting Condition Code:

0 Normal completion
1 Verification-pattern mismatch
2 Invalid bit index or message length
3 Partial completion

Program Exceptions:

- Access (fetch, parameter block; fetch and store, intermediate bit index, XTS parameter, initial chaining value)
- Operation (if the message-security-assist extension 4 is not installed)
- Specification
- Transaction constraint

When the operation ends due to normal completion, condition code 0 is set and the intermediate bit index field (t) in the parameter block is set to 128. When the operation ends due to partial completion, condition code 3 is set and the intermediate bit index field (t) in the parameter block is set to the index of the next bit in j to be processed. For the Compute-XTS-Parameter-Using-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 80-95 of the parameter block. For the Compute-XTS-Parameter-Using-Encrypted-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 112-127 of the parameter block.

Condition code 1 is not applicable to the PCC-Compute-XTS-Parameter-Using-AES-256 function.

Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

Resulting Condition Code:

0 Normal completion
1 Verification-pattern mismatch
2 Invalid bit index or message length
3 Partial completion

Program Exceptions:

- Access (fetch, parameter block; fetch and store, intermediate bit index, XTS parameter, initial chaining value)
- Operation (if the message-security-assist extension 4 is not installed)
- Specification
- Transaction constraint

When the operation ends due to normal completion, condition code 0 is set and the intermediate bit index field (t) in the parameter block is set to 128. When the operation ends due to partial completion, condition code 3 is set and the intermediate bit index field (t) in the parameter block is set to the index of the next bit in j to be processed. For the Compute-XTS-Parameter-Using-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 80-95 of the parameter block. For the Compute-XTS-Parameter-Using-Encrypted-AES-256 function, the computed XTS parameter or partial XTS parameter is placed in byte offsets 112-127 of the parameter block.

Condition code 1 is not applicable to the PCC-Compute-XTS-Parameter-Using-AES-256 function.

Special Conditions

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

Resulting Condition Code:

0 Normal completion
1 Verification-pattern mismatch
2 Invalid bit index or message length
3 Partial completion

Program Exceptions:
lock is released. However, as observed by other CPUs: (1) storage operands, including fields in a parameter list that may be used, may be fetched, and may be tested for store-type access exceptions if a store at a tested location is possible, before the lock is obtained, and (2) operands may be stored in the parameter list after the lock has been released. If an operand not in the parameter list is fetched before the lock is obtained, it is fetched again after the lock has been obtained.

The function code can specify any of six operations: compare and load, compare and swap, double compare and swap, compare and swap and store, compare and swap and double store, or compare and swap and triple store.

A test bit in general register 0 specifies, when one, that a lock is not to be obtained and none of the six operations is to be performed but, instead, the validity of the function code is to be tested. This will be useful if additional function codes for additional operations are assigned in the future. This definition is written as if the test bit is zero except when stated otherwise.

If compare and load is specified, the first-operand comparison value and the second operand are compared. If they are equal, the fourth operand is placed in the third-operand location. If the comparison indicates inequality, the second operand is placed in the first-operand-comparison-value location as a new first-operand comparison value.

If compare and swap is specified, the first-operand comparison value and the second operand are compared. If they are equal, the first-operand replacement value is stored at the second-operand location. If the comparison indicates inequality, the second operand is placed in the first-operand-comparison-value location as a new first-operand comparison value.

If double compare and swap is specified, the first-operand comparison value and the second operand are compared. If they are equal, the third-operand comparison value and the fourth operand are compared. If both comparisons indicate equality, the first-operand and third-operand replacement values are stored at the second-operand location and fourth-operand location, respectively. If the first comparison indicates inequality, the second operand is placed in the first-operand-comparison-value location as a new first-operand comparison value. If the first comparison indicates equality but the second does not, the fourth operand is placed in the third-operand-comparison-value location as a new third-operand comparison value.

If compare and swap and store, double store, or triple store is specified, the first-operand comparison value and the second operand are compared. If they are equal, the first-operand replacement value is stored at the second-operand location, and the third operand is stored at the fourth-operand location. Then, if the operation is the double-store or triple-store operation, the fifth operand is stored at the sixth-operand location, and, if it is the triple-store operation, the seventh operand is stored at the eighth-operand location. If the first-operand comparison indicates inequality, the second operand is placed in the first-operand-comparison-value location as a new first-operand comparison value.

After any of the six operations, the result of the comparison or comparisons is indicated in the condition code.

The function code (FC) is in bit positions 56-63 of general register 0. The function code specifies not only the operation to be performed but also the length of the operands and whether the first-operand comparison and replacement values and the third operand or third-operand comparison and replacement values, which are referred to collectively simply as the first and third operands, are in general registers or a parameter list. The pattern of the function codes is as follows:

- A function code that is a multiple of 4 (including 0) specifies a 32-bit length with the first and third operands in bit positions 32-63 of general registers.
- A function code that is one more than a multiple of 4 specifies a 64-bit length with the first and third operands in a parameter list.
- A function code that is 2 more than a multiple of 4 specifies a 64-bit length with the first and third operands in bit positions 0-63 of general registers.
- A function code that is 3 more than a multiple of 4 specifies a 128-bit length with the first and third operands in a parameter list.

Figure 7-291 on page 7-286 shows the function codes, operation names, and operand lengths, and
also symbols that may be used to refer to the operations in discussions. For example, PLO.DCS may be used to mean PERFORM LOCKED OPERATION with function code 8. In the symbols, the letter “G” indicates a 64-bit operand length, the letter “R” indicates that some or all 64-bit operands are in general registers, and the letter “X” indicates a 128-bit operand length.

The CPU can perform all of the operations specified by the function codes listed in Figure 7-291. Specifying operations that the CPU can perform are called valid. Function codes that have not been assigned to operations or that specify operations that the CPU cannot perform because the operations are not implemented (installed) are called invalid.

Bit 55 of general register 0 is the test bit (T). When bit 55 is zero, the function code in general register 0 must be valid; otherwise, a specification exception is recognized. When bit 55 is one, the condition code is set to 0 if the function code is valid or to 3 if the function code is invalid, and no other operation is performed.

Bits 32-54 of general register 0 must be all zeros; otherwise, a specification exception is recognized. When bit 55 of the register is one, this is the only exception that can be recognized. Bits 0-31 of general register 0 are ignored.

The lock to be used is represented by a program lock token (PLT) whose logical address is specified in general register 1. In the 24-bit addressing mode, the PLT address is bits 40-63 of general register 1, and bits 0-39 of the register are ignored. In the 31-bit addressing mode, the PLT address is bits 33-63 of the register, and bits 0-32 of the register are ignored. In the 64-bit addressing mode, the PLT address is bits 0-63 of the register.

The contents of general registers 0 and 1 described above are shown in Figure 7-292.

For the even-numbered function codes, including 0, the first-operand comparison value is in general register R1. For the even-numbered function codes beginning with 4, the first-operand replacement value is in general register R1 + 1, and R1 designates an even-odd pair of registers and must designate an even-numbered register; otherwise, a specification exception is recognized. For function codes 0 and 2, R1 can be even or odd.

For function codes 0, 2, 12, and 14, the third operand is in general register R3, and R3 can be even or odd.

For function codes 8 and 10, the third-operand comparison value is in general register R3, the third-operand replacement value is in general register R3 + 1, and R3 designates an even-odd pair of registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

For all function codes, the B2 and D2 fields of the instruction specify the second-operand address.

For function codes 0, 2, 8, 10, 12, and 14, the B4 and D4 fields of the instruction specify the fourth-operand address.

<table>
<thead>
<tr>
<th>Function Code</th>
<th>Operation</th>
<th>Operand Length (Bits)</th>
<th>Function Symbol</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Compare and load</td>
<td>32</td>
<td>CL</td>
</tr>
<tr>
<td>1</td>
<td>Same as 0</td>
<td>64</td>
<td>CLG</td>
</tr>
<tr>
<td>2</td>
<td>Same as 0</td>
<td>64</td>
<td>CLGR</td>
</tr>
<tr>
<td>3</td>
<td>Same as 0</td>
<td>128</td>
<td>CLX</td>
</tr>
<tr>
<td>4</td>
<td>Compare and swap</td>
<td>32</td>
<td>CS</td>
</tr>
<tr>
<td>5</td>
<td>Same as 4</td>
<td>64</td>
<td>CSG</td>
</tr>
<tr>
<td>6</td>
<td>Same as 4</td>
<td>64</td>
<td>CSGR</td>
</tr>
<tr>
<td>7</td>
<td>Same as 4</td>
<td>128</td>
<td>CSX</td>
</tr>
<tr>
<td>8</td>
<td>Double compare and swap</td>
<td>32</td>
<td>DCS</td>
</tr>
<tr>
<td>9</td>
<td>Same as 8</td>
<td>64</td>
<td>DCSG</td>
</tr>
<tr>
<td>10</td>
<td>Same as 8</td>
<td>64</td>
<td>DCSGR</td>
</tr>
<tr>
<td>11</td>
<td>Same as 8</td>
<td>128</td>
<td>DCSX</td>
</tr>
<tr>
<td>12</td>
<td>Compare and swap and store</td>
<td>32</td>
<td>CSST</td>
</tr>
<tr>
<td>13</td>
<td>Same as 12</td>
<td>64</td>
<td>CSSTG</td>
</tr>
<tr>
<td>14</td>
<td>Same as 12</td>
<td>64</td>
<td>CSSTGR</td>
</tr>
<tr>
<td>15</td>
<td>Same as 12</td>
<td>128</td>
<td>CSSTX</td>
</tr>
<tr>
<td>16</td>
<td>Compare and swap and double store</td>
<td>32</td>
<td>CSDST</td>
</tr>
<tr>
<td>17</td>
<td>Same as 16</td>
<td>64</td>
<td>CSDSTG</td>
</tr>
<tr>
<td>18</td>
<td>Same as 16</td>
<td>64</td>
<td>CSDSTGR</td>
</tr>
<tr>
<td>19</td>
<td>Same as 16</td>
<td>128</td>
<td>CSDSTX</td>
</tr>
<tr>
<td>20</td>
<td>Compare and swap and triple store</td>
<td>32</td>
<td>CSTST</td>
</tr>
<tr>
<td>21</td>
<td>Same as 20</td>
<td>64</td>
<td>CSTSTG</td>
</tr>
<tr>
<td>22</td>
<td>Same as 20</td>
<td>64</td>
<td>CSTSTGR</td>
</tr>
<tr>
<td>23</td>
<td>Same as 20</td>
<td>128</td>
<td>CSTSTX</td>
</tr>
</tbody>
</table>

Figure 7-291. PERFORM LOCKED OPERATION Function Codes and Operations
For function codes 1, 3, 5, 7, 9, 11, 13, 15, and 16-23, the B₄ and D₄ fields of the instruction specify the address of a parameter list that is used by the instruction, and this address is not called the fourth-operand address. The parameter list contains odd-numbered operands, including comparison and replacement values, and addresses of even-numbered operands other than the second operand. In the access-register mode, the parameter list also contains access-list-entry tokens (ALETs) associated with the even-numbered-operand addresses.

In the access-register mode, for function codes that cause use of a parameter list containing an ALET, R₃ must not be zero; otherwise, a specification exception is recognized.

The rules about R₁ and R₃, and the use of the address specified by B₄ and D₄, are summarized in Figure 7-293 on page 7-287.

### Function Codes Operation | R₁ | R₃ | D₄(B₄)
--- | --- | --- | ---
0 and 2 | Compare and load | EO | EO | Op4a
1 and 3 | Compare and load | - | NZ | PLa
4 and 6 | Compare and swap | E | - | -
5 and 7 | Compare and swap | - | - | PLa
8 and 10 | Double compare and swap | E | E | Op4a
9 and 11 | Double compare and swap | - | NZ | PLa
12 and 14 | Compare and swap and store | E | EO | Op4a

Explanation:
- Ignored.
E Must be even.
EO Can be even or odd.
NZ Must be nonzero in the access-register mode. Ignored otherwise.
Op4a D4(B4) is operand-4 address.
PLa D4(B4) is parameter-list address.

Figure 7-293. Register Rules and D₄(B₄) Usage for PERFORM LOCKED OPERATION

Figure 7-294 on page 7-288 shows the locations of the operands (including operand comparison and replacement values), operand addresses, and parameter-list address used by the instruction.

Operand addresses in a parameter list, if used, are in doublewords in the list. In the 24-bit addressing mode, an operand address is bits 40-63 of a doubleword, and bits 0-39 of the doubleword are ignored. In the 31-bit addressing mode, an operand address is bits 33-63 of a doubleword, and bits 0-32 of the doubleword are ignored. In the 64-bit addressing mode, an operand address is bits 0-63 of a doubleword.
In the access-register mode, access register 1 specifies the address space containing the program lock token (PLT), access register B2 specifies the address space containing the second operand, and access register B4 specifies the address space containing a fourth operand or a parameter list as shown in Figure 7-294 on page 7-288. Also, for an operand whose address is in the parameter list, the associated ALET in the parameter list is loaded into access register R3 when the exception or event is recognized. Then, during the resulting program interruption, if a value is due to be stored as the exception access identification at real location 160 or the PER access identification at real location 161, R3 is stored. If the instruction execution is completed without the recognition of an exception or event, the contents of access register R3 are unpredictable. When not in the access-register mode, or when a parameter list containing an ALET is not used, the contents of access register R3 remain unchanged.

<table>
<thead>
<tr>
<th>Function Codes</th>
<th>Operation</th>
<th>Op1c</th>
<th>Op1r</th>
<th>Op2a</th>
<th>Op3 or Op4</th>
<th>Op5 and Op6a</th>
<th>Op7 and Op8a</th>
<th>PLa</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 and 2</td>
<td>Compare and load</td>
<td>R1</td>
<td>-</td>
<td>D2(B2)</td>
<td>R3</td>
<td>D4(B4)</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>1 and 3</td>
<td>Compare and load</td>
<td>PL</td>
<td>R1</td>
<td>D2(B2)</td>
<td>PL</td>
<td>PL</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>4 and 6</td>
<td>Compare and swap</td>
<td>R1</td>
<td>R1+1</td>
<td>D2(B2)</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>5 and 7</td>
<td>Compare and swap</td>
<td>PL</td>
<td>PL</td>
<td>D2(B2)</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>8 and 10</td>
<td>Double compare and swap</td>
<td>R1</td>
<td>R1+1</td>
<td>D2(B2)</td>
<td>R3</td>
<td>R3+1</td>
<td>D4(B4)</td>
<td>-</td>
</tr>
<tr>
<td>9 and 11</td>
<td>Double compare and swap</td>
<td>PL</td>
<td>PL</td>
<td>D2(B2)</td>
<td>PL</td>
<td>PL</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>12 and 14</td>
<td>Compare and swap and store</td>
<td>R1</td>
<td>R1+1</td>
<td>D2(B2)</td>
<td>R3</td>
<td>D4(B4)</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>13 and 15</td>
<td>Compare and swap and store</td>
<td>PL</td>
<td>PL</td>
<td>D2(B2)</td>
<td>PL</td>
<td>PL</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>16 and 18</td>
<td>Compare and swap and double store</td>
<td>R1</td>
<td>R1+1</td>
<td>D2(B2)</td>
<td>PL</td>
<td>PL</td>
<td>-</td>
<td>D4(B4)</td>
</tr>
<tr>
<td>17 and 19</td>
<td>Compare and swap and double store</td>
<td>PL</td>
<td>PL</td>
<td>D2(B2)</td>
<td>PL</td>
<td>PL</td>
<td>-</td>
<td>D4(B4)</td>
</tr>
<tr>
<td>20 and 22</td>
<td>Compare and swap and triple store</td>
<td>R1</td>
<td>R1+1</td>
<td>D2(B2)</td>
<td>PL</td>
<td>PL</td>
<td>-</td>
<td>D4(B4)</td>
</tr>
<tr>
<td>21 and 23</td>
<td>Compare and swap and triple store</td>
<td>PL</td>
<td>PL</td>
<td>D2(B2)</td>
<td>PL</td>
<td>PL</td>
<td>-</td>
<td>D4(B4)</td>
</tr>
</tbody>
</table>

Explanation:

1 For function codes that are a multiple of 4 (including 0) or one more than a multiple of 4, operands in general registers are in bit positions 32-63 of the registers, and bits 0-31 of the registers are ignored and remain unchanged. For function codes that are two more than a multiple of 4, operands in general registers are in bit positions 0-63 of the registers.

- Operand, value, or address is not used in the operation.

OpNC Operand-N comparison value.

OpNr Operand-N replacement value.

OpNa Operand-N address.

PL Operand, value, or address is in the parameter list.

PLa Parameter-list address.

Figure 7-294. Operand and Address Locations for PERFORM LOCKED OPERATION
Storage operand 2, and, when present, storage operands 4, 6, and 8 must be designated on an integral boundary, which is a word boundary for function codes that are a multiple of 4, a doubleword boundary for function codes that are one or 2 more than a multiple of 4, or a quadword boundary for function codes that are 3 more than a multiple of 4. A parameter list, if used, must be designated on a doubleword boundary. Otherwise, a specification exception is recognized. The program-lock-token (PLT) address in general register 1 does not have a boundary-alignment requirement.

All unused fields in a parameter list should contain all zeros; otherwise, the program may not operate compatibly in the future.

A serialization function is performed immediately after the lock is obtained and again immediately before it is released. However, values fetched from the parameter list before the lock is obtained are not necessarily refetched. A serialization function is not performed if the test bit, bit 55 of general register 0, is one.

In the following figures showing the parameter lists for the different function codes, the offsets shown on the left are byte values.

**Function Codes 0-3 (Compare and Load)**
The locations of the operands and addresses used by the instruction are as shown in Figure 7-294 on page 7-288.

The parameter list used for function code 1 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
<tr>
<td>Operand-1 Comparison Value</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-3</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-4 ALET</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-4 Address</td>
</tr>
</tbody>
</table>

The parameter list used for function code 3 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 3</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
<tr>
<td>Operand-1 Comparison Value</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-1 Comparison Value</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-3</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-3 (continued)</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-4 ALET</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-4 Address</td>
</tr>
</tbody>
</table>

The first-operand comparison value is compared to the second operand. When the first-operand comparison value is equal to the second operand, the third operand is replaced by the fourth operand, and condition code 0 is set.

When the first-operand comparison value is not equal to the second operand, the first-operand comparison value is replaced by the second operand, and condition code 1 is set.

**Function Codes 4-7 (Compare and Swap)**
The locations of the operands and addresses used by the instruction are as shown in Figure 7-294 on page 7-288.

The parameter list used for function code 5 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 5</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-1 Comparison Value</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-1 Replacement Value</td>
</tr>
</tbody>
</table>

The parameter list used for function code 7 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 7</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-1 Comparison Value</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-1 Replacement Value</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>Operand-1 Replacement Value</td>
</tr>
</tbody>
</table>

In the following figures showing the parameter lists for the different function codes, the offsets shown on the left are byte values.
The first-operand comparison value is compared to the second operand. When the first-operand comparison value is equal to the second operand, the first-operand replacement value is stored at the second-operand location, and condition code 0 is set.

When the first-operand comparison value is not equal to the second operand, the first-operand comparison value is replaced by the second operand, and condition code 1 is set.

**Function Codes 8-11 (Double Compare and Swap)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-294 on page 7-288.

The parameter list used for function code 9 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 9</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
</tbody>
</table>

The parameter list used for function code 11 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 11</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
</tbody>
</table>

The parameter list used for function code 13 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 13</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
</tbody>
</table>

The first-operand comparison value is compared to the second operand. When the first-operand comparison value is equal to the second operand, the third-operand comparison value is compared to the fourth operand. When the third-operand comparison value is equal to the fourth operand (after the first-operand comparison value has been found equal to the second operand), the first-operand replacement value is stored at the second-operand location, the third-operand replacement value is stored at the fourth-operand location, and condition code 0 is set.

When the first-operand comparison value is not equal to the second operand, the first-operand comparison value is replaced by the second operand, and condition code 1 is set.

When the third-operand comparison value is not equal to the fourth operand (after the first-operand comparison value has been found equal to the second operand), the third-operand comparison value is replaced by the fourth operand, and condition code 2 is set.

**Function Codes 12-15 (Compare and Swap and Store)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-294 on page 7-288.

The parameter list used for function code 13 has the following format:
The parameter list used for function code 15 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 15</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>64</td>
</tr>
</tbody>
</table>

The first-operand comparison value is compared to the second operand. When the first-operand comparison value is equal to the second operand, the first-operand replacement value is stored at the second-operand location, the third operand is stored at the fourth-operand location, and condition code 0 is set.

When the first-operand comparison value is not equal to the second operand, the first-operand comparison value is replaced by the second operand, and condition code 1 is set.

**Function Codes 16-19 (Compare and Swap and Double Store)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-294 on page 7-288.

The parameter list used for function code 16 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 16</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>80</td>
</tr>
<tr>
<td>96</td>
</tr>
<tr>
<td>104</td>
</tr>
</tbody>
</table>

The parameter list used for function code 17 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 17</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>80</td>
</tr>
<tr>
<td>96</td>
</tr>
<tr>
<td>104</td>
</tr>
</tbody>
</table>
The parameter list used for function code 18 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 18</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
</tbody>
</table>

The parameter list used for function code 19 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 19</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
<tr>
<td>80</td>
</tr>
<tr>
<td>88</td>
</tr>
<tr>
<td>96</td>
</tr>
<tr>
<td>104</td>
</tr>
</tbody>
</table>

The first-operand comparison value is compared to the second operand. When the first-operand comparison value is equal to the second operand, the first-operand replacement value is stored at the second-operand location, the third operand is stored at the fourth-operand location, the fifth operand is stored at the sixth-operand location, and condition code 0 is set.

When the first-operand comparison value is not equal to the second operand, the first-operand comparison value is replaced by the second operand, and condition code 1 is set.

**Function Codes 20-23 (Compare and Swap and Triple Store)**

The locations of the operands and addresses used by the instruction are as shown in Figure 7-294 on page 7-288.

The parameter list used for function code 20 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 20</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
<tr>
<td>80</td>
</tr>
</tbody>
</table>
The parameter list used for function code 21 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 21</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
<tr>
<td>80</td>
</tr>
<tr>
<td>88</td>
</tr>
<tr>
<td>96</td>
</tr>
<tr>
<td>104</td>
</tr>
<tr>
<td>112</td>
</tr>
<tr>
<td>120</td>
</tr>
<tr>
<td>128</td>
</tr>
<tr>
<td>136</td>
</tr>
<tr>
<td>Operand-1 Comparison Value</td>
</tr>
<tr>
<td>Operand-1 Replacement Value</td>
</tr>
<tr>
<td>Operand 3</td>
</tr>
<tr>
<td>Operand-4 ALET</td>
</tr>
<tr>
<td>Operand-4 Address</td>
</tr>
<tr>
<td>Operand 5</td>
</tr>
<tr>
<td>Operand-6 ALET</td>
</tr>
<tr>
<td>Operand-6 Address</td>
</tr>
<tr>
<td>Operand 7</td>
</tr>
<tr>
<td>Operand-8 ALET</td>
</tr>
<tr>
<td>Operand-8 Address</td>
</tr>
</tbody>
</table>

The parameter list used for function code 22 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 22</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
<tr>
<td>80</td>
</tr>
<tr>
<td>88</td>
</tr>
<tr>
<td>96</td>
</tr>
<tr>
<td>104</td>
</tr>
<tr>
<td>112</td>
</tr>
<tr>
<td>120</td>
</tr>
<tr>
<td>128</td>
</tr>
<tr>
<td>136</td>
</tr>
<tr>
<td>Operand 3</td>
</tr>
<tr>
<td>Operand-4 ALET</td>
</tr>
<tr>
<td>Operand-4 Address</td>
</tr>
<tr>
<td>Operand 5</td>
</tr>
<tr>
<td>Operand-6 ALET</td>
</tr>
<tr>
<td>Operand-6 Address</td>
</tr>
<tr>
<td>Operand 7</td>
</tr>
<tr>
<td>Operand-8 ALET</td>
</tr>
<tr>
<td>Operand-8 Address</td>
</tr>
</tbody>
</table>
The parameter list used for function code 23 has the following format:

<table>
<thead>
<tr>
<th>Parameter List for Function Code 23</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>32</td>
</tr>
<tr>
<td>40</td>
</tr>
<tr>
<td>48</td>
</tr>
<tr>
<td>56</td>
</tr>
<tr>
<td>64</td>
</tr>
<tr>
<td>72</td>
</tr>
<tr>
<td>80</td>
</tr>
<tr>
<td>88</td>
</tr>
<tr>
<td>96</td>
</tr>
<tr>
<td>104</td>
</tr>
<tr>
<td>112</td>
</tr>
<tr>
<td>120</td>
</tr>
<tr>
<td>128</td>
</tr>
<tr>
<td>136</td>
</tr>
</tbody>
</table>

The first-operand comparison value is compared to the second operand. When the first-operand comparison value is equal to the second operand, the first-operand replacement value is stored at the second-operand location, the third operand is stored at the fourth-operand location, the fifth operand is stored at the sixth-operand location, the seventh operand is stored at the eighth-operand location, and condition code 0 is set.

When the first-operand comparison value is not equal to the second operand, the first-operand comparison value is replaced by the second operand, and condition code 1 is set.

**Locking**

A lock is obtained at the beginning of the operation and released at the end of the operation. The lock obtained is represented by a program lock token (PLT) whose logical address is specified in general register 1 as already described.

A PLT is a value produced by a model-dependent transformation of the PLT logical address. Depending on the model, the PLT may be derived directly from the PLT logical address or, when DAT is on, from the real address that results from transformation of the PLT logical address by DAT. If DAT is used, access-register translation (ART) precedes DAT in the access-register mode.

A PLT selects one of a model-dependent number of locks within the configuration. Programs being executed by different CPUs can be assured of specifying the same lock only by specifying PLT logical addresses that are the same and that can be transformed to the same real address by the different CPUs.

Since a model may or may not use ART and DAT when forming a PLT, access-exception conditions that can be encountered during ART and DAT may or may not be recognized as exceptions. There is no accessing of a location designated by a PLT, but an addressing exception may be recognized for the location. A protection exception is not recognized for any reason during processing of a PLT logical address.

The CPU can hold one lock at a time.

When PERFORM LOCKED OPERATION is executed by this CPU and is to use a lock that is already held by another CPU due to the execution of a PERFORM LOCKED OPERATION instruction by the other CPU, the execution by this CPU is delayed until the lock is no longer held. An excessive delay can be caused only by a machine malfunction and is a machine-check condition.

The order in which multiple requests for the same lock are satisfied is undefined.

A nonrecoverable failure of a CPU while holding a lock may result in a machine check, entry into the check-stop state, or system check stop. The machine check is processing backup if all operands are undamaged or processing damage if register operands are damaged. If a machine check or the check-stop state is the result, either no storage operands have been changed or else all storage operands that were due to be changed have been correctly changed, and, in either case, the lock has been released. If the storage operands are not in either their correct original state or their correct final state, the result is system check stop.

**Storage-Operand References**
The accesses to the even-numbered storage operands appear to be word concurrent, as observed by other CPUs, for function codes that are a multiple of 4 or doubleword concurrent for function codes that are one, 2, or 3 more than a multiple of 4. The accesses to the doublewords in the parameter list appear to be doubleword concurrent, as observed by other CPUs, regardless of the function code.

As observed by other CPUs, all storage operands may be tested for access exceptions before a lock is obtained. (A channel program cannot observe a lock.)

As observed by other CPUs, in all operations except the compare-and-swap operation (which does not have a fourth operand), the fourth operand is accessed while the lock is held only if a comparison of the first-operand comparison value to the second operand while the lock is held has indicated equality. In these operations, the fourth operand is accessed before the lock is held only if a comparison of the first-operand comparison value to the second operand and has indicated equality and only if, when DAT is on, an INVALIDATE PAGE TABLE ENTRY instruction executed by another CPU after the fetch of the second operand will not be the cause of a page-translation exception recognized for the fourth operand, which it will if it sets to one the page-invalid bit in the page-table entry for the fourth operand when this CPU does not have a TLB entry corresponding to that page-table entry. In the compare-and-swap-and-double-store and compare-and-swap-and-triple-store operations, the sixth operand, and also the eighth operand in the triple-store operation, are treated the same as the fourth operand described above. The reason for this specification about INVALIDATE PAGE TABLE ENTRY is given in programming note 7.

Provided that accessing of an operand is not prohibited as described in the preceding paragraph, store-type access exceptions may be recognized for the fourth, sixth, or eighth operands even when a store does not occur because of the results of a comparison. A storage-alteration PER event is recognized, and a change bit is set, only if a store occurs.

When a comparison is made between an operand comparison value and an operand before the lock is obtained and indicates inequality, the lock still is obtained. The condition code is set only as a result of a comparison made while the lock is held. When condition code 1 or 2 is set, the first-operand comparison value or third-operand comparison value is replaced only by means of a fetch of the second operand or fourth operand, respectively, made while the lock is held, as observed by other CPUs.

In those cases when a store is performed to the second-operand location and one or more of the fourth-, sixth-, and eighth-operand locations, the store to the second-operand location is always performed last, as observed by other CPUs and by channel programs.

Stores into the parameter list may be performed while the lock is held or after it has been released.

Access exceptions may be recognized for parameter-list locations even when the locations are not required in the operation. The locations are those beginning at offset 0 and extending up through the last location defined for the function code used.

For the compare-and-load and compare-and-swap operations, the operation is suppressed on all addressing and protection exceptions.

When a nonrecoverable failure of a CPU while holding a lock results in a machine check or entry into the check-stop state, either no storage operands have been changed or else all storage operands that were due to be changed have been correctly changed. The latter may be accomplished by repeating stores that were performed successfully before the failure. Therefore, there may be two single-access store references (possibly the store part of an update reference and then a store reference) to the store-type operands, with the first value stored equal to the second value stored.

**Resulting Condition Code:**

When test bit is zero:

- 0 All comparisons equal; replacement value or values stored or loaded
- 1 First-operand comparison not equal; first-operand comparison value replaced
- 2 -- (all operations except double compare and swap)
- 2 First-operand comparison equal but third-operand comparison not equal; third-operand comparison value replaced (double compare and swap)
- 3 --
When test bit is one:

0  Function code valid
1  --
2  --
3  Function code invalid

Program Exceptions:

- Access (for all function codes, fetch, except addressing and protection for PLT location, program lock token, model-dependent; for function codes 0-3, fetch, operand 2; for function codes 4-23, fetch and store, operand 2; for odd-numbered function codes, fetch and store, parameter list; for function codes 16, 18, 20, and 22, fetch, parameter list; for function codes 0-3, fetch, operand 4; for function codes 8-11, fetch and store, operand 4; for function codes 12-23, store, operand 4; for function codes 16-23, store, operand 6; for function codes 20-23, store, operand 8)
- Specification
- Transaction constraint

Programming Notes:

1. In configurations that support the transactional-execution facility, a transaction may provide benefits over the use of PERFORM LOCKED OPERATION, as follows:
   a. Transactional execution may provide improved performance over an equivalent code path that uses PLO.
   b. Transactional execution does not require the specification of a program lock token in general register 1.
   c. Transactional execution does not require the use of a parameter list for more complex operations.
   d. Transactional execution provides a much broader scope of operations that can be performed, all of which appear to execute in a block-concurrent manner as observed by other CPUs and the channel subsystem.
   e. The use of classic interlocked-access techniques on one CPU can correctly coexist with transactional execution on another CPU. This coexistence is not possible using PLO, as explained in programming note 4, below.

2. An example of the use of the PERFORM LOCKED OPERATION instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

3. When the contents of storage locations are changed by PERFORM LOCKED OPERATION instructions that are executed concurrently by different CPUs and that use the same lock, the changes to operands not in the parameter list will be completed by one of the CPUs before they are begun by the other CPU, depending on which CPU first obtains the lock.

4. The compare-and-swap functions of PERFORM LOCKED OPERATION are not performed by means of interlocked-update references. Concurrent store references by another CPU to the storage operands, even if they are interlocked-update references, will interfere unpredictably, in terms of the resulting register and storage contents, with the intended operation of PERFORM LOCKED OPERATION. All changes to the contents of the storage locations must be made by PERFORM LOCKED OPERATION instructions that use the same lock, if predictable storage results are to be obtained.

5. Because a nonrecoverable failure of a CPU while executing PERFORM LOCKED OPERATION may cause two stores of the same value to a store-type operand, a concurrent store made by another CPU to the same operand but not by executing PERFORM LOCKED OPERATION may be lost.

6. When programs in different address spaces are using the same lock when DAT is on, the programs must ensure that they are using PLT logical addresses that are the same and that will be translated to the same real address regardless of the address space in which a translation occurs. Otherwise, the programs may in fact use different locks.

7. The section “Storage-Operand References” on page 7-294 contains a specification concerning the INVALIDATE PAGE TABLE ENTRY (IPTE) instruction. The need for the specification is
shown by the following example that is possible without the specification.

a. CPU 1 begins to execute a PERFORM LOCKED OPERATION instruction with function code 8, which is referred to as PLO.DCS. Operand 2 is a location, Qtail, containing the address (the first-operand comparison value) of the last element, element X, on a queue, and operand 4 is a location in that element containing the address (0, the third-operand comparison value) of the next (nonexisting) element on the queue. The purpose of the PLO instruction is to enqueue an element by placing the address of the element (the first-operand and third-operand replacement values) in both operand 2 and operand 4. With the lock not held, the PLO instruction fetches operand 2 and compares it, with an equal result, to the first-operand comparison value.

b. CPU 2 completely executes a PLO.DCS instruction to dequeue element X, which is the only element on the queue, from the queue. The PLO instruction stores 0 in Qtail and also in Qhead, which is a location containing the address of the first element on the queue. The program on CPU 2 processes the dequeued element and then invokes the freemain service of the control program to deallocate the storage containing the element. The freemain service uses IPTE to set the page-invalid bit to one in the page-table entry for the page containing element X. The IPTE instruction immediately sets the page-invalid bit to one, and then it waits for the signal that all other CPUs have cleared their TLBs of entries corresponding to the page.

c. CPU 1 attempts to fetch operand 4. CPU 1 does not have a TLB entry for the operand-4 page. CPU 1 signals CPU 2 that the CPU 2 IPTE instruction may proceed.

d. CPU 2 completes its IPTE instruction. The program on CPU 2 sets a software bit in the page-table entry to one to indicate that the page has been freemained and that, therefore, a reference to the page should result in presentation by the control program of an addressing exception to the program making the reference.

e. CPU 1 attempts to do DAT for operand 4 and sees that the page-invalid bit is one. CPU 1 performs a program interruption indicating a page-translation exception. The exception handler sees that the software bit indicating freemained is one, and it presents an addressing exception to the CPU 1 program, which causes an abend of the program.

If CPU 1 had had a TLB entry for the page, its PLO instruction would not have been interrupted, and the comparison of the first-operand comparison value to the second operand while the lock was held would indicate that CPU 2 had changed the second operand. The PLO instruction would set condition code 1. If CPU 1 did not have a TLB entry but IPTE could not set the page-invalid bit to one while CPU 1 was executing an instruction, CPU 1 could successfully translate the operand-4 address and, again, discover while the lock was held that operand 2 had changed. The case when operand 2 points to element X but the freemained bit for the element-X page is one is a programming error.

8. For functions that use a parameter list in the access register mode, the value in the R3 field of the instruction should be different from that of the B2 and B4 fields. Because access register R3 is modified as a result of an access exception, subsequent re-execution of the instruction (for example, following the resolution of a page-translation exception) may yield unpredictable results if the R3 field designates the same access register as that of the second operand or parameter list.
The operation of each assist function, and the registers used by the function are as follows:

**Transaction-Abort Assist:** When the function code in the M3 field is 1, the processor is requested to assist following an aborted nonconstrained transaction. The program is expected to provide an unsigned 32-bit binary integer in bits 32-63 of general register R1, specifying the number of times the nonconstrained transaction has been repeatedly aborted. Depending on the value of this integer, the processor may take escalating actions to increase the likelihood of successful completion of the transaction in a subsequent execution.

---

### PERFORM PROCESSOR ASSIST

**PPA R1 R2 M3 [RRF-c]**

<table>
<thead>
<tr>
<th>PPA</th>
<th>R1</th>
<th>R2</th>
<th>M3</th>
<th>[RRF-c]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B2E8'</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
<td>24</td>
<td>28 31</td>
</tr>
</tbody>
</table>

The M3 field contains a 4-bit unsigned binary integer function code specifying the processor-assist function to be performed. The function codes for PERFORM PROCESSOR ASSIST are as follows:

<table>
<thead>
<tr>
<th>Op1c=Op2</th>
<th>Op3c=Op4</th>
<th>Cond Code</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>No</td>
<td>-</td>
<td>1</td>
<td>Op2 → Op1c</td>
</tr>
<tr>
<td>Yes</td>
<td>-</td>
<td>0</td>
<td>Op4 → Op3</td>
</tr>
</tbody>
</table>

#### Function Codes 0-3 (Compare and Load)

<table>
<thead>
<tr>
<th>Op1c=Op2</th>
<th>Op3c=Op4</th>
<th>Cond Code</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>No</td>
<td>-</td>
<td>1</td>
<td>Op2 → Op1c</td>
</tr>
<tr>
<td>Yes</td>
<td>-</td>
<td>0</td>
<td>Op1r → Op2</td>
</tr>
</tbody>
</table>

#### Function Codes 4-7 (Compare and Swap)

<table>
<thead>
<tr>
<th>Op1c=Op2</th>
<th>Op3c=Op4</th>
<th>Cond Code</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>No</td>
<td>-</td>
<td>1</td>
<td>Op2 → Op1c</td>
</tr>
<tr>
<td>Yes</td>
<td>-</td>
<td>0</td>
<td>Op1r → Op2</td>
</tr>
</tbody>
</table>

#### Function Codes 8-11 (Double Compare and Swap)

<table>
<thead>
<tr>
<th>Op1c=Op2</th>
<th>Op3c=Op4</th>
<th>Cond Code</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>No</td>
<td>-</td>
<td>1</td>
<td>Op2 → Op1c</td>
</tr>
<tr>
<td>Yes</td>
<td>No</td>
<td>2</td>
<td>Op4 → Op3c</td>
</tr>
<tr>
<td>Yes</td>
<td>Yes</td>
<td>0</td>
<td>Op1r → Op2 Op3r → Op4</td>
</tr>
</tbody>
</table>

#### Function Codes 12-15 (Compare and Swap and Store)

<table>
<thead>
<tr>
<th>Op1c=Op2</th>
<th>Op3c=Op4</th>
<th>Cond Code</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>No</td>
<td>-</td>
<td>1</td>
<td>Op2 → Op1c</td>
</tr>
<tr>
<td>Yes</td>
<td>-</td>
<td>0</td>
<td>Op1r → Op2 Op3 → Op4</td>
</tr>
</tbody>
</table>

#### Function Codes 16-19 (Compare and Swap and Double Store)

<table>
<thead>
<tr>
<th>Op1c=Op2</th>
<th>Op3c=Op4</th>
<th>Cond Code</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>No</td>
<td>-</td>
<td>1</td>
<td>Op2 → Op1c</td>
</tr>
<tr>
<td>Yes</td>
<td>-</td>
<td>0</td>
<td>Op1r → Op2 Op3 → Op4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Op5 → Op6</td>
</tr>
</tbody>
</table>

#### Function Codes 20-23 (Compare and Swap and Triple Store)

<table>
<thead>
<tr>
<th>Op1c=Op2</th>
<th>Op3c=Op4</th>
<th>Cond Code</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>No</td>
<td>-</td>
<td>1</td>
<td>Op2 → Op1c</td>
</tr>
<tr>
<td>Yes</td>
<td>-</td>
<td>0</td>
<td>Op1r → Op2 Op3 → Op4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Op5 → Op6 Op7 → Op8</td>
</tr>
</tbody>
</table>

**Explanation:**

- Not applicable.
- OpNc Operand-N comparison value.
- OpNr Operand-N replacement value.

*Figure 7-295. Summary of PERFORM LOCKED OPERATION Results*
Reserved: Reserved function codes should not be specified; otherwise, the program may not operate compatibly in the future.

Condition Code: The code remains unchanged.

Program Exceptions:

- Operation (processor-assist facility not installed)
- Transaction constraint

Programming Notes:

1. For the transaction-abort-assist function, a larger value in general register R1 does not necessarily guarantee successful completion when the transaction is reexecuted, and it may unnecessarily delay the CPU. Therefore, the program should provide an accurate count of the number of times a transaction has been aborted in the register.

A value of one in bits 32-63 of general register R1 means that the transaction has been aborted once, a value of two means the transaction has been aborted twice, and so forth.

2. An example of the use of PERFORM PROCESSOR ASSIST is shown in programming note 2 on page 5-106.

3. The processor-assist facility is indicated by facility bit 49.

PERFORM PSEUDORANDOM NUMBER OPERATION

PPNO R1 R2 [RRE]

A function specified by the function code in general register 0 is performed.

Bits 16-23 of the instruction are reserved and should contain zeros; otherwise, the instruction may not operate compatibly in the future.

Bit positions 57-63 of general register 0 contain the function code. Figure 7-296 shows the assigned function codes for PERFORM PSEUDORANDOM NUMBER OPERATION. All other function codes are unassigned.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parameter Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>PPNO Query</td>
<td>16</td>
</tr>
<tr>
<td>3</td>
<td>PPNO-SHA-512-DRNG</td>
<td>240</td>
</tr>
</tbody>
</table>

Figure 7-296. Function Codes for PERFORM PSEUDORANDOM NUMBER OPERATION

If bits 57-63 of general register 0 designate an unassigned or uninstalled function code, a specification exception is recognized.

The query function provides the means of indicating the availability of the other functions.

For all functions other than the query function, bit 56 of general register 0 is the modifier bit. When the modifier bit is zero, a generate operation is performed, and when the modifier bit is one, a seed operation is performed. The modifier bit is ignored for the query function. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address. In the access-register mode, access register 1 specifies the address space containing the parameter block.

The R1 and R2 fields each designate an even-odd pair of general registers and must designate an even-numbered register other than general register 0; otherwise, a specification exception is recognized.

For the generate operation, the leftmost byte of the first operand is specified by the contents of general register R1, and the length of the first operand is specified in general register R1 + 1. The contents of general register R2 are ignored by a generate operation.
For a seed operation, the leftmost byte of the second operand is specified by the contents of general register \( R_2 \), and the length of the second operand is specified in general register \( R_2 + 1 \). The contents of general register \( R_1 \) are ignored by a seed operation.

Regardless of whether a generate or seed operation is specified, the contents of the even-numbered general register designating the storage operand (\( R_1 \) or \( R_2 \), respectively) are subject to the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of the register constitute the address of the storage operand, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the register constitute the address of the storage operand, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of the register constitute the address of the storage operand. In the access-register mode, the respective access register (\( R_1 \) or \( R_2 \)) specifies the address space containing the storage operand.

Regardless of whether a generate or seed operation is specified, in both the 24-bit and the 31-bit addressing modes, the contents of bit positions 32-63 of the odd-numbered general register (\( R_1 + 1 \) or \( R_2 + 1 \), respectively) form a 32-bit unsigned binary integer which specifies the number of bytes in the storage operand. In the 64-bit addressing mode, the contents of bit positions 0-63 of the register form a 64-bit unsigned binary integer which specifies the number of bytes in the storage operand.

For a generate operation, the first-operand length is updated in general register \( R_1 + 1 \) at the completion of the instruction. In both the 24-bit and the 31-bit addressing modes, the updated value replaces the contents of bit positions 32-63 of general register \( R_1 + 1 \); the contents of bit positions 0-31 of general register \( R_1 + 1 \), always remain unchanged. In the 64-bit addressing mode, the updated value replaces the contents of general register \( R_1 + 1 \).

Figure 7-297 on page 7-300 shows the contents of the general registers just described.

```
<table>
<thead>
<tr>
<th>All Addressing Modes</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \text{GR0} )</td>
</tr>
<tr>
<td>( \text{GR1} )</td>
</tr>
<tr>
<td>( R_1 )</td>
</tr>
<tr>
<td>( R_1 + 1 )</td>
</tr>
<tr>
<td>( R_2 )</td>
</tr>
<tr>
<td>( R_2 + 1 )</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>24-Bit Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \text{Parameter-Block Address} )</td>
</tr>
<tr>
<td>( \text{First-Operand Address (generate operation)} )</td>
</tr>
<tr>
<td>( \text{First-Operand Length (generate operation)} )</td>
</tr>
<tr>
<td>( \text{Second-Operand Address (seed operation)} )</td>
</tr>
<tr>
<td>( \text{Second-Operand Length (seed operation)} )</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>31-Bit Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \text{Parameter-Block Address} )</td>
</tr>
<tr>
<td>( \text{First-Operand Address (generate operation)} )</td>
</tr>
<tr>
<td>( \text{First-Operand Length (generate operation)} )</td>
</tr>
<tr>
<td>( \text{Second-Operand Address (seed operation)} )</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>64-Bit Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \text{Parameter-Block Address} )</td>
</tr>
<tr>
<td>( \text{First-Operand Address (generate operation)} )</td>
</tr>
<tr>
<td>( \text{First-Operand Length (generate operation)} )</td>
</tr>
<tr>
<td>( \text{Second-Operand Address (seed operation)} )</td>
</tr>
</tbody>
</table>
```

Figure 7-297. General Register Assignment for PPNO (Part 1 of 2)
When the parameter block overlaps any portion of the storage operand, the results are unpredictable.

When the storage-operand length is zero, access exceptions for the storage-operand location are not recognized. However, the parameter block is accessed even when the storage-operand length is zero. For a generate operation when the storage-operand length is zero, general register R1 + 1 is not changed, and condition code 0 is set.

As observed by other CPUs and the I/O subsystem, references to the parameter block and storage operand may be multiple-access references, accesses to these locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

A PER storage-alteration event is recognized only for the portion of the parameter block that is stored. For a generate operation, when a PER storage-alteration event is recognized, fewer than 4K additional bytes are stored into the first-operand locations before the event is reported. When a PER storage-alteration event is recognized both for the first-operand and location and for the portion of the parameter block that is stored, it is unpredictable which of these two locations is identified in the PAID and AI. Similarly, when a PER zero-address-detection event is recognized for both for the first-operand location and for the parameter block, it is unpredictable which of these two locations is identified in the PAID and AI.

For a generate operation, access exceptions may be reported for a larger portion of the first operand than is processed in a single execution of the instruction. However, access exceptions are not recognized for locations that do not encompass the first operand nor for locations more than 4K bytes from the current location being processed.

For a generate operation, when the operation ends due to normal completion, condition code 0 is set and the resulting value in general register R1 + 1 is zero. When the operation ends due to partial completion, condition code 3 is set and the resulting value in general register R1 + 1 is nonzero.

**PPNO-Query (PPNO Function Code 0)**
The contents of general registers R1, R1 + 1, R2, and R2 + 1 are ignored by the query function.

The locations of the operands and addresses used by the instruction are as shown in Figure 7-297 on page 7-300.
PERFORM PSEUDORANDOM NUMBER OPERATION

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>16</th>
<th>232</th>
</tr>
</thead>
</table>
| Status Word | Stream Bytes | Reseed Counter | \_

*Figure 7-298. Parameter Block for PPNO-Query*

A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the PERFORM PSEUDORANDOM NUMBER OPERATION instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

Condition code 0 is set when execution of the PPNO-Query function completes; condition code 3 is not applicable to this function.

**PPNO-SHA-512-DRNG (PPNO Function Code 3)**

Depending on the modifier bit, bit 56 of general register 0, the PPNO-SHA-512-DRNG function performs either a deterministic pseudorandom-number generate operation or a deterministic pseudorandom-number seed operation using the 512-bit secure-hash algorithm (SHA-512).

Deterministic pseudorandom-number generation, also known as deterministic random-bit generation, is defined in Reference [16.] on page xxviii; refer to this publication for further description on terms used in this definition. Further description of the secure hash algorithm may be found in Reference [13.] on page xxviii.

The locations of the operands and addresses used by the instruction are as shown in Figure 7-297 on page 7-300.

The same parameter block format is used by both the generate operation and the seed operation (including instantiation and reseeding). A parameter block containing all zeros is considered to be not instantiated. The program should zero the parameter block prior to issuing the seed operation to instantiate the parameter block, and subsequently, the program should not alter the contents of the parameter block except to zero it; otherwise, unpredictable results may be produced by the instruction.

**Reserved:** Bytes 0-3, 16, and 128 of the parameter block are reserved. As observed by other CPUs and the I/O subsystem, the contents of byte 16 may appear to change during the execution of the instruction; however, byte 16 will contain zero when the instruction completes with condition code 0. As observed by other CPUs and the I/O subsystem, the contents of byte 128 may appear to change during the execution of the seed operation, however, byte 128 will contain zero at the completion of the seed operation.

**Reseed Counter:** Bytes 4-7 of the parameter block contain a 32-bit unsigned binary integer indicating the number of times that the instruction has completed with condition code 0 since the parameter block was last instantiated or reseeded.

When the reseed counter contains zero, the parameter block is considered to be not instantiated, and the following applies:

- Execution of the seed operation causes the parameter block to be instantiated with initial val-
ues, including setting the reseed counter to a value of one.

- Execution of the generate operation results in a general-operand data exception being recognized.

When the reseed counter contains a nonzero value, the parameter block is considered to be instantiated, and the following applies:

- Execution of the seed operation causes the parameter block to be reseeded, including resetting the reseed counter to a value of one.
- Execution of a generate operation that results in condition code 0 causes the reseed counter to be incremented by one; any carry out of bit position 0 of the reseed-counter field is ignored.

Stream Bytes: Bytes 8-15 of the parameter block contain a 64-bit unsigned binary integer. The stream-bytes field is set to zero by the execution of the seed operation when instantiating the parameter block (that is, when the reseed counter is zero); the field is not changed by the execution of the seed operation when the parameter block is already instantiated.

Partial or full completion of a generate operation causes the contents of the stream-bytes field to be incremented by the number of bytes stored into the first operand; any carry out of bit position 0 of the stream-bytes field is ignored.

Value (V): Bytes 17-127 of the parameter block contain an 888-bit value indicating the internal state of the random-number generator represented by the parameter block. V is initialized by the execution of the seed operation when instantiating the parameter block. V is updated by either (a) the execution of the seed operation when the reseed counter is nonzero, or (b) the execution of the generate operation that ends in condition code 0.

Constant (C): Bytes 129-239 of the parameter block contain an 888-bit value indicating the internal state of the random-number generator represented by the block. C is initialized by the execution of the seed operation, and inspected by the generate operation.

Seed Operation

The PPNO-SHA-512-DRNG seed operation instantiates or reseeds a deterministic-pseudorandom-number-generation parameter block using the 512-bit secure-hash algorithm.

Depending on whether the reseed counter in bytes 4-7 of the parameter block is zero or nonzero, an instantiation or reseeding operation is performed, respectively.

- For the instantiation operation, the second operand in storage contains entropy input, nonce, and an optional personalization string, used to form seed material.
- For the reseed operation, the second operand in storage contains entropy input and optional additional input, used to form the seed material.

See Reference [16.] on page xxviii for the definition and usage of entropy input, nonce, personalization string, and additional input, and for details on the algorithms used. The length of the second operand in general register \( R_2 + 1 \) must not exceed 512 bytes, otherwise, a specification exception is recognized.

When performing an instantiation operation, seed material is formed using only the second operand. When performing a reseeding operation, seed material is formed from a concatenation of the value 01 hex, the V field of the parameter block, and the second operand. The formation of the seed material is illustrated in Figure 7-300.

Figure 7-300. PPNO-SHA-512-DRNG Seed Operation’s Generation of Seed Material (Part 1 of 2)
For either the instantiation or reseeding operation, a new value field \( (V_{\text{new}}) \) is formed as follows: A one byte counter, four-byte value of 888, the seed material, and padding are used as input to the SHA-512 algorithm. The padding consists of a value of 80 hex, concatenated with 0-127 bytes of zeros, concatenated with a 16-byte binary integer designating the length in bits of the input to the SHA-512 algorithm not including the padding (that is, the length of the one-byte counter, four-byte value of 888, and the seed material). The SHA-512 algorithm is invoked twice to form two 64-bit hashed results; the one-byte counter contains the value 1 for the first invocation of the SHA-512 algorithm, and it contains the value 2 for the second invocation. The two 64-byte hashed results are concatenated together, and the leftmost 111 bytes of the 128-byte concatenation form the new value field \( (V_{\text{new}}) \) in the parameter block. The generation of \( V_{\text{new}} \) is illustrated in Figure 7-301.

**Explanation:**

- \(<b>\) Length of field in bytes
- \( R2+1 \) Length of operand 2 in storage in the range of 0-512 bytes.

*Figure 7-300. PPNO-SHA-512-DRNG Seed Operation’s Generation of Seed Material (Part 2 of 2)*

*Figure 7-301. PPNO-SHA-512-DRNG Seed Operation’s Formation of New Value \( (V_{\text{new}}) \) (Part 1 of 2)*
Similar to the formation of the \( V_{\text{new}} \) field, the new constant field \( (C_{\text{new}}) \) is formed during both the instantiation or reseeding operation. A one byte counter, four-byte value of 888, one byte value of zero, the \( V_{\text{new}} \) field, and padding are concatenated to form input to the SHA-512 algorithm. The padding consists of a value of 80 hex, concatenated with 122 bytes of zeros, concatenated with a 16-byte binary integer designating the length in bits of the input to the SHA-512 algorithm not including the padding (that is, the length of the one-byte counter, four-byte value of 888, one-byte value of zero, and the \( V_{\text{new}} \) field). The SHA-512 algorithm is invoked twice to form two 64-bit hashed results; the one-byte counter contains the value 1 for the first invocation of the SHA-512 algorithm, and it contains the value 2 for the second invocation. The two 64-byte hashed results are concatenated together, and the leftmost 111 bytes of the 128-byte concatenation form the new constant field \( (C_{\text{new}}) \) in the parameter block.

For either the instantiate or reseeding operation, the reseed-counter field in the parameter block is set to a value of one. For the instantiate operation only, the stream-bytes field in the parameter block is set to zeros; the stream-bytes field remains unchanged by a reseeding operation.
The generation of $C_{\text{new}}$ and the initialization of the reseed-counter and stream-bytes fields is illustrated in Figure 7-302.

**Generate Operation**

If the reseed counter in the parameter block is zero, a general-operand data exception is recognized and the operation is suppressed.

General register $R_1$ contains the address of the *leftmost* byte of the first operand. When the first-operand length in general register $R_1 + 1$ is nonzero, the first operand is formed in right-to-left order in units of 64-byte blocks, except that the rightmost block may contain fewer than 64 bytes. The number of blocks to be stored, including any partial rightmost block, is determined by rounding the first-operand length in general register $R_1 + 1$ up to a multiple of 64 and dividing this value by 64. The blocks of the first oper-
and are numbered from left to right as 0 to n–1, where n–1 represents the rightmost block. The following procedure is performed for each block of the first-operand location, beginning with the rightmost (n–1) block and proceeding to the left.

1. The value (V) from the parameter block is added to the block number being processed, with any overflow from the addition ignored.

2. The 111-byte sum of this addition, concatenated with 17 bytes of padding, are used as input to the SHA-512 algorithm, resulting in a 64-byte hashed value. The 17-byte padding provided to the SHA-512 algorithm consists of a value of 80 hex followed by a 16-byte binary integer value of 888 (the length of V in bits).

3. If the first-operand length in general register $R_1 + 1$ is a multiple of 64, then the resulting 64-byte hashed value is stored in the respective block of the first-operand location, and the length in general register $R_1 + 1$ is decremented by 64.

If the first-operand length is not a multiple of 64, then the leftmost $m$ bytes of the resulting 64-byte hashed value is stored in the rightmost partial block of the first operand, where $m$ represents the remainder of the first-operand length divided by 64. In this case, the length in general register $R_1 + 1$ is decremented by $m$.

4. Regardless of whether a full or partial block is stored, the stream-bytes field in bytes 8-15 of the parameter block is incremented by the number of bytes stored into the first-operand location.

The above process is repeated until either the first-operand length in general register $R_1 + 1$ is zero (called normal completion) or a CPU-determined number of blocks has been processed (called partial completion). The CPU-determined number of blocks depends on the model, and may be a different number each time the instruction is executed. The CPU-determined number of blocks is usually nonzero. In certain unusual situations, this number may be zero, and condition code 3 may be set with no progress. However, the CPU protects against endless reoccurrence of this no-progress case.

The process of generating the deterministic pseudorandom numbers in the first operand is shown in Figure 7-303.
When the first-operand length in general register R1 + 1 is initially zero, normal completion occurs without storing into the first-operand location; however, the parameter block is updated as described below.

When the pseudorandom-number-generation process ends due to normal completion, the parameter block is updated as described below.

1. A one byte value of 03 hex, 111-byte value (V) from the parameter block, and 144 bytes of padding are used as input to the SHA-512 algorithm, resulting in a 64-byte hashed value. The padding consists of a value of 80 hex, concatenated with 127 bytes of zeros, concatenated with a 16-byte binary integer designating the length in bits of the input to the SHA-512 algorithm not including the padding (that is, the length of the one-byte value of 03 hex and the V field). The values of the 4-byte reseed-counter field and the 111-byte value (V) and constant (C) fields in the parameter block, and the 64-byte hashed value (from the above computation) are added. For the purposes of this addition, each value is treated as an unsigned binary integer, extended to the left with zeros as necessary. Any overflow from the addition is ignored, and the resulting 111-byte sum replaces the value field in the parameter block (∆Vnew).

2. The 4-byte reseed-counter field in the parameter block is incremented by one.

3. Condition code 0 is set.

Steps 1 and 2 of the normal completion processing are illustrated in Figure 7-304.

When the pseudorandom-number-generation process ends due to partial completion, the first-operand length in general register R1 + 1 contains a nonzero multiple of 64, the reseed-counter and value (V) fields in the parameter block are not updated, and condition code 3 is set.
Special Conditions

A specification exception is recognized and no other action is taken if any of the following conditions exist:

1. Bits 57-63 of general register 0 specify an unsigned or uninstalled function code.
2. The \( R_1 \) or \( R_2 \) fields designate an odd-numbered register or general register 0.
3. For the seed operation, the length in general register \( R_2 + 1 \) is greater than 512.

A general-operand data exception is recognized for the generate operation if the reseed counter in the parameter block is zero.

| 0 | Normal completion |
| 1 | -- |
| 2 | -- |
| 3 | Partial completion (generate operation only) |

Program Exceptions:

- Access (store, operand 1, generate operation; fetch, operand 2, seed operation; fetch and store, parameter block)
- Data with DXC 0, general operand
- Operation (if the message-security-assist extension 5 is not installed)
- Specification
- Transaction constraint

Programming Notes:

1. For the generate operation, when condition code 3 is set, the first operand length in general register \( R_1 + 1 \) is updated such that the program can simply branch back to the instruction to continue the operation.
2. The PPNO-SHA-512-DRNG seed operation (instantiation and reseeding) and generate operation correspond to the following algorithm specifications in Reference [16.] on page xxviii:
   - Section 10.1.1.2: Instantiation of Hash_DRBG
   - Section 10.1.1.3: Reseeding a Hash_DRBG Instantiation
   - Section 10.1.1.4: Generating Pseudorandom Bits Using Hash_DRBG (steps 3–7)
3. If a carry out of bit position 0 of the reseed-counter field occurs during a generate operation, then the counter wraps around to zero; in this case, the parameter block is considered not to be instantiated. Unless a seed operation is performed to reinstantiate the parameter block, a subsequent generate operation will result in a general-operand data exception being recognized.
4. The PERFORM PSEUDORANDOM NUMBER OPERATION instruction does not implement the testing and uninstantiation functions described in Reference [16.] on page xxviii. As the parameter block exists in program storage, the program can effect the testing function by directly inspecting the parameter block; similarly, the program can effect the uninitialization function by zeroing the parameter block.
5. The program is responsible for reseeding the parameter block depending on policy and pseudorandom-number-generation state. For example, reseeding may be required after each generate operation if prediction resistance is required. Reseeding may be appropriate after a preset number of stream bytes is produced. See Reference [16.] on page xxviii for further explanation.
6. Even though the generate operation processes the blocks of the first operand in right to left order, it is the address of the leftmost byte of the operand in general register \( R_1 \) that is used for PER zero-address detection. If the first-operand address is nonzero, and length of the operand is such that the operand wraps around to location zero, stores to the first-operand location – including stores to location zero – will not result in the recognition of a PER zero-address-detection event.
7. For the PPNO-SHA-512-DRNG function, the length in bits of the input to the SHA-512 algorithm is implicitly determined by the instruction; this length is described as occupying the rightmost 16 bytes of the padding field. This differs from the KLMD-SHA-512 function of the COMPUTE LAST MESSAGE DIGEST instruction where the message-bit length (\( mbl \)) is explicitly specified in the parameter block, and the padding (\( p \)) and \( mbl \) are described separately.
8. The initial chaining value (ICV) used by the PPNO-SHA-512-DRNG function is described as the initial-hash value (IHV) in Reference [16.] on page xxviii.
9. The program may issue a seed operation with the second-operand length in general register \( R_2 + 1 \) set to zero. However, the results in this case will always be deterministic.

10. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

### POPULATION COUNT

**POPCTN R1,R2 [RRE]**

A count of the number of one bits in each of the eight bytes of general register \( R_2 \) is placed into the corresponding byte of general register \( R_1 \). Each byte of general register \( R_1 \) is an 8-bit binary integer in the range of 0-8.

**Resulting Condition Code:**

- 0: Result zero
- 1: Result not zero
- 2: --
- 3: --

**Program Exceptions:**

- Operation (if the population-count facility is not installed)

**Programming Notes:**

1. The condition code is set based on all 64 bits of general register \( R_1 \).

2. The total number of one bits in a general register can be computed as shown below. In this example, general register 15 contains the bits to be counted; the result containing the total number of one bits in general register 15 is placed in general register 8. (General register 9 is used as a work register and contains residual values on completion.)

3. Using techniques similar to that shown in programming note 2, the number of one bits in a word, halfword, or discontiguous bytes of the second operand may be determined.

### PREFETCH DATA

**PFD M1,D2(X2,B2) [RXY-b]**

**PFDRL M1,RI2 [RIL-c]**

Note: In this instruction definition, the name "PREFETCH DATA (RELATIVE LONG)" refers to both the PREFETCH DATA instruction and the PREFETCH DATA RELATIVE LONG instruction.

Subject to the controls specified in the \( M_1 \) field, the CPU is signalled to perform one of the following operations:

- Prefetch the second operand into a cache line.
- Release a cache line containing the second operand.

The second operand designates a logical address. The \( M_1 \) field contains a 4-bit unsigned binary integer that is used as a code to signal the CPU as to the
intended use of the second operand. The codes are as follows:

<table>
<thead>
<tr>
<th>Code</th>
<th>Function Performed</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Prefetch the data at the second-operand address into a cache line for fetch access.</td>
</tr>
<tr>
<td>2</td>
<td>Prefetch the data at the second-operand address into a cache line for store access.</td>
</tr>
<tr>
<td>6</td>
<td>Release the cache line containing the second operand from store access; retain the data in the cache line for fetch access.</td>
</tr>
<tr>
<td>7</td>
<td>Release the cache line containing the second operand from all accesses.</td>
</tr>
</tbody>
</table>

All other codes are reserved. Depending on the model, the CPU may not implement all of the prefetch functions. For functions that are not implemented by the CPU, and for reserved functions, the instruction acts as a no-op. Code 0 always acts as a no-op.

No access exceptions or PER storage-alteration events are recognized for the second operand.

Code 2 has no effect on the change bit for the second operand. For all codes, it is model dependent whether any TLB entry is formed for the data that is prefetched.

For PREFETCH DATA, the displacement is treated as a 20-bit signed binary integer.

For PREFETCH DATA RELATIVE LONG, the contents of the RI2 field are signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

When PREFETCH DATA (RELATIVE LONG) is attempted in a nonconstrained transaction, and the code in the M1 field is 6 or 7, the transaction may be aborted due to abort code 16. When PREFETCH DATA (RELATIVE LONG) is attempted in a constrained transaction, a transaction-constraint program interruption is recognized, and the transaction is aborted with abort code 4.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Operation (if the general-instructions-extension facility is not installed)
- Transaction constraint

**Programming Notes:**

1. PREFETCH DATA (RELATIVE LONG) signals the CPU to perform the specified operation, but it does not guarantee that the CPU will necessarily honor the request.

2. There is no guarantee that storage location will still be in the cache when a subsequent instruction references the location. Likewise, there is no guarantee that when a cache line is released, that the CPU will not subsequently refetch it (independent of any prefetching operations). Rather, PREFETCH DATA (RELATIVE LONG) simply provides hints as to the program's anticipated use of storage areas.

3. If an exception condition would otherwise be recognized when accessing the second operand, PREFETCH DATA (RELATIVE LONG) is completed with no indication of the exception provided to the program, however, the performance of PREFETCH DATA (RELATIVE LONG) may be significantly slower than if the exception condition did not exist.

4. A significant delay may be experienced if a storage location has been prefetched and then released, and then a subsequent instruction references the same storage location. Similarly, a delay may be experienced if a storage location has been prefetched for fetch access, and then a subsequent instruction references the same location for storing.

5. On models that implement a unified data and instruction cache, the function performed may affect both subsequent operand accesses and instruction fetches from the second-operand location. On such models, a significant delay may be experienced if the code 7 is used to release data in a cache line from which an instruction is subsequently fetched.

6. On models that implement separate data and instruction caches, codes 1 and 2 cause the second operand to be prefetched into the data cache. Similarly, on such models, codes 6 and 7 cause the second operand to be released from
the data cache. However, on certain models with separate data and instruction caches, code 7 may also cause the second operand to be released from the instruction cache, in addition to being released from the data cache.

7. On models that implement separate data and instruction caches, the use of code 2 to prefetch (for storing) a cache line from which instructions will subsequently be fetched may cause significant delays. Similar delays may be experienced for any store operation into a cache line from which instructions are subsequently fetched.

8. The use of PREFETCH DATA (RELATIVE LONG) to prefetch operands that are frequently updated in a multiprocessing environment may actually degrade performance by causing unnecessary contention for the cache line.

9. A prefetch operation consists of fetching a cache line on an integral boundary. The cache line size (and corresponding integral boundary) may be determined by executing EXTRACT CPU ATTRIBUTE.

10. The second operand is fetched into the cache line in model-dependent units, on an integral boundary, the minimum size of which is a double-word. Thus, at least the rightmost three bits of the second-operand address are assumed to contain zeros, regardless of what is specified by the program.

11. On most models, the unit directly addressed by the second-operand address is prefetched first. The order in which the remaining units of the cache line are prefetched is also model dependent.

12. When PREFETCH DATA RELATIVE LONG is the target of an execute-type instruction, the second-operand address is relative to the target address.

### ROTATE LEFT SINGLE LOGICAL

<table>
<thead>
<tr>
<th>RLL</th>
<th>R1, R2, D2(B2) [RSYa]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘EB’</td>
<td>R1</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
</tr>
</tbody>
</table>

The 32-bit or 64-bit third operand is rotated left the number of bits specified by the second-operand address, and the result is placed at the first-operand location. Except for when the R1 and R3 fields designate the same register, the third operand remains unchanged in general register R3. For ROTATE LEFT SINGLE LOGICAL (RLL), bits 0-31 of general registers R1 and R3 remain unchanged.

The second-operand address is not used to address data; its rightmost six bits indicate the number of bit positions to be rotated. The remainder of the address is ignored.

For RLL, the first and third operands are in bit positions 32-63 of general registers R1 and R3, respectively. For RLLG, the operands are in bit positions 0-63 of the registers.

All 32 or 64 bits of the third operand participate in a left shift. Each bit shifted out of the leftmost bit position of the operand is placed in the rightmost bit position of the operand.

**Condition Code:** The code remains unchanged.

**Program Exceptions:** None.

### ROTATE THEN AND SELECTED BITS

<table>
<thead>
<tr>
<th>RNSBG</th>
<th>R1, R2, I3, I4, [I5] [RIE-f]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘EC’</td>
<td>R1</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
</tr>
</tbody>
</table>

### ROTATE THEN EXCLUSIVE OR SELECTED BITS

<table>
<thead>
<tr>
<th>RXSBG</th>
<th>R1, R2, I3, I4, [I5] [RIE-f]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘EC’</td>
<td>R1</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
</tr>
</tbody>
</table>
The second operand is rotated left by the number of bits specified in the fifth operand. Each bit shifted out of the leftmost bit position of the operand is placed in the rightmost bit position of the operand. Depending on the instruction, the selected bits of the rotated second operand are logically ANDed, exclusive ORed, or ORed with the corresponding bits of the first operand, and the results of the logical operation may replace the selected bits of the first operand. The result is indicated by the condition code.

The second operand remains unchanged in general register R2.

Bits 2-7 of the I3 field (bits 18-23 of the instruction) contain an unsigned binary integer specifying the starting bit position of the selected range of bits in the first operand and in the second operand after rotation. Bits 2-7 of the I4 field (bits 26-31 of the instruction) contain an unsigned binary integer specifying the ending bit position (inclusive) of the selected range of bits. When the ending bit position is less than the starting bit position, the range of bits wraps around from bit 63 to bit 0.

Bits 2-7 of the I5 field (bits 34-39 of the instruction) contain an unsigned binary integer specifying the number of bits that the second operand is rotated to the left.

Bit 0 of the I3 field (bit 16 of the instruction) contains the test-results control (T). When the T bit is zero, the results of the logical operation replace the selected bits of the first operand, and the remaining bits of the first operand are unchanged. When the T bit is one, the entire first operand is unchanged.

The condition code is set based on the results of the logical operation, regardless of the setting of the T bit. Only the selected range of bits is used to determine the condition code.

Bit 1 of the I3 field and bits 0-1 of the I4 field (bits 17 and 24-25 of the instruction) are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future. Bits 0-1 of the I5 field (bits 32-33 of the instruction) are ignored.

**Resulting Condition Code:**

0  Result is zero
1  Result is not zero
2  --
3  --

**Program Exceptions:**

- Operation (if the general-instructions-extension facility is not installed)

**Programming Notes:**

1. Although the bits 2-7 of the I5 field are defined to contain an unsigned binary integer specifying the number of bits that the second operand is rotated to the left, a negative value may be coded which effectively specifies a rotate-right amount.

2. The first operand is always used in its unrotated form. When the R1 and R2 fields designate the same register, the contents of the register are first rotated, and then the selected bits of the rotated value logically operate upon the corresponding bits of the unrotated register contents.

3. Examples of the use of ROTATE THEN EXCLUSIVE OR SELECTED BITS, and ROTATE THEN OR SELECTED BITS are given in “Number Representation and Instruction-Use Examples” on page A-1.

4. In the assembler syntax, the I5 operand containing the rotate amount is considered to be optional. When the I5 field is not coded, a rotate amount of zero is implied.

5. The I3 field contains both the test-results control (in bit 0) and the starting bit position value (in bits 2-7). For example, to AND bits 40-43 of register 5 with the corresponding bits of register 7 (no rota-
The X'80' represents the test-results control which is added to the starting-bit position to form the $I_3$ field.

The high-level assembler (HLASM) provides alternative mnemonics for the test versions of these instructions, as shown below:

\[
\text{RNSBG} \quad R_5, R_7, X'80'+40, 43, 0
\]

The "T" suffix to the mnemonic indicates that the specified $I_3$ field is ORed with a value of X'80' when generating the object code. The T mnemonic suffix also applies to ROSBG and RXSBG.

The High-Level Assembler implements various high-word logical operations by providing extended-mnemonics for the RNSBG, ROSBG, and RXSBG instructions, as shown in Figure 7-305.

<table>
<thead>
<tr>
<th>Instruction Name</th>
<th>Extended-Mnemonic Syntax</th>
<th>RxSBG Equivalent</th>
</tr>
</thead>
<tbody>
<tr>
<td>AND HIGH (HIGH ← HIGH)</td>
<td>NHHR $R_1$, $R_2$</td>
<td>RNSBG $R_1$, $R_2$, 0, 31</td>
</tr>
<tr>
<td>AND HIGH (HIGH ← LOW)</td>
<td>NHLR $R_1$, $R_2$</td>
<td>RNSBG $R_1$, $R_2$, 0, 31, 32</td>
</tr>
<tr>
<td>AND HIGH (LOW ← HIGH)</td>
<td>NLHR $R_1$, $R_2$</td>
<td>RNSBG $R_1$, $R_2$, 32, 63, 32</td>
</tr>
<tr>
<td>EXCLUSIVE OR HIGH (HIGH ← HIGH)</td>
<td>XHHR $R_1$, $R_2$</td>
<td>RXSBG $R_1$, $R_2$, 0, 31</td>
</tr>
<tr>
<td>EXCLUSIVE OR HIGH (HIGH ← LOW)</td>
<td>XLHR $R_1$, $R_2$</td>
<td>RXSBG $R_1$, $R_2$, 0, 31, 32</td>
</tr>
<tr>
<td>EXCLUSIVE OR HIGH (LOW ← HIGH)</td>
<td>XHLR $R_1$, $R_2$</td>
<td>RXSBG $R_1$, $R_2$, 32, 63, 32</td>
</tr>
<tr>
<td>OR HIGH (HIGH ← HIGH)</td>
<td>OHHR $R_1$, $R_2$</td>
<td>ROSBG $R_1$, $R_2$, 0, 31</td>
</tr>
<tr>
<td>OR HIGH (HIGH ← LOW)</td>
<td>OHLR $R_1$, $R_2$</td>
<td>ROSBG $R_1$, $R_2$, 0, 31, 32</td>
</tr>
<tr>
<td>OR HIGH (LOW ← HIGH)</td>
<td>OHLR $R_1$, $R_2$</td>
<td>ROSBG $R_1$, $R_2$, 32, 63, 32</td>
</tr>
</tbody>
</table>

Figure 7-305. Extended-Mnemonics Formed Using RNSBG, RXSBG, and ROSBG

**ROTATE THEN INSERT SELECTED BITS**

\[
\text{RISBG} \quad R_1, R_2, I_3, I_4 [I_5] [\text{RIE-}] \\
\text{RISBGN} \quad R_1, R_2, I_3, I_4 [I_5] [\text{RIE-}]
\]

<table>
<thead>
<tr>
<th>Instruction Name</th>
<th>Extended-Mnemonic Syntax</th>
<th>RxSBG Equivalent</th>
</tr>
</thead>
<tbody>
<tr>
<td>AND HIGH (HIGH ← HIGH)</td>
<td>NHHR $R_1$, $R_2$</td>
<td>RNSBG $R_1$, $R_2$, 0, 31</td>
</tr>
<tr>
<td>AND HIGH (HIGH ← LOW)</td>
<td>NHLR $R_1$, $R_2$</td>
<td>RNSBG $R_1$, $R_2$, 0, 31, 32</td>
</tr>
<tr>
<td>AND HIGH (LOW ← HIGH)</td>
<td>NLHR $R_1$, $R_2$</td>
<td>RNSBG $R_1$, $R_2$, 32, 63, 32</td>
</tr>
<tr>
<td>EXCLUSIVE OR HIGH (HIGH ← HIGH)</td>
<td>XHHR $R_1$, $R_2$</td>
<td>RXSBG $R_1$, $R_2$, 0, 31</td>
</tr>
<tr>
<td>EXCLUSIVE OR HIGH (HIGH ← LOW)</td>
<td>XLHR $R_1$, $R_2$</td>
<td>RXSBG $R_1$, $R_2$, 0, 31, 32</td>
</tr>
<tr>
<td>EXCLUSIVE OR HIGH (LOW ← HIGH)</td>
<td>XHLR $R_1$, $R_2$</td>
<td>RXSBG $R_1$, $R_2$, 32, 63, 32</td>
</tr>
<tr>
<td>OR HIGH (HIGH ← HIGH)</td>
<td>OHHR $R_1$, $R_2$</td>
<td>ROSBG $R_1$, $R_2$, 0, 31</td>
</tr>
<tr>
<td>OR HIGH (HIGH ← LOW)</td>
<td>OHLR $R_1$, $R_2$</td>
<td>ROSBG $R_1$, $R_2$, 0, 31, 32</td>
</tr>
<tr>
<td>OR HIGH (LOW ← HIGH)</td>
<td>OHLR $R_1$, $R_2$</td>
<td>ROSBG $R_1$, $R_2$, 32, 63, 32</td>
</tr>
</tbody>
</table>

Bits 2-7 of the $I_3$ field (bits 18-23 of the instruction) contain an unsigned binary integer specifying the starting bit position of the selected range of bits in the first operand and in the second operand after rotation. Bits 2-7 of the $I_4$ field (bits 26-31 of the instruction) contain an unsigned binary integer specifying the ending bit position (inclusive) of the selected range of bits. When the ending bit position is less than the starting bit position, the range of bits wraps around from bit 63 to bit 0.

Bits 2-7 of the $I_5$ field (bits 34-39 of the instruction) contain an unsigned binary integer specifying the number of bits that the second operand is rotated to the left.

Bit 0 of the $I_4$ field (bit 24 of the instruction) contains the zero-remaining-bits control (Z). The Z bit controls how the remaining bits of the first operand are set (that is, those bits, if any, that are outside of the specified range). When the Z bit is zero, the remaining bits of the first operand are unchanged. When the Z bit is one, the remaining bits of the first operand are set to zeros.
The immediate fields just described are as follows:

<table>
<thead>
<tr>
<th>I3 Field</th>
<th>I4 Field</th>
<th>I5 Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>/</td>
<td>/</td>
<td>/</td>
</tr>
<tr>
<td>0 2 7</td>
<td>0 2 7</td>
<td>0 2 7</td>
</tr>
</tbody>
</table>

Bits 0-1 of the I3 field and bit 1 of the I4 field (bits 16-17 and 25 of the instruction) are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future. Bits 0-1 of the I5 field (bits 32-33 of the instruction) are ignored.

For the purposes of setting the condition code for RISBG, the result in general register R1 is treated as being a 64-bit signed binary integer.

**Resulting Condition Code:**

For RISBG, the condition code is set as follows:

- 0: Result is zero
- 1: Result is less than zero
- 2: Result is greater than zero
- 3: --

For RISBGN, the condition code remains unchanged.

**Program Exceptions:**

- Operation (RISBG, if the general-instructions-extension facility is not installed; RISBGN, if the miscellaneous-instruction-extensions facility is not installed)

**Programming Notes:**

1. Although the bits 2-7 of the I3 field are defined to contain an unsigned binary integer specifying the number of bits that the second operand is rotated to the left, a negative value may be coded which effectively specifies a rotate-right amount.

2. When used with the zero-remaining-bits control, ROTATE THEN INSERT SELECTED BITS provides a means of effecting a shift operation.

3. When the R1 and R2 fields designate the same register and the Z bit is one, ROTATE THEN INSERT SELECTED BITS may be used to zero a selected range of bits in a register. Note, this technique cannot be used to zero all 64 bits of the register.

4. The first operand is always used in its unrotated form. When the R1 and R2 fields designate the same register, the contents of the register are first rotated, and then the selected bits of the rotated value are inserted into the corresponding bits of the unrotated register contents.

5. Examples of the use of ROTATE THEN INSERT SELECTED BITS are given in “Number Representation and Instruction-Use Examples” on page A-1.

6. In the assembler syntax, the I5 operand containing the rotate amount is considered to be optional. When the I5 field is not coded, a rotate amount of zero is implied.

7. The I4 field contains both the zero-remaining-bits control (in bit 0) and the ending bit position value (in bits 2-7). For example, to insert bits 40-43 of register 7 into the corresponding bits of register 5 (no rotation) and zero the remaining bits in register 5, the programmer might code:

```
RISBG R5,R7,40,X’80’+43,0
RISBGN R5,R7,40,X’80’+43,0
```

The ‘X’80’ represents the zero-remaining-bits control which is added to the ending-bit position to form the I4 field.

The high-level assembler (HLASM) provides an alternative mnemonic for the zero-remaining-bits versions of the instruction, as shown below:

```
RISBGZ R5,R7,40,43,0
RISBGNZ R5,R7,40,43,0
```

The “Z” suffix to the mnemonic indicates that the specified I4 field is ORed with a value of X’80’ when generating the object code.

**ROTATE THEN INSERT SELECTED BITS HIGH**

<table>
<thead>
<tr>
<th>RISBHGs</th>
<th>R1,R2,I3,I4[,I5][ RIE-f]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘EC’</td>
<td>R1</td>
</tr>
<tr>
<td>0 8 12 16 24 32 40 47</td>
<td></td>
</tr>
</tbody>
</table>
ROTATE THEN INSERT SELECTED BITS LOW

The 64-bit second operand is rotated left by the number of bits specified in the fifth operand. Each bit shifted out of the leftmost bit position of the operand is placed in the rightmost bit position of the operand. The selected bits of the rotated second operand replace the contents of the corresponding bit positions of the first operand.

For ROTATE THEN INSERT SELECTED BITS HIGH, the first operand is in bits 0-31 of general register R1, and bits 32-63 of the register are unchanged. For ROTATE THEN INSERT SELECTED BITS LOW, the first operand is in bits 32-63 of general register R1, and bits 0-31 of the register are unchanged.

The second operand remains unchanged in general register R2.

For ROTATE THEN INSERT SELECTED BITS HIGH, bits 3-7 of the I3 and I4 fields (bits 19-23 and 27-31 of the instruction, respectively), with a binary zero appended on the left of each, form six-bit unsigned binary integers specifying the starting and ending bit positions (inclusive) of the selected range of bits in the first operand and in the second operand after rotation. When the ending bit position is less than the starting bit position, the range of selected bits wraps around from bit 31 to bit 0. Thus, the starting and ending bit positions of the selected range of bits are always between 0 and 31.

For ROTATE THEN INSERT SELECTED BITS LOW, bits 3-7 of the I3 and I4 fields, with a binary one appended on the left of each, form six-bit unsigned binary integers specifying the starting and ending bit positions (inclusive) of the selected range of bits in the first operand and in the second operand after rotation. When the ending bit position is less than the starting bit position, the range of selected bits wraps around from bit 63 to bit 32. Thus, the starting and ending bit positions of the selected range of bits are always between 32 and 63.

Bits 2-7 of the I5 field (bits 34-39 of the instruction) contain an unsigned binary integer specifying the number of bits that the second operand is rotated to the left.

Bit 0 of the I4 field (bit 24 of the instruction) contains the zero-remaining-bits control (Z). The Z bit controls how the remaining bits of the first operand are set (that is, those bits, if any, that are outside of the specified range). When the Z bit is zero, the remaining bits of the first operand are unchanged. When the Z bit is one, the remaining bits of the first operand are set to zeros.

The immediate fields just described are as follows:

```
<table>
<thead>
<tr>
<th>I3 Field</th>
<th>I4 Field</th>
<th>I5 Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>/ / / Starting Bit Position</td>
<td>Z / / Ending Bit Position</td>
<td>0 2 Rotate Amount</td>
</tr>
</tbody>
</table>
```

Bits 0-2 of the I3 field and bits 1-2 of the I4 field (bits 16-19 and 25-26 of the instruction) are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future. Bits 0-1 of the I5 field (bits 32-33 of the instruction) are ignored.

Condition Code: The code remains unchanged

Program Exceptions:
- Operation (if the high-word facility is not installed)

Programming Notes:
1. Although the bits 2-7 of the I5 field are defined to contain an unsigned binary integer specifying the number of bits that the second operand is rotated to the left, a negative value may be coded which effectively specifies a rotate-right amount.
2. The first operand is always used in its unrotated form. When the R1 and R2 fields designate the same register, the value contained in the register is first rotated, and then the selected bits of the rotated value are inserted into the corresponding bits of the unrotated register contents.
3. In the assembler syntax, the I5 operand containing the rotate amount is considered to be optional. When the I5 field is not coded, a rotate amount of zero is implied.
4. The I4 field contains both the zero-remaining-bits control (in bit 0) and the ending bit position value (in bits 2-7). For example, to insert bits 40-43 of
register 7 into the corresponding bits of register 5 (no rotation) and zero the remaining bits in the right half of register 5, the programmer might code:

RISBLG R5,R7,40,X'80'+43,0

The X'80' represents the zero-remaining-bits control which is added to the ending-bit position to form the I4 field.

The High-Level Assembler (HLASM) provides alternative mnemonics for the zero-remaining-bits versions of RISBHG and RISBLG in the form of RISBHGZ and RISBLGZ, respectively. The "Z" suffix to the mnemonic indicates that the specified I4 field is ORed with a value of X'80' when generating the object code.

An equivalent to the example shown above using the Z-suffixed mnemonic is as follows:

RISBLGZ R5,R7,40,43,0

5. On some models, improved performance of RISBHG and RISBLG may be realized by setting the zero-remaining-bits control to one (or using the Z mnemonic suffix).

6. Unlike ROTATE THEN INSERT SELECTED BITS which sets the condition code, ROTATE THEN INSERT SELECTED BITS HIGH and ROTATE THEN INSERT SELECTED BITS LOW do not set the condition code.

7. The High-Level Assembler implements various high-word logical operations by providing extended-mnemonics for the RISBHG and RISBLG instructions, as shown in Figure 7-306.

<table>
<thead>
<tr>
<th>Instruction Name</th>
<th>Extended-Mnemonic Syntax</th>
<th>RISBHG / RISBLG Equivalent</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOAD (HIGH ↔ HIGH)</td>
<td>LHHR R1,R2</td>
<td>RISBHG R1,R2,0,31</td>
</tr>
<tr>
<td>LOAD (HIGH ↔ LOW)</td>
<td>LHLR R1,R2</td>
<td>RISBLG R1,R2,0,31,32</td>
</tr>
<tr>
<td>LOAD (LOW ↔ HIGH)</td>
<td>LLHFR R1,R2</td>
<td></td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (HIGH ↔ HIGH)</td>
<td>LLHHR R1,R2</td>
<td>RISBHG R1,R2,16,31</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (HIGH ↔ LOW)</td>
<td>LLHLHR R1,R2</td>
<td>RISBHG R1,R2,16,31,32</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (LOW ↔ HIGH)</td>
<td>LLHLHR R1,R2</td>
<td>RISBLG R1,R2,16,31,32</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (HIGH ↔ HIGH)</td>
<td>LLCHHR R1,R2</td>
<td>RISBHG R1,R2,24,31</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (HIGH ↔ LOW)</td>
<td>LLCHLR R1,R2</td>
<td>RISBHG R1,R2,24,31,32</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (LOW ↔ HIGH)</td>
<td>LLCLHR R1,R2</td>
<td>RISBLG R1,R2,24,31,32</td>
</tr>
</tbody>
</table>

Figure 7-306. Extended Mnemonics Formed Using RISBHG and RISBLG

The second operand is searched until a specified character is found, the end of the second operand is reached, or a CPU-determined number of bytes have been searched, whichever occurs first. The CPU-determined number is at least 256. The result is indicated in the condition code.

The location of the first byte of the second operand is designated by the contents of general register R1. The location of the first byte after the second operand is designated by the contents of general register R2.

The handling of the addresses in general registers R1 and R2 is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R2 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

In the access-register mode, the address space containing the second operand is specified only by means of access register R2. The contents of access register R1 are ignored.

The character for which the search occurs is specified in bit positions 56-63 of general register 0. Bit positions 32-55 of general register 0 are reserved for possible future extensions and must contain all
zeros; otherwise, a specification exception is recognized.

The operation proceeds left to right and ends as soon as the specified character has been found in the second operand, the address of the next second-operand byte to be examined equals the address in general register R1, or a CPU-determined number of second-operand bytes have been examined, whichever occurs first. The CPU-determined number is at least 256. When the specified character is found, condition code 1 is set. When the address of the next second-operand byte to be examined equals the address in general register R1, condition code 2 is set. When a CPU-determined number of second-operand bytes have been examined, condition code 3 is set. When the CPU-determined number of second-operand bytes have been examined and the address of the next second-operand byte is in general register R1, it is unpredictable whether condition code 2 or 3 is set.

When condition code 1 is set, the address of the specified character found in the second operand is placed in general register R1, and the contents of general register R2 remain unchanged. When condition code 3 is set, the address of the next byte to be processed in the second operand is placed in general register R2, and the contents of general registers R1 and R2 remain unchanged. Whenever an address is placed in a general register, bits 32-39 of the register, in the 24-bit addressing mode, or bit 32, in the 31-bit addressing mode, are set to zeros. Bits 0-31 of the R1 and R2 registers always remain unchanged in the 24-bit or 31-bit mode.

When the address in general register R1 equals the address in general register R2, condition code 2 is set immediately, and access exceptions are not recognized. When the address in general register R1 is less than the address in general register R2, condition code 2 can be set only if the operand wraps around from the top of storage to location 0.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

Access exceptions for the second operand are recognized only for that portion of the operand that is necessarily examined.

The storage-operand-consistency rules are described in the section “Storage-Operand Consistency” on page 5-123.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>--</td>
</tr>
<tr>
<td>1</td>
<td>Specified character found; general register R1 updated with address of character; general register R2 unchanged</td>
</tr>
<tr>
<td>2</td>
<td>Specified character not found in entire second operand; general registers R1 and R2 unchanged</td>
</tr>
<tr>
<td>3</td>
<td>CPU-determined number of bytes searched; general register R1 unchanged; general register R2 updated with address of next byte</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operand 2)
- Specification
- Transaction constraint

**Programming Notes:**

1. Examples of the use of the SEARCH STRING instruction are given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. When condition code 3 is set, the program can simply branch back to the instruction to continue the search. The program need not determine the number of bytes that were searched.

3. The R1 or R2 fields may designate general register 0, in which case general register 0 is treated as containing an address and also the specified character.

However, if the program branches back to the SEARCH STRING instruction following condition code 3, specifying R2 as register 0 is impractical. This is because bits 32-55 of the register will have been altered to a nonzero value, thus resulting in a specification exception on the subsequent execution. The search character in bit positions 56-63 of the register also may have been altered.

4. When it is desired to search a string of unknown length for its ending character, and assuming that the specified character in general register 0
need not be preserved, then the $R_1$ field can designate general register 0 in order to have SEARCH STRING use only two general registers instead of three. In this case, the rightmost portion of general register 0 containing the required zeros and the 8-bit search character is also used to form the address of the first byte after the second operand.

5. If the program branches back to the SEARCH STRING instruction when condition code 3 is set, and a subsequent execution results in condition code 1 or 2, general register $R_2$ will have changed from its initial value, even though the definition states that the register is unchanged when the character is found.

6. If the length of the string (as determined by the difference between the addresses in general registers $R_1$ and $R_2$) is 255 characters or less, condition code 3 will never be set, and branching on that condition is not necessary. However, if the length of the string is 256 or more characters, condition code 3 may be set – even if condition code 2 also applies.

**SEARCH STRING UNICODE**

<table>
<thead>
<tr>
<th>SRSTU</th>
<th>$R_1$, $R_2$</th>
<th>[RRE]</th>
</tr>
</thead>
</table>

The second operand is searched until a specified two-byte character is found, the end of the second operand is reached, or a CPU-determined number of two-byte characters have been searched, whichever occurs first. The CPU-determined number is at least 256 two-byte characters. The result is indicated in the condition code.

The location of the first two-byte character of the second operand is designated by the contents of general register $R_2$. When the contents of bit position 63 of general registers $R_1$ and $R_2$ are identical (that is, when both addresses are even or both addresses are odd), the location of the first two-byte character after the second operand is designated by the contents of general register $R_1$. When the contents of bit position 63 of general registers $R_1$ and $R_2$ differ (that is, when one address is even and the other is odd), the location of the first two-byte character after the second operand is one more than the contents of general register $R_1$.

The handling of the addresses in general registers $R_1$ and $R_2$ is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers $R_1$ and $R_2$ constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

In the access-register mode, the address space containing the second operand is specified only by means of access register $R_2$. The contents of access register $R_1$ are ignored.

The two-byte character for which the search occurs is specified in bit positions 48-63 of general register 0. Bit positions 32-47 of general register 0 are reserved for possible future extensions and must contain all zeros; otherwise, a specification exception is recognized.

Except for the case when the address in general register $R_1$ equals the address in general register $R_2$, the operation proceeds from left to right in steps of two bytes and ends as soon as the specified two-byte character has been found in the second operand, the address of the next second-operand two-byte character to be examined (excluding the first two-byte character) is equal to the address of the first two-byte character after the second operand (as designated by general register $R_1$), or a CPU-determined number of second-operand two-byte characters have been examined, whichever occurs first. The CPU-determined number is at least 256. When the specified two-byte character is found, condition code 1 is set. When the address of the next second-operand two-byte character to be examined (excluding the first two-byte character) is equal to the address of the first two-byte character after the second operand, condition code 2 is set. When a CPU-determined number of second-operand two-byte characters have been examined, condition code 3 is set, except that condition code 2 is set if the conditions for setting it also apply.

When condition code 1 is set, the address of the specified two-byte character found in the second operand is placed in general register $R_1$, and the contents of general register $R_2$ remain unchanged. When condition code 3 is set, the address of the next two-byte character to be processed in the second operand is placed in general register $R_2$, and the contents
of general register R1 remain unchanged. When condition code 2 is set, the contents of general registers R1 and R2 remain unchanged. Whenever an address is placed in a general register, bits 32-39 of the register, in the 24-bit addressing mode, or bit 32, in the 31-bit addressing mode, are set to zeros. Bits 0-31 of the R1 and R2 registers always remain unchanged in the 24-bit or 31-bit mode.

When the address in general register R1 equals the address in general register R2, condition code 2 is set immediately, and access exceptions are not recognized. When the address in general register R1 is less than the address in general register R2, condition code 2 can be set only if the operand wraps around from the top of storage to location 0.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

Access exceptions for the second operand are recognized only for that portion of the operand that is necessarily examined.

The storage-operand-consistency rules are described in the section “Storage-Operand Consistency” on page 5-123.

**Resulting Condition Code:**

0  --
1  Specified two-byte character found; general register R1 updated with address of character; general register R2 unchanged
2  Specified two-byte character not found in entire second operand; general registers R1 and R2 unchanged
3  CPU-determined number of two-byte characters searched; general register R1 unchanged; general register R2 updated with address of next two-byte character

**Program Exceptions:**

- Access (fetch, operand 2)
- Operation (if the extended-translation facility 3 is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the program can simply branch back to the instruction to continue the search. The program need not determine the number of two-byte characters that were searched.
2. The R1 or R2 fields may designate general register 0, in which case general register 0 is treated as containing an address and also the specified character.

However, if the program branches back to the SEARCH STRING UNICODE instruction following condition code 3, specifying R2 as register 0 is impractical. This is because bits 32-47 of the register may have been altered to a nonzero value, thus resulting in a specification exception on the subsequent execution. The search character in bit positions 48-63 of the register also may have been altered.

3. When it is desired to search a string of unknown length for its ending two-byte character, and assuming that the specified two-byte character in general register 0 need not be preserved, then the R1 field can designate general register 0 in order to have SEARCH STRING UNICODE use only two general registers instead of three. In this case, the rightmost portion of general register 0 containing the required zeros and the 16-bit search character is also used to form the address of the first byte after the second operand.

4. If the program branches back to the SEARCH STRING UNICODE instruction when condition code 3 is set, and a subsequent execution results in condition code 1 or 2, general register R2 will have changed from its initial value, even though the definition states that the register is unchanged when the two-byte character is found.

5. If the length of the string (as determined by the difference between the addresses in general registers R1 and R2) is 256 two-byte characters or less, condition code 3 will never be set, and branching on that condition is not necessary. However, if the length of the string is 257 or more two-byte characters, condition code 3 may be set.
SET ACCESS

SAR R1, R2 [RRE]

The contents of bit positions 32-63 of general register R2 are placed in access register R1.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Transaction constraint

SET ADDRESSING MODE

SAM24 [E]

0 15

0 15

SAM31 [E]

0 15

0 15

SAM64 [E]

0 15

The addressing mode is set by setting the extended-addressing-mode bit, bit 31 of the current PSW, and the basic-addressing-mode bit, bit 32 of the current PSW, as follows:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>PSW Bit 31</th>
<th>PSW Bit 32</th>
<th>Resulting Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAM24</td>
<td>0</td>
<td>0</td>
<td>24-bit</td>
</tr>
<tr>
<td>SAM31</td>
<td>0</td>
<td>1</td>
<td>31-bit</td>
</tr>
<tr>
<td>SAM64</td>
<td>1</td>
<td>1</td>
<td>64-bit</td>
</tr>
</tbody>
</table>

The instruction address in the PSW is updated under the control of the new addressing mode, as follows. The value 2 (the instruction length) is added to the contents of bit positions 64-127 of the PSW, or the value 4 is added if the instruction is the target of EXECUTE, or the value 6 is added if the instruction is the target of EXECUTE RELATIVE LONG. In any case, a carry out of bit position 0 is ignored. Then bits 64-103 of the PSW are set to zeros if the new addressing mode is the 24-bit mode, or bits 64-96 are set to zeros if the new addressing mode is the 31-bit mode.

The instruction is completed only if the new addressing mode and the unupdated instruction address in the PSW are a valid combination. When the new addressing mode is to be the 24-bit mode, bits 64-103 of the unupdated PSW must be all zeros, or, when the new addressing mode is to be the 31-bit mode, bits 64-96 of the unupdated PSW must be all zeros; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Specification (SAM24 and SAM31 only)
- Trace
- Transaction constraint

**Programming Note:** Checking the unupdated instruction address prevents completion in two major cases: the instruction is located at address $2^{24}$ or above and the new addressing mode is to be the 24-bit mode, or the instruction is located at address $2^{31}$ or above and the new addressing mode is to be the 24-bit or 31-bit mode. In these cases, if the instruction were completed, the updating of the instruction address under the control of the new addressing mode would cause one or more leftmost bits of the address to be set to zeros, which would cause the next instruction to be fetched from other than the next sequential location. This action is sometimes called a "wild branch." A wild branch still can occur if the instruction is located at $2^{24} - 2$ or $2^{31} - 2$, or at $2^{24} - 4$ or $2^{31} - 4$ if EXECUTE or EXECUTE RELATIVE LONG is used, or at $2^{24} - 6$ or $2^{31} - 6$ if EXECUTE RELATIVE LONG is used.

SET PROGRAM MASK

SPM R1 [RR]

The first operand is used to set the condition code and the program mask of the current PSW.

Bits 34 and 35 of general register R1 replace the condition code, and bits 36-39 replace the program
SHIFT LEFT DOUBLE

SLDA R1,D2(B2)

The 63-bit numeric part of the signed first operand is shifted left the number of bits specified by the second-operand address, and the result is placed at the first-operand location. The first operand consists of bits 32-63 of general register R1 followed on the right by bits 32-63 of general register R1 + 1.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The second-operand address is not used to address data; its rightmost six bits indicate the number of bit positions to be shifted. The remainder of the address is ignored.

The first operand is treated as a 64-bit signed binary integer. The sign bit of the first operand, bit 32 of the even-numbered register, remains unchanged. Bit position 32 of the odd-numbered register contains a numeric bit, which participates in the shift in the same manner as the other numeric bits. Zeros are supplied to the vacated bit positions on the right. Bits 0-31 of general registers R1 and R1 + 1 remain unchanged.

If one or more bits unlike the sign bit are shifted out of bit position 33 of the even-numbered register, an overflow occurs, and condition code 3 is set. If the fixed-point-overflow mask bit is one, a program interruption for fixed-point overflow occurs.

Resulting Condition Code:

0  Result zero; no overflow
1  Result less than zero; no overflow
2  Result greater than zero; no overflow
3  Overflow

Program Exceptions:
- Fixed-point overflow
- Specification

Programming Notes:
1. An example of the use of the SHIFT LEFT DOUBLE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. The eight shift instructions that are in both ESA/390 and z/Architecture provide the following three pairs of alternatives for 32 bits in one general register or, for double, in each of two general registers: left or right, single or double, and signed or logical. The four additional shift instructions in z/Architecture provide left or right, signed or logical shifts of 64 bits in one general register. The signed shifts differ from the logical shifts in that, in the signed shifts, overflow is recognized, the condition code is set, and the leftmost bit participates as a sign.
3. A zero shift amount in the two signed double-shift operations provides a double-length sign and magnitude test.
4. The base register participating in the generation of the second-operand address permits indirect specification of the shift amount by means of placement of the shift amount in the base regis-
A zero in the $B_2$ field indicates the absence of indirect shift specification.

**SHIFT LEFT DOUBLE LOGICAL**

<table>
<thead>
<tr>
<th>SLDL</th>
<th>$R_1, D_2(B_2)$</th>
<th>[RS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'8D'</td>
<td>$R_1$ $B_2$ $D_2$</td>
<td></td>
</tr>
</tbody>
</table>

The 64-bit first operand is shifted left the number of bits specified by the second-operand address, and the result is placed at the first-operand location. The first operand consists of bits 32-63 of general register $R_1$ followed on the right by bits 32-63 of general register $R_1 + 1$.

The $R_1$ field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The second-operand address is not used to address data; its rightmost six bits indicate the number of bit positions to be shifted. The remainder of the address is ignored.

All 64 bits of the first operand participate in the shift. Bits shifted out of bit position 32 of the even-numbered register are not inspected and are lost. Zeros are supplied to the vacated bit positions on the right. Bits 0-31 of general registers $R_1$ and $R_1 + 1$ remain unchanged.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Specification

**SHIFT LEFT SINGLE**

<table>
<thead>
<tr>
<th>SLA</th>
<th>$R_1, D_2(B_2)$</th>
<th>[RS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'8B'</td>
<td>$R_1$ $B_2$ $D_2$</td>
<td></td>
</tr>
</tbody>
</table>

SLA, the 31-bit numeric part of the signed first operand is shifted left the number of bits specified by the second-operand address, and the result is placed at the first-operand location. Bits 0-31 of general register $R_1$ remain unchanged.

For SLA, the first operand is treated as a 32-bit signed binary integer in bit positions 32-63 of general register $R_1$. The sign of the first operand remains unchanged. All 31 numeric bits of the operand participate in the left shift.

For SLAK, the first and third operands are treated as 64-bit signed binary integers in bit positions 0-63 of general registers $R_1$ and $R_3$, respectively. The sign of the first operand is set equal to the sign of the third operand. All 63 numeric bits of the third operand participate in the left shift.

For SLAG, the first and third operands are treated as 64-bit signed binary integers in bit positions 0-63 of general registers $R_1$ and $R_3$, respectively. The sign of the first operand is set equal to the sign of the third operand. All 63 numeric bits of the third operand participate in the left shift.
For SLA, SLAG, or SLAK, zeros are supplied to the vacated bit positions on the right.

If one or more bits unlike the sign bit are shifted out of bit position 33, for SLA or SLAK, or 1, for SLAG, an overflow occurs, and condition code 3 is set. If the fixed-point-overflow mask bit is one, a program interruption for fixed-point overflow occurs.

**Resulting Condition Code:**

0 Result zero; no overflow  
1 Result less than zero; no overflow  
2 Result greater than zero; no overflow  
3 Overflow

**Program Exceptions:**

- Fixed-point overflow  
- Operation (SLAK, if the distinct-operands facility is not installed)

**Programming Notes:**

1. An example of the use of the SHIF T LEFT SINGLE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. For SHIF T LEFT SINGLE (SLA and SLAK), for numbers with a value greater than or equal to -2^30 and less than 2^30, a left shift of one bit position is equivalent to multiplying the number by 2. For SHIF T LEFT SINGLE (SLAG), the comparable values are -2^62 and 2^62.

3. For SHIF T LEFT SINGLE (SLA and SLAK), shift amounts from 31 to 63 cause the entire numeric part to be shifted out of the register, leaving a result of the maximum negative number or zero, depending on whether or not the initial contents were negative. For SHIF T LEFT SINGLE (SLAG), a shift amount of 63 causes the same effect.

**SHIFT LEFT SINGLE LOGICAL**

<table>
<thead>
<tr>
<th>SLL</th>
<th>R_i, D_j (B_j)</th>
<th>[RS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'89'</td>
<td>R_i // B_j</td>
<td>D_j</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SLLK</th>
<th>R_i, R_3, D_j (B_j)</th>
<th>[RSY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB'</td>
<td>R_i R_3 B_j</td>
<td>DL_j DH_j 'DF'</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SLLG</th>
<th>R_i, R_3, D_j (B_j)</th>
<th>[RSY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB'</td>
<td>R_i R_3 B_j</td>
<td>DL_j DH_j '0D'</td>
</tr>
</tbody>
</table>

For SLL, the 32-bit first operand is shifted left the number of bits specified by the second-operand address, and the result is placed at the first-operand location. Bits 0-31 of general register R_i remain unchanged.

For SLLK, the 32-bit third operand is shifted left the number of bits specified by the second-operand address, and the result is placed at the first-operand location. Bits 0-31 of general register R_i remain unchanged. Except for when the R_i and R_3 fields designate the same register, the third operand remains unchanged in general register R_3.

For SLLG, the 64-bit third operand is shifted left the number of bits specified by the second-operand address, and the result is placed at the first-operand location. Except for when the R_i and R_3 fields designate the same register, the third operand remains unchanged in general register R_3.

The second-operand address is not used to address data; its rightmost six bits indicate the number of bit positions to be shifted. The remainder of the address is ignored.

For SLL, the first operand is in bit positions 32-63 of general register R_i. All 32 bits of the operand participate in the left shift.

For SLLK, the first and third operands are in bit positions 32-63 of general registers R_i and R_3, respectively. All 32 bits of the third operand participate in the left shift.

For SLLG, the first and third operands are in bit positions 0-63 of general registers R_i and R_3, respectively. All 64 bits of the third operand participate in the left shift.

For SLL, SLLG, or SLLK, zeros are supplied to the vacated bit positions on the right.

**Condition Code:** The code remains unchanged.
Program Exceptions:

- Operation (SLLK, if the distinct-operands facility is not installed)

Programming Note: The rightmost six bits of the second-operand address are treated as a 6-bit unsigned binary integer specifying the number of bit positions to be shifted to the left. Thus, the number of bit positions to be shifted is the value of the second-operand address, modulo 64.

When the number of bit positions to be shifted is between 32 and 63, SLL and SLLK can be used to zero the rightmost 32 bits of the result in general register R1. However, because of the modulo 64 behavior, it is not true that any second-operand-address value greater than 32 produces a result of zero.

Because the number of shifted bit positions is limited to 63, SLLG cannot be used to zero all 64 bits of the result.

SHIFT RIGHT DOUBLE

<table>
<thead>
<tr>
<th>SRDA</th>
<th>R1,D2(B2)</th>
<th>[RS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>8E</td>
<td>R1</td>
<td>B2</td>
</tr>
</tbody>
</table>

0 8 12 16 20 31

The 64-bit first operand is shifted right the number of bits specified by the second-operand address, and the result is placed at the first-operand location. The first operand consists of bits 32-63 of general register R1 followed on the right by bits 32-63 of general register R1 + 1.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The second-operand address is not used to address data; its rightmost six bits indicate the number of bit positions to be shifted. The remainder of the address is ignored.

The first operand is treated as a 64-bit signed binary integer. The sign bit of the first operand, bit 32 of the even-numbered register, remains unchanged. Bit position 32 of the odd-numbered register contains a numeric bit, which participates in the shift in the same manner as the other numeric bits. Bits shifted out of bit position 63 of the odd-numbered register are not inspected and are lost. Bits equal to the sign are supplied to the vacated bit positions on the left. Bits 0-31 of general registers R1 and R1 + 1 remain unchanged.

Resulting Condition Code:

0 Result zero
1 Result less than zero
2 Result greater than zero
3 --

Program Exceptions:

- Specification

SHIFT RIGHT DOUBLE LOGICAL

<table>
<thead>
<tr>
<th>SRDL</th>
<th>R1,D2(B2)</th>
<th>[RS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>8C</td>
<td>R1</td>
<td>B2</td>
</tr>
</tbody>
</table>

0 8 12 16 20 31

The 64-bit first operand is shifted right the number of bits specified by the second-operand address, and the result is placed at the first-operand location. The first operand consists of bits 32-63 of general register R1 followed on the right by bits 32-63 of general register R1 + 1.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The second-operand address is not used to address data; its rightmost six bits indicate the number of bit positions to be shifted. The remainder of the address is ignored.

All 64 bits of the first operand participate in the shift. Bits shifted out of bit position 63 of the odd-numbered register are not inspected and are lost. Zeros are supplied to the vacated bit positions on the left. Bits 0-31 of general registers R1 and R1 + 1 remain unchanged.

Condition Code: The code remains unchanged.

Program Exceptions:

- Specification
SHIFT RIGHT SINGLE

For SRA, the first and third operands are treated as 32-bit signed binary integers in bit positions 32-63 of general registers R1 and R3, respectively. The sign of the first operand is set equal to the sign of the third operand. All 31 numeric bits of the third operand participate in the right shift.

For SRAK, the first and third operands are treated as 64-bit signed binary integers in bit positions 0-63 of general registers R1 and R3, respectively. The sign of the first operand is set equal to the sign of the third operand. All 63 numeric bits of the third operand participate in the right shift.

For SRAG, the first and third operands are treated as 64-bit signed binary integers in bit positions 0-63 of general registers R1 and R3, respectively. The sign of the first operand is set equal to the sign of the third operand. All 63 numeric bits of the third operand participate in the right shift.

The second-operand address is not used to address data; its rightmost six bits indicate the number of bit positions to be shifted. The remainder of the address is ignored.

For SRA, the first operand is treated as a 32-bit signed binary integer in bit positions 32-63 of general register R1. The sign of the first operand remains unchanged. All 31 numeric bits of the operand participate in the right shift.

Resulting Condition Code:

0  Result zero
1  Result less than zero
2  Result greater than zero
3  --

Program Exceptions:

- Operation (SRAK, if the distinct-operands facility is not installed)

Programming Notes:

1. A right shift of one bit position is equivalent to division by 2 with rounding downward. When an even number is shifted right one position, the result is equivalent to dividing the number by 2. When an odd number is shifted right one position, the result is equivalent to dividing the next lower number by 2. For example, +5 shifted right by one bit position yields +2, whereas -5 yields -3.

2. For SRA and SRAK, shift amounts from 31 to 63 cause the entire numeric part to be shifted out of the register, leaving a result of -1 or zero, depending on whether or not the initial contents were negative. For SHIFT RIGHT SINGLE (SRAG), a shift amount of 63 causes the same effect.
SHIFT RIGHT SINGLE LOGICAL

For SRL, the 32-bit first operand is shifted right the number of bits specified by the second-operand address, and the result is placed at the first-operand location. Bits 0-31 of general register R1 remain unchanged.

For SRLK, the 32-bit third operand is shifted right the number of bits specified by the second-operand address, and the result is placed at the first-operand location. Bits 0-31 of general register R1 remain unchanged. Except for when the R1 and R3 fields designate the same register, the third operand remains unchanged in general register R3.

For SRLG, the 64-bit third operand is shifted right the number of bits specified by the second-operand address, and the result is placed at the first-operand location. Except for when the R1 and R3 fields designate the same register, the third operand remains unchanged in general register R3.

The second-operand address is not used to address data; its rightmost six bits indicate the number of bit positions to be shifted to the right. Thus, the number of bit positions to be shifted is the value of the second-operand address, modulo 64.

When the number of bit positions to be shifted is between 32 and 63, SRL and SRLK can be used to zero the rightmost 32 bits of the result in general register R1. However, because of the modulo 64 behavior, it is not true that any second-operand-address value greater than 32 produces a result of zero.

Because the number of shifted bit positions is limited to 63, SRLG cannot be used to zero all 64 bits of the result.

STOR E

STORE

ST R1,D2(X2,B2) [RX-a]

STY R1,D2(X2,B2) [RXY-a]

STG R1,D2(X2,B2) [RXY-a]
STORE RELATIVE LONG

STRL  R1,RI2  [RIL-b]

The first operand is placed unchanged at the second-operand location.

For STORE (ST, STY) and STORE RELATIVE LONG (STRL), the operands are 32 bits, and, for STORE (STG) and STORE RELATIVE LONG (STGRL), the operands are 64 bits.

The displacement for ST is treated as a 12-bit unsigned binary integer. The displacement for STY and STG is treated as a 20-bit signed binary integer.

For STORE RELATIVE LONG, the contents of the RI2 field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand in storage. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

For STORE RELATIVE LONG (STRL), the second operand must be aligned on a word boundary, and for STORE RELATIVE LONG (STGRL), the second operand must be aligned on a doubleword boundary; otherwise, a specification exception is recognized.

Condition Code:  The code remains unchanged.

Program Exceptions:

- Access (store, operand 2)
- Operation (STY, if the long-displacement facility is not installed; STRL and STGRL, if the general-instructions-extension facility is not installed)
- Specification (STRL, STGRL only)

Programming Notes:

1. For STORE RELATIVE LONG, the second operand must be aligned on an integral boundary corresponding to the operand’s size.
2. When STORE RELATIVE LONG is the target of an execute-type instruction, the second-operand address is relative to the target address.
3. Significant delay may be incurred if the program stores into the same cache line as that containing the storing instruction or into the cache line from which a subsequent instruction may be fetched. The EXTRACT CPU ATTRIBUTE instruction may be used to determine the cache-line size.

STORE ACCESS MULTIPLE

STAM  R1,R3,D2(B2) [RS-a]
           '9B'  R1  R3  B2  D2
    0  8  12  16  20  31

STAMY  R1,R3,D2(B2) [RSY-a]
          'EB'  R1  R3  B2  DL2  DH2  '9B'
   0  8  12  16  20  22  32  40  47

The contents of the set of access registers starting with access register R1 and ending with access register R3 are stored at the locations designated by the second-operand address.

The storage area where the contents of the access registers are placed starts at the location designated by the second-operand address and continues through as many storage words as the number of access registers specified. The contents of the access registers are stored in ascending order of their register numbers, starting with access register R1, and continuing up to and including access register R3, with access register 0 following access register 15. The contents of the access registers remain unchanged.

The displacement for STAM is treated as a 12-bit unsigned binary integer. The displacement for STAMY is treated as a 20-bit signed binary integer.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.
**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Operation (STAMY, if the long-displacement facility is not installed)
- Specification

**STORE CHARACTER**

<table>
<thead>
<tr>
<th>STC</th>
<th>R₁,D₉(X₂,B₂)</th>
<th>[RX-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'42' R₁ X₂ B₂ D₂</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>STCY</th>
<th>R₁,D₉(X₂,B₂)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3' R₁ X₂ B₂ DL₂ DH₂ '72'</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Bits 56-63 of general register R₁ are placed unchanged at the second-operand location. The second operand is one byte in length.

The displacement for STC is treated as a 12-bit unsigned binary integer. The displacement for STCY is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Operation (STCY, if the long-displacement facility is not installed)

**STORE CHARACTER HIGH**

<table>
<thead>
<tr>
<th>STCH</th>
<th>R₁,D₉(X₂,B₂)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3' R₁ X₂ B₂ DL₂ DH₂ 'C3'</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Bits 24-31 of general register R₁ are placed unchanged at the second-operand location. The second operand is one byte in length.

The displacement is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**STOR CHARACTER UNDER MASK**

**STORE CHARACTERS UNDER MASK**

<table>
<thead>
<tr>
<th>STCM</th>
<th>R₁,M₃,D₉(B₂)</th>
<th>[RS-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'BE' R₁ M₃ B₂ D₂</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>STCMY</th>
<th>R₁,M₃,D₉(B₂)</th>
<th>[RSY-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB' R₁ M₃ B₂ DL₂ DH₂ '2D'</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>STCMH</th>
<th>R₁,M₃,D₉(B₂)</th>
<th>[RSY-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB' R₁ M₃ B₂ DL₂ DH₂ '2C'</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Bytes selected from general register R₁ under control of a mask are placed at contiguous byte locations beginning at the second-operand address.

The contents of the M₃ field are used as a mask. These four bits, left to right, correspond one for one with four bytes, left to right, of general register R₁. For STORE CHARACTERS UNDER MASK (STCM, STCMY), the four bytes to which the mask bits correspond are in bit positions 32-63 of general register R₁. For STORE CHARACTERS UNDER MASK (STCMH), the four bytes are in the high-order half, bit positions 0-31, of the register. The bytes corresponding to ones in the mask are placed in the same order at successive and contiguous storage locations beginning at the second-operand address. When the mask is not zero, the length of the second operand is equal to the number of ones in the mask. The contents of the general register remain unchanged.

When the mask is not zero, exceptions associated with storage-operand accesses are recognized only for the number of bytes specified by the mask.

When the mask is zero, the single byte designated by the second-operand address remains unchanged. However, on some models, an access exception may be recognized for the location. If accessible, (a) a PER zero-address-detection event may be recognized for the location, and (b) the contents may be
fetched and subsequently stored back unchanged at the same storage location; this update appears to be an interlocked-update reference as observed by other CPUs.

The displacement for STCM is treated as a 12-bit unsigned binary integer. The displacement for STCMY and STCMH is treated as a 20-bit signed binary integer.

When STORE CHARACTERS UNDER MASK (STCMH) is attempted in a nonconstrained transaction, the M₃ field is 0, and the code in the R₁ field is 6 or 7, the transaction may be aborted due to abort code 16. When STORE CHARACTER UNDER MASK (STCMH) is attempted in a constrained transaction, the M₃ field is 0, and the code in the R₁ field is 6 or 7, a transaction-constraint program interruption is recognized, and the transaction is aborted with abort code 4.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (store, operand 2)
- Operation (STCMY, if the long-displacement facility is not installed)
- Transaction constraint (STCMH)

Programming Notes:

1. An example of the use of the STORE CHARACTERS UNDER MASK instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. STORE CHARACTERS UNDER MASK (STCM, STCMY), with a mask of 0111 binary may be used to store a three-byte address, for example, in modifying the address in a format-0 CCW.

3. STORE CHARACTERS UNDER MASK (STCM, STCMY) with a mask of 1111, 0011, or 0001 binary performs the same function as STORE (ST), STORE HALFWORD, or STORE CHARACTER, respectively.

4. Using STORE CHARACTERS UNDER MASK with a zero mask may cause any of the following to occur for the byte designated by the second-operand address: a PER storage-alteration event may be recognized; access exceptions may be recognized; and, provided no access exceptions exist, the change bit may be set to one. Because the contents of storage remain unchanged, the change bit may or may not be one when a PER storage-alteration event is recognized.

5. On certain models, STORE CHARACTERS UNDER MASK with mask field that specifies discontiguous bytes may perform slower than when the mask specifies contiguous bytes.

### STORE CLOCK

<table>
<thead>
<tr>
<th>D₂(B₂)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘B205’</td>
<td>B₂</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>31</td>
</tr>
</tbody>
</table>

### STORE CLOCK FAST

<table>
<thead>
<tr>
<th>D₂(B₂)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘B27C’</td>
<td>B₂</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>31</td>
</tr>
</tbody>
</table>

The current value of bits 0-63 of the TOD clock is stored in the eight-byte field designated by the second-operand address, provided the clock is in the set, stopped, or not-set state.

When the clock is stopped, zeros are stored in positions to the right of the rightmost bit position that is incremented when the clock is running. For STORE CLOCK, when the value of a running clock is stored, nonzero values may be stored in positions to the right of the rightmost incremented bit; this is to ensure that a unique value is stored. For STORE CLOCK FAST, when the value of a running clock is stored, bits to the right of the rightmost bit that is incremented are stored as zeros.

Zeros are stored at the operand location when the clock is in the error state or the not-operational state.

The quality of the clock value stored by the instruction is indicated by the resultant condition-code setting.

For STORE CLOCK, a serialization function is performed before the value of the clock is fetched and again after the value is placed in storage.
Resulting Condition Code:

0 Clock in set state
1 Clock in not-set state
2 Clock in error state
3 Clock in stopped state or not-operational state

Program Exceptions:

- Access (store, operand 2)
- Operation (STCKF, if the store-clock-fast facility is not installed)
- Transaction constraint

Programming Notes:

1. Bit position 31 of the clock is incremented every 1.048576 seconds; hence, for timing applications involving human responses, the leftmost clock word may provide sufficient resolution.

2. Condition code 0 normally indicates that the clock has been set by the control program. Accordingly, the value may be used in elapsed-time measurements and as a valid time-of-day and calendar indication. Condition code 1 indicates that the clock value is the elapsed time since the power for the clock was turned on. In this case, the value may be used in elapsed-time measurements but is not a valid time-of-day indication. Condition codes 2 and 3 mean that the value provided by STORE CLOCK cannot be used for time measurement or indication.

3. Condition code 3 indicates that the clock is in either the stopped state or the not-operational state. These two states can normally be distinguished because an all-zero value is stored when the clock is in the not-operational state.

4. If a problem program written for z/Architecture is to be executed also on a system in the System/370 mode, then the program should take into account that, in the System/370 mode, the value stored when the condition code is 2 is not necessarily zero.

5. Two executions of STORE CLOCK FAST, or an execution of STORE CLOCK FAST and STORE CLOCK, either on the same or different CPUs, do not necessarily return different values of the clock if the clock is running. Similarly, an execution of STORE CLOCK FAST and STORE CLOCK EXTENDED, either on the same or different CPUs, do not necessarily return different values of TOD clock bits 0-63 if the clock is running.

6. When the TOD-clock-steering facility is installed, and assuming a valid operating system, then, for the problem program, the TOD clock is always in the set state and there is no need to test the condition code after issuing STORE CLOCK or STORE CLOCK FAST.

STORE CLOCK EXTENDED

\[
\text{STCKE} \quad D_i(B_2) \quad [S]
\]

<table>
<thead>
<tr>
<th>B278</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>

The current value of bits 0-103 of the TOD clock is stored in byte positions 1-13 of the sixteen-byte field designated by the second-operand address, provided the clock is in the set, stopped, or not-set state. Zeros are stored in byte position 0. The TOD programmable field, bits 16-31 of the TOD programmable register, is stored in byte positions 14 and 15.

The operand just described has the following format:

<table>
<thead>
<tr>
<th>Zeros</th>
<th>TOD Clock</th>
<th>Programmable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>112</td>
</tr>
<tr>
<td></td>
<td>120</td>
<td>127</td>
</tr>
</tbody>
</table>

When the clock is stopped, zeros are stored in the clock value in positions to the right of the rightmost bit position that is incremented when the clock is running. The programmable field still is stored.

When the value of a running clock is stored, the value in bit positions 64-103 of the clock (bit positions 72-111 of the storage operand) is always nonzero; this ensures that values stored by STORE CLOCK EXTENDED are unique when compared with values stored by STORE CLOCK and extended with zeros.

Zeros are stored at the operand location when the clock is in the error state or the not-operational state.
The quality of the clock value stored by the instruction is indicated by the resultant condition-code setting.

A serialization function is performed before the value of the clock is fetched and again after the value is placed in storage.

**Resulting Condition Code:**

0  Clock in set state
1  Clock in not-set state
2  Clock in error state
3  Clock in stopped state or not-operational state

**Program Exceptions:**

- Access (store, operand 2)
- Transaction constraint

1. Condition code 0 normally indicates that the clock has been set by the control program. Accordingly, the value may be used in elapsed-time measurements and as a valid time-of-day and calendar indication. Condition code 1 indicates that the clock value is the elapsed time since the power for the clock was turned on. In this case, the value may be used in elapsed-time measurements but is not a valid time-of-day indication. Condition codes 2 and 3 mean that the value provided by STORE CLOCK EXTENDED cannot be used for time measurement or indication.

2. When the TOD-clock-steering facility is installed, and assuming a valid operating system, then, for the problem program, the TOD clock is always in the set state and there is no need to test the condition code after issuing STORE CLOCK EXTENDED.

3. Programming notes beginning on page 4-45 show hex values related to the value of the TOD clock as it is stored by the STORE CLOCK instruction. Notes 4-6, below, are repetitions of those notes except with the text and hex values adjusted so they apply to bits 0-71 of the value stored by STORE CLOCK EXTENDED.

4. The following chart shows the time interval between instants at which various bits of the TOD-clock value stored by STORE CLOCK EXTENDED are stepped. This time value may also be considered as the weighted time value that the bit, when one, represents. The bit numbers are those of the STORE CLOCK EXTENDED operand.

<table>
<thead>
<tr>
<th>STCKE Bit</th>
<th>Stepping Interval</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Days</td>
</tr>
<tr>
<td>59</td>
<td>0.000</td>
</tr>
<tr>
<td>55</td>
<td>0.000</td>
</tr>
<tr>
<td>51</td>
<td>0.000</td>
</tr>
<tr>
<td></td>
<td>0.004</td>
</tr>
<tr>
<td>43</td>
<td>0.065</td>
</tr>
<tr>
<td>39</td>
<td>1.048</td>
</tr>
<tr>
<td>35</td>
<td>16.777</td>
</tr>
<tr>
<td>31</td>
<td>28.435</td>
</tr>
<tr>
<td>27</td>
<td>34.967</td>
</tr>
<tr>
<td></td>
<td>19.476</td>
</tr>
<tr>
<td>19</td>
<td>11.627</td>
</tr>
<tr>
<td>15</td>
<td>6.044</td>
</tr>
<tr>
<td>11</td>
<td>36.710</td>
</tr>
</tbody>
</table>

5. The following chart shows the setting of bits 0-63 of the STORE CLOCK EXTENDED operand for 00:00:00 (0 am), UTC time, for several dates: January 1, 1900, January 1, 1972, and for that instant in time just after each of the 26 leap seconds that will have occurred through July, 2015. Each of these leap seconds is inserted in the UTC time scale beginning at 23:59:60 UTC of the day previous to the one listed and ending at 00:00:00 UTC of the day listed.

<table>
<thead>
<tr>
<th>Year</th>
<th>Month</th>
<th>Day</th>
<th>Leap Sec.</th>
<th>STCKE Value (Hex) Bits 0-63</th>
</tr>
</thead>
<tbody>
<tr>
<td>1900</td>
<td>1</td>
<td>1</td>
<td>0000</td>
<td>0000 0000 0000 0000 0000</td>
</tr>
<tr>
<td>1972</td>
<td>1</td>
<td>1</td>
<td>0081</td>
<td>2006E0 0000 0000</td>
</tr>
<tr>
<td>1972</td>
<td>7</td>
<td>1</td>
<td>0082</td>
<td>820A91 811E 2400</td>
</tr>
<tr>
<td>1973</td>
<td>1</td>
<td>1</td>
<td>0082</td>
<td>F300AEE2 4800</td>
</tr>
<tr>
<td>1974</td>
<td>1</td>
<td>1</td>
<td>0084</td>
<td>BDE97114 6C00</td>
</tr>
<tr>
<td>1975</td>
<td>1</td>
<td>1</td>
<td>0086</td>
<td>88D23346 9000</td>
</tr>
<tr>
<td>1976</td>
<td>1</td>
<td>1</td>
<td>0088</td>
<td>53BAF578 4B00</td>
</tr>
<tr>
<td>1977</td>
<td>1</td>
<td>1</td>
<td>008A</td>
<td>1FE5952D0 8000</td>
</tr>
<tr>
<td>1978</td>
<td>1</td>
<td>1</td>
<td>008B</td>
<td>EACE5752 FC00</td>
</tr>
<tr>
<td>1979</td>
<td>1</td>
<td>1</td>
<td>008D</td>
<td>55B79185 2000</td>
</tr>
<tr>
<td>1980</td>
<td>1</td>
<td>1</td>
<td>008F</td>
<td>80FFDBB7 4400</td>
</tr>
<tr>
<td>1981</td>
<td>1</td>
<td>1</td>
<td>0092</td>
<td>305C4FC5 7000</td>
</tr>
<tr>
<td>1982</td>
<td>1</td>
<td>1</td>
<td>0093</td>
<td>FB44D1FF 8000</td>
</tr>
<tr>
<td>1983</td>
<td>7</td>
<td>1</td>
<td>0095</td>
<td>C62D9431 8000</td>
</tr>
<tr>
<td>1985</td>
<td>7</td>
<td>1</td>
<td>0099</td>
<td>5D40F517 0000</td>
</tr>
<tr>
<td>1988</td>
<td>1</td>
<td>1</td>
<td>009D</td>
<td>DAE9A557 8F00</td>
</tr>
<tr>
<td>1990</td>
<td>1</td>
<td>1</td>
<td>00A1</td>
<td>717D063E 1C00</td>
</tr>
</tbody>
</table>
The stepping value of TOD-clock bit position 63, if implemented, is $2^{-12}$ microseconds, or approximately 244 picoseconds. This value is called a clock unit.

The following chart shows various time intervals in clock units expressed in hexadecimal notation. The chart shows the values stored in bit positions 0-71 of the STORE CLOCK EXTENDED operand. Bit 71 of the operand represents a clock unit.

<table>
<thead>
<tr>
<th>Interval</th>
<th>Clock Units (Hex)</th>
<th>Bits 0-71</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 microsecond</td>
<td>0010 00</td>
<td></td>
</tr>
<tr>
<td>1 millisecond</td>
<td>3E80 00</td>
<td></td>
</tr>
<tr>
<td>1 second</td>
<td>00F4 2400 00</td>
<td></td>
</tr>
<tr>
<td>1 minute</td>
<td>3938 7000 00</td>
<td></td>
</tr>
<tr>
<td>1 hour</td>
<td>000D 693A 4000 00</td>
<td></td>
</tr>
<tr>
<td>1 day</td>
<td>0141 DD76 0000 00</td>
<td></td>
</tr>
<tr>
<td>365 days</td>
<td>0001 CAE8 C13E 0000 00</td>
<td></td>
</tr>
<tr>
<td>366 days</td>
<td>0001 CC2A 9EB4 0000 00</td>
<td></td>
</tr>
<tr>
<td>1,461 days*</td>
<td>0007 2CE4 E2E0 0000 00</td>
<td></td>
</tr>
</tbody>
</table>

* Number of days in four years, including a leap year. Note that the year 1900 was not a leap year. Thus, the four-year span starting in 1900 has only 1,460 days.

For the leftmost doublewords in which facility bits are assigned, the reserved bits are stored as zeros. Doublewords to the right of the doubleword in which the highest-numbered facility bit is assigned for a model may or may not be stored. Access exceptions and PER events are not recognized for doublewords that are not stored.

The size of the second operand, in doublewords, is one more than the value specified in bits 56-63 of general register 0. The remaining bits of general register 0 are unassigned and should contain zeros; otherwise, the program may not operate compatibly in the future.

When the size of the second operand is large enough to contain all of the facility bits assigned for a model, then the complete facility list is stored in the second operand location, bits 56-63 of general register 0 are updated to contain one less than the number of doublewords needed to contain all of the facility bits assigned for the model, and condition code 0 is set.

When the size of the second operand is not large enough to contain all of the facility bits assigned for a model, then only the number of doublewords specified by the second-operand size are stored, bits 56-63 of general register 0 are updated to contain one less than the number of doublewords needed to contain all of the facility bits assigned for the model, and condition code 3 is set.

Figure 4-24, “Assigned Facility Bits” on page 4-76 shows the meanings of the assigned facility bits.

### Special Conditions

The second operand must be designated on a doubleword boundary; otherwise, a specification exception is recognized.

### Resulting Condition Code:

- 0 Complete facility list stored
- 1 --
- 2 --
- 3 Incomplete facility list stored

### Program Exceptions:

- Access (store, second operand)
- Operation (if the store-facility-list-extended facility is not installed)
- Specification
• Transaction constraint

Programming Notes:

1. The performance of STORE FACILITY LIST EXTENDED may be significantly slower than that of simply testing a byte in storage. Programs that need to frequently test for the presence of a facility — for example, dual-path code in which the facility is used in one path but not another — should execute the STORE FACILITY LIST EXTENDED instruction once during initialization. Subsequently, the program may test for the presence of the facility by examining the stored result, using an instruction such as TEST UNDER MASK.

2. When condition code 0 is set, bits 56-63 of general register 0 are updated to contain a value that is one less than the number of doublewords stored. If the program chooses to ignore the results in general register 0, then it should ensure that the entire second operand in storage is set to zero prior to executing STORE FACILITY LIST EXTENDED.

STORE HALFWORD

STH $R_1, D_2(X_2, B_2)$ [RX-a]

For STORE HALFWORD RELATIVE LONG, the contents of the $R_{I_2}$ field are a signed binary integer specifying the number of halfwords that is added to the address of the instruction to generate the address of the second operand in storage. When DAT is on, the second operand is accessed using the same addressing-space mode as that used to access the instruction. When DAT is off, the second operand is accessed using a real address.

Condition Code: The code remains unchanged.

Program Exceptions:

Access (store, operand 2)

Operation (STHY if the long-displacement facility is not installed; STHRL, if the general-instructions-extension facility is not installed.)

Programming Notes:

1. For STORE HALFWORD RELATIVE LONG, the second operand is necessarily aligned on an integral boundary corresponding to the operand's size.

2. When STORE HALFWORD RELATIVE LONG is the target of an execute-type instruction, the second-operand address is relative to the target address.

3. Significant delay may be incurred if the program stores into the same cache line as that containing the storing instruction. The EXTRACT CPU ATTRIBUTE instruction may be used to determine the cache-line size.

STORE HALFWORD HIGH

STHH $R_1, D_2(X_2, B_2)$

Bits 48-63 of general register $R_1$ are placed unchanged at the second-operand location. The second operand is two bytes in length.

The displacement for STH is treated as a 12-bit unsigned binary integer. The displacement for STHY is treated as a 20-bit signed binary integer.

STORE HALFWORD RELATIVE LONG

STHRL $R_1, R_{I_2}$ [RIL-b]

The displacement is treated as a 20-bit signed binary integer.

Condition Code: The code remains unchanged.
Program Exceptions:

- Access (store, operand 2)
- Operation (if the high-word facility is not installed)

STORE HIGH

```
STFH R1,D2(X2,B2) [RXY-a]

'E3' R1 X2 B2 DL2 DH2 'CB'
0 8 12 16 20 32 40 47
```

The first operand is placed unchanged at the second-operand location. The first operand is in bits 0-31 of general register R1, and the second operand is 32 bits in storage.

The displacement is treated as a 20-bit signed binary integer.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (store, operand 2)
- Operation (if the high-word facility is not installed)

STORE MULTIPLE

```
STM R1,R3,D2(B2) [RS-a]

'90' R1 R3 B2 D2
0 8 12 16 20 31
```

```
STMY R1,R3,D2(B2) [RSY-a]

'EB' R1 R3 B2 DL2 DH2 '90'
0 8 12 16 20 32 40 47
```

```
STMG R1,R3,D2(B2) [RSY-a]

'EB' R1 R3 B2 DL2 DH2 '24'
0 8 12 16 20 32 40 47
```

The contents of bit positions of the set of general registers starting with general register R1 and ending with general register R3 are placed in the storage area beginning at the location designated by the second-operand address and continuing through as many locations as needed.

For STORE MULTIPLE (STM, STMY), the contents of bit positions 32-63 of the general registers are stored in successive four-byte fields beginning at the second-operand address. For STORE MULTIPLE (STMG), the contents of bit positions 0-63 of the general registers are stored in successive eight-byte fields beginning at the second-operand address.

The general registers are stored in the ascending order of their register numbers, starting with general register R1, and continuing up to and including general register R3, with general register 0 following general register 15.

The displacement for STM is treated as a 12-bit unsigned binary integer. The displacement for STMY and STMG is treated as a 20-bit signed binary integer.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (store, operand 2)
- Operation (STMY, if the long-displacement facility is not installed)

Programming Note: An example of the use of the STORE MULTIPLE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

STORE MULTIPLE HIGH

```
STMH R1,R3,D2(B2) [RSY-a]

'EB' R1 R3 B2 DL2 DH2 '26'
0 8 12 16 20 32 40 47
```

The contents of the high-order halves, bit positions 0-31, of the set of general registers starting with general register R1 and ending with general register R3 are placed in the storage area beginning at the location designated by the second-operand address and continuing through as many locations as needed, that is, the contents of bit positions 0-31 are stored in successive four-byte fields beginning at the second-operand address. Bits 32-63 of the registers are ignored.

The general registers are stored in the ascending order of their register numbers, starting with general register R1, and continuing up to and including general register R15, with general register 0 following general register 15.
**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 2)

**Programming Note:** All combinations of register numbers specified by \( R_1 \) and \( R_3 \) are valid. When the register numbers are equal, only four bytes are transmitted. When the number specified by \( R_3 \) is less than the number specified by \( R_1 \), the register numbers wrap around from 15 to 0.

---

**STORE ON CONDITION**

\[
\text{STOC} \quad R_1, D_2(B_2), M_3 \quad [\text{RSY-b}]
\]

The first operand is placed unchanged at the second-operand location if the condition code has one of the values specified by \( M_3 \); otherwise, the second operand remains unchanged.

For STOC and STOCFH, the first and second operands are 32 bits, and for STOCG, the first and second operands are 64 bits. For STOC, the first operand is in bits 32-63 of general register \( R_1 \), and bits 0-31 of the register are ignored. For STOCFH, the first operand is in bits 0-31 of general register \( R_1 \), and bits 32-63 of the register are ignored.

The M₃ field is used as a four-bit mask. The four condition codes (0, 1, 2, and 3) correspond, left to right, with the four bits of the mask, as follows:

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Mask Position Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
</tr>
<tr>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
</tr>
</tbody>
</table>

The current condition code is used to select the corresponding mask bit. If the mask bit selected by the condition code is one, the store is performed. If the mask bit selected is zero, the store is not performed.

The displacement is treated as a 20-bit signed binary integer.

When the condition specified by the M₃ field is not met (that is, store operation is not performed), it is model dependent whether any or all of the following occur for the second operand: (a) an access exception is recognized, (b) the change bit is set, or (c) a PER storage-alteration or zero-address-detection event is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 2)
- Operation (if the load/store-on-condition facility 1 is not installed; STOCFH, if the load/store-on-condition facility 2 is not installed)

**Programming Notes:**

1. When the M₃ field contain all zeros and no exception condition exists, the instruction acts as a NOP. When the M₃ field contains all ones and no exception condition exists, the store operation is always performed. However, these are not the preferred means of implementing a NOP or unconditional store, respectively.

2. When the condition specified by the M₃ field is not met, it is model dependent whether the second operand is brought into the cache.

3. STORE ON CONDITION provides a function similar to that of a separate BRANCH ON CONDITION instruction followed by a STORE instruc-
tion, except that STORE ON CONDITION does not provide an index register. For example, assuming the storage location is accessible, the following two instruction sequences are equivalent.

<table>
<thead>
<tr>
<th>STORE REVERSED</th>
<th>BC</th>
<th>SKIP</th>
</tr>
</thead>
<tbody>
<tr>
<td>STOCG 15,256(7,8)</td>
<td>STG 15,256(0,7)</td>
<td>SKIP DS 0H</td>
</tr>
</tbody>
</table>

On models that implement predictive branching, the combination of the BRANCH ON CONDITION and STORE instructions may perform somewhat better than the STORE ON CONDITION instruction when the CPU is able to successfully predict the branch condition. However, on models where the CPU is not able to successfully predict the branch condition, such as when the condition is more random, the STORE ON CONDITION instruction may provide significant performance improvement.

4. See programming note 4 on page 7-240 for details on extended mnemonics for the instructions of the load/store-on-condition facilities.

**STORE PAIR TO QUADWORD**

<table>
<thead>
<tr>
<th>STORE PAIR TO QUADWORD</th>
<th>STPQ R1,D2(X2,B2)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘E3’</td>
<td>R1</td>
<td>X2</td>
</tr>
</tbody>
</table>

The quadword first operand is stored at the second-operand location. The store at the second-operand location appears to be quadword concurrent as observed by other CPUs. The left doubleword of the first operand is in general register R1, and the right doubleword is in general register R1 + 1.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register. The second operand must be designated on a quadword boundary. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 2)
- Specification
- Transaction constraint

**Programming Notes:**

1. The STORE MULTIPLE (STM or STMG) instruction does not necessarily provide quadword-concurrent access.

2. The performance of STORE PAIR TO QUADWORD on some models may be significantly slower than that of STORE MULTIPLE (STMG). Unless quadword consistency is required, STMG should be used instead of STPQ.

**STORE REVERSED**

<table>
<thead>
<tr>
<th>STORE REVERSED</th>
<th>STRVH R1,D2(X2,B2)</th>
<th>STG R1,D2(X2,B2)</th>
<th>STVG R1,D2(X2,B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘E3’</td>
<td>R1</td>
<td>X2</td>
<td>B2</td>
</tr>
<tr>
<td>‘E3’</td>
<td>R1</td>
<td>X2</td>
<td>B2</td>
</tr>
<tr>
<td>‘E3’</td>
<td>R1</td>
<td>X2</td>
<td>B2</td>
</tr>
</tbody>
</table>

The first operand is placed at the second-operand location with the left-to-right sequence of the bytes reversed.

For STORE REVERSED (STRVH), the first operand is two bytes in bit positions 48-63 of general register R1. For STORE REVERSED (STRV), the first operand is four bytes in bit positions 32-63 of general register R1. For STORE REVERSED (STRVG), the first operand is eight bytes in bit positions 0-63 of general register R1.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 2)

**Programming Notes:**

1. The instruction can be used to convert two, four, or eight bytes from a “little-endian” format to a “big-endian” format, or vice versa. In the big-endian format, the bytes in a left-to-right sequence are in the order most significant to
least significant. In the little-endian format, the bytes are in the order least significant to most significant. For example, the bytes ABCD in the big-endian format are DCBA in the little-endian format.

2. The storage-operand references of STORE REVERSED may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

**SUBTRACT**

*Register-and-register formats:*

SR \( R_1, R_2 \) \([RR]\)

\[
1'B' \ R_1 \ R_2
\]

SGR \( R_1, R_2 \) \([RRE]\)

\[
'B909' \ R_1 \ R_2
\]

SGFR \( R_1, R_2 \) \([RRE]\)

\[
'B919' \ R_1 \ R_2
\]

SRK \( R_1, R_2, R_3 \) \([RRF-a]\)

\[
'B9F9' \ R_3 \ R_1 \ R_2
\]

SGRK \( R_1, R_2, R_3 \) \([RRF-a]\)

\[
'B9E9' \ R_3 \ R_1 \ R_2
\]

*Register-and-storage formats:*

S \( R_1, D_2(X_2, B_2) \) \([RX-a]\)

\[
5'B' \ R_1 \ X_2 \ B_2 \ D_2
\]

SY \( R_1, D_2(X_2, B_2) \) \([RXY-a]\)

\[
'E3' \ R_1 \ X_2 \ B_2 \ DL_2 \ DH_2 \ '5B'
\]

SG \( R_1, D_2(X_2, B_2) \) \([RXY-a]\)

\[
'E3' \ R_1 \ X_2 \ B_2 \ DL_2 \ DH_2 \ '09'
\]

For S, SG, SGF, SGFR, SGR, SR, and SY, the second operand is subtracted from the first operand, and the difference is placed at the first-operand location. For SGRK and SRK, the third operand is subtracted from the second operand, and the difference is placed at the first-operand location.

For S, SR, SRK, and SY, the operands and the difference are treated as 32-bit signed binary integers. For SG, SGR, and SGRK, they are treated as 64-bit signed binary integers. For SGFR and SGF, the second operand is treated as a 32-bit signed binary integer, and the first operand and the difference are treated as 64-bit signed binary integers.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

The displacement for S is treated as a 12-bit unsigned binary integer. The displacement for SY, SG, and SGF is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

0  Result zero; no overflow
1  Result less than zero; no overflow
2  Result greater than zero; no overflow
3  Overflow

**Program Exceptions:**

- Access (fetch, operand 2 of S, SY, SG, and SGF only)
- Fixed-point overflow
- Operation (SY, if the long-displacement facility is not installed; SRK, SGRK, if the distinct-operands facility is not installed)

**Programming Notes:**

1. For SR and SGR, when \( R_1 \) and \( R_2 \) designate the same register, subtracting is equivalent to clearing the register.
2. Subtracting a maximum negative number from itself gives a zero result and no overflow.

**SUBTRACT HALFWORD**

The second operand is subtracted from the first operand, and the difference is placed at the first-operand location. The second operand is two bytes in length and is treated as a 16-bit signed binary integer. The first operand and the difference are treated as 32-bit signed binary integers.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

The displacement for SH is treated as a 12-bit unsigned binary integer. The displacement for SHY is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

0 Result zero; no overflow  
1 Result less than zero; no overflow  
2 Result greater than zero; no overflow  
3 Overflow

**Program Exceptions:**

- Access (fetch, operand 2)  
- Fixed-point overflow  
- Operation (SHY, if the long-displacement facility is not installed)

**Programming Note:** The function of a SUBTRACT HALFWORD IMMEDIATE instruction, which is an instruction not provided, can be obtained by using an ADD HALFWORD IMMEDIATE instruction with a negative I_2 field.

---

**SUBTRACT HIGH**

The third operand is subtracted from the second operand, and the difference is placed at the first-operand location. The operands and the difference are treated as 32-bit signed binary integers.

The first and second operands are in bits 0-31 of general registers R_1 and R_2, respectively; bits 32-63 of general register R_1 are unchanged, and bits 32-63 of general register R_2 are ignored. For SHHHR, the third operand is in bits 0-31 of general register R_3; bits 32-63 of the register are ignored. For SHHLR, the third operand is in bits 32-63 of general register R_3; bits 0-31 of the register are ignored.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position, and condition code 3 is set. If the fixed-point-overflow mask is one, a program interruption for fixed-point overflow occurs.

**Resulting Condition Code:**

0 Result zero; no overflow  
1 Result less than zero; no overflow  
2 Result greater than zero; no overflow  
3 Overflow

**Program Exceptions:**

- Fixed-point overflow  
- Operation (if the high-word facility is not installed)

---

**SUBTRACT LOGICAL**

Register-and-register formats:

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Registers</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SLR R_1 R_2</td>
<td>[RR]</td>
<td>SUBTRACT LOGICAL</td>
</tr>
</tbody>
</table>
For SUBTRACT LOGICAL (SL, SLR, SLRK, and SLY) and for SUBTRACT LOGICAL IMMEDIATE (SLFI), the operands and the difference are treated as 32-bit unsigned binary integers. For SUBTRACT LOGICAL (SLG, SLGR, and SLGRK), they are treated as 64-bit unsigned binary integers. For SUBTRACT LOGICAL (SLGFR, SLGF) and for SUBTRACT LOGICAL IMMEDIATE (SLGFI), the second operand is treated as a 32-bit unsigned binary integer, and the first operand and the difference are treated as 64-bit unsigned binary integers.

The displacement for SL is treated as a 12-bit unsigned binary integer. The displacement for SLY, SLG, and SLGF is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

- 0 --
- 1 Result not zero; borrow
- 2 Result zero; no borrow
- 3 Result not zero; no borrow

**Program Exceptions:**

- Access (fetch, operand 2 of SL, SLY, SLG, and SLGF only)
- Operation (SLY, if the long-displacement facility is not installed; SLFI and SLGFI, if the extended-immediate facility is not installed; SLRK and SLGRK, if the distinct-operands facility is not installed)

**Programming Notes:**

1. Logical subtraction is performed by adding the one’s complement of the second operand and a value of one to the first operand. The use of the one’s complement and the value of one instead of the two’s complement of the second operand results in a carry when the second operand is zero.

2. SUBTRACT LOGICAL differs from SUBTRACT only in the meaning of the condition code and in the absence of the interruption for overflow.
3. A zero difference is always accompanied by a carry out of bit position 0 for 64-bit results or bit position 32 for 32-bit results, and, therefore, no borrow.

4. The condition-code setting for SUBTRACT LOGICAL can also be interpreted as indicating the presence or absence of a carry, as follows:

   1. Result not zero; no carry
   2. Result zero; carry
   3. Result not zero; carry

**SUBTRACT LOGICAL HIGH**

<table>
<thead>
<tr>
<th>SLHHHR</th>
<th>R1,R2,R3</th>
<th>[RRF-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B9CB'</td>
<td>R3 /// R1 R2</td>
<td></td>
</tr>
<tr>
<td>0 16 20 24 28 31</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SLHHLR</th>
<th>R1,R2,R3</th>
<th>[RRF-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B9DB'</td>
<td>R3 /// R1 R2</td>
<td></td>
</tr>
<tr>
<td>0 16 20 24 28 31</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The third operand is subtracted from the second operand, and the difference is placed at the first-operand location. The operands and the difference are treated as 32-bit unsigned binary integers.

The first and second operands are in bits 0-31 of general registers R1 and R2, respectively; bits 32-63 of general register R1 are unchanged, and bits 32-63 of general register R2 are ignored. For SLHHHR, the third operand is in bits 0-31 of general register R3; bits 32-63 of the register are ignored. For SLHHLR, the third operand is in bits 32-63 of general register R3; bits 0-31 of the register are ignored.

**Resulting Condition Code:**

0  --
1  Result not zero; borrow
2  Result zero; no borrow
3  Result not zero; no borrow

**Program Exceptions:**

- Operation (if the high-word facility is not installed)

**SUBTRACT LOGICAL WITH BORROW**

**Register-and-register formats:**

<table>
<thead>
<tr>
<th>SLBR</th>
<th>R1,R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B999'</td>
<td>R1,R2</td>
<td></td>
</tr>
<tr>
<td>0 16 20 24 28 31</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SLBGR</th>
<th>R1,R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B999'</td>
<td>R1,R2</td>
<td></td>
</tr>
<tr>
<td>0 16 20 24 28 31</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Register-and-storage formats:**

<table>
<thead>
<tr>
<th>SLB</th>
<th>R1,D(X2,B2)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td>R1 X2 B2 DL2 DH2 '99'</td>
<td></td>
</tr>
<tr>
<td>0 8 12 16 20 32 40 47</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SLBG</th>
<th>R1,D(X2,B2)</th>
<th>[RXY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td>R1 X2 B2 DL2 DH2 '89'</td>
<td></td>
</tr>
<tr>
<td>0 8 12 16 20 32 40 47</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The second operand and the borrow are subtracted from the first operand, and the difference is placed at the first-operand location. For SUBTRACT LOGICAL WITH BORROW (SLBR, SLB), the operands, the borrow, and the difference are treated as 32-bit unsigned binary integers. For SUBTRACT LOGICAL WITH BORROW (SLBGR, SLBG), they are treated as 64-bit unsigned binary integers.

**Resulting Condition Code:**

0  Result zero; borrow
1  Result not zero; borrow
2  Result zero; no borrow
3  Result not zero; no borrow

**Program Exceptions:**

- Access (fetch, operand 2 of SLB and SLBG only)

**Programming Notes:**

1. A borrow is represented by a zero value of bit 18 of the current PSW. Bit 18 is the leftmost bit of the two-bit condition code in the PSW. Bit 18 is set to zero by an execution of a SUBTRACT LOGICAL or SUBTRACT LOGICAL WITH BOR-
ROW instruction that produces a borrow into the leftmost bit position of the 32-bit or 64-bit result.

2. Logical subtraction with borrow is performed by adding the one's complement of the second operand and bit 18 of the current PSW to the first operand. Therefore, when bit 18 is one, indicating no borrow, the addition is the same as for SUBTRACT LOGICAL.

3. Condition code zero is set for SUBTRACT LOGICAL WITH BORROW (SLBR, SLB), when the maximum 32-bit unsigned binary integer, \(2^{32} - 1\), is subtracted from zero when PSW bit 18 indicates a borrow. For SUBTRACT LOGICAL WITH BORROW (SLBGR, SLBG) condition code zero is set when the maximum 64-bit unsigned binary integer, \(2^{64} - 1\), is subtracted from zero when PSW bit 18 indicates a borrow.

4. SUBTRACT and SUBTRACT LOGICAL may provide better performance than SUBTRACT LOGICAL WITH BORROW, depending on the model.

**SUPERVISOR CALL**

SVC I [I]

<table>
<thead>
<tr>
<th>0A</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
</tr>
</tbody>
</table>

The instruction causes a supervisor-call interruption, with the I field of the instruction providing the rightmost byte of the interruption code.

Bits 8-15 of the instruction, with eight zeros appended on the left, are placed in the supervisor-call interruption code that is stored in the course of the interruption. See “Supervisor-Call Interruption” on page 6-54.

A serialization and checkpoint-synchronization function is performed.

**Condition Code:** The code remains unchanged and is saved as part of the old PSW. A new condition code is loaded as part of the supervisor-call interruption.

**Program Exceptions:**
- Transaction constraint

**TEST ADDRESSING MODE**

TAM [E]

<table>
<thead>
<tr>
<th>010B</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 15</td>
</tr>
</tbody>
</table>

The extended-addressing-mode bit and basic-addressing-mode bit, bits 31 and 32 of the current PSW, respectively, are tested, and the result is indicated in the condition code.

**Resulting Condition Code:**

| 0 | PSW bits 31 and 32 zeros (indicating 24-bit addressing mode) |
| 1 | PSW bit 31 zero and bit 32 one (indicating 31-bit addressing mode) |
| 2 | -- |
| 3 | PSW bits 31 and 32 ones (indicating 64-bit addressing mode) |

**Program Exceptions:**
- Transaction constraint

**Programming Note:** The case when PSW bit 31 is one and bit 32 is zero causes an early PSW specification exception to be recognized.

**TEST AND SET**

TS D2(B2) [S]

<table>
<thead>
<tr>
<th>'93'</th>
<th>/ / / / / / / /</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 16 20 31</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The leftmost bit (bit position 0) of the byte located at the second-operand address is used to set the condition code, and then the byte is set to all ones.

Bits 8-15 of the instruction are ignored.

The byte in storage is set to all ones as it is fetched for the testing of bit 0. This update appears to be an interlocked-update reference as observed by other CPUs.

A serialization function is performed before the byte is fetched and again after the storing of all ones.
**Resulting Condition Code:**

0  Leftmost bit zero  
1  Leftmost bit one  
2  --  
3  --  

**Program Exceptions:**

- Access (fetch and store, operand 2)  
- Transaction constraint

**Programming Notes:**

1. TEST AND SET may be used for controlled sharing of a common storage area by programs operating on different CPUs. This instruction is provided primarily for compatibility with programs written for System/360. The instructions COMPARE AND SWAP and COMPARE DOUBLE AND SWAP provide functions which are more suitable for sharing among programs on a single CPU or for programs that may be interrupted. See the description of these instructions and the associated programming notes for details.

2. TEST AND SET does not interlock against storage accesses by channel programs. Therefore, the instruction should not be used to update a location into which a channel program may store, since the channel-program data may be lost.

**TEST UNDER MASK (TEST UNDER MASK HIGH, TEST UNDER MASK LOW)**

<table>
<thead>
<tr>
<th>TM</th>
<th>D_{i}(B_{1}), I_{2} [SI]</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>'91'</td>
<td>I_{2} B_{1} D_{1}</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TMY</th>
<th>D_{i}(B_{1}), I_{2} [SI/Y]</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>'EB'</td>
<td>I_{2} B_{1} DL_{1} DH_{1} '51'</td>
<td></td>
</tr>
</tbody>
</table>

A mask is used to select bits of the first operand, and the result is indicated in the condition code.

TEST UNDER MASK is a new name of, and TMLH and TMLL are new mnemonics for, the ESA/390 instructions TEST UNDER MASK HIGH (TMH) and TEST UNDER MASK LOW (TML), respectively.

In TEST UNDER MASK (TM, TMY), the byte of immediate data, I_{2}, is used as an eight-bit mask. The bits of the mask are made to correspond one for one with the bits of the byte in storage designated by the first-operand address.

A mask bit of one indicates that the storage bit is to be tested. When the mask bit is zero, the storage bit is ignored. When all storage bits thus selected are zero, condition code 0 is set. Condition code 0 is also set when the mask is all zeros. When the selected bits are all ones, condition code 3 is set; otherwise, condition code 1 is set.

Access exceptions associated with the storage operand are recognized for one byte even when the mask is all zeros.

In TEST UNDER MASK (TMHH, TMHL, TMLH, TMLL), The contents of the I_{2} field are used as a 16-bit mask. For each instruction, the bits of the
A mask bit of one indicates that the first-operand bit is to be tested. When the mask bit is zero, the first-operand bit is ignored. When all first-operand bits thus selected are zero, condition code 0 is set. Condition code 0 is also set when the mask is all zeros. When the selected bits are mixed zeros and ones, condition code 1 is set if the leftmost selected bit is zero, or condition code 2 is set if the leftmost selected bit is one. When the selected bits are all ones, condition code 3 is set.

The displacement for TM is treated as a 12-bit unsigned binary integer. The displacement for TMY is treated as a 20-bit signed binary integer.

**Resulting Condition Code:**

0  Selected bits all zeros; or mask bits all zeros
1  Selected bits mixed zeros and ones (TM and TMY only)
1  Selected bits mixed zeros and ones, and leftmost is zero (TMHH, TMHL, TMLH, TMLL)
2  -- (TM and TMY only)
2  Selected bits mixed zeros and ones, and leftmost is one (TMHH, TMHL, TMLH, TMLL)
3  Selected bits all ones

**Program Exceptions:**

- Access (fetch, operand 1, TM and TMY only)
- Operation (TMY, if the long-displacement facility is not installed)

**Programming Notes:**

1. An example of the use of the TEST UNDER MASK (TM) instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. When the mask for TMHH, TMHL, TMLH, or TMLL selects exactly two bits, the two selected bits effectively are loaded into the condition code.

**TRANSACTION ABORT**

**Instruction Bits Tested**

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Bits Tested</th>
</tr>
</thead>
<tbody>
<tr>
<td>TMHH</td>
<td>0-15</td>
</tr>
<tr>
<td>TMHL</td>
<td>16-31</td>
</tr>
<tr>
<td>TMLH (or TMH)</td>
<td>32-47</td>
</tr>
<tr>
<td>TMLL (or TML)</td>
<td>48-63</td>
</tr>
</tbody>
</table>

If the CPU is in the nonconstrained transactional-execution mode, the transaction is aborted.

The second-operand address is not used to address data; instead, the address specified by the $B_2$ and $D_2$ fields forms the transaction abort code which is placed in the transaction diagnostic block during abort processing. Address computation for the second-operand address follows the rules of address arithmetic; in the 24-bit addressing mode, bits 0-39 are set to zeros; in the 31-bit addressing mode, bits 0-32 are set to zeros.

Aborting of a transaction by the TABORT instruction consists of performing steps 1-7 of the section “Transaction Abort Processing” on page 5-103. The condition code in the transaction-abort PSW is set to either 2 or 3, depending on whether bit 63 of the second-operand address is zero or one, respectively.

A serialization function is implicitly performed by the abort processing.

When TRANSACTION ABORT is the target of an execute-type instruction, the operation is suppressed and an execute exception is recognized.

A specification exception is recognized and the operation is suppressed if the second-operand address is between 0 and 255.

A special-operation exception is recognized and the operation is suppressed if the CPU is not in the transactional-execution mode at the beginning of the instruction.

If the CPU is in the constrained transactional-execution mode, a transaction-constraint program exception condition is recognized.

**Condition Code:** The code remains unchanged. However, the condition code of the transaction-abort PSW will be set by the subsequent transaction-abort processing.
Program Exceptions:

- Execute
- Operation (transactional-execution facility not installed)
- Special-operation
- Specification
- Transaction constraint

Programming Notes:

1. If the transactional-execution control, bit 8 of control register 0, is zero, the CPU cannot be in the transactional-execution mode; Attempted execution of a TRANSACTION ABORT in this case results in a special-operation exception.

2. Abort codes 0-255 are reserved for transactions that are implicitly aborted by the CPU. See “Transaction Abort Conditions” on page 5-100 for details.

3. Program interruptions are subject to the effective program-interruption filtering control.

4. Execution of TABORT may result in significant performance degradation, potentially causing high contention which, in turn, can lead to other abort conditions.

5. Following the TABORT instruction, program execution continues at the instruction designated by the transaction-abort PSW.

 TRANSACTION BEGIN (TBEGIN)

<table>
<thead>
<tr>
<th>TBEGIN</th>
<th>D1(B1)</th>
<th>I2</th>
<th>[SIL]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E560'</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Execution of the TRANSACTION BEGIN (TBEGIN) instruction causes the CPU either to enter or to remain in the nonconstrained transactional-execution mode.

When the B1 field is nonzero, the following applies:

- When the transaction nesting depth is initially zero, the first-operand address designates the location of the 256-byte transaction diagnostic block, called the TBEGIN-specified TDB, into which various diagnostic information may be stored if the transaction is aborted (see “Transaction Diagnostic Block (TDB)” on page 5-94). When the CPU is in the primary-space mode or access-register mode, the first-operand address designates a location in the primary address space. When the CPU is in the secondary-space or home-space mode, the first-operand address designates a location in the secondary or home address space, respectively. When DAT is off, the TDBA designates a location in real storage.

- Store accessibility to the first operand is determined. If accessible, the logical address of the operand is placed into the transaction-diagnostic-block address (TDBA), and the TDBA is valid.

When the B1 field is zero, no access exceptions are detected for the first operand, and, for the outermost TBEGIN instruction, the TDBA is invalid.

The I2 field contains various controls for the instruction and has the following format:

```
GRSM / / / A FC PI
```

The bits of the I2 field are defined as follows:

**General Register Save Mask (GRSM):** Bits 0-7 of the I2 field contain the general register save mask (GRSM). Each bit of the GRSM represents an even-odd pair of general registers, where bit 0 represents registers 0 and 1, bit 1 represents registers 2 and 3, and so forth. When a bit in the GRSM of the outermost TBEGIN instruction is zero, the corresponding register pair is not saved. When a bit in the GRSM of the outermost TBEGIN instruction is one, the corresponding register pair is saved in a model-dependent location that is not directly accessible by the program.

If the transaction aborts, saved register pairs are restored to their contents when the outermost TBEGIN instruction was executed. The contents of all other (unsaved) general registers are not restored when a transaction aborts.

The general register save mask is ignored on all TBEGINs except for the outermost one.
**Allow AR Modification (A):** The A control, bit 12 of the I₂ field, controls whether the transaction is allowed to modify an access register. The effective allow-AR-modification control is the logical AND of the A control in the TBEGIN instruction for the current nesting level and for all outer levels.

If the effective A control is zero, the transaction will be aborted with abort code 11 (restricted instruction) if an attempt is made to modify any access register. If the effective A control is one, the transaction will not be aborted if an access register is modified (absent of any other abort condition).

**Allow Floating-Point Operation (F):** The F control, bit 13 of the I₂ field, controls whether the transaction is allowed to execute any floating-point instruction (that is, any instruction defined in Chapters 9, 18, 19, or 20) or any vector instruction (that is, any instruction defined in Chapters 21, 22, 23, or 24). The effective allow-floating-point-operation control is the logical AND of the F control in the TBEGIN instruction for the current nesting level and for all outer levels.

If the effective F control is zero, then (a) the transaction will be aborted with abort code 11 (restricted instruction) if an attempt is made to execute a floating-point or vector instruction, and (b) the data-exception code (DXC) in byte 2 of the floating-point control register (FPCR) will not be set by any data-exception program-exception condition. If the effective F control is one, then (a) the transaction will not be aborted if an attempt is made to execute a floating-point or vector instruction (absent any other abort condition), and (b) the DXC or VXC in the FPCR may be set by a data-exception or vector-exception program-exception condition.

**Program-Interuption-Filtering Control (PIFC):**

Bits 14-15 of the I₂ field are the program-interuption-filtering control (PIFC). The PIFC controls whether certain classes of program-exception conditions that occur while the CPU is in the transactional-execution mode result in an interruption. See “Program-Interuption Filtering on a Transaction Abort” on page 5-104 for a description of these classes.

The effective PIFC is the highest value of the PIFC in the TBEGIN instruction for the current nesting level and for all outer levels. When the effective PIFC is zero, all program-exception conditions result in an interruption. When the effective PIFC is one, program-exception conditions having a transactional-execution class of 1 and 2 result in an interruption. When the effective PIFC is two, program-exception conditions having a transactional-execution class of 1 result in an interruption. A PIFC of 3 is reserved.

Bits 8-11 of the I₂ field (bits 40-43 of the instruction) are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.

**TRANSACTION BEGIN (TBEGIN) Processing**

Execution of the TRANSACTION BEGIN (TBEGIN) instruction consists of the following steps: Note, exception checking does not necessarily need to occur in the order listed below. See Figure 7-307 on page 7-348 for the precise ordering requirements for exception checking.

1. A serialization function is performed.
2. A special-operation exception is recognized and the operation is suppressed if the transactional-execution control, bit 8 of control register 0, is zero.
3. A specification exception is recognized and the operation is suppressed if either of the following is true.
   a. The program-interuption-filtering control, bits 14-15 of I₂ field of the instruction, contains the value 3.
   b. The first-operand address does not designate a doubleword boundary. It is model dependent whether a specification exception is recognized when the first-operand address does not designate a doubleword boundary if either the B₁ field is zero or the transaction-nesting depth is nonzero.
4. If the CPU is in the constrained transactional-execution mode, then a transaction-constraint-exception program exception is recognized and the operation is suppressed.
5. When the B₁ field is nonzero, the following applies:
   - If the CPU is not in the transactional-execution mode (that is, the transaction nesting depth is zero), then the following occurs:
     - Store accessibility to the first operand is determined. If the first operand cannot
be accessed for stores, then an access exception is recognized and the operation is either nullified, suppressed, or terminated, depending on the specific access-exception condition.

- Any PER storage-alteration or zero-address-detection event for the first operand is recognized.

- If the CPU is already in the transactional-execution mode, it is unpredictable whether (a) store accessibility to the first operand is determined, and (b) PER storage-alteration or zero-address-detection events are detected for the first operand.

If the B₁ field is zero, then the first operand is not accessed.

6. If the transaction nesting depth, when incremented by one, would exceed a model-dependent maximum transaction nesting depth, the transaction is aborted with abort code 13. See “Transaction Abort Processing” on page 5-103 for details on the handling of a transaction abort.

7. If the CPU is not in the transactional-execution mode, the following occurs:

   a. If the B₁ field is nonzero, the first-operand address is placed in the transaction-diagnostic-block address, and the transaction-diagnostic-block address is valid. If the B₁ field is zero, the transaction-diagnostic-block address is invalid.

   b. The transaction-abort PSW is set from the contents of the current PSW. The instruction address of the transaction-abort PSW designates the next-sequential instruction (that is, the instruction following the outermost TBEGIN).

8. An effective value of the allow-AR-modification (A) control, bit 12 of the I₂ field of the instruction, is determined. The effective A control is the logical AND of the A control in the TBEGIN instruction for the current level and for all outer levels.

9. An effective value of the allow-floating-point-operation (F) control, bit 13 of the I₂ field of the instruction, is determined. The effective F control is the logical AND of the F control in the TBEGIN instruction for the current level and for all outer levels.

10. An effective value of the program-interruption-filtering control (PIFC), bits 14-15 of the I₂ field of the instruction, is determined. The effective PIFC value is highest value in the TBEGIN instruction for the current level and for all outer levels.

11. If the CPU is not in the transactional-execution mode, the contents of the general register pairs designated by the general-register save mask are saved in a model-dependent location that is not directly accessible by the program.

12. A value of one is added to the transaction nesting depth, and the instruction completes by setting condition code 0. If the transaction nesting depth transitions from zero to one, the CPU enters the nonconstrained transactional-execution mode; otherwise, the CPU remains in the nonconstrained transactional-execution mode.

When TBEGIN is the target of an execute-type instruction, the operation is suppressed and an execute exception is recognized.

See “Event-Suppression Control (ES)” on page 4-25 for additional details on the recognition of PER instruction-fetching events during the execution of TRANSACTION BEGIN.

**Resulting Condition Code:**

0 Transaction initiation successful
1 – (see programming notes 3 and 4)
2 – (see programming notes 3 and 4)
3 – (see programming notes 3 and 4)

**Program Exceptions:**

- Access (store, first operand)
- Execute
- Operation (transactional-execution facility not installed)
- Special operation
- Specification
- Transaction constraint
Programming Notes:

1. When the $B_1$ field is nonzero, the following applies:
   
   • An accessible transaction diagnostic block (TDB) must be provided when an outermost transaction is initiated — even if the transaction never aborts.
   
   • Since it is unpredictable whether accessibility of the TDB is tested for nested transactions, an accessible TDB should be provided for any nested TBEGIN instruction.
   
   • The performance of any TBEGIN in which the $B_1$ field is nonzero, and the performance of any abort processing that occurs for a transaction that was initiated by an outermost TBEGIN in which the $B_1$ field is nonzero, may be slower than when the $B_1$ field is zero.

2. Registers designated to be saved by the general register save mask are only restored if the transaction aborts, not when the transaction ends normally by means of TRANSACTION END. Only the registers designated by the GRSM of the outermost TRANSACTION BEGIN instruction are restored on abort.

   The $I_2$ field should designate all register pairs that provide input values that are changed by the transaction. Thus, if the transaction is aborted, the input register values will be restored to their original contents when the abort handler is entered.

3. The TRANSACTION BEGIN (TBEGIN) instruction is expected to be followed by a conditional branch instruction that will determine whether the transaction was successfully initiated. See programming note 3 on page 5-103 for a complete explanation of each condition code.

4. If a transaction is aborted due to conditions that do not result in an interruption, the instruction designated by the transaction-abort PSW receives control (that is, the instruction following the outermost TRANSACTION BEGIN (TBEGIN)). In addition to the condition code set by the TRANSACTION BEGIN (TBEGIN) instruction, condition codes 1-3 are also set when a transaction aborts.

   Therefore, the instruction sequence following the outermost TRANSACTION BEGIN (TBEGIN) instruction should be able to accommodate all four condition codes, even though the TBEGIN instruction only sets code 0. See the explanation of abort condition codes in programming note 3 on page 5-103.

5. On most models, improved performance may be realized, both on TRANSACTION BEGIN and when a transaction aborts, by specifying the minimum number of registers needed to be saved and restored in the general-register save mask.

6. While in the nonconstrained transactional-execution mode, a program may call a service function which may alter access registers, floating-point registers (including the floating-point control register), or vector registers. Although such a service routine may save the altered registers on entry and restore them at exit, the transaction may be aborted prior to normal exit of the routine. If the calling program makes no provision for preserving these registers while the CPU is in the nonconstrained transactional-execution mode, it may not be able to tolerate the service function’s alteration of the registers.

To prevent inadvertent alteration of access registers while in the nonconstrained transactional-execution mode, the program can set the allow-AR-modification control, bit 12 of the $I_2$ field of the TRANSACTION BEGIN instruction, to zero. Similarly, to prevent the inadvertent alteration of the floating-point registers or vector registers, the program can set the allow-floating-point-opera-
tion control, bit 13 of the $I_2$ field of the TBEGIN instruction, to zero.

7. Program-interruption conditions recognized during the execution of TRANSACTION BEGIN (TBEGIN) instruction are subject to the effective program-interruption filtering control set by any outer TBEGIN instructions. Program-interruption conditions recognized during the execution of the outermost TBEGIN instruction are not subject to filtering.

8. In order to update multiple storage locations in a serialized manner, conventional code sequences may employ a lock word (semaphore). If (a) transactional execution is used to implement updates of multiple storage locations, (b) the program also provides a “fall-back” path to be invoked if the transaction aborts, and (c) the fall-back path employs a lock word, then the transactional-execution path should also test for the availability of the lock, and, if the lock is unavailable, end the transaction by means of the TRANSACTION END instruction and branch to the fall-back path. This ensures consistent access to the serialized resources, regardless of whether they are updated transactionally.

Alternatively, the program could abort if the lock is unavailable, however the abort processing may be significantly slower than simply ending the transaction via TEND.

9. If the effective program-interruption filtering control (PIFC) is greater than zero, the CPU filters most data-exception program interruptions. If the effective allow-floating-point-operation (F) control is zero, the data-exception code (DXC) will not be set in the floating-point control register as a result of an abort due to a data-exception program-exception condition. In this scenario (filtering applies and the effective F control is zero), the only location in which the DXC can be inspected is in the TBEGIN-specified TDB. If the program’s abort handler needs to inspect the DXC in such a situation, general register $B_1$ should be nonzero, such that a valid transaction-diagnostic-block address (TDBA) is set.

10. If a PER storage-alteration or zero-address-detection condition exists for the TBEGIN-specified TDB of the outermost TBEGIN instruction, and PER event suppression does not apply, the PER event will be recognized during the execution of the instruction, thus causing the transac-

**TRANSACTION BEGIN (TBEGINC)**

<table>
<thead>
<tr>
<th>$E561'$</th>
<th>$B_1$</th>
<th>$D_1$</th>
<th>$I_2$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
<td>32</td>
</tr>
</tbody>
</table>

Execution of the TRANSACTION BEGIN (TBEGINC) instruction causes the CPU to enter the constrained transactional-execution mode or remain in the non-constrained transactional-execution mode.

The first-operand address is not used to access storage. The $B_1$ field, bits 16-19 of the instruction, must contain zeros; otherwise, a specification exception is recognized.

The $I_2$ field contains various controls for the instruction and has the following format:

The bits of the $I_2$ field are defined as follows:

**General Register Save Mask (GRSM):** Bits 0-7 of the $I_2$ field contain the general register save mask (GRSM). Each bit of the GRSM represents an even-odd pair of general registers, where bit 0 represents registers 0 and 1, bit 1 represents registers 2 and 3, and so forth. When a bit in the GRSM is zero, the corresponding register pair is not saved. When a bit in the GRSM is one, the corresponding register pair is saved in a model-dependent location that is not directly accessible by the program.

If the transaction aborts, saved register pairs are restored to their contents when the outermost TRANSACTION BEGIN instruction was executed. The contents of all other (unsaved) general registers are not restored when a constrained transaction aborts.

When TBEGINC is used to continue execution in the nonconstrained transactional-execution mode, the general register save mask is ignored.

**Allow AR Modification (A):** The A control, bit 12 of the $I_2$ field, controls whether the transaction is allowed to modify an access register. The effective...
allow-AR-modification control is the logical AND of the A control in the TBEGINC instruction for the current nesting level and for any outer TRANSACTION BEGIN or TBEGINC instructions.

If the effective A control is zero, the transaction will be aborted with abort code 11 (restricted instruction) if an attempt is made to modify any access register. If the effective A control is one, the transaction will not be aborted if an access register is modified (absent of any other abort condition).

Bits 8-11 and 13-15 of the I2 field (bits 40-43 and 45-47 of the instruction) are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.

 TRANSACTION BEGIN (TBEGINC) Processing

Execution of the TRANSACTION BEGIN (TBEGINC) instruction consists of the following steps: Note, exception checking does not necessarily need to occur in the order listed below. See Figure 7-308 on page 7-351 for the precise ordering requirements for exception checking.

1. A serialization function is performed.
2. A special-operation exception is recognized and the operation is suppressed if the transactional-execution control, bit 8 of control register 0, is zero.
3. A specification exception is recognized and the operation is suppressed if the B1 field, bits 16-19 of the instruction, is nonzero.
4. If the CPU is already in the constrained transactional-execution mode, then a transaction-constraint-exception program exception is recognized and the operation is suppressed.
5. If the transaction nesting depth, when incremented by one, would exceed a model-dependent maximum transaction nesting depth, the transaction is aborted with abort code 13. See “Transaction Abort Processing” on page 5-103 for details on the handling of a transaction abort.
6. If the transaction nesting depth is zero, then the following is performed:
   a. The transaction-diagnostic-block address is considered to be invalid.
   b. The transaction-abort PSW is set from the contents of the current PSW, except that the instruction address of the transaction-abort PSW designates the TBEGINC instruction (rather than the next-sequential instruction).
   c. The contents of the general register pairs designated by the general-register save mask are saved in a model-dependent location that is not directly accessible by the program.
7. An effective value of the allow-AR-modification (A) control, bit 12 of the I2 field of the instruction, is determined. The effective A control is the logical AND of the A control in the TBEGINC instruction for the current level and for any outer TRANSACTION BEGIN instructions.
8. If the transaction nesting depth is zero, then it is set to one, and the CPU enters the constrained transactional-execution mode. The effective allow-floating-point-operation and program-interruption-filtering controls (F and PIFC, respectively) are set to zero.
   If the transaction nesting depth is nonzero, then it is incremented by one, and the CPU remains in the nonconstrained transactional-execution mode. In this case, the effective value of the allow-floating-point-operation control is set to zero, and the effective value of the program-interruption-filtering control is unchanged. See “Allow Floating-Point Operation (F)” on page 7-346 and “Program-Interruption-Filtering Control (PIFC)” on page 7-346 for a description of these controls.
9. The instruction completes by setting condition code 0.

When TBEGINC is the target of an execute-type instruction, the operation is suppressed and an execute exception is recognized.

See “Event-Suppression Control (ES)” on page 4-25 for additional details on the recognition of PER instruction-fetching events during the execution of TRANSACTION BEGIN.

Resulting Condition Code:

0  Transaction initiation successful
1  –
2  –
3  –
Program Exceptions:

- Execute
- Operation (constrained transactional-execution facility not installed)
- Special operation
- Specification
- Transaction constraint

1.-7 Exceptions with the same priority as the priority of program-interruption conditions for the general case.

8.A Specification exception due to the B_1 field containing a nonzero value.

8.B Abort due to exceeding transaction nesting depth.

9 Condition code 0 due to normal completion.

Programming Notes:

1. Registers designated to be saved by the general register save mask are only restored if the transaction aborts, not when the transaction ends normally by means of TRANSACTION END. Only the registers designated by the GRSM of the outermost TRANSACTION BEGIN instruction are restored on abort.

   The I_2 field should designate all register pairs that provide input values that are changed by a constrained transaction. Thus, if the transaction is aborted, the input register values will be restored to their original contents when constrained transaction is reexecuted.

2. On most models, improved performance may be realized, both on TRANSACTION BEGIN and when a transaction aborts, by specifying the minimum number of registers needed to be saved and restored in the general-register save mask.

3. Figure 7-309 on page 7-351 illustrates the results of the TRANSACTION BEGIN instruction (both TBEGIN and TBEGINC) based on the current transaction nesting depth and, when the TND is nonzero, whether the CPU is in the non-constrained or constrained transactional-execution mode.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>TND = 0</th>
<th>TND &gt; 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>TBEGIN</td>
<td>Enter the unconstrained transactional-execution mode</td>
<td>Continue in the unconstrained transactional-execution mode</td>
</tr>
<tr>
<td>TBEGINC</td>
<td>Enter the constrained transactional-execution mode</td>
<td>Continue in the constrained transactional-execution mode</td>
</tr>
</tbody>
</table>

   Explanation:

   - CTX CPU is in the constrained transactional-execution mode
   - NTX CPU is in the nonconstrained transactional-execution mode
   - TND Transaction nesting depth at the beginning of the instruction

   Figure 7-309. Operation of TRANSACTION BEGIN based on Transaction Nesting Depth and Transactional-Execution Mode

<table>
<thead>
<tr>
<th>TRANSACTION END</th>
</tr>
</thead>
<tbody>
<tr>
<td>TEND</td>
</tr>
<tr>
<td>[S]</td>
</tr>
<tr>
<td>B2F8</td>
</tr>
<tr>
<td>00</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>31</td>
</tr>
</tbody>
</table>

   If the CPU is in the transactional-execution mode, the transaction nesting depth is decremented. If the transactional nesting depth is zero following the decrementing, all store accesses made by the transaction are committed, the CPU leaves the transactional-execution mode, and the instruction completes.

   The effective allow-floating-point-operation (F) control, allow-AR-modification (A) control, and program-interruption-filtering control (PIFC) are reset to their respective values prior to TRANSACTION BEGIN instruction that initiated the level being ended.

   If the CPU is in the transactional-execution mode at the beginning the operation, the condition code is set to 0; otherwise, the condition code is set to 2.

   A serialization function is performed at the completion of the operation.
When TRANSACTION END is the target of an execute-type instruction, the operation is suppressed and an execute exception is recognized.

A special-operation exception is recognized and the operation is suppressed if the transactional-execution control, bit 8 of control register 0, is zero.

**Resulting Condition Code:**

- 0 CPU in the transactional-execution mode at the beginning of the operation
- 1–2 CPU not in the transactional-execution mode at the beginning of the operation
- 3–

**Program Exceptions:**

- Execute
- Operation (transactional-execution facility not installed)
- Special operation

**Programming Notes:**

1. If the transactional-execution control, bit 8 of control register 0, is zero, the CPU cannot be in the transactional-execution mode. Attempted execution of a TRANSACTION END in this case results in a special-operation exception.

2. PER instruction-fetching and transaction-end events that are recognized at the completion of the outermost TRANSACTION END instruction do not result in the transaction being aborted. See “Event-Suppression Control (ES)” on page 4-25 for additional details on the recognition of PER instruction-fetching events during the execution of TRANSACTION END.

**TRANSLATE**

<table>
<thead>
<tr>
<th>TR</th>
<th>D1(B1),D1(B2)</th>
<th>[SS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'DC'</td>
<td>L</td>
<td>B1</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>16</td>
</tr>
</tbody>
</table>

The bytes of the first operand are used as eight-bit arguments to reference a list designated by the second-operand address. Each function byte selected from the list replaces the corresponding argument in the first operand.

The L field specifies the length of only the first operand.

The bytes of the first operand are selected one by one for translation, proceeding left to right. Each argument byte is added to the initial second-operand address. The addition is performed following the rules for address arithmetic, with the argument byte treated as an eight-bit unsigned binary integer and extended with zeros on the left. The sum is used as the address of the function byte, which then replaces the original argument byte.

The operation proceeds until the first-operand field is exhausted. The list is not altered unless an overlap occurs.

When the operands overlap, the result is obtained as if each result byte were stored immediately after fetching the corresponding function byte.

Access exceptions are recognized only for those bytes in the second operand which are actually required.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2; fetch and store, operand 1)
- Transaction constraint

**Programming Notes:**

1. An example of the use of the TRANSLATE instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. TRANSLATE may be used to convert data from one code to another code.

3. The instruction may also be used to rearrange data. This may be accomplished by placing a pattern in the destination area, by designating the pattern as the first operand of TRANSLATE, and by designating the data that is to be rearranged as the second operand. Each byte of the pattern contains an eight-bit number specifying the byte destined for this position. Thus, when the instruction is executed, the pattern selects the bytes of the second operand in the desired order.
4. Because each eight-bit argument byte is added to the initial second-operand address to obtain the address of a function byte, the list may contain 256 bytes. In cases where it is known that not all eight-bit argument values will occur, it is possible to reduce the size of the list.

5. Significant performance degradation is possible when the second-operand address of TRANSLATE designates a location that is less than 256 bytes to the left of a 4K-byte boundary. This is because the machine may perform a trial execution of the instruction to determine if the second operand actually crosses the boundary.

6. The fetch and subsequent store accesses to a particular byte in the first-operand field do not necessarily occur one immediately after the other. Thus, this instruction cannot be safely used to update a location in storage if the possibility exists that another CPU or a channel program may also be updating the location. An example of this effect is shown for OR (OI) in “Multiprogramming and Multiprocessing Examples” in Appendix A, “Number Representation and Instruction-Use Examples.”

7. The storage-operand references of TRANSLATE may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

**TRANSLATE AND TEST**

<table>
<thead>
<tr>
<th>TRT</th>
<th>D1(L,B1)</th>
<th>D2(B2)</th>
<th>[SS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'DD'</td>
<td>L</td>
<td>B1</td>
<td>D1</td>
</tr>
</tbody>
</table>

The bytes of the first operand are used as eight-bit arguments to select function bytes from a list designated by the second-operand address. The first nonzero function byte is inserted in general register 2, and the related argument address in general register 1.

The L field specifies the length of only the first operand.

The bytes of the first operand are selected one by one for translation, proceeding left to right. The first operand remains unchanged in storage. Calculation of the address of the function byte is performed as in the TRANSLATE instruction. The function byte retrieved from the list is inspected for a value of zero.

When the function byte is zero, the operation proceeds with the next byte of the first operand. When the first-operand field is exhausted before a nonzero function byte is encountered, the operation is completed by setting condition code 0. The contents of general registers 1 and 2 remain unchanged.

When the function byte is nonzero, the operation is completed by inserting the function byte in general register 2 and the related argument address in general register 1. This address points to the argument byte last translated. The function byte replaces bits 56-63 of general register 2, and bits 0-55 of this register remain unchanged. In the 24-bit addressing mode, the address replaces bits 40-63 of general register 1, and bits 0-39 of this register remain unchanged. In the 31-bit addressing mode, the address replaces bits 33-63 of general register 1, bit 32 of this register is set to zero, and bits 0-31 of the register remain unchanged. In the 64-bit addressing mode, the address replaces bits 0-63 of general register 1.

When the function byte is nonzero, either condition code 1 or 2 is set, depending on whether the argument byte is the rightmost byte of the first operand. Condition code 1 is set if one or more argument bytes remain to be translated. Condition code 2 is set if no more argument bytes remain.

The contents of access register 1 always remain unchanged.

Access exceptions are recognized only for those bytes in the second operand which are actually required. Access exceptions are not recognized for those bytes in the first operand which are to the right of the first byte for which a nonzero function byte is obtained.

**Resulting Condition Code:**

0 All function bytes zero
1 Nonzero function byte; first-operand field not exhausted
2 Nonzero function byte; first-operand field exhausted
3 --

**Program Exceptions:**

- Access (fetch, operands 1 and 2)
- Transaction constraint
Programming Notes:

1. An example of the use of the TRANSLATE AND TEST instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. TRANSLATE AND TEST may be used to scan the first operand for characters with special meaning. The second operand, or list, is set up with all-zero function bytes for those characters to be skipped over and with nonzero function bytes for the characters to be detected.

**TRANSLATE AND TEST EXTENDED**

```
TRTE R1(R2),M3 [RRF-c]
```

The argument characters of the first operand are used to select function codes from a function-code table designated by general register 1. For TRANSLATE AND TEST EXTENDED, the argument characters are processed in a left-to-right direction; for TRANSLATE AND TEST REVERSE EXTENDED, the argument characters are processed in a right-to-left direction. When a nonzero function code is selected, it is inserted in general register R2, the related argument address is placed in general register R1, and the first-operand length in general register R1 + 1 is decremented by the number of bytes processed. The operation proceeds until a nonzero function code is encountered, the end of the first operand is reached, or a CPU-determined number of characters have been processed, whichever occurs first. The result is indicated in the condition code.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

General register R1 + 1 contains the length of the first operand in bytes.

Operation of the instruction is subject to controls specified in the M3 field, bits 16-19 of the instruction. The M3 field has the following format:

```
AFL
```

The bits of the M field are defined as follows:

- **Argument-Character Control (A):** The A bit, bit 0 of the M3 field, controls the size of the argument characters in the first operand. When the A bit is zero, the argument characters are one byte in length. When the A bit is one, the argument characters are two bytes in length.

When the A bit is one, the first-operand length in general register R1 + 1 must specify an even number of bytes; otherwise, a specification exception is recognized.

- **Function-Code Control (F):** The F bit, bit 1 of the M3 field, controls the size of the function codes in the function-code table designated by general register 1. When the F bit is zero, a function code is one byte in length. When the F bit is one, a function code is two bytes in length.

- **Argument-Character Limit (L):** The L bit, bit 2 of the M3 field, controls whether argument characters with a value greater than 255 are used to select function codes. When the L bit is zero, argument character values are unlimited. When the L bit is one, an argument character with a value greater than 255 is not used to select a function code; rather, the function code is assumed to contain zeros.

When the A bit of the M3 field is zero, the L bit is ignored.

- **Unassigned:** Bit 3 of the M3 field is unassigned and should contain zero; otherwise, the program may not operate compatibly in the future.

Figure 7-310 summarizes the size of the function-code table based on the A, F, and L bits.

The location of the first argument character in the first operand is designated by the contents of general register R1. The location of the leftmost byte of the function-code table is designated by the contents of
The argument characters of the first operand are selected one by one for processing, proceeding in a left-to-right direction for TRANSLATE AND TEST EXTENDED, or in a right-to-left direction for TRANSLATE AND TEST REVERSE EXTENDED. Depending on the A bit of the M3 field, the argument characters are treated as either eight-bit or sixteen-bit unsigned binary integers, extended with zeros on the left.

When the F bit of the M3 field is zero, the argument character is added to the function-code-table address in general register 1 to form the address of the selected 8-bit function code. When the F bit is one, the argument character, extended on the right with a binary 0, is added to the function-code-table address in general register 1 to form the address of the selected 16-bit function code. These additions follow the rules for address arithmetic.

When both the A and L bits are one, and the value of the argument character is greater than 255, then the function code table is not accessed. The function code is assumed to contain zero in this case.

When the selected function code contains zero, or when the function code is assumed to contain zero, processing continues with the next argument character in the first operand. The operation proceeds until a nonzero function code is selected, the first-operand location is exhausted, or a CPU-determined number of first-operand bytes have been processed.

When the first-operand location is exhausted without having selected a nonzero function code, general register R1 is either incremented or decremented by the first operand length in general register R1 + 1; general register R1 + 1 is set to zero; general register R2 is set as though a function code of zero was selected; and condition code 0 is set. For TRANSLATE AND TEST EXTENDED, general register R1 is incremented by the first operand length; for TRANSLATE AND TEST REVERSE EXTENDED, general register R1 is decremented by the first operand length. In the 24-bit or 31-bit addressing mode, bits

<table>
<thead>
<tr>
<th>A bit</th>
<th>F bit</th>
<th>L bit</th>
<th>Table Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>–</td>
<td>256</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>–</td>
<td>512</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>65,536</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>131,072</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>256</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>512</td>
</tr>
</tbody>
</table>

Explanation:
– Not applicable

Figure 7-310. Function-Code Table Size

general register 1. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand location is specified by the contents of bit positions 32-63 of general register R1 + 1, and those contents are treated as a 32-bit unsigned binary integer. In the 64-bit addressing mode, the number of bytes in the first-operand location is specified by the entire contents of general register R1 + 1, and those contents are treated as a 64-bit unsigned binary integer.

The handling of the argument-character address in general register 1 is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-63 of the register constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the register constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The function-code table is treated as being on a doubleword boundary. The handling of the function-code-table address in general register 1 is dependent on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-60 of the register constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-60 of the register constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-60 constitute the address.

When a nonzero function code is selected, it is inserted into either bits 56-63 or bits 48-63 of general register R2, depending on whether the F bit of the M3 field is zero or one, respectively. In the 24-bit or 31-bit addressing mode, bits 0-31 of general register R2 are unchanged, and bits 32-55 (F=0) or 32-47 (F=1) of the register are set to zero. In the 64-bit addressing mode, bits 0-55 (F=0) or 0-47 (F=1) are set to zero.

The contents of the registers just described are shown in Figure 7-311.
0-31 of general register $R_2$ are unchanged, and bits 32-63 of the register are set to zeros; in the 64-bit addressing mode, bits 0-63 of general register $R_2$ are set to zeros.

When a nonzero function code is selected, the function code replaces bits 56-63 or bits 48-63 of general register $R_2$, depending on whether the F bit is zero or one, respectively; depending on the addressing mode, the remaining bits in general register $R_2$ are set to zeros; the address of the argument character used to select the nonzero function code is placed in general register $R_1$; general register $R_1 + 1$ is decremented by the number of first-operand bytes processed prior to selecting the nonzero function byte; and condition code 1 is set. In the 24-bit or 31-bit addressing mode, bits 0-31 of general register $R_2$ are unchanged, and bits 32-55 ($F=0$) or 32-47 ($F=1$) are set to zero; in the 64-bit addressing mode, bits 0-55 ($F=0$) or 0-47 ($F=1$) are set to zeros.

When a CPU-determined number of bytes have been processed, general register $R_1$ is either incremented or decremented by the number of bytes in the first operand that were processed, general register $R_1 + 1$ is decremented by this number, and condition code 3 is set. For TRANSLATE AND TEST EXTENDED, general register $R_1$ is incremented by the number of bytes processed; for TRANSLATE AND TEST REVERSE EXTENDED, general register $R_1$ is decre-
mented by the number of bytes processed. Condition code 3 may be set even when the first-operand location is exhausted or when the next argument character to be processed selects a nonzero function byte. In these cases, condition code 0 or 1 will be set when the instruction is executed again.

When the R₂ field designates the same register as register R₁, the updated first-operand address is placed in the register. When the R₂ field designates the same register as register R₁+1, the updated first-operand length is placed in the register.

When general register R₁ is updated in the 24-bit or 31-bit addressing mode, bits 32-39, in the 24-bit mode, or bit 32, in the 31-bit mode, may be set to zeros or may remain unchanged from their original values.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers R₁, R₁ + 1, and R₂ always remain unchanged.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.

Access exceptions for the portion of the first operand beyond the last byte processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed. When the length of the first operand is zero, no access exceptions for the first operand are recognized.

Access exceptions for any byte of the function-code table specified by general register 1 may be recognized, even if not all bytes are used.

Special Conditions

A specification exception is recognized for any of the following conditions:

1. The R₁ field designates an odd-numbered register.

2. The A bit of the M₃ field is one and the first operand length in general register R₁ + 1 is odd.

Resulting Condition Code:

0 Entire first operand processed without selecting a nonzero function code
1 Nonzero function code selected
2 --
3 CPU-determined number of bytes processed

Program Exceptions:

- Access (fetch, operand 1 and the function-code table)
- Operation (if the parsing-enhancement facility is not installed)
- Specification
- Transaction constraint

Programming Notes:

1. When condition code 3 is set, the program can simply branch back to the instruction to continue processing. The program need not determine the number of bytes that were processed.

2. The storage-operand references of TRANSLATE AND TEST EXTENDED and TRANSLATE AND TEST REVERSE EXTENDED may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

3. The following example illustrates the use of TRANSLATE AND TEST EXTENDED to parse a buffer of 16-bit Unicode argument characters for delimiters such as those used in common markup languages. Because the Unicode representation of such delimiters is in the range of 0000 - 00FF hex, a limited function-code table is used (the L bit of the M₃ field is one).

In this example, the variable BUFFER is used to hold the 16-bit characters to be parsed. If a delimiting character is not found, control passes to the label NOTFND. If a delimiting character is found, the function code placed in general register R₂ is used as an index to the branch table that
TRANSLATE AND TEST REVERSE

The bytes of the first operand are used as eight-bit arguments to select function bytes from a list designated by the second-operand address. The first-operand address designates the rightmost byte of the first operand. The first nonzero function byte is inserted in general register 2, and the related argument address in general register 1.

The L field specifies the length of only the first operand.

The bytes of the first operand are selected one by one for translation, proceeding from right to left. The first operand remains unchanged in storage. Calculation of the address of the function byte is performed as in the TRANSLATE instruction. The function byte retrieved from the list is inspected for a value of zero.

When the function byte is zero, the operation proceeds with the preceding byte of the first operand. When the first-operand field is exhausted before a nonzero function byte is encountered, the operation is completed by setting condition code 0. The contents of general registers 1 and 2 remain unchanged.

When the function byte is nonzero, the operation is completed by inserting the function byte in general register 2 and the related argument address in general register 1. This address points to the argument byte last translated. The function byte replaces bits 56-63 of general register 2, and bits 0-55 of this register remain unchanged. In the 24-bit addressing mode, the address replaces bits 40-63 of general register 1, and bits 0-39 of this register remain unchanged. In the 31-bit addressing mode, the address replaces bits 33-63 of general register 1, and bits 0-32 of this register remain unchanged. In the 64-bit addressing mode, the address replaces bits 0-63 of general register 1.

When the function byte is nonzero, either condition code 1 or 2 is set, depending on whether the argument byte is the leftmost byte of the first operand. Condition code 1 is set if one or more argument bytes remain to be translated. Condition code 2 is set if no more argument bytes remain.

Note, the branch to label NOT_FND does not result from a function-code-table entry of zeros. Rather, the branch is taken when the first operand is exhausted without selecting a nonzero function-code-table entry.

As an alternative to treating the selected function-code value as a table index (as shown in programming note 3, above), the function-code value may be used directly as a branch offset.

The performance of TRANSLATE AND TEST EXTENDED and TRANSLATE AND TEST REVERSE EXTENDED may be significantly slower if the program modifies the function-code table prior to execution of the instruction.

In the assembler syntax, the M₃ operand is considered to be optional. When the M₃ field is not coded, it is considered to contain zeros by the assembler.
The contents of access register 1 always remain unchanged.

Access exceptions can be recognized for any byte in either the first or in the second operand.

**Resulting Condition Code:**

0  All function bytes zero
1  Nonzero function byte; first-operand field not exhausted
2  Nonzero function byte; first-operand field exhausted
3  --

**Program Exceptions:**

- Access (fetch, operands 1 and 2)
- Operation (if the extended-translation facility 3 is not installed)
- Transaction constraint

**Programming Note:**

TRANSLATE AND TEST REVERSE may be used to scan the first operand for characters with special meaning. The second operand, or list, is set up with all-zero function bytes for those characters to be skipped over and with nonzero function bytes for the characters to be detected.

**TRANSLATE EXTENDED**

<table>
<thead>
<tr>
<th>TRE</th>
<th>[RRE]</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B2A5' [\|\|\</td>
<td>\</td>
<td>\] R1 R2</td>
</tr>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

The bytes of the first operand are compared to a test byte in general register 0 and, unless an equal comparison occurs, are used as eight-bit arguments to reference a 256-byte translation table designated by the second-operand address. Each function byte selected from the second operand replaces the corresponding argument in the first operand. The operation proceeds until a first-operand byte equal to the test byte is encountered, the end of the first operand is reached, or a CPU-determined number of bytes have been processed, whichever occurs first. The result is indicated in the condition code.

The \(R_1\) field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and second operand is designated by the contents of general registers \(R_1\) and \(R_2\), respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the first-operand location is specified by the contents of bit positions 32-63 of general register \(R_1 + 1\), and those contents are treated as a 32-bit unsigned binary integer. In the 64-bit addressing mode, the number of bytes in the first-operand location is specified by the entire contents of general register \(R_1 + 1\), and those contents are treated as a 64-bit unsigned binary integer.

The handling of the addresses in general registers \(R_1\) and \(R_2\) is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers \(R_1\) and \(R_2\) constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of the registers constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 constitute the address.

The test byte is in bit positions 56-63 of general register 0, and the contents of bit positions 0-55 of this register are ignored.

The contents of the registers just described are shown in Figure 7-312.

The bytes of the first operand are selected one by one for translation, proceeding left to right. Each argument byte is first compared to the test byte in general register 0. If the result is an equal comparison, the operation is completed. If the argument byte is not equal to the test byte, the argument byte is added to the initial second-operand address. The addition is performed following the rules for address arithmetic, with the argument byte treated as an eight-bit unsigned binary integer and extended with zeros on the left. The sum is used as the address of the function byte, which then replaces the original argument byte. The second operand is not altered unless an overlap occurs.

The operation proceeds until a first-operand byte equal to the test byte is encountered, the first-operand location is exhausted, or a CPU-determined number of first-operand bytes have been processed.
When the first-operand location is exhausted without finding a byte equal to the test byte, condition code 0 is set. When a first-operand byte equal to the test byte is encountered, condition code 1 is set. When a CPU-determined number of bytes have been processed, condition code 3 is set. Condition code 3 may be set even when the first-operand location is exhausted or when the next byte to be processed is equal to the test byte. In these cases, condition code 0 or 1, respectively, will be set when the instruction is executed again.

If the operation is completed with condition code 0, the contents of general register \( R_1 \) are incremented by the contents of general register \( R_1 + 1 \), and then the contents of general register \( R_1 + 1 \) are set to zero. If the operation is completed with condition code 1, the contents of general register \( R_1 + 1 \) are decremented by the number of bytes processed before the first-operand byte equal to the test byte was encountered, and the contents of general register \( R_1 \) are incremented by the same number, so that general register \( R_1 \) contains the address of the equal byte. If the operation is completed with condition code 3, the contents of general register \( R_1 + 1 \) are decremented by the number of bytes processed, and the contents of general register \( R_1 \) are incremented by the same number, so that the instruction, when reexecuted, resumes at the next byte to be processed. When general register \( R_1 \) is updated in the 24-bit or 31-bit addressing mode, bits 32-39 of it, in the 24-bit mode, or bit 32, in the 31-bit mode, may be set to zeros or may remain unchanged from their original values.

In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers \( R_1 \) and \( R_1 + 1 \) always remain unchanged.

The amount of processing that results in the setting of condition code 3 is determined by the CPU on the basis of improving system performance, and it may be a different amount each time the instruction is executed.
When the $R_2$ register is the same register as the $R_1$ or $R_1 + 1$ register, the results are unpredictable.

When $R_1$ or $R_2$ is zero, the results are unpredictable.

When the second operand overlaps the first operand, the results are unpredictable.

Access exceptions for the portion of the first operand to the right of the last byte processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last byte processed.

Access exceptions for all 256 bytes of the second operand may be recognized, even if not all bytes are used.

Access exceptions are not recognized if the $R_1$ field is odd. When the length of the first operand is zero, no access exceptions for the first operand are recognized.

**Resulting Condition Code:**

0  Entire first operand processed without finding a byte equal to the test byte
1  First-operand byte is equal to the test byte
2  --
3  CPU-determined number of bytes processed

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Specification
- Transaction constraint

**Programming Notes:**

1. When condition code 3 is set, the program can simply branch back to the instruction to continue the translation. The program need not determine the number of bytes that were translated.

2. The instruction can improve performance by being used in place of a TRANSLATE AND TEST instruction that locates an escape character, followed by a TRANSLATE instruction that translates the bytes preceding the escape character.

3. The storage-operand references of TRANSLATE EXTENDED may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)
reached, or a CPU-determined number of characters have been processed, whichever occurs first.

The result is indicated in the condition code.

When the ETF2-enhancement facility is installed, the M3 field has the following format:

```
/ / / C
0 1 2
```

The bits of the M3 field are defined as follows:

- **Unassigned**: Bits 0-2 are unassigned and should contain zeros; otherwise, the program may not operate compatibly in the future.

- **Test-Character-Comparison Control (C)**: The C bit, bit 3 of the M3 field, controls test-character comparison. When the C bit is zero, test-character comparison is performed. When the C bit is one, test-character comparison is not performed.

When the ETF2-enhancement facility is not installed, the M3 field is ignored.

The lengths of the operand and test characters are as follows:

- For TRANSLATE ONE TO ONE, the second-operand, first-operand, and test characters are single bytes.
- For TRANSLATE ONE TO TWO, the second-operand characters are single bytes, and the first-operand and test characters are double bytes.
- For TRANSLATE TWO TO ONE, the second-operand characters are double bytes, and the first-operand and test characters are single bytes.
- For TRANSLATE TWO TO TWO, the second-operand, first-operand, and test characters are double bytes.

For TRANSLATE ONE TO ONE and TRANSLATE TWO TO TWO, the test character is in bit positions 56-63 of general register 0. For TRANSLATE ONE TO TWO and TRANSLATE TWO TO TWO, the test character is in bit positions 48-63 of general register 0.

The R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

The location of the leftmost byte of the first operand and second operand is designated by the contents of general registers R1 and R2, respectively. In the 24-bit or 31-bit addressing mode, the number of bytes in the second-operand location is specified by the contents of bit positions 32-63 of general register R1 + 1, and those contents are treated as a 32-bit unsigned binary integer. In the 64-bit addressing mode, the number of bytes in the second-operand location is specified by the contents of bit positions 0-63 of general register R1 + 1, and those contents are treated as a 64-bit unsigned binary integer. The length of the first-operand location is considered to be the same as that of the second operand for TRANSLATE ONE TO ONE and TRANSLATE TWO TO TWO, twice that for TRANSLATE ONE TO TWO, and one half that for TRANSLATE TWO TO ONE.

For TRANSLATE TWO TO ONE and TRANSLATE TWO TO TWO, the length in general register R1 + 1 must be an even number of bytes; otherwise, a specification exception is recognized.

The translation table is treated as being on a double-word boundary for TRANSLATE ONE TO ONE and TRANSLATE ONE TO TWO. For TRANSLATE TWO TO ONE and TRANSLATE TWO TO TWO, the translation table is treated as follows:

- When the ETF2-enhancement facility is not installed, the translation table is treated as being on a 4K-byte boundary.
- When the ETF2-enhancement facility is installed, the translation table is treated as being on a doubleword boundary.

The rightmost bits of the register that are not used to form the address, which are bits 61-63 in the doubleword case and bits 52-63 in the 4K-byte case, are ignored but should contain zeros; otherwise, the program may not operate compatibly in the future.

The handling of the addresses in general registers R1, R2, and 1 is dependent on the addressing mode.

In the 24-bit addressing mode, the contents of bit positions 40-63 of general registers R1 and R2 and 40-60 or 40-51 of 1 constitute the address, and the
contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of registers \( R_1 \) and \( R_2 \) and 33-60 or 33-51 of 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of registers \( R_1 \) and \( R_2 \) and 0-60 or 0-51 of 1 constitute the address.

The contents of the registers just described are shown in Figure 7-313 on page 7-364.

In the access-register mode, the contents of access registers \( R_1 \), \( R_2 \), and 1 are used for accessing the first operand, second operand, and translation table, respectively.

The length of the translation table designated by the address contained in general register 1 is as follows:

- For TRANSLATE ONE TO ONE, the translation-table length is 256 bytes; each of the 256 function characters is a single byte.
- For TRANSLATE ONE TO TWO, the translation-table length is 512 bytes; each of the 256 function characters is a double byte.
- For TRANSLATE TWO TO ONE, the translation-table length is 65,536 (64K) bytes; each of the 64K function characters is a single byte.
- For TRANSLATE TWO TO TWO, the translation-table length is 131,072 (128K) bytes; each of the 64K function characters is a double byte.

The characters of the second operand are selected one by one for translation, proceeding left to right. Each argument character is added to the initial translation-table address. The addition is performed following the rules for address arithmetic, with the argument character treated as follows:

- For TRANSLATE ONE TO ONE, the argument character is treated as an eight-bit unsigned binary integer extended on the left with 56 zeros.
- For TRANSLATE ONE TO TWO, the argument character is treated as an eight-bit unsigned binary integer extended on the right with a zero and on the left with 55 zeros.
- For TRANSLATE TWO TO ONE, the argument character is treated as a 16-bit unsigned binary integer extended on the left with 48 zeros.
- For TRANSLATE TWO TO TWO, the argument character is treated as a 16-bit unsigned binary integer extended on the right with a zero and on the left with 47 zeros.

The rightmost bits of the translation-table address that are ignored (61-63 or 52-63) are treated as zeros during this addition.

The sum is used as the address of the function character.

When the ETF2-enhancement facility is not installed, or when the test-character-comparison control is zero, processing is as follows. Each function character selected as described above is first compared to the test character in general register 0. If the result is an equal comparison, the operation is completed. If the function character is not equal to the test character, the function character is placed in the next available character position in the first operand, that is, the first function character is placed at the beginning of the first-operand location, and each successive function character is placed immediately to the right of the preceding character. The second operand and the translation table are not altered unless an overlap occurs.

The operation proceeds until a selected function character equal to the test character is encountered, the second-operand location is exhausted, or a CPU-determined number of second-operand characters have been processed.

When the ETF2-enhancement facility is installed and the test-character-comparison control is one, processing is as described above, except that no test-character comparison is performed.

When a selected function character equal to the test character is encountered, condition code 1 is set. When the second-operand location is exhausted without finding a selected function character equal to the test character, condition code 0 is set. When a CPU-determined number of characters have been processed, condition code 3 is set. Condition code 3 may be set even when the next character to be processed results in a function character equal to the test character or when the second-operand location is exhausted. In these cases, condition code 1 or 0, respectively, will be set when the instruction is executed again. When the ETF2-enhancement facility is installed and the test-character-comparison control is one, condition code 1 does not apply.
If the operation is completed with condition code 0, the contents of general register $R_2$ are incremented by the contents of general register $R_1 + 1$, and the contents of general register $R_1$ are incremented as follows:

**Explanation:**

1. When the ETF2-enhancement facility is not installed, or when the C bit, bit 3 of the M3 field, is zero, test-character comparison is performed. When the ETF2-enhancement facility is installed and the C bit is one, test-character comparison is not performed, and general register 0 is ignored.

2. When the ETF2-enhancement facility is not installed, $N$ is 61 for TRANSLATE ONE TO ONE and TRANSLATE ONE TO TWO, and $N$ is 52 for TRANSLATE TWO TO ONE and TRANSLATE TWO TO TWO. When the ETF2-enhancement facility is installed, $N$ is 61.

**Figure 7-313. Register Contents for TRANSLATE ONE TO ONE, TRANSLATE ONE TO TWO, TRANSLATE TWO TO ONE, and TRANSLATE TWO TO TWO**
• For TRANSFORM ONE TO ONE and TRANSFORM TWO TO TWO, the same as for general register R2.
• For TRANSFORM ONE TO TWO, by twice the amount for general register R2.
• For TRANSFORM TWO TO ONE, by one half the amount for general register R2.

The contents of general register R1 + 1 are then set to zero.

If the operation is completed with condition code 1, the contents of general register R1 + 1 are decremented by the number of second-operand bytes processed before the character that selected a function character equal to the test character was encountered, and the contents of general register R2 are incremented by the same number, so that general register R2 contains the address of the character that selected a function character equal to the test character. The contents of general register R1 are incremented by the same, twice, or one half the number, as described above for condition code 0.

If the operation is completed with condition code 3, the contents of general register R1 + 1 are decremented by the number of second-operand bytes processed, and the contents of general register R2 are incremented by the same number, so that the instruction, when reexecuted, contains the address of the next character to be processed. The contents of general register R1 are incremented by the same, twice, or one half the number, as described above for condition code 0.

When general registers R1 and R2 are updated in the 24-bit or 31-bit addressing mode, the bits in bit positions 32-39 of them that are not part of the address may be set to zeros or may remain unchanged from their original values. In the 24-bit or 31-bit addressing mode, the contents of bit positions 0-31 of general registers R1, R1 + 1, and R2 always remain unchanged.

The contents of general registers 0 and 1 remain unchanged.

When any of the following conditions are true, the results are unpredictable:

• Either the R1 or R1 + 1 registers are the same register as the R2 register.
• The R1 register is register 0.
• The R2 register is register 0, and either the ETF2-enhancement facility is not installed, or the facility is installed and the C bit is zero.
• The R2 register is register 1.
• Any of the first and second operands and the translation table overlaps another of them.

Access exceptions for the portion of the first or second operand to the right of the last character processed may or may not be recognized. For an operand longer than 4K bytes, access exceptions are not recognized for locations more than 4K bytes beyond the last character processed.

Access exceptions for all characters of the translation table may be recognized even if not all characters are used.

Access exceptions are not recognized if the R1 field is odd. When the length of the second operand is zero, no access exceptions for the first or second operand are recognized, and access exceptions for the translation table may or may not be recognized.

Resulting Condition Code:

0: Entire second operand processed; if test-character comparison was performed, no resulting function character was equal to the test character
1: Second-operand character found resulting in a function character equal to the test character (applicable only when test-character comparison is performed)
2: --
3: CPU-determined number of characters processed

Program Exceptions:

• Access (fetch, operand 2 and translation table; store, operand 1)
• Operation (if the extended-translation facility 2 is not installed)
• Specification
• Transaction constraint
Programming Notes:

1. These instructions differ from the TRANSLATE EXTENDED instruction by having the following attributes:
   • Depending on the instruction used, the sets of argument characters and function characters each can contain single-byte or double-byte characters.
   • The test character is compared to a resulting function character instead of to an argument character.
   • The argument (source) and function (destination) operands are different operands.

2. When condition code 3 is set, the program can simply branch back to the instruction to continue the translation. The program need not determine the number of characters that were translated.

3. The storage operand references of these instructions may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

4. As observed by this CPU, other CPUs, and the I/O subsystem, inconsistent results may be briefly stored in the first-operand location. See the section “Effects of CPU Retry” on page 11-3 for further details.

UNPACK

\[ \text{UNPK} \quad D_{1}(L_{1},B_{1}),D_{2}(L_{2},B_{2}) \quad \text{[SS-b]} \]

The format of the second operand is changed from signed-packed-decimal to zoned, and the result is placed at the first-operand location. The signed-packed-decimal and zoned formats are described in Chapter 8, “Decimal Instructions.”

The second operand is treated as having the signed-packed-decimal format. Its digits and sign are placed unchanged in the first-operand location, using the zoned format. Zone bits with coding of 1111 are supplied for all bytes except the rightmost byte, the zone of which receives the sign of the second operand. The sign and digits are not checked for valid codes.

The result is obtained as if the operands were processed right to left. When necessary, the second operand is considered to be extended on the left with zeros. If the first-operand field is too short to contain all digits of the second operand, the remaining leftmost portion of the second operand is ignored. Access exceptions for the unused portion of the second operand may or may not be indicated.

When the operands overlap, the result is obtained as if the operands were processed one byte at a time and as if the first result byte were stored immediately after fetching the first operand byte. The entire rightmost second-operand byte is used in forming the first result byte. For the remainder of the field, information for two result bytes is obtained from a single second-operand byte, and execution proceeds as if the leftmost four bits of the byte were to remain available for the next result byte and need not be refetched. Thus, the result is as if two result bytes were to be stored immediately after fetching a single operand byte.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Transaction constraint

**Programming Notes:**

1. An example of the use of the UNPACK instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. A field that is to be unpacked can be destroyed by improper overlapping. To save storage space for unpacking by overlapping the operands, the rightmost byte of the first operand must be to the right of the rightmost byte of the second operand by the number of bytes in the second operand minus 2. If only one or two bytes are to be unpacked, the rightmost bytes of the two operands may coincide.

3. The storage-operand references of UNPACK may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)
UNPACK ASCII

The format of the second operand is changed from signed-packed-decimal to ASCII, and the result is placed at the first-operand location. The signed-packed-decimal format is described in Chapter 8, “Decimal Instructions.”

The second operand is treated as having the signed-packed-decimal format. Its digits are converted to ASCII characters by extending them on the left with 0011 binary, and the ASCII characters are then placed at the first operand location. The digits are not checked for valid codes.

The sign of the second operand is not transferred to the first operand but is checked for validity and determines the condition code. If the sign is 1010, 1100, 1110 or 1111 binary (plus), condition code 0 is set. If the sign is 1011 or 1101 binary (minus), condition code 1 is set. If the sign is not one of the codes for plus or minus, condition code 3 is set.

The converted last digit is placed in the rightmost byte position of the result field, and the other converted digits are placed adjacent to the last and to each other in the remainder of the result field.

The result is obtained as if the operands were processed right to left.

The length of the second operand is 16 bytes. The second operand consists of 31 digits and a sign.

The length of the first operand is designated by the contents of the L1 field. The first-operand length must not exceed 32 bytes (L1 must be less than or equal to 31); otherwise, a specification exception is recognized.

If the first operand is too short to contain all digits of the second operand, the remaining leftmost portion of the second operand is ignored. Access exceptions for the unused portion of the second operand may or may not be indicated.

When the length of the first operand is 32 bytes, the leftmost byte is set to ASCII zero, 30 hex.

The results are unpredictable if the first and second operands overlap in any way.

As observed by other CPUs and by channel programs, the first operand is not necessarily stored into in any particular order.

Resulting Condition Code:

0  Sign is plus
1  Sign is minus
2  --
3  Sign is invalid

Program Exceptions:

• Access (fetch, operand 2; store, operand 1)
• Operation (if the extended-translation facility 2 is not installed)
• Specification
• Transaction constraint

Programming Note:

1. The following example illustrates the use of the instruction to unpack to ASCII digits:

   ASDIGITS DS CL31
   PKDIGITS DS 0PL16
   DC X'1234567890'
   DC X'1234567890'
   DC X'1234567890'
   DC X'1C'
   UNPKA ASDIGITS(31), PKDIGITS

2. The storage-operand references of UNPACK ASCII may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

3. The UNPACK ASCII and UNPACK UNICODE instructions set condition code 0 to indicate a positive sign, and these instructions provide no indication of a zero result. In all other instructions that indicate a signed result, condition code 0 indicates a result of zero, and condition code 2 indicates a positive result.

UNPACK UNICODE

The results are unpredictable if the first and second operands overlap in any way.

As observed by other CPUs and by channel programs, the first operand is not necessarily stored into in any particular order.

Resulting Condition Code:

0  Sign is plus
1  Sign is minus
2  --
3  Sign is invalid

Program Exceptions:

• Access (fetch, operand 2; store, operand 1)
• Operation (if the extended-translation facility 2 is not installed)
• Specification
• Transaction constraint

Programming Note:

1. The following example illustrates the use of the instruction to unpack to ASCII digits:

   ASDIGITS DS CL31
   PKDIGITS DS 0PL16
   DC X'1234567890'
   DC X'1234567890'
   DC X'1234567890'
   DC X'1C'
   UNPKA ASDIGITS(31), PKDIGITS

2. The storage-operand references of UNPACK ASCII may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

3. The UNPACK ASCII and UNPACK UNICODE instructions set condition code 0 to indicate a positive sign, and these instructions provide no indication of a zero result. In all other instructions that indicate a signed result, condition code 0 indicates a result of zero, and condition code 2 indicates a positive result.
The format of the second operand is changed from signed-packed-decimal to Unicode Basic Latin, and the result is placed at the first-operand location. The signed-packed-decimal format is described in Chapter 8, “Decimal Instructions.”

The second operand is treated as having the signed-packed-decimal format. Its digits are converted to two-byte Unicode characters by extending them on the left with 000000000011 binary (003 hex), and the Unicode characters are then placed at the first operand location. The digits are not checked for valid codes. The sign of the second operand is not transferred to the first operand but is checked for validity and determines the condition code. If the sign is 1010, 1100, 1110 or 1111 binary (plus), condition code 0 is set. If the sign is 1011 or 1101 binary (minus), condition code 1 is set. If the sign is not one of the codes for plus or minus, condition code 3 is set.

The converted last digit is placed in the rightmost character position of the result field, and the other converted digits are placed adjacent to the last and to each other in the remainder of the result field.

The result is obtained as if the operands were processed right to left.

The length of the second operand is 16 bytes; the second operand consists of 31 digits and a sign.

The length of the first operand is designated by the contents of the L1 field. The first-operand length must not exceed 32 characters or 64 bytes (L1 must be less than or equal to 63 and must be odd); otherwise a specification exception is recognized.

If the first operand is too short to contain all digits of the second operand, the remaining leftmost portion of the second operand is ignored. Access exceptions for the unused portion of the second operand may or may not be indicated.

When the length of the first operand is 32 characters, the leftmost character is set to Unicode Basic Latin zero, 0030 hex.

The results are unpredictable if the first and second operands overlap in any way.

As observed by other CPUs and by channel programs, the first operand is not necessarily stored into in any particular order.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Sign is plus</td>
</tr>
<tr>
<td>1</td>
<td>Sign is minus</td>
</tr>
<tr>
<td>2</td>
<td>--</td>
</tr>
<tr>
<td>3</td>
<td>Sign is invalid</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Operation (if the extended-translation facility 2 is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. The following example illustrates the use of the instruction to unpack to European numbers:

   ```asm
   UNDIGITS DS CL62
   PKDIGITS DS 0PL16
   DC 'X'1234567890'
   DC 'X'1234567890'
   DC 'X'1234567890'
   DC 'X'1C'
   UNPKU UNDIGITS(62),PKDIGITS
   UNDIGITS UNPKU UNDIGITS(62),PKDIGITS
   UNPACK ASCII UNPACK UNICODE
   ```

2. The storage-operand references of UNPACK UNICODE may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

3. The UNPACK ASCII and UNPACK UNICODE instructions set condition code 0 to indicate a positive sign, and these instructions provide no indication of a zero result. In all other instructions that indicate a signed result, condition code 0 indicates a result of zero, and condition code 2 indicates a positive result.

**UPDATE TREE**

```
  | E |
  0 102
```

The nodes of a tree in storage are examined successively on a path toward the base of the tree, and contents of general register 0, conceptually followed on the right by contents of general register 1, are conditionally interchanged with the contents of the nodes so as to give a unique maximum logical value in gen-
eral register 0. The first half of a node and general register 0 contain a codeword, which is for use in sort/merge algorithms.

If the codeword in general register 0 equals the codeword in a node, the contents of the node are placed in general registers 2 and 3.

General register 4 contains the base address of the tree, and general register 5 contains the index of a node whose parent node will be examined first.

In the access-register mode, access register 4 specifies the address space containing the tree.

This instruction may be interrupted between units of operation. The condition code is unpredictable if the instruction is interrupted.

The size of a node, the size of a codeword, and the participation of bits 0-31 of general registers 1-5 in the operation depend on the addressing mode. In the 24-bit or 31-bit addressing mode, a node is eight bytes, a codeword is four bytes, and bits 0-31 are ignored and remain unchanged. In the 64-bit addressing mode, a node is 16 bytes, a codeword is eight bytes, and bits 0-31 are used in and may be changed by the operation.

Operation in the 24-Bit or 31-Bit Addressing Mode

In the 24-bit or 31-bit addressing mode, the double-word nodes of a tree in storage are examined successively on a path toward the base of the tree, and the contents of bit positions 32-63 of general register 0, conceptually followed on the right by the contents of bit positions 32-63 of general register 1, are conditionally interchanged with the contents of the nodes so as to give a unique maximum logical value in bit positions 32-63 of general register 0.

Bit positions 32-63 of general register 4 contain the base address of the tree, and bit positions 32-63 of general register 5 contain the index of a node whose parent node will be examined first. The base address is eight less than the address of the root node of the tree. The initial contents of bit positions 32-63 of general registers 4 and 5 must be a multiple of 8; otherwise, a specification exception is recognized.

A unit of operation begins by shifting the contents of bit positions 32-63 of general register 5 right logically one position and then setting bit 61 to zero. However, bits 32-63 of general register 5 remain unchanged if the execution of a unit of operation is nullified or suppressed. If after shifting and setting bit 61 to zero, bits 32-63 of general register 5 are all zeros, the instruction is completed, and condition code 1 is set; otherwise, the unit of operation continues.

Bit 32 of general register 0 is tested. If bit 32 of general register 0 is one, the instruction is completed, and condition code 3 is set.

If bit 32 of general register 0 is zero, the sum of bits 32-63 of general registers 4 and 5 is used as the intermediate value for normal operand address generation. The generated address is the address of a node in storage.

Bits 32-63 of general register 0 are logically compared with the contents of the first word of the currently addressed node. If the register operand is low, the contents of bit positions 32-63 of general registers 0 and 1 are interchanged with those of the node, and a unit of operation is completed. If the register operand is high, no additional action is taken, and the unit of operation is completed. If the compare values are equal, bit positions 32-63 of general register 2, conceptually followed on the right by bit positions 32-63 of general register 3, are loaded from the currently addressed node, the instruction is completed, and condition code 0 is set.

In those cases when the value in the first word of the node is less than or equal to the value in bit positions 32-63 of the register, the contents of the node remain unchanged. However, in some models, these contents may be fetched and subsequently stored back.

Operation in the 64-Bit Addressing Mode

In the 64-bit addressing mode, the quadword nodes of a tree in storage are examined successively on a path toward the base of the tree, and the contents of general register 0, conceptually followed on the right by the contents of general register 1, are conditionally interchanged with the contents of the nodes so as to give a unique maximum logical value in general register 0.

General register 4 contains the base address of the tree, and general register 5 contain the index of a node whose parent node will be examined first. The base address is 16 less than the address of the root node of the tree. The initial contents of general regis-
A unit of operation begins by shifting the contents of general register 5 right logically one position and then setting bit 60 to zero. However, general register 5 remains unchanged if the execution of a unit of operation is nullified or suppressed. If after shifting and setting bit 60 to zero, the contents of general register 5 are zero, the instruction is completed, and condition code 1 is set; otherwise, the unit of operation continues.

Bit 0 of general register 0 is tested. If bit 0 of general register 0 is one, the instruction is completed, and condition code 3 is set.

If bit 0 of general register 0 is zero, the sum of the contents of general registers 4 and 5 is used as the intermediate value for normal operand address generation. The generated address is the address of a node in storage.

The contents of general register 0 are logically compared with the contents of the first doubleword of the currently addressed node. If the register operand is low, the contents of general registers 0 and 1 are interchanged with those of the node, and a unit of operation is completed. If the register operand is high, no additional action is taken, and the unit of operation is completed. If the compare values are equal, general registers 2 and 3 are loaded from the currently addressed node, the instruction is completed, and condition code 0 is set.

In those cases when the value in the first doubleword of the node is less than or equal to the value in the register, the contents of the node remain unchanged. However, in some models, these contents may be fetched and subsequently stored back.

Specifications Independent of Addressing Mode

Access exceptions are recognized only for one node at a time. Access exceptions, change-bit action, and PER storage alteration do not occur for subsequent nodes until the previous node has been successfully compared and updated, and they also do not occur if a specification-exception condition exists.

Resulting Condition Code:

0  Equal compare values at currently addressed node
1  No equal compare values found on path, or no comparison made
2  --
3  In 24-bit or 31-bit mode, bits 32-63 of general register 5 nonzero and bits 32-63 of general register 0 negative; in 64-bit mode, general register 5 nonzero and general register 0 negative

Program Exceptions:
- Access (fetch and store, nodes of tree)
- Specification
- Transaction constraint

Programming Notes:

1. An example of the use of UPDATE TREE is given in “Sorting Instructions” in Appendix A, “Number Representation and Instruction-Use Examples.”

2. For use in sorting in the 24-bit or 31-bit addressing mode, when equal compare values have been found, the contents of bit positions 32-63 of general registers 1 and 3 can be appropriate (depending on the contents of the tree) for the subsequent execution of COMPARE AND FORM CODEWORD. The contents of bit positions 32-63 of general register 2, shifted right 16 bit positions, can be similarly appropriate, and they can provide for minimal recomparison of partially equal keys. The same applies in the 64-bit addressing mode except to the contents of bit positions 0-63 of the registers and with the contents of bit positions 0-63 of general register 2 shifted right 48 bit positions. Refer to “Sorting Instructions” on page A-53 for a discussion of trees and their use in sorting.

3. The program should avoid placing a nonzero value in bit positions 32-38 of general register 5 when in the 24-bit addressing mode. If any bit in bit positions 32-38 is a one, the nodes of the tree will not be examined successively.

4. When bits 32-63 of general register 0 are negative in the 24-bit or 31-bit addressing mode, or when bits 0-63 are negative in the 64-bit mode, and provided that the tree has been updated properly previously, the node represented by general registers 0 and 1 either is the node or is equal to the node (equal keys) that would be
selected if the unit of operation continued. In this case, ending the unit of operation and setting condition code 3 is a faster means of selecting an appropriate node because it does not require further examination and updating of the tree.

5. Setting condition code 3 provides improved performance when the replacement record is equal to the old winner and, more importantly (since the first case can be detected by means of the condition code of CFC), when the update path contains a negative codeword, indicating equality with the old winner.

6. In those cases when the codeword in the node is less than or equal to the codeword in general register 0, depending on the model, the contents of the node may be fetched and subsequently stored back. As a result, any of the following may occur for the storage location containing the node: a PER storage-alteration event may be recognized; a protection exception for storing may be recognized; and, provided no access exceptions exist, the change bit may be set to one. Because the contents of storage remain unchanged, the change bit may or may not be one when a PER storage-alteration event is recognized.

7. Special precautions should be taken when UPDATE TREE is made the target of an execute-type instruction. See the programming note concerning interruptible instructions under EXECUTE.

8. Further programming notes concerning interruptible instructions are included in “Interruptible Instructions” on page 5-24.

9. The storage-operand references for UPDATE TREE may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

10. Figure 7-314 on page 7-372 is a summary of the operation of UPDATE TREE in the 24-bit or 31-bit addressing mode, and Figure 7-315 on page 7-373 is a summary of the operation in the 64-bit addressing mode.
Figure 7-314. Execution of UPDATE TREE in the 24-Bit or 31-Bit Addressing Mode
Figure 7-315. Execution of UPDATE TREE in the 64-Bit Addressing Mode
Protection of Cryptographic Keys

When the message-security-assist-extension-3 facility is installed, two wrapping-key registers and two wrapping-key-verification-pattern registers are provided for each configuration. The two wrapping-key registers consist of a 192-bit DES wrapping-key (WKd) register and a 256-bit AES wrapping-key (WKa) register. The two wrapping-key-verification-pattern registers consist of a 192-bit DES wrapping-key-verification-pattern (WKdVP) register and a 256-bit AES wrapping-key-verification-pattern (WKaVP) register.

WKd is used to protect user DES or TDES keys, and WKdVP is used to verify the value of WKd. WKa is used to protect user AES keys, and WKaVP is used to verify the value of WKa. Whenever the contents of the WKd or WKa register are changed, the contents of the corresponding verification-pattern register are also changed.

Each time a clear reset is performed, a new set of wrapping keys and their associated verification patterns are generated. The contents of the two wrapping-key registers are kept internal to the model so that no program, including the operating system, can directly observe their clear value.

The following instructions provide functions supporting encrypted cryptographic keys:

- CIPHER MESSAGE
- CIPHER MESSAGE WITH CHAINING
- CIPHER MESSAGE WITH CIPHER FEEDBACK
- CIPHER MESSAGE WITH COUNTER
- CIPHER MESSAGE WITH OUTPUT FEEDBACK
- COMPUTE MESSAGE AUTHENTICATION CODE
- PERFORM CRYPTOGRAPHIC COMPUTATION

For each of these instructions, a program-specified DES or AES wrapping-key-verification-pattern in the parameter block is compared with the respective wrapping-key-verification-pattern register. the instruction completes with condition code 1 if the two do not match.

The program may also inspect the value of the DES or AES wrapping-key verification patterns in the parameter block stored by PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION.

Programming Notes:

1. Upon condition code 1, the program should re-import the cryptographic key for encrypting it under the appropriate wrapping key before the operation is resumed.

2. Even though the architecture defines that a new set of wrapping keys are generated upon a clear reset, condition code 1 could occur at any time for message-security-assist functions using an encrypted key because the application may be relocated to another system with a different set of wrapping keys.

Symbols Used in Subsequent Descriptions

The following symbols are used in the subsequent description. For data-encryption-algorithm (DEA) functions, the DEA-key-parity bit in each byte of the DEA key is ignored, and the operation proceeds normally, regardless of the DEA-key parity of the key.

Further description of the data-encryption algorithm may be found in Reference [11.] on page xxviii. Further description of the AES standard may be found in Reference [12.] on page xxviii.
Protection of DES Keys

When the message-security-assist-extension-3 facility is installed, user DEA or TDEA keys may be protected under the 192-bit DEA wrapping key.

Figure 7-320 on page 7-375 describes encryption of a 64-bit DEA key, a 128-bit TDEA key, and a 192-bit TDEA key using the 192-bit DEA wrapping key.

Figure 7-321 on page 7-376 describes decryption of an encrypted 64-bit DEA key, an encrypted 128-bit TDEA key, and an encrypted 192-bit TDEA key using the 192-bit DEA wrapping key.
Protection of AES Keys

When the message-security-assist-extension-3 facility is installed, user AES keys may be protected under the 256-bit AES wrapping key.

Figure 7-322 on page 7-376 describes encryption of a 128-bit AES key using the 256-bit AES wrapping key. Figure 7-323 on page 7-376 describes decryption of an encrypted 128-bit AES key using the 256-bit AES wrapping key.

Figure 7-324 on page 7-377 describes encryption of a 192-bit AES key using the 256-bit AES wrapping key. Figure 7-325 on page 7-377 describes decryption of an encrypted 192-bit AES key using the 256-bit AES wrapping key.

Figure 7-326 on page 7-377 describes encryption of a 256-bit AES key using the 256-bit AES wrapping key. Figure 7-327 on page 7-377 describes decryption of an encrypted 256-bit AES key using the 256-bit AES wrapping key.
**Explanation:**

K = K1 || K2; a user 192-bit AES key.

WK_a(K) = C1 || C2; K is encrypted under WK_a using AES-256 encryption.

Pad is a 64-bit value of zero.

*Figure 7-324. Encryption of 192-Bit AES Key Using WK_a*

**Explanation:**

K = K1 || K2; a user 256-bit AES key.

WK_a(K) = C1 || C2; K is encrypted under WK_a using AES-256 encryption.

*Figure 7-326. Encryption of 256-Bit AES Key Using WK_a*

**Explanation:**

K = K1 || K2; a user 192-bit AES key.

WK_a(K) = C1 || C2; K is encrypted under WK_a using AES-256 encryption.

*Figure 7-325. Decryption of 192-Bit AES Key Using WK_a*

**Explanation:**

K = K1 || K2; a user 256-bit AES key.

WK_a(K) = C1 || C2; K is encrypted under WK_a using AES-256 encryption.

*Figure 7-327. Decryption of 256-Bit AES Key Using WK_a*
Chapter 8. Decimal Instructions

Decimal-Number Formats .......................... 8-1
Zoned Format .................................. 8-1
Packed-Decimal Formats ...................... 8-1
  Signed-Packed-Decimal Format ............ 8-1
  Unsigned-Packed-Decimal Format ...... 8-2
Decimal Codes ............................... 8-2
Decimal Operations ........................... 8-3
  Decimal-Arithmetic Instructions ......... 8-3
  Editing Instructions ....................... 8-4
  Execution of Decimal Instructions ...... 8-4
  Other Instructions for Decimal Operands . 8-4
  General-Operand Data Exception ....... 8-4

Instructions .................................. 8-5
  ADD DECIMAL ................................ 8-6
  COMPARE DECIMAL ......................... 8-7
  DIVIDE DECIMAL .......................... 8-7
  EDIT ....................................... 8-8
  EDIT AND MARK .......................... 8-11
  MULTIPLY DECIMAL ....................... 8-12
  SHIFT AND ROUND DECIMAL ........... 8-12
  SUBTRACT DECIMAL .................... 8-13
  TEST DECIMAL .......................... 8-14
  ZERO AND ADD .......................... 8-14

The decimal instructions of this chapter perform arithmetic and editing operations on decimal data. Additional operations on decimal data are provided by several of the instructions in Chapter 7, “General Instructions.” Also, several instructions in Chapter 20, “Decimal-Floating-Point Instructions” operate on decimal numbers in the packed-decimal format. Except for decimal-floating-point instructions, decimal operands always reside in storage, and most decimal instructions use the SS instruction format. Decimal operands occupy storage fields that can start on any byte boundary. For decimal-floating-point instructions, the packed-decimal operands are fixed length and occupy a general register, or general register pair.

Decimal-Number Formats

Decimal numbers may be represented in several formats, including zoned, signed-packed-decimal and unsigned-packed-decimal. These formats are of variable length; most instructions used to operate on these formats specify the length of their operands and results. Each byte of a format consists of a pair of four-bit codes; the four-bit codes include decimal-digit codes, sign codes, and a zone code.

Zoned Format

\[ Z \bar{Z} N \bar{Z} N \bar{Z} N \bar{Z}/S N \]

In the zoned format, the rightmost four bits of a byte are called the numeric bits (N) and normally consist of a code representing a decimal digit. The leftmost four bits of a byte are called the zone bits (Z), except for the rightmost byte of a decimal operand, where these bits may be treated either as a zone or as a sign (S).

Decimal digits in the zoned format may be part of a larger character set, which includes also alphabetic and special characters. The zoned format is, therefore, suitable for input, editing, and output of numeric data in human-readable form. There are no decimal-arithmetic instructions which operate directly on decimal numbers in the zoned format; such numbers must first be converted to the signed-packed-decimal format or one of the DFP formats.

The editing instructions produce a result of up to 256 bytes; each byte may be a decimal digit in the zoned format, a message byte, or a fill byte.

Packed-Decimal Formats

There are two packed-decimal formats, signed-packed, and unsigned-packed.

Signed-Packed-Decimal Format

\[ D \bar{D} D \bar{D}/D D D S \]

In the signed-packed-decimal format, each byte contains two decimal digits (D), except for the rightmost byte, which contains a sign (S) to the right of a decimal digit. Decimal arithmetic is performed with operands in the signed-packed-decimal format and
generates results in the signed-packed-decimal format.

The signed-packed-decimal operands and results of decimal-arithmetic instructions may be up to 16 bytes (31 digits and sign), except that the maximum length of a multiplier or divisor is eight bytes (15 digits and sign). In division, the sum of the lengths of the quotient and remainder may be from two to 16 bytes. The editing instructions can fetch as many as 256 decimal digits from one or more decimal numbers of variable length, each in the signed-packed-decimal format. CONVERT FROM PACKED and CONVERT TO PACKED may have signed-packed-decimal operands up to 18 bytes (34 digits and sign).

**Unsigned-Packed-Decimal Format**

\[
\begin{array}{cccc}
D & D & D & D \\
/ & D & D & D \\
\end{array}
\]

In the unsigned-packed-decimal format, each byte contains two decimal digits (D) and there is no sign. The unsigned-packed-decimal format can be used as the source operand of the editing instructions, as the second operand of MOVE WITH OFFSET, and is also used by the decimal floating-point (DFP) instructions CONVERT FROM PACKED, CONVERT FROM SIGNED PACKED, CONVERT TO PACKED, and CONVERT TO UNSIGNED PACKED.

**Decimal Codes**

The decimal digits 0-9 have the binary encoding 0000-1001.

The preferred sign codes are 1100 for plus and 1101 for minus. These are the sign codes generated for the results of the decimal-arithmetic instructions and the CONVERT TO DECIMAL instruction. The instructions PACK ASCII and PACK UNICODE supply an implied positive sign (1100 binary). The DFP instructions CONVERT TO PACKED, CONVERT TO SIGNED PACKED, and CONVERT TO ZONED include a plus sign-code selection bit. The plus sign can be encoded as either 1100 or 1111.

Alternate sign codes are also recognized as valid in the sign position: 1010, 1110, and 1111 are alternate codes for plus, and 1011 is an alternate code for minus. Alternate sign codes are accepted for any decimal source operand, but are not generated in the completed result of a decimal-arithmetic instruction or CONVERT TO DECIMAL. This is true even when an operand remains otherwise unchanged, such as when adding zero to a number. An alternate sign code is, however, left unchanged by MOVE NUMERICS, MOVE WITH OFFSET, MOVE ZONES, PACK, and UNPACK.

When an invalid sign or digit code is detected, a general-operand data exception is recognized. For the decimal-arithmetic instructions and CONVERT TO BINARY, and the decimal floating-point instructions CONVERT FROM PACKED, CONVERT FROM SIGNED PACKED, CONVERT FROM UNSIGNED PACKED, and CONVERT FROM ZONED, the operation is suppressed.

For the editing instructions EDIT and EDIT AND MARK, an invalid sign code is not recognized. It is model dependent whether the operation is suppressed or terminated for a general-operand data exception due to an invalid digit code. No validity checking is performed by MOVE NUMERICS, MOVE WITH OFFSET, MOVE ZONES, PACK, PACK ASCII, PACK UNICODE, and UNPACK. The instructions UNPACK ASCII and UNPACK UNICODE do not check for invalid digit codes; invalid sign codes are recognized, but are not reported as a general-operand data exception, instead condition code 3 is set.

The zone code 1111 is generated in the left four bit positions of each byte representing a zone and a decimal digit in zoned-format results. Zoned-format results are produced by EDIT, EDIT AND MARK, and UNPACK. For EDIT and EDIT AND MARK, each result byte representing a zoned-format decimal digit contains the zone code 1111 in the left four bit positions and the decimal-digit code in the right four bit positions. For UNPACK, zone bits with a coding of 1111 are supplied for all bytes except the rightmost byte, the zone of which receives the sign.

The zone code 0011 is generated in the leftmost four bit positions of each byte representing a zone for a decimal digit in ASCII format. ASCII formats are produced by CONVERT TO ZONED when the zone-control bit is one and by UNPACK ASCII.
The meaning of the decimal codes is summarized in Figure 8-1.

<table>
<thead>
<tr>
<th>Code (Binary)</th>
<th>Recognized As</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Digit</td>
<td>Sign</td>
</tr>
<tr>
<td>0000</td>
<td>0</td>
<td>Invalid</td>
</tr>
<tr>
<td>0001</td>
<td>1</td>
<td>Invalid</td>
</tr>
<tr>
<td>0010</td>
<td>2</td>
<td>Invalid</td>
</tr>
<tr>
<td>0011</td>
<td>3</td>
<td>Invalid *</td>
</tr>
<tr>
<td>0100</td>
<td>4</td>
<td>Invalid</td>
</tr>
<tr>
<td>0101</td>
<td>5</td>
<td>Invalid</td>
</tr>
<tr>
<td>0110</td>
<td>6</td>
<td>Invalid</td>
</tr>
<tr>
<td>0111</td>
<td>7</td>
<td>Invalid</td>
</tr>
<tr>
<td>1000</td>
<td>8</td>
<td>Invalid</td>
</tr>
<tr>
<td>1001</td>
<td>9</td>
<td>Invalid</td>
</tr>
<tr>
<td>1010</td>
<td>Invalid</td>
<td>Plus</td>
</tr>
<tr>
<td>1011</td>
<td>Invalid</td>
<td>Minus</td>
</tr>
<tr>
<td>1100</td>
<td>Invalid</td>
<td>Plus (preferred)</td>
</tr>
<tr>
<td>1101</td>
<td>Invalid</td>
<td>Minus (preferred)</td>
</tr>
<tr>
<td>1110</td>
<td>Invalid</td>
<td>Plus</td>
</tr>
<tr>
<td>1111</td>
<td>Invalid</td>
<td>Plus (zone)</td>
</tr>
</tbody>
</table>

Explanation:

* The zone code 0011 binary is generated in the leftmost four bit positions of each byte representing a decimal digit in the ASCII format.

Figure 8-1. Summary of Digit and Sign Codes

**Programming Note:** Since 1111 is both the zone code and an alternate code for plus, unsigned (positive) decimal numbers may be represented in the zoned format with 1111 zone codes in all byte positions. The result of the PACK instruction converting such a number to the signed-packed-decimal format may be used directly as an operand for decimal instructions.

---

**Decimal Operations**

The decimal instructions in this chapter consist of two classes, the decimal-arithmetic instructions and the editing instructions.

**Decimal-Arithmetic Instructions**

The decimal-arithmetic instructions perform addition, subtraction, multiplication, division, comparison, and shifting.

Operands of the decimal-arithmetic instructions are in the signed-packed-decimal format and are treated as signed decimal integers. A decimal integer is represented in true form as an absolute value with a separate plus or minus sign. It contains an odd number of decimal digits, from one to 31, and the sign; this corresponds to an operand length of one to 16 bytes.

A decimal zero normally has a plus sign, but multiplication, division, and overflow may produce a zero value with a minus sign. Such a negative zero is a valid operand and is treated as equal to a positive zero by COMPARE DECIMAL.

The lengths of the two operands specified in the instruction need not be the same. If necessary, the shorter operand is considered to be extended with zeros on the left. Results, however, cannot exceed the first-operand length as specified in the instruction.

When a carry or leftmost nonzero digits of the result are lost because the first-operand field is too short, the result is obtained by ignoring the overflow digits, condition code 3 is set, and, if the decimal-overflow mask bit is one, a program interruption for decimal overflow occurs. The operand lengths alone are not an indication of overflow; nonzero digits must have been lost during the operation.

The operands of decimal-arithmetic instructions should not overlap at all or should have coincident rightmost bytes. In ZERO AND ADD, the operands may also overlap in such a manner that the rightmost byte of the first operand (which becomes the result) is to the right of the rightmost byte of the second operand. For these cases of proper overlap, the result is obtained as if operands were processed right to left. Because the codes for digits and signs are verified during the performance of the arithmetic, improperly overlapping operands are recognized as general-operand data exceptions. However, in ZERO AND ADD when the rightmost byte of the first operand is to the left of the rightmost byte of the second operand, the entire second operand may be fetched, depending on the model, before any storing occurs, which will cause a general-operand data exception not to be recognized. See “Interlocks within a Single Instruction” on page 5-114 for how overlap is detected in the access-register mode.

**Programming Note:** A signed-packed-decimal number in storage may be designated as both the first and second operand of ADD DECIMAL, COMPARE DECIMAL, DIVIDE DECIMAL, MULTIPLY DECIMAL,
SUBTRACT DECIMAL, or ZERO AND ADD. Thus, a decimal number may be added to itself, compared with itself, and so forth; SUBTRACT DECIMAL may be used to set a decimal field in storage to zero; and, for MULTIPLY DECIMAL, a decimal number may be squared in place. In these cases, the lengths of the two operands are not necessarily equal and may, depending on the instruction, be prohibited from being equal.

**Editing Instructions**

The editing instructions are EDIT and EDIT AND MARK. For these instructions, only the first operand (the pattern) has an explicitly specified length. The second operand (the source) is considered to have as many digits as necessary for the completion of the operation.

Overlapping operands for the editing instructions yield unpredictable results.

**Execution of Decimal Instructions**

During the execution of a decimal instruction, all bytes of the operands are not necessarily accessed concurrently, and the fetch and store accesses to a single location do not necessarily occur one immediately after the other. Furthermore, for decimal instructions, data in source fields may be accessed more than once, and intermediate values may be placed in the result field that may differ from the original operand and final result values. (See “Storage-Operand Consistency” on page 5-123.) Thus, in a multiprocessing configuration, an instruction such as ADD DECIMAL cannot be safely used to update a shared storage location when the possibility exists that another CPU may also be updating that location.

**Other Instructions for Decimal Operands**

In addition to the decimal-arithmetic instructions in this chapter, (which operate on decimal numbers in the signed-packed-decimal format) several other instructions are provided for operating on decimal data in the zoned, signed-packed-decimal, or unsigned-packed-decimal format.

The editing instructions (described in this chapter) convert decimal numbers in either the signed-packed-decimal or unsigned-packed-decimal format to the zoned format. Zoned results of up to 256 bytes in length can be produced.

CONVERT TO DECIMAL and CONVERT TO BINARY (described in Chapter 7) provide conversion between signed-binary-integer formats and decimal numbers in the signed-packed-decimal format. Signed-packed-decimal operands of up to 16 bytes in length (31 digits and a sign) can be processed.

CONVERT TO SIGNED PACKED and CONVERT FROM SIGNED PACKED (described in Chapter 20) provide conversion between decimal floating point (DFP) formats and the signed-packed-decimal format. Signed-packed-decimal operands of up to 16 bytes in length (31 digits and a sign) can be processed.

CONVERT TO UNSIGNED PACKED and CONVERT FROM UNSIGNED PACKED (described in Chapter 20) provide conversion between decimal floating point (DFP) formats and the unsigned-packed-decimal format. Unsigned-packed-decimal operands of up to 16 bytes in length (32 digits) can be processed.

MOVE WITH OFFSET (described in Chapter 7) operates on data in the packed format. (The first operand is treated as signed-packed decimal and the second operand as unsigned-packed decimal.) Operands are not checked for valid codes. Signed-packed-decimal operands of up to 16 bytes in length (31 digits and a sign) can be processed.

PACK, UNPACK, PACK ASCII, UNPACK ASCII, PACK UNICODE, and UNPACK UNICODE provide conversion between zoned or character data and signed-packed-decimal data. Operands are not checked for valid codes. Signed-packed-decimal operands of up to 16 bytes in length (31 digits and a sign) can be processed.

MOVE NUMERICS and MOVE ZONES (described in Chapter 7) operate on data in the zoned format. Operands are not checked for valid codes. Zoned operands of up to 256 bytes in length can be processed.

**General-Operand Data Exception**

A general-operand data exception is recognized when any of the following is true:
1. The sign or digit codes are invalid in the operands of the decimal instructions or in CONVERT TO BINARY (described in Chapter 7, “General Instructions’); or in CONVERT FROM PACKED, CONVERT FROM SIGNED PACKED, CONVERT FROM UNSIGNED PACKED, and CONVERT FROM ZONED (described in Chapter 20, “Decimal-Floating-Point Instructions”).

2. The operand fields in ADD DECIMAL, COMPARE DECIMAL, DIVIDE DECIMAL, MULTIPLY DECIMAL, and SUBTRACT DECIMAL overlap in a way other than with coincident rightmost bytes; or operand fields in ZERO AND ADD overlap, and the rightmost byte of the second operand is to the right of the rightmost byte of the first operand. On some models, the improper overlap of operands for ZERO AND ADD is not recognized as a general-operand data exception; instead, the operation is performed as if the entire second operand were fetched before any byte of the result is stored.

3. The multiplicand in MULTIPLY DECIMAL has an insufficient number of leftmost zeros.

4. COMPRESSION CALL encounters errors in its dictionaries.

5. The reseed counter is zero for a PERFORM PSEUDORANDOM NUMBER OPERATION generate operation.

A general-operand data exception causes the operation to be suppressed, except that, for EDIT and EDIT AND MARK, and COMPRESSION CALL, the operation may be suppressed or terminated. In the case of EDIT and EDIT AND MARK, and COMPRESSION CALL, an invalid sign code cannot occur.

**Note:** In earlier versions of the architecture, the general-operand data exception was known as the decimal-operand data exception.

### Instructions

The decimal instructions and their mnemonics, formats, and operation codes are listed in Figure 8-2 on page 8-6. The figure also indicates when the condition code is set, the instruction fields that designate access registers, and the exceptional conditions in operand designations, data, or results that cause a program interruption.

**Note:** In the detailed descriptions of the individual instructions, the mnemonic and the symbolic operand designation for the assembler language are shown with each instruction. For ADD DECIMAL, for example, AP is the mnemonic and D1(L1,B1),D2(L2,B2) the operand designation.

**Programming Note:** The decimal instruction TEST DECIMAL is available when the extended-translation facility 2 is installed.
The second operand is added to the first operand, and the resulting sum is placed at the first-operand location. The operands and result are in the signed-packed-decimal format.

Addition is algebraic, taking into account the signs and all digits of both operands. All sign and digit codes are checked for validity.

If the first operand is too short to contain all leftmost nonzero digits of the sum, decimal overflow occurs. The operation is completed. The result is obtained by ignoring the overflow digits, and condition code 3 is set. If the decimal-overflow mask is one, a program interruption for decimal overflow occurs.

The sign of the sum is determined by the rules of algebra. In the absence of overflow, the sign of a zero result is made positive. If overflow occurs, a zero result is given either a positive or negative sign, as determined by what the sign of the correct sum would have been.

**Resulting Condition Code:**

- 0 Result zero; no overflow
- 1 Result less than zero; no overflow
- 2 Result greater than zero; no overflow
- 3 Overflow

**Program Exceptions:**

- Access (fetch, operand 2; fetch and store, operand 1)
- Data with DXC 0, general operand
- Decimal overflow
- Transaction constraint
**Programming Note:** An example of the use of the ADD DECIMAL instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

## COMPARE DECIMAL

The first operand is compared with the second operand, and the result is indicated in the condition code. The operands are in the signed-packed-decimal format.

Comparison is algebraic and follows the procedure for decimal subtraction, except that both operands remain unchanged. When the difference is zero, the operands are equal. When a nonzero difference is positive or negative, the first operand is high or low, respectively.

Overflow cannot occur because the difference is discarded.

All sign and digit codes are checked for validity.

### Resulting Condition Code:

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Operands equal</td>
</tr>
<tr>
<td>1</td>
<td>First operand low</td>
</tr>
<tr>
<td>2</td>
<td>First operand high</td>
</tr>
<tr>
<td>3</td>
<td>--</td>
</tr>
</tbody>
</table>

### Program Exceptions:

- Access (fetch, operands 1 and 2)
- Data with DXC 0, general operand
- Transaction constraint

### Programming Notes:

1. An example of the use of the COMPARE DECIMAL instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The preferred and alternate sign codes for a particular sign are treated as equivalent for comparison purposes.

3. A negative zero and a positive zero compare equal.

## DIVIDE DECIMAL

The first operand (the dividend) is divided by the second operand (the divisor). The resulting quotient and remainder are placed at the first-operand location. The operands and results are in the signed-packed-decimal format.

The quotient is placed leftmost in the first-operand location. The number of bytes in the quotient field is equal to the difference between the dividend and divisor lengths (L1 - L2). The remainder is placed rightmost in the first-operand location and has a length equal to the divisor length. Together, the quotient and remainder fields occupy the entire first operand; therefore, the address of the quotient is the address of the first operand.

The divisor length cannot exceed 15 digits and sign (L2 not greater than seven) and must be less than the dividend length (L2 less than L1); otherwise, a specification exception is recognized.

The dividend, divisor, quotient, and remainder are each signed decimal integers in the signed-packed-decimal format and are right-aligned in their fields. All sign and digit codes of the dividend and divisor are checked for validity.

The sign of the quotient is determined by the rules of algebra from the dividend and divisor signs. The sign of the remainder has the same value as the dividend sign. These rules hold even when the quotient or remainder is zero.

Overflow cannot occur. If the divisor is zero or the quotient is too large to be represented by the number of digits specified, a decimal-divide exception is recognized. This includes the case of division of zero by zero. The decimal-divide exception is indicated only if the sign codes of both the dividend and divisor are valid, and only if the digit or digits used in establishing the exception are valid.

### Condition Code:

The code remains unchanged.

### Program Exceptions:
- Access (fetch, operand 2; fetch and store, operand 1)
- Data with DXC 0, general operand
- Decimal divide
- Specification
- Transaction constraint

**Programming Notes:**

1. An example of the use of the DIVIDE DECIMAL instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. The dividend cannot exceed 31 digits and sign. Since the remainder cannot be shorter than one digit and sign, the quotient cannot exceed 29 digits and sign.

3. The condition for a decimal-divide exception can be determined by a trial comparison. The leftmost digit of the divisor is aligned one digit to the right of the leftmost dividend digit, with rightmost zeros appended up to the length of the dividend. When the divisor, so aligned, is less than or equal to the dividend, ignoring signs, a divide exception is indicated.

4. If a general-operand data exception does not exist, a decimal-divide exception occurs when the leftmost dividend digit is not zero.

**EDIT**

```
ED D1(L,B1),D2(B2) [SS-a]
```

The second operand (the source), which normally contains one or more decimal numbers in the signed-packed-decimal or unsigned-packed-decimal format, is changed to the zoned format and modified under the control of the first operand (the pattern). The edited result replaces the first operand.

The length field specifies the length of the first operand, which may contain bytes of any value.

The length of the source is determined by the operation according to the contents of the pattern. The source normally consists of one or more decimal numbers, each in the signed-packed-decimal or unsigned-packed-decimal format. The leftmost four bits of each source byte must specify a decimal-digit code (0000-1001); a sign code (1010-1111) is recognized as a general-operand data exception. The rightmost four bits may specify either a sign code or a decimal-digit code. Access and data exceptions and PER zero-address-detection events are recognized only for those bytes in the second operand which are actually required.

The result is obtained as if both operands were processed left to right one byte at a time. Overlapping pattern and source fields give unpredictable results.

During the editing process, each byte of the pattern is affected in one of three ways:

1. It is left unchanged.
2. It is replaced by a source digit expanded to the zoned format.
3. It is replaced by the first byte in the pattern, called the fill byte.

Which of the three actions takes place is determined by one or more of the following: the type of the pattern byte, the state of the significance indicator, and whether the source digit examined is zero.

**Pattern Bytes:** There are four types of pattern bytes: digit selector, significance starter, field separator, and message byte. Their coding is as follows:

<table>
<thead>
<tr>
<th>Name</th>
<th>Code (Binary)</th>
<th>Code (Hex)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Digit Selector</td>
<td>0010 0000</td>
<td>20</td>
</tr>
<tr>
<td>Significance starter</td>
<td>0010 0001</td>
<td>21</td>
</tr>
<tr>
<td>Field separator</td>
<td>0010 0010</td>
<td>22</td>
</tr>
<tr>
<td>Message byte</td>
<td>Any other</td>
<td>Any other</td>
</tr>
</tbody>
</table>

The detection of either a digit selector or a significance starter in the pattern causes an examination to be made of the significance indicator and of a source digit. As a result, either the expanded source digit or the fill byte, as appropriate, is selected to replace the pattern byte. Additionally, encountering a digit selector or a significance starter may cause the significance indicator to be changed.

The field separator identifies individual fields in a multiple-field editing operation. It is always replaced in the result by the fill byte, and the significance indicator is always off after the field separator is encountered.
Message bytes in the pattern are either replaced by the fill byte or remain unchanged in the result, depending on the state of the significance indicator. They may thus be used for padding, punctuation, or text in the significant portion of a field or for the insertion of sign-dependent symbols.

**Fill Byte:** The first byte of the pattern is used as the fill byte. The fill byte can have any code and may concurrently specify a control function. If this byte is a digit selector or significance starter, the indicated editing action is taken after the code has been assigned to the fill byte.

**Source Digits:** Each time a digit selector or significance starter is encountered in the pattern, a new source digit is examined for placement in the pattern field. Either the source digit is disregarded, or it is expanded to the zoned format, by appending the zone code 1111 on the left, and stored in place of the pattern byte.

Execution is as if the source digits were selected one byte at a time. The leftmost four bits of each byte are examined first, and the rightmost four bits, when they represent a decimal-digit code, remain available for the next pattern byte that calls for a digit examination. When the leftmost four bits contain an invalid digit code, a general-operand data exception is recognized, and the operation is either suppressed or terminated.

At the time the left digit of a source byte is examined, the rightmost four bits are checked for the existence of a sign code. When a sign code is encountered in the rightmost four bit positions, these bits are not treated as a decimal-digit code, and a new source byte is fetched from storage when the next pattern byte calls for a source-digit examination.

When the pattern contains no digit selector or significance starter, no source bytes are fetched and examined.

**Significance Indicator:** The significance indicator is turned on or off to indicate the significance or non-significance, respectively, of subsequent source digits or message bytes. Significant source digits replace their corresponding digit selectors or significance starters in the result. Significant message bytes remain unchanged in the result.

The significance indicator, by its on or off state, indicates also the negative or positive value, respectively, of a completed source field and is used as one factor in the setting of the condition code.

The significance indicator is set to off at the start of the editing operation, after a field separator is encountered, or after a source byte is examined that has a plus code in the rightmost four bit positions.

The significance indicator is set to on when a significance starter is encountered whose source digit is a valid decimal digit, or when a digit selector is encountered whose source digit is a nonzero decimal digit, provided that in both instances the source byte does not have a plus code in the rightmost four bit positions.

In all other situations, the significance indicator is not changed. A minus sign code has no effect on the significance indicator.

**Result Bytes:** The result of an editing operation replaces and is equal in length to the pattern. It is composed of pattern bytes, fill bytes, and zoned source digits.

If the pattern byte is a message byte and the significance indicator is on, the message byte remains unchanged in the result. If the pattern byte is a field separator or if the significance indicator is off when a message byte is encountered in the pattern, the fill byte replaces the pattern byte in the result.

If the digit selector or significance starter is encountered in the pattern with the significance indicator off and the source digit zero, the source digit is considered nonsignificant, and the fill byte replaces the pattern byte. If the digit selector or significance starter is encountered either with the significance indicator on or with a nonzero decimal source digit, then the source digit (a) is considered significant, (b) is changed to the zoned format, and (c) replaces the pattern byte in the result. Examination of the significance indicator occurs prior to the processing of the source digit (which might change the significance indicator).

**Condition Code:** The sign and magnitude of the last field edited are used to set the condition code. The term “last field” refers to those source digits, if any, in the second operand selected by digit selectors or significance starters after the last field separator; if the pattern contains no field separator, there is only one field, which is considered to be the last field.
If no such source digits are selected, the last field is considered to be of zero length.

Condition code 0 is set when the last field edited is zero or of zero length.

Condition code 1 is set when the last field edited is nonzero and the significance indicator is on. (This indicates a result less than zero if the last source byte examined contained a sign code in the rightmost four bits.)

Condition code 2 is set when the last field edited is nonzero and the significance indicator is off. (This indicates a result greater than zero if the last source byte examined contained a sign code in the rightmost four bits.)

For the purposes of setting condition codes 2 or 3, the significance indicator is examined after the processing of the last source digit.

Figure 8-3 on page 8-10 summarizes the functions of the EDIT and EDIT AND MARK operations. The leftmost four columns list all the significant combinations of the four conditions that can be encountered in the execution of an editing operation. The rightmost two columns list the action taken for each case — the type of byte placed in the result field and the new setting of the significance indicator.

<table>
<thead>
<tr>
<th>Conditions</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pattern Byte</td>
<td>Previous State of Significance Indicator</td>
</tr>
<tr>
<td>Digit selector</td>
<td>Off</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>On</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>Significance starter</td>
<td>Off</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>On</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>Field separator</td>
<td>*</td>
</tr>
<tr>
<td>Message byte</td>
<td>Off</td>
</tr>
<tr>
<td></td>
<td>On</td>
</tr>
</tbody>
</table>

Explanation:
* No effect on result byte or on new state of significance indicator.
** Not applicable because source is not examined.
# For EDIT AND MARK only, the address of the rightmost such result byte is placed in general register 1.

Figure 8-3. Summary of Editing Functions

**Resulting Condition Code:**

0 Last field zero or zero length
1 Last field less than zero
2 Last field greater than zero
3 --

**Program Exceptions:**

- Access (fetch, operand 2; fetch and store, operand 1)
- Data with DXC 0, general operand
- Transaction constraint

**Programming Notes:**

1. Examples of the use of the EDIT instruction are given in Appendix A, “Number Representation and Instruction-Use Examples.”
2. Editing includes sign and punctuation control, and the suppression of leading zeros by replacing them with blanks, or the protection of leading zeros from malicious alteration by replacing them with asterisks or other characters. It also facilitates programmed blanking of all-zero fields. Several fields may be edited in one operation, and numeric information may be combined with text.

3. In most cases, the source is shorter than the pattern because each four-bit source digit produces an eight-bit byte in the result.

4. The total number of digit selectors and significance starters in the pattern always equals the number of source digits edited.

5. If the fill byte is a blank, if no significance starter exists in the pattern, and if the source digit examined for each digit selector is zero, the editing operation blanks the result field.

6. The resulting condition code indicates whether or not the last field is all zeros and, if nonzero, reflects the state of the significance indicator. The significance indicator reflects the sign of the source field only if the last source byte examined contains a sign code in the rightmost four bits. For multiple-field editing operations, the condition code reflects the sign and value only of the field following the last field separator.

7. Significant performance degradation is possible when the second-operand address of an EDIT instruction designates a location that is closer to the left of an access boundary than the length of the first operand of that instruction (for the purposes of this discussion, an access boundary is 4 K-bytes, except when fetch-protection override applies in which case it is 2 K-bytes). This is because the machine may perform a trial execution of the instruction to determine if the second operand actually crosses the boundary. The second operand of EDIT, while normally shorter than the first operand, can in the extreme case have the same length as the first.

**EDIT AND MARK**

<table>
<thead>
<tr>
<th>EDMK</th>
<th>D1(L,B1),D2(B2)</th>
<th>[SS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'DF'</td>
<td>L</td>
<td>B1</td>
</tr>
</tbody>
</table>

0 8 16 20 32 36 47

The second operand (the source), which normally contains one or more decimal numbers in the signed-packed-decimal or unsigned-packed-decimal format, is changed to the zoned format and modified under the control of the first operand (the pattern). The address of the first significant result byte of the rightmost (or only) field is inserted in general register 1. The edited result replaces the pattern.

EDIT AND MARK is identical to EDIT, except for the additional function of inserting the address of the result byte in general register 1 if the result byte is a zoned source digit and the significance indicator was off before the examination of the source bytes. If no result byte meets the criteria, general register 1 remains unchanged; if more than one result byte meets the criteria, the address of the rightmost such result byte is inserted.

In the 24-bit addressing mode, the address replaces bits 40-63 of general register 1, and bits 0-39 of the register are not changed. In the 31-bit addressing mode, the address replaces bits 33-63 of general register 1, bit 32 of the register is set to zero, and bits 0-31 of the register remain unchanged. In the 64-bit addressing mode, the address replaces bits 0-63 of general register 1.

The contents of access register 1 remain unchanged.

See Figure 8-3 on page 8-10 for a summary of the EDIT and EDIT AND MARK operations.

**Resulting Condition Code:**

0 Last field zero or zero length
1 Last field less than zero
2 Last field greater than zero
3 --

**Program Exceptions:**

- Access (fetch, operand 2; fetch and store, operand 1)
- Data
- Transaction constraint

**Programming Notes:**

1. Examples of the use of the EDIT AND MARK instruction are given Appendix A, “Number Representation and Instruction-Use Examples.”
2. EDIT AND MARK facilitates the programming of floating currency-symbol insertion. Using appropriate source and pattern data, the address inserted in general register 1 is one greater than the address where a floating currency-sign would be inserted.

3. No address is inserted in general register 1 when the significance indicator is turned on as a result of encountering a significance starter with the corresponding source digit zero. To ensure that general register 1 contains a proper address when this occurs, the address of the pattern byte that immediately follows the appropriate significance starter could be placed in the register beforehand.

4. When multiple fields are edited with one execution of the EDIT AND MARK instruction, the address, if any, inserted in general register 1 applies to the rightmost field edited for which the criteria were met.

5. See also the programming note under EDIT regarding performance degradation due to a possible trial execution.

MULTIPLY DECIMAL

The product of the first operand (the multiplicand) and the second operand (the multiplier) is placed at the first-operand location. The operands and result are in the signed-packed-decimal format.

The multiplier length cannot exceed 15 digits and sign (L2 not greater than seven) and must be less than the multiplicand length (L2 less than L1); otherwise, a specification exception is recognized.

The multiplicand must have at least as many bytes of leftmost zeros as the number of bytes in the multiplier; otherwise, a general-operand data exception is recognized. This restriction ensures that no product overflow occurs.

The multiplicand, multiplier, and product are each signed decimal integers in the signed-packed-decimal format and are right-aligned in their fields. All sign and digit codes of the multiplicand and multiplier are checked for validity. The sign of the product is determined by the rules of algebra from the multiplier and multiplicand signs, even if one or both operands are zeros.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2; fetch and store, operand 1)
- Data with DXC 0, general operand
- Specification
- Transaction constraint

**Programming Notes:**
1. An example of the use of the MULTIPLY DECIMAL instruction is given Appendix A, “Number Representation and Instruction-Use Examples.”
2. The product cannot exceed 31 digits and sign. The leftmost digit of the product is always zero.

SHIFT AND ROUND DECIMAL

The first operand is shifted in the direction and for the number of decimal-digit positions specified by the second-operand address, and, when shifting to the right is specified, the absolute value of the first operand is rounded by the rounding digit, I3. The first operand and the result are in the signed-packed-decimal format.

The first operand is considered to be in the signed-packed-decimal format. Only its digit portion is shifted; the sign position does not participate in the shifting. Zeros are supplied for the vacated digit positions. The result replaces the first operand. Nothing is stored outside of the specified first-operand location.

The second-operand address, specified by the \( B_2 \) and \( D_2 \) fields, is not used to address data; bits 58-63 of that address are the shift value, and the leftmost bits of the address are ignored.
The shift value is a six-bit signed binary integer, indicating the direction and the number of decimal-digit positions to be shifted. Positive shift values specify shifting to the left. Negative shift values, which are represented in two's complement notation, specify shifting to the right. The following are examples of the interpretation of shift values:

<table>
<thead>
<tr>
<th>Shift Value (Binary)</th>
<th>Amount and Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>011111</td>
<td>31 digits to the left</td>
</tr>
<tr>
<td>000001</td>
<td>One digit to the left</td>
</tr>
<tr>
<td>000000</td>
<td>No shift</td>
</tr>
<tr>
<td>111111</td>
<td>One digit to the right</td>
</tr>
<tr>
<td>100000</td>
<td>32 digits to the right</td>
</tr>
</tbody>
</table>

For a right shift, the I3 field, bits 12-15 of the instruction, is used as a decimal rounding digit. The first operand, which is treated as positive by ignoring the sign, is rounded by decimally adding the rounding digit to the leftmost of the digits to be shifted out and by propagating the carry, if any, to the left. The result of this addition is then shifted right. Except for validity checking and the participation in rounding, the digits shifted out of the rightmost decimal-digit position are ignored and are lost.

If one or more nonzero digits are shifted out during a left shift, decimal overflow occurs. The operation is completed. The result is obtained by ignoring the overflow digits, and condition code 3 is set. If the decimal-overflow mask is one, a program interruption for decimal overflow occurs. Overflow cannot occur for a right shift, with or without rounding, or when no shifting is specified.

In the absence of overflow, the sign of a zero result is made positive. If overflow occurs, the sign of the result is the same as the original sign but with the preferred sign code.

A general-operand data exception is recognized when the first operand does not have valid sign and digit codes or when the rounding digit is not a valid digit code. The validity of the first-operand codes is checked even when no shift is specified, and the validity of the rounding digit is checked even when no addition for rounding takes place.

**Resulting Condition Code:**

0  Result zero; no overflow  
1  Result less than zero; no overflow  
2  Result greater than zero; no overflow

**Program Exceptions:**

- Access (fetch and store, operand 1)  
- Data with DXC 0, general operand  
- Decimal overflow  
- Transaction constraint

**Programming Notes:**

1. Examples of the use of the SHIFT AND ROUND DECIMAL instruction are given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. SHIFT AND ROUND DECIMAL can be used for shifting up to 31 digit positions left and up to 32 digit positions right. This is sufficient to clear all digits of any decimal number even with rounding.

3. For right shifts, the rounding digit 5 provides conventional rounding of the result. The rounding digit 0 specifies truncation without rounding.

4. When the B2 field is zero, the six-bit shift value is obtained directly from bits 42-47 of the instruction.

**SUBTRACT DECIMAL**

The second operand is subtracted from the first operand, and the resulting difference is placed at the first-operand location. The operands and result are in the signed-packed-decimal format.

**SUBTRACT DECIMAL**

```
SP  D1(L1,B1),D2(L2,B2) [SS-b]
```

The second operand is subtracted from the first operand, and the resulting difference is placed at the first-operand location. The operands and result are in the signed-packed-decimal format.

**SUBTRACT DECIMAL**

```
SP  D1(L1,B1),D2(L2,B2) [SS-b]
```

The second operand is subtracted from the first operand, and the resulting difference is placed at the first-operand location. The operands and result are in the signed-packed-decimal format.

**Resulting Condition Code:**

0  Result zero; no overflow  
1  Result less than zero; no overflow  
2  Result greater than zero; no overlap  
3  Overflow

**Program Exceptions:**
• Access (fetch, operand 2; fetch and store, operand 1)
• Data with DXC 0, general operand
• Decimal overflow
• Transaction constraint

TEST DECIMAL

The first operand is tested for valid decimal digits and a valid sign code, and the result is indicated in the condition code. The operand is in the signed-packed-decimal format.

Resulting Condition Code:
0   All digit codes and the sign valid
1   Sign invalid
2   At least one digit code invalid
3   Sign invalid and at least one digit code invalid

Program Exceptions:
• Access (fetch, operand 1)
• Operation (if the extended-translation facility 2 is not installed)
• Transaction constraint

ZERO AND ADD

The second operand is placed at the first-operand location. The operation is equivalent to an addition to zero. The operand and result are in the signed-packed-decimal format.

Only the second operand is checked for valid sign and digit codes. Extra zeros are supplied on the left for the shorter operand if needed.

If the first operand is too short to contain all leftmost nonzero digits of the second operand, decimal overflow occurs. The operation is completed. The result is obtained by ignoring the overflow digits, and condition code 3 is set. If the decimal-overflow mask is one, a program interruption for decimal overflow occurs.

In the absence of overflow, the sign of a zero result is made positive. If overflow occurs, a zero result is given the sign of the second operand but with the preferred sign code.

The two operands may overlap, provided the rightmost byte of the first operand is coincident with or to the right of the rightmost byte of the second operand. In this case, the result is obtained as if the operands were processed right to left. When the operands overlap and the rightmost byte of the first operand is to the left of the rightmost byte of the second operand, then, depending on the model, either a general-operand data exception is recognized or the result is obtained as if the entire second operand were fetched before any byte of the result is stored.

Resulting Condition Code:
0   Result zero; no overflow
1   Result less than zero; no overflow
2   Result greater than zero; no overflow
3   Overflow

Program Exceptions:
• Access (fetch, operand 2; store, operand 1)
• Data with DXC 0, general operand
• Decimal overflow
• Transaction constraint

Programming Note: An example of the use of the ZERO AND ADD instruction is given in Appendix A, “Number Representation and Instruction-Use Examples.”
# Chapter 9. Floating-Point Overview and Support Instructions

- Sign Bit ......................................................... 9-2
- Finite Floating-Point Numbers ......................... 9-2
- Infinities ....................................................... 9-2
- Not-A-Number (NaN) .......................................... 9-2
- Signaling and Quiet NaNs ................................. 9-2
- Payload ......................................................... 9-3
- Propagation of NaNs ......................................... 9-3
- Default QNaN .................................................. 9-3
- Floating-Point Number Representations ................. 9-3
- Hexadecimal-Floating-Point (HFP) ....................... 9-3
- Binary Floating-Point (BFP) .............................. 9-4
- Decimal Floating-Point (DFP) ............................. 9-4
- Canonical DFP Data ........................................... 9-4
- Comparison of Floating-Point Number Representations ......................................................... 9-5
- Floating-Point Number Ranges ......................... 9-5
- Equivalent Floating-Point Number Representations ......................................................... 9-5
- Effective Width ............................................... 9-7
- Floating-Point Data in Storage ......................... 9-8
- Registers And Controls .................................... 9-8
- Floating-Point Registers ................................ 9-8
- Additional Floating-Point (AFP) Registers .......... 9-9
- Valid Floating-Point-Register Designations ......... 9-9
- Floating-Point-Control (FPC) Register ................ 9-9
- IEEE Masks and Flags ...................................... 9-10
- FPC DXC Byte .................................................. 9-10
- Operations on the FPC Register ......................... 9-10
- AFP-Register-Control Bit ................................ 9-11
- IEEE Computational Operations ...................... 9-11
- Intermediate Values ....................................... 9-11
- Precise Intermediate Value .............................. 9-12
- Precision-Rounded Value .................................. 9-12
- Denormalized Value ........................................... 9-12
- Functionally-Rounded Value ............................ 9-12
- Rounded Intermediate Value ........................... 9-12
- Scaled Value ..................................................... 9-12
- Scale Factor ($\gamma$) ......................................... 9-12
- Unsigned Scaling Exponent ($\alpha$) ...................... 9-12
- Signed Scaling Exponent ($\Omega$) ......................... 9-12
- IEEE Rounding ............................................... 9-13
- Permissible Set .............................................. 9-13
- Selection of Candidates .................................. 9-13
- Ties ............................................................... 9-13
- Voting Digit and Common-Rounding-Point View .......... 9-13
- Rounding Methods .......................................... 9-13
- Explicit Rounding Methods ............................ 9-16
- Summary of Rounding Action ............................ 9-17
- IEEE Exceptions .............................................. 9-18
- Concurrent IEEE Exceptions ............................. 9-18
- IEEE Invalid Operation ..................................... 9-18
- IEEE Division-By-Zero ....................................... 9-19
- IEEE Overflow ................................................... 9-19
- IEEE Underflow ............................................... 9-20
- IEEE Inexact ..................................................... 9-20
- Quantum Exception ......................................... 9-21
- Suppression of Certain IEEE Exceptions ............. 9-23
- IEEE Same-Radix Format Conversion .................. 9-23
- IEEE Comparison .............................................. 9-24
- Condition Codes for IEEE Instructions ............... 9-24
- Instructions ...................................................... 9-24
- CONVERT BFP TO HFP ........................................ 9-27
- CONVERT HFP TO BFP ......................................... 9-28
- COPY SIGN ....................................................... 9-30
- EXTRACT FPC ...................................................... 9-30
- LOAD ............................................................... 9-31
- LOAD COMPLEMENT ............................................. 9-31
- LOAD FPC .......................................................... 9-31
- LOAD FPC AND SIGNAL ....................................... 9-32
- LOAD FPR FROM GR ........................................... 9-34
- LOAD GR FROM FPR ............................................ 9-34
- LOAD NEGATIVE .................................................. 9-34
- LOAD POSITIVE .................................................... 9-34
- LOAD ZERO ....................................................... 9-35
- PERFORM FLOATING-POINT OPERATION .................. 9-35
- General Register 0 (GR0) .................................. 9-36
- Return Code ..................................................... 9-38
- Sign Preservation ............................................. 9-38
- Preferred Quantum .......................................... 9-39
- NaN Conversion ................................................. 9-39
- Scaled Value and Signed Scaling Exponent ($\Omega$) for PFPO ..................................................... 9-39
- HFP Values ...................................................... 9-39
- HFP Zero Result ................................................ 9-39
- HFP Overflow and Underflow for PFPO ............... 9-39
- IEEE Exceptions for PFPO .................................. 9-40
- PFPO Actions .................................................... 9-45
- SET BFP Rounding Mode .................................... 9-47
- SET DFP Rounding Mode .................................... 9-47
- SET FPC .......................................................... 9-47
- SET FPC AND SIGNAL .......................................... 9-48
- STORE ............................................................. 9-48
- STORE FPC ......................................................... 9-49
- Impacts on ESA/390 ........................................... 9-52

© Copyright IBM Corp. 1990-2015
Floating-point instructions are used to perform calculations on operands having a wide range of magnitude and to obtain results scaled to preserve precision.

Floating-point operands have formats based on three radices: 2, 10, or 16. These radix values lead to the terminology “binary,” “decimal,” and “hexadecimal” floating point (BFP, DFP, and HFP), respectively. The formats are also based on three operand lengths: short (32 bits), long (64 bits), and extended (128 bits). Short operands require less storage than long or extended operands. On the other hand, long and extended operands permit greater precision in computation.

Sign Bit
All floating-point data have a sign bit. The sign bit is zero for plus and one for minus.

Finite Floating-Point Numbers
A finite floating-point number has three components: a sign bit, an exponent, and a significand. The magnitude (an unsigned value) of the number is the product of the significand and the radix raised to the power of the exponent. The number is positive or negative depending on whether the sign bit is zero or one, respectively.

The significand consists of a string of digits, where each digit is an integral value from zero to one less than the radix (2, 10, or 16). (Thus, a BFP digit is one bit, an HFP digit is four bits, and a DFP digit is a value from zero to nine.) The number of digit positions in the significand is called the precision of the floating-point number. The significand has an implied radix point, which, depending on the view, may be considered to be on the left, to the right of the leftmost digit, on the right, or elsewhere.

The exponent, a signed value, is represented as an unsigned binary value by adding a bias; the result, for BFP and DFP, is called the biased exponent; for HFP, it is called the characteristic. The value of the bias depends on the view. In the fraction view, the radix point is considered to be the left of the significand. In the left-units view, the radix point is considered to be to the right of the leftmost digit. In the right-units view, the radix point is considered to be on the right of the significand. By choosing the appropriate bias, any finite floating-point number can be considered in any of these views, or even in another view. For the first three of these views, the bias is called the fraction-view bias, left-units-view bias, and right-units-view bias, respectively. Except where otherwise indicated, HFP is defined in terms of the fraction view, BFP terms of the left-units view, and DFP in terms of the right-units view.

For HFP, the significand is considered to be a fraction with the implied radix point on the left. In this view, the significand is referred to as the fraction. For BFP, the significand consists of an implicit unit digit to the left of an implied radix point and an explicit fraction field to the right. For DFP, the significand is considered to be an integer with the implied radix point on the right.

Infinities
BFP and DFP data include an infinite numeric datum, called infinity. Infinities can participate in most arithmetic operations and give a consistent result, usually infinity. An infinity has a sign bit. In comparisons, infinities of the same sign compare equal, \(+\infty\) compares greater than any finite number, and \(-\infty\) compares less than any finite number.

Not-A-Number (NaN)
BFP and DFP data types include a nonnumeric datum, called not-a-number (or NaN). A NaN is produced in place of a numeric result after an invalid operation when there is no IEEE trap action. NaNs may also be used by the program to flag special operands, such as the contents of an uninitialized storage area. A NaN has a sign bit, a NaN-type bit, and a payload.

Signaling and Quiet NaNs
There are two types of NaNs, signaling and quiet. A signaling NaN (SNaN) is distinguished from the corresponding quiet NaN (QNaN) by the NaN-type bit.

For BFP, the NaN-type bit is the leftmost bit of the fraction field, and is called the QNaN bit: a BFP NaN is an SNaN, or a QNaN, depending on whether the QNaN bit is zero, or one, respectively. For DFP, the
NaN-type bit is in bit position 6 in all three formats, and is called the SNaN bit: a DFP NaN is a QNaN, or an SNaN, depending on whether the SNaN bit is zero, or one, respectively.

Payload
NaNs include diagnostic information called the payload. For BFP, the payload has two fewer bits than the precision and is considered to be a left-aligned bit-reversed binary integer. For DFP, the payload has one fewer digit than the precision and is considered to be a right-aligned decimal integer.

For both BFP and DFP the payload of a NaN is considered to be an unsigned integer. Let \( p \) represent the precision, in digits, of a particular format. For DFP, bit 6 of the format is called the SNaN bit and the \( p-1 \) digits in the trailing significand field are the numeric value of the payload. For BFP, the leftmost bit in the fraction field is called the QNaN bit and the remaining \( p-2 \) bits of the fraction field are the numeric value of the payload.

The numeric value of the BFP NaN payload is bit-reversed. That is, the first bit to the right of the QNaN bit is considered to have a value of one, the next bit a value of two, and so on, with each bit having a value of twice the value of the bit to its left.

Propagation of NaNs
Normally, QNaNs are just propagated during computations so that they will remain visible at the end; while an SNaN operand causes an IEEE-invalid-operation exception. If the IEEE-invalid-operation mask (FPC 0.0) is zero, the result is the corresponding QNaN, which is produced by inverting the NaN-type bit, and setting the IEEE-invalid-operation flag (FPC 1.0) is set to one. If the IEEE-invalid-operation mask (FPC 0.0) is one, the operation is suppressed, and a data exception for IEEE-invalid operation occurs.

Default QNaN
A special QNaN is supplied as the default result for an IEEE-invalid-operation exception; it has a plus sign and a payload of zeros.

Programming Notes:
1. The program can generate and assign values to the payload of a NaN. The CPU propagates those values unchanged, except that an SNaN is changed to the corresponding QNaN if the IEEE-invalid-operation mask bit is zero, and conversion to a narrower format truncates digits from the payload. For BFP, bits are truncated on the right; for DFP, digits are truncated on the left. For the PFPO-convert-floating-point-radix operation, payloads are preserved, except that payloads larger than the capacity of the target format are replaced by the default QNaN (payload zero).

2. Depending on the application, the program may or may not desire that an SNaN signal the IEEE invalid-operation exception. The sign-handling instructions LOAD COMPLEMENT, LOAD NEGATIVE, and LOAD POSITIVE do not signal the invalid-operation exception but, instead, treat SNaNs like any other data. LOAD AND TEST signals the invalid-operation exception when the operand is an SNaN. This instruction, in conjunction with the above instructions, gives the program the choice of either option.

3. The instructions LOAD LENGTHENED and LOAD ROUNDED change the precision of a floating-point datum. The BFP versions of these instructions signal the invalid-operation exception when the operand is an SNaN. The DFP instructions have a modifier bit to control whether the exception is signaled.

Floating-Point Number Representations

Hexadecimal-Floating-Point (HFP)

Hexadecimal-floating-point (HFP) operands have formats which provide for exponents that specify powers of the radix 16 and significands that are hexadecimal numbers. The exponent range is the same for the short, long, and extended formats.

The results of most operations on HFP data are truncated to fit into the target format, but there are instructions available to round the result when converting to a narrower format. Additionally, the PERFORM FLOATING POINT OPERATION instruction provides rounding methods when converting to an HFP format from BFP or DFP.

For HFP operands, the implicit unit digit of the significand is always zero. Since the value of the significand and fraction are the same, HFP operations are
described in terms of the fraction, and the term significand is not used.

Either normalized or unnormalized numbers may be used as operands for any HFP or DFP operation, where, for HFP, a normalized number is one having a nonzero leftmost fraction digit, or, for DFP, a normalized number is one having a nonzero leftmost significand digit. Most HFP instructions generate normalized results for greatest precision. HFP add and subtract instructions that generate unnormalized results are also available.

**Binary Floating-Point (BFP)**

Binary-floating-point (BFP) operands have formats which provide for exponents that specify powers of the radix 2 and significands that are binary numbers. The exponent range differs for different formats, the range being greater for the longer formats. In the long and extended formats, the exponent range is significantly greater for BFP data than for HFP data.

The results of operations performed on BFP data are rounded automatically to fit into the target format. The manner of rounding is determined by a program-settable BFP rounding mode; however, explicit rounding modes may be specified in various BFP instructions.

There are no unnormalized operands for BFP operations. For normal BFP numbers, the implicit unit digit of the significand is one. For values too small in magnitude to be represented in normalized form, the implicit unit digit is zero. These numbers are called subnormal numbers. Unlike the HFP and DFP formats, where the same value can have multiple representations in a given format because of the possibility of unnormalized numbers, the BFP format does not allow such redundancy.

**Decimal Floating-Point (DFP)**

Decimal-floating-point (DFP) operands have formats which provide for exponents that specify powers of the radix 10 and significands that are decimal numbers. The exponent range differs for different formats, the range being greater for the longer formats. The exponent range is greater for DFP data than for BFP data.

The results of operations performed on DFP data are rounded automatically to fit into the target format. The manner of rounding is determined by a program-settable DFP rounding mode; however, explicit rounding modes may be specified in various DFP instructions.

Like HFP, DFP numbers can be normalized or unnormalized. Either normalized or unnormalized numbers may be used as operands for any DFP operation. For DFP, a normalized number is one having a nonzero leftmost significand digit. Because of the possibility of unnormalized numbers, the same value can have multiple representations in a given DFP format. The representations having the same value are called members of a cohort. Unlike HFP, DFP instructions generate normalized results for greater precision only when the result is inexact. When the result is exact, most DFP instructions produce a value in the form that preserves information called the quantum.

**Canonical DFP Data**

A canonical DFP number has only canonical declets, that is, the digits in the trailing-significand field are encoded using only the preferred DPD codes. A canonical DFP infinity has bit 6 and all bits to the right of this in the format set to zeros. A canonical DFP NaN has zeros in all bits to the right of the NaN-type bit in the combination field and only canonical declets in the trailing significand field.

Noncanonical DFP numbers, infinities, and NaNs are accepted as source operands, but all DFP results are canonical.

---

1. Subnormal numbers were previously called denormalized numbers.
Comparison of Floating-Point Number Representations

Floating-Point Number Ranges
Figure 9-1 shows the range of numbers, in decimal form, that can be represented in different floating-point formats.

<table>
<thead>
<tr>
<th></th>
<th>Type</th>
<th>Short</th>
<th>Long</th>
<th>Extended</th>
</tr>
</thead>
<tbody>
<tr>
<td>Nmax</td>
<td>HFP</td>
<td>±7.2×10^75</td>
<td>±7.2×10^75</td>
<td>±7.2×10^75</td>
</tr>
<tr>
<td></td>
<td>BFP</td>
<td>±3.4×10^38</td>
<td>±1.8×10^308</td>
<td>±1.2×10^4832</td>
</tr>
<tr>
<td></td>
<td>DFP</td>
<td>±1.0×10^97</td>
<td>±1.0×10^385</td>
<td>±1.0×10^6145</td>
</tr>
<tr>
<td>Nmin</td>
<td>BFP</td>
<td>±1.2×10^38</td>
<td>±2.2×10^306</td>
<td>±3.4×10^4832</td>
</tr>
<tr>
<td></td>
<td>DFP</td>
<td>±1.0×10^38</td>
<td>±1.0×10^383</td>
<td>±1.0×10^6143</td>
</tr>
<tr>
<td>Dmin</td>
<td>HFP</td>
<td>±5.1×10^85</td>
<td>±1.2×10^34</td>
<td>±1.7×10^111</td>
</tr>
<tr>
<td></td>
<td>BFP</td>
<td>±4.9×10^95</td>
<td>±4.9×10^324</td>
<td>±6.5×10^9966</td>
</tr>
<tr>
<td></td>
<td>DFP</td>
<td>±1.0×10^101</td>
<td>±1.0×10^398</td>
<td>±1.0×10^6176</td>
</tr>
</tbody>
</table>

Explanation:
- **Dmin**: Smallest (in magnitude) representable subnormal (BFP or DFP) or nonzero unnormalized (HFP) number.
- **Nmax**: Largest (in magnitude) representable number.
- **Nmin**: Smallest (in magnitude) representable normal (BFP or DFP) or normalized (HFP) number.

Values are decimal approximations for all of the HFP, BFP, and DFP formats.

Figure 9-1. Decimal Approximations of Number Ranges for HFP, BFP, and DFP Formats

Equivalent Floating-Point Number Representations
The exponent of an HFP number is represented in the format as an unsigned seven-bit binary integer called the characteristic. The characteristic is obtained by adding 64 to the exponent value (excess-64 notation). The range of the characteristic is 0 to 127, which corresponds to an exponent range of -64 to +63.

The exponent of a BFP or DFP datum is represented in the format as an unsigned binary integer called the biased exponent. The biased exponent is obtained by adding a bias to the exponent value. The number of bit positions containing the biased exponent, the value of the bias, and the exponent range depend on the data format (short, long, or extended) and are shown for the three formats in Figure 19-4 on page 19-3 and the three DFP formats in Figure 20-3 on page 20-6. Biased exponents are similar to the characteristics of the HFP format, except that, for BFP, special meanings are attached to biased exponents of all zeros and all ones. This is discussed in the section “Classes of BFP Data” on page 19-4.

In each of the three BFP or HFP formats, the binary or hexadecimal point of a number, respectively, is considered to be to the left of the leftmost fraction digit. To the left of the point there is an implied unit digit, which is considered to be zero for HFP numbers or, for BFP numbers, one for normal numbers and zero for zeros and subnormal numbers.

Figure 9-2 on page 9-6 and Figure 9-3 on page 9-7 give examples of the closest representation of the same numbers in the BFP, DFP, and HFP formats, with BFP and DFP values being rounded to nearest and HFP values being truncated.

The figures do not necessarily show the results of conversions exactly. Rounding errors may make a small difference. Also, Figure 9-2 on page 9-6 shows corresponding rounded short-format numbers, not the long HFP results of conversion from short BFP operands.
<table>
<thead>
<tr>
<th>Value</th>
<th>S</th>
<th>BE or C</th>
<th>Trailing Significand</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.0</td>
<td>B 0 011 1111 1</td>
<td>000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 100 0001</td>
<td>0001 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 010 0010 0100</td>
<td>0000 0000 0000 0001 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[10×10⁻¹]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0.5</td>
<td>B 0 011 1111 0</td>
<td>000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 100 0000</td>
<td>1000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 010 0010 0100</td>
<td>0000 0000 0000 0000 0010 0101</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[5×10⁻¹]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1/64</td>
<td>B 0 011 1100 1</td>
<td>000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 111 1111</td>
<td>0100 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 010 0011 1111</td>
<td>0000 0101 0111 0010 0101</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[15625×10⁻¹]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>+0</td>
<td>B 0 000 0000 0</td>
<td>000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 000 0000</td>
<td>0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 010 0010 0101</td>
<td>0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[+0×10⁰]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>-0</td>
<td>B 1 000 0000 0</td>
<td>000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 1 000 0000</td>
<td>0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 1 010 0010 0101</td>
<td>0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[-0×10⁰]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>-15.0</td>
<td>B 1 100 0001 0</td>
<td>111 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 1 100 0001</td>
<td>1111 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 1 010 0010 0100</td>
<td>0000 0000 1101 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[-150×10⁻¹]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2⁰/₁₂₇</td>
<td>B 0 100 0000 0</td>
<td>011 0101 1011 0110 1110</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 100 0001</td>
<td>0010 1101 1011 1101 1111</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 010 1001 1111</td>
<td>1101 0111 0100 1100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[2857143×10⁻⁶]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2⁻¹₂₅</td>
<td>B 0 000 0000 0</td>
<td>000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 000 0001</td>
<td>0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 000 0111 1001</td>
<td>0011 1101 0110 0101 0101 0101</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[1175494×10⁻⁶⁴]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2⁻¹₀²₄</td>
<td>B 0 000 0000 0</td>
<td>000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 000 1011</td>
<td>1000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 000 0111 0010</td>
<td>1000 0000 0101 0101 1110</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[1401298×10⁻⁵¹]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2⁻¹⁰²₃</td>
<td>B 0 111 1111 0</td>
<td>111 1111 1111 1111 1111 1111</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 110 0000</td>
<td>1111 1111 1111 1111 1111 1111</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 100 1100 0101</td>
<td>1000 0000 1001 0010 1101</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[3402823×10⁻⁶⁵]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2⁻¹⁰²⁴</td>
<td>B 0 000 0000 0</td>
<td>000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>H 0 000 1111</td>
<td>1111 1111 1111 1111 1111 1111</td>
<td></td>
</tr>
<tr>
<td></td>
<td>D 0 101 0010 1001</td>
<td>1010 1000 1100 1010 1000</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[4523128×10⁻⁶⁸]</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Explanation:

B  BFP.
BE or C Biased exponent of BFP number, combination field of DFP number, or characteristic of HFP number.
D  DFP.
H  HFP.
S  Sign.

Figure 9-2. Examples of Floating-Point Numbers in Short Format
The resolution of a floating-point format may be described in terms of the spacing between adjacent representable numbers in the format. This is called an ulp (unit in the last place). Thus, for example, when rounding to nearest, the maximum error is 1/2 ulp. The magnitude of an ulp is directly related to the precision of the format. Another way to measure the resolution of the format in the vicinity of a particular value is in terms of relative spacing, which is simply the value of an ulp divided by the value of the number. Relative spacing may be converted to a form called effective width, which is very similar to precision. The effective width ($W_x$) for any particular normalized floating-point value, $v$, is defined as:

$$W_x(v) = \log_x(v/u)$$

### Table: Examples of Floating-Point Numbers

<table>
<thead>
<tr>
<th>Value</th>
<th>S</th>
<th>BE or C</th>
<th>Trailing Significand</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.0</td>
<td>011 1111 1111</td>
<td>0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td>0.5</td>
<td>010 0000 0001</td>
<td>0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td>1/64</td>
<td>011 1111 1001</td>
<td>0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td>+0</td>
<td>0000 0000 0000</td>
<td>0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td>-0</td>
<td>0000 0000 0000</td>
<td>0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td>-15.0</td>
<td>010 0000 0010</td>
<td>0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000</td>
<td></td>
</tr>
<tr>
<td>$2^{1022}$</td>
<td>H</td>
<td>Zero (number too small)</td>
<td>0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000</td>
</tr>
<tr>
<td>$2^{1023}$</td>
<td>B</td>
<td>0010 0000 0000</td>
<td>0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000</td>
</tr>
<tr>
<td>$2^{1024}$F</td>
<td>F=1-2^{56}</td>
<td>H</td>
<td>Not representable</td>
</tr>
<tr>
<td>$2^{200}$</td>
<td>B</td>
<td>100 1111 1111</td>
<td>1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111</td>
</tr>
<tr>
<td>$2^{248}$F</td>
<td>F=1-2^{56}</td>
<td>H</td>
<td>Not representable</td>
</tr>
<tr>
<td>Explanation:</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B</td>
<td>BFP.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>BE or C</td>
<td>Biased exponent of BFP number, combination field of DFP number, or characteristic of HFP number.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>D</td>
<td>DFP.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>H</td>
<td>HFP.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>Sign.</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 9-3. Examples of Floating-Point Numbers in Long Format
Where:

<table>
<thead>
<tr>
<th>Symbol or Formula</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Va</td>
<td>9.99</td>
</tr>
<tr>
<td>Vb</td>
<td>10.0</td>
</tr>
<tr>
<td>Vc</td>
<td>10.1</td>
</tr>
<tr>
<td>Vb-Va</td>
<td>0.01</td>
</tr>
<tr>
<td>Vc-Vb</td>
<td>0.1</td>
</tr>
</tbody>
</table>

The distance between points Va and Vb (Vb-Va) represents a resolution of one part in a thousand; whereas, the distance between points Vb and Vc (Vc-Vb) represents a resolution of one part in a hundred. In the first case, the effective width is three digits; in the second case, it is only two digits. For other values in the format, the effective width lies between these two extremes.

**Floating-Point Data in Storage**

All floating-point data formats appear in storage in the same left-to-right sequence as all other data formats. Bits of a data format that are numbered 0-7 constitute the byte in the leftmost (lowest-numbered) byte location in storage, bits 8-15 form the byte in the next sequential location, and so on. (See also the section “Storage Addressing” on page 3-2.)

Most of the floating-point instructions are defined in detail in this publication in Chapter 18, “Hexadecimal-Floating-Point Instructions,” Chapter 19, “Binary-Floating-Point Instructions,” and Chapter 20, “Decimal-Floating-Point Instructions.” This chapter, Chapter 9, defines in detail instructions called floating-point-support (FPS) instructions. The FPS instructions either have operands that may be in any floating-point format or have the function of converting between formats. This chapter also provides summary information about all of the floating-point instructions.

**Registers And Controls**

**Floating-Point Registers**

All floating-point instructions (FPS, BFP, DFP, and HFP) use the same 16 floating-point registers. The floating-point registers are identified by the numbers 0-15 and are designated by a four-bit R field in float-
Floating-point instructions. Each floating-point register is 64 bits long and can contain either a short (32-bit) or a long (64-bit) floating-point operand.

A short floating-point datum requires only the leftmost 32 bit positions of a floating-point register. The rightmost 32 bit positions of the register are ignored when the register is the source of an operand in the short format, and they remain unchanged when a short result is placed in the register.

A datum in the extended (128-bit) format occupies a register pair. Register pairs are formed by coupling the 16 registers as follows: 0 and 2, 4 and 6, 8 and 10, 12 and 14, 1 and 3, 5 and 7, 9 and 11, and 13 and 15.

Each of the eight pairs is referred to by the number of the lower-numbered register of the pair.

Additional Floating-Point (AFP) Registers
Floating-point registers 0, 2, 4, and 6 are ones that were originally available on ESA/390 models. The remaining 12 floating-point registers (1, 3, 5, and 7-15) were added to ESA/390 and are referred to as the additional floating-point (AFP) registers. The AFP registers can be used only if bit 45 of control register 0, the AFP-register-control bit, is one. Attempting to use an AFP register when the AFP-register-control bit is zero results in an AFP-register data exception (DXC 1).

Valid Floating-Point-Register Designations
Any installed register may be designated by an instruction to specify the register location of a short or long floating-point operand.

An instruction specifying a floating-point operand in the extended format must designate register 0, 1, 4, 5, 8, 9, 12, or 13; otherwise, a specification exception is recognized.

Floating-Point-Control (FPC) Register
The floating-point-control (FPC) register is a 32-bit register that contains mask bits, flag bits, a data-exception code, and two rounding-mode fields. An overview of the FPC register is shown in Figure 9-5.

Details are shown in Figure 9-6 and in Figure 9-8. (In Figure 9-6, the abbreviations “IM” and “SF” are based on the terms “interruption mask” and “status flag,” respectively.)

The bits of the FPC register are often referred to as, for example, FPC 1.0, meaning bit 0 of byte 1 of the register.

<table>
<thead>
<tr>
<th>Byte</th>
<th>Bit(s)</th>
<th>Name</th>
<th>Abbr.</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>IEEE-invalid-operation mask</td>
<td>IMi</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>IEEE-division-by-zero mask</td>
<td>IMz</td>
</tr>
<tr>
<td>0</td>
<td>2</td>
<td>IEEE-overflow mask</td>
<td>IMo</td>
</tr>
<tr>
<td>0</td>
<td>3</td>
<td>IEEE-underflow mask</td>
<td>IMu</td>
</tr>
<tr>
<td>0</td>
<td>4</td>
<td>IEEE-inexact mask</td>
<td>IMx</td>
</tr>
<tr>
<td>0</td>
<td>5</td>
<td>Quantum-exception mask</td>
<td>IMq</td>
</tr>
<tr>
<td>0</td>
<td>6-7</td>
<td>(Unassigned)</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>IEEE-invalid-operation flag</td>
<td>SFi</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>IEEE-division-by-zero flag</td>
<td>SFz</td>
</tr>
<tr>
<td>1</td>
<td>2</td>
<td>IEEE-overflow flag</td>
<td>SFo</td>
</tr>
<tr>
<td>1</td>
<td>3</td>
<td>IEEE-underflow flag</td>
<td>SFu</td>
</tr>
<tr>
<td>1</td>
<td>4</td>
<td>IEEE-inexact flag</td>
<td>SFx</td>
</tr>
<tr>
<td>1</td>
<td>5</td>
<td>Quantum-exception flag</td>
<td>SFq</td>
</tr>
<tr>
<td>1</td>
<td>6-7</td>
<td>(Unassigned)</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0-7</td>
<td>Data-exception code</td>
<td>DXC</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>(Unassigned)</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>1-3</td>
<td>DFP rounding mode</td>
<td>DRM</td>
</tr>
<tr>
<td>3</td>
<td>4</td>
<td>(Unassigned)</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>5-7</td>
<td>BFP rounding mode</td>
<td>BRM</td>
</tr>
</tbody>
</table>

Figure 9-5. FPC Register Overview

Figure 9-6. FPC-Register Bit Assignments
When the floating-point extension facility is installed, the FPC register contains six IEEE mask bits and six IEEE flag bits that each correspond to one of the six IEEE exceptions that may be recognized when an IEEE computational instruction is executed. When the floating-point extension facility is not installed, the quantum exception is not recognized; the mask bit FPC 0.5 and the status flag bit FPC 1.5 corresponding to the quantum exception are unsupported and are zeros.

The mask bits, when one, in the FPC register cause an interruption to occur if an exception is recognized. If the mask bit for an exception is zero, the recognition of the exception causes the corresponding flag bit to be set to one. Thus, a flag bit indicates whether the corresponding exception has been recognized at least once since the program last set the flag bit to zero. Except for PFPO, the mask bits are ignored, and the flag bits remain unchanged, when exceptions are recognized for floating-point-support (FPS) and HFP instructions.

The IEEE flag bits in the FPC register are set to zero only by explicit program action, initial CPU reset, clear reset, or power-on reset.

Note: The quantum exception is not part of the IEEE Standard 754-2008 (see Reference [17.] on page xxviii). However, since this data exception with its mask and status flag in the FPC is handled very much like the five IEEE exceptions, this architecture lists the quantum exception among the IEEE exceptions.

**FPC DXC Byte**

Byte 2 of the FPC register contains the data-exception code (DXC), which is an eight-bit code indicating the specific cause of a data exception. When the AFP-register-control bit, bit 45 of control register 0, is one and a program interruption causes the DXC to be placed at real location 147, the DXC is also placed in the DXC field of the FPC register. The DXC field in the FPC register remains unchanged when the AFP-register-control bit is zero or when any other program exception is reported. The DXC is described in "Data-Exception Code (DXC)" on page 6-16.

The DXC is a code, meaning it should be treated as an integer rather than as individual bits. However, when bits 6 and 7 are zero, bits 0-5 are bit significant; bits 0-4 (i, z, o, u, and x) are trap flags and correspond to the same bits in bytes 0 and 1 of the FPC register (IEEE masks and IEEE flags), and bit 5 (y) is used in conjunction with bit 4, inexact (x), to indicate that the result has been incremented in magnitude.

When the floating-point extension facility is installed, DXC bit 5 (q) is also the quantum-exception trap flag. The trap flag for an exception, instead of the IEEE flag, is set to one when an interruption for the exception is enabled by the corresponding IEEE mask bit.

**Operations on the FPC Register**

The following unprivileged instructions allow problem-state programs to operate on the FPC register:

```
EXTRACT FPC (DXC 2)
LOAD FPC (DXC 2)
```
LOAD FPC AND SIGNAL (DXC 3)
SET BFP ROUNDDING MODE (DXC 2)
SET DFP ROUNDDING MODE (DXC 3)
SET FPC (DXC 2)
SET FPC AND SIGNAL (DXC 3)
STORE FPC (DXC 2)

These instructions are subject to the AFP-register-control bit, bit 45 of control register 0. An attempt to execute any of the above instructions when the AFP-register-control bit is zero results in a data exception. The term (DXC 2) or (DXC 3) after the name indicates the type of exception: that is, BFP-instruction data exception, (DXC 2), or DFP-instruction data exception, (DXC 3), respectively.

Programming Note: The use of DXC 2 and DXC 3 for these floating-point-support (FPS) instructions is rather arbitrary, but assuming a valid operating system, these exceptions are never reported to the user, as the operating system will set bit 45 of control register 0 to one and re-issue the instruction.

AFP-Register-Control Bit

Bit 45 of control register 0 is the AFP-register-control bit. The AFP registers, the BFP instructions, the DFP instructions, and PFPO can be used successfully only when the AFP-register-control bit is one. Attempting to use one of the 12 additional floating-point registers or executing PFPO when the AFP-register-control bit is zero results in an AFP-register data exception (DXC 1). Attempting to execute any BFP instruction when the AFP-register-control bit is zero results in a BFP-instruction data exception (DXC 2). Attempting to execute any DFP instruction when the AFP-register-control bit is zero results in a DFP-instruction data exception (DXC 3).

DXC 2 and 3 are mutually exclusive and are of higher priority than any other DXC. Thus, for example, DXC 2 (BFP instruction) takes precedence over any IEEE exception; and DXC 3 (DFP instruction) takes precedence over any IEEE exception. As another example, if the conditions for both DXC 3 (DFP instruction) and DXC 1 (AFP register) exist, DXC 3 is reported.

If the conditions for both a data exception and a specification exception exist, it is unpredictable which exception is reported.

The initial value of the AFP-register-control bit is zero.

IEEE Computational Operations

Note: The following section primarily discusses the BFP and DFP formats, however the topics on rounding also discuss the HFP format, as indicated in the text.

Instructions which operate on BFP or DFP source operands or produce BFP or DFP results and recognize IEEE exceptions are called IEEE computational operations, and the associated operands and results are sometimes referred to as IEEE operands and IEEE results, respectively.

Execution of IEEE computational operations normally follows a certain pattern. Source operands are first tested for special cases and then processed to form a result. The priority for testing of special cases is SNaN, QNaN, infinity, and then finite number.

If a source operand is an SNaN, an IEEE-invalid-operation exception is recognized; and, in the non-trap case, the result is set to the corresponding QNaN.

In the absence of a source SNaN, if a source operand is a QNaN the result is set to that QNaN.

Handling of the case when more than one source operand is a NaN is covered in the individual instruction descriptions.

In the absence of a NaN, if an operand is an infinity, special “infinity arithmetic” rules are followed to produce the result.

Programming Note: PERFORM FLOATING-POINT OPERATION is an IEEE computational operation.

Intermediate Values

In the normal case (when all source operands are finite numbers), first, a precise intermediate value is produced, then a rounded intermediate value. In the absence of trapped overflow and trapped underflow, the rounded intermediate value is used as the delivered value. For trapped overflow and trapped underflow, the rounded intermediate value is divided by a scale factor to produce a scaled value, which is used as the delivered value. Finally, the delivered value is placed in the target location. For DFP, since the
cohort for the delivered value may have multiple members, one member from the cohort must be selected. Selection is performed by choosing the member having a quantum closest to the preferred quantum (or for trapped overflow and trapped underflow, a scaled preferred quantum).

Precise Intermediate Value
Every IEEE computational operation producing a numeric result computes a value called the precise intermediate value. This is the value that would have been computed were both the precision and exponent range unbounded.

Precision-Rounded Value
Except when otherwise specified, the precise intermediate value is rounded to the precision of the target format, but with unbounded exponent range. This process is called target-precision-constrained rounding, and the value selected by this type of rounding is called the precision-rounded value.

Denormalized Value
For IEEE targets, when the IEEE-underflow trap is disabled and the tininess condition exists, the precise intermediate value is rounded to fit in the destination format (that is, with both precision and exponent range of the target format). This process is called denormalization rounding and the value selected by this type of rounding is called the denormalized value.

Functionally-Rounded Value
The instructions CONVERT TO FIXED, LOAD FP INTEGER, QUANTIZE, and REROUND, as an integral part of the function, take a source operand and modify it to fit in a subset of the destination format. This process is called functionally-constrained rounding and the value selected by this type of rounding is called the functionally-rounded value.

Rounded Intermediate Value
In any particular instance, only one of the three rounding processes is performed and the value selected (precision-rounded value, denormalized value, or functionally-rounded value) is generically referred to as the rounded intermediate value.

Scaled Value
For both overflow and underflow when the associated trap is enabled, the precision-rounded value is scaled to bring it into the representable exponent range of the target. This is called the scaled value and is derived as explained in the next section.

Scale Factor ($\Psi$)
IEEE-overflow trap action and IEEE-underflow trap action produce a scaled value using a scale factor. The scaled value ($z$) is computed from the precision-rounded value ($g$) using the scale factor ($\Psi$) as follows:

$$z = g \times \Psi$$

Unsigned Scaling Exponent ($\alpha$)
For BFP and DFP instructions, the scale factor ($\Psi$) is computed using the unsigned scaling exponent ($\alpha$) and different formulas are used for overflow and underflow.

For overflow:
$$\Psi = b^\alpha$$

For underflow:
$$\Psi = b^{-\alpha}$$

where $b$ is the radix of the target (2 for BFP and 10 for DFP). The unsigned scaling exponent ($\alpha$) depends on the type of operation and operand format.

For all BFP operations except LOAD ROUNDED, $\alpha$ depends on the target format and is 192 for short, 1536 for long, and 24576 for extended. For BFP LOAD ROUNDED, $\alpha$ depends on the source format, and is 512 for long and 8192 for extended.

For all DFP operations except LOAD ROUNDED, $\alpha$ depends on the target format and is 576 for long and 9216 for extended. For DFP LOAD ROUNDED, $\alpha$ depends on the source format, and is 192 for long and 3072 for extended.

Signed Scaling Exponent ($\Omega$)
For PFPO convert floating-point radix, the scale factor ($\Psi$) is computed using the signed scaling exponent ($\Omega$) and the formula for the scale factor ($\Psi$) is the same for overflow and underflow:

$$\Psi = b^\Omega$$

Where $b$ is the radix (2, 10, and 16) for BFP, DFP and HFP, respectively. Thus, for overflow, the signed scaling exponent ($\Omega$) is a positive value, and for underflow it is a negative value.
IEEE Rounding

Rounding takes an input value, and, using the effective rounding method, selects a value from a permissible set. The input value, considered to be infinitely-precise, may be an operand of an instruction or the numeric output from an arithmetic operation. The effective rounding method may be the current rounding method specified in the BFP-rounding-mode or DFP-rounding-mode field of the FPC register; or, for some instructions, an explicit rounding method is specified by a modifier field. For the PFPO-convert-floating-point-radix operation, rounding is specified by a field in an implicit register.

For target-precision-constrained rounding and denormalization rounding, the input is the precise intermediate value. For functionally-constrained rounding, the input is a source operand.

Permissible Set
Rounding selects a value from the permissible set. A permissible set is a set of values, and not representations; thus, for DFP, the selection of a member from the cohort is considered to be performed after rounding. A permissible set differs from the values representable in a particular format in the following ways:

1. A permissible set does not include infinity. Infinity is handled as a special case.
2. For target-precision-constrained rounding, the permissible set is considered to have an unbounded exponent range.
3. For denormalization rounding, the permissible set is limited to the values representable in a particular format.
4. For LOAD FP INTEGER, the permissible set contains only integral values.
5. For QUANTIZE, the permissible set is similar to LOAD FP INTEGER, containing only those values which are integral multiples of the requested quantum.
6. For REROUND, the permissible set contains only those values which can be represented within the requested precision.

Selection of Candidates
If a member of the permissible set is equal in value to the input value, then that member is selected; otherwise, two adjacent candidates with the same sign as the input value are chosen from the permissible set. One candidate, called TZ (toward zero), is the member of the permissible set nearest to and smaller in magnitude than the input value; the other candidate, called AZ (away from zero), is the member of the permissible set nearest to and larger in magnitude than the input value. Which of the two candidates is selected depends on the rounding method.

Ties
Three rounding methods depend on a condition called a “tie.” This condition exists when the two candidates are equidistant from the input value.

Voting Digit and Common-Rounding-Point View
Two rounding methods depend on the value of the voting digit of each candidate. (Each “digit” is an integral value from zero to one less than the radix. Thus, a BFP digit is one bit, an HFP digit is four bits, and a DFP digit is a value from zero to nine.) The voting digit is the units digit of the significand when considered in the common-rounding-point view.

Without changing the value of a floating-point number, the significand may be viewed with the implied radix point in different positions, provided a corresponding adjustment is made to the exponent. In the common-rounding-point view, an implied radix point (called the common rounding point) and an associated exponent are selected for the input value and the two candidates, TZ and AZ. The common-rounding point is selected to satisfy the following requirements:

1. The input value and the two candidates all have the same exponent.
2. The significand of TZ is equal to the significand of the input value truncated at the rounding point.
3. The significand of AZ is one greater in magnitude than the significand of TZ.

Rounding Methods
Figure 9-8 and Figure 9-7 on page 9-10 show the implicit rounding methods available for BFP and DFP operations respectively. The section “Explicit Rounding Methods” on page 9-16 describes rounding methods that may be explicitly specified in an instruction, overriding the implicit rounding method. The rounding methods are as follows:
**Round to nearest with ties to even:** The candidate nearest to the input value is selected. In case of a tie, the candidate selected is the one whose voting digit has an even value.

**Round toward 0:** The candidate that is smaller in magnitude is selected.

**Round toward +∞:** The candidate that is algebraically greater is selected.

**Round toward −∞:** The candidate that is algebraically less is selected.

**Round to nearest with ties away from 0:** The candidate nearest to the input value is selected. In case of a tie, the candidate selected is the one that is larger in magnitude.

**Round to nearest with ties toward 0:** The candidate nearest to the input value is selected. In case of a tie, the candidate selected is the one that is smaller in magnitude.

**Round away from 0:** The candidate that is greater in magnitude is selected.

**Round to prepare for shorter precision:** For a BFP or HFP permissible set, the candidate selected is the one whose voting digit has an odd value. For a DFP permissible set, the candidate that is smaller in magnitude is selected, unless its voting digit has a value of either 0 or 5; in that case, the candidate that is greater in magnitude is selected.

**Programming Notes:**

1. The two candidates are defined as: “nearest to and smaller” and “nearest to and larger”. Note that the simpler definition, “the two closest values,” is incorrect, as it is possible that the two closest values to the input value can be on the same side (toward zero). To illustrate this, Figure 9-9 on page 9-15 gives an example of rounding the integer value 10,000,003 to DFP short. Several members in the permissible set near this value are shown in three views: left-units view, right-units view, and integer view. The fourth column shows the distance of each member from the input value. In this example, the four closest members are all smaller in magnitude than the input value. Although the example is shown using DFP, corresponding examples can be shown for both BFP and HFP. In the extreme case, the number of members in the permissible set which are closer than candidate AZ, is 2, 10, and 16, for BFP, DFP, and HFP, respectively.

2. Except for rounding methods using the voting digit, rounding can normally be considered to be performed using values independent of the representation and the view. Figure 9-10 on page 9-15 is an example, using the instruction LOAD FP INTEGER, to illustrate the concepts of different representations, views, rounding point, common-rounding-point view, and voting digit. In the example, the input value (source operand) is 29.5 and the two candidates are 29 and 30. The figure shows all three of these values using the left-units, right-units, and common-rounding-point views in both decimal and binary representations. Note that as shown in the left-units and right-units view columns, the rightmost digit is odd for both TZ and AZ. (But as represented in all BFP formats, these values would have an even rightmost digit; and as represented in DFP formats, these values could have an even or odd rightmost digit, depending on the quantum.) The voting digit can be identified in the common-rounding-point view as the digit to the immediate left of the rounding point. In both the decimal and binary representations, candidate TZ has an odd voting digit and candidate AZ has an even voting digit.

LOAD FP INTEGER produces consistent results between decimal and binary for five of the six rounding methods currently supported by the BFP instruction; for the round-to-prepare-for-shorter-precision rounding method, this is not always the case. Figure 9-11 on page 9-16 shows results of LOAD FP INTEGER for several input values for all eight rounding methods. Only in the round-to-prepare-for-shorter-precision method are the results different for decimal and binary.

3. An example of LOAD ROUNDED (long to short DFP) is shown in Figure 9-12 on page 9-16. In this example, the integer 99,999,995 is rounded from DFP long to DFP short. The cohort for candidate TZ in this case, has only one member and is odd. The cohort of candidate AZ has seven members, one of which is odd and the other six are even. The common-rounding-point view makes it clear that in this case, candidate AZ should be considered to be even.
4. The rightmost digit and the voting digit of a candidate are not necessarily the same digit. Figure 9-13 on page 9-16 and Figure 9-14 on page 9-16 give two examples using the instruction REROUND (long DFP). In both examples, the requested significance is one (Result Digits=1). The input value is 95 in the first example and 150 in the second example. Note that candidate AZ in the first example is the same value as candidate TZ in the second example. In the first example, this member is considered to be even, and in the second example it is considered to be odd.

<table>
<thead>
<tr>
<th>Value in Permissible Set</th>
<th>Distance from 10000003</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Left-Units View</td>
<td>Right-Units View</td>
<td>Integer View</td>
</tr>
<tr>
<td>9.999996×10⁰</td>
<td>9999996×10⁰</td>
<td>9999996</td>
</tr>
<tr>
<td>9.999997×10⁰</td>
<td>9999997×10⁰</td>
<td>9999997</td>
</tr>
<tr>
<td>9.999998×10⁰</td>
<td>9999998×10⁰</td>
<td>9999998</td>
</tr>
<tr>
<td>9.999999×10⁰</td>
<td>9999999×10⁰</td>
<td>9999999</td>
</tr>
<tr>
<td>1.000000×10¹</td>
<td>1000000×10⁻¹</td>
<td>1000000</td>
</tr>
<tr>
<td>1.000001×10¹</td>
<td>1000001×10⁻¹</td>
<td>10000010</td>
</tr>
<tr>
<td>1.000002×10¹</td>
<td>1000002×10⁻¹</td>
<td>10000020</td>
</tr>
</tbody>
</table>

Explanation:

* Closer than AZ.
AZ Selected as candidate AZ (away from zero).
TZ Selected as candidate TZ (toward zero).

Figure 9-9. Choosing Candidates (short DFP)

<table>
<thead>
<tr>
<th>Participant</th>
<th>Decimal</th>
<th>Binary¹</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Left-Units View</td>
<td>Right-Units View</td>
</tr>
<tr>
<td>Input Value</td>
<td>2.95×10¹</td>
<td>295×10¹</td>
</tr>
<tr>
<td>Candidate TZ</td>
<td>2.9×10¹</td>
<td>29×10¹</td>
</tr>
<tr>
<td>Candidate AZ</td>
<td>3.0×10¹</td>
<td>3×10¹</td>
</tr>
</tbody>
</table>

Explanation:

¹ Significand is shown in binary, exponent in decimal.

Figure 9-10. LOAD FP INTEGER - Decimal and Binary
Explicit Rounding Methods

The floating-point-support instruction CONVERT HFP TO BFP includes an M3 modifier field which can specify any of six rounding methods. One HFP instruction (CONVERT TO FIXED); three BFP instructions (CONVERT TO FIXED, DIVIDE TO INTEGER, and LOAD FP INTEGER); and five DFP instructions (CONVERT TO FIXED, LOAD FP INTEGER, LOAD ROUNDED, QUANTIZE, and REROUND) also include either an M3 modifier field or a similar M4 modifier field. When the floating-point extension facility is installed, four more BFP instructions (CONVERT FROM FIXED, CONVERT FROM LOGICAL, CONVERT TO LOGICAL, and LOAD ROUNDED) and seven more DFP instructions (ADD, CONVERT FROM FIXED, CONVERT FROM LOGICAL, CONVERT TO LOGICAL, DIVIDE, MULTIPLY, and SUBTRACT) also include an M3 or M4 modifier field.

The handling of an M3 or M4 value of zero depends on the type of instruction. For BFP instructions, an M3 or M4 value of zero causes rounding to be performed according to the current BFP rounding mode specified in the FPC register. For DFP instructions, an M3 or M4 value of zero causes rounding to be performed according to the current DFP rounding mode speci-

<table>
<thead>
<tr>
<th>Input Value</th>
<th>RNTE</th>
<th>RZ</th>
<th>RP</th>
<th>RM</th>
<th>RNTA</th>
<th>RNTZ</th>
<th>RA</th>
<th>RFS</th>
</tr>
</thead>
<tbody>
<tr>
<td>-9.5</td>
<td>-10</td>
<td>-9</td>
<td>-9</td>
<td>-10</td>
<td>-10</td>
<td>-10</td>
<td>-10</td>
<td>-9</td>
</tr>
<tr>
<td>-5.5</td>
<td>-6</td>
<td>-5</td>
<td>-5</td>
<td>-6</td>
<td>-6</td>
<td>-6</td>
<td>-6</td>
<td>-5</td>
</tr>
<tr>
<td>-2.5</td>
<td>-2</td>
<td>-2</td>
<td>-2</td>
<td>-3</td>
<td>-3</td>
<td>-3</td>
<td>-3</td>
<td>-2</td>
</tr>
<tr>
<td>-1.5</td>
<td>-2</td>
<td>-1</td>
<td>-1</td>
<td>-2</td>
<td>-2</td>
<td>-2</td>
<td>-2</td>
<td>-1</td>
</tr>
<tr>
<td>-0.5</td>
<td>-0</td>
<td>-0</td>
<td>-0</td>
<td>-1</td>
<td>-1</td>
<td>-1</td>
<td>-1</td>
<td>-1</td>
</tr>
<tr>
<td>+0.5</td>
<td>+0</td>
<td>+0</td>
<td>+1</td>
<td>+1</td>
<td>+1</td>
<td>+1</td>
<td>+1</td>
<td>+1</td>
</tr>
<tr>
<td>+1.5</td>
<td>+2</td>
<td>+1</td>
<td>+2</td>
<td>+2</td>
<td>+2</td>
<td>+2</td>
<td>+2</td>
<td>+1</td>
</tr>
<tr>
<td>+2.5</td>
<td>+2</td>
<td>+2</td>
<td>+3</td>
<td>+2</td>
<td>+2</td>
<td>+3</td>
<td>+3</td>
<td>+3</td>
</tr>
<tr>
<td>+5.5</td>
<td>+6</td>
<td>+6</td>
<td>+6</td>
<td>+6</td>
<td>+6</td>
<td>+6</td>
<td>+6</td>
<td>+5</td>
</tr>
<tr>
<td>+9.5</td>
<td>+10</td>
<td>+9</td>
<td>+10</td>
<td>+9</td>
<td>+10</td>
<td>+9</td>
<td>+9</td>
<td>+9</td>
</tr>
</tbody>
</table>

Explanation:

RNTE: Round to nearest with ties to even
RZ: Round toward 0
RP: Round toward +∞
RM: Round toward -∞
RNTA: Round to nearest with ties away from 0
RNTZ: Round to nearest with ties toward 0
RA: Round away from 0
RFS: Round to prepare for shorter precision

Figure 9-11. LOAD FP INTEGER Examples for All Rounding Methods

<table>
<thead>
<tr>
<th>Participant</th>
<th>Left-Units View</th>
<th>Right-Units View</th>
<th>Common-Rounding-Point View</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input Value</td>
<td>9.9999995×10⁻⁶</td>
<td>9999995×10⁻⁶</td>
<td>9999999.5×10⁻⁶</td>
</tr>
<tr>
<td>Candidate TZ</td>
<td>9.999999×10⁻⁶</td>
<td>9999999×10⁻⁶</td>
<td>9999999.0×10⁻⁶</td>
</tr>
<tr>
<td>Candidate AZ</td>
<td>1.0×10⁻⁶</td>
<td>1×10⁻⁶</td>
<td>1000000.0×10⁻⁶</td>
</tr>
</tbody>
</table>

Figure 9-12. LOAD ROUNDED (long to short DFP)

<table>
<thead>
<tr>
<th>Participant</th>
<th>Left-Units View</th>
<th>Right-Units View</th>
<th>Common-Rounding-Point View</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input Value</td>
<td>9.5×10⁻¹</td>
<td>95×10⁻¹</td>
<td>9.5×10⁻¹</td>
</tr>
<tr>
<td>Candidate TZ</td>
<td>9.0×10⁻¹</td>
<td>9×10⁻¹</td>
<td>9.0×10⁻¹</td>
</tr>
<tr>
<td>Candidate AZ</td>
<td>1.0×10⁻²</td>
<td>1×10⁻²</td>
<td>10.0×10⁻²</td>
</tr>
</tbody>
</table>

Figure 9-13. REROUND (long DFP), Result Digits=1, Input Value=95

<table>
<thead>
<tr>
<th>Participant</th>
<th>Left-Units View</th>
<th>Right-Units View</th>
<th>Common-Rounding-Point View</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input Value</td>
<td>1.5×10⁻²</td>
<td>15×10⁻¹</td>
<td>1.5×10⁻²</td>
</tr>
<tr>
<td>Candidate TZ</td>
<td>1.0×10⁻²</td>
<td>1×10⁻²</td>
<td>1.0×10⁻²</td>
</tr>
<tr>
<td>Candidate AZ</td>
<td>2.0×10⁻²</td>
<td>2×10⁻²</td>
<td>2.0×10⁻²</td>
</tr>
</tbody>
</table>

Figure 9-14. REROUND (long DFP), Result Digits=1, Input Value=150
fied in the FPC register. The floating-point-support instruction CONVERT HFP TO BFP and the HFP instruction CONVERT TO FIXED treat an M3 value of zero the same as five; that is, round toward zero.

For PERFORM FLOATING POINT OPERATION (PFPO), any of the rounding methods described in this section may be explicitly specified, or the program may specify the current BFP or DFP rounding method (in the floating-point-control register). The program-specified rounding method is used by PFPO regardless of whether the target-operand format is BFP, DFP or HFP.

**Summary of Rounding Action**

Figure 9-15 on page 9-17 summarizes the rounding action for floating-point-support (FPS), BFP, DFP, and HFP instructions.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD</td>
<td>MAC</td>
<td>RTZ</td>
<td>E</td>
<td>E</td>
</tr>
<tr>
<td>ADD NORMALIZED</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>ADD UNNORMALIZED</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>CONVERT BFP TO HFP</td>
<td>E</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>CONVERT FROM FIXED</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>CONVERT HFP TO BFP</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>CONVERT TO FIXED</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>DIVIDE</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>DIVIDE TO INTEGER</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>HALVE</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>LOAD FP INTEGER</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>LOAD ROUNDED</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>MULTIPLY</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>MULTIPLY AND ADD</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORMALIZED</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>MULTIPLY UNNORMALIZED</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>PERFORM FLOATING-POINT OPERATION</td>
<td>MBD</td>
<td>MAC</td>
<td>RTZ</td>
<td>RTZ</td>
</tr>
<tr>
<td>QUANTIZE</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
<tr>
<td>REROUND</td>
<td>MAC</td>
<td>RTZ</td>
<td>GD</td>
<td>GD</td>
</tr>
</tbody>
</table>

**Explanation:**

- **CBRM** Rounded according to current BFP rounding mode.
- **E** Result is exact, no rounding is required.
- **GD** Round using a guard digit; see the instruction definition. This is almost, but not quite, round toward 0.
- **M** Rounding is specified by a modifier field in the instruction. Five rounding methods are supported.
- **MA** Rounding is specified by a modifier field in the instruction. Six rounding methods are supported; current BFP rounding mode can also be specified.
- **MB** Rounding is specified by a modifier field in the instruction. When the floating-point extension facility is not installed, five rounding methods are supported; when the floating-point extension facility is installed, six rounding methods are supported; current BFP rounding mode can also be specified.
- **MBB** When the floating-point extension facility is not installed, rounding is specified by the current BFP rounding mode; four rounding modes are supported. When the floating-point extension facility is installed, rounding is specified by a modifier field in the instruction; six rounding modes are supported; current BFP rounding mode can also be specified.
- **MBD** Rounding is specified by a field in general register 0. Eight rounding methods are supported; current BFP rounding mode and current DFP rounding mode can also be specified.
- **MC** Rounding is specified by a modifier field in the instruction. When the floating-point extension facility is not installed, five rounding methods are supported; when the floating-point extension facility is installed, six rounding methods are supported; current BFP rounding mode cannot be specified.
- **MD** Rounding is specified by a modifier field in the instruction. Eight rounding methods are supported; current DFP rounding mode can also be specified.

*Figure 9-15. Comparison of Rounding Action (Part 2 of 3)*
This section defines handling of IEEE exceptions for most IEEE computational operations. For some instructions the action may differ from the general rules; including, for example, a special controls to suppress recognition of certain IEEE exceptions. These differences are described in the individual instruction descriptions.

The action taken for each IEEE exception is controlled by a mask bit in the FPC register. When an IEEE exception is recognized, one of two actions is taken:

- If the corresponding mask bit in the FPC register is zero, a default action, called IEEE nontrap action, is taken, as specified for each condition, and the corresponding flag bit in the FPC register is set to one. Program execution then continues normally.

- If the corresponding mask bit in the FPC register is one, an action, called IEEE trap action, is taken for that exception, a program interruption for a data exception occurs, and the operation is suppressed or completed, depending on the exception, and the data-exception code (DXC) assigned for that exception is provided. For PFPO, a control bit in GR0 can select alternate exception handling, where overflow or underflow can be reflected by completion with a distinguished condition code, avoiding the interruption.

### Concurrent IEEE Exceptions
IEEE-overflow or IEEE-underflow exception, IEEE-inexact exception, and quantum exception can coincide concurrently.

### IEEE Invalid Operation
An IEEE-invalid-operation exception is recognized when, in the execution of an IEEE computational operation, any of the following occurs:

1. An SNaN is encountered in an IEEE computational operation.
2. A QNaN is encountered in an unordered-signaling comparison (COMPARE AND SIGNAL with a QNaN operand).
3. An IEEE difference is undefined (addition of infinities of opposite sign, or subtraction of infinities of like sign).
4. An IEEE product is undefined (zero times infinity).
5. An IEEE quotient is undefined (DIVIDE instruction with both operands zero or both operands infinity).
6. A BFP remainder is undefined (DIVIDE TO INTEGER with a dividend of infinity or a divisor of zero).
7. A BFP square root is undefined (negative non-zero operand).
8. Any other IEEE computational operation whose result is either undefined or not representable in the target format.

Even though an invalid-operation condition exists, the exception is not recognized if recognition of the exception is suppressed by means of an IEEE-invalid-operation-exception control (XiC).

**IEEE-Invalid-Operation Nontrap Action:** IEEE-invalid-operation nontrap action occurs when the IEEE-invalid-operation exception is recognized and the IEEE-invalid-operation mask bit in the FPC register is zero. The operation is completed and the IEEE-invalid-operation flag bit in the FPC register is set to one. The result of the operation depends on the type of operation and the operands.

If the instruction performs a comparison, the comparison result is *unordered*.

If the instruction is one that produces an IEEE result and none of the operands is a NaN, the result is the default QNaN.

If the instruction is one that produces an IEEE result and one of the operands is a NaN, that operand becomes the result unchanged, except that an SNaN is first converted to the corresponding QNaN and, for DFP, NaNs are canonicalized.

**IEEE-Invalid-Operation Trap Action:** IEEE-invalid-operation trap action occurs when the IEEE-invalid-operation exception is recognized and the IEEE-invalid-operation mask bit in the FPC register is one. The operation is suppressed, and the exception is reported as a program interruption for a data exception with DXC 80 hex.

**IEEE Division-By-Zero**

An IEEE-division-by-zero exception is recognized when in IEEE division the divisor is zero and the dividend is a nonzero finite number.

**IEEE-Division-By-Zero Nontrap Action:** IEEE-division-by-zero nontrap action occurs when the IEEE-division-by-zero exception is recognized and the IEEE-division-by-zero mask bit in the FPC register is zero. The operation is completed and the IEEE-division-by-zero flag bit in the FPC register is set to one. The result is set to an infinity with a sign that is the exclusive or of the dividend and divisor signs.

**IEEE-Division-By-Zero Trap Action:** IEEE-division-by-zero trap action occurs when the IEEE-division-by-zero exception is recognized and the IEEE-division-by-zero mask bit in the FPC register is one. The operation is suppressed, and the exception is reported as a program interruption for a data exception with DXC 40 hex.

**IEEE Overflow**

An IEEE-overflow exception is recognized for an IEEE target when the precision-rounded value of an IEEE computational operation is greater in magnitude than the largest finite number (Nmax) representable in the target format.

**IEEE-Overflow Nontrap Action:** IEEE-overflow nontrap action occurs when the IEEE-overflow exception is recognized and the IEEE-overflow mask bit in the FPC register is zero. The operation is completed and the IEEE-overflow flag bit in the FPC register is set to one. The result of the operation depends on the sign of the precise intermediate value and on the effective rounding method:

1. For all round-to-nearest methods and round-away-from-0, the result is infinity with the sign of the precise intermediate value.
2. For round-toward-0 and round-to-prepare-for-shorter-precision, the result is the largest finite number of the format, with the sign of the precise intermediate value.
3. For round toward $+\infty$, the result is $+\infty$, if the sign is plus, or it is the negative finite number with the largest magnitude if the sign is minus.
4. For round toward $-\infty$, the result is the largest positive finite number if the sign is plus or $-\infty$ if the sign is minus.

**IEEE-Overflow Trap Action:** IEEE-overflow trap action occurs when the IEEE-overflow exception is recognized and the IEEE-overflow mask bit in the FPC register is zero. The operation is completed by setting the result to the scaled value and the exception is reported as a program interruption for a data exception with DXC 20, 28, or 2C hex, depending on whether the delivered value is exact, inexact and truncated, or inexact and incremented, respectively.
The result of the operation is derived from the precision-rounded value, the scale factor, and, for DFP, on the scaled preferred quantum. The value of the scale factor depends on the type of operation and operand format. The scaled preferred quantum for a particular operation is equal to the preferred quantum for that operation divided by the scale factor for that operation.

The delivered value is equal to the precision-rounded value divided by the scale factor. For DFP targets, the cohort member with the quantum nearest to the scaled preferred quantum is selected.

**IEEE Underflow**

An IEEE-underflow exception is recognized for an IEEE target when the tininess condition exists and either: (1) the IEEE-underflow mask bit in the FPC register is zero and the denormalized value is inex-act, or (2) the IEEE-underflow mask bit in the FPC register is one.

The tininess condition exists when the precise intermediate value of an IEEE computational operation is nonzero and smaller in magnitude than the smallest normal number (Nmin) representable in the target format.

The denormalized value is inexact if it is not equal to the precise intermediate value.

**IEEE-Underflow Nontrap Action:** IEEE-underflow nontrap action occurs when the IEEE-underflow exception is recognized and the IEEE-underflow mask bit in the FPC register is zero.

The operation is completed and the IEEE-underflow flag bit in the FPC register is set to one. The result is set to the denormalized value. For DFP targets, the cohort member with the smallest quantum is selected.

**IEEE-Underflow Trap Action:** IEEE-underflow trap action occurs when the IEEE-underflow exception is recognized and the IEEE-underflow mask bit in the FPC register is one.

The operation is completed by setting the result to the scaled value and the exception is reported as a program interruption for a data exception with DXC 10, 18, or 1C hex, depending on whether the delivered value is exact, inexact and truncated, or inexact and incremented, respectively.

The result of the operation is derived from the precision-rounded value, the scale factor and, for DFP, on the scaled preferred quantum. The value of the scale factor depends on the type of operation and operand format. The scaled preferred quantum for a particular operation is equal to the preferred quantum for that operation divided by the scale factor for that operation.

The result is set to the precision-rounded value divided by the scale factor. For DFP targets, the cohort member with the quantum nearest to the scaled preferred quantum is selected.

**IEEE Inexact**

An IEEE-inexact exception is recognized when, for an IEEE computational operation, an inexact condition exists, recognition of the exception is not suppressed, and neither IEEE-overflow trap action nor IEEE-underflow trap action occurs.

In the absence of an IEEE-invalid-operation condition, an inexact condition exists when the rounded intermediate value differs from the precise intermediate value. The condition also exists when IEEE-overflow nontrap action occurs. When the inexact condition exists, the delivered value and the result are said to be inexact.

Even though an inexact condition exists, the IEEE-inexact exception is not recognized if recognition of the exception is suppressed by means of an IEEE-inexact-exception control (XxC) or if IEEE overflow or IEEE underflow trap action occurs. When an inexact condition exists and the conditions for an IEEE-overflow trap action or IEEE-underflow trap action also apply, the trap action takes precedence and the inexact condition is reported in the DXC.

**IEEE-Inexact Nontrap Action:** IEEE-inexact nontrap action occurs when the IEEE-inexact exception is recognized and the IEEE-inexact mask bit in the FPC register is zero.

In the absence of another IEEE nontrap action, the operation is completed using the rounded intermediate value and the IEEE-inexact flag bit in the FPC register is set to one. For DFP targets, except for QUANTIZE and REROUND, the cohort member with the smallest quantum is selected.

When an IEEE-inexact nontrap action and another IEEE nontrap action coincide, the operation is com-
pleted using the result specified for the other exception and the flag bits for both exceptions are set to one.

**IEEE-Inexact Trap Action:** IEEE-inexact trap action occurs when the IEEE-inexact exception is recognized and the IEEE-inexact mask bit in the FPC register is one. The operation is completed and the exception is reported as a program interruption for a data exception with DXC 08 or 0C hex, depending on whether the result is inexact and truncated or inexact and incremented, respectively.

In the absence of a coincident IEEE nontrap action, the delivered value is set to the rounded intermediate value. For DFP targets, the cohort member with the smallest quantum is selected.

When the IEEE-inexact trap action coincides with an IEEE nontrap action, the operation is completed using the result specified for the IEEE nontrap action, the flag bit for the nontrap exception is set to one, and the IEEE-inexact trap action takes place.

**Quantum Exception**
A quantum exception is recognized when floating-point extension facility is installed and when, for an IEEE computational operation, a quantum-exception condition exists, recognition of the exception is not suppressed, and none of IEEE-overflow trap action, IEEE-underflow trap action, and IEEE-inexact trap action occurs.

For computational operations except DIVIDE, LOAD FP INTEGER, PERFORM FLOATING-POINT OPERATION, QUANTIZE, and REROUND, a quantum-exception condition exists when the delivered DFP result is inexact, or when the delivered DFP result is exact and finite, but the delivered quantum is different from the preferred quantum.

For DIVIDE, a quantum-exception condition exists (1) when the delivered DFP result is inexact, or (2) when the dividend is a finite number and the divisor is an infinity, or (3) when the delivered DFP result is exact and is a finite number, the delivered quantum is the maximum quantum and is not the preferred quantum, and the rightmost significand digit is zero, or (4) when the delivered DFP result is exact and is a finite number, the delivered quantum is the minimum quantum and is greater than the preferred quantum. Note that the maximum quantum is the value of $1 \times 10^{Q_{\text{max}}}$ and the minimum quantum is the value of $1 \times 10^{Q_{\text{min}}}$, where $Q_{\text{max}}$ and $Q_{\text{min}}$ are the maximum and minimum right-units-view exponents, respectively.

For LOAD FP INTEGER, QUANTIZE, and REROUND, a quantum-exception condition exists when the delivered DFP result is a finite number, but the delivered quantum is different from the quantum of the source operand (the second operand for LOAD FP INTEGER, and the third operand for QUANTIZE and REROUND).

For PERFORM FLOATING-POINT OPERATION, a quantum-exception condition exists when the delivered quantum exceeds the preferred quantum of 1.

When floating-point extension facility is not installed, no quantum exception is recognized by executing any instruction.

Even though a quantum-exception condition exists, the exception is not recognized if recognition of the exception is suppressed or if IEEE-overflow, IEEE-underflow, or IEEE-inexact trap action occurs. When a quantum-exception condition exists and the conditions for an IEEE-overflow, IEEE-underflow, or IEEE-inexact trap action also apply, the trap action takes precedence and the quantum-exception condition is not reported.

**Quantum-Exception Nontrap Action:** Quantum-exception nontrap action occurs when the quantum exception is recognized and the quantum-exception flag bit in the FPC register is zero.

In the absence of another IEEE nontrap action, the operation is completed using the rounded intermediate value and the quantum-exception flag bit in the FPC register is set to one. The delivered result, if it is a finite number, is the cohort member with the quantum closest to the preferred quantum.

When a quantum-exception nontrap action and other concurrent IEEE nontrap actions coincide, the operation is completed using the result specified for the other exceptions and the flag bits for all exceptions are set to one.

**Quantum-Exception Trap Action:** Quantum-exception trap action occurs when the quantum-exception is recognized and the quantum-exception mask bit in the FPC register is one. The operation is completed and the exception is reported as a program interruption for a data exception with DXC 04 hex.
In the absence of a coincident IEEE nontrap action, the delivered value is set to the rounded intermediate value, and the delivered result, if it is a finite number, is the cohort member with the quantum closest to the preferred quantum.

When the quantum-exception trap action coincides with other IEEE nontrap actions, the operation is completed using the result specified for the other IEEE nontrap actions, the flag bits for the other IEEE nontrap exceptions are set to one, and the quantum-exception trap action takes place.

Programming Notes:

1. IEEE traps are reported by means of a program interruption for a data exception with a data-exception code. The use of data exception provides the application program with a convenient interface since this exception is one of the original 15 exceptions in the System/360 architecture and is supported by most control programs that support the z/Architecture.

2. ANSI/IEEE Standard 754-2008 includes recommendations for the trap handler (see Reference [17.] on page xxviii). When a system traps, the trap handler should be able to determine:
   a. Which exception(s) were recognized on this operation.
   b. The kind of operation that was being performed.
   c. The destination's format.
   d. For overflow, underflow, and inexact exceptions, the correctly rounded result, including information that might not fit in the destination's format.
   e. For invalid-operation and divide-by-zero exceptions, the operand values.

   Items a and d are supplied as part of the interruption action. Items b, c, and e can be obtained starting with the instruction address in the old PSW and from this finding the instruction (which indicates the operation and format) and then the operands.

3. The description of underflow is one of the most difficult parts of the standard to understand. This is because:

   a. The condition is described as two “correlated events” — “tininess” and “loss of accuracy”.
   b. For tininess, ANSI/IEEE Standard 754-2008 provides two options for detection: “after rounding” or “before rounding”.
   c. For loss of accuracy, ANSI/IEEE Standard 754-2008 provides two options for detection: “denormalization loss” or “inexact result”.
   d. Implementation of the trap is optional.
   e. The conditions to signal underflow are different depending on whether or not the trap is taken.

Each of the above items is discussed below.

a. Tininess refers to a nonzero number strictly between \( \pm N_{\text{min}} \). (All subnormal numbers are in this range.) Loss of accuracy means that the result cannot be represented exactly.

b. Detection of tininess after or before rounding differs only for the case when “rounding” would increase the magnitude of the result to exactly \( \pm N_{\text{min}} \). It must be noted, however, that the action which ANSI/IEEE Standard 754-2008 here calls “rounding” is not the rounding to produce the delivered result but rounding to compute an intermediate value having the precision of the result but “as though the exponent range were unbounded”. In fact, it is possible that the delivered result may not be tiny even though the intermediate value “after rounding” is tiny.

The option selected in the z/Architecture (and the Power architecture) is to detect tininess before rounding.

c. The difference between detection of loss of accuracy as a denormalization loss or as an inexact result can best be understood by considering three intermediate values: (1) the precise intermediate value, which has unbounded precision and unbounded exponent range, (2) the precision-rounded value, which is obtained by rounding the precise intermediate value to the precision of the target format but with unbounded exponent range, and (3) the denormalized value, which is obtained by rounding the precise intermediate value to the precision and expo-
nent range of the target format. An inexact condition is said to exist when the denormalized value (3) differs from the precise intermediate value (1). A denormalization loss is said to exist when the denormalized value (3) differs from the precision-rounded value (2). The two options differ in the case when the denormalized value (3) is equal to the precision-rounded value (2) but these are not equal to the precise intermediate value (1). Although ANSI/IEEE Standard 754-2008 uses the term “denormalization loss”, this condition includes a case in which the delivered result is normal.

The option selected in the z/Architecture (and the Power architecture) is to detect “loss of accuracy” as an inexact result.

d. Although ANSI/IEEE Standard 754-2008 does not require traps to be implemented for underflow or the other IEEE exceptions, it does state that “with each exception should be associated a trap under user control”. Since it also defines “should” as “that which is strongly recommended as being in keeping with the intent of the standard”, the z/Architecture provides traps by means of program interruptions.

e. When the underflow trap is enabled, underflow is to be signaled when tininess is detected regardless of loss of accuracy. When the underflow trap is not enabled, the underflow flag bit is to be set only when both tininess and loss of accuracy have been detected. Add and subtract can result in tiny or inexact results, but not both. Thus, when underflow is disabled, add and subtract never set the underflow flag bit.

Suppression of Certain IEEE Exceptions

For IEEE-invalid-operation exception, IEEE-inexact exception, and quantum exception, a special control may be provided for an IEEE computational operation to control whether recognition of the exception is suppressed. These controls are called IEEE-invalid-operation-exception control (XIC), IEEE-inexact-exception control (XxC), and quantum-exception control (XqC), respectively.

When a special control is zero, recognition of the designated exception is not suppressed, and normal handling of the exception is performed. And, when the exception is recognized, it further depends on the mask bit in the FPC register to determine if a trap action occurs.

When a special control is one, recognition of the designated exception is suppressed, and no trap or non-trap action for the exception occurs. This suppression affects only recognition of the exception for setting the status flag or for causing the trap action. For example, the IEEE-inexact-exception control (XxC) has no effect on the DXC; that is, the DXC for IEEE-overflow or IEEE-underflow exceptions along with the detail for exact, inexact and truncated, or inexact and incremented, is reported according to the actual condition. Also, it has no effect on recognition of a quantum exception, which may depend on the actual inexact condition regardless of the setting of IEEE-inexact-exception control.

Multiple exception controls may be provided to a single IEEE computational operation. In this case, the effect and setting of each control is independent of other controls. The specific exception controls that are provided are described in the individual instruction descriptions.

IEEE Same-Radix Format Conversion

The instructions LOAD LENGTHENED and LOAD ROUNDED perform conversions of data between the short, long, and extended formats, where the source and target operands are in the same radix. (For mixed-radix conversions, see PFPO.) For BFP and DFP formats, same-radix conversion involves adjustments to both the significand and the biased exponent. Conversion to a narrower format requires rounding of the significand and an IEEE-inexact exception may result.

When converting to a narrower format, adjustment of the biased exponent causes IEEE underflow if the resultant left-units-view (LUV) exponent would be less than the minimum LUV exponent (Emin), or IEEE overflow if the resultant LUV exponent would be greater than the maximum LUV exponent (Emax) for the new format.
Programming Notes:

1. When a NaN is converted to a narrower format, for BFP the appropriate number of payload bits on the right (or for DFP, the appropriate number of payload digits on the left) are simply dropped with no indication. This is unlike the conversion of nonzero numbers, where the loss of nonzero significand digits causes an IEEE-inexact exception. Thus, programs which encode NaN payloads for specific purposes must ensure that the distinguishing bits (or digits) are placed in the left part of the payload for BFP and in the right part of the payload for DFP.

2. For BFP, converting a NaN to a narrower format cannot turn the NaN into an infinity because an SNaN either causes an interruption or turns into a QNaN, and all QNaNs have a leftmost fraction bit of one.

IEEE Comparison

Comparisons are always exact and cannot cause IEEE-overflow or IEEE-underflow exceptions.

Comparison ignores the sign of zero, that is, +0 equals -0.

Infinities with like sign compare equal, that is, +∞ equals +∞, and -∞ equals -∞.

A NaN compares as unordered with any other operand, whether a finite number, an infinity, or another NaN, including itself.

Two sets of instructions are provided: COMPARE and COMPARE AND SIGNAL. In the absence of QNaNs, these instructions work the same. These instructions work differently only when both of the following are true:

- Neither operand of the instruction is an SNaN
- At least one operand of the instruction is a QNaN

In this case, COMPARE simply sets condition code 3, but COMPARE AND SIGNAL recognizes the IEEE-invalid-operation exception. If any operand is an SNaN, both instructions recognize the IEEE-invalid-operation exception.

The action when the IEEE-invalid-operation exception is recognized depends on the IEEE-invalid-operation mask bit in the FPC register. If the mask bit is zero, then the instruction execution is completed by setting condition code 3, and the IEEE-invalid-operation flag in the FPC register is set to one. If the mask bit is one, then the exception is reported as a program interruption for a data exception with DXC 80 hex (IEEE invalid operation).

Programming Note: A compiler can select either COMPARE or COMPARE AND SIGNAL for a comparison, depending on whether it is desired that a QNaN to be recognized as an exception.

Condition Codes for IEEE Instructions

For those operations which set the condition code to indicate the value of an IEEE result, condition codes 0, 1, and 2 are set to indicate that the result is a zero of either sign, less than zero, or greater than zero, respectively. The condition-code setting depends only on an inspection of the rounded result. For comparison operations, condition codes 0, 1, and 2 indicate equal, low, or high, respectively. These settings are the same as for the HFP instructions.

Condition code 3 can also be set. After an arithmetic operation, condition code 3 indicates a NaN result of either sign. After a comparison, it indicates that a NaN was involved in the comparison (the unordered condition). See Figure 9-16.

<table>
<thead>
<tr>
<th>CC</th>
<th>Arithmetic</th>
<th>Comparison</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>±0</td>
<td>Equal</td>
</tr>
<tr>
<td>1</td>
<td>&lt;0</td>
<td>Low</td>
</tr>
<tr>
<td>2</td>
<td>&gt;0</td>
<td>High</td>
</tr>
<tr>
<td>3</td>
<td>±NaN</td>
<td>Unordered</td>
</tr>
</tbody>
</table>

Figure 9-16. Condition Codes

Instructions

The floating-point-support instructions and their mnemonics and operation codes are listed in Figure 9-17 on page 9-26. The figure indicates, in the column labeled “Characteristics”, the instruction format, when the condition code is set, the instruction fields that designate access registers, and the exceptional conditions in operand designations, data, or results that cause a program interruption.
All floating-point-support instructions are subject to the AFP-register-control bit, bit 45 of control register 0. The AFP-register-control bit must be one when an AFP register is specified as an operand location; otherwise, an AFP-register data exception, DXC 1, is recognized.

Mnemonics for the floating-point instructions have an R as the last letter when the instruction is in the RR, RRE, or RRF format. Certain letters are used for floating-point instructions to represent operand-format length, as follows:

D Long
E Short
X Extended

Note: In the detailed descriptions of the individual instructions, the mnemonic and the symbolic operand designation for the assembler language are shown with each instruction. For a register-to-register operation using LOAD (short), for example, LER is the mnemonic and R1,R2 the operand designation.

Programming Notes:

1. The following additional floating-point-support instruction is available when the decimal-floating-point facility is installed:
   - SET DFP ROUNDED MODE (SRNMT)

2. The following additional floating-point-support instructions are available when the floating-point-support-sign-handling facility is installed:
   - COPY SIGN (CPNSR)
   - LOAD COMPLEMENT (LCDFR)
   - LOAD NEGATIVE (LNEFR)
   - LOAD POSITIVE (LPNSR)

3. The following additional floating-point-support instructions are available when the FPR-GR-transfer facility is installed:
   - LOAD FPR FROM GR (LDGR)
   - LOAD GR FROM FPR (LGDR)

4. The following additional floating-point-support instructions are available when the IEEE-exception-simulation facility is installed:
   - LOAD FPC AND SIGNAL (LFAS)
   - SET FPC AND SIGNAL (SFASR)

5. The following additional floating-point-support instructions are available when the long-displacement facility is installed:
   - LOAD (LDY, LEY)
   - STORE (STDY, STEY)

6. The following additional floating-point-support instruction is available when the PFPO facility is installed:
   - PERFORM FLOATING POINT OPERATION (PFPO)

7. The following additional floating-point-support instruction and features are available when the floating-point extension facility is installed:
   - A new floating-point-support instruction, SET BFP ROUNDED MODE (SRNMB), is added.
   - A new exception, the quantum exception, is defined for some computational operations.
   - Bit 5 of the floating-point-control (FPC) register is assigned to the quantum-exception mask.
   - Bit 13 of the FPC register is assigned to the quantum-exception flag.
   - Data-exception code (DXC) 04 (hex) is assigned to the quantum exception.
   - DXC 07 (hex) is assigned to the simulated quantum exception.
   - The BFP-rounding-mode field in the FPC register is changed to 3 bits to support one additional BFP rounding mode, round to prepare for shorter precision.
   - One new value of the effective rounding method field is assigned to support the round to prepare for shorter precision rounding method for CONVERT HFP TO BFP.
   - For PFPO with a DFP result, bit 58 of general register 0 is assigned to be the DFP quantum-permission control.
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT BFP TO HFP (long)</td>
<td>THDR</td>
<td>Da g^7</td>
<td></td>
<td>B359</td>
</tr>
<tr>
<td>CONVERT BFP TO HFP (short to long)</td>
<td>THDER</td>
<td>Da g^7</td>
<td></td>
<td>B358</td>
</tr>
<tr>
<td>CONVERT HFP TO BFP (long)</td>
<td>TBDR</td>
<td>Da g^7,3</td>
<td></td>
<td>B351</td>
</tr>
<tr>
<td>CONVERT HFP TO BFP (long to short)</td>
<td>TBEDR</td>
<td>Da g^7,3</td>
<td></td>
<td>B350</td>
</tr>
<tr>
<td>COPY SIGN (long)</td>
<td>CPSDR</td>
<td>Da g^7</td>
<td></td>
<td>B372</td>
</tr>
<tr>
<td>EXTRACT FPC</td>
<td>EFPC</td>
<td>Da g^3</td>
<td></td>
<td>B38C</td>
</tr>
<tr>
<td>LOAD (extended)</td>
<td>LXR</td>
<td>Da g^7,3</td>
<td></td>
<td>B365</td>
</tr>
<tr>
<td>LOAD (long)</td>
<td>LDR</td>
<td>Da g^7</td>
<td>28</td>
<td>B363</td>
</tr>
<tr>
<td>LOAD (long)</td>
<td>LD</td>
<td>Da g^7,3, A</td>
<td>68</td>
<td>B373</td>
</tr>
<tr>
<td>LOAD (long)</td>
<td>LDY</td>
<td>Da g^7,3, A</td>
<td></td>
<td>B372</td>
</tr>
<tr>
<td>LOAD (short)</td>
<td>LER</td>
<td>Da g^7</td>
<td>38</td>
<td>B365</td>
</tr>
<tr>
<td>LOAD (short)</td>
<td>LE</td>
<td>Da g^7,3, A</td>
<td>78</td>
<td>B373</td>
</tr>
<tr>
<td>LOAD (short)</td>
<td>LEY</td>
<td>Da g^7,3, A</td>
<td></td>
<td>B373</td>
</tr>
<tr>
<td>LOAD (short)</td>
<td>LCDFR</td>
<td>Da g^7,3</td>
<td></td>
<td>B373</td>
</tr>
<tr>
<td>LOAD FPC AND SIGNAL</td>
<td>LFPC</td>
<td>Da g^7,3, A, SP</td>
<td></td>
<td>B29D</td>
</tr>
<tr>
<td>LOAD FPR FROM GR (64 to long)</td>
<td>LDGR</td>
<td>Da g^7</td>
<td></td>
<td>B363</td>
</tr>
<tr>
<td>LOAD GR FROM FPR (long to 64)</td>
<td>LGDR</td>
<td>Da g^7</td>
<td></td>
<td>B364</td>
</tr>
<tr>
<td>LOAD NEGATIVE (long)</td>
<td>LNDFR</td>
<td>Da g^7,3</td>
<td></td>
<td>B371</td>
</tr>
<tr>
<td>LOAD NEGATIVE (long)</td>
<td>LPDFR</td>
<td>Da g^7,3</td>
<td></td>
<td>B370</td>
</tr>
<tr>
<td>LOAD ZERO (extended)</td>
<td>LZXR</td>
<td>Da g^7,3</td>
<td></td>
<td>B374</td>
</tr>
<tr>
<td>LOAD ZERO (long)</td>
<td>LZDR</td>
<td>Da g^7</td>
<td></td>
<td>B375</td>
</tr>
<tr>
<td>LOAD ZERO (short)</td>
<td>LZER</td>
<td>Da g^7</td>
<td></td>
<td>B376</td>
</tr>
<tr>
<td>PERFORM FLOATING-POINT OPERATION</td>
<td>PPFO</td>
<td>Da g^7,3</td>
<td></td>
<td>B377</td>
</tr>
<tr>
<td>SET BFP Rounding Mode (2 bit)</td>
<td>SRNMT</td>
<td>Da g^7,3</td>
<td></td>
<td>B299</td>
</tr>
<tr>
<td>SET BFP Rounding Mode (3 bit)</td>
<td>SRNMB</td>
<td>Da g^7,3</td>
<td></td>
<td>B299</td>
</tr>
<tr>
<td>SET DFP Rounding Mode</td>
<td>SFPC</td>
<td>Da g^7,3</td>
<td></td>
<td>B299</td>
</tr>
<tr>
<td>SET FPC</td>
<td>SFASR</td>
<td>Da g^7,3</td>
<td></td>
<td>B299</td>
</tr>
<tr>
<td>STORE (long)</td>
<td>STDY</td>
<td>Da g^7</td>
<td></td>
<td>B299</td>
</tr>
<tr>
<td>STORE (short)</td>
<td>STE</td>
<td>Da g^7</td>
<td></td>
<td>B299</td>
</tr>
<tr>
<td>STORE (short)</td>
<td>STEY</td>
<td>Da g^7</td>
<td></td>
<td>B299</td>
</tr>
</tbody>
</table>

Explanation:

- g^7: Restricted from transactional execution when the effective allow-floating-point-operation control is zero.
- g^6: May be restricted from transactional execution depending on machine conditions.
- g^5: Restricted in the constrained transactional-execution mode; a transaction-constraint program exception may be recognized.
- A: Access exceptions for logical addresses.
- B2: B2 field designates an access register in the access-register mode.
- C: Condition code is set.
- Da: AFP-register data exception.
- Dt: DFP-instruction data exception.
- F: Floating-point extension facility.
- FG: FPR-GR-transfer facility.
- FS: Floating-point-support-sign-handling facility.

Figure 9-17. Summary of Floating-Point-Support Instructions
CONVERT BFP TO HFP

The second operand (the source operand) is converted from the binary-floating-point (BFP) format to the hexadecimal-floating-point (HFP) format, and the normalized result is placed at the first-operand location. The sign and magnitude of the source operand are tested to determine the setting of the condition code.

For numeric operands, the sign of the result is the sign of the source operand. If the source operand has a sign bit of one and all other operand bits are zeros, the result also is a one followed by all zeros.

When, for THDR, the characteristic of the hexadecimal intermediate result is too large to fit into the target format, the result is set to all ones (that is, the largest-in-magnitude representable finite number) but with the same sign as that of the source operand, and condition code 3 is set.

See Figure 9-18 for a detailed description of the results of this instruction.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Source was zero</td>
</tr>
<tr>
<td>1</td>
<td>Source was less than zero</td>
</tr>
<tr>
<td>2</td>
<td>Source was greater than zero</td>
</tr>
<tr>
<td>3</td>
<td>Special case</td>
</tr>
</tbody>
</table>

**Program Exceptions:**
- Data with DXC 1, AFP register
- Transaction constraint

**Programming Notes:**
1. The BFP-to-HFP conversion instructions are summarized in Figure 9-19.
2. CONVERT BFP TO HFP (THDER) converts BFP operands in the short format to HFP operands in the long format, rather than converting short to short, to retain full precision. Using this long HFP result subsequently as a short operand requires no extra conversion steps.

<table>
<thead>
<tr>
<th>Source Operand (a)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>$-\infty &lt; a &lt; -\text{Hmax}$</td>
<td>$T(-\text{Hmax}), \text{cc3}$</td>
</tr>
<tr>
<td>$-\text{Hmax} \leq a \leq -\text{Hmin}$</td>
<td>$T(r), \text{cc1}$</td>
</tr>
<tr>
<td>$-\text{Hmin} &lt; a &lt; 0$</td>
<td>$T(-0), \text{cc1}$</td>
</tr>
<tr>
<td>$0 &lt; a &lt; +\text{Hmin}$</td>
<td>$T(+0), \text{cc0}$</td>
</tr>
<tr>
<td>$0 &lt; a &lt; +\text{Hmax}$</td>
<td>$T(+0), \text{cc2}$</td>
</tr>
<tr>
<td>$\text{Hmin} \leq a \leq +\text{Hmax}$</td>
<td>$T(r), \text{cc2}$</td>
</tr>
<tr>
<td>$+\text{Hmax} &lt; a \leq +\infty$</td>
<td>$T(+\text{Hmax}), \text{cc3}$</td>
</tr>
<tr>
<td>NaN</td>
<td>$T(+\text{Hmax}), \text{cc3}$</td>
</tr>
</tbody>
</table>

Explanation:

1. Condition code 1 is set to indicate the source was less than zero.
2. Condition code 2 is set to indicate the source was greater than zero.
ccn Condition code is set to n.
r The value derived when the BFP source value a is converted to the HFP format. This result is always exact.
Hmax Largest (in magnitude) representable number in the target HFP format.
Hmin Smallest (in magnitude) representable normalized number in the target HFP format.
$T(x)$ The value x is placed at the target operand location.

Figure 9-18. Results: CONVERT BFP TO HFP

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Mnemonic</th>
<th>Source Format</th>
<th>Source Significant Bits</th>
<th>Target Format</th>
<th>Target Significant Bits</th>
<th>Result</th>
<th>Overflow, Underflow Possible</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT BFP TO HFP</td>
<td>THDER</td>
<td>BFP short</td>
<td>24</td>
<td>HFP long</td>
<td>53-56</td>
<td>Exact</td>
<td>No</td>
</tr>
<tr>
<td></td>
<td>THDR</td>
<td>BFP long</td>
<td>53</td>
<td>HFP long</td>
<td>53-56</td>
<td>Exact</td>
<td>No</td>
</tr>
<tr>
<td>CONVERT HFP TO BFP</td>
<td>TBEDR</td>
<td>HFP long</td>
<td>53-56</td>
<td>BFP short</td>
<td>24</td>
<td>Rounded</td>
<td>Yes</td>
</tr>
<tr>
<td></td>
<td>TDBR</td>
<td>HFP long</td>
<td>53-56</td>
<td>BFP long</td>
<td>53</td>
<td>Rounded</td>
<td>No</td>
</tr>
</tbody>
</table>

Figure 9-19. Summary of BFP-to/from-HFP Conversion Instructions

CONVERT HFP TO BFP

The second operand (the source operand) is converted from the hexadecimal-floating-point (HFP) for-
mat to the binary-floating-point (BFP) format, and the result rounded according to the rounding method specified by the $M_3$ field is placed at the first-operand location. The sign and magnitude of the source operand are tested to determine the setting of the condition code.

The $M_3$ field contains a modifier specifying a rounding method, as follows:

$M_3$ Effective Rounding Method

- Round toward 0
- Round to nearest with ties away from 0
- Round to prepare for shorter precision
- Round to nearest with ties to even
- Round toward 0
- Round toward $+\infty$
- Round toward $-\infty$

A modifier other than 0, 1, or 3-7 is invalid. If the floating-point extension facility is not installed, an $M_3$ modifier of 3 is also invalid.

The sign of the result is the sign of the second operand. If the second operand has a sign bit of one and all other operand bits are zeros, the result also is a one followed by all zeros.

See Figure 9-20 on page 9-29 for a detailed description of the results of this instruction.

If the $M_3$ field designates any of the following invalid modifier values: 2 and 8-15, then a specification exception is recognized. When the floating-point extension facility is not installed, if the $M_3$ field designates the invalid value 3, it is undefined whether a specification exception is recognized or an unpredictable rounding method is performed.

Resulting Condition Code:

- Source was zero
- Source was less than zero
- Source was greater than zero

Overflow

IEEE Exceptions: None.

Program Exceptions:

- Data with DXC 1, AFP register
- Specification
- Transaction constraint

Programming Notes:

1. The HFP-to-BFP conversion instructions are summarized in Figure 9-19 on page 9-28.

2. Conversion to short BFP data requires HFP operands in the long format; a short HFP operand should be extended to long by ensuring that the right half of the register is cleared. Thus, the entire register should be cleared before loading a short HFP operand into it for conversion to BFP. This avoids unrepeatable rounding errors in the BFP result due to data left over from previous use.

### Precision Rounded Source Operand (g) Results for Rounding Method Specified in $M_3$

<table>
<thead>
<tr>
<th>Precision Rounded Source Operand (g)</th>
<th>Round to Nearest with Ties away from 0</th>
<th>Round to Nearest with Ties to Even</th>
<th>Round to Prepare for Shorter Precision</th>
<th>Round toward 0</th>
<th>Round toward $+\infty$</th>
<th>Round toward $-\infty$</th>
</tr>
</thead>
<tbody>
<tr>
<td>$g &lt; -N_{\max}$</td>
<td>$T(-\infty)$, cc3</td>
<td>$T(-\infty)$, cc3</td>
<td>$T(-N_{\max})$, cc3</td>
<td>$T(-N_{\max})$, cc3</td>
<td>$T(-N_{\max})$, cc3</td>
<td>$T(-\infty)$, cc3</td>
</tr>
<tr>
<td>$+N_{\max} &lt; g$</td>
<td>$T(+\infty)$, cc3</td>
<td>$T(+\infty)$, cc3</td>
<td>$T(+N_{\max})$, cc3</td>
<td>$T(+N_{\max})$, cc3</td>
<td>$T(+\infty)$, cc3</td>
<td>$T(+N_{\max})$, cc3</td>
</tr>
</tbody>
</table>

Figure 9-20. (Part 1 of 2) Results: CONVERT HFP to BFP

Figure 9-20. (Part 2 of 2) Results: CONVERT HFP to BFP
**COPY SIGN**

CPSDR  \( R_1, R_2, R_3 \)  \([\text{RRF-b}]\)

<table>
<thead>
<tr>
<th>Precision</th>
<th>Results for Rounding Method Specified in ( M_3 )</th>
</tr>
</thead>
<tbody>
<tr>
<td>( g )</td>
<td>Round to Nearest with Ties away from 0</td>
</tr>
<tr>
<td>( g )</td>
<td>Round to Nearest with Ties to Even</td>
</tr>
<tr>
<td>( g )</td>
<td>Round to Prepare for Shorter Precision</td>
</tr>
<tr>
<td>( g )</td>
<td>Round toward ( 0 )</td>
</tr>
<tr>
<td>( g )</td>
<td>Round toward ( +\infty )</td>
</tr>
<tr>
<td>( g )</td>
<td>Round toward ( -\infty )</td>
</tr>
</tbody>
</table>

1. The second operand is placed at the first-operand location with the sign bit set to the sign of the third operand. The first, second, and third operands are each in a 64-bit floating-point register. The sign bit of the second operand and bits 1-63 of the third operand are ignored.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC 1, AFP register
- Operation (if the floating-point-support-sign-handling facility is not installed)
- Transaction constraint

**Programming Notes:**
1. COPY SIGN is radix independent and can be used to operate on HFP, BFP, or DFP operands or even to copy the sign between operands having different radices.

2. Since the sign is in the same bit position (the leftmost bit) in all widths for all radices, the third operand can be a short, long, or extended format.

3. COPY SIGN can be used in conjunction with LOAD (LDR) to copy the sign of an operand in the extended format.

---

**EXTRACT FPC**

EFPC  \( R_1 \)  \([\text{RRE}]\)

The contents of the FPC (floating-point-control) register are placed in bit positions 32-63 of the general register designated by \( R_1 \). Bit positions 0-31 of the general register remain unchanged.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 2, BFP instruction
- Transaction constraint
LOAD

Mnemonic1 R1,R2 [RR]

Op Code R1 R2
0  8 12 15

Mnemonic1 Op Code Operands
LER '38' Short
LDR '28' Long

Mnemonic2 R1,R2 [RRE]

Op Code R1 R2
0  16 24 28 31

Mnemonic2 Op Code Operands
LXR 'B365' Extended

Mnemonic3 R1,D2(X2,B2) [RX-a]

Op Code R1 X2 B2 D2
0  8 12 16 20 31

Mnemonic3 Op Code Operands
LE '78' Short
LD '68' Long

Mnemonic4 R1,D2(X2,B2) [RXY-a]

0  8 12 16 20 32 36 40 47

Mnemonic4 Op Code Operands
LEY 'ED64' Short
LDY 'ED65' Long

The second operand is placed unchanged at the first-operand location.

The operation is performed without inspecting the contents of the second operand; no arithmetic exceptions are recognized.

For LXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

The displacement for LE and LD is treated as a 12-bit unsigned binary integer. The displacement for LEY and LDY is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC 1, AFP register
- Operation (LEY and LDY, if the long-displacement facility is not installed)
- Specification (LXR only)
- Transaction constraint

LOAD COMPLEMENT

Mnemonic4 R1,R2 [RR]

Op Code R1 R2
0  16 24 28 31

Mnemonic4 Op Code Operands
LCDFR 'B373' [RRE]

The second operand is placed at the first-operand location with the sign bit inverted. Both the first and second operands are each in a 64-bit floating-point register.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC 1, AFP register
- Operation (if the floating-point-support-sign-handling facility is not installed)
- Transaction constraint

**Programming Notes:**

1. LOAD COMPLEMENT (LCDFR) is radix independent and can be used to operate on HFP, BFP, or DFP operands.

2. LOAD COMPLEMENT (LCDFR) can be used in conjunction with LOAD (LDR) to set the sign of an operand in the extended format.

LOAD FPC

Mnemonic4 D2(B2) [S]

Op Code B2 D2
0  16 20 31

The four-byte second operand in storage is loaded into the FPC (floating-point-control) register.

Bits corresponding to unsupported bit positions in the FPC register must be zero; otherwise, a specification exception is recognized. For purposes of this checking, a bit position is considered to be unsupported only if it is either unassigned or assigned to a facility
which is not installed in any architectural mode of the configuration.

When the floating-point extension facility is installed, the bits corresponding to the BFP rounding mode must specify a valid rounding mode; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Access (fetch, operand 2)
- Data with DXC 2, BFP instruction
- Specification
- Transaction constraint

**Programming Notes:**
1. When the architectural mode of a CPU is changed without resetting the FPC register (by means of the set architecture signal-processor order, for example) the entire contents of the FPC register are preserved. This is true even when some of these bits are associated with a facility which is not available in both architectural modes. Checking for unsupported bit positions of the FPC register is performed independently of the current architectural mode of the CPU; thus, it is always safe to restore the FPC register from a value previously saved on this CPU, even after the architectural mode has changed.
2. When the floating-point extension facility is installed, bits 29-31 of the second operand must specify a valid BFP rounding mode and bits 6-7, 14-15, 24, and 28 must be zero; otherwise, a specification exception is recognized.
3. When the floating-point extension facility is not installed, bits 5-7, 13-15, 24, and 28-29 are unassigned and must be zero; otherwise, a specification exception is recognized.

**LOAD FPC AND SIGNAL**

<table>
<thead>
<tr>
<th>LOAD FPC AND SIGNAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>LFAS</td>
</tr>
<tr>
<td>D2(B2)</td>
</tr>
<tr>
<td>[S]</td>
</tr>
<tr>
<td>'B2BD'</td>
</tr>
<tr>
<td>B3</td>
</tr>
<tr>
<td>D2</td>
</tr>
<tr>
<td>0</td>
</tr>
<tr>
<td>16</td>
</tr>
<tr>
<td>20</td>
</tr>
<tr>
<td>31</td>
</tr>
</tbody>
</table>

First, flags of byte 1 of the floating-point-control (FPC) register at the beginning of the operation are preserved to be used as signaling flags. Next, the contents of the source operand are placed in the FPC register; then the flags in the FPC register are set to the logical OR of the signaling flags and the source flags. Finally, the conditions for simulated-IEEE-exception trap action are examined.

The source operand is the second operand in storage.

If any signaling flag is one and the corresponding source mask is also one, simulated-IEEE-exception trap action occurs. The data-exception code (DXC) in the FPC register is updated to indicate the specific cause of the interruption and a data-exception program interruption occurs at completion of the instruction execution. The DXC for the interruption is shown in Figure 9-21.

If no signaling flag is enabled, the DXC in the FPC register remains as loaded from the source and instruction execution completes with no trap action.

See Figure 9-22 for a detailed description of the result of this instruction.

Bits in the source operand that correspond to unsupported bit positions in the FPC register must be zero; otherwise, a specification exception is recognized. For purposes of this checking, a bit position is considered to be unsupported only if it is either unassigned or assigned to a facility which is not installed in any architectural mode of the configuration.

When the floating-point extension facility is installed, the bits corresponding to the BFP rounding mode must specify a valid rounding mode; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Data with DXC 3, DFP instruction
- Data with DXC for simulated IEEE exception
- Operation (if the IEEE-exception-simulation facility is not installed)
- Specification
- Transaction constraint
Programming Notes:

1. When the floating-point extension facility is installed, bits 29-31 of the second operand must specify a valid BFP rounding mode and bits 6-7, 14-15, 24, and 28 must be zero; otherwise, a specification exception is recognized.

2. When the floating-point extension facility is not installed, bits 5-7, 13-15, 24, and 28-29 are unassigned and must be zero; otherwise, a specification exception is recognized.

3. The IEEE-exception-simulation instructions (LOAD FPC AND SIGNAL and SET FPC AND SIGNAL) are provided to facilitate program simulation of IEEE operations not provided directly in the machine. These instructions permit the simulation routine to restore the caller's masks, flags, and rounding modes; and, when appropriate, to simulate IEEE exceptions, including traps when enabled.

4. On entry, the simulation routine should first save the FPC register contents (containing the caller's masks, flags, and rounding modes), disable all traps, clear all flags, establish appropriate rounding modes, and then perform the necessary floating-point operations. Finally, the routine should set the current flags (called signaling flags) appropriately, and invoke either LOAD FPC AND SIGNAL or SET FPC AND SIGNAL.

5. When a program interruption for a data exception occurs, and both bit 6 and 7 of the DXC are ones, it indicates to the trap handler that the interruption was caused by a simulated-IEEE-exception trap action. The remaining bits of the DXC indicate the type of IEEE exception. Additional information required by the trap handler can be determined by the contents of a trap-information block, located by convention, at a fixed offset from the location where the instruction causing the trap resides.

The following shows an example of this scheme. The block and the code below are inserted at an appropriate place where a trap can occur. In this example, the LOAD FPC AND SIGNAL instruction is used, and the caller’s FPC register contents are at the location, SAVEDFPC.

The trap information block can contain the designation of floating-point registers and general registers containing the information (or addresses of the information) for the following types of items:

a. The operation being simulated
b. Format and values of source operands
c. Format and value of the result
d. Any additional information useful to the trap handler.

**LOAD FPR FROM GR**

**LDGR**

R1,R2 [RRE]

'B3C1' 0 16 24 28 31

The second operand is placed at the first-operand location. The second operand is in a general register, and the first operand is in a floating-point register.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC 1, AFP register
- Operation (if the FPR-GR-transfer facility is not installed)
- Transaction constraint

**LOAD GR FROM FPR**

**LGDR**

R1,R2 [RRE]

'B3CD' 0 16 24 28 31

The second operand is placed at the first-operand location. The second operand is in a floating-point register, and the first operand is in a general register.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC 1, AFP register
- Operation (if the FPR-GR-transfer facility is not installed)
- Transaction constraint

**LOAD NEGATIVE**

**LNDFR**

R1,R2 [RRE]

'B371' 0 16 24 28 31

The second operand is placed at the first-operand location with the sign bit set to one. Both the first and second operands are each in a 64-bit floating-point register.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC 1, AFP register
- Operation (if the floating-point-support-sign-handling facility is not installed)
- Transaction constraint

**Programming Notes:**

1. LOAD NEGATIVE (LNDFR) is radix independent and can be used to operate on HFP, BFP, or DFP operands.
2. LOAD NEGATIVE (LNDFR) can be used in conjunction with LOAD (LDR) to set the sign of an operand in the extended format.

**LOAD POSITIVE**

**LPDFR**

R1,R2 [RRE]

'B370' 0 16 24 28 31

The second operand is placed at the first-operand location with the sign bit set to zero. Both the first and second operands are each in a 64-bit floating-point register.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC 1, AFP register
- Operation (if the floating-point-support-sign-handling facility is not installed)
- Transaction constraint

**Programming Notes:**

1. LOAD POSITIVE (LPDFR) is radix independent and can be used to operate on HFP, BFP, or DFP operands.
2. LOAD POSITIVE (LPDFR) can be used in conjunction with LOAD (LDR) to set the sign of an operand in the extended format.
LOAD ZERO

Mnemonic R 1 [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R 1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
</tr>
<tr>
<td>24</td>
<td>28</td>
</tr>
<tr>
<td>31</td>
<td></td>
</tr>
</tbody>
</table>

Mnemonic Op Code Operands
LZER 'B374' Short
LZDR 'B375' Long
LZXR 'B376' Extended

All bits of the first operand are set to zeros.

For LZXR, the R 1 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC 1, AFP register
- Specification (LZXR only)
- Transaction constraint

**Programming Note:** LOAD ZERO sets all bits of a register to zeros, which produces a positive zero value in the BFP, DFP, and HFP formats. For DFP, addition of an all-zero value to any normal value, X, normalizes X.

PERFORM FLOATING-POINT OPERATION

PFPO [E]

<table>
<thead>
<tr>
<th>'010A'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

The operation specified by the function code in general register 0 is performed and the condition code is set to indicate the result. When there are no exceptional conditions, condition code 0 is set. When an IEEE nontrap exception is recognized, condition code 1 is set. When an IEEE trap exception with alternate action is recognized, condition code 2 is set. In the absence of suppression, a 32-bit return code is placed in bits 32-63 of general register 1; bits 0-31 of general register 1 remain unchanged.

The PERFORM FLOATING-POINT OPERATION (PFPO) instruction is subject to the AFP-register-control bit, bit 45 of control register 0. For PFPO to be executed successfully, the AFP-register-control bit must be one; otherwise, an AFP-register data exception, DXC 1, is recognized.

Bit 32 of general register 0 is the test bit. When bit 32 is zero, the function specified by bits 33-63 of general register 0 is performed; each field in bits 33-63 must be valid and the combination must be a valid and installed function; otherwise a specification exception is recognized. When bit 32 is one, the function specified by bits 33-63 is not performed; rather, the condition code is set to indicate whether these bits specify a valid and installed function; the condition code is set to 0 if the function is valid and installed, or to 3 if the function is invalid or not installed. This definition is written as if the test bit is zero except when stated otherwise.

Bits 33-39 of GR0 specify the operation type. Only one operation type is currently defined: 01, hex, is the PFPO-convert-floating-point-radix operation.

For the PFPO-convert-floating-point-radix operation, other fields in general register 0 include first-operand format, second operand format, control flags, and rounding method. The second operand is converted to the format of the first operand and placed at the first-operand location, a return code is placed in bits 32-63 of general register 1, and the condition code is set to indicate whether an exceptional condition was recognized. Alternatively, an exceptional condition may be indicated by the recognition of a data exception resulting in either completion or suppression.

The first and second operands are in implicit floating-point registers. The first operand is in floating-point register 0 (paired with floating-point register 2 for extended). The second operand is in floating-point register 4 (paired with floating-point register 6 for extended).
PERFORM FLOATING-POINT OPERATION

General Register 0 (GR0)

Figure 9-23 illustrates the contents of general register 0; bits 0-31 of the register are ignored.

<table>
<thead>
<tr>
<th>GR0</th>
<th>T</th>
<th>OTC</th>
<th>OFC (operand 1)</th>
<th>OFC (operand 2)</th>
<th>IA</th>
<th>IE</th>
<th>TR</th>
<th>RM</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Explanation:

/ Ignored
T Test bit (bit 32)
OTC PFPO-operation-type code (bits 33-39)
OFC PFPO-operand format code (bits 40-47 for operand 1, bits 48-55 for operand 2)
IS Inexact-suppression control (bit 56)
AE Alternate-exception-action control (bit 57)
TR Target-radix-dependent controls (bits 58-59)
RM PFPO rounding method (bits 60-63)

Figure 9-23. General Register 0 for PERFORM FLOATING POINT OPERATION

Figure 9-24 illustrates the contents of the PFPO-operation-type code in bits 33-32 of general register 0.

<table>
<thead>
<tr>
<th>Op Type Code (hex)</th>
<th>Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Reserved/Invalid</td>
</tr>
<tr>
<td>01</td>
<td>PFPO Convert Floating-Point Radix</td>
</tr>
<tr>
<td>02-7F</td>
<td>Reserved/Invalid</td>
</tr>
</tbody>
</table>

Figure 9-24. PFPO-Operation-Type Code (GR0 bits 33-39)

Figure 9-25 illustrates the contents of the PFPO-operand-format codes for the first and second operands (in bits 40-47 and 48-55 of general register 0, respectively).

<table>
<thead>
<tr>
<th>Code (hex)</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>HFP short</td>
</tr>
<tr>
<td>01</td>
<td>HFP long</td>
</tr>
<tr>
<td>02</td>
<td>HFP extended</td>
</tr>
<tr>
<td>03</td>
<td>Reserved/Invalid</td>
</tr>
<tr>
<td>04</td>
<td>Reserved/Invalid</td>
</tr>
<tr>
<td>05</td>
<td>BFP short</td>
</tr>
<tr>
<td>06</td>
<td>BFP long</td>
</tr>
<tr>
<td>07</td>
<td>BFP extended</td>
</tr>
<tr>
<td>08</td>
<td>DFP short</td>
</tr>
<tr>
<td>09</td>
<td>DFP long</td>
</tr>
<tr>
<td>0A</td>
<td>DFP extended</td>
</tr>
<tr>
<td>0B-FF</td>
<td>Reserved/Invalid</td>
</tr>
</tbody>
</table>

Figure 9-25. PFPO-Operand-Format Codes (GR0 bits 40-47 and 48-55)

Figure 9-26 illustrates the contents of the PFPO-target-radix-dependent controls in bits 58-59 of general register 0.

<table>
<thead>
<tr>
<th>Radix of Target</th>
<th>GR0 Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>HFP</td>
<td>58</td>
<td>HFP-overflow control</td>
</tr>
<tr>
<td>HFP</td>
<td>59</td>
<td>HFP-underflow control</td>
</tr>
<tr>
<td>BFP</td>
<td>58</td>
<td>Reserved, must be zero</td>
</tr>
<tr>
<td>BFP</td>
<td>59</td>
<td>Reserved, must be zero</td>
</tr>
<tr>
<td>DFP</td>
<td>58</td>
<td>Reserved, must be zero when the floating-point extension facility is not installed; it is the DFP quantum-permission control (DQPC) when the facility is installed.</td>
</tr>
<tr>
<td>DFP</td>
<td>59</td>
<td>DFP preferred-quantum control (DPQC)</td>
</tr>
</tbody>
</table>

Figure 9-26. PFPO-Target-Radix-Dependent Controls (GR0, bits 58-59)
Figure 9-28 illustrates the PFPO-rounding-method codes in bits 60-63 of general register 0.

<table>
<thead>
<tr>
<th>Value</th>
<th>Method*</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>According to current DFP rounding mode in bits 25-27 of the floating-point-control register</td>
</tr>
<tr>
<td>1</td>
<td>According to current BFP rounding mode in bits 29-31 of the floating-point-control register</td>
</tr>
<tr>
<td>2-7</td>
<td>Reserved/Invalid</td>
</tr>
<tr>
<td>8</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>9</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>10</td>
<td>Round toward +\infty</td>
</tr>
<tr>
<td>11</td>
<td>Round toward -\infty</td>
</tr>
<tr>
<td>12</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>13</td>
<td>Round to nearest with ties toward 0</td>
</tr>
<tr>
<td>14</td>
<td>Round away from 0</td>
</tr>
<tr>
<td>15</td>
<td>Round to prepare for shorter precision</td>
</tr>
</tbody>
</table>

* All rounding methods, other than those listed as reserved, are valid for any conversion function, regardless of the radix of the result.

Figure 9-27. PFPO-Rounding Method (GR0 bits 60-63)

Figure 9-28 shows the basic PFPO functions. PFPO basic functions comprise the set of combinations of the operation-type, first-operand-format, and second-operand-format fields which are valid when the PFPO instruction is installed. Other combinations of operation type and format are not valid and will result in either a specification exception being recognized (when the test bit is zero) or condition code 3 (when the test bit is one).

<table>
<thead>
<tr>
<th>GR0 bits 33-55 (hex)</th>
<th>Function</th>
<th>Exceptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>010000</td>
<td>Convert HFP short to HFP short</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010001</td>
<td>Convert HFP short to HFP long</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010002</td>
<td>Convert HFP short to HFP extended</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010003</td>
<td>Convert BFP short to DFP short</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010004</td>
<td>Convert BFP short to DFP long</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010005</td>
<td>Convert BFP short to DFP extended</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010006</td>
<td>Convert BFP long to HFP short</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010007</td>
<td>Convert BFP long to HFP long</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010008</td>
<td>Convert BFP long to HFP extended</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010009</td>
<td>Convert BFP long to DFP short</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010010</td>
<td>Convert BFP long to DFP long</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010011</td>
<td>Convert BFP long to DFP extended</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010012</td>
<td>Convert BFP long to HFP short</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010013</td>
<td>Convert BFP long to HFP long</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010014</td>
<td>Convert BFP long to HFP extended</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010015</td>
<td>Convert BFP long to DFP short</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010016</td>
<td>Convert BFP long to DFP long</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010017</td>
<td>Convert BFP long to DFP extended</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010018</td>
<td>Convert BFP short to BFP short</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010019</td>
<td>Convert BFP short to BFP long</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010020</td>
<td>Convert BFP short to BFP extended</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010021</td>
<td>Convert BFP extended to DFP short</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010022</td>
<td>Convert BFP extended to DFP long</td>
<td>SP Da Xi Xx</td>
</tr>
<tr>
<td>010023</td>
<td>Convert BFP extended to DFP extended</td>
<td>SP Da Xi Xx</td>
</tr>
</tbody>
</table>

Da AFP-register data exception.
SP Specification exception due to invalid PFPO rounding method; for BFP target, specification exception due to nonzero target-radix-dependent controls; for DFP target, specification exception due to nonzero DFP-quantum-permission control when the floating-point-extension facility is not installed.
Xi IEEE-invalid-operation exception.
Xo IEEE-overflow exception.
Xq Quantum exception, if the floating-point-extension facility is installed.
Xu IEEE-underflow exception.
Xx IEEE-inexact exception.

In the detailed descriptions that follow there are many references to quantum exceptions. Those apply only when the floating-point-extension facility is installed, and bit 58 of general register 0 is one.

**Inexact-Suppression Control:** Bit 56 of general register 0 is the inexact-suppression control. When the inexact-suppression control is zero, IEEE-inexact exceptions are recognized and reported in the normal manner. When the inexact-suppression control is one, IEEE-inexact exceptions are not recognized, and no trap or nontrap action for the exceptions
PERFORM FLOATING-POINT OPERATION

occurs. The inexact-suppression control has no effect on the DXC; that is, the DXC for IEEE-overflow or IEEE-underflow exceptions along with the detail for exact, inexact and truncated, or inexact and incremented, is reported according to the actual condition.

Alternate-Exception-Action Control: Bit 57 of general register 0 is the alternate-exception-action control. The setting of this control affects the action taken for IEEE-overflow and IEEE-underflow trap exceptions.

When the alternate-exception-action control is zero, IEEE-overflow and IEEE-underflow trap exceptions are reported in the normal manner. That is, the appropriate data exception code (DXC) is placed in byte 2 of the floating-point control register, the operation is completed, and a program interruption for a data exception occurs. (As part of the program interruption, the DXC is stored at location 147.) This is called an IEEE trap exception with normal action.

When the alternate-exception-action control is one, the DXC is placed in byte 2 of the floating-point control register, the operation is completed, condition code 2 is set, and program execution continues with the next sequential instruction. (There is no program interruption and the DXC is not stored at location 147.) This is called an IEEE trap exception with alternate action.

Target-Radix-Dependent Controls: Bits 58 and 59 comprise controls for a target (first) operand having either the HFP or DFP format, as described below. When the operand-format control for the first operand designates the BFP format, both bits 58 and 59 must contain zeros; otherwise, a specification exception is recognized (when the test bit is zero) or condition code 3 is set (when the test bit is one).

HFP-Overflow Control: Bit 58 of general register 0 is the HFP-overflow control. When the HFP-overflow control is zero, an HFP-overflow condition is reported as an IEEE-invalid-operation exception and is subject to the IEEE-invalid-operation mask. When the HFP-overflow control is one, an HFP-overflow condition is reported as an IEEE-overflow exception and is subject to the IEEE-overflow mask.

HFP-Underflow Control: For HFP targets, bit 59 of general register 0 is the HFP alternate underflow control. When the HFP-underflow control is zero, HFP underflow causes the result to be set to a true zero with the same sign as the source and underflow is not reported. (The result in this case is inexact and subject to the inexact-suppression control.) When the HFP-underflow control is one, the condition is reported as an IEEE-underflow exception and is subject to the IEEE-underflow mask.

DFP Quantum-Permission Control (DQPC): When the floating-point extension facility is installed, for DFP targets, bit 58 of general register 0 is the DFP quantum-permission control (DQPC). If this control is zero, recognition of the quantum exception is suppressed so that no trap or nontrap action for the exception occurs; if the control is one, recognition of the quantum exception is not suppressed.

DFP Preferred Quantum Control (DPQC): For DFP targets, bit 59 of general register 0 is the DFP preferred quantum control (DPQC). For radix conversion with DFP targets, if the delivered value is inexact, the cohort member with the smallest quantum is selected; if the delivered value is exact, selection depends on the value of bit 59 of general register 0, the DFP preferred quantum control (DPQC). When the delivered value is exact and the DQPC bit is zero, the cohort member with the largest quantum is selected. When the delivered value is exact and the DPQC bit is one, the preferred quantum is one and the cohort member with the quantum closest to one is selected.

Return Code
Regardless of what condition code is set, and independent of whether the test bit is one, a 32-bit return code is placed in bits 32-63 of general register 1; bits 0-31 of general register 1 remain unchanged. A return code is also placed in general register 1 when a program interruption occurs for an IEEE trap exception that completes; general register 1 is not updated when a program interruption occurs for an IEEE trap exception that suppresses. Thus, general register 1 is updated on a program interruption for IEEE-overflow, IEEE-underflow, IEEE-inexact, and quantum-exception trap exceptions, but is not updated on a program interruption for an IEEE-invalid-operation trap exception.

Except where otherwise specified, the return code is a value of zero.

Sign Preservation
For PFPO convert floating-point radix, the sign of the result is the same as the sign of the source. The only exception to this is when the source is a NaN and the
target is HFP; in this case, the result is the largest representable number in the target HFP format (Hmax) with the sign set to plus.

**Preferred Quantum**
For radix conversion with DFP targets, the handling of the quantum is described in “DFP Preferred Quantum Control (DPQC)” on page 9-38.

**NaN Conversion**
When converting between DFP and BFP, the sign of the NaN is always preserved, and the value of the payload is preserved, when possible. If the value of the source payload exceeds the maximum value of the target payload, the target is set to the default QNaN, but with the same sign as the source.

When traps are disabled, an SNaN is converted to the corresponding QNaN, and the payload is preserved, when possible; that is, SNaN(x) is converted to QNaN(x), where x is the value of the payload. See the section “Propagation of NaNs” on page 9-3 for additional details.

For DFP, both QNaN(0) and SNaN(0) can be represented; but in BFP, there is a representation for QNaN(0), but not for SNaN(0).

**Scaled Value and Signed Scaling Exponent (Ω) for PFPO**
When, for the PFPO-convert-floating-point-radix operation, IEEE-overflow trap action or IEEE-underflow trap action occurs, the scaled value is computed using the following steps:

\[
\Psi = b^\Omega \\
z = g \times \Psi
\]

Where \( \Omega \) is the signed scaling exponent, \( b \) is the target radix (2, 10, or 16), \( \Psi \) is the scale factor, \( g \) is the precision-rounded value, and \( z \) is the scaled value.

The signed scaling exponent (Ω) is selected to make the magnitude of the value of the scaled result (z) lie in the range:

\[1 \leq |z| < b.\]

The value of the signed scaling exponent (Ω), treated as a 32-bit signed binary integer, is placed in bits 32-63 of general register 1; bits 0-31 of general register 1 remain unchanged.

The scaled value is used as the delivered value and is placed in the result location. For DFP targets, the cohort member with the quantum nearest to the scaled preferred quantum is selected. (But it should be noted that for all currently supported conversions where scaling is required, the result is always inexact, so the cohort member with the smallest quantum is selected.) For BFP targets, there are no redundant representations, there is only one member in a cohort. For HFP targets, the result is normalized.

**HFP Values**
Unnormalized HFP values are accepted on input, but all HFP results are normalized. If an HFP result would be less than the smallest (in magnitude) representable normalized number, an HFP underflow condition exists.

**HFP Zero Result**
For PFPO-convert-BFP-to-HFP or PFPO-convert-DFP-to-HFP functions, if the source operand is zero, the result has the same sign as that of the source operand, and has all zeros in fraction and characteristic.

**HFP Overflow and Underflow for PFPO**
For an HFP target of a PFPO-convert-floating-point-radix operation, the handling of overflow and underflow conditions is controlled by the HFP-overflow control and the HFP-underflow control, respectively.

**HFP Overflow:** An HFP-overflow condition exists when an HFP target precision's largest number (Hmax) is exceeded in magnitude by the precision-rounded value. That is, when the characteristic of a normalized HFP result would exceed 127 and the fraction is not zero.

When the HFP-overflow control is zero, HFP-overflow is reported as an IEEE-invalid-operation exception and is subject to the IEEE-invalid-operation mask in the FPC register. This is called an **HFP-overflow-as-IEEE-invalid-operation condition**.

When the HFP-overflow control is one, HFP overflow is reported as an IEEE-overflow exception and is subject to the IEEE-overflow mask in the FPC register. This is called an **HFP-overflow-as-IEEE-overflow condition**.

**HFP Underflow:** An HFP-underflow condition exists when the precision-rounded value is nonzero and less in magnitude than the HFP target preci-
PERFORM FLOATING-POINT OPERATION

...sion's smallest normalized number, \( H_{\text{min}} \). That is, when the characteristic of a normalized HFP result would be less than zero and the fraction is not zero. Reporting of the HFP-underflow condition is subject to the HFP-underflow control. The result in this case, however, is inexact and is subject to the controls for that condition.

When the HFP-underflow control is zero, the HFP-underflow condition is not reported. The result is set to a true zero with the same sign as the source.

When the HFP-underflow control is one, HFP underflow is reported as an IEEE-underflow exception and is subject to the IEEE-underflow mask (IMu) in the FPC register. This is called an HFP-underflow-as-IEEE-underflow condition. When IMu is zero, the result is set to a true zero with the same sign as the source, and the return code in general register 1 is zero; when IMu is one, the result is set to a scaled value, and the return code is nonzero.

**IEEE Exceptions for PFPO**

Except where otherwise stated, the following sections on IEEE exceptions apply to both BFP and DFP.

**IEEE Invalid Operation:** An IEEE-invalid-operation exception is recognized when any of the following occurs:

1. An SNaN is encountered in an IEEE source.
2. In an IEEE-to-HFP conversion, a NaN (QNaN or SNaN) or an infinity is encountered in the IEEE source.

IEEE-invalid-operation exceptions are recognized as either IEEE-invalid-operation nontrap exceptions or IEEE-invalid-operation trap exceptions.

**IEEE-Invalid-Operation Nontrap Action:** IEEE-invalid-operation nontrap action occurs when an IEEE-invalid-operation exception is recognized and the IEEE-invalid-operation mask bit in the FPC register is zero. The operation is completed and the IEEE-overflow flag bit in the FPC register is set to one. For IEEE targets, the result of the operation depends on the sign of the precise intermediate value and on the effective rounding method:

1. For all round-to-nearest methods and round-away-from-0, the result is infinity with the sign of the precise intermediate value.
2. For round-toward-0 and round-to-prepare-for-shorter-precision, the result is the largest finite number of the format, with the sign of the precise intermediate value.
3. For round toward \(+\infty\), the result is \(+\infty\) if the sign is plus, or it is the negative finite number with the largest magnitude if the sign is minus.

**IEEE-Invalid-Operation Trap Action:** IEEE-invalid-operation trap action occurs when an IEEE-invalid-operation exception is recognized and the IEEE-invalid-operation mask bit in the FPC register is one. The operation is suppressed, and the exception is reported as a program interruption for a data exception with DXC 80 hex.

**IEEE Overflow:** For IEEE targets, an IEEE-overflow exception is recognized when the precision-rounded value is greater in magnitude than the largest finite number (Nmax) representable in the target format. For HFP targets, an IEEE-overflow exception is recognized when the HFP-overflow condition exists and the HFP-overflow control is one.

**IEEE-Overflow Nontrap Action:** IEEE-overflow nontrap action occurs when the IEEE-overflow exception is recognized and the IEEE-overflow mask bit in the FPC register is zero.

The operation is completed and the IEEE-overflow flag bit in the FPC register is set to one. For IEEE targets, the result of the operation depends on the sign of the precise intermediate value and on the effective rounding method:

1. For all round-to-nearest methods and round-away-from-0, the result is infinity with the sign of the precise intermediate value.
2. For round-toward-0 and round-to-prepare-for-shorter-precision, the result is the largest finite number of the format, with the sign of the precise intermediate value.
3. For round toward \(+\infty\), the result is \(+\infty\) if the sign is plus, or it is the negative finite number with the largest magnitude if the sign is minus.
4. For round toward \(-\infty\), the result is the largest positive finite number if the sign is plus or \(-\infty\) if the sign is minus.

For HFP targets, the result is set to the largest representable number in the target HFP format (Hmax) with the same sign as the source.

Additional action depends on whether there is also an IEEE-inexact exception or a quantum exception.

When IEEE-overflow nontrap action occurs, and neither IEEE-inexact exception nor quantum exception has been recognized, the IEEE-overflow flag bit in the FPC register is set to one and condition code 1 is set.

When an IEEE-overflow nontrap action occurs together with an IEEE-inexact nontrap action, or with a quantum-exception nontrap action, or with nontrap actions for both IEEE-inexact and quantum-exception, the IEEE flag bits in the FPC register for all the recognized exceptions are set to ones and condition code 1 is set.

When IEEE-overflow nontrap action and IEEE-inexact trap action occur, the condition code is not set, the IEEE-overflow flag bit in the FPC register is set to one, and the IEEE-inexact exception is reported as a program interruption for a data exception with DXC 08 or 0C hex, depending on whether the result is inexact and truncated (rounded toward zero) or inexact and incremented, respectively.

When IEEE-overflow nontrap action and quantum-exception trap action occur, the condition code is not set, the IEEE-overflow flag bit in the FPC register is set to one, and the quantum exception is reported as a program interruption for a data exception with DXC 04 hex. When in addition an IEEE-inexact nontrap action occurs, the IEEE-inexact flag bit in the FPC register is set to one.

**IEEE-Overflow Trap Action:** IEEE-overflow trap action occurs when the IEEE-overflow exception is recognized and the IEEE-overflow mask bit in the FPC register is one.

The operation is completed by setting the result to the scaled value; placing the value of the signed scaling exponent (\(\Omega\)), treated as a 32-bit signed binary integer in bits 32-63 of general register 1; and setting DXC 20, 28, or 2C hex, depending on whether the delivered value is exact, inexact and truncated (rounded toward zero), or inexact and incremented, respectively. When the precise intermediate result is rounded to an infinity, it is considered to be an incremented result.

For DFP targets, the delivered value is always inexact and the cohort member with the smallest quantum is selected.

Additional action depends on the value of the alternate-exception-action control.

When the alternate-exception-action control is zero, condition code is not set and the exception is reported as a program interruption for a data exception.

When the alternate-exception-action control is one, condition code 2 is set and no program interruption occurs.

**IEEE Underflow:** For IEEE targets, an IEEE-underflow exception is recognized when the tininess condition exists and either: (1) the IEEE-underflow mask bit in the FPC register is zero and the denormalized value is inexact, or (2) the IEEE-underflow mask bit in the FPC register is one.

The tininess condition exists when the precise intermediate value of an IEEE computational operation is nonzero and smaller in magnitude than the smallest normal number (Nmin) representable in the target format.

The denormalized value is inexact if it is not equal to the precise intermediate value.

For HFP targets, an IEEE-underflow exception is recognized when the HFP-underflow condition exists and the HFP-underflow control is one.

**IEEE-Underflow Nontrap Action:** IEEE-underflow nontrap action occurs when the IEEE-underflow exception is recognized and the IEEE-underflow mask bit in the FPC register is zero.

The operation is completed and the IEEE-underflow flag bit in the FPC register is set to one.

For IEEE targets, the result is set to the denormalized value. For DFP targets, the cohort member with the smallest quantum is selected.
For HFP targets, the result is set to a true zero with the same sign as the source.

Additional action depends on whether there is also an IEEE-inexact exception or a quantum exception.

When IEEE-underflow nontrap action occurs, and neither IEEE-inexact exception nor quantum exception has been recognized, the IEEE-underflow flag bit in the FPC register is set to one and condition code 1 is set.

When an IEEE-underflow nontrap action occurs together with an IEEE-inexact nontrap action, or with a quantum-exception nontrap action, or with nontrap actions for both IEEE-inexact and quantum-exception, the IEEE flag bits in the FPC register for all the recognized exceptions are set to ones and condition code 1 is set.

When IEEE-underflow nontrap action and IEEE-inexact trap action occur, the condition code is not set, the IEEE-underflow flag bit in the FPC register is set to one, and the IEEE-inexact trap exception is reported as a program interruption for a data exception with DXC 10, 18, or 1C hex, depending on whether the result is exact and truncated (rounded toward zero) or inexact and incremented, respectively.

For DFP targets, the delivered value is always inexact and the cohort member with the smallest quantum is selected.

Additional action depends on the value of the alternate-exception-action control.

When the alternate-exception-action control is zero, the condition code is not set and the exception is reported as a program interruption for a data exception.

When the alternate-exception-action control is one, condition code 2 is set and no program interruption occurs.

**IEEE Inexact:** An IEEE-inexact exception is recognized when, for a PFPO-convert-floating-point-radix operation, an inexact condition exists, recognition of the exception is not suppressed, and neither IEEE-overflow trap action nor IEEE-underflow trap action occurs.

In the absence of an IEEE-invalid-operation condition, an inexact condition exists when the rounded intermediate value differs from the precise intermediate value. The condition also exists when IEEE-overflow trap action occurs.

Even though an inexact condition exists, the IEEE-inexact exception is not recognized if the inexact-suppression control is one or if IEEE overflow or IEEE underflow trap action occurs. When an inexact condition exists and the conditions for an IEEE-overflow trap action or IEEE-underflow trap action also apply, the trap action takes precedence and the inexact condition is reported in the DXC.

**IEEE-Inexact Nontrap Action:** IEEE-inexact nontrap action occurs when the IEEE-inexact exception is recognized and the IEEE-inexact mask bit in the FPC register is zero.

IEEE-Inexact Nontrap Action: IEEE-inexact nontrap action occurs when the IEEE-inexact exception is recognized and the IEEE-inexact mask bit in the FPC register is zero.

The operation is completed by setting the result to the scaled value; placing the value of the signed scaling exponent (\( \hat{\ell} \)), treated as a 32-bit signed binary integer in bits 32-63 of general register 1; and setting DXC 10, 18, or 1C hex, depending on whether the result is exact, inexact and truncated (rounded toward zero), or inexact and incremented, respectively.

In the absence of another IEEE nontrap action, the operation is completed using the rounded intermediate value, condition code 1 is set, and the IEEE-inexact flag bit in the FPC register is set to one. For DFP targets, the cohort member with the smallest quantum is selected.

When an IEEE-inexact nontrap action and an IEEE-overflow or IEEE-underflow nontrap action coincide, the operation is completed using the result specified for the other exception and the flag bits for both
exceptions are set to one, and condition code 1 is set. When in addition, a quantum-exception nontrap action occurs, the quantum-exception flag bit in the FPC register is also set to one.

**IEEE-Inexact Trap Action:** IEEE-inexact trap action occurs when the IEEE-inexact exception is recognized and the IEEE-inexact mask bit in the FPC register is one. The operation is completed, the condition code is not set, and the exception is reported as a program interruption for a data exception with DXC 08 or 0C hex, depending on whether the result is inexact and truncated (rounded toward zero) or inexact and incremented, respectively. When the precise intermediate result is rounded to an infinity, it is considered to be an incremented result.

In the absence of a coincident IEEE nontrap action, the delivered value is set to the rounded intermediate value. For DFP targets, the cohort member with the smallest quantum is selected.

When the IEEE-inexact trap action coincides with an IEEE nontrap action, the operation is completed using the result specified for the IEEE nontrap action, the flag bit for the nontrap exception is set to one, and the IEEE-inexact trap action takes place.

**Quantum Exception:** A quantum exception is recognized when the floating-point extension facility is installed, and when a quantum-exception condition exists, recognition of the exception is not suppressed (DQPC = 1), and none of IEEE-overflow trap action, IEEE-underflow trap action, and IEEE-inexact trap action occurs.

For a PFPO-convert-floating-point-radix operation with DFP result, a quantum-exception condition exists when the delivered DFP result is inexact, or when the delivered DFP result is exact and finite, but the delivered quantum exceeds the preferred quantum of 1. (See programming note 6.)

When the floating-point extension facility is not installed, no quantum exception is recognized.

Even though a quantum-exception condition exists, the quantum exception is not recognized if recognition of the exception is suppressed (DQPC = 0), or if IEEE-overflow, IEEE-underflow, or IEEE-inexact trap action occurs. When a quantum-exception condition exists, and the conditions for an IEEE-overflow, IEEE-underflow, or IEEE-inexact trap action also apply, the trap action takes precedence and the quantum exception is not reported in status flag or DXC.

**Quantum-Exception Nontrap Action:** Quantum-exception nontrap action occurs when the quantum exception is recognized and the quantum-exception mask bit in the FPC register is zero.

In the absence of another IEEE nontrap action, the operation is completed using the rounded intermediate value, condition code 1 is set, and the quantum-exception flag bit in the FPC register is set to one.

When a quantum-exception nontrap action and another one or two IEEE nontrap actions coincide, the operation is completed using the result specified for the other exceptions and the flag bits for all two or three exceptions are set to one, and condition code 1 is set.

**Quantum-Exception Trap Action:** Quantum-exception trap action occurs when the quantum exception is recognized and the quantum-exception mask bit in the FPC register is one. The operation is completed, the condition code is not set, and the exception is reported as a program interruption for a data exception with DXC 04 hex.

In the absence of a coincident IEEE nontrap action, the delivered value is set to the rounded intermediate value.

When the quantum-exception trap action coincides with other IEEE nontrap actions, the operation is completed using the result specified for the other IEEE nontrap actions, the flag bits for the nontrap exceptions are set to one, and the quantum-exception trap action takes place.

**Resulting Condition Code (when test bit is zero):**

- 0 Normal result
- 1 Nontrap exception
- 2 Trap exception with alternate action
- 3 --

**Resulting Condition Code (when test bit is one):**

- 0 Function is valid
- 1 --
- 2 --
- 3 Function is invalid

**IEEE Exceptions:**
- Invalid operation
- Overflow
- Underflow
- Inexact
- Quantum (if the floating-point extension facility is installed)

**Program Exceptions:**

- Data with DXC 1, AFP register
- Data with DXC for IEEE exception
- Operation (if the PFPO facility is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. The PFPO-convert-floating-point-radix operation performs “correct rounding”; that is, the result is accurately obtained from the precise intermediate value using the effective rounding method. This is in contrast to some radix conversion programs, which may produce results with larger rounding errors.

2. Note that a value of zero in the rounding-method field (GR0 bits 60-63) specifies rounding according to the current DFP rounding mode (FPC 3.1-3) regardless of whether the target is DFP, BFP, or HFP. Similarly, a value of one in the rounding-method field specifies rounding according to the current BFP rounding mode (FPC 3.5-7), regardless of the target format.

3. If the program does not supply a default QNaN (payload = zero) as a source, then its presence as a result indicates that the machine either created a new QNaN or the program attempted to convert a payload which was too large for this format.

4. If the program restricts payloads to values within the smallest payload capacity of any first-oper-and format, then payloads are preserved across radix conversions.

5. To display a value in scientific notation, many programming languages, calculators, and spreadsheet use the letter e (or E) to separate the significand from the exponent. This is referred to as e-form notation. In this document, e-form notation, along with other forms of conventional numeric notation, is used to represent a value without regard to quantum. To indicate that both value and quantum are being represented, a variation of e-form notation, called q-form notation, is used. In q-form notation, the letter q replaces the letter e and the value shown after q is the right-units-view exponent, that is, the base 10 logarithm of the quantum. Thus, for example, the seven members of the cohort for the value 1e6 in the DFP short format are: 1q6, 10q5, 100q4, 1000q3, 10000q2, 100000q1, and 1000000q0.

As an example of the distinction between e-form and q-form notation, consider the representation of the members of the cohort of zero. The DFP short format, for example, can represent 198 exact powers of 10, ranging in value from 1e-101 to 1e96; but can represent only 192 values for a quantum, ranging from 1e-101 to 1e90. Thus, the 192 members of the cohort for zero range from 0q-101 to 0q90.

The effect of the DFP preferred quantum control is shown in Figure 9-29.

<table>
<thead>
<tr>
<th>Rounded Intermediate Value</th>
<th>Result If Inexact</th>
<th>Result If Exact and DPOQ = 0</th>
<th>Result If Exact and DPOQ = 1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0q-101</td>
<td>0q90</td>
<td>0q0</td>
</tr>
<tr>
<td>0.125</td>
<td>12500000q-7</td>
<td>125q-3</td>
<td>125q-3</td>
</tr>
<tr>
<td>1</td>
<td>10000000q-6</td>
<td>1q0</td>
<td>1q0</td>
</tr>
<tr>
<td>10</td>
<td>10000000q-5</td>
<td>1q1</td>
<td>10q0</td>
</tr>
<tr>
<td>100</td>
<td>10000000q-4</td>
<td>1q2</td>
<td>100q0</td>
</tr>
<tr>
<td>1000</td>
<td>10000000q-3</td>
<td>1q3</td>
<td>1000q0</td>
</tr>
<tr>
<td>9999</td>
<td>99999999999q-3</td>
<td>9999q0</td>
<td>9999q0</td>
</tr>
<tr>
<td>10000</td>
<td>100000000q-2</td>
<td>1q4</td>
<td>10000q0</td>
</tr>
<tr>
<td>10001</td>
<td>10001000q-2</td>
<td>10001q0</td>
<td>100001q0</td>
</tr>
<tr>
<td>1e5</td>
<td>10000000q-1</td>
<td>1q5</td>
<td>1000000q0</td>
</tr>
<tr>
<td>1e6</td>
<td>100000000q0</td>
<td>1q6</td>
<td>100000000q0</td>
</tr>
<tr>
<td>1e10</td>
<td>100000000q4</td>
<td>1q10</td>
<td>100000000q4</td>
</tr>
<tr>
<td>1e15</td>
<td>100000000q9</td>
<td>1q15</td>
<td>100000000q9</td>
</tr>
</tbody>
</table>

*Figure 9-29. Effect of DPOQ on DFP Short Results*
6. When the floating-point extension facility is installed, for a PFPO-convert-floating-point-radix operation with DFP result, if DPQC is zero and the DFP result is finite and exact, no quantum exception is recognized. This is because the operation always delivers the DFP result with the preferred quantum in this case.

7. The test bit (bit 32 of general register 0) provides a means of determining whether any future extensions to the operation-type code, operand-format code, target-radix-dependent controls, rounding method, and various combinations thereof are supported by the CPU.

**PFPO Actions**

Figure 9-30 summarizes the actions performed by the PFPO-convert-floating-point-radix operation for various target formats.

### Table: Actions for Various PERFORM Floating Point Conditions

<table>
<thead>
<tr>
<th>Condition</th>
<th>Response</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Source</strong></td>
<td><strong>Rx</strong></td>
</tr>
<tr>
<td>Normal</td>
<td>N</td>
</tr>
<tr>
<td>Normal</td>
<td>Y</td>
</tr>
<tr>
<td>Normal</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>N</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>N</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>N</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>N</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Xu</td>
<td>N</td>
</tr>
<tr>
<td>Xu</td>
<td>Y</td>
</tr>
<tr>
<td>Infinity</td>
<td>N</td>
</tr>
<tr>
<td>QNaN</td>
<td>N</td>
</tr>
<tr>
<td>QNaN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
<tr>
<td>XoN</td>
<td>N</td>
</tr>
<tr>
<td>XoN</td>
<td>Y</td>
</tr>
</tbody>
</table>

**Figure 9-30. Actions for Various PERFORM FLOATING POINT Conditions (Part 1 of 2)**
### Actions for PFPO Hexadecimal-Floating-Point Targets

<table>
<thead>
<tr>
<th>Condition</th>
<th>Response</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Normal</strong></td>
<td></td>
</tr>
<tr>
<td>N</td>
<td>Complete CC0</td>
</tr>
<tr>
<td>Y</td>
<td>Complete CC0</td>
</tr>
<tr>
<td>Y 0</td>
<td>Complete CC1 1</td>
</tr>
<tr>
<td>Normal Y 0</td>
<td>Complete PI 00001y00</td>
</tr>
<tr>
<td><strong>Ho</strong></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Hmax CC1 1</td>
</tr>
<tr>
<td>0 1</td>
<td>Supp. PI 10000000</td>
</tr>
<tr>
<td>Ho Y' 1</td>
<td>Hmax CC1 1</td>
</tr>
<tr>
<td>Ho Y' 0</td>
<td>Hmax CC1 1 1</td>
</tr>
<tr>
<td>Ho Y' 0 1</td>
<td>Hmax CC1 1 1 1</td>
</tr>
<tr>
<td>Ho Y' 0 1</td>
<td>Hmax CC1 1 1 1</td>
</tr>
<tr>
<td>Ho Y' 1 1</td>
<td>Hmax CC1 1</td>
</tr>
<tr>
<td><strong>Hu</strong></td>
<td></td>
</tr>
<tr>
<td>Y</td>
<td>TZ CC0</td>
</tr>
<tr>
<td>Y 0</td>
<td>TZ CC1 1</td>
</tr>
<tr>
<td>Y 0 1</td>
<td>TZ PI 00001000</td>
</tr>
<tr>
<td>Hu Y' 1</td>
<td>TZ CC1 1</td>
</tr>
<tr>
<td>Hu Y' 0</td>
<td>TZ CC1 1 1</td>
</tr>
<tr>
<td>Hu Y' 0 1</td>
<td>TZ PI 00001000</td>
</tr>
<tr>
<td>Hu Y' 0 1</td>
<td>TZ PI 00001000</td>
</tr>
<tr>
<td><strong>Infinity</strong></td>
<td></td>
</tr>
<tr>
<td>N</td>
<td>Hmax CC1 1</td>
</tr>
<tr>
<td>+N</td>
<td>Hmax CC1 1</td>
</tr>
<tr>
<td><strong>NaN</strong></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Supp. PI 10000000</td>
</tr>
<tr>
<td>1</td>
<td>Supp. PI 10000000</td>
</tr>
</tbody>
</table>

### Explanation:
- **Caa**: Alternate-exception-action control (GR0.57)
- **Cho**: HFP-overflow control (GR0.58 for HFP targets)
- **Csa**: Inexact-suppression control (GR0.56)
- **DQPC**: DFP quantum-permission control (GR0.58 for DFP targets)
- **DXC**: Data-Exception Code (shown in binary)
- **Hmax**: The largest (in magnitude) representable number in this HFP format with the same sign as the source.
- **+Hmax**: Hmax with a plus sign
- **Ho**: HFP-overflow condition
- **Hu**: HFP-underflow condition
- **IMi**: IEEE-invalid-operation mask (FPC.0)
- **IMo**: IEEE-overflow mask (FPC.2)
- **IMq**: Quantum-exception mask (FPC.5)
- **IMu**: IEEE-underflow mask (FPC.3)
- **IMx**: IEEE-inexact mask (FPC.4)
- **N**: No
- **N'**: No (true by virtue of other conditions in this row)
- **Pi**: Program interruption
- **Rx**: Inexact-result condition
- **SFi**: IEEE-invalid-operation flag (FPC.8)
- **SFo**: IEEE-overflow flag (FPC.10)
- **SFq**: Quantum-exception flag (FPC.13)
- **SFu**: IEEE-underflow flag (FPC.11)
- **SFx**: IEEE-inexact flag (FPC.12)
- **x**: Inexact result (bit 4 of the DXC)
- **X**: IEEE-invalid-operation exception
- **Xi**: IEEE-overflow exception
- **Xo**: IEEE-underflow exception
- **Y**: Inexact result was incremented in magnitude (bit 5 of the DXC)
- **Y': Yes (true by virtue of other conditions in this row)

Figure 9-30. Actions for Various PERFORM FLOATING POINT Conditions (Part 2 of 2)
SET BFP ROUNDING MODE

Mnemonic | D2(B2) [S]
---|---
Op Code | B2
---|---
0 | 16
---|---
20 | 31

Mnemonic | Op Code | Operands
---|---|---
SRNMT | 'B2B9' | 2-bit BFP rounding mode
SRNMB | 'B2B8' | 3-bit BFP rounding mode

The BFP rounding-mode bits in the FPC register are set from the second-operand address.

For SRNM, the second-operand address is not used to address data; instead, bits 30-31 of the FPC register are set to bits 62 and 63, respectively, of the address. Bits other than 62 and 63 of the second-operand address are ignored. When the floating-point extension facility is installed, bit 29 of the FPC register is set to zero.

For SRNMB, the second-operand address is not used to address data; instead, bits 29-31 of the FPC register are set to bits 61-63, respectively, of the address. Bits 0-55 of the second-operand address are ignored, bits 56-60 must be zero, and bits 61-63 must designate a valid rounding mode; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

IEEE Exceptions: None.

Program Exceptions:

- Data with DXC 3, DFP instruction
- Operation (if the decimal-floating-point-rounding facility is not installed)
- Transaction constraint

SET FPC

SFPC | R1 | [RRE]
---|---|---
'B2B9' | 24 | 28

The contents of bit positions 32-63 of the general register designated by R1 are placed in the FPC (floating-point-control) register.

All of bits 32-63 corresponding to unsupported bit positions in the FPC register must be zero; otherwise, a specification exception is recognized. For purposes of this checking, a bit position is considered to be unsupported only if it is either unassigned or assigned to a facility which is not installed in any architectural mode of the configuration. Bits 0-31 of the general register are ignored.

When the floating-point extension facility is installed, the bits corresponding to the BFP rounding mode must specify a valid rounding mode; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

IEEE Exceptions: None.

Program Exceptions:

- Data with DXC 2, BFP instruction
SET FPC AND SIGNAL

First, bits 0-4 of byte 1 of the floating-point-control (FPC) register at the beginning of the operation are preserved to be used as signaling flags. Next, the contents of the source operand are placed in the FPC register; then the flags in the FPC register are set to the logical OR of the signaling flags and the source flags. Finally, the conditions for simulated-IEEE-exception trap action are examined.

The source operand is in bits 32-63 of the general register designated by R1; bits 0-31 of the general register are ignored.

If any signaling flag is one and the corresponding source mask is also one, simulated-IEEE-exception trap action occurs. The data-exception code (DXC) in the FPC register is updated to indicate the specific cause of the interruption and a data-exception program interruption occurs at completion of the instruction execution. The DXC for the interruption is shown in Figure 9-21 on page 9-33.

If no signaling flag is enabled, the DXC in the FPC register remains as loaded from the source and instruction execution completes with no trap action.

See Figure 9-22 on page 9-33 for a detailed description of the result of this instruction.

Bits in the source operand that correspond to unsupported bit positions in the FPC register must be zero; otherwise, a specification exception is recognized. For purposes of this checking, a bit position is considered to be unsupported only if it is either unassigned or assigned to a facility which is not installed in any architectural mode of the configuration.

When the floating-point extension facility is installed, the bits corresponding to the BFP rounding mode must specify a valid rounding mode; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for simulated IEEE exception
- Operation (if the IEEE-exception-simulation facility is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. See also the programming notes under LOAD FPC AND SIGNAL.

2. Bits 0-31 of the general register designated by the R1 field are reserved for future extension and should be set to zeros.

STORE

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>R1,D(X2,B2)</th>
<th>[RX-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
<td>X2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>STE</td>
<td>‘70’</td>
<td>Short</td>
</tr>
<tr>
<td>STD</td>
<td>‘60’</td>
<td>Long</td>
</tr>
</tbody>
</table>

9-48 IBM z/Architecture Principles of Operation
Mnemonic2  R1,D2(X2,B2)

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>40</td>
</tr>
</tbody>
</table>

Mnemonic2  Op Code  Operands
STEY  ‘ED66’  Short
STDY  ‘ED67’  Long

The first operand is placed unchanged in storage at the second-operand location.

The displacement for STE and STD is treated as a 12-bit unsigned binary integer. The displacement for STEY and STDY is treated as a 20-bit signed binary integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Data with DXC 1, AFP register
- Operation (STEY and STDY, if the long-displacement facility is not installed)
- Transaction constraint

**STORE FPC**

STFPC  D2(B2)  [S]

<table>
<thead>
<tr>
<th>‘B29C’</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>

The contents of the FPC (floating-point-control) register are placed in storage at the second-operand location.

The operand is four bytes in length. All 32 bits of the FPC register are stored.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Access (store, operand 2)
- Data with DXC 2, BFP instruction
- Transaction constraint

---

**Summary of All Floating-Point Instructions**

Figures 9-31 through 9-37 on the following pages show mnemonics for all floating-point instructions (except for PFPO) arranged in various categories of operand format and type of operation. Figure 9-31 shows those instructions which operate on the FPC register. Figure 9-32 on page 9-50 shows the floating-point instructions which have all operands in the same format (same radix and same length), including those FPS (floating-point support) instructions which operate on floating-point operands in a radix-independent manner. Figure 9-33 on page 9-51 and Figure 9-34 on page 9-51 show the floating-point instructions in which all operands are in the same radix but not all of the same length. Figure 9-35 on page 9-51 and Figure 9-36 on page 9-52 show the floating-point instructions in which the source or the result is in a general register. Figure 9-37 on page 9-52 shows the floating-point instructions other than PFPO which perform radix conversion.

<table>
<thead>
<tr>
<th>Instruction Name</th>
<th>Mnemonic</th>
<th>Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>EXTRACT FPC</td>
<td>EFPC</td>
<td>BFP</td>
</tr>
<tr>
<td>LOAD FPC</td>
<td>LFPC</td>
<td>BFP</td>
</tr>
<tr>
<td>LOAD FPC AND SIGNAL</td>
<td>LFAS</td>
<td>DFP</td>
</tr>
<tr>
<td>SET BFP ROUNDI NG MODE</td>
<td>SRNM, SRNM,</td>
<td>BFP</td>
</tr>
<tr>
<td></td>
<td>SFRNMB1</td>
<td></td>
</tr>
<tr>
<td>SET DFP ROUNDI NG MODE</td>
<td>SFRNMT</td>
<td>DFP</td>
</tr>
<tr>
<td>SET FPC</td>
<td>SFPIC</td>
<td>BFP</td>
</tr>
<tr>
<td>SET FPC AND SIGNAL</td>
<td>SFASR</td>
<td>DFP</td>
</tr>
<tr>
<td>STORE FPC</td>
<td>STFPC</td>
<td>BFP</td>
</tr>
</tbody>
</table>

**Explanation:**

- Mnemonics in **bold** indicate a register-and-storage operation.
- **BFP** The instruction is considered to be part of the BFP facility. An attempt to execute this instruction when the AFP-register-control bit is zero results in a BFP-instruction data exception, DXC 2.
- **DFP** The instruction is considered to be part of the DFP facility. An attempt to execute this instruction when the AFP-register-control bit is zero results in a DFP-instruction data exception, DXC 3.

Figure 9-31. Floating-Point-Control-Register Instructions
<table>
<thead>
<tr>
<th>Instruction Name</th>
<th>FPS</th>
<th>HFP</th>
<th>BFP</th>
<th>DFP</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD (NORMALIZED)</td>
<td>AER</td>
<td>AE</td>
<td>ADR</td>
<td>AD</td>
</tr>
<tr>
<td>ADD UNNORMALIZED</td>
<td>AUR</td>
<td>AU</td>
<td>AWR</td>
<td>AW</td>
</tr>
<tr>
<td>COMPARE</td>
<td>CER</td>
<td>CE</td>
<td>CDR</td>
<td>CD</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL</td>
<td>KEPR</td>
<td>KEB</td>
<td>KDBR</td>
<td>KDB</td>
</tr>
<tr>
<td>COMPARE BIASED EXPONENT</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COPY SIGN</td>
<td>CPSDR</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DIVIDE</td>
<td>DER</td>
<td>DE</td>
<td>DDR</td>
<td>DD</td>
</tr>
<tr>
<td>DIVIDE TO INTEGER</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>HALVE</td>
<td>HER</td>
<td>HDR</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LOAD</td>
<td>LER</td>
<td>LE</td>
<td>LDR</td>
<td>LD</td>
</tr>
<tr>
<td>LOAD AND TEST</td>
<td>LTEBR</td>
<td>LTE</td>
<td>LTDBR</td>
<td>LTXBR</td>
</tr>
<tr>
<td>LOAD COMPLEMENT</td>
<td>LCEBR</td>
<td>LCER</td>
<td>LCBR</td>
<td>LCB</td>
</tr>
<tr>
<td>LOAD FP INTEGER</td>
<td>FIEBR(A)</td>
<td>FIER</td>
<td>FIXR</td>
<td>FIDB</td>
</tr>
<tr>
<td>LOAD NEGATIVE</td>
<td>LNDFR</td>
<td>LNER</td>
<td>LDBR</td>
<td>LDB</td>
</tr>
<tr>
<td>LOAD POSITIVE</td>
<td>LPDFR</td>
<td>LPER</td>
<td>LDBR</td>
<td>LDB</td>
</tr>
<tr>
<td>LOAD ZERO</td>
<td>LZER</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MULTIPLY</td>
<td>MEER</td>
<td>MEE</td>
<td>MDR</td>
<td>MD</td>
</tr>
<tr>
<td>MULTIPLY AND ADD</td>
<td>MAER</td>
<td>MAE</td>
<td>MADR</td>
<td>MAD</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORMALIZED</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT</td>
<td>MSER</td>
<td>MSE</td>
<td>MSDR</td>
<td>MSD</td>
</tr>
<tr>
<td>MULTIPLY UNNORMALIZED</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>QUANTIZE</td>
<td>QADTR</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>REROUND</td>
<td>RRDR</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND LEFT</td>
<td>SLDT</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND RIGHT</td>
<td>SRDT</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SQUARE ROOT</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>STORE</td>
<td>STE</td>
<td></td>
<td>STDY</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT (NORMALIZED)</td>
<td>SER</td>
<td>SE</td>
<td>SDR</td>
<td>SD</td>
</tr>
<tr>
<td>SUBTRACT UNNORMALIZED</td>
<td>SUR</td>
<td>SU</td>
<td>SWR</td>
<td>SW</td>
</tr>
<tr>
<td>TEST DATA CLASS</td>
<td>TCEB</td>
<td>TCER</td>
<td>TCDB</td>
<td>TCDB</td>
</tr>
<tr>
<td>TEST DATA GROUP</td>
<td>TDGET</td>
<td>TDGE</td>
<td>TDGDT</td>
<td>TDGDT</td>
</tr>
</tbody>
</table>

**Explanation:**

Mnemonics in **bold** indicate a register-and-storage operation. When the last letter of mnemonic is A, the instruction is an alternate instruction, which uses additional modifier fields not available to the original instruction.

*Figure 9-32. Floating-Point Instructions: All Operands Same Format*
### Instruction Name

<table>
<thead>
<tr>
<th>Instruction Name</th>
<th>HFP</th>
<th>BFP</th>
<th>DFP</th>
</tr>
</thead>
<tbody>
<tr>
<td>Short to Long</td>
<td>Long to Ext.</td>
<td>Short to Ext.</td>
<td>Long to Ext.</td>
</tr>
<tr>
<td>LOAD LENGTHENED</td>
<td>LDER</td>
<td>LDE</td>
<td>LXDR</td>
</tr>
<tr>
<td>MULTIPLY</td>
<td>MDER</td>
<td>MDE</td>
<td>MXDR</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORMALIZED</td>
<td>MAYR</td>
<td>MAY</td>
<td></td>
</tr>
<tr>
<td>MULTIPLY UNNORMALIZED</td>
<td>MYR</td>
<td>MY</td>
<td></td>
</tr>
</tbody>
</table>

**Explanation:**

Mnemonics in **bold** indicate a register-and-storage operation.

---

**Figure 9-33. Floating-Point Instructions: Result Longer than Source**

<table>
<thead>
<tr>
<th>Instruction Name</th>
<th>HFP</th>
<th>BFP</th>
<th>DFP</th>
</tr>
</thead>
<tbody>
<tr>
<td>Long to Short</td>
<td>Ext. to Long</td>
<td>Ext. to Short</td>
<td>Long to Ext.</td>
</tr>
<tr>
<td>LOAD ROUNDED</td>
<td>LEDR</td>
<td>LDXR</td>
<td>LEXR</td>
</tr>
</tbody>
</table>

---

**Figure 9-34. Floating-Point Instructions: Result Shorter than Source**

<table>
<thead>
<tr>
<th>Instruction Name</th>
<th>Source GR Size (bits)</th>
<th>FPS</th>
<th>HFP</th>
<th>Result</th>
<th>BFP</th>
<th>DFP</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT FROM FIXED</td>
<td>32</td>
<td>CEFR</td>
<td>CDFR</td>
<td>CFBR(A)</td>
<td>CDFBR(A)</td>
<td>CFTR</td>
</tr>
<tr>
<td>CONVERT FROM FIXED</td>
<td>64</td>
<td>CEGR</td>
<td>CDGR</td>
<td>CGBR(A)</td>
<td>CDGBR(A)</td>
<td>CGTR(A)</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL</td>
<td>32</td>
<td>CELFBR</td>
<td>CDLFBR</td>
<td>CXLFBR</td>
<td>CDLFBR</td>
<td>CXLTR</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL</td>
<td>64</td>
<td>CELGBR</td>
<td>CDLGBR</td>
<td>CXLGBR</td>
<td>CDLGBR</td>
<td>CXLGR</td>
</tr>
<tr>
<td>CONVERT FROM SIGNED PACKED</td>
<td>64</td>
<td>CDSTR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CONVERT FROM SIGNED PACKED</td>
<td>128</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CONVERT FROM UNSIGNED PACKED</td>
<td>64</td>
<td>CDUTR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CONVERT FROM UNSIGNED PACKED</td>
<td>128</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>INSERT BIASED EXPONENT</td>
<td>64</td>
<td>IEDTR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LOAD FPR FROM GR</td>
<td>64</td>
<td>LDGR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

---

**Figure 9-35. Floating-Point Instructions: General Register Source**
Impacts on ESA/390

When the decimal-floating-point facility or the floating-point extension facility is installed in the z/Architecture architectural mode, the behavior of some instructions in the ESA/390 mode is deviated from the definition in the ESA/390 architecture.

The following summarizes the different behavior of affected ESA/390 instructions caused by those two facilities in the z/Architecture architectural mode.

### Impacts of the Decimal-Floating-Point Facility

When the decimal-floating-point facility is installed in the z/Architecture architectural mode, it causes the following deviations from the ESA/390 architecture.

- For LOAD FPC (LFPC) and SET FPC (SFPC), if bits 25-27 of the source operand contain a nonzero value, it is unpredictable whether a specification exception is recognized or the corresponding bits in the FPC register are set to this nonzero value.
Impacts of the Floating-Point
Extension Facility

When the floating-point extension facility is installed in the z/Architectural architecture mode, it causes the following deviations from the ESA/390 architecture.

1. For LOAD FPC (LFPC) and SET FPC (SFPC), if bit 5 of the source operand is one, it is unpredictable whether a specification exception is recognized or the corresponding bit in the FPC register is set to one; if bits 29-31 of the source operand contain all ones, is unpredictable whether a specification exception is recognized or the corresponding bits in the FPC register are set to all ones.

2. For CONVERT HFP TO BFP (TBEDR, TBDR), if the M3 field designates the value 3, it is unpredictable whether a specification exception is recognized or an undefined rounding method is performed.

3. For BFP CONVERT TO FIXED (CFEBR, CFDBR, CFXBR), if the M3 field designates the value 3, it is unpredictable whether a specification exception is recognized or an undefined rounding method is performed. In addition, if bits 20-23 of the instruction contain a nonzero value, it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

4. For BFP CONVERT FROM FIXED (CEFBR, CDFBR, CXFBR), if bits 16-19 of the instruction contain a nonzero value, it is unpredictable whether a specification exception is recognized or an undefined rounding method is performed. In addition, if bits 20-23 of the instruction contain a nonzero value, it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

5. For BFP DIVIDE TO INTEGER (DIEBR, DIDBR), if the M3 field designates the value 3, it is unpredictable whether a specification exception is recognized or an undefined rounding method is performed.

6. For BFP LOAD FP INTEGER (FIEBR, FIDBR, FIXBR), if the M3 field designates the value 3, it is unpredictable whether a specification exception is recognized or an undefined rounding method is performed. In addition, if bits 20-23 of the instruction contain a nonzero value, it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

7. For BFP LOAD ROUNDED (LEDBR, LDXBR, LEXBR), if bits 16-19 of the instruction contain a nonzero value, it is unpredictable whether a specification exception is recognized or an undefined rounding method is performed. In addition, if bits 20-23 of the instruction contain a nonzero value, it is unpredictable whether recognition of IEEE-inexact exception is suppressed.
This chapter includes all privileged and semiprivileged instructions described in this publication, except the input/output instructions, which are described in “I/O Instructions” on page 14-1.

Privileged instructions may be executed only when the CPU is in the supervisor state. An attempt to execute a privileged instruction in the problem state generates a privileged-operation exception.
The semiprivileged instructions are those instructions that can be executed in the problem state when certain authority requirements are met. An attempt to execute a semiprivileged instruction in the problem state when the authority requirements are not met generates a privileged-operation exception or some other program-interruption condition depending on the particular requirement which is violated. Those requirements which cause a privileged-operation exception to be generated in the problem state are not enforced when execution is attempted in the supervisor state.

The control instructions and their mnemonics, formats, and operation codes are listed in Figure 10-1 on page 10-3. The figure also indicates which instructions are new in z/Architecture as compared to ESA/390, when the condition code is set, the instruction fields that designate access registers, and the exceptional conditions in operand designations, data, or results that cause a program interruption.

The instructions that are new in z/Architecture are indicated in Figure 10-1 by "N."

When the operands of an instruction are 32-bit operands, the mnemonic for the instruction does not include a letter indicating the operand length. If there is an instruction with the same name but with 64-bit operands, its mnemonic includes the letter “G.” In Figure 10-1, when there is an instruction with 32-bit operands and another instruction with the same name but with “G” added in its mnemonic, the first instruction has “(32)” after its name, and the other instruction has “(64)” after its name.

For those control instructions which have special rules regarding the handling of exceptional situations, a section called “Special Conditions” is included. This section indicates the type of ending (suppression, nullification, or completion) only for those exceptions for which the ending may vary.

Note: In the detailed descriptions of the individual instructions, the mnemonic and the symbolic operand designation for the assembler language are shown with each instruction. For LOAD PSW, for example, LPSW is the mnemonic and D_2(B_2) the operand designation.

**Programming Notes:**

1. The following additional control instructions are available when the DAT-enhancement facility is installed:
   - COMPARE AND SWAP AND PURGE (CSPG)
   - INVALIDATE DAT TABLE ENTRY

   CSPG operates on a doubleword in storage, in contrast to the previously existing instruction COMPARE AND SWAP AND PURGE (CSP), which operates on a word in storage.

2. The long-displacement facility uses new instruction formats, named RSY, RXY, and SIY, to provide 20-bit signed displacements. In connection with the long-displacement facility, all previously existing control instructions of the RSE or RXE format are changed to be of format RSY or RXY, respectively, where the new formats differ from the old by using a previously unused byte, now named DH, in the instructions. When the long-displacement facility is installed, the displacement for an instruction operand address is formed by appending DH on the left of the previous displacement field, now named DL, of the instruction. When the long-displacement facility is not installed, eight zero bits are appended on the left of DL, and DH is ignored.

   The following additional control instruction is available when the long-displacement facility is installed:
   - LOAD REAL ADDRESS (LRAY)

3. The following additional control instructions are available when the ASN-and-LX-reuse facility is installed:
   - EXTRACT PRIMARY ASN AND INSTANCE
   - EXTRACT SECONDARY ASN AND INSTANCE
   - PROGRAM TRANSFER WITH INSTANCE
   - SET SECONDARY ASN WITH INSTANCE

4. The LOAD PAGE TABLE ENTRY ADDRESS control instruction is available when the DAT-enhancement facility 2 is installed.

5. The PERFORM TIMING FACILITY FUNCTION control instruction is available when the TOD-clock-steering facility is installed.
6. The **MOVE WITH OPTIONAL SPECIFICATIONS** control instruction is available when the move-with-optional-specifications facility is installed.

7. The **PERFORM TOPOLOGY FUNCTION** control instruction is available when the configuration-topology facility is installed.

8. The **PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION** control instruction is available when the message-security-assist extension 3 is installed.

9. The **RESET REFERENCE BITS MULTIPLE** control instruction is available when the reset-reference-bits-multiple facility is installed.

10. The **COMPARE AND REPLACE DAT TABLE ENTRY** instruction is available when the enhanced-DAT facility 2 is installed.

---

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>BRANCH AND SET AUTHORITY</td>
<td>BSA</td>
<td>Q A^* SO T</td>
<td>B</td>
<td>10-6</td>
</tr>
<tr>
<td>BRANCH AND STACK</td>
<td>BAKR</td>
<td>A^* Z^* T</td>
<td>B ST</td>
<td>10-10</td>
</tr>
<tr>
<td>BRANCH IN SUBSPACE GROUP</td>
<td>BSG</td>
<td>A^* SO T</td>
<td>B</td>
<td>10-12</td>
</tr>
<tr>
<td>COMPARE AND REPLACE DAT TABLE ENTRY</td>
<td>CRDTE</td>
<td>A^* SP $</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE AND SWAP AND PURGE (32)</td>
<td>CSP</td>
<td>A^* SP $</td>
<td>ST</td>
<td>10-20</td>
</tr>
<tr>
<td>COMPARE AND SWAP AND PURGE (64)</td>
<td>CSPG</td>
<td>A^* SP $</td>
<td>ST</td>
<td>10-20</td>
</tr>
<tr>
<td>DIAGNOSE</td>
<td>ERE</td>
<td>Q SO</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXTRACT AND SET EXTENDED AUTHORITY</td>
<td>ESEA</td>
<td>Q P</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXTRACT PRIMARY ASN</td>
<td>EPA</td>
<td>Q SO</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXTRACT PRIMARY ASN AND INSTANCE</td>
<td>EPAIR</td>
<td>Q SO</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXTRACT SECONDARY ASN</td>
<td>ESAR</td>
<td>Q SO</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXTRACT SECONDARY ASN AND INSTANCE</td>
<td>ESAIR</td>
<td>Q SP $</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXTRACT STACKED REGISTERS (32)</td>
<td>EREG</td>
<td>A^* SE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXTRACT STACKED REGISTERS (64)</td>
<td>EREGG</td>
<td>A^* SE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXTRACT STACKED STATE</td>
<td>EA</td>
<td>A^* SP $</td>
<td></td>
<td></td>
</tr>
<tr>
<td>INSERT ADDRESS SPACE CONTROL</td>
<td>IAC</td>
<td>Q SO</td>
<td></td>
<td></td>
</tr>
<tr>
<td>INSERT PSW KEY</td>
<td>IPK</td>
<td>Q G2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>INSERT STORAGE KEY EXTENDED</td>
<td>ISKE</td>
<td>P A^*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>INSERT VIRTUAL STORAGE KEY</td>
<td>IVSK</td>
<td>Q A^* SO</td>
<td></td>
<td></td>
</tr>
<tr>
<td>INVALIDATE DAT TABLE ENTRY</td>
<td>IDTE</td>
<td>P A^* SP $</td>
<td></td>
<td></td>
</tr>
<tr>
<td>INVALIDATE PAGE TABLE ENTRY</td>
<td>IPTE</td>
<td>P A^* SP $</td>
<td>B_b</td>
<td>10-36</td>
</tr>
<tr>
<td>LOAD ADDRESS SPACE PARAMETERS</td>
<td>LASP</td>
<td>P A^* SP SO</td>
<td>B_1</td>
<td>10-39</td>
</tr>
<tr>
<td>LOAD CONTROL (32)</td>
<td>LCTL</td>
<td>P A SP</td>
<td>B_7</td>
<td>10-49</td>
</tr>
<tr>
<td>LOAD CONTROL (64)</td>
<td>LCTLG</td>
<td>P A SP</td>
<td>B_7</td>
<td>10-49</td>
</tr>
<tr>
<td>LOAD PAGE TABLE ENTRY ADDRESS</td>
<td>LIPE</td>
<td>P A^* SP SO</td>
<td>B_1</td>
<td>10-49</td>
</tr>
<tr>
<td>LOAD PSW</td>
<td>LPSW</td>
<td>P A SP $</td>
<td>B_6</td>
<td>10-53</td>
</tr>
<tr>
<td>LOAD PSW EXTENDED</td>
<td>LPSWE</td>
<td>P A SP $</td>
<td>B_6</td>
<td>10-53</td>
</tr>
<tr>
<td>LOAD REAL ADDRESS (32)</td>
<td>LRA</td>
<td>P A^* SO</td>
<td>BP</td>
<td>10-54</td>
</tr>
<tr>
<td>LOAD REAL ADDRESS (32)</td>
<td>LRAY</td>
<td>P A^* SO</td>
<td>BP</td>
<td>10-54</td>
</tr>
<tr>
<td>LOAD REAL ADDRESS (64)</td>
<td>LRA</td>
<td>P A^* SO</td>
<td>BP</td>
<td>10-54</td>
</tr>
<tr>
<td>LOAD USING REAL ADDRESS (32)</td>
<td>LURA</td>
<td>P A SP</td>
<td>B_4</td>
<td>10-59</td>
</tr>
<tr>
<td>LOAD USING REAL ADDRESS (64)</td>
<td>LURAG</td>
<td>P A SP</td>
<td>B_4</td>
<td>10-59</td>
</tr>
<tr>
<td>MODIFY STACKED STATE</td>
<td>MSTA</td>
<td>A^* SP $</td>
<td></td>
<td></td>
</tr>
<tr>
<td>MOVE PAGE</td>
<td>MVPG</td>
<td>Q A SP G0</td>
<td>ST</td>
<td></td>
</tr>
<tr>
<td>MOVE TO PRIMARY</td>
<td>MVC</td>
<td>Q A SO $</td>
<td>ST</td>
<td></td>
</tr>
<tr>
<td>MOVE TO SECONDARY</td>
<td>MVC</td>
<td>Q A SO $</td>
<td>ST</td>
<td></td>
</tr>
<tr>
<td>MOVE WITH DESTINATION KEY</td>
<td>MVC</td>
<td>Q A GM</td>
<td>ST</td>
<td></td>
</tr>
<tr>
<td>MOVE WITH KEY</td>
<td>MVC</td>
<td>Q A</td>
<td>ST</td>
<td></td>
</tr>
<tr>
<td>MOVE WITH OPTIONAL SPECIFICATIONS</td>
<td>MVC</td>
<td>Q A SO G0</td>
<td>ST</td>
<td></td>
</tr>
</tbody>
</table>

---

*Figure 10-1. Summary of Control Instructions  (Part 1 of 4)*
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>MOVE WITH SOURCE KEY</td>
<td>MCSK</td>
<td>Q A</td>
<td>GM</td>
<td></td>
</tr>
<tr>
<td>PAGE IN</td>
<td>PGIN</td>
<td>C ES P A'</td>
<td>c</td>
<td>10-69</td>
</tr>
<tr>
<td>PAGE OUT</td>
<td>POUT</td>
<td>C ES P A'</td>
<td>c</td>
<td>10-70</td>
</tr>
<tr>
<td>PERFORM CRYPTO. KEY MGMT. OPERATION</td>
<td>PCKM</td>
<td>M3 P A SP</td>
<td>GM</td>
<td></td>
</tr>
<tr>
<td>PERFORM FRAME MANAGEMENT FUNCTION</td>
<td>PFMF</td>
<td>ED1 P A' SP II</td>
<td>c²</td>
<td></td>
</tr>
<tr>
<td>PERFORM TIMING FACILITY FUNCTION</td>
<td>PTFF</td>
<td>E CT Q A SP</td>
<td>GM</td>
<td></td>
</tr>
<tr>
<td>PERFORM TOPOLOGY FUNCTION</td>
<td>PTF</td>
<td>RRE C CT P SP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PROGRAM CALL</td>
<td>PC</td>
<td>S Q A'' Z¹ T c GM</td>
<td>B ST</td>
<td>10-85</td>
</tr>
<tr>
<td>PROGRAM RETURN</td>
<td>PR</td>
<td>E L c¹ A'' SP Z² T c²</td>
<td>B ST</td>
<td>10-86</td>
</tr>
<tr>
<td>PROGRAM TRANSFER</td>
<td>PT</td>
<td>RRE Q A'' SP Z² T c</td>
<td>B</td>
<td>10-88</td>
</tr>
<tr>
<td>PROGRAM TRANSFER WITH INSTANCE</td>
<td>PTI</td>
<td>RRE RA Q A'' SP Z² T c</td>
<td>B</td>
<td>10-89</td>
</tr>
<tr>
<td>PURGE ALB</td>
<td>PALB</td>
<td>RRE P $</td>
<td></td>
<td>10-112</td>
</tr>
<tr>
<td>PURGE TLB</td>
<td>PTLB</td>
<td>S P $</td>
<td></td>
<td>10-112</td>
</tr>
<tr>
<td>RESET REFERENCE BIT EXTENDED</td>
<td>RRBE</td>
<td>RRE C P A''</td>
<td></td>
<td>10-113</td>
</tr>
<tr>
<td>RESET REFERENCE BITS MULTIPLE</td>
<td>RRBM</td>
<td>RRE RB P A''</td>
<td></td>
<td>10-113</td>
</tr>
<tr>
<td>RESUME PROGRAM</td>
<td>RP</td>
<td>S L Q A SP WE T</td>
<td>B</td>
<td>10-113</td>
</tr>
<tr>
<td>SET ADDRESS SPACE CONTROL</td>
<td>SAC</td>
<td>S Q SP SW c</td>
<td></td>
<td>10-115</td>
</tr>
<tr>
<td>SET ADDRESS SPACE CONTROL FAST</td>
<td>SACF</td>
<td>S Q SP</td>
<td></td>
<td>10-116</td>
</tr>
<tr>
<td>SET CLOCK</td>
<td>SCK</td>
<td>S C P A SP</td>
<td></td>
<td>10-117</td>
</tr>
<tr>
<td>SET CLOCK COMPARATOR</td>
<td>SCKC</td>
<td>S P A SP</td>
<td></td>
<td>10-118</td>
</tr>
<tr>
<td>SET CLOCK PROGRAMMABLE FIELD</td>
<td>SCKPF</td>
<td>E P SP G0</td>
<td></td>
<td>10-119</td>
</tr>
<tr>
<td>SET CPU TIMER</td>
<td>SPT</td>
<td>S P A SP</td>
<td>B²</td>
<td>10-119</td>
</tr>
<tr>
<td>SET PREFIX</td>
<td>SPX</td>
<td>S P A SP $</td>
<td>B²</td>
<td>10-119</td>
</tr>
<tr>
<td>SET PSW KEY FROM ADDRESS</td>
<td>SPKA</td>
<td>S Q</td>
<td></td>
<td>10-120</td>
</tr>
<tr>
<td>SET SECONDARY ASN</td>
<td>SSAR</td>
<td>RRE c¹ A'' Z² T c</td>
<td></td>
<td>10-120</td>
</tr>
<tr>
<td>SET SECONDARY ASN WITH INSTANCE</td>
<td>SSAIR</td>
<td>RRE RA c¹ A'' Z² T c</td>
<td></td>
<td>10-120</td>
</tr>
<tr>
<td>SET STORAGE KEY EXTENDED</td>
<td>SSKE</td>
<td>RRF-c C P A''</td>
<td>II c</td>
<td>10-126</td>
</tr>
<tr>
<td>SET SYSTEM MASK</td>
<td>SSM</td>
<td>S P A SP SO</td>
<td></td>
<td>10-129</td>
</tr>
<tr>
<td>SIGNAL PROCESSOR</td>
<td>SIGP</td>
<td>RS-a P $</td>
<td>AE</td>
<td>10-129</td>
</tr>
<tr>
<td>STORE CLOCK COMPARATOR</td>
<td>STCKC</td>
<td>S P A SP</td>
<td>ST B³</td>
<td>10-131</td>
</tr>
<tr>
<td>STORE CONTROL (32)</td>
<td>STCTL</td>
<td>RS-a P A SP</td>
<td>ST B³</td>
<td>10-131</td>
</tr>
<tr>
<td>STORE CONTROL (64)</td>
<td>STCTG</td>
<td>RSY-a N P A SP</td>
<td>ST B³</td>
<td>10-131</td>
</tr>
<tr>
<td>STORE CPU ADDRESS</td>
<td>STAP</td>
<td>S P A SP</td>
<td>ST B³</td>
<td>10-132</td>
</tr>
<tr>
<td>STORE CPU ID</td>
<td>STIDP</td>
<td>S P A SP</td>
<td>ST B³</td>
<td>10-132</td>
</tr>
<tr>
<td>STORE CPU TIMER</td>
<td>STPT</td>
<td>S P A SP</td>
<td>ST B³</td>
<td>10-133</td>
</tr>
<tr>
<td>STORE FACILITY LIST</td>
<td>STFL</td>
<td>S N3 P</td>
<td>ST B³</td>
<td>10-134</td>
</tr>
<tr>
<td>STORE PREFIX</td>
<td>STPX</td>
<td>S P A SP</td>
<td>ST B³</td>
<td>10-134</td>
</tr>
<tr>
<td>STORE REAL ADDRESS (64)</td>
<td>STRAG</td>
<td>SSE N P A' SP</td>
<td>ST B³ BP</td>
<td>10-134</td>
</tr>
<tr>
<td>STORE SYSTEM INFORMATION</td>
<td>STSI</td>
<td>S C P A SP GM</td>
<td>ST B³</td>
<td>10-135</td>
</tr>
<tr>
<td>STORE THEN AND SYSTEM MASK</td>
<td>STNSM</td>
<td>SI P A</td>
<td>ST B³</td>
<td>10-158</td>
</tr>
<tr>
<td>STORE THEN OR SYSTEM MASK</td>
<td>STOSM</td>
<td>SI P A</td>
<td>ST B³</td>
<td>10-158</td>
</tr>
<tr>
<td>STORE USING REAL ADDRESS (32)</td>
<td>STURSA</td>
<td>RRE P A' SP</td>
<td></td>
<td>10-159</td>
</tr>
<tr>
<td>STORE USING REAL ADDRESS (64)</td>
<td>STURSN</td>
<td>RRE N P A' SP</td>
<td></td>
<td>10-159</td>
</tr>
<tr>
<td>TEST ACCESS</td>
<td>TAR</td>
<td>RRE C c¹ A''</td>
<td>U₁</td>
<td>10-159</td>
</tr>
<tr>
<td>TEST BLOCK</td>
<td>TB</td>
<td>RRE C P A'' II</td>
<td>$ G0</td>
<td>10-161</td>
</tr>
<tr>
<td>TEST PROTECTION</td>
<td>TTPROTE</td>
<td>SSE C P A''</td>
<td></td>
<td>10-163</td>
</tr>
<tr>
<td>TRACE (32)</td>
<td>TRACE</td>
<td>RS-a P A T c</td>
<td>B²</td>
<td>10-166</td>
</tr>
<tr>
<td>TRACE (64)</td>
<td>TRACG</td>
<td>RSY-a N P A T c</td>
<td>B²</td>
<td>10-166</td>
</tr>
<tr>
<td>TRAP</td>
<td>TRAP2</td>
<td>E c¹ A' SO T</td>
<td>B ST</td>
<td>10-167</td>
</tr>
<tr>
<td>TRAP</td>
<td>TRAP4</td>
<td>S c¹ A' SO T</td>
<td>B ST</td>
<td>10-167</td>
</tr>
</tbody>
</table>

**Figure 10-1. Summary of Control Instructions (Part 2 of 4)**
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
</tr>
</thead>
<tbody>
<tr>
<td>c</td>
<td>Causes serialization and checkpoint synchronization.</td>
<td></td>
</tr>
<tr>
<td>c²</td>
<td>Causes serialization and checkpoint synchronization when the state entry to be unstacked is a program-call state entry.</td>
<td></td>
</tr>
<tr>
<td>c³</td>
<td>Causes serialization and checkpoint synchronization when the set-key control is one.</td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>Causes serialization.</td>
<td></td>
</tr>
<tr>
<td>s¹</td>
<td>Restricted from transactional execution.</td>
<td></td>
</tr>
<tr>
<td>r</td>
<td>PER zero-address-detection not recognized.</td>
<td></td>
</tr>
<tr>
<td>A</td>
<td>Access exceptions for logical addresses.</td>
<td></td>
</tr>
<tr>
<td>A¹</td>
<td>Access exceptions; not all access exceptions may occur; see instruction description for details.</td>
<td></td>
</tr>
<tr>
<td>B</td>
<td>PER branch event.</td>
<td></td>
</tr>
<tr>
<td>B₁</td>
<td>B₁ field designates an access register in the access-register mode.</td>
<td></td>
</tr>
<tr>
<td>B₂</td>
<td>B₂ field designates an access register in the access-register mode.</td>
<td></td>
</tr>
<tr>
<td>BP</td>
<td>Bₚ field designates an access register when PSW bits 16 and 17 have the value 01 binary.</td>
<td></td>
</tr>
<tr>
<td>B†</td>
<td>Bₚ field designates an access register when bit 47 of GR0 is zero, and bits 16-17 of the current PSW are 01 binary; or when bit 47 of GR0 is one, and bits 40-41 of GR0 are 01 binary.</td>
<td></td>
</tr>
<tr>
<td>B‡</td>
<td>B₂ field designates an access register when bit 63 of GR0 is zero, and bits 16-17 of the current PSW are 01 binary; or when bit 63 of GR0 is one, and bits 56-57 of GR0 are 01 binary.</td>
<td></td>
</tr>
<tr>
<td>C</td>
<td>Condition code is set.</td>
<td></td>
</tr>
<tr>
<td>CT</td>
<td>Configuration-topology facility.</td>
<td></td>
</tr>
<tr>
<td>DE</td>
<td>DAT-enhancement facility.</td>
<td></td>
</tr>
<tr>
<td>DM</td>
<td>Depending on the model, DIAGNOSE may generate various program exceptions and may change the condition code.</td>
<td></td>
</tr>
<tr>
<td>D2</td>
<td>DAT-enhancement facility 2.</td>
<td></td>
</tr>
<tr>
<td>E</td>
<td>E instruction format.</td>
<td></td>
</tr>
<tr>
<td>ED1</td>
<td>Enhanced-DAT facility 1.</td>
<td></td>
</tr>
<tr>
<td>ED2</td>
<td>Enhanced-DAT facility 2.</td>
<td></td>
</tr>
<tr>
<td>ES</td>
<td>Expanded-storage facility.</td>
<td></td>
</tr>
<tr>
<td>FC</td>
<td>Designation of access registers depends on the function code of the instruction.</td>
<td></td>
</tr>
<tr>
<td>G₀</td>
<td>Instruction execution includes the implied use of general register 0.</td>
<td></td>
</tr>
<tr>
<td>G₁</td>
<td>Instruction execution includes the implied use of general register 2.</td>
<td></td>
</tr>
<tr>
<td>GM</td>
<td>Instruction execution includes the implied use of multiple general registers: General registers 0 and 1 for MOVE WITH DESTINATION KEY, MOVE WITH SOURCE KEY, PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION, PERFORM TIMING FACILITY FUNCTION, and STORE SYSTEM INFORMATION. General registers 3, 4, and 14, and, when the ASN-and-LX-reuse facility is installed, general register 15 for PROGRAM CALL.</td>
<td></td>
</tr>
<tr>
<td>II</td>
<td>Interruptible instruction (for SSKE, the instruction is interruptible when the multiple-block control is one).</td>
<td></td>
</tr>
<tr>
<td>L</td>
<td>New condition code is loaded.</td>
<td></td>
</tr>
<tr>
<td>LD</td>
<td>Long-displacement facility.</td>
<td></td>
</tr>
<tr>
<td>MD</td>
<td>Designation of access registers in the access-register mode is model-dependent.</td>
<td></td>
</tr>
<tr>
<td>MO</td>
<td>Move-with-optional-specifications facility.</td>
<td></td>
</tr>
<tr>
<td>M3</td>
<td>Message-security assist extension 3.</td>
<td></td>
</tr>
<tr>
<td>N</td>
<td>Instruction is new in z/Architecture as compared to ESA/390.</td>
<td></td>
</tr>
<tr>
<td>N3</td>
<td>Instruction is new in z/Architecture and has been added to ESA/390.</td>
<td></td>
</tr>
<tr>
<td>P</td>
<td>Privileged-operation exception; also, restricted from transactional execution.</td>
<td></td>
</tr>
<tr>
<td>Q</td>
<td>Privileged-operation exception for semiprivate instructions also, restricted from transactional execution.</td>
<td></td>
</tr>
<tr>
<td>R₁</td>
<td>R₁ field designates an access register in the access-register mode.</td>
<td></td>
</tr>
</tbody>
</table>

Figure 10-1. Summary of Control Instructions (Part 3 of 4)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1</td>
<td>R1 field designates an access</td>
<td>register in the access-register mode.</td>
</tr>
<tr>
<td>RA</td>
<td>Reusable-ASN-and-LX facility.</td>
<td></td>
</tr>
<tr>
<td>RB</td>
<td>Reset-reference-bits-multiple</td>
<td>facility.</td>
</tr>
<tr>
<td>RRE</td>
<td>RRE instruction format.</td>
<td></td>
</tr>
<tr>
<td>RRF</td>
<td>RRF instruction format.</td>
<td></td>
</tr>
<tr>
<td>RS</td>
<td>RS instruction format.</td>
<td></td>
</tr>
<tr>
<td>RSY</td>
<td>RSY instruction format.</td>
<td></td>
</tr>
<tr>
<td>RX</td>
<td>RX instruction format.</td>
<td></td>
</tr>
<tr>
<td>RXY</td>
<td>RXY instruction format.</td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>S instruction format.</td>
<td></td>
</tr>
<tr>
<td>SE</td>
<td>Special-operation, stack-empty,</td>
<td>stack-specification, and stack-type exceptions.</td>
</tr>
<tr>
<td>SF</td>
<td>Special-operation, stack-full,</td>
<td>and stack-specification exceptions.</td>
</tr>
<tr>
<td>SI</td>
<td>SI instruction format.</td>
<td></td>
</tr>
<tr>
<td>SO</td>
<td>Special-operation exception.</td>
<td></td>
</tr>
<tr>
<td>SP</td>
<td>Specification exception.</td>
<td></td>
</tr>
<tr>
<td>SS</td>
<td>SS instruction format.</td>
<td></td>
</tr>
<tr>
<td>SSE</td>
<td>SSE instruction format.</td>
<td></td>
</tr>
<tr>
<td>SSF</td>
<td>SSF instruction format.</td>
<td></td>
</tr>
<tr>
<td>ST</td>
<td>PER storage-alteration event.</td>
<td></td>
</tr>
<tr>
<td>SU</td>
<td>PER store-using-real-address</td>
<td>event.</td>
</tr>
<tr>
<td>SW</td>
<td>Special-operation exception and</td>
<td>space-switch event.</td>
</tr>
<tr>
<td>T</td>
<td>Trace exceptions (which include</td>
<td>trace table, addressing, and low-address protection).</td>
</tr>
<tr>
<td>TS</td>
<td>TOD-clock-steering facility.</td>
<td></td>
</tr>
<tr>
<td>U1</td>
<td>R1 field designates an access</td>
<td>register unconditionally.</td>
</tr>
<tr>
<td>U2</td>
<td>R2 field designates an access</td>
<td>register unconditionally.</td>
</tr>
<tr>
<td>WE</td>
<td>Space-switch event.</td>
<td></td>
</tr>
<tr>
<td>Z1</td>
<td>Additional exceptions and events</td>
<td>for PROGRAM CALL (which include ASX-translation, EX-translation, LFX-translation,</td>
</tr>
<tr>
<td></td>
<td>for PROGRAM CALL (which include</td>
<td>LSTE-sequence, LSX-translation, LX-translation, PC-translation-specification,</td>
</tr>
<tr>
<td></td>
<td>ASX-translation, EX-translation,</td>
<td>special-operation, stack-full, stack-specification and subspace-replacement</td>
</tr>
<tr>
<td></td>
<td>LFX-translation, LSTE-sequence,</td>
<td>exceptions and space-switch event).</td>
</tr>
<tr>
<td></td>
<td>LSX-translation, LX-translation,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>PC-translation-specification,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>special-operation, stack-full,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>stack-specification and</td>
<td></td>
</tr>
<tr>
<td></td>
<td>subspace-replacement exceptions</td>
<td></td>
</tr>
<tr>
<td></td>
<td>and space-switch event).</td>
<td></td>
</tr>
<tr>
<td>Z2</td>
<td>Additional exceptions and events</td>
<td>for PROGRAM TRANSFER (which include AFX-translation, ASX-translation, primary-</td>
</tr>
<tr>
<td></td>
<td>for PROGRAM TRANSFER (which</td>
<td>authority, special-operation, and subspace-replacement exceptions and space-</td>
</tr>
<tr>
<td></td>
<td>include AFX-translation, ASX-</td>
<td>switch event).</td>
</tr>
<tr>
<td></td>
<td>translation, primary-authority,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>special-operation, and</td>
<td></td>
</tr>
<tr>
<td></td>
<td>subspace-replacement exceptions</td>
<td></td>
</tr>
<tr>
<td></td>
<td>and space-switch event).</td>
<td></td>
</tr>
<tr>
<td>Z3</td>
<td>Additional exceptions for SET</td>
<td>SECONDARY ASN (which include AFX translation, ASX translation, secondary</td>
</tr>
<tr>
<td></td>
<td>SECONDARY ASN (which include AFX</td>
<td>authority, special operation and subspace replacement).</td>
</tr>
<tr>
<td></td>
<td>translation, ASX translation,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>secondary authority, special</td>
<td></td>
</tr>
<tr>
<td></td>
<td>operation and subspace</td>
<td></td>
</tr>
<tr>
<td></td>
<td>replacement).</td>
<td></td>
</tr>
<tr>
<td>Z4</td>
<td>Additional exceptions and events</td>
<td>for PROGRAM RETURN (which include AFX-translation, ASTE-instance, ASX-translation,</td>
</tr>
<tr>
<td></td>
<td>for PROGRAM RETURN (which include</td>
<td>secondary-authority, special-operation, stack-empty, stack-operation, stack-</td>
</tr>
<tr>
<td></td>
<td>ASX-translation, ASTE-instance,</td>
<td>specification, stack-type, and subspace-replacement exceptions and space-</td>
</tr>
<tr>
<td></td>
<td>ASX-translation, secondary-</td>
<td>switch event).</td>
</tr>
<tr>
<td></td>
<td>authority, special-operation,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>stack-empty, stack-operation,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>stack-specification, stack-type,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>and subspace-replacement exceptions</td>
<td></td>
</tr>
<tr>
<td></td>
<td>and space-switch event).</td>
<td></td>
</tr>
<tr>
<td>Z5</td>
<td>Additional exceptions for BRANCH</td>
<td>AND STACK (which include special operation, stack full, and stack specification)</td>
</tr>
<tr>
<td>Z6</td>
<td>Additional exceptions and events</td>
<td>for PROGRAM TRANSFER WITH INSTANCE (which include AFX-translation, ASTE-</td>
</tr>
<tr>
<td></td>
<td>for PROGRAM TRANSFER WITH INSTANCE</td>
<td>instance, ASX-translation, primary-authority, special-operation, and subspace-</td>
</tr>
<tr>
<td></td>
<td>(which include AFX-translation,</td>
<td>replacement exceptions and space-switch event).</td>
</tr>
<tr>
<td></td>
<td>ASTE-instance, ASX-translation,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>primary-authority, special-</td>
<td></td>
</tr>
<tr>
<td></td>
<td>operation, and subspace-replacement</td>
<td></td>
</tr>
<tr>
<td></td>
<td>exceptions and space-switch event).</td>
<td></td>
</tr>
<tr>
<td>Z7</td>
<td>Additional exceptions for SET</td>
<td>SECONDARY ASN WITH INSTANCE (which include AFX translation, ASTE instance, ASX-</td>
</tr>
<tr>
<td></td>
<td>SECONDARY ASN WITH INSTANCE (which</td>
<td>translation, secondary authority, special operation, and subspace replacement)</td>
</tr>
<tr>
<td></td>
<td>include AFX translation, ASTE</td>
<td></td>
</tr>
<tr>
<td></td>
<td>instance, ASX translation,</td>
<td></td>
</tr>
<tr>
<td></td>
<td>secondary authority, special</td>
<td></td>
</tr>
<tr>
<td></td>
<td>operation, and subspace</td>
<td></td>
</tr>
<tr>
<td></td>
<td>replacement).</td>
<td></td>
</tr>
</tbody>
</table>

Figure 10-1. Summary of Control Instructions (Part 4 of 4)
If the dispatchable unit is in the base-authority state and the 24-bit or 31-bit addressing mode: bits 32 and 97-127 of the current PSW, the basic-addressing-mode bit and bits 33-63 of the updated instruction address, are saved in the dispatchable-unit control table (DUCT); the PSW-key mask (PKM), PSW key, and problem-state bit also are saved in the DUCT; the PKM and PSW key are replaced using the contents of general register R1; the problem-state bit is set to one; bits 32 and 97-127 of the PSW are replaced using the contents of general register R2; and the dispatchable unit is placed in the reduced-authority state. In the 64-bit addressing mode, the action is the same except that bits 64-127 of the current PSW are saved in the DUCT and replaced from general register R2, and bit 32 of the PSW is neither saved nor replaced.

If the dispatchable unit is in the reduced-authority state and the 24-bit or 31-bit addressing mode: bits 32 and 97-127 of the current PSW are saved in general register R1 if R1 is not zero; bits 32 and 97-127 of the PSW and the PKM, PSW key, and problem-state bit are replaced by values saved in the DUCT; and the dispatchable unit is placed in the base-authority state. In the 64-bit addressing mode, the action is the same except that bits 64-127 of the current PSW are saved in general register R1 if R1 is not zero, those bits in the PSW are replaced from the DUCT, and bit 32 of the PSW is neither saved nor replaced.

Words 5, 8, and 9 of the DUCT are used by this instruction. The contents of those words are as follows:

<table>
<thead>
<tr>
<th>Word 5</th>
<th>Word 8</th>
<th>Word 9</th>
</tr>
</thead>
<tbody>
<tr>
<td>PSW-Key Mask</td>
<td>All Zeros</td>
<td>Bits 33-63 of Return Address</td>
</tr>
<tr>
<td>PSW Key</td>
<td>RA</td>
<td>P</td>
</tr>
<tr>
<td>Bits 0-16</td>
<td>Bits 0-31 of Return Address</td>
<td>Bits 32-63 of Return Address</td>
</tr>
</tbody>
</table>

In the 24-Bit or 31-Bit Addressing Mode

In the 64-Bit Addressing Mode

The fields in words 5, 8, and 9 of the DUCT are allocated as follows:

**PSW-Key Mask:** Bit positions 0-15 of word 5 contain the PSW-key mask (PKM), bits 32-47 of control register 3, saved by BRANCH AND SET AUTHORITY executed in the base-authority state. The PKM is restored to control register 3 by BRANCH AND SET AUTHORITY executed in the reduced-authority state.

**PSW Key:** Bit positions 24-27 of word 5 contain the PSW key, bits 8-11 of the PSW, saved by BRANCH AND SET AUTHORITY executed in the base-authority state. The PSW key is restored to the PSW by BRANCH AND SET AUTHORITY executed in the reduced-authority state.

**Reduced Authority (RA):** Bit 28 of word 5 indicates, when zero, that the dispatchable unit associated with the DUCT is in the base-authority state or, when one, that the dispatchable unit is in the reduced-authority state. Bit 28 is set to one by BRANCH AND SET AUTHORITY executed in the base-authority state, and it is set to zero by BRANCH AND SET AUTHORITY executed in the reduced-authority state.

**Problem State (P):** Bit position 31 of word 5 contains the problem-state bit, bit 15 of the PSW, saved by BRANCH AND SET AUTHORITY executed in the base-authority state. The problem-state bit is restored to the PSW by BRANCH AND SET AUTHORITY executed in the reduced-authority state.

**Basic Addressing Mode (BA):** In the 24-bit or 31-bit addressing mode, bit position 0 of word 9 contains the basic-addressing-mode bit, bit 32 of the PSW, saved by BRANCH AND SET AUTHORITY executed in the base-authority state. The basic-addressing-mode bit is restored to the PSW from the DUCT by BRANCH AND SET AUTHORITY executed in the reduced-authority state.

**Return Address:** In the 24-bit or 31-bit addressing mode, bit positions 1-31 of word 9 contain bits 33-63 of the updated instruction address, bits 97-127 of the PSW, saved by BRANCH AND SET AUTHORITY executed in the base-authority state. Bits 1-31 of word 9 of the DUCT are restored to bit positions 97-127 of the PSW by BRANCH AND SET AUTHORITY executed in the reduced-authority state. In the 64-bit addressing mode, words 8 and 9 contain the updated instruction address saved by BRANCH AND SET AUTHORITY executed in the base-author-
ity state. The contents of words 8 and 9 are restored to bit positions 64-127 of the PSW by BRANCH AND SET AUTHORITY executed in the reduced-authority state.

In the 24-bit or 31-bit addressing mode, all zeros are stored in word 8 when saving occurs in the base-authority state. In any addressing mode, all zeros are stored in bit positions 16-23, 29, and 30 of word 5 when saving occurs in the base-authority state.

All other fields in words 5, 8, and 9 remain unchanged when bit 28 of word 5 is set to zero in the reduced-authority state.

The fetch, store, and update references to the DUCT are single-access references and appear to be word concurrent as observed by other CPUs. The words of the DUCT are accessed in no particular order.

Base-Authority Operation

When BRANCH AND SET AUTHORITY is executed in the base-authority state, as indicated by the reduced-authority bit (RA) in the DUCT being zero, R₂ must be nonzero; otherwise, a special-operation exception is recognized. R₁ may be zero or nonzero.

The contents of bit positions 32-63 of general register R₁ and of general register R₂ when the execution of the instruction begins in the base-authority state are as follows:

<table>
<thead>
<tr>
<th>R₁</th>
<th>Key Mask</th>
<th>Key</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>48</td>
<td>56</td>
</tr>
</tbody>
</table>

In the 24-Bit or 31-Bit Addressing Mode

<table>
<thead>
<tr>
<th>R₂</th>
<th>Ignored</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>31</td>
</tr>
</tbody>
</table>

In the 64-Bit Addressing Mode

<table>
<thead>
<tr>
<th>R₂</th>
<th>Bits 33-63 of Branch Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>32</td>
</tr>
<tr>
<td>30</td>
<td>63</td>
</tr>
</tbody>
</table>

The problem-state bit in the PSW is set to one.

In the 24-bit or 31-bit addressing mode, bit 32 of general register R₂ is placed in bit position 32 of the PSW as the new basic-addressing-mode bit. A branch address is generated from bits 33-63 of general register R₂ under the control of the new basic addressing mode, and the result is placed in bit positions 64-127 of the PSW as the new instruction address.

In the 64-bit addressing mode, a branch address is generated from bits 0-63 of general register R₂ and is placed in bit positions 64-127 of the PSW as the new instruction address. Bit 32 of the PSW remains unchanged.

Bits 48-55 and 60-63 of general register R₁ may be used for future extensions and should be zeros; otherwise, the program may not operate compatibly in the future.

Reduced-Authority Operation

When BRANCH AND SET AUTHORITY is executed in the reduced-authority state, as indicated by the reduced-authority (RA) bit in the DUCT being one, R₂ must be zero; otherwise, a special-operation exception is recognized. R₁ may be zero or nonzero. The

or 31-bit addressing mode, the contents of bit positions 0-31 of general register R₂ are ignored.

In the 24-bit or 31-bit addressing mode, PSW bits 32 and 97-127 are saved in word 9 of the DUCT, and zeros are stored in word 8. In the 64-bit addressing mode, PSW bits 64-127 are saved in words 8 and 9 of the DUCT. In any addressing mode, the PKM, the PSW key, and the problem-state bit are saved in word 5 of the DUCT, the RA bit in word 5 is set to one, and bits 16-23, 29, and 30 of word 5 are set to zeros.

Bits 56-59 of general register R₁ are placed in bit positions 8-11 of the PSW as the new PSW key. In the problem state, the new PSW key must be authorized by the PKM; otherwise, if the new PSW key is not authorized, a privileged-operation exception is recognized.

After the new PSW key has been placed in the PSW, bits 32-47 of general register R₁ are ANDed with the PKM in control register 3, and the result replaces the PKM in control register 3.

Bits 48-55 and 60-63 of general register R₁ may be used for future extensions and should be zeros; otherwise, the program may not operate compatibly in the future.
initial contents of general registers R₁ and R₂ are ignored.

If R₁ is nonzero in the 24-bit or 31-bit addressing mode, bits 32 and 97-127 of the current PSW, the basic-addressing-mode bit and bits 33-63 of the updated instruction address, are placed in bit positions 32 and 33-63, respectively, of general register R₁, and bits 0-31 of the register remain unchanged. If R₁ is nonzero in the 64-bit addressing mode, bits 64-127 of the current PSW are placed in bit positions 0-63 of general register R₁. If R₁ is zero, general register 0 remains unchanged.

In the 24-bit or 31-bit addressing mode, bit 0 of word 9 of the DUCT is placed in PSW bit position 32, and bits 1-31 of word 9, with 33 leftmost zeros appended, are placed in PSW bit positions 64-127.

In the 64-bit addressing mode, the contents of words 8 and 9 of the DUCT are placed in PSW bit positions 64-127, and bit 32 of the PSW remains unchanged.

In any addressing mode, the PKM, the PSW key, and the problem-state bit are restored from the DUCT, and the RA bit is set to zero, as previously described. There is no test for whether the restored PSW key is authorized by the restored PKM.

Special Conditions

R₂ must be nonzero in the base-authority state and zero in the reduced-authority state. If either of these rules is violated, a special-operation exception is recognized, and the operation is suppressed.

In the problem state, the execution of the instruction in the base-authority state is subject to control by the PSW-key mask in control register 3. When the bit in the PSW-key mask corresponding to the PSW-key value to be set is one, the instruction is executed successfully. When the selected bit in the PSW-key mask is zero, a privileged-operation exception is recognized. In the supervisor state, any value for the PSW key is valid.

Key-controlled protection does not apply to any access made during the operation. Low-address protection does apply.

In the 24-bit or 31-bit addressing mode, the contents of word 9 of the DUCT are not checked for validity before they are loaded into the PSW. If the newly-loaded PSW contains a zero in bit position 32 and the contents of bit positions 97-103 are not zeros, then (a) the instruction is completed, (b) the resulting instruction-length code is 0, (c) a specification-exception is recognized, and (d) a program interruption occurs. The specification exception, which in this case is listed as a program exception in this instruction, is described in “Early Exception Recognition” on page 6-9.

The operation is suppressed on all addressing and protection exceptions.

Condition Code: The code remains unchanged.

Program Exceptions:

- Addressing (dispatchable-unit control table)
- Privileged operation (selected PSW-key-mask bit is zero in the problem state, base-authority operation only)
- Protection (low-address; dispatchable-unit control table)
- Special operation
- Specification
- Trace
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-2 on page 10-9.

| 1.-6. | Exceptions with the same priority as the priority of program-interruption conditions for the general case. |
| 8.A | Trace exceptions. |
| 8.B | Protection exception (low-address protection) for access to dispatchable-unit control table. |
| 8.C.1 | Addressing exception for access to dispatchable-unit control table. |
| 8.C.2 | Special-operation exception due to R₂ being zero in the base-authority state or R₂ being nonzero in the reduced-authority state. |
| 8.C.3 | Privileged-operation exception due to selected PSW-key-mask bit being zero (base-authority operation only). |

Figure 10-2. Priority of Execution: BRANCH AND SET AUTHORITY (Part 1 of 2)
Programming Notes:

1. BRANCH AND SET AUTHORITY can improve performance by replacing to-current-primary forms of PROGRAM TRANSFER (PT-cp) and basic (nonstacking) PROGRAM CALL (PC-cp) instructions. PT-cp and PC-cp are often used (within a single address space) to reduce the authority of the PSW-key mask (PKM) or change from supervisor state to problem state during a calling linkage made by PT-cp and then to restore the PKM authority or supervisor state during a return linkage made by PC-cp. Also, the PSW-key-setting operations of BRANCH AND SET AUTHORITY can be substituted for SET PSW KEY FROM ADDRESS instructions, and, since BRANCH AND SET AUTHORITY combines branching with PSW-key setting, it can be used to change the PSW key when branching from or to a fetch-protected program.

2. Only one base-authority state and one reduced-authority state are available to a dispatchable unit. Nested use of BRANCH AND SET AUTHORITY, that is, use within different subroutine levels, is not possible. The requirement that R2 must be nonzero in the base-authority state and zero in the reduced-authority state provides detection of an attempt to use BRANCH AND SET AUTHORITY in the base-authority state when the dispatchable unit is already in the reduced-authority state because of a previous use of the instruction in the base-authority state.

3. BRANCH AND SET AUTHORITY in the base authority-state does not save an indication in the DUCT of whether the current addressing mode is the extended (64-bit) addressing mode or a basic (24-bit or 31-bit) addressing mode. The instruction, in either the base-authority state or the reduced-authority state, does not cause a switch between the extended addressing mode and a basic addressing mode. In the reduced-authority state, the contents of words 8 and 9 of the DUCT are interpreted based only on the current addressing mode. If saving occurs in the 31-bit addressing mode and then restoring occurs in the 64-bit addressing mode, bit 0 of word 9 of the DUCT will be used as an address bit instead of as the basic-addressing-mode bit. If saving occurs in the 64-bit addressing mode and then restoring occurs in the 24-bit addressing mode, an early specification exception may be recognized, after the instruction execution is completed, because bits 97-103 of the PSW may be nonzero when bit 32 is zero.

4. The instruction may be referred to as BSA-ba or BSA-ra depending on whether it is executed in the base-authority state or the reduced-authority state, respectively.

BRANCH AND STACK

<table>
<thead>
<tr>
<th>BAKR</th>
<th>R1,R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>&quot;B240&quot;</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

A linkage-stack branch state entry is formed, and the current PSW, except with an unpredictable PER mask and with the addressing-mode bits and instruction address replaced from the first operand, is placed in the state entry. Subsequently, the updated instruction address in the current PSW is replaced from the second operand. Indications of the current addressing-mode bits and the new instruction address are placed in the state entry, and the PSW-key mask, PASN, SASN, EAX, and contents of general registers 0-15 and access registers 0-15 also are placed in the state entry. When the ASN-and-LX-reuse facility is installed and the ASN-and-LX-reuse control in control register 0 is one, the PASTEIN and SASTEIN also are placed in the state entry. The action associated with an operand is not performed if the R field designating the operand is zero.

When the R1 field is nonzero, the contents of general register R1 specify an address referred to as the return address.

When R1 is nonzero and bit 63 of general register R1 is zero, the return address is generated from the contents of the register under the control of the basic addressing mode specified by bit 32 of the register: 24-bit mode if bit 32 is zero, or 31-bit mode if bit 32 is one. Bit 32 of the register and the return address are substituted for the basic-addressing-mode bit, bit 32, and the updated instruction address, respectively, in the current PSW when the contents of that PSW are placed in the state entry. The extended-addressing-
mode bit, bit 31, is set to zero in the PSW that is placed in the state entry. The contents of the current PSW are not changed.

When R1 is nonzero and bit 63 of general register R1 is one, the return address is generated from the contents of the register under the control of the 64-bit addressing mode. Bits 0-62 of the return address, with a zero appended on the right, are substituted for the updated instruction address in the current PSW when the contents of that PSW are placed in the state entry. Bits 31 and 32 are set to one in the PSW that is placed in the state entry. The contents of the current PSW are not changed.

When the R1 field is zero, the current PSW is placed in the state entry without any change except for an unpredictable PER mask.

Subsequently, when the R2 field is nonzero, the instruction address in the current PSW is replaced by the branch address. The branch address is generated from the contents of general register R2 under the control of the current addressing mode. When the R2 field is zero, the operation is performed without branching.

The branch state entry is formed and information is placed in it as described in “Stacking Process” on page 5-85.

In the 24-bit or 31-bit addressing mode, bits 33-63 of the branch address (or of the updated instruction address if the operation is performed without branching) are placed in bit positions 33-63 of bytes 144-151 in the state entry, bit 32 of the current PSW is placed in bit position 32 of those bytes, and zeros are placed in bit positions 0-31 of the bytes.

In the 64-bit addressing mode, bits 0-62 of the branch address (or of the updated instruction address if the operation is performed without branching) are placed in bit positions 0-62 of bytes 144-151 in the state entry, and a one is placed in bit position 63 of those bytes.

The entry-type code in the state entry is 00011000 binary.

Key-controlled protection does not apply to accesses to the linkage stack, but low-address and DAT protection do apply.

**Special Conditions**

The CPU must be in the primary-space mode or access-register mode; otherwise, a special-operation exception is recognized.

A stack-full or stack-specification exception may be recognized during the stacking process.

The operation is suppressed on all addressing and protection exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch or store, except for key-controlled protection, linkage-stack entry)
- Special operation
- Stack full
- Stack specification
- Trace
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-3 on page 10-11.

| 1.-6. | Exceptions with the same priority as the priority of program-interruption conditions for the general case. |
| 7.B | Special-operation exception due to DAT being off or the CPU being in secondary-space mode or home-space mode. |
| 8.A | Trace exceptions (only if R2 is nonzero). |
| 8.B.1 | Access exceptions (fetch) for entry descriptor of the current linkage-stack entry. |

**Note:** Exceptions 8.B.2-8.B.7 can occur only if there is not enough remaining free space in the current linkage-stack section.

| 8.B.2 | Stack-specification exception due to remaining-free-space value in current linkage-stack entry not being a multiple of 8. |

**Figure 10-3. Priority of Execution: BRANCH AND STACK**

*(Part 1 of 2)*
8.B.3 Access exceptions (fetch) for second word of the trailer entry of the current section. The entry is presumed to be a trailer entry; its entry-type field is not examined.

8.B.4 Stack-full exception due to forward-section validity bit in the trailer entry being zero.

8.B.5 Access exceptions (fetch) for entry descriptor of the header entry of the next section. This entry is presumed to be a header entry; its entry-type field is not examined.

8.B.6 Stack-specification exception due to not enough remaining free space in the next section.

8.B.7 Access exceptions (store) for second word of the header entry of the next section. If there is no exception, the header is now called the current entry.

8.B.8 Access exceptions (store) for entry descriptor of the current entry and for the new state entry.

Figure 10-3. Priority of Execution: BRANCH AND STACK

Programming Notes:

1. Examples of the use of the BRANCH AND STACK instruction are given in Appendix A, “Number Representation and Instruction-Use Examples.”

2. In no case does BRANCH AND STACK change the current addressing mode.

3. The effect when the \( R_1 \) field is zero is that the return address, which would otherwise be specified by the \( R_1 \) general register, is the address of the next sequential instruction. In this case, BRANCH AND STACK provides a program-linkage function that is comparable to the function of BRANCH AND SAVE.

4. BRANCH AND STACK with a nonzero \( R_1 \) field is intended for use at or near the entry point of a called program. The program may be called by means of BRANCH AND LINK (BALR) or BRANCH AND SAVE (BAS or BASR) from a program being executed in the 24-bit or 31-bit addressing mode, by means of BRANCH AND SAVE AND SET MODE from a program being executed in any addressing mode, or by means of a BRANCH AND SET MODE instruction located in a “glue module” and being executed in any addressing mode. In all of these cases when the nonzero \( R_1 \) field of the calling instruction is the same as the \( R_1 \) field of BRANCH AND STACK, and even when the addressing mode was changed during the calling linkage, BRANCH AND STACK correctly saves the addressing mode and return address of the calling program so that the subsequent execution of PROGRAM RETURN will return correctly to the calling program.

Provided that the current primary address space is in the subspace group, if any, associated with the current dispatchable unit, the access-list-entry token (ALET) in access register \( R_2 \) is translated by means of a special form of access-register translation (ART) to locate a destination ASN-second-table entry (DASTE). If the DASTE specifies the base space of the subspace group, the primary ASCE (PASCE) in control register 1 is replaced by the ASCE in the DASTE. If the DASTE specifies a subspace of the group, bits 0-55 and 58-63 of the PASCE are replaced by the same bits of the ASCE in the DASTE. In either case, the following actions also occur.

In the 24-bit or 31-bit addressing mode, bits 32 and 97-127 of the current PSW, the basic-addressing-mode bit and bits 33-63 of the updated instruction address, are saved in bit positions 32 and 33-63, respectively, of general register \( R_1 \), and bits 0-31 of the register remain unchanged. Subsequently, the basic-addressing-mode bit and bits 33-63 of the instruction address in the current PSW are replaced from bit positions 32-63 of general register \( R_2 \), and bits 0-31 of the register are ignored.

In the 64-bit addressing mode, bits 64-127 of the current PSW, the updated instruction address, are saved in bit positions 0-63 of general register \( R_1 \). Subsequently, the instruction address in the current PSW is replaced from bit positions 0-63 of general register \( R_2 \). Bit 32 of the PSW remains unchanged.

In any addressing mode, general register 0 remains unchanged if the \( R_1 \) field is zero.
The secondary ASCE (SASCE) in control register 7 is set equal to the new PASCE in control register 1. Also, the secondary ASN (SASN), bits 48-63 of control register 3, is set equal to the primary ASN (PASN), bits 48-63 of control register 4. If the ASN-and-LX-reuse facility is installed and is enabled by the ASN-and-LX-reuse control in control register 0, the secondary ASTEIN (SASTEIN), bits 0-31 of control register 3, is set equal to the primary ASTEIN (PASTEIN), bits 0-31 of control register 4.

The current primary address space is in the subspace group for the dispatchable unit if the current primary-ASTE origin (PASTEO), bits 33-57 of control register 5, designates the ASTE for the base space of the group. The PASTEO designates the base-space ASTE if the PASTEO is equal to the base-ASTE origin (BASTEO), bits 1-25 of word 0 of the dispatchable-unit control table (DUCT). For determining whether the PASTEO equals the BASTEO, either the PASTEO may be compared to the BASTEO or the entire contents of bit positions 32-63 of control register 5 may be compared to the entire contents of word 0 of the DUCT.

Ordinary ART is described in “Access-Register-Translation Process” on page 5-60. The special ART performed by this instruction is contrasted to ordinary ART as follows:

1. The special ART is performed regardless of whether the CPU is in the access-register mode.
2. If the ALET being translated is 00000000 hex, called ALET 0, the DASTE is the ASTE for the base space. Bit 0 of the DASTE is ignored.
3. If the ALET is 00000001 hex, called ALET 1, the DASTE is the ASTE for the last subspace entered by the dispatchable unit by means of BRANCH IN SUBSPACE GROUP. That ASTE is designated by the subspace-ASTE origin (SSASTEO), bits 1-25 of word 0 of the dispatchable-unit control table (DUCT). A special-operation exception is recognized if a subspace has not previously been entered, as indicated by an SSASTEO of all zeros. An ASTE-validity exception is recognized if bit 0 of the DASTE is one. An ASTE-sequence exception is recognized if the ASTE sequence number (ASTESN) in the DASTE does not equal the ASTESN in word 3 of the DUCT.

The DASTE located due to an ALET other than ALET 0 and ALET 1 may be the ASTE for the base space of the subspace group associated with the dispatchable unit. The DASTE is the base-space ASTE if the DASTE origin (DASTEO) obtained from an ALE by ART equals the BASTEO in the DUCT. For determining whether the DASTEO equals the BASTEO, either the DASTEO may be compared to the BASTEO, or the DASTEO with one leftmost and six rightmost zeros appended may be compared to the entire contents of word 0 of the DUCT. If the DASTE is not the base-space ASTE, the DASTE is treated as the ASTE for a subspace of the dispatchable unit's subspace group provided that (1) the subspace-group bit, bit 54, in the ASCE in the DASTE is one, and (2) the DASTE does not specify the base space of another subspace group. The DASTE specifies the base space of another subspace group if the base-space bit, bit 31 of word 0 of the DASTE, is one.

4. If the ALET is other than ALET 0 and ALET 1, an ASTE is located by obtaining its origin from an access-list entry (ALE) in a way similar to ordinary ART, and the DASTE is that located ASTE. In this case, as in ordinary ART:
   - An ALET-specification exception is recognized if bits 0-6 of the ALET are not zeros.
   - An ALEN-translation exception is recognized if the ALE is outside the effective access list or bit 0 of the ALE is one.
   - An ASTE-validity exception is recognized if bit 0 of the DASTE is one.
   - An ASTE-sequence exception is recognized if the ALE sequence number (ASTESN) in the DASTE does not equal the ASTESN in the ALE.

The operation differs from ordinary ART in that the ALE sequence number (ALESN) in the ALE is not compared to the ALESN in the ALET, and the private bit in the ALE is treated as zero. Thus, ALE-sequence and extended-authority exceptions cannot occur.

The fetch-only bit in the ALE is ignored.

When the ALET is other than ALET 0 and ALET 1, the special ART may be performed by using the ART-lookaside buffer (ALB).
special-operation exception is recognized if either of those two provisions is not met.

If the DASTE specifies the base space of the subspace group, the PASCE in control register 1 is replaced by the ASCE in the DASTE. If the DASTE specifies a subspace, bits 0-55 and 58-63 of the PASCE are replaced by the same bits of the ASCE in the DASTE, and bits 56 and 57 of the PASCE, the storage-alteration-event bit and space-switch-event-control bit, remain unchanged.

If R1 is nonzero in the 24-bit or 31-bit addressing mode, bits 32 and 97-127 of the current PSW, the basic-addressing-mode bit and bits 33-63 of the updated instruction address, are placed in bit positions 32 and 33-63, respectively, of general register R1, and bits 0-31 of the register remain unchanged. If R1 is nonzero in the 64-bit addressing mode, bits 64-127 of the current PSW, the updated instruction address, are placed in bit positions 0-63 of general register R1. If R1 is zero, general register 0 remains unchanged.

Whether R2 is nonzero or zero, in the 24-bit or 31-bit addressing mode, bits 32-63 of general register R2 specify the new basic addressing mode and designate the branch address. Bit 32 of the register specifies the new basic addressing mode and replaces bit 32 of the current PSW, and the branch address is generated from the contents of bits positions 33-63 of the register under the control of the new basic addressing mode.

When R2 is nonzero or zero in the 64-bit addressing mode, the contents of general register R2 designate the branch address. The branch address is generated from the contents of the register under the control of the 64-bit addressing mode. Bit 32 of the PSW remains unchanged.

Regardless of the addressing mode, the new value for the PSW is computed before general register R1 is changed.

The secondary ASCE (SASCE) in control register 7 is set equal to the new PASCE in control register 1. The secondary ASN (SASN), bits 48-63 of control register 3, is set equal to the primary ASN (PASN), bits 48-63 of control register 4. If the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0, the secondary ASTEIN (SASTEIN), bits 0-31 of control register 3, is set equal to the primary ASTEIN (PASTEIN), bits 0-31 of control register 4.

If the DASTE specifies the base space, the subspace-active bit, bit 0 of word 1 of the DUCT, is set to zero, and bits 1-31 of word 1 remain unchanged. If the DASTE specifies a subspace by means of ALET 1, then (1) the subspace-active bit is set to one, (2) the SSASTEO in bit positions 1-25 of word 1 remains unchanged, and (3) bits 26-31 of word 1 either are set to zeros or remain unchanged. If the DASTE specifies a subspace by means of an ALET other than ALET 1, then (1) the subspace-active bit is set to one, (2) the DASTEO is stored in bit positions 1-25 of word 1 as the SSASTEO, (3) zeros are stored in bit positions 26-31 of word 1, and (4) the ASTESN in the DASTE is stored in word 3 of the DUCT as the SSASTESN.

The fetch, store, and update references to the DUCT are single-access references and appear to be word concurrent as observed by other CPUs. The words of the DUCT are accessed in no particular order.

The operation, since it changes a translation parameter in control register 1, causes all copies of prefetched instructions to be discarded, except when in the home-space mode.

**Special Conditions**

DAT must be on; otherwise, a special-operation exception is recognized. A special-operation exception is also recognized if the current primary address space is not in a subspace group associated with the current dispatchable unit, if the ALET in access register R2 is ALET 1 but a subspace has not previously been entered by the dispatchable unit by means of BRANCH IN SUBSPACE GROUP, or if the ALET used is other than ALET 0 and ALET 1 and the destination ASTE does not specify the base space or a subspace of the subspace group.

The primary space-switch-event-control bit, bit 57 of control register 1 either before or after the operation, does not cause a space-switch-event program interruption to occur.

Key-controlled protection does not apply to any access made during the operation. Low-address protection does apply.

The operation is suppressed on all addressing and protection exceptions.
**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Addressing (dispatchable-unit control table, effective access-list designation, access-list entry, destination ASN-second-table entry)
- ALET specification
- ALEN translation
- ASTE sequence
- ASTE validity
- Protection (low-address; dispatchable-unit control table)
- Special operation
- Trace
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in the Figure 10-4.

<table>
<thead>
<tr>
<th>Exception</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.-6.</td>
<td>Exceptions with the same priority as the priority of program-interruption conditions for the general case.</td>
</tr>
<tr>
<td>7.B</td>
<td>Special-operation exception due to DAT being off.</td>
</tr>
<tr>
<td>8.A</td>
<td>Trace exceptions.</td>
</tr>
<tr>
<td>8.B</td>
<td>Protection exception (low-address protection) for access to dispatchable-unit control table.</td>
</tr>
<tr>
<td>8.C.1</td>
<td>Addressing exception for access to dispatchable-unit control table.</td>
</tr>
<tr>
<td>8.C.2</td>
<td>Special-operation exception due to current primary address space not being in a subspace group associated with the current dispatchable unit (primary-ASTE origin in control register 5 not equal to base-ASTE origin in dispatchable-unit control table).</td>
</tr>
</tbody>
</table>

**Note:** Exception 8.C.3.A can occur only if the access-list-entry token (ALET) in access register R2 is ALET 0.

<table>
<thead>
<tr>
<th>Exception</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8.C.3.B.1</td>
<td>Special-operation exception due to subspace-ASTE origin in dispatchable-unit control table being zero.</td>
</tr>
<tr>
<td>8.C.3.B.2</td>
<td>Addressing exception for access to subspace ASTE.</td>
</tr>
<tr>
<td>8.C.3.B.3</td>
<td>ASTE-validity exception due to bit 0 in subspace ASTE being one.</td>
</tr>
<tr>
<td>8.C.3.B.4</td>
<td>ASTE-sequence exception due to ASTE sequence number in subspace ASTE not being equal to subspace-ASTE sequence number in dispatchable-unit control table.</td>
</tr>
</tbody>
</table>

**Note:** Exceptions 8.C.3.C.1-8.C.3.C.9 can occur only if the access-list-entry token (ALET) in access register R2 is other than ALET 0 and ALET 1.

<table>
<thead>
<tr>
<th>Exception</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8.C.3.C.1</td>
<td>ALET-specification exception due to bits 0-6 of ALET not being all zeros.</td>
</tr>
<tr>
<td>8.C.3.C.2</td>
<td>Addressing exception for access to effective access-list designation.</td>
</tr>
<tr>
<td>8.C.3.C.3</td>
<td>ALEN-translation exception due to access-list entry being outside the list.</td>
</tr>
<tr>
<td>8.C.3.C.4</td>
<td>Addressing exception for access to access-list entry.</td>
</tr>
<tr>
<td>8.C.3.C.5</td>
<td>ALEN-translation exception due to l bit in access-list entry being one.</td>
</tr>
<tr>
<td>8.C.3.C.6</td>
<td>Addressing exception for access to destination ASTE.</td>
</tr>
<tr>
<td>8.C.3.C.7</td>
<td>ASTE-validity exception due to bit 0 in destination ASTE being one.</td>
</tr>
<tr>
<td>8.C.3.C.8</td>
<td>ASTE-sequence exception due to ASTE sequence number (ASTESN) in access-list entry not being equal to ASTESN in destination ASTE.</td>
</tr>
<tr>
<td>8.C.3.C.9</td>
<td>Special-operation exception due to destination-ASTE origin not equal to base-ASTE origin in dispatchable-unit control table and (1) subspace-group bit, bit 54 in address-space-control element in destination ASTE being zero or (2) base-space bit 31, in destination ASTE being one.</td>
</tr>
</tbody>
</table>

Figure 10-4. Priority of Execution: BRANCH IN SUBSPACE GROUP (Part 1 of 2)
Programming Notes:

1. See the discussion of BRANCH IN SUBSPACE GROUP in "Subroutine Linkage without the Linkage Stack" on page 5-14. It is intended that there be a separate ASN-second-table entry (ASTE) for each of the base space and each subspace of a subspace group. The ASTEs for the subspaces can be "pseudo" ASTEs as described in the programming note in "Address-Space Number" on page 3-21. A subspace can contain a subset of the storage in the base space by having the DAT tables for the subspace designate a subset of the pages that are designated by the DAT tables for the base space. A dispatchable unit has access to a subspace if an access-list entry designating the ASTE for the subspace is in the primary-space or dispatchable-unit access list of the dispatchable unit.

2. BRANCH IN SUBSPACE GROUP can be used to give control from the base space to a subspace, from a subspace to another subspace, and from a subspace to the base space. The instruction can also be used to give control from the base space to the base space or from a subspace to the same subspace.

3. Since BRANCH IN SUBSPACE GROUP sets the secondary address-space-control element (ASCE) in control register 7 equal to the new primary ASCE in control register 1 (along with setting the secondary ASN in control register 3 equal to the primary ASN in control register 4), the program in an address space given control by BRANCH IN SUBSPACE GROUP does not have access to the calling program's address space by means of that address space being the secondary address space.

4. When a dispatchable unit has used BRANCH IN SUBSPACE GROUP to enter a subspace and has not subsequently used BRANCH IN SUBSPACE GROUP to return to the base space, the dispatchable unit is said to be "subspace active." When LOAD ADDRESS SPACE PARAMETERS, PROGRAM CALL, PROGRAM RETURN, PROGRAM TRANSFER, PROGRAM TRANSFER WITH INSTANCE, SET SECONDARY ASN, or SET SECONDARY ASN WITH INSTANCE places an ASCE in control register 1 as the primary ASCE or in control register 7 as the secondary ASCE, and if (1) the ASCE has the subspace-group bit on in it, (2) the dispatchable unit is subspace active, and (3) the ASCE was obtained from the ASN-second-table entry (ASTE) for the base space of the current dispatchable unit, then the instruction (any of the seven named instructions) replaces bits 0-55 and 58-63 of the ASCE in the control register with the same bits of the ASCE in the ASTE for the subspace in which the dispatchable unit last had control. Further details about the effects of the subspace-group facility on the seven named instructions are given in "Subspace-Replace-Operation" on page 5-71 and in the definitions of the instructions.

5. The use of BRANCH IN SUBSPACE GROUP (BSG) along with PROGRAM CALL (PC) and either PROGRAM TRANSFER (PT) (or PROGRAM TRANSFER WITH INSTANCE) or PROGRAM RETURN (PR) can produce results that may be unexpected. Consider the following sequence of operations:
   a. Start in the base space
   b. BSG to a subspace
   c. PC (the first PC) to an address space that is not in the subspace group.
   d. PC (the second PC) to the base space. Since the dispatchable unit is subspace active, control is given to the subspace.
   e. BSG back to the base space.
   f. PT or PR (paired with the second PC) back to the address space that is not in the subspace group.
   g. PT or PR (paired with the first PC) back to the subspace group. Since the dispatchable unit is no longer subspace active, control is given to the base space even though the first PC was issued in the subspace.

6. BRANCH IN SUBSPACE GROUP does not perform the serialization or checkpoint-synchronization functions, but it does cause all copies of prefetched instructions to be discarded except when in the home-space mode.

7. Unlike the RR-format branch instructions, a value of zero in the R2 field for BRANCH IN SUBSPACE GROUP designates general register 0, and branching occurs.

8. When the R2 field designates access register 0, the access register is treated as containing ALET.
The first operand is called the compare value and is contained in bit positions 0-63 of general register \( R_1 \). Bit positions 0-63 of general register \( R_1 + 1 \) are called the replacement value.

The second operand is a doubleword in storage designated by general registers \( R_2 \) and \( R_2 + 1 \). Bits 59-61 of general register \( R_2 \) are the designated-table type (DTT), specifying the bits in general register \( R_2 \) that form the origin of a table in storage; the DTT also specifies the bits in general register \( R_2 + 1 \) that are used as the effective index into the table to locate the second operand, as follows:

<table>
<thead>
<tr>
<th>DTT (bits 59-61 of Reg. ( R_2 ))</th>
<th>Table Type</th>
<th>Table Origin Bits in Reg. ( R_2 )</th>
<th>Effective Index Bits in Reg. ( R_2 + 1 )</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>Page</td>
<td>0-52</td>
<td>44-51</td>
</tr>
<tr>
<td>001-011</td>
<td>—</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>100</td>
<td>Segment</td>
<td>0-51</td>
<td>33-43</td>
</tr>
<tr>
<td>101</td>
<td>Region third</td>
<td>0-51</td>
<td>22-32</td>
</tr>
<tr>
<td>110</td>
<td>Region second</td>
<td>0-51</td>
<td>11-21</td>
</tr>
<tr>
<td>111</td>
<td>Region first</td>
<td>0-51</td>
<td>0-10</td>
</tr>
</tbody>
</table>

When the DTT is 000 binary, the contents of bit positions 0-52 of general register \( R_2 \), with eleven zeros appended on the right, form the table origin, and bits 53-58, 62, and 63 of the register are ignored. When the DTT is 100-111 binary, the contents of bit positions 0-51 of general register \( R_2 \), with twelve zeros appended on the right, form the table origin, and bits 52-58, 62, and 63 of the register are ignored. DTT values of 001, 010, and 011 binary are invalid; a specification exception is recognized if the DTT is invalid.

Bits 0-51 of general register \( R_2 + 1 \) have the format of the region index, segment index, and page index of a virtual address. The part of bits 0-51 normally used by DAT to select an entry in the type of table designated by the DTT is called the effective index. The part of bits 0-51 of general register \( R_2 + 1 \) to the right of the effective index is ignored. Bit positions 52-63 of general register \( R_2 + 1 \) are reserved and must contain zeros; otherwise, a specification exception is recognized.

If \( R_3 \) is nonzero, the contents of general register \( R_3 \) have the format of an address-space-control element with only the table origin, bits 0-51, and designation-type control (DT), bits 60 and 61, used. These contents are used to select TLB entries to be cleared.

The first and second operands are compared. If they are equal, the contents of general register \( R_1 + 1 \) are stored at the second-operand location, and the specified CPU or CPUs in the configuration are cleared of (1) all TLB table entries of the designated type formed through the use of the replaced entry in storage, and (2) all lower-level TLB table entries formed through the use of the cleared higher-level TLB table entries. The TLB entries cleared may optionally be limited to entries formed to translate addresses in a specified address space.

If the first and second operands are unequal, the second operand is loaded at the first-operand location. However, on some models, the second operand may be fetched and subsequently stored back unchanged at the second-operand location. This update appears to be a block-concurrent interlocked-update reference as observed by other CPUs. The result of the comparison is indicated by the condition code.

The \( R_1 \) and \( R_2 \) fields each designate an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.
Bits 52-59, 62, and 63 of general register $R_3$ are ignored. If $R_3$ is zero, the entire contents of general register 0 are ignored, and TLB entries are cleared regardless of the ASCE used to form them.

The contents of the general registers just described are shown in Figure 10-15 on page 10-33.

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$R_1$</td>
<td>Compare Value</td>
</tr>
<tr>
<td>$R_1 + 1$</td>
<td>Replacement Value</td>
</tr>
<tr>
<td>$R_2$</td>
<td>Page-Table Origin (when DTT = 000 binary)</td>
</tr>
<tr>
<td></td>
<td>/ / / / / / DTT / /</td>
</tr>
<tr>
<td>$R_2$</td>
<td>Region-Table, or Segment-Table Origin (when DTT = 100-111 binary)</td>
</tr>
<tr>
<td></td>
<td>/ / / / / / DTT / /</td>
</tr>
<tr>
<td>$R_2 + 1$</td>
<td>Region-First Index</td>
</tr>
<tr>
<td></td>
<td>0 1 12 23 34 4 5 2 6 3</td>
</tr>
</tbody>
</table>

Note: Used only if $R_3$ is nonzero.

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$R_3$</td>
<td>Region-Table or Segment-Table Origin of the ASCE used for Clearing</td>
</tr>
<tr>
<td></td>
<td>/ / / / / / DT / /</td>
</tr>
</tbody>
</table>

Figure 10-5. Register Contents for COMPARE AND REPLACE DAT TABLE ENTRY

The $M_4$ field has the following format:

```
/ / / L
0 1 2 3
```

The bits of the $M_4$ field are defined as follows:

- **Reserved:** Bits 0-2 are reserved. Reserved bit positions of the $M_4$ field are ignored but should contain zeros; otherwise, the program may not operate compatibly in the future.

- **Local-Clearing Control (LC):** The LC bit, bit 3 of the $M_4$ field controls whether only the TLB in the local CPU is cleared, or whether the TLBs in all CPUs of the configuration are cleared.

When the first and second operands are equal, the contents of general register $R_1 + 1$ are stored at the second-operand location, and the translation-lookaside buffers (TLBs) in the specified CPUs in the configuration are cleared of (1) all TLB table entries of the designated type formed through the use of the original contents of the second operand in storage (that is, the contents of the second operand before it is replaced with the replacement value), and (2) all lower-level TLB table entries formed through the use of the cleared higher-level TLB table entries. The TLB entries cleared may optionally be limited to entries formed to translate addresses in a specified address space.

Depending on the table type, the table origin in general register $R_2$ and effective index in general register $R_2 + 1$ designate a table entry in accordance with the rules in “Lookup in a Table Designated by an Address-Space-Control Element” on page 3-53, or “Page-Table Lookup” on page 3-57, except that a carry from bit position 0 of the resulting address is always ignored, and the index is not checked against a table-length field. The table origin is treated as a 64-bit address, and the addition is performed by using the rules for 64-bit address arithmetic, regardless of the current addressing mode specified by bits 31 and 32 of the current PSW. The address formed from these two components is a real or absolute address. The contents of the table entry are not examined for validity, and no exception conditions are recognized due to the contents of the table entry.

The fetch and store of the table entry are performed as a block-concurrent interlocked update. The fetch access to the entry is subject to key-controlled protection, and the store access is subject to key-controlled protection and low-address protection.

A serialization function is performed before the operation begins and again after the operation is completed. As is the case for all serialization operations,
this serialization applies only to this CPU; other CPUs are not necessarily serialized.

When the first and second operands are equal, this CPU clears selected entries from its TLB. In addition to the clearing of the local CPU, if the LC bit in the $M_4$ field is zero, all other CPUs in the configuration are signalled to clear selected entries from their TLBs. Each TLB is cleared of at least those entries for which all of the following conditions are met:

- The effective index in general register $R_2 + 1$ matches the corresponding index in the TLB table entry of type designated by the DTT field in bits 59-61 of general register $R_2$. If the model implements a composite TLB entry that includes the index designated by the DTT field, bits to the left of the effective index in general register $R_2 + 1$ also match any corresponding bits provided in the designated TLB table entry.

- Either the $R_3$ field is zero, or the table-origin and designation-type fields in general register $R_3$ match the table-origin and designation-type fields in the address-space-control element (ASCE) used to form the TLB table entry.

  If the $R_3$ field is zero, then the condition described in this step does not apply.

- If EDAT-1 applies and the entry replaced in storage is a segment-table entry, or if EDAT-2 applies and the entry replaced in storage is a region-third-table entry, the format control in the replaced entry matches that of the TLB entry.

- If the replaced entry in storage designates a lower-level translation table, the lower-level table origin in the entry matches the table-origin field in the TLB table entry.

- If EDAT-1 applies and the entry replaced in storage is a segment-table entry, or if EDAT-2 applies and the entry replaced in storage is a region-third-table entry in which the format control is one, the segment-frame absolute address or region-frame absolute address, respectively, in the replaced entry matches that of the TLB entry.

Each affected TLB is also cleared of at least any lower-level TLB table entries for which all of the following conditions are met:

- The lower-level TLB table entry was formed through use of the replaced entry in storage or through use of a higher-level TLB table entry formed through use of either the replaced entry in storage or a TLB entry cleared in this process.

- Either the $R_3$ field is zero or the table-origin and designation-type fields in general register $R_3$ match the table-origin and designation-type fields in the address-space-control element (ASCE) used to form the lower-level TLB table entry. This ASCE may be one that attached a translation path containing a higher-level table entry that attached the lower-level table entry in storage from which the lower-level TLB table entry was formed, or it may be one that made usable a higher-level TLB table entry that attached the lower-level table entry in storage from which the lower-level TLB table entry was formed. See “Formation of TLB Entries” on page 3-59 for the meaning of the terminology used here.

  If the $R_3$ field is zero, then the condition described in this step does not apply.

Special Conditions
A specification exception is recognized, and the operation is suppressed if any of the following is true:

- Either the R₁ or R₂ field is odd.
- The DTT field, bit positions 59-61 of general register R₂, contain 001, 010, or 011 binary.
- Bit positions 52-63 of general register R₂ + 1 contain nonzero values.

The operation is suppressed on all addressing and protection exceptions.

**Resulting Condition Code:**

0  First and second operands equal, second operand replaced by contents of general register R₁ + 1
1  First and second operands unequal, first operand replaced by second operand
2  --
3  --

**Program Exceptions:**

- Addressing
- Operation (if the enhanced-DAT facility 2 is not installed)
- Privileged operation
- Protection (fetch and store, region-, segment-, or page-table entry, key-controlled protection and low-address protection)
- Specification
- Transaction constraint

**Programming Notes:**

1. The selective clearing of TLB entries may be implemented in different ways, depending on the model, and, in general, more entries may be cleared than the minimum number required.

2. When clearing TLB entries associated with common segments, note that these entries may have been formed through use of address-space-control elements containing many different table origins.

3. The M₄ field of the instruction is considered to be optional, as indicated by the field being contained within brackets [ ] in the assembler syntax. When the M₄ field is not specified, the assembler places zeros in that field of the instruction.

4. The local-clearing control should be specified as one only when either of the following are true; otherwise, unpredictable results, including the presentation of a delayed-access-exception machine check, may occur.

   - The program is running in a uniprocessor configuration.
   - The program is assigned to run on a single CPU and the affinity between the program and that CPU is maintained.

On some models, use of COMPARE AND REPLACE DAT TABLE ENTRY specifying clearing of only the local TLB for the cases listed above may result in significant performance improvements.

### COMPARE AND SWAP AND PURGE

**CSP**  
\[
\text{R₁, R₂} \quad [\text{RRE}]
\]

\[
\text{01} \quad \text{24} \quad \text{16} \quad \text{0} \quad \text{B250}
\]

\[
\text{01} \quad \text{24} \quad \text{16} \quad \text{0} \quad \text{B98A}
\]

The first and second operands are compared. If they are equal, contents of general register R₁ + 1 are stored at the second-operand location, and a purging operation is performed. If they are unequal, the second operand is loaded at the first-operand location. The result of the comparison is indicated in the condition code.

The R₁ field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

For COMPARE AND SWAP AND PURGE (CSP), the first operand is the contents of bit positions 32-63 of general register R₁. The second operand is a word in storage.

For COMPARE AND SWAP AND PURGE (CSPG), the first operand is the contents of bit positions 0-63...
of general register \( R_1 \). The second operand is a doubleword in storage.

For both CSP and CSPG, the location of the leftmost byte of the second operand is designated by contents of general register \( R_2 \).

The purging operation applies to ART-lookaside buffers (ALBs) and translation-lookaside buffers (TLBs) in all CPUs in the configuration. Either ALBs or TLBs, or both ALBs and TLBs, may be selected for purging. All entries are cleared from the selected buffers.

The purging operation is specified by means of bits 62 and 63 of general register \( R_2 \). When bit 62 is one, entries are cleared from ALBs. When bit 63 is one, entries are cleared from TLBs. When bits 62 and 63 both are ones, entries are cleared from ALBs and TLBs. When bits 62 and 63 both are zeros, no entries are cleared.

The handling of the address in general register \( R_2 \) is dependent on the addressing mode. For CSP in the 24-bit addressing mode, the contents of bit positions 40-61 of general register \( R_2 \), with two zeros appended on the right, constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-60 of the register, with three zeros appended on the right, constitute the address, and the contents of bit positions 0-39 and 61 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-60 of the register, with three zeros appended on the right, constitute the address, and the contents of bit positions 0-61 are ignored.

The contents of the registers just described are shown in Figure 10-6 on page 10-21 and Figure 10-7 on page 10-22. When an equal comparison occurs, the contents of bit positions 32-63 of general register \( R_1 +1 \) for CSP, or of bit positions 0-63 for CSPG, are stored at the second-operand location. The fetch of the second operand for purposes of comparison and the store into the second-operand location appear to be a block-concurrent interlocked-update reference as observed by other CPUs.

When the result of the comparison is unequal, the second-operand is loaded at the first-operand location, bits 0-31 of general register \( R_1 \) remain unchanged for CSP only, and the second-operand location remains unchanged. However, on some models, the second operand may be fetched and subsequently stored back unchanged at the second-operand location. This update appears to be a block-
concurrent interlocked-update reference as observed by other CPUs.

A serialization function is performed before the operand is fetched and again after the operation is completed.

When an equal comparison occurs, this CPU clears entries from its ALB and TLB, as specified by bits 62 and 63 of general register R₂, and signals all CPUs in the configuration to clear the same specified entries from their ALBs and TLBs. The ALB entries that are cleared are all ALB access-list designations, access-list entries, ASN-second-table entries, and authority-table entries. The TLB entries that are cleared are all region-first-table entries, region-second-table entries, region-third-table entries, segment-table entries, page-table entries, and real-space entries.

Before the TLB purging operation, when bits 62 or 63 of general register R₂ are one, any active transactions on other CPUs in the configuration are aborted with abort code 255, condition code 2.

The execution of COMPARE AND SWAP AND PURGE is not completed on the CPU which executes it until (1) all specified entries have been cleared from the ALB and TLB of this CPU and (2) all other CPUs in the configuration have completed any storage accesses, including the updating of the change and reference bits, by using the specified ALB and TLB entries.

**Special Conditions**

The R₁ field must designate an even register; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  First and second operands equal, second operand replaced by contents of general register R₁ + 1
1  First and second operands unequal, first operand replaced by second operand
2  --
3  --

**Program Exceptions:**

- Access (fetch and store, operand 2)
- Operation (if DAT-enhancement facility is not installed, CSPG only)
- Privileged operation
- Specification
- Transaction constraint

**Programming Note:** COMPARE AND SWAP AND PURGE provides a broadcast form of the PURGE ALB and PURGE TLB instructions, thus making it possible to avoid uses of SIGNAL PROCESSOR.

**DIAGNOSE**

The CPU performs built-in diagnostic functions, or other model-dependent functions. The purpose of
the diagnostic functions is to verify proper functioning of equipment and to locate faulty components. Other model-dependent functions may include disabling of failing buffers, reconfiguration of CPUs, storage, and channel paths, and modification of control storage.

Bits 8-31 may be used as in the SI or RS formats, or in some other way, to specify the particular diagnostic function. The use depends on the model.

The execution of the instruction may affect the state of the CPU and the contents of a register or storage location, as well as the progress of an I/O operation. Some diagnostic functions may cause the test indicator to be turned on.

Resulting Condition Code: The code is unpredictable.

Program Exceptions:

- Privileged operation
- Transaction constraint

Depending on the model, other exceptions may be recognized.

Programming Notes:

1. Since the instruction is not intended for problem-state-program or control-program use, DIAGNOSE has no mnemonic.

2. DIAGNOSE, unlike other instructions, does not follow the rule that programming errors are distinguished from equipment errors. Improper use of DIAGNOSE may result in false machine-check indications or may cause actual machine malfunctions to be ignored. It may also alter other aspects of system operation, including instruction execution and channel-program operation, to an extent that the operation does not comply with that specified in this publication. As a result of the improper use of DIAGNOSE, the system may be left in such a condition that the power-on reset or initial-microprogram-loading (IML) function must be performed. Since the function performed by DIAGNOSE may differ from model to model and between versions of a model, the program should avoid issuing DIAGNOSE unless the program recognizes the model number stored by STORE CPU ID.

EXTRACT AND SET EXTENDED AUTHORITY

<table>
<thead>
<tr>
<th>ESEA</th>
<th>R₁</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B99D'</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

The extended authorization index (EAX), bits 32-47 of control register 8, is saved in bit positions 32-47 of the first operand, and then the EAX in control register 8 is replaced by the contents of bit positions 48-63 of the first operand. Bits 0-31 of the first operand are ignored, and bits 0-31 and 48-63 of the operand remain unchanged.

Condition Code: The code remains unchanged.

Program Exceptions:

- Privileged operation
- Transaction constraint

EXTRACT PRIMARY ASN

<table>
<thead>
<tr>
<th>EPAR</th>
<th>R₁</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B226'</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

The 16-bit PASN, bits 48-63 of control register 4, is placed in bit positions 48-63 of general register R₁. Bits 32-47 of the general register are set to zeros.

In the EXTRACT PRIMARY ASN AND INSTANCE operation, the PASTEIN, bits 0-31 of control register 4, is placed in bit positions 0-31 of general register R₁. In the EXTRACT PRIMARY ASN operation, bits 0-31 of general register R₁ remain unchanged.

Special Conditions

The instruction must be executed with DAT on; otherwise, a special-operation exception is recognized.
In the problem state, the extraction-authority control, bit 36 of control register 0, must be one; otherwise, a privileged-operation exception is recognized. In the supervisor state, the extraction-authority-control bit is not examined.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Operation (if the ASN-and-LX-reuse facility is not installed, EPAIR only)
- Privileged operation (extraction-authority control is zero in the problem state)
- Special operation
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-8.

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.


7.B.1 Operation exception if the ASN-and-LX-reuse facility is not installed (EPAIR only).

7.B.2 Special-operation exception due to DAT being off.


8. Privileged-operation exception due to extraction-authority control, bit 36 of control register 0, being zero in problem state.

**EXTRACT SECONDARY ASN AND INSTANCE**

<table>
<thead>
<tr>
<th>ESAR</th>
<th>R₁</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B99B'</td>
<td>/ / / / / / / / R₁</td>
<td>/ / /</td>
</tr>
</tbody>
</table>

The 16-bit SASN, bits 48-63 of control register 3, is placed in bit positions 48-63 of general register R₁. Bits 32-47 of the general register are set to zeros.

In the EXTRACT SECONDARY ASN AND INSTANCE operation, the SASTEIN, bits 0-31 of control register 3, is placed in bit positions 0-31 of general register R₁. In the EXTRACT SECONDARY ASN operation, bits 0-31 of general register R₁ remain unchanged.

**Special Conditions**

The instruction must be executed with DAT on; otherwise, a special-operation exception is recognized.

In the problem state, the extraction-authority control, bit 36 of control register 0, must be one; otherwise, a privileged-operation exception is recognized. In the supervisor state, the extraction-authority-control bit is not examined.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Operation (if the ASN-and-LX-reuse facility is not installed, ESAIR only)
- Privileged operation (extraction-authority control is zero in the problem state)
- Special operation
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-9.

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.


10-24 IBM z/Architecture Principles of Operation
EXTRACT STACKED REGISTERS

For EXTRACT STACKED REGISTERS (EREG), the contents of bit positions 32-63 of the general registers are restored, and the contents of bit positions 0-31 of the registers remain unchanged. For EXTRACT STACKED REGISTERS (EREGG), the contents of bit positions 0-63 of the general registers are restored. In either case, the contents of bit positions 0-31 of the access registers are restored.

For each of the general registers and the access registers, the registers are loaded in ascending order of their register numbers, starting with register R₁ and continuing up to and including register R₂, with register 0 following register 15. The bit positions of each register are loaded from the position in the state entry where the contents of the bit positions were saved when the state entry was created. The contents of the state entry remain unchanged.

The last state entry is located as described in “Unstacking Process” on page 5-87. The state entry remains in the linkage stack, and the linkage-stack-entry address in control register 15 remains unchanged.

Key-controlled protection does not apply to references to the linkage stack.

**Special Conditions**

The CPU must be in the primary-space mode, access-register mode, or home-space mode; otherwise, a special-operation exception is recognized.

A stack-empty, stack-specification, or stack-type exception may be recognized during the unstacking process.

The operation is suppressed on all addressing exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, except for protection, linkage-stack entry)
- Special operation
- Stack empty
- Stack specification
- Stack type
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-10.

---

Figure 10-9. Priority of Execution: EXTRACT SECONDARY ASN (AND INSTANCE) (Part 2 of 2)

<table>
<thead>
<tr>
<th>EREG</th>
<th>R₁R₂</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B249'</td>
<td>01 6 24 28 31</td>
<td>R₁ R₂</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>EREGG</th>
<th>R₁R₂</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B90E'</td>
<td>01 6 24 28 31</td>
<td>R₁ R₂</td>
</tr>
</tbody>
</table>

Figure 10-10. Priority of Execution: EXTRACT STACKED REGISTERS (Part 1 of 2)
Sixty-four or 128 bits of status information in the last state entry in the linkage stack are placed in the pair of general registers designated by the R1 field. The condition code is set to indicate whether the state entry is a branch state entry or a program-call state entry.

The R1 field designates the even-numbered register of an even-odd pair of general registers.

Bits 56-63 of general register R2 are an unsigned binary integer that is used as a code to select the state-entry byte positions, or byte and bit positions, from which information is to be extracted, as shown in Figure 10-11.

<table>
<thead>
<tr>
<th>Code (Bits 56-63 of GR R2)</th>
<th>State-Entry Content</th>
<th>State-Entry Byte, or Byte and Bit Positions, Selected</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>PKM, SASN, EAX, and PASN</td>
<td>128-135</td>
</tr>
<tr>
<td>1</td>
<td>PSW bits 0-32 and 97-127</td>
<td>136-139, 140.0, and 168-175.33-63 (see text)</td>
</tr>
<tr>
<td>2</td>
<td>Branch address or called space and PC number</td>
<td>144-151</td>
</tr>
<tr>
<td>3</td>
<td>Modifiable area</td>
<td>152-159</td>
</tr>
<tr>
<td>4</td>
<td>PSW bits 0-127</td>
<td>136-143 and 168-175</td>
</tr>
<tr>
<td>5</td>
<td>Secondary and primary ASTEIN</td>
<td>176-183</td>
</tr>
</tbody>
</table>

For a code of 0, 2, or 3 in bit positions 56-63 of general register R2, the contents of the leftmost four bytes of the eight bytes of status information are placed in bit positions 32-63 of general register R1, and the contents of the rightmost four bytes of the status information are placed in bit positions 32-63 of general register R1 + 1. The contents of bit positions 0-31 of general registers R1 and R1 + 1 remain unchanged.

For a code of 1 in bit positions 56-63 of general register R2, the contents of bytes 136-139 of the state entry, which are bits 0-31 of the PSW in the state entry, are placed in bit positions 32-63 of general register R1; the contents of bit position 0 of byte 140 of the entry, which is bit 32 of that PSW, are placed in bit position 32 of general register R1 + 1; and the contents of bit positions 33-63 of bytes 168-175 of the entry, which are bits 97-127 of the PSW, are placed in bit positions 33-63 of general register R1 + 1. However, bit 44 of general register R1, which corresponds to bit 12 of the PSW in the state entry, is set to one, indicating the ESA/390 mode. Also, if bits 0-32 of bytes 168-175 of the state entry are not all zeros, bit 63 of general register R1 + 1 is set to one; otherwise, bit 63 remains with the value loaded from bit position 63 of bytes 168-175 of the state entry. The contents of bit positions 0-31 of general registers R1 and R1 + 1 remain unchanged.

For a code of 4 in bit positions 56-63 of general register R2, the contents of bytes 136-143 of the state entry, which are bits 0-63 of the PSW in the state entry, are placed in bit positions 0-63 of general reg-
ister R₁, and the contents of bytes 168-175 of the state entry, which are bits 64-127 of that PSW, are placed in bit positions 0-63 of general register R₁ + 1.

Code 5 in bit positions 56-63 of general register R₂ is valid only if the ASN-and-LX-reuse facility is installed. For code 5, the contents of the leftmost four bytes of the eight bytes of status information are placed in bit positions 0-31 of general register R₁, and the contents of the rightmost four bytes of the status information are placed in bit positions 0-31 of general register R₁ + 1. The contents of bit positions 32-63 of general registers R₁ and R₁ + 1 remain unchanged.

The format of byte positions 128-183 of the state entry is as follows:

<table>
<thead>
<tr>
<th>PKM</th>
<th>SASN</th>
<th>EAX</th>
<th>PASN</th>
</tr>
</thead>
<tbody>
<tr>
<td>128</td>
<td>130</td>
<td>132</td>
<td>134</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>136</td>
<td>143</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

In a Branch State Entry Made in 24-Bit or 31-Bit Mode

- A Bits 33-63 of Branch Address

In a Branch State Entry Made in 64-Bit Mode

- Bits 0-62 of Branch Address

In a Program-Call State Entry Made When Resulting Mode Is 24 Bit or 31 Bit

- Called-Space Id. 0 Numeric Part of PC Number

In a Program-Call State Entry Made When Resulting Mode Is 64 Bit

- Called-Space Id. 1 Numeric Part of PC Number

- Modifiable Area

- All Zeros

- PSW Bits 64-127

If ASN-and-LX Reuse Is Enabled; otherwise Unpredictable

<table>
<thead>
<tr>
<th>Secondary ASTEIN</th>
<th>Primary ASTEIN</th>
</tr>
</thead>
<tbody>
<tr>
<td>176</td>
<td>180</td>
</tr>
</tbody>
</table>

The contents of the state entry remain unchanged.

The last state entry is located as described in “Unstacking Process” on page 5-87. The state entry remains in the linkage stack, and the linkage-stack-entry address in control register 15 remains unchanged.

When the entry-type code in the entry descriptor of the state entry is 0001100 binary, indicating a branch state entry, the condition code is set to 0. When the entry-type code is 0001101 binary, indicating a program-call state entry, the condition code is set to 1.

Key-controlled protection does not apply to references to the linkage stack.

Bits 0-55 of general register R₂ are ignored.

Special Conditions

A specification exception is recognized when R₁ is odd or the code in bit positions 56-63 of general register R₂ is greater than 4 when the ASN-and-LX-reuse facility is not installed or is greater than 5 when the facility is installed.

The CPU must be in the primary-space mode, access-register mode, or home-space mode; otherwise, a special-operation exception is recognized.

A stack-empty, stack-specification, or stack-type exception may be recognized during the unstacking process.

The operation is suppressed on all addressing exceptions.

Resulting Condition Code:

0 Branch state entry
1 Program-call state entry
2 --
3 --
Program Exceptions:

- Access (fetch, except for protection, linkage-stack entry)
- Special operation
- Specification
- Stack empty
- Stack specification
- Stack type
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-12.

1.6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.


7.B Special-operation exception due to DAT being off or the CPU being in secondary-space mode.


8.A Specification exception due to \( R_1 \) being odd or bits 56-63 of general register \( R_2 \) having a value greater than 4 when the ASN-and-LX-reuse facility is not installed or greater than 5 when the facility is installed.

8.B.1 Access exceptions (fetch) for entry descriptor of the current linkage-stack entry.

8.B.2 Stack-type exception due to current entry not being a state entry or header entry.

Note: Exceptions 8.B.3-8.B.7 can occur only if the current entry is a header entry.

8.B.3 Access exceptions (fetch) for second word of the header entry.

8.B.4 Stack-empty exception due to backward stack-entry validity bit in the header entry being zero.

8.B.5 Access exceptions (fetch) for entry descriptor of preceding entry, which is the entry designated by the backward stack-entry address in the current (header) entry.

8.B.6 Stack-specification exception due to preceding entry being a header entry.

8.B.7 Stack-type exception due to preceding entry not being a state entry.

The address-space-control bits, bits 16 and 17 of the current PSW, are placed in reversed order in bit positions 54 and 55 of general register \( R_1 \); that is, bit 16 is placed in bit position 55, and bit 17 is placed in bit position 54. Bits 48-53 of the register are set to zeros, and bits 0-47 and 56-63 of the register remain unchanged. The address-space-control bits are also used to set the condition code.

Special Conditions

The instruction must be executed with DAT on; otherwise, a special-operation exception is recognized.

In the problem state, the extraction-authority control, bit 36 of control register 0, must be one; otherwise, a privileged-operation exception is recognized. In the supervisor state, the extraction-authority-control bit is not examined.

Resulting Condition Code:

0 PSW bits 16 and 17 zeros (indicating primary-space mode)
1 PSW bit 16 one and bit 17 zero (indicating secondary-space mode)
2 PSW bit 16 zero and bit 17 one (indicating access-register mode)
3 PSW bits 16 and 17 ones (indicating home-space mode)
**Program Exceptions:**

- Privileged operation (extraction-authority control is zero in the problem state)
- Special operation
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-13.

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.
7.B Special-operation exception due to DAT being off.
8. Privileged-operation exception due to extraction-authority control, bit 36 of control register 0, being zero in problem state.

**Special Conditions**

In the problem state, the extraction-authority control, bit 36 of control register 0, must be one; otherwise, a privileged-operation exception is recognized. In the supervisor state, the extraction-authority-control bit is not examined.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Privileged operation (extraction-authority control is zero in the problem state)
- Transaction constraint

**INSERT STORAGE KEY EXTENDED**

The storage key for the block that is addressed by the contents of general register \( R_2 \) is inserted in general register \( R_1 \).

In the 24-bit addressing mode, bits 40-51 of general register \( R_2 \) designate a 4K-byte block in real storage, and bits 0-39 and 52-63 of the register are ignored. In the 31-bit addressing mode, bits 33-51 of general register \( R_2 \) designate a 4K-byte block in real storage, and bits 0-32 and 52-63 of the register are ignored. In the 64-bit addressing mode, bits 0-51 of general register \( R_2 \) designate a 4K-byte block in real storage, and bits 52-63 of the register are ignored.

The address designating the storage block, being a real address, is not subject to dynamic address translation. The reference to the storage key is not subject to a protection exception.

The seven-bit storage key is inserted in bit positions 56-62 of general register \( R_1 \), and bit 63 is set to zero. The contents of bit positions 0-55 of the register remain unchanged.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
• Addressing (address specified by general register $R_2$
• Privileged operation
• Transaction constraint

**INSERT VIRTUAL STORAGE KEY**

The following diagram shows the storage key and the register positions just described.

The storage key for the location designated by the virtual address in general register $R_2$ is inserted in general register $R_1$.

Selected bits of general register $R_2$ are used as a virtual address. In the 24-bit addressing mode, the address is specified by bits 40-63 of the register, and bits 0-39 are ignored. In the 31-bit addressing mode, the address is specified by bits 33-63, and bits 0-32 is ignored. In the 64-bit addressing mode, the address is specified by bits 0-63 of the register.

The address is a virtual address and is subject to the address-space-control bits, bits 16 and 17 of the current PSW. The address is treated as a primary virtual address in the primary-space mode, as a secondary virtual address in the secondary-space mode, as an AR-specified virtual address in the access-register mode, or as a home virtual address in the home-space mode. The reference to the storage key is not subject to a protection exception.

Bits 0-4 of the storage key, which are the access-control bits and the fetch-protection bit, are placed in bit positions 56-60 of general register $R_1$, with bits 61-63 set to zeros. The contents of bit positions 0-55 of the register remain unchanged. The change and reference bits in the storage key are not inspected. The change bit is not affected by the operation. The reference bit, depending on the model, may or may not be set to one as a result of the operation.

**Special Conditions**

The instruction must be executed with DAT on; otherwise, a special-operation exception is recognized.

In the problem state, the extraction-authority control, bit 36 of control register 0, must be one; otherwise, a privileged-operation exception is recognized. In the supervisor state, the extraction-authority-control bit is not examined.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (except for protection, address specified by general register $R_2$)
- Privileged operation (extraction-authority control is zero in the problem state)
- Special operation
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-14.

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.


7.B Special-operation exception due to DAT being off.


*Figure 10-14. Priority of Execution: INSERT VIRTUAL STORAGE KEY (Part 1 of 2)*
8. Privileged-operation exception due to extraction-authority control, bit 36 of control register 0, being zero.

9. Access exceptions (except for protection) for address specified by general register R2.

Figure 10-14. Priority of Execution: INSERT VIRTUAL STORAGE KEY (Part 2 of 2)

Programming Notes:

1. Since all bytes in a 4K-byte block are associated with the same page and the same storage key, bits 52-63 of general register R2 essentially are ignored. Similarly, since all bytes in a 1 M-byte block are associated with the same segment, bits 44-63 of general register R2 may be ignored when EDAT-1 applies and the STE-format and ACCF-validity controls are both one. Since all bytes in a 2 G-byte block are associated with the same region, bits 33-63 of general register R2 may be ignored when EDAT-2 applies and the RTTE-format and ACCF-validity controls are both one.

2. In the access-register mode, access register 0 designates the primary address space regardless of the contents of access register 0.

INVALIDATE DAT TABLE ENTRY

<table>
<thead>
<tr>
<th>IDTE</th>
<th>R1, R2, [M4]</th>
<th>[RRF-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B98E'</td>
<td>R3</td>
<td>M4</td>
</tr>
</tbody>
</table>

0 16 20 24 28 31

Note: The term “specified CPU or CPUs” has the following meaning for scope of TLBs affected by this instruction:

- When the local-TLB-clearing facility is not installed, or when the facility is installed and the local-clearing-control (LC) bit in the M4 field is zero, the term “specified CPU or CPUs” means all of the CPUs in the configuration.

- When the local-TLB-clearing facility is installed and the LC bit in the M4 field is one, the term “specified CPU or CPUs” means only the CPU executing the IDTE instruction (the local CPU). The TLBs in all other CPUs in the configuration may not be affected.

When the clearing-by-ASCE-option bit, bit 52 of general register R2, is zero, an operation called the invalidation-and-clearing operation is performed, as follows. The designated region-table entry or segment-table entry in storage, or a range of entries beginning with the designated entry, is invalidated, and the translation-lookaside buffers (TLBs) in the specified CPU or CPUs in the configuration are cleared of (1) all TLB table entries of the designated type formed through the use of the invalidated entry or entries in storage, and (2) all lower-level TLB table entries formed through the use of the cleared higher-level TLB table entries. The TLB entries cleared may optionally be limited to entries formed to translate addresses in a specified address space.

When the clearing-by-ASCE-option bit is one, an operation called the clearing-by-ASCE operation is performed, as follows. The operation does not perform any invalidation of DAT-table entries in storage, but it does clear, from the TLBs in all CPUs in the configuration, all region-first-table entries, region-second-table entries, region-third-table entries, segment-table entries and page-table entries formed to translate addresses in a specified address space.

The two operations are described separately below, before the section “Common Operation.”

The M4 field has the following format:

The bits of the M4 field are defined as follows:

- **Reserved:** Bits 0-1 of the M4 field are ignored but should contain zeros; otherwise, the program may not operate compatibly in the future.

- **Format-Control Summary (FS):** When EDAT-2 applies, bit 2 of the M4 field is the format-control summary (FS) for the invalidation-and-clearing operation. Bit 2 of the M4 field is ignored for the clearing-by-ASCE operation and when EDAT-2 does not apply.

The format-control summary applies when the designation type (DT), bits 60-61 of the general register R1, is 00 or 01 binary; when the DT in general register R1 is 10 or 11 binary, the format-
control summary is ignored. The meaning of the FS bit is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The format control is not known to be one in all of the table entries designated by the effective invalidation index and additional-entry count.</td>
</tr>
<tr>
<td>1</td>
<td>The format control is one in all of the table entries designated by the effective invalidation index and additional-entry count.</td>
</tr>
</tbody>
</table>

• **Local-Clearing Control (LC):** When the local-TLB-clearing facility is installed, the LC bit, bit 3 of the M₄ field, controls whether only the TLB in the local CPU is cleared or whether the TLBs in all CPUs of the configuration are cleared. When the local-TLB-clearing facility is not installed, bit 3 of the M₄ field is ignored.

### Invalidation-and-Clearing Operation

When bit 52 of general register R₂, the clearing-by-ASCE-option bit, is zero, the invalidation-and-clearing operation is specified.

The contents of general register R₁ have the format of an address-space-control element with only the table origin, bits 0-51, and designation-type control (DT), bits 60 and 61, used. The table origin designates the DAT table in which one or more entries are to be invalidated, and DT specifies the type of that table.

Bits 52-59, 62, and 63 of general register R₁ are ignored.

Bits 0-43 of general register R₂ have the format of the region index and segment index of a virtual address. The part of bits 0-43 normally used by DAT to select an entry in the type of table designated by general register R₁ is called the effective invalidation index.

Bits 60 and 61 of general register R₁ specify a table type and an effective invalidation index as follows:

<table>
<thead>
<tr>
<th>Bits 60 and 61 of Reg. R₁</th>
<th>Table Type</th>
<th>Effective Invalidation Index in Reg. R₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>11</td>
<td>Region first table</td>
<td>Region first index (bits 0-10)</td>
</tr>
<tr>
<td>10</td>
<td>Region second table</td>
<td>Region second index (bits 11-21)</td>
</tr>
<tr>
<td>01</td>
<td>Region third table</td>
<td>Region third index (bits 22-32)</td>
</tr>
<tr>
<td>00</td>
<td>Segment table</td>
<td>Segment index (bits 33-43)</td>
</tr>
</tbody>
</table>

The part of bits 0-43 of general register R₂ to the right of the effective invalidation index is ignored.

The table origin in general register R₁ and the effective invalidation index designate a DAT-table entry to be invalidated. Bits 53-63 of general register R₂ are an unsigned binary integer specifying the number of additional table entries to be invalidated. Therefore, the number of entries to be invalidated is 1-2,048, corresponding to a value of bits 53-63.

Bits 44-51 of general register R₂ must be zeros; otherwise, a specification exception is recognized.

If R₃ is nonzero, the contents of general register R₃ have the format of an address-space-control element with only the table origin, bits 0-51, and designation-type control (DT), bits 60 and 61, used. These contents are used to select TLB entries to be cleared. Bits 52-59, 62, and 63 of general register R₃ are ignored. If R₃ is zero, the entire contents of general register 0 are ignored, and TLB entries are cleared regardless of the ASCE used to form them.

The contents of the general registers just described are shown in Figure 10-15 on page 10-33.

The table origin in general register R₁ and effective invalidation index in general register R₂ designate a table entry in accordance with the rules in “Lookup in a Table Designated by an Address-Space-Control Element” on page 3-53, except that a carry from bit position 0 of the resulting address is always ignored, and the index is not checked against a table-length field. The table origin is treated as a 64-bit address, and the addition is performed by using the rules for 64-bit address arithmetic, regardless of the current
INVALIDATE DAT TABLE ENTRY

addressing mode specified by bits 31 and 32 of the current PSW. The address formed from these two components is a real or absolute address. The invalid bit, bit 58, of this region-table or segment-table entry is set to one. During this procedure, the entry is not checked for a format error or for whether the origin, in the entry, of the next-lower-level table would cause an addressing exception. The table-type field in the entry is ignored. If the entry is a segment-table entry, the common-segment bit in the entry is ignored. If EDAT-2 applies and the entry is a region-third-table entry, the common-region bit in the entry is ignored.

The entire table entry is fetched concurrently from storage. Subsequently, the byte containing the invalid bit is stored. The fetch access to the entry is subject to key-controlled protection, and the store access is subject to key-controlled protection and low-address protection.

If bits 53-63 of general register R2 are not all zeros, the setting of the invalid bit to one in a region-table or segment-table entry is repeated by adding one to the previously used value of the effective invalidation index, and this is done as many times as are specified by bits 53-63. A carry out of the leftmost bit position of the index is ignored, and wraparound in the table occurs in this case. The contents of general register R2 remain unchanged.

A serialization function is performed before the operation begins and again after the operation is completed. As is the case for all serialization operations, this serialization applies only to this CPU; other CPUs are not necessarily serialized.

After it has set an invalid bit to one, this CPU clears selected entries from its TLB. Then if the local-TLB-clearing facility is not installed, or if the facility is installed and LC bit in the M4 field is zero, this CPU signals all other CPUs in the configuration to clear selected entries from their TLBs. Each affected TLB is cleared of at least those entries for which all of the following conditions are met:

- The effective invalidation index in general register R3 matches the corresponding index in the TLB table entry of type designated by the DT field in bits 60-61 of general register R1. If the model implements a composite TLB entry that includes the index designated by the DT field, bits to the left of the effective index in general register R2 also match any corresponding bits provided in the designated TLB table entry. Note that when multiple table entries are invalidated due to bits 53-63 of general register R2, then the effective invalidation index is incremented, a carry out of the leftmost bit position of the index is lost, and TLB region- or segment-table entries are cleared for each value of the index so obtained.

- Either the R3 field is zero, or the table-origin and designation-type fields in general register R3 match the table-origin and designation-type fields in the address-space-control element (ASCE) used to form the TLB table entry.

If the R3 field is zero, then the condition described in this step does not apply.

- If the entry invalidated in storage designates a lower-level translation table, the lower-level table origin in the invalidated entry matches the table-origin field in the TLB table entry.

Each affected TLB is also cleared of at least any lower-level TLB table entries for which all of the following conditions are met:
• The lower-level TLB table entry was formed through use of an entry invalidated in storage or through use of a higher-level TLB table entry formed through use of either an entry invalidated in storage or a TLB entry cleared in this process.

• Either the R₃ field is zero or the table-origin and designation-type fields in general register R₃ match the table-origin and designation-type fields in the address-space-control element (ASCE) used to form the lower-level TLB table entry. This ASCE may be one that attached a translation path containing a higher-level table entry that attached the lower-level table entry in storage from which the lower-level TLB table entry was formed, or it may be one that made usable a higher-level TLB table entry that attached the lower-level table entry in storage from which the lower-level TLB table entry was formed. See “Formation of TLB Entries” on page 3-59 for the meaning of the terminology used here.

If the R₃ field is zero, then the condition described in this step does not apply.

• If the entry invalidated in storage designates a lower-level translation table, the lower-level table origin in the invalidated entry matches the table-origin field in the TLB table entry.

Programming Notes:

1. Setting the format-control summary to one may provide improved performance on certain models.

2. When the designation type (DT), bits 60-61 of general register R₁, is 00 binary, the format-control summary applies to the segment-table entries being invalidated. When the DT in general register R₁ is 01 binary, the format-control summary applies to the region-third-table entries being invalidated.

3. The program should only set the format-control summary to one if it can ensure that format control (bit 53 of the table entry) is one in all of the table entries being invalidated. If the format-control summary is set to one, but the format control is not one in all of the table entries being invalidated, incomplete purging of the TLB may occur, resulting in unpredictable results from DAT.

4. The M₄ field of the instruction is considered to be optional, as indicated by the field being contained within brackets [ ] in the assembler syntax. When the M₄ field is not specified, the assembler places zeros in that field of the instruction.

Storing in the region- or segment-table entry and the clearing of TLB entries may or may not occur if the invalid bit is already one in the region- or segment-table entry.

When multiple entries are invalidated, clearing of TLB entries may be delayed until all entries have been invalidated.

Clearing-by-ASCE Operation

When bit 52 of general register R₂, the clearing-by-ASCE-option bit, is one, the clearing-by-ASCE operation is specified.

The contents of general register R₃ have the format of an address-space-control element with only the table origin, bits 0-51, and designation-type control (DT), bits 60 and 61, used. These contents are used to select TLB entries to be cleared. Bits 52-59, 62, and 63 of general register R₃ are ignored. R₃ may be zero or nonzero, that is, any general register, including register 0, may be designated.

Bits 44-51 of general register R₃ must be zeros; otherwise, a specification exception is recognized.

The contents of general register R₁ and of bit positions 0-43 and 53-63 of general register R₂ are ignored.

The contents of the general registers just described are shown in Figure 10-16 on page 10-35.

The TLBs of the specified CPU or CPUs in the configuration are cleared at all levels of at least those entries for which the table-origin and designation-type fields in general register R₃ match the table-origin and designation-type fields in the address-space-control element (ASCE) used to form the entry. This ASCE is the one used in the translation during which the entry was formed. See “Formation of TLB Entries” on page 3-59 for the meaning of the terminology used here.

When the clearing-by-ASCE-option bit (bit 52 of general register R₂ is one), the M₄ field is ignored.
The execution of INVALIDATE DAT TABLE ENTRY is not completed on the CPU which executes it until the following occur:

1. All entries meeting the criteria specified above have been cleared from the TLB of this CPU. When the local-TLB-clearing facility is installed and the LC bit in the M₄ field is one, execution of INVALIDATE DAT TABLE ENTRY is complete at this point and the following step is not performed.

2. When the local-TLB-clearing facility is not installed, or when the facility is installed and the LC bit in the M₄ field is zero, all other CPUs in the configuration have completed any storage accesses, including the updating of the change and reference bits, by using TLB entries corresponding to the specified parameters.

Before the TLB purging operation, transactional execution by other CPUs in the configuration is aborted with abort code 255, condition code 2. The aborting of transactional execution affects at least those CPUs accessing the locations (transactionally or nontransactionally) for which TLB entries are being cleared. It is unpredictable whether some or all other CPUs are affected as well.

The operations do not necessarily have any effect on TLB real-space entries.

### Special Conditions

Bits 44-51 of general register R₂ must be zeros; otherwise, a specification exception is recognized.

The operation is suppressed on all addressing and protection exceptions (invalidation-and-clearing operation only).

### Resulting Condition Code:
The code is unpredictable.

### Program Exceptions:

- Addressing (invalidated region- or segment-table entry, invalidation-and-clearing operation only).
- Operation (if the DAT-enhancement facility is not installed)
- Privileged operation
- Protection (fetch and store, region- or segment-table entry, key-controlled protection and low-address protection; invalidation-and-clearing operation only).
- Specification
- Transaction constraint

### Programming Notes:

1. The selective clearing of TLB entries may be implemented in different ways, depending on the model, and, in general, more entries may be cleared than the minimum number required. When the invalidation-and-clearing operation is performed, some models may clear all TLB entries when the effective invalidation index is not a segment index or may clear an entry regardless of the page-table origin in the entry. When that operation or the clearing-by-ASCE operation is performed, some models may clear a TLB entry regardless of the designation-type field in general register R₃. When either operation is performed, other models may clear precisely the minimum number of entries required. Therefore, in order for a program to operate on all models, the program should not take advantage of any properties obtained by a less selective clearing on a particular model.

2. When using the clearing-by-ASCE operation to clear TLB entries associated with common segments, note that these entries may have been
formed through use of address-space-control elements containing many different table origins.

The following notes apply when the invalidation-and-clearing operation is specified.

3. The clearing of TLB entries may make use of the page-table origin in a segment-table entry. Therefore, if the segment-table entry, when in the attached state, ever contained a page-table origin that is different from the current value, copies of entries containing the previous values may remain in the TLB.

4. INVALIDATE DAT TABLE ENTRY cannot be safely used to update a shared location in main storage if the possibility exists that another CPU or a channel program may also be updating the location.

5. The address of the DAT-table entry for INVALIDATE DAT TABLE ENTRY is a 64-bit address, and the address arithmetic is performed by following the normal rules for 64-bit address arithmetic, with wraparound at \(2^{64} - 1\). Also, offset and length fields are not used. Contrast this with implicit translation and the translations for LOAD REAL ADDRESS and STORE REAL ADDRESS, all of which may result either in wraparound or in an addressing exception when a carry occurs out of bit position 0 and which indicate an exception condition when the designated entry does not lie within its table. Accordingly, the DAT tables should not be specified to wrap from maximum storage locations to location 0, and the first designated entry and all additional entries specified by bits 53-63 of general register \(R_2\) should lie within the designated table.

6. When the local-TLB-clearing facility is installed, the local-clearing control should be specified as one when the ASCE used to form the TLB entries being cleared has been attached only to the CPU on which the IDTE instruction is executed (for example, if the program is running on a uniprocessor). Otherwise, unpredictable results, including the presentation of a delayed-access-exception machine check, may occur.

On some models, use of INVALIDATE DAT TABLE ENTRY specifying clearing of only the local TLB for the cases listed above may result in significant performance improvements.

7. The \(M_4\) field of the instruction is considered to be optional, as indicated by the field being contained within brackets \([\ ]\) in the assembler syntax. When the \(M_4\) field is not specified, the assembler places zeros in that field of the instruction.

### INVALIDATE PAGE TABLE ENTRY

**IPTE** \[R_1,R_2[,R_3[,M_4]]\] \[RRF-a\]

**Note:** The term “specified CPU or CPUs” has the following meaning for scope of TLBs affected by this instruction:

- When the local-TLB-clearing facility is not installed, or when the facility is installed and the local-clearing-control (LC) bit in the \(M_4\) field is zero, the term “specified CPU or CPUs” means all of the CPUs in the configuration.

- When the local-TLB-clearing facility is installed and the LC bit in the \(M_4\) field is one, the term “specified CPU or CPUs” means only the CPU executing the IPTE instruction (the local CPU). The TLBs in all other CPUs in the configuration may not be affected.

The designated page-table entries are invalidated, and the translation-lookaside buffers (TLBs) in the specified CPU or CPUs in the configuration are cleared of the associated entries.

The contents of general register \(R_1\) have the format of a segment-table entry, with only the page-table origin used. The contents of general register \(R_2\) have the format of a virtual address, with only the page index used. The contents of fields that are not part of the page-table origin or page index are ignored.

When the IPTE-range facility is not installed, or when the \(R_3\) field is zero, the single page-table entry designated by the first and second operands is invalidated.

When the IPTE-range facility is installed and the \(R_3\) field is nonzero, bits 56-63 of general register \(R_3\) contain an unsigned binary integer specifying the count of additional page-table entries to be invalidated. Therefore, the number of page-table entries to be invalidated is \(1-256\), corresponding to a value of \(0-255\) in bits 56-63 of the register.
The contents of the general registers just described are shown in Figure 10-17 on page 10-37.

<table>
<thead>
<tr>
<th>R1</th>
<th>Page-Table Origin</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>53</td>
</tr>
<tr>
<td>63</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>R2</th>
<th>Page Index</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>44</td>
</tr>
<tr>
<td>52</td>
<td>63</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>R3</th>
<th>Additional Entries</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>56</td>
</tr>
<tr>
<td>63</td>
<td></td>
</tr>
</tbody>
</table>

**Figure 10-17. Register Contents for INVALIDATE PAGE TABLE ENTRY**

When the IPTE-range facility is not installed, the R3 field is ignored but should contain zeros; otherwise, the program may not operate compatibly in the future.

The M4 field has the following format:

```
/ / / C
```

The bits of the M4 field are defined as follows:

- **Reserved**: Bits 0-2 are reserved. Reserved bit positions of the M4 field are ignored but should contain zeros; otherwise, the program may not operate compatibly in the future.

- **Local-Clearing Control (LC)**: When the local-TLB-clearing facility is installed, the LC bit, bit 3 of the M4 field, controls whether only the TLB in the local CPU is cleared or whether the TLBs in all CPUs of the configuration are cleared. When the local-TLB-clearing facility is not installed, bit 3 of the M4 field is reserved.

The page-table origin and the page index designate a page-table entry, following the dynamic-address-translation rules for page-table lookup. The page-table origin is treated as a 64-bit address, and the addition is performed by using the rules for 64-bit address arithmetic, regardless of the current addressing mode, which is specified by bits 31 and 32 of the current PSW. A carry out of bit position 0 as a result of the addition of the page index and page-table origin cannot occur. The address formed from these two components is a real or absolute address. The page-invalid bit of this page-table entry is set to one. During this procedure, the page-table entry is not inspected for whether the page-invalid bit is already one or for format errors. Additionally, the page-frame real address contained in the entry is not checked for an addressing exception.

When the IPTE-range facility is installed and the R3 field is nonzero, the instruction is interruptible, and processing is as follows:

1. The invalidation process described above is repeated for each subsequent entry in the page table until either the number of additional entries specified in bits 56-63 of general register R3 have been invalidated or an interruption occurs.

2. The page-index in bits 44-51 of general register R2 is incremented by the number of page-table entries that were invalidated; a carry out of bit position 44 of general register R2 is ignored.

3. The additional-entry count in bits 56-63 of general register R3 is decremented by the number of page-table entries that were invalidated.

Therefore, when the IPTE-range facility is installed, the R3 field is nonzero, and an interruption occurs (other than one that causes termination), general registers R2 and R3 have been updated, so that the instruction, when reexecuted, resumes at the point of interruption.

When the IPTE-range facility is not installed, or when the R3 field is zero, the contents of registers R2, and R3 remain unchanged.

For each page-table entry that is invalidated, the entire page-table entry appears to be fetched concurrently from storage as observed by other CPUs. Subsequently, the byte containing the page-invalid bit is stored. The fetch access to each page-table entry is subject to key-controlled protection, and the store access is subject to key-controlled protection and low-address protection.
A serialization function is performed before the operation begins and again after the operation is completed. As is the case for all serialization operations, this serialization applies only to this CPU; other CPUs are not necessarily serialized.

If no exceptions are recognized, this CPU clears selected entries from its TLB. Then if the local-TLB-clearing facility is not installed, or if the facility is installed and LC bit in the M₄ field is zero, this CPU signals all CPUs in the configuration to clear selected entries from their TLBs. For each page-table entry invalidated, each affected TLB is cleared of at least those entries that have been formed using all of the following:

- The page-table origin specified by general register R₁
- The page index specified by general register R₂
- The page-frame real address contained in the designated page-table entry

The execution of INVALIDATE PAGE TABLE ENTRY is not completed on the CPU which executes it until the following occur:

1. All page-table entries corresponding to the specified parameters have been invalidated.
2. All entries corresponding to the specified parameters have been cleared from the TLB of this CPU. When the local-TLB-clearing facility is installed and the LC bit in the M₄ field is one, the execution of INVALIDATE PAGE TABLE entry is complete at this point and the following step is not performed.
3. When the local-TLB-clearing facility is not installed, or when the facility is installed and LC bit in the M₄ field is zero, all other CPUs in the configuration have completed any storage accesses, including the updating of the change and reference bits, by using TLB entries corresponding to the specified parameters.

Before the TLB purging operation, transactional execution by other CPUs in the configuration is aborted with abort code 255, condition code 2. The aborting of transactional execution affects at least those CPUs accessing the locations (transactionally or nontransactionally) for which TLB entries are being cleared. It is unpredictable whether some or all other CPUs are affected as well.

**Special Conditions**

When the IPTE-range facility is installed, the R₃ field is nonzero, and the page index in general register R₂ plus the additional-entry count in general register R₃ is greater than 255, a specification exception is recognized.

The operation is suppressed on all addressing and protection exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Addressing (page-table entry)
- Privileged operation
- Protection (fetch and store, page-table entry, key-controlled protection, and low-address protection)
- Specification
- Transaction constraint

**Programming Notes:**

1. The selective clearing of entries may be implemented in different ways, depending on the model, and, in general, more entries may be cleared than the minimum number required. Some models may clear all entries which contain the page-frame real addresses obtained from the page-table entries in storage. Others may clear all entries which contain the designated page index (or indices), and some implementations may clear precisely the minimum number of entries required. Therefore, in order for a program to operate on all models, the program should not take advantage of any properties obtained by a less selective clearing on a particular model.

2. The clearing of TLB entries may make use of the page-frame real addresses in the page-table entries. Therefore, if the page-table entries, when in the attached state, ever contained page-frame real addresses that are different from the current values, copies of entries containing the previous values may remain in the TLB.

3. INVALIDATE PAGE TABLE ENTRY cannot be safely used to update a shared location in main storage if the possibility exists that another CPU or a channel program may also be updating the location.
4. When the IPTE-range facility is installed and the R<sub>3</sub> field is nonzero, the following applies:

   a. All of the page-table entries to be invalidated must reside in the same page table. A specification exception is recognized if the page index in general register R<sub>1</sub> plus the additional-entry count in general register R<sub>3</sub> is greater than the maximum page index of 255.

   b. The number of page-table entries that are invalidated by INVALIDATE PAGE TABLE ENTRY may vary from one execution to another.

   c. The instruction cannot be used for situations where the program must rely on uninterrupted execution of the instruction. Similarly, the program should normally not use INVALIDATE PAGE TABLE ENTRY to invalidate a page-table entry, the page-frame-real address of which designates the 4K-byte block containing the instruction or of an execute-type instruction that executes the IPTE.

   d. Further programming notes concerning interruptible instructions are included in “Interruptible Instructions” on page 5-24.

5. When the local-TLB-clearing facility is installed, the local-clearing control should be specified as one when the ASCE used to form the TLB entries being cleared has been attached only to the CPU on which the IPTE instruction is executed (for example, if the program is running on a uniprocessor). Otherwise, unpredictable results, including the presentation of a delayed-access-exception machine check, may occur.

   On some models, use of INVALIDATE PAGE TABLE ENTRY specifying clearing of only the local TLB for the cases listed above may result in significant performance improvements.

6. The R<sub>3</sub> and M<sub>4</sub> fields of the instruction are considered to be optional, as indicated by the fields being contained within brackets [ ] in the assembler syntax. When either field is not specified, the assembler places zeros in the corresponding field of the instruction. When the M<sub>4</sub> field is coded but the R<sub>3</sub> field is not required, a zero should be coded to designate the place of the third operand.

---

LOAD ADDRESS SPACE PARAMETERS

<table>
<thead>
<tr>
<th>LASP</th>
<th>D&lt;sub&gt;1&lt;/sub&gt;(B&lt;sub&gt;1&lt;/sub&gt;)</th>
<th>D&lt;sub&gt;2&lt;/sub&gt;(B&lt;sub&gt;2&lt;/sub&gt;)</th>
<th>[SSE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘E500’</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>D&lt;sub&gt;1&lt;/sub&gt;</td>
<td>D&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
</tbody>
</table>

The first operand contains values to be loaded into control registers 3 and 4, including a secondary ASN (SASN) and a primary ASN (PASN), and, possibly, a secondary ASTE instance number (SASTEIN) and a primary ASTE instance number (PASTEIN). Execution of the instruction consists in performing four major steps: PASN translation, SASN translation, SASN authorization, and control-register loading. Each of these steps may or may not be performed, depending on the outcome of certain tests and on the setting of bits 61-63 of the second-operand address. The first three of these steps, when performed and successful, obtain additional values, that are loaded into control registers 1, 5, and 7. When the first three steps are not successful when performed, no control registers are changed, and the reason is indicated in the condition code.

When the ASN-and-LX-reuse facility is not installed, or is installed but is not enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0, the first operand is a doubleword containing a PSW-key mask (PKM), a SASN, an authorization index (AX), and a PASN. When the ASN-and-LX-reuse facility is installed and enabled, the first operand is two consecutive doublewords containing those four values and also a SASTEIN and a PASTEIN.

The primary ASN may be translated by means of the ASN-translation tables to obtain a primary-ASTE (PASTE) origin (PASTEO) and, from the PASTE, a primary ASCE (PASCE). The secondary ASN may be translated by means of the ASN-translation tables to obtain a secondary ASCE (SASCE). If the first operand is two doublewords and PASN or SASN translation occurs, the ASTEIN in the located ASTE is checked for being equal to the PASTEIN or SASTEIN, respectively, in the first operand. An authority check for ensuring that the new AX is authorized to establish the new SASN can be prevented when SASN translation occurs, or it can be required and cause SASN translation even when SASN translation would not otherwise occur. The new AX, which is placed in a control register and is used in SASN authorization if that occurs, is the old AX if PASN...
translation has not occurred or is the AX in the located PASTE otherwise. However, in either of these cases, the new AX may be the AX specified in the first operand.

A doubleword first operand has the following format:

First Operand if ASN-and-LX Reuse Is Not Enabled

<table>
<thead>
<tr>
<th>Bit</th>
<th>Function Specified in Second-Operand Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>61</td>
<td>ASN translation performed only when new ASN and old ASN are different.</td>
</tr>
<tr>
<td>62</td>
<td>AX associated with new PASN used.</td>
</tr>
<tr>
<td>63</td>
<td>SASN authorization performed.*</td>
</tr>
</tbody>
</table>

Explanation:

* SASN translation and SASN authorization are performed only when SASN-d is not equal to PASN-d. When SASN-d is equal to PASN-d, the SASCE is set equal to the PASCE, the SASTEIN is set equal to the PASTEIN (if ASN-and-LX reuse is enabled), and no authorization is performed.

A two-doubleword first operand has the following format:

First Operand if ASN-and-LX Reuse Is Enabled

<table>
<thead>
<tr>
<th>Bit</th>
<th>Function Specified in Second-Operand Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>61</td>
<td>ASN translation performed only when new ASN and old ASN are different.</td>
</tr>
<tr>
<td>62</td>
<td>AX associated with new PASN used.</td>
</tr>
<tr>
<td>63</td>
<td>SASN authorization performed.*</td>
</tr>
</tbody>
</table>

The “d” stands for designated value and is used to distinguish these fields from other fields with similar names which are referred to in the definition. The current contents of the corresponding fields in the control registers are referred to as SASTEIN-old, PKM-old, SASN-old, etc. The updated contents of the control registers are referred to as SASTEIN-new, PKM-new, SASN-new, etc.

The second-operand address is not used to address data; instead, the rightmost three bits are used to control portions of the operation. The remainder of the second-operand address is ignored. Bits 61-63 of the second-operand address are used as follows:

The operation of LOAD ADDRESS SPACE PARAMETERS is depicted in Figure 10-21 on page 10-48.

Note: In the following sections, the actions involving the PASTEIN and SASTEIN occur only if the ASN-and-LX-reuse facility is installed and is enabled by the ASN-and-LX-reuse control in control register 0.

PASN Translation and Related Processing

In the PASN-translation process, the PASN-d is translated by means of the ASN first table and the ASN second table. The PASTEO resulting from PASN translation replaces the PASTEO in control register 5. The ASCE in the located ASTE replaces the PASCE in control register 1. When bit 62 of the second-operand address is zero, the AX in the ASTE replaces the AX in control register 4. When bit 62 is one, AX-d replaces the AX in the control register. When ASN-and-LX reuse is enabled, PASTEIN-d is compared to the ASTEIN in the ASTE, and, when equal, replaces the PASTEIN in control register 4.

When bit 61 of the second-operand address is one, PASN translation is always performed. When bit 61 is zero, PASN translation is performed only if PASN-d is not equal to PASN-old. When bit 61 is zero and PASN-d is equal to PASN-old, the PASCE-old, PASTE-old, and PASTEIN-old are left unchanged in the control registers and become the PASCE-new, PAS-
TEO-new, and PASTEIN-new, respectively. In this case, if bit 62 is zero, then the AX-old is left unchanged in the control register and becomes the AX-new, or, if bit 62 is one, AX-new is set equal to AX-d.

The PASN translation follows the normal rules for ASN translation, except that the invalid bits, bit 0 in the ASN-first-table entry and bit 0 in the ASTE, when ones, do not result in an ASN-translation exception. When either of the invalid bits is one, condition code 1 is set. Condition code 1 is also set if PASN translation occurs, the ASN-and-LX-reuse facility is enabled, and PASTEIN-d is not equal to the ASTEIN in the ASTE. When a reason for setting condition code 1 does not exist and either the current primary space-switch-event-control bit in control register 1 is one or the space-switch-event-control bit in the ASTE is one, a space-switch event does not occur; instead, condition code 3 is set. When condition code 1 or 3 is set, the control registers remain unchanged.

The contents of the AX, ASCE, and ASTEIN fields in the ASTE which is accessed as a result of the PASN translation are referred to as AX-p, ASCE-p, and ASTEIN-p, respectively. The origin of the ASTE is referred to as PASTEO-p.

The description in this paragraph applies to use of the subspace-group facility. After ASCE-p has been obtained, if (1) the subspace-group-control bit, bit 54 in ASCE-p, is one, (2) the dispatchable unit is subspace active, and (3) PASTEO-p designates the ASTE for the base space of the dispatchable unit, then a copy of ASCE-p, called ASCE-rp, is made, and bits 0-55 and 58-63 of ASCE-rp are replaced by the same bits of the ASCE in the ASTE for the subspace in which the dispatchable unit last had control. Further details are in “Subspace-Replacement Operations” on page 5-71. If bit 0 in the subspace ASTE is one, or if the ASTE sequence number (ASTESN) in the subspace ASTE does not equal the subspace ASTESN in the dispatchable-unit control table, an exception is not recognized; instead, condition code 1 is set, and the control registers remain unchanged.

**SASN Translation and Related Processing**

In the SASN-translation process, the SASN-d is translated by means of the ASN first table and the ASN second table. The ASCE field obtained from the ASTE subsequently replaces the secondary ASCE (SASCE) in control register 7. When ASN-and-LX reuse is enabled, SASTEIN-d is compared to the ASTEIN in the ASTE, and, when equal, replaces the SASTEIN in control register 3.

SASN translation is performed only when, but not necessarily when, SASN-d is not equal to PASN-d. When SASN-d is equal to PASN-d, SASCE-new and SASTEIN-new are set equal to SASCE-new and SASTEIN-new, respectively. In this case, there is not a test of whether SASTEIN-d is equal to PASTEIN-d; SASTEIN-d is ignored. When SASN-d is not equal to PASN-d and is equal to SASN-old, bit 61 (force ASN translation) is zero, and bit 63 (skip SASN authorization) is one, SASN translation is not performed, and SASCE-old and SASTEIN-old become SASCE-new and SASTEIN-new, respectively. In this case, there is not a test of whether SASTEIN-d is equal to SASTEIN-old; SASTEIN-d is ignored.

SASN translation is performed in each of the following cases:

- SASN-d is not equal to PASN-d or SASN-old.
- SASN-d is not equal to PASN-d but is equal to SASN-old, and either bit 61 (force ASN translation) of the second-operand address is one or bit 63 (skip secondary authority test) of that address is zero. (The translation must be performed when bit 63 is zero in order to obtain the ATO and ATL from the SASTE.)

The SASN translation follows the normal rules for ASN translation, except that the invalid bits, bit 0 in the ASN-first-table entry and bit 0 in the ASTE, when ones, do not result in an ASN-translation exception. When either of the invalid bits is one, condition code 2 is set. Condition code 2 is also set if SASN translation occurs, the ASN-and-LX-reuse facility is enabled, and SASTEIN-d is not equal to the ASTEIN in the ASTE. When condition code 2 is set, the control registers remain unchanged.

The contents of the ASCE, ATO, ATL and ASTEIN fields in the ASTE which is accessed as a result of the SASN translation are referred to as ASCE-s, ATO-s, ATL-s, and ASTEIN-s, respectively. The origin of the ASTE is referred to as SASTEO-s.

The description in this paragraph applies to use of the subspace-group facility. After ASCE-s has been obtained, if (1) the subspace-group-control bit, bit 54 in ASCE-s, is one, (2) the dispatchable unit is subspace active, and (3) SASTEO-s designates the ASTE for the base space of the dispatchable unit,
then a copy of ASCE-s, called ASCE-rs, is made, and bits 0-55 and 58-63 of ASCE-rs are replaced by the same bits of the ASCE in the ASTE for the subspace in which the dispatchable unit last had control. Further details are in “Subspace-Replacement Operations” on page 5-71. If bit 0 in the subspace ASTE is one, or if the ASTE sequence number (ASTEEN) in the subspace ASTE does not equal the subspace ASTEEN in the dispatchable-unit control table, an exception is not recognized; instead, condition code 2 is set, and the control registers remain unchanged.

SASN Authorization

SASN authorization is performed when bit 63 of the second-operand address is zero and SASN-d is not equal to PASN-d; it is performed in this case regardless of whether SASN-d is equal to SASN-old. When SASN-d is equal to PASN-d or when bit 63 of the second-operand address is one, SASN authorization is not performed.

SASN authorization is performed by using ATO-s, ATL-s, and the intended value for AX-new. When bit 62 of the second-operand address is zero and PASN translation was performed, the intended value for AX-new is AX-p. When bit 62 of that address is zero and PASN translation was not performed, the AX is not changed, and AX-new is the same as AX-old. When bit 62 of that address is one, the intended value for AX-new is AX-d. SASN authorization follows the rules for secondary authorization as described in “ASN-Authorization Process” on page 3-33. If the SASN is not authorized (that is, the authority-table length is exceeded, or the selected bit is zero), condition code 2 is set, and none of the control registers is updated.

Control-Register Loading

When the PASN-translation and SASN-translation functions and related functions, and the SASN-authorization functions and subspace-replacement operations, if called for in the instruction execution, are performed without encountering any exceptions or exception conditions, the execution is completed by replacing the contents of control registers 1, 3, 4, 5, and 7 with the new values, and condition code 0 is set. The control registers are loaded as follows.

The PSW-key-mask, bits 32-47, and SASN, bits 48-63, in control register 3 are replaced by the contents of the PKM-d and SASN-d fields of the first operand.

If ASN-and-LX reuse is enabled, the SASTEIN, bits 0-31, in control register 3 is replaced as follows:

- When SASN translation is performed, by SASTEIN-d.
- When SASN translation is not performed because SASN-d is equal to PASN-d, by PASTEIN-new.
- When SASN translation is not performed because (1) SASN-d is not equal to PASN-d but is equal to SASN-old, (2) bit 61 (force ASN translation) of the second-operand address is zero, and (3) bit 63 (skip secondary authority test) of the second-operand address is one, the SASTEIN remains unchanged.

When ASN-and-LX reuse is not enabled, bits 0-31 of control register 3 always remain unchanged.

The PASN, bits 48-63 of control register 4, is replaced by the PASN-d of the first operand. If ASN-and-LX reuse is enabled, the PASTEIN, bits 0-31 of control register 4, is replaced by the PASTEIN-d of the first operand; otherwise, bits 0-31 of the register remain unchanged.

The authorization index, bits 32-47 of control register 4, is replaced as follows:

- When bit 62 of the second-operand address is one, by AX-d.
- When bit 62 of the second-operand address is zero and PASN translation is performed, by AX-p.
- When bit 62 of the second-operand address is zero and PASN translation is not performed, the authorization index remains unchanged.

The primary address-space-control element (PASCE) in control register 1 and the primary-ASN-second-table-entry origin (PASTEIO) in control register 5 are replaced as follows:

- When PASN translation is performed, the PASCE in control register 1 is replaced by the ASCE-p obtained as a result of PASN translation, except that it is replaced by ASCE-rp if a subspace-replacement operation was performed on ASCE-p. Also, the PASTEIO in control register 5 is replaced by PASTEIO-p.
The PASTEO-p is placed in bit positions 33-57 of control register 5, and zeros are placed in bit positions 32 and 58-63. Bits 0-31 of the register remain unchanged.

- When PASN translation is not performed, the contents of control registers 1 and 5 remain unchanged.

The secondary address-space-control element (SASCE) in control register 7 is replaced as follows:

- When SASN-d equals PASN-d, by the new contents of control register 1, the PASCE. The new contents may be PASCE-old, ASCE-p, or ASCE-rp.

- When SASN translation is performed, by ASCE-s, or by ASCE-rs if a subspace-replacement operation was performed on ASCE-s.

When SASN-d does not equal PASN-d and SASN translation is not performed, the SASCE remains unchanged.

**Other Condition-Code Settings**

When PASN translation is called for and cannot be completed because bit 0 is one in either the ASN-first-table entry or the ASTE, or if it can be completed but (1) ASN-and-LX reuse is enabled and PASTEIN-d does not equal the ASTEIN in the ASTE or (2) a subspace-replacement-exception condition exists due to bit 0 or the ASTE sequence number in the subspace ASTE during a subspace-replacement operation on the ASCE-p, condition code 1 is set, and the control registers are not changed.

When PASN translation is called for and completed and any required PASTEIN-d comparison and subspace-replacement operations on the ASCE-p are also completed, and then either (1) the current primary space-switch-event-control bit, bit 57 of control register 1, is one or (2) the space-switch-event-control bit in the ASTE designated by PASTEO-p is one, condition code 3 is set, and the control registers are not changed.

When SASN translation is called for and the translation cannot be completed because bit 0 is one in either the ASN-first-table entry or the ASTE, or if it can be completed but (1) ASN-and-LX reuse is enabled and SASTEIN-d does not equal the ASTEIN in the ASTE, (2) a subspace-replacement-exception condition exists due to bit 0 or the ASTE sequence number in the subspace ASTE during a subspace-replacement operation on the ASCE-s, or (3) SASN authorization is called for and the SASN is not authorized, or condition code 2 is set, and the control registers are not changed.

**Special Conditions**

The instruction can be executed only when the ASN-translation control, bit 44 of control register 14, is one. If the ASN-translation-control bit is zero, a special-operation exception is recognized.

The first operand must be designated on a double-word boundary; otherwise, a specification exception is recognized.

The operation is suppressed on all addressing and protection exceptions.

Figure 10-20 on page 10-47 and Figure 10-18 on page 10-44 summarize the functions of the instruction.

**Resulting Condition Code:**

0  Translation and authorization complete; parameters loaded
1  Primary ASN or subspace not available; parameters not loaded
2  Secondary ASN not available or not authorized, or secondary subspace not available; parameters not loaded
3  Space-switch event specified; parameters not loaded

**Program Exceptions:**

- Access (fetch, operand 1)
- Addressing (ASN-first-table entry, ASN-second-table entry, authority-table entry, dispatchable-unit control table)
- Privileged operation
- Special operation
- Specification
- Transaction constraint
The priority of recognition of program exceptions for the instruction is shown in Figure 10-18.

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.

7.A Access exceptions for second and third instruction halfwords.

7.B.1 Privileged-operation exception.

7.B.2 Special-operation exception due to the ASN-translation control, bit 44 of control register 14, being zero.


8. Specification exception.


10. PASN translation and related processing (when performed).

10.1 Addressing exception for access to ASN-first-table entry.

10.2 Condition code 1 due to I bit (bit 0) in ASN-first-table entry being one.

10.3 Addressing exception for access to ASN-second-table entry.

10.4 Condition code 1 due to (1) I bit (bit 0) in ASN-second-table entry (ASTE) being one or (2) ASN-and-LX reuse enabled and primary ASTE instance number (PASTEIN) in first operand not being equal to ASTEIN in ASTE.

10.5 Addressing exception for access to dispatchable-unit control table.

10.6 Addressing exception for access to subspace ASN-second-table entry.

10.7 Condition code 1 due to I bit (bit 0) in subspace ASN-second-table entry being one.

10.8 Condition code 1 due to subspace ASN-second-table-entry sequence number (SSASTESN) in dispatchable-unit control table not being equal to ASTESN in subspace ASN-second-table entry.

10.9 Condition code 3 due to either the old or new space-switch-event-control bit being one.

11. SASN translation and related processing (when performed).

11.1 Addressing exception for access to ASN-first-table entry.

11.2 Condition code 2 due to I bit (bit 0) in ASN-first-table entry being one.

11.3 Addressing exception for access to ASN-second-table entry.

11.4 Condition code 2 due to (1) I bit (bit 0) in ASN-second-table entry (ASTE) being one or (2) ASN-and-LX reuse enabled and secondary ASTE instance number (SASTEIN) in first operand not being equal to ASTEIN in ASTE.

12.A Execution of secondary authorization (when performed).

12.A.1 Condition code 2 due to authority-table entry being outside table.

12.A.2 Addressing exception for access to authority-table entry.

12.A.3 Condition code 2 due to S bit in authority-table entry being zero.

12.B.1 Addressing exception for access to dispatchable-unit control table.

12.B.2 Addressing exception for access to subspace ASN-second-table entry.

12.B.3 Condition code 2 due to I bit (bit 0) in subspace ASN-second-table entry being one.

12.B.4 Condition code 2 due to subspace ASN-second-table-entry sequence number (SSASTESN) in dispatchable-unit control table not being equal to ASTESN in subspace ASN-second-table entry.

Programming Notes:

1. Bits 61 and 63 in the second-operand address are intended primarily to provide improved performance for those cases where the associated action is unnecessary.

   When bit 61 is set to zero, the action of the instruction is based on the assumption that the current values for PASCE-old, PASTEO-old, and AX-old are consistent with PASN-old and that SASCE-old is consistent with SASN-old. When this is not the case, bit 61 should be set to one.

   Bit 63, when one, eliminates the SASN-authorization test. The program may be able to determine in certain cases that the SASN is
authorized, either because of prior use or because the AX being loaded is authorized to access all address spaces.

2. The SASN-translation and SASN-authorization steps are not performed when SASN-d is equal to PASN-d. This is consistent with the action in SET SECONDARY ASN to current primary (SSAR-cp), which does not perform the translation or ASN authorization.

3. The storage-operand references for LOAD ADDRESS SPACE PARAMETERS may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

4. See Figure 10-19 on page 10-46 for a listing of abbreviations used in this instruction description.
<table>
<thead>
<tr>
<th>First-Operand Bit Positions when ASN-and-LX Reuse Not Enabled</th>
<th>Abbreviation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-15</td>
<td>PKM-d</td>
</tr>
<tr>
<td>16-31</td>
<td>SASN-d</td>
</tr>
<tr>
<td>32-47</td>
<td>AX-d</td>
</tr>
<tr>
<td>48-63</td>
<td>PASN-d</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>First-Operand Bit Positions when ASN-and-LX Reuse Enabled</th>
<th>Abbreviation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-31</td>
<td>SASTEIN-d</td>
</tr>
<tr>
<td>32-47</td>
<td>PKM-d</td>
</tr>
<tr>
<td>48-63</td>
<td>SASN-d</td>
</tr>
<tr>
<td>64-95</td>
<td>PASTEIN-d</td>
</tr>
<tr>
<td>96-111</td>
<td>AX-d</td>
</tr>
<tr>
<td>112-127</td>
<td>PASN-d</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Control-Register Number.Bit</th>
<th>Abbreviation for Previous Contents</th>
<th>Abbreviation for Subsequent Contents</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.0-63</td>
<td>PASCE-old</td>
<td>PASCE-new</td>
</tr>
<tr>
<td>3.0-31</td>
<td>SASTEIN-old</td>
<td>SASTEIN-new</td>
</tr>
<tr>
<td>3.32-47</td>
<td>PKM-old</td>
<td>PKM-new</td>
</tr>
<tr>
<td>3.48-63</td>
<td>SASN-old</td>
<td>SASN-new</td>
</tr>
<tr>
<td>4.0-31</td>
<td>PASTEIN-old</td>
<td>PASTEIN-new</td>
</tr>
<tr>
<td>4.32-47</td>
<td>AX-old</td>
<td>AX-new</td>
</tr>
<tr>
<td>4.48-63</td>
<td>PASN-old</td>
<td>PASN-new</td>
</tr>
<tr>
<td>5.33-57</td>
<td>PASTE0-old</td>
<td>PASTE0-new</td>
</tr>
<tr>
<td>7.0-63</td>
<td>SASCE-old</td>
<td>SASCE-new</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field in ASN-Second-Table Entry</th>
<th>Abbreviation Used for the Field When Accessed as Part of PASN Translation</th>
<th>SASN Translation</th>
</tr>
</thead>
<tbody>
<tr>
<td>1-29</td>
<td>-</td>
<td>ATO-s</td>
</tr>
<tr>
<td>32-47</td>
<td>AX-p</td>
<td>-</td>
</tr>
<tr>
<td>48-59</td>
<td>ASCE-p</td>
<td>ATL-s</td>
</tr>
<tr>
<td>64-127</td>
<td>ASCE-1</td>
<td>ASCE-s1</td>
</tr>
<tr>
<td>352-383</td>
<td>ASTEIN-p</td>
<td>ASTEIN-1</td>
</tr>
</tbody>
</table>

Explanation:
- The field is not used in this case.
- ASCE-rp is formed from ASCE-p, and ASCE-rs is formed from ASCE-s, by a subspace-replacement operation.

Figure 10-19. Summary of Abbreviations for LOAD ADDRESS SPACE PARAMETERS
## Figure 10-20. Summary of Actions: LOAD ADDRESS SPACE PARAMETERS (Part 1 of 2).

<table>
<thead>
<tr>
<th>PASN-d Equals PASN-old</th>
<th>Second-Operand-Address Bits(^1)</th>
<th>PASN Translation Performed</th>
<th>Result Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>61 62</td>
<td>PASCE-new AX-new PASTEEO-new PKM-new SASN-new PASN-new PASTEIN-new</td>
<td></td>
</tr>
<tr>
<td>Yes 0 0</td>
<td>No</td>
<td>PASCE-old AX-old PASTEEO-old PKM-d SASN-d PASN-d PASTEIN-old</td>
<td></td>
</tr>
<tr>
<td>Yes 0 1</td>
<td>No</td>
<td>PASCE-old AX-d PASTEEO-old PKM-d SASN-d PASN-d PASTEIN-old</td>
<td></td>
</tr>
<tr>
<td>Yes 1 0</td>
<td>Yes</td>
<td>ASCE-p(^2) AX-p PASTEEO-p PKM-d SASN-d PASN-d PASTEIN-d</td>
<td></td>
</tr>
<tr>
<td>Yes 1 1</td>
<td>Yes</td>
<td>ASCE-p(^2) AX-d PASTEEO-p PKM-d SASN-d PASN-d PASTEIN-d</td>
<td></td>
</tr>
<tr>
<td>No - 0</td>
<td>Yes</td>
<td>ASCE-p(^2) AX-p PASTEEO-p PKM-d SASN-d PASN-d PASTEIN-d</td>
<td></td>
</tr>
<tr>
<td>No - 1</td>
<td>Yes</td>
<td>ASCE-p(^2) AX-d PASTEEO-p PKM-d SASN-d PASN-d PASTEIN-d</td>
<td></td>
</tr>
</tbody>
</table>

### Explanation:

1. Action in this case is the same regardless of the outcome of this comparison or of the setting of this bit.
2. Second-operand-address bits:
   - 61: Force ASN translation.
   - 62: Use AX from first operand.
   - 63: Skip secondary authority test.
3. PASN-new is ASCE-rp (a copy of ASCE-p except with bits 0-55 and 58-63 replaced from the ASCE in the subspace ASTE), if subspace replacement is performed.
4. SASCE-new is ASCE-rs (a copy of ASCE-s except with bits 0-55 and 58-63 replaced from the ASCE in the subspace ASTE), if subspace replacement is performed.

## Figure 10-20. Summary of Actions: LOAD ADDRESS SPACE PARAMETERS (Part 2 of 2).

<table>
<thead>
<tr>
<th>SASN-d Equals PASN-old</th>
<th>SASN-d Equals PASN-old</th>
<th>Second-Operand-Address Bits(^1)</th>
<th>SASN Translation Performed</th>
<th>SASN Authorization Performed(^2)</th>
<th>Result Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>61 63</td>
<td>SASCE-new SASTEIN-new</td>
<td>SASCE-new SASCE-p(^4) SASCE-s(^4) SASTEIN-d SASTEIN-d</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Yes -</td>
<td>-</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>PASCE-new PASTEIN-new</td>
</tr>
<tr>
<td>No Yes</td>
<td>0 1</td>
<td>No</td>
<td>No</td>
<td>No</td>
<td>SASCE-old SASTEIN-old</td>
</tr>
<tr>
<td>No Yes</td>
<td>1 1</td>
<td>Yes</td>
<td>No</td>
<td>Yes</td>
<td>ASCE-s(^4) SASTEIN-d</td>
</tr>
<tr>
<td>No Yes</td>
<td>- 0</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>ASCE-s(^4) SASTEIN-d</td>
</tr>
<tr>
<td>No No</td>
<td>- 1</td>
<td>Yes</td>
<td>Yes</td>
<td>No</td>
<td>ASCE-s(^4) SASTEIN-d</td>
</tr>
<tr>
<td>No No</td>
<td>- 0</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>SASTEIN-d</td>
</tr>
</tbody>
</table>

### Explanation:

2. PASN-new is ASCE-rp (a copy of ASCE-p except with bits 0-55 and 58-63 replaced from the ASCE in the subspace ASTE), if subspace replacement is performed.
Figure 10-21. Execution of LOAD ADDRESS SPACE PARAMETERS

Explanation:
* PASCE-tmp is ASCE-rp if subspace replacement occurred.
** SASCE-tmp is ASCE-rs if subspace replacement occurred.
Note: Actions involving PASTEIN and SASTEIN occur only if ASN-and-LX reuse is enabled.
LOAD CONTROL

**LCTL**  \( R_1, R_2, D_2(B_2) \) \([RS-a]\)

<table>
<thead>
<tr>
<th>'B7'</th>
<th>R_1</th>
<th>R_3</th>
<th>B_2</th>
<th>D_2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>

**LCTLG**  \( R_1, R_2, D_2(B_2) \) \([RSY-a]\)

<table>
<thead>
<tr>
<th>'EB'</th>
<th>R_1</th>
<th>R_3</th>
<th>B_2</th>
<th>DL_2</th>
<th>DH_2</th>
<th>'2F'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>40</td>
</tr>
</tbody>
</table>

Bit positions of the set of control registers starting with control register \( R_1 \) and ending with control register \( R_3 \) are loaded from storage beginning at the location designated by the second-operand address and continuing through as many locations as needed.

For LOAD CONTROL (LCTL), bit positions 32-63 of the control registers are loaded from successive words beginning at the second-operand address, and bits 0-31 of the registers remain unchanged. For LOAD CONTROL (LCTLG), bit positions 0-63 of the control registers are loaded from successive double-words beginning at the second-operand address. The control registers are loaded in ascending order of their register numbers, starting with control register \( R_1 \) and continuing up to and including control register \( R_3 \), with control register 0 following control register 15.

The information loaded into the control registers becomes active when instruction execution has ended.

The displacement for LCTL is treated as a 12-bit unsigned binary integer. The displacement for LCTLG is treated as a 20-bit signed binary integer.

**Special Conditions**

The second operand must be designated on a word boundary for LCTL or on a doubleword boundary for LCTLG; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Privileged operation
- Specification
- Transaction constraint

---

LOAD PAGE TABLE ENTRY ADDRESS

**LPTEA**  \( R_1, R_2, R_3, M_4 \) \([RRF-b]\)

<table>
<thead>
<tr>
<th>'B9AA'</th>
<th>R_3</th>
<th>M_4</th>
<th>R_1</th>
<th>R_2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
<td>28</td>
<td>31</td>
</tr>
</tbody>
</table>

General register \( R_2 \) contains a virtual address that is processed by means of dynamic address translation to locate a page-table entry, the 64-bit real or absolute address of which is returned in general register \( R_1 \). The \( M_4 \) field contains a value designating the effective address-space-control element (ASCE) that is used by DAT, as shown in the following table:

<table>
<thead>
<tr>
<th>( M_4 ) Field (binary)</th>
<th>Effective Address-Space-Control Element Used by DAT</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000</td>
<td>Contents of control register 1</td>
</tr>
<tr>
<td>0001</td>
<td>The address-space-control element obtained by applying the access-register-translation (ART) process to the access register designated by the ( R_2 ) field.</td>
</tr>
<tr>
<td>0010</td>
<td>Contents of control register 7</td>
</tr>
<tr>
<td>0011</td>
<td>Contents of control register 13</td>
</tr>
<tr>
<td>0100</td>
<td>The address-space-control element corresponding to the current address-space-control bits, bits 16 and 17 of the PSW.</td>
</tr>
</tbody>
</table>
When the M4 field contains 0001 binary, or when the M4 field contains 0100 binary and bits 16-17 of the PSW contain 01 binary, then access-register translation precedes, as is normal, the dynamic address translation.

The R3 field is ignored but should be zero to permit possible future extensions.

The virtual address specified by the R2 field is translated by means of dynamic-address translation, regardless of whether DAT is on or off. ART and DAT may be performed with the use of the ART-lookaside buffer (ALB) and translation-lookaside buffer (TLB), respectively. The DAT process completes upon locating the page-table entry. The contents of the page-table entry are not examined for format errors, the I bit is not examined to determine whether the page is invalid, and the page-frame real address is not fetched.

Virtual address computation is performed according to the addressing mode specified by bits 31 and 32 of the current PSW.

The addresses of the region-table entry or entries, if used, and of the segment-table entry and page-table entry are treated as 64-bit addresses, regardless of the current addressing mode. It is unpredictable whether the addresses of these entries are treated as real or absolute addresses.

If the DAT process successfully locates the page-table entry, the 64-bit real or absolute address of the entry is placed in general register R1, and the condition code is set as follows:

- When EDAT-1 does not apply, the condition code is set based on the DAT-protection bit (P) of the segment-table entry used in the translation. Condition code 0 is set when the P bit is zero; condition code 1 is set when the P bit is one.
- When EDAT-1 applies, the condition code is set based on all of the DAT-protection bits encountered in the translation. If the DAT-protection bit is zero in the segment-table entry and the DAT-protection bits are zero in any and all region-table entries used in the translation, condition code 0 is set. If the DAT-protection bit is one in any region- or segment-table entry used in the translation, condition code 1 is set.

When EDAT-1 applies and the DAT process successfully locates a valid segment-table entry in which the STE-format control is one, bits 0-60 of the segment-table entry address are placed in bit positions 0-60 of general register R1, bit 61 of the register is set to the logical OR of the DAT-protection bit in the segment-table entry and any region-table entries used in the translation, bits 62-63 of the register are set to zeros, and the instruction completes by setting condition code 2.

When EDAT-2 applies and the DAT process successfully locates a valid region-third-table entry in which the RTTE-format control is one, bits 0-60 of the region-third-table entry address are placed in bit positions 0-60 of general register R1, bit 61 of the register is set to the logical OR of the DAT-protection bit in the region-third-table entry and any higher-level region-table entries used in the translation, bits 62-63 of the register are set to zeros, and the instruction completes by setting condition code 2.

When a condition exists that would normally cause one of the exceptions shown in Figure 10-22, processing is as follows:

1. General register R1 is updated as follows:
   a. Bits 0-60 of the table-entry address are placed in bit positions 0-60 of the register.
   b. When EDAT-1 does not apply, bit 61 of the register is set to zero. When enhanced DAT applies, bit 61 is set to the logical OR of the DAT-protection bits in all valid region-table entries used in the translation; if the DAT process does not require region-table entries, or if no valid region-table entries are encountered, bit 61 is set to zero.
   c. The expected table-type bits are placed in bit positions 62-63 of the register. When the region table or segment table containing the invalid entry is directly designated by the address-space-control element, then the expected table-type bits are those contained in the designation-type control (DT) in the ASCE. Otherwise, the expected table-type bits are one less than the value of those bits in the next-higher-level table.
2. The instruction is completed by setting condition code 2.

<table>
<thead>
<tr>
<th>Exception Name</th>
<th>Cause</th>
<th>Code (hex)</th>
<th>Expected TT Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>Region first translation</td>
<td>Invalid bit is one in the region-first-table entry selected by the RFX portion of the virtual address.</td>
<td>0039</td>
<td>11</td>
</tr>
<tr>
<td>Region second translation</td>
<td>Invalid bit is one in the region-second-table entry selected by the RSX portion of the virtual address.</td>
<td>003A</td>
<td>10</td>
</tr>
<tr>
<td>Region third translation</td>
<td>Invalid bit is one in the region-third-table entry selected by the RTX portion of the virtual address.</td>
<td>003B</td>
<td>01</td>
</tr>
<tr>
<td>Segment translation</td>
<td>Invalid bit is one in the segment-table entry selected by the SX portion of the virtual address.</td>
<td>0010</td>
<td>00</td>
</tr>
</tbody>
</table>

Figure 10-22. LPTEA Exception Conditions Causing CC2

When a condition exists that would normally cause one of the exceptions shown in Figure 10-23, (1) the interruption code assigned to the exception is placed in bit positions 48-63 of general register R1, and bits 0-47 of the register are set to zeros; and (2) the instruction is completed by setting condition code 3.

<table>
<thead>
<tr>
<th>Exception Name</th>
<th>Cause</th>
<th>Code (hex)</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALET specification</td>
<td>ALET bits 0-6 not all zeros.</td>
<td>0028</td>
</tr>
<tr>
<td>ALEN translation</td>
<td>ALE outside list or I bit is one.</td>
<td>0029</td>
</tr>
<tr>
<td>ALE sequence</td>
<td>ALESN in ALET not equal to ALESN in ALE.</td>
<td>002A</td>
</tr>
<tr>
<td>ASTE validity</td>
<td>ASTE I bit is one.</td>
<td>002B</td>
</tr>
<tr>
<td>ASTE sequence</td>
<td>ASTESN in ALE not equal to ASTESN in ASTE.</td>
<td>002C</td>
</tr>
<tr>
<td>Extended authority</td>
<td>ALE P bit not zero, ALEAX not equal to EAX, and secondary bit selected by EAX either outside authority table or zero.</td>
<td>002D</td>
</tr>
</tbody>
</table>

Figure 10-23. LPTEA Exception Conditions Causing CC3 (Part 1 of 2)

Special Conditions

If the M4 field contains any value other than 0000-0100 binary, a specification exception is recognized.

The address-space-control element used in the translation must not be a real-space designation; otherwise, a special-operation exception is recognized. The exception due to the address-space-control element has priority 9 in Figure 6-6 on page 6-49.

An addressing exception is recognized when the address used by ART to fetch the effective access-list designation, the access-list entry, the address-space-second-table entry, or the authority-table entry designates a location which is not available in the configuration. An addressing exception is also recognized when the address used by DAT to fetch a region-table entry or the segment-table entry designates a location which is not available in the configuration.

A carry out of bit position 0 as a result of the addition done to compute the address of a region-table entry or the segment-table entry may be ignored or may result in an addressing exception.
A translation-specification exception is recognized if an accessed region-table entry or the segment-table entry has a zero I bit and a format error.

The operation is suppressed on all addressing exceptions.

**Resulting Condition Code:**

0  PTE address returned; P bit is 0 in all DAT-table entries examined
1  PTE address returned; P bit is 1 in any DAT-table entry examined
2  Invalid bit is one in the region- or segment-table entry; EDAT-1 applies, a valid STE was located, and STE FC is 1; or EDAT-2 applies, a valid RTTE was located, and RTTE FC is 1
3  Exception condition exists

**Program Exceptions:**

- Addressing (effective access-list designation, access-list entry, ASN-second-table entry, authority-table entry, region-table entry, or segment-table entry)
- Operation (DAT-enhancement facility 2 not installed)
- Privileged operation
- Special operation
- Specification
- Transaction constraint
- Translation specification

**Programming Notes:**

1. An addressing exception is not recognized if the page-table-entry address returned in general register R1 is not available in the configuration.

2. When EDAT-1 applies, the STE-format control is one, and no other exception conditions apply, the address of the segment-table entry is placed in general register R1, and condition code 2 is set. This effectively performs a load-segment-table-entry-address function, although no such instruction is defined.

   However, because condition code 2 is also used to indicate an invalid region-table entry, all of the following conditions must exist in order to assume that the located table entry is a valid STE:

   a. Bit positions 62-63 of general register R1 (the expected table-type) must contain 00 binary.

2. Bit position 58 of the table entry designated by general register R1 must contain zero (indicating a valid table entry).

3. When EDAT-2 applies, the RTTE-format control is one, and no other exception conditions apply, the address of the region-third-table entry is placed in general register R1, and condition code 2 is set. This effectively performs a load-region-third-table-entry-address function, although no such instruction is defined.

   However, because condition code 2 is also used to indicate an invalid region-table entry, all of the following conditions must exist in order to assume that the located table entry is a valid RTTE:

   a. Bit positions 62-63 of general register R1 (the expected table-type) must contain 01 binary.

   b. Bit position 58 of the table entry designated by general register R1 must contain 00 binary (indicating a valid table entry).

   c. The table-type field in bit positions 60-61 of the table entry designated by general register R1 must contain 00 binary (designating a segment-table entry).

The following program fragment illustrates this determination when only EDAT-1 applies. If no branch is taken, then the address in general register 1 is that of a segment-table entry in which the STE-format control is one:

```
LPTEA 1,0,2,4
BRC 8,PTE_WITH_NEITHER_STE_NOR_RTE_PROT
BRC 4,PTE_WITH_PROTECTED_STE_OR_RTE
BRC 1,EXCEPTION_EXISTS
TMLL 1,X'0003'
JNZ EXCEPTION_EXISTS
NILL 1,X'FFF8'
LURAG 10,1
TMLL 10,X'0020'
JO EXCEPTION_EXISTS
```
that of a region-third-table entry in which the RTTE-format control is one:

```
* Further check for EDAT-2
TMLL 10,X'000C
JZ VALID_F1_STE
* Must be valid F1 RTTE
```

4. When condition code 2 is set as a result of locating a valid segment-table entry in which the STE-format control is one, bit 61 of general register R1 indicates whether DAT protection applies to the segment. Similarly, when condition code 2 is set as a result of locating a valid region-third-table entry in which the RTTE-format control is one, bit 61 of general register R1 indicates whether DAT protection applies to the region.

5. When EDAT-1 does not apply, only the STE is examined in determining whether condition code 0 or 1 is set. When EDAT applies, all DAT-table entries used in the translation may be examined in determining whether condition code 0 or 1 is to be set.

**LOAD PSW**

LPSW  \[ D_3(B_2) \]  [S]

The current PSW is replaced by a 16-byte PSW formed from the contents of the doubleword at the location designated by the second-operand address.

Bit 12 of the doubleword must be one; otherwise, a specification exception may be recognized, depending on the model.

Bits 0-32 of the doubleword, except with bit 12 inverted, are placed in bit positions 0-32 of the current PSW. Bits 33-63 of the doubleword are placed in bit positions 97-127 of the current PSW. Bits 33-96 of the current PSW are set to zeros.

A serialization and checkpoint-synchronization function is performed before or after the operand is fetched and again after the operation is completed.

**Special Conditions**

The operand must be designated on a doubleword boundary; otherwise, a specification exception is recognized. A specification exception may be recognized if bit 12 of the operand is zero, depending on the model.

The PSW fields which are to be loaded by the instruction are not checked for validity before they are loaded, except for the optional checking of bit 12. However, immediately after loading, a specification exception is recognized, and a program interruption occurs, when any of the following is true for the newly loaded PSW:

- Any of bits 0, 2-4, 12, or 25-30 is a one.
- Bit 24 is one (recognition of this condition is optional)
- Bits 31 and 32 are both zero, and bits 97-103 are not all zeros.
- Bits 31 and 32 are one and zero, respectively.

In these cases, the operation is completed, and the resulting instruction-length code is 0.

The test for a specification exception after the PSW is loaded is described in “Early Exception Recognition” on page 6-9.

The operation is suppressed on all addressing and protection exceptions.

**Resulting Condition Code:** The code is set as specified in the new PSW loaded.

**Program Exceptions:**

- Access (fetch, operand 2)
- Privileged operation
- Specification
- Transaction constraint

**Programming Note:** The second operand should have the format of an ESA/390 PSW. A specification exception will be recognized during or after the execution of LOAD PSW if bit 12 of the operand is zero.

**LOAD PSW EXTENDED**

LPSWE \[ D_3(B_2) \]  [S]

The operand must be designated on a doubleword boundary; otherwise, a specification exception is rec-
The current PSW is replaced by the contents of the 16-byte second operand.

A serialization and checkpoint-synchronization function is performed before or after the operand is fetched and again after the operation is completed.

**Special Conditions**

The operand must be designated on a doubleword boundary; otherwise, a specification exception is recognized.

The value which is to be loaded by the instruction is not checked for validity before it is loaded. However, immediately after loading, a specification exception is recognized, and a program interruption occurs, when any of the following is true for the newly loaded PSW:

- Any of the unassigned bits (0, 2-4, 25-30, or 33-63) is a one.
- Bit 12 is a one.
- Bit 24 is one (recognition of this condition is optional)
- Bits 31 and 32 are both zero, and bits 64-103 are not all zeros.
- Bits 31 and 32 are one and zero, respectively.

In these cases, the operation is completed, and the resulting instruction-length code is zero.

The test for a specification exception after the PSW is loaded is described in “Early Exception Recognition” on page 6-9.

The operation is suppressed on all addressing and protection exceptions.

**Resulting Condition Code:** The code is set as specified in the new PSW loaded.

**Program Exceptions:**

- Access (fetch, operand 2)
- Privileged operation
- Specification
- Transaction constraint

---

**LOAD REAL ADDRESS**

<table>
<thead>
<tr>
<th>LRA</th>
<th>( R_1, D_2(X_2, B_2) )</th>
<th>([RX-a])</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B1'</td>
<td>( R_1 )</td>
<td>( X_2 )</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LRAY</th>
<th>( R_1, D_2(X_2, B_2) )</th>
<th>([RXY-a])</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td>( R_1 )</td>
<td>( X_2 )</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LRAG</th>
<th>( R_1, D_2(X_2, B_2) )</th>
<th>([RX-y])</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E3'</td>
<td>( R_1 )</td>
<td>( X_2 )</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

For LOAD REAL ADDRESS (LRA, LRAY) in the 24-bit or 31-bit addressing mode, if bits 0-32 of the 64-bit real or absolute address corresponding to the second-operand virtual address are all zeros, bits 32-63 of the real or absolute address are placed in bit positions 32-63 of general register \( R_1 \), and bits 0-31 of the register remain unchanged. If bits 0-32 of the real address or absolute are not all zeros, a special-operation exception is recognized.

For LRA or LRAY in the 64-bit addressing mode, and for LOAD REAL ADDRESS (LRAG) in any addressing mode, the 64-bit real or absolute address corresponding to the second-operand virtual address is placed in general register \( R_1 \).

When EDAT-1 does not apply, or when EDAT-1 applies but the second operand is translated by means of a segment-table entry in which the STE-format control is zero, the address placed in general register \( R_1 \) is real. When EDAT-1 applies and the second operand is translated by means of a segment-table entry in which the STE-format control is one, or when EDAT-2 applies and the second operand is translated by means of a region-third-table entry in which the RTTE-format control is one, the address placed in general register \( R_1 \) is absolute.

The virtual address specified by the \( X_2 \), \( B_2 \), and \( D_2 \) fields is translated by means of the dynamic-address-translation facility, regardless of whether DAT is on or off.

The displacement for LRA is treated as a 12-bit unsigned binary integer. The displacement for LRAY and LRAG is treated as a 20-bit signed binary integer.
DAT is performed by using an address-space-control element that depends on the current value of the address-space-control bits, bits 16 and 17 of the PSW, as shown in Figure 10-24.

<table>
<thead>
<tr>
<th>PSW Bits 16 and 17</th>
<th>Address-Space-Control Element Used by DAT</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Contents of control register 1</td>
</tr>
<tr>
<td>01</td>
<td>The address-space-control element obtained by applying the access-register-translation (ART) process to the access register designated by the B2 field</td>
</tr>
<tr>
<td>10</td>
<td>Contents of control register 7</td>
</tr>
<tr>
<td>11</td>
<td>Contents of control register 13</td>
</tr>
</tbody>
</table>

Figure 10-24. Address-Space Control used by LOAD REAL ADDRESS

ART and DAT may be performed with the use of the ART-lookaside buffer (ALB) and translation-lookaside buffer (TLB), respectively.

The virtual-address computation is performed according to the current addressing mode, specified by bits 31 and 32 of the current PSW.

The addresses of the region-table entry or entries, if used, and of the segment-table entry and page-table entry, if used, are treated as 64-bit addresses regardless of the current addressing mode. It is unpredictable whether the addresses of these entries are treated as real or absolute addresses.

Condition code 0 is set when both ART, if applicable, and DAT can be completed and a special-operation exception is not recognized, that is, when an address-space-control element can be obtained, the entry in each DAT table lies within the table and has a zero I bit, and, for LRA or LRAY in the 24-bit or 31-bit addressing mode, bits 0-32 of the resulting real or absolute address are zeros. The translated address is not inspected for boundary alignment or for addressing or protection exceptions.

When PSW bits 16 and 17 are 01 binary and an address-space-control element cannot be obtained because of a condition that would normally cause one of the exceptions shown in Figure 10-25, (1) the interruption code assigned to the exception is placed in bit positions 48-63 of general register R1, bit 32 of this register is set to one, bits 33-47 are set to zeros, and bits 0-31 remain unchanged, and (2) the instruction is completed by setting condition code 3.

When ART is completed normally, the operation is continued through the performance of DAT.

When the segment-table entry is outside the table and bits 0-32 of the real or absolute address of the entry are all zeros, bits 32-63 of the entry address are placed in bit positions 32-63 of general register R1, bits 0-31 of the register remain unchanged, and the instruction completes by setting condition code 3. If bits 0-32 of the address are not all zeros, the result is as described in the section “DAT-Related Exceptions for LOAD REAL ADDRESS” on page 10-56.

When the I bit in the segment-table entry is one, the following applies:

- For LRA or LRAY in the 64-bit addressing mode or for LRAG in any addressing mode, the 64-bit real or absolute address of the segment-table entry is placed in general register R1, and the instruction is completed by setting condition code 1.
- For LRA or LRAY in the 24-bit or 31-bit addressing mode, the following applies:
  - If bits 0-32 of the address of the segment-table entry are all zeros, bits 32-63 of the real or absolute address of the segment-table entry are placed in bits 32-63 of general register R1, bits 0-31 of the register remain unchanged, and the instruction is completed by setting condition code 1.

<table>
<thead>
<tr>
<th>Exception Name</th>
<th>Cause</th>
<th>Code (Hex)</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALET specification</td>
<td>Access-list-entry-token (ALET) bits 0-6 not all zeros</td>
<td>0028</td>
</tr>
<tr>
<td>ALEN translation</td>
<td>Access-list entry (ALE) outside list or invalid (bit 0 is one)</td>
<td>0029</td>
</tr>
<tr>
<td>ALE sequence validity</td>
<td>ALE sequence number (ALESN) in ALET not equal to ALESN in ALE</td>
<td>002A</td>
</tr>
<tr>
<td>ASTE sequence invalidity</td>
<td>ASN-second-table entry (ASTE) invalid (bit 0 is one)</td>
<td>002B</td>
</tr>
<tr>
<td>ASTE sequence</td>
<td>ASTE sequence number (ASTESN) in ALE not equal to ASTESN in ASTE</td>
<td>002C</td>
</tr>
<tr>
<td>Extended authority</td>
<td>ALE private bit not zero, ALE authorization index (ALEAX) not equal to extended authorization index (EAX), and secondary bit selected by EAX either outside authority table or zero</td>
<td>002D</td>
</tr>
</tbody>
</table>

Figure 10-25. Handling of ART-Related Exceptions for LOAD REAL ADDRESS
When the I bit in the page-table entry is one, the following applies:

- For LRA or LRAY in the 64-bit addressing mode or for LRAG in any addressing mode, the 64-bit real or absolute address of the page-table entry is placed in general register R1, and the instruction is completed by setting condition code 2.

- For LRA or LRAY in the 24-bit or 31-bit addressing mode, the following applies:
  - If bits 0-32 of the address of the page-table entry are all zeros, bits 32-63 of the real or absolute address of the page-table entry are placed in bits 32-63 of general register R1, bits 0-31 of the register remain unchanged, and the instruction is completed by setting condition code 2.
  - If bits 0-32 of the address of the page-table entry are not all zeros, the result is as described in the section “DAT-Related Exceptions for LOAD REAL ADDRESS”, below.

A segment-table-entry or page-table-entry address placed in general register R1 is real or absolute in accordance with the type of address that was used during the attempted translation.

### DAT-Related Exceptions for LOAD REAL ADDRESS

If a condition exists that would normally cause one of the exceptions shown in the Figure 10-26, (1) the interruption code assigned to the exception is placed in bit positions 48-63 of general register R1, bit 32 of this register is set to one, bits 33-47 are set to zeros, and bits 0-31 remain unchanged, and (2) the instruction is completed by setting condition code 3.

<table>
<thead>
<tr>
<th>Exception Name</th>
<th>Cause</th>
<th>Code (Hex)</th>
</tr>
</thead>
<tbody>
<tr>
<td>ASCE type</td>
<td>Address-space-control element (ASCE) being used is a region-second-table designation, and bits 0-10 of virtual address not all zeros; ASCE is a region-third-table designation, and bits 0-21 of virtual address not all zeros; or ASCE is a segment-table designation, and bits 0-32 of virtual address not all zeros.</td>
<td>0038</td>
</tr>
<tr>
<td>Region first translation</td>
<td>Region-first-table entry selected by region-first-index portion of virtual address outside table or invalid.</td>
<td>0039</td>
</tr>
<tr>
<td>Region second translation</td>
<td>Region-second-table entry selected by region-second-index portion of virtual address outside table or invalid.</td>
<td>003A</td>
</tr>
<tr>
<td>Region third translation</td>
<td>Region-third-table entry selected by region-third-index portion of virtual address outside table or invalid.</td>
<td>003B</td>
</tr>
<tr>
<td>Segment translation</td>
<td>Segment-table entry selected by segment-index portion of virtual address outside table (for all instructions and all addressing modes, but only when bits 0-32 of entry address not all zeros); or segment-table entry invalid (LRA and LRAY only, and only in 24-bit or 31-bit addressing mode when bits 0-32 of entry address not all zeros).</td>
<td>0010</td>
</tr>
<tr>
<td>Page translation</td>
<td>Page-table entry selected by page-index portion of virtual address invalid (LRA and LRAY only, and only in 24-bit or 31-bit addressing mode when bits 0-32 of entry address not all zeros).</td>
<td>0011</td>
</tr>
</tbody>
</table>

Figure 10-26. Handling of DAT-Related Exceptions for LOAD REAL ADDRESS

### Special Conditions

A special-operation exception is recognized when, for LRA or LRAY in the 24-bit or 31-bit addressing mode, bits 0-32 of the resultant 64-bit real address are not all zeros.

An addressing exception is recognized when the address used by ART to fetch the effective access-list designation or the ALE, ASTE, or authority-table...
entry designates a location which is not available in the configuration or when the address used to fetch the region-table entry or entries, if any, segment-table entry, or page-table entry designates a location which is not available in the configuration.

A translation-specification exception is recognized when an accessed region-table entry or the segment-table entry or page-table entry has a zero I bit and a format error, that is, when any of the reasons listed in “Translation-Specification Exception” on page 6-44 applies.

A carry out of bit position 0 as a result of the addition done to compute the address of a region-table entry or the segment-table entry may be ignored or may result in an addressing exception.

The operation is suppressed on all addressing exceptions.

**Resulting Condition Code:**

0  Translation available
1  Segment-table entry invalid (I bit one)
2  Page-table entry invalid (I bit one)
3  Address-space-control element not available, region-table entry outside table or invalid (I bit one), segment-table entry outside table, or, for LRA and LRAY only, and only in 24-bit or 31-bit addressing mode when bits 0-32 of entry address not all zeros, segment-table entry or page-table entry invalid (I bit one)

**Program Exceptions:**

- Addressing (effective access-list designation, access-list entry, ASN-second-table entry, authority-table entry, region-table entry, segment-table entry, or page-table entry)
- Operation (LRAY, if the long-displacement facility is not installed)
- Privileged operation
- Special operation (LRA, LRAY only)
- Transaction constraint
- Translation specification

**Programming Notes:**

1. Caution must be exercised in the use of LOAD REAL ADDRESS in a multiprocessing configuration. Since INVALIDATE DAT TABLE ENTRY or INVALIDATE PAGE TABLE ENTRY may set I bits in storage to one before causing the corresponding entries in TLBs of other CPUs to be cleared, the simultaneous execution of LOAD REAL ADDRESS on this CPU and either INVALIDATE DAT TABLE ENTRY or INVALIDATE PAGE TABLE ENTRY on another CPU may produce inconsistent results. Because LOAD REAL ADDRESS may access the tables in storage, the region-table entries, segment-table entry or page-table entry may appear to be invalid (condition codes 3, 1, or 2, respectively) even though the corresponding TLB entry has not yet been cleared, and the TLB entry may remain in the TLB until the completion of INVALIDATE DAT TABLE ENTRY or INVALIDATE PAGE TABLE ENTRY on the other CPU. There is no guaranteed limit to the number of instructions which may be executed between the completion of LOAD REAL ADDRESS and the TLB being cleared of the entry.

The above cautions for using LOAD REAL ADDRESS also apply when COMPARE AND SWAP AND PURGE or COMPARE AND REPLACE DAT TABLE ENTRY is used to explicitly set the invalid bit in a DAT-table entry.

2. Figure 10-27 on page 10-57 summarizes the resulting contents of general register R1, and the condition code.

<table>
<thead>
<tr>
<th>Exception/Cause/Entry-Address Size or Resultant-Real-Address Size</th>
<th>General Register R1 Contents and Condition Code</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>LRA or LRAY in 24-Bit or 31-Bit Addressing Mode</td>
</tr>
<tr>
<td></td>
<td>0-31</td>
</tr>
<tr>
<td>ALET specification</td>
<td>U</td>
</tr>
<tr>
<td>ALEN translation</td>
<td>U</td>
</tr>
<tr>
<td>ALE sequence</td>
<td>U</td>
</tr>
<tr>
<td>ASTE validity</td>
<td>U</td>
</tr>
</tbody>
</table>

*Figure 10-27. Summary of Results: LOAD REAL ADDRESS*
3. When the instruction completes with condition code 3, the following applies:
   - Only the rightmost 32 bits of general register \( R_1 \) are meaningful, regardless of the addressing mode or instruction executed. The program can determine whether the rightmost bits of general register \( R_1 \) contain the address of a DAT-table entry or a program-interruption code based on whether bit 32 of the register is zero or one, respectively.
   - In order to correctly use a DAT-table-entry address returned in general register \( R_1 \) in the

---

<table>
<thead>
<tr>
<th>Exception/Cause/Entry-Address Size or Resultant-Real-Address Size</th>
<th>General Register ( R_1 ) Contents and Condition Code</th>
<th>LRA or LRAY in 24-Bit or 31-Bit Addressing Mode</th>
<th>LRA or LRAY in 64-Bit Addr. Mode or LRAG in Any Addressing Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>0-31</td>
<td>32</td>
</tr>
<tr>
<td>ASTE sequence</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>Extended authority</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>ASCE type</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>Region first trans.</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>Region second trans.</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>Region third trans.</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>Segment translation/entry outside table/entry address &lt; 2GB</td>
<td>U</td>
<td>0</td>
<td>EA3</td>
</tr>
<tr>
<td>Segment translation/entry outside table/entry address &gt;= 2GB</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>Segment translation/I bit one/entry address &lt; 2GB</td>
<td>U</td>
<td>0</td>
<td>EA3</td>
</tr>
<tr>
<td>Segment translation/I bit one/entry address &gt;= 2GB</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>Page translation/I bit one/entry address &lt; 2GB</td>
<td>U</td>
<td>0</td>
<td>EA3</td>
</tr>
<tr>
<td>Page translation/I bit one/entry address &gt;= 2GB</td>
<td>U</td>
<td>1</td>
<td>0s</td>
</tr>
<tr>
<td>Real Address &lt; 2GB</td>
<td>U</td>
<td>0</td>
<td>RA3</td>
</tr>
<tr>
<td>Real Address &gt;= 2GB</td>
<td>Special-Operation Exception</td>
<td>RA1</td>
<td>RA2</td>
</tr>
</tbody>
</table>

**Explanation:**

- EA1: Bits 0-31 of the entry address.
- EA2: Bit 32 of the entry address.
- EA3: Bits 33-47 of the entry address.
- EA4: Bits 48-63 of the entry address.
- RA1: Bits 0-31 of the resultant real address.
- RA2: Bit 32 of the resultant real address.
- RA3: Bits 33-47 of the resultant real address.
- RA4: Bits 48-63 of the resultant real address.
- U: Unchanged.

*Figure 10-27. Summary of Results: LOAD REAL ADDRESS*
64-bit addressing mode, the leftmost 32 bits of the register must be set to zeros.

**LOAD USING REAL ADDRESS**

<table>
<thead>
<tr>
<th>LURA</th>
<th>R&lt;sub&gt;1&lt;/sub&gt;,R&lt;sub&gt;2&lt;/sub&gt;</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B24B'</td>
<td>0 16 24 28 31</td>
<td>R&lt;sub&gt;1&lt;/sub&gt;</td>
</tr>
</tbody>
</table>

For LOAD USING REAL ADDRESS (LURA), the word at the real-storage location addressed by the contents of general register R<sub>2</sub> is placed in bit positions 32-63 of general register R<sub>1</sub>, and the contents of bit positions 0-31 remain unchanged. For LOAD USING REAL ADDRESS (LURAG), the doubleword at that real-storage location is placed in bit positions 0-63 of general register R<sub>1</sub>.

In the 24-bit addressing mode, bits 40-63 of general register R<sub>2</sub> designate the real-storage location, and bits 0-39 of the register are ignored. In the 31-bit addressing mode, bits 33-63 of general register R<sub>2</sub> designate the real-storage location, and bits 0-32 of the register are ignored. In the 64-bit addressing mode, bits 0-63 of general register R<sub>2</sub> designate the real-storage location.

Because it is a real address, the address designating the storage word or doubleword is not subject to dynamic address translation.

**Special Conditions**

The contents of general register R<sub>2</sub> must designate a location on a word boundary for LURA or on a doubleword boundary for LURAG; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Addressing (address specified by general register R<sub>2</sub>)
- Privileged operation

**MODIFY STACKED STATE**

<table>
<thead>
<tr>
<th>MSTA</th>
<th>R&lt;sub&gt;1&lt;/sub&gt;</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B247'</td>
<td>0 16 24 28 31</td>
<td>R&lt;sub&gt;1&lt;/sub&gt;</td>
</tr>
</tbody>
</table>

The contents of bit positions 32-63 of the pair of general registers designated by the R<sub>1</sub> field are placed in the modifiable area, byte positions 152-159, of the last state entry in the linkage stack.

The R<sub>1</sub> field designates the even-numbered register of an even-odd pair of general registers.

The last state entry is located as described in “Unstacking Process” on page 5-87. The state entry remains in the linkage stack, and the linkage-stack-entry address in control register 15 remains unchanged.

Key-controlled protection does not apply to the references to the linkage stack, but low-address and DAT protection do apply.

**Special Conditions**

A specification exception is recognized when R<sub>1</sub> is odd.

The CPU must be in the primary-space mode, access-register mode, or home-space mode; otherwise, a special-operation exception is recognized.

A stack-empty, stack-specification, or stack-type exception may be recognized during the unstacking process.

The operation is suppressed on all addressing and protection exceptions.

The priority of recognition of program exceptions for the instruction is shown in Figure 10-28 on page 10-60.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
• Access (fetch and store, except for key-controlled protection, linkage-stack entry)
• Special operation
• Specification
• Stack empty
• Stack specification
• Stack type
• Transaction constraint

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.


7.B Special-operation exception due to DAT being off or the CPU being in secondary-space mode.


8.A Specification exception due to R_1 being odd.

8.B.1 Access exceptions (fetch) for entry descriptor of the current linkage-stack entry.

8.B.2 Stack-type exception due to current entry not being a state entry or header entry.

Note: Exceptions 8.B.3-8.B.7 can occur only if the current entry is a header entry.

8.B.3 Access exceptions (fetch) for second word of the header entry.

8.B.4 Stack-empty exception due to backward stack-entry validity bit in the header entry being zero.

8.B.5 Access exceptions (fetch) for entry descriptor of preceding entry, which is the entry designated by the backward stack-entry address in the current (header) entry.

8.B.6 Stack-specification exception due to preceding entry being a header entry.

8.B.7 Stack-type exception due to preceding entry not being a state entry.

8.B.8 Access exceptions (store) for the modifiable area of the state entry.

Figure 10-28. Priority of Execution: MODIFY STACKED STATE

Programming Note: The modifiable area can be obtained from the last linkage-stack state entry by means of EXTRACT STACKED STATE.

The first operand is replaced by the second operand. The first and second operands both are 4K bytes on 4K-byte boundaries. The results are indicated in the condition code. The accesses to the first-operand location or the second-operand location, but not to both locations, may be performed by using the key specified in general register 0; otherwise, the accesses to an operand location are performed by using the PSW key.

The location of the leftmost byte of the first operand and second operand is designated by the contents of general registers R_1 and R_2, respectively.

The handling of the addresses in general registers R_1 and R_2 depends on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-51 of a general register, with 12 rightmost zeros appended, are the address, and bits 0-39 and 52-63 in the register are ignored. In the 31-bit addressing mode, the contents of bit positions 33-51 of a general register, with 12 rightmost zeros appended, are the address, and bits 0-32 and 52-63 in the register are ignored. In the 64-bit addressing mode, the contents of bit positions 0-51 of a general register, with 12 rightmost zeros appended, are the address, and bits 52-63 in the register are ignored.

Bits 56-59 of general register 0 are used as the specified access key. Bit 52 of general register 0, when one, specifies that the specified access key is to be used for accessing the first operand, and bit 53 specifies the same for the second operand. A specification exception is recognized if bits 52 and 53 are both ones. Bit 54 of general register 0 is a destination-reference-intention bit, and bit 55 is a condition-code-option bit. Bits 48-51 of general register 0 must be zeros; otherwise, a specification exception is recognized. Bits 0-47 and 60-63 of general register 0 are ignored.

The contents of the registers just described are shown in Figure 10-29 on page 10-61.

When bit 52 of general register 0 is one, the fetch accesses to the second-operand location are performed by using the PSW key, and the store

MOVE PAGE

\[
\text{MVPG } R_1, R_2 \quad \text{[RRE]}
\]

The first operand is replaced by the second operand.

The first and second operands both are 4K bytes on 4K-byte boundaries. The results are indicated in the condition code. The accesses to the first-operand location or the second-operand location, but not to both locations, may be performed by using the key specified in general register 0; otherwise, the accesses to an operand location are performed by using the PSW key.

The location of the leftmost byte of the first operand and second operand is designated by the contents of general registers R_1 and R_2, respectively.

The handling of the addresses in general registers R_1 and R_2 depends on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-51 of a general register, with 12 rightmost zeros appended, are the address, and bits 0-39 and 52-63 in the register are ignored. In the 31-bit addressing mode, the contents of bit positions 33-51 of a general register, with 12 rightmost zeros appended, are the address, and bits 0-32 and 52-63 in the register are ignored. In the 64-bit addressing mode, the contents of bit positions 0-51 of a general register, with 12 rightmost zeros appended, are the address, and bits 52-63 in the register are ignored.

Bits 56-59 of general register 0 are used as the specified access key. Bit 52 of general register 0, when one, specifies that the specified access key is to be used for accessing the first operand, and bit 53 specifies the same for the second operand. A specification exception is recognized if bits 52 and 53 are both ones. Bit 54 of general register 0 is a destination-reference-intention bit, and bit 55 is a condition-code-option bit. Bits 48-51 of general register 0 must be zeros; otherwise, a specification exception is recognized. Bits 0-47 and 60-63 of general register 0 are ignored.

The contents of the registers just described are shown in Figure 10-29 on page 10-61.

When bit 52 of general register 0 is one, the fetch accesses to the second-operand location are performed by using the PSW key, and the store
accesses to the first-operand location are performed by using the key specified in general register 0. When bit 53 of general register 0 is one, the fetch accesses to the second-operand location are performed by using the key specified in general register 0, and the store accesses to the first-operand location are performed by using the PSW key. When bits 52 and 53 are both zeros, the PSW key is used for accessing both operands.

When 4K bytes have been moved, condition code 0 is set.

When a page-translation-exception condition exists, the exception is not recognized if the condition-code-option bit, bit 55 in general register 0, is one; instead, condition code 1 or 2 is set. Condition code 1 is set if a page-translation-exception condition exists for the first operand and not for the second operand. Condition code 2 is set if a page-translation-exception condition exists for the second operand, regardless of whether the condition exists for the first operand.

When an access exception can be recognized for both operands, it is unpredictable for which operand an exception is recognized. If one of the exceptions is a page-translation exception that would cause condition code 1 or 2 to be set, it is unpredictable whether the access exception for the other operand is recognized or condition code 1 or 2 is set.

When the instruction completes by setting condition codes 1 or 2, and a PER zero-address-detection condition also exists for either the first or second operand, it is unpredictable whether the zero-address-detection condition is recognized.

**Explanation:**

CCO  Condition-code-option bit.
DRI  Destination-reference-intention bit.
F When one, specified access key applies to first operand. A specification exception is recognized if F and S both are one.
Key  Specified access key.
S When one, specified access key applies to second operand. A specification exception is recognized if F and S both are one.

*Figure 10-29. Register Contents for MOVE PAGE*
The references to main storage are not necessarily single-access references and are not necessarily performed in a left-to-right direction, as observed by other CPUs and by channel programs.

Special Conditions

In the problem state, when either bit 52 or bit 53 in general register 0 is one, the operation is performed only if the access key specified in general register 0 is valid, that is, if the corresponding PSW-key-mask bit in control register 3 is one. Otherwise, a privileged-operation exception is recognized. In the supervisor state, any value for the specified access key is valid. When bits 52 and 53 are both zeros, the access key in general register 0 is not tested for validity.

In the problem state, when bits 52 and 53 in general register 0 are both ones and the access key in general register 0 is not permitted by the PSW-key mask, it is unpredictable whether a specification exception or a privileged-operation exception is recognized.

Resulting Condition Code:

0 Data moved
1 Condition-code-option bit one, page-table entry for first operand invalid, and page-table entry for second operand valid
2 Condition-code-option bit one and page-table entry for second operand invalid
3 --

Program Exceptions:

- Access (fetch, operand 2; store, operand 1)
- Privileged operation (access key specified, and selected PSW-key-mask bit is zero in the problem state)
- Specification
- Transaction constraint

Programming Notes:

1. MOVE PAGE, or a loop of MOVE PAGE instructions that moves multiple pages, may provide, on most models, better performance than a MOVE LONG instruction or a loop of MOVE (MVC) instructions that performs the same function. Whether MOVE PAGE provides better performance depends on control-program specifications and the method by which the control program handles page-translation exceptions.

2. The destination-reference-intention bit should be set to one when there is an intention to reference the first operand by means of an instruction other than MOVE PAGE. The bit may allow the control program to process a page-translation exception more efficiently.

3. The condition-code-option bit provides compatibility with the MOVE PAGE instruction of the ESA/390 move-page facility 1. The bit is for use by the MVS/ESA HSPSERV macro expansion.

4. The condition code set by the instruction normally need not be examined if the condition-code-option bit is zero or if DAT is off.

5. See the definitions of real locations 162 and 168-175 under “Assigned Storage Locations” in Chapter 3, “Storage” for a description of information stored during a program interruption due to a DAT-related translation exception recognized by MOVE PAGE.

MOVE TO PRIMARY

<table>
<thead>
<tr>
<th>MVCP</th>
<th>(D_i(R_i,B_i),D_2(B_2),R_3)</th>
<th>[SS-d]</th>
</tr>
</thead>
<tbody>
<tr>
<td>(DA')</td>
<td>(R_i)</td>
<td>(R_3)</td>
</tr>
</tbody>
</table>

MOVE TO SECONDARY

<table>
<thead>
<tr>
<th>MVCS</th>
<th>(D_i(R_i,B_i),D_2(B_2),R_3)</th>
<th>[SS-d]</th>
</tr>
</thead>
<tbody>
<tr>
<td>(DB')</td>
<td>(R_i)</td>
<td>(R_3)</td>
</tr>
</tbody>
</table>

The first operand is replaced by the second operand. One operand is in the primary address space, and the other is in the secondary address space. The accesses to the operand in the primary space are performed by using the PSW key; the accesses to the operand in the secondary space are performed by using the key specified by the third operand.

The addresses of the first and second operands are virtual, one operand address being translated by means of the primary address-space-control element and the other by means of the secondary address-space-control element. Operand-address translation is performed in the same way when the address-space-control bits in the current PSW specify either the primary-space mode or the secondary-space mode.
For MOVE TO PRIMARY, movement is to the primary space from the secondary space. The first-operand address is translated by using the primary address-space-control element, and the second-operand address is translated by using the secondary address-space-control element.

For MOVE TO SECONDARY, movement is to the secondary space from the primary space. The first-operand address is translated by using the secondary address-space-control element, and the second-operand address is translated by using the primary address-space-control element.

Bit positions 56-59 of general register R₃ are used as the secondary-space access key. Bit positions 0-55 and 60-63 of the register are ignored.

General register R₁ contains an unsigned binary integer called the true length. In the 24-bit or 31-bit addressing mode, the true length is in bit positions 32-63 of the register, and the contents of bit positions 0-31 of the register are ignored. In the 64-bit addressing mode, the true length is in bit positions 0-63 of the register.

The contents of the general registers just described are shown in Figure 10-30 on page 10-63.

The first and second operands are the same length, called the effective length. The effective length is equal to the true length or 256, whichever is less. Access exceptions for the first and second operands are recognized only for that portion of the operand within the effective length. When the effective length is zero, no access exceptions are recognized for the first and second operands, and no movement takes place.

Each storage operand is processed left to right. The storage-operand-consistency rules are the same as for MOVE (MVC), except that when the operands overlap in real storage, the use of the common real-storage locations is not necessarily recognized.

As part of the execution of the instruction, the value of the true length is used to set the condition code. If the true length is 256 or less, including zero, the true length and effective length are equal, and condition code 0 is set. If the true length is greater than 256, the effective length is 256, and condition code 3 is set.

For both MOVE TO PRIMARY and MOVE TO SECONDARY, a serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed.

**Special Conditions**

Since the secondary space is accessed, the operation is performed only when the secondary-space control, bit 37 of control register 0, is one and DAT is on. When either the secondary-space control is zero or DAT is off, a special-operation exception is recognized. A special-operation exception is also recognized when the address-space-control bits in the current PSW specify the access-register or home-space mode.

In the problem state, the operation is performed only if the secondary-space access key is valid, that is, if the corresponding PSW-key-mask bit in control register 3 is one. Otherwise, a privileged-operation exception is recognized. In the supervisor state, any value for the secondary-space access key is valid.
**Resulting Condition Code:**

0  True length less than or equal to 256  
1  --  
2  --  
3  True length greater than 256

**Program Exceptions:**

- Access (fetch, primary virtual address, operand 2, MVCS; fetch, secondary virtual address, operand 2, MVCP; store, secondary virtual address, operand 1, MVCS; store, primary virtual address, operand 1, MVCP)
- Privileged operation (selected PSW-key-mask bit is zero in the problem state)
- Special operation
- Transaction constraint

The priority of the recognition of exceptions and condition codes is shown in Figure 10-31.

1. Exceptions with the same priority as the priority of program-interruption conditions for the general case.
2. Access exceptions for second and third instruction halfwords.
3. Special-operation exception due to the secondary-space control, bit 37 of control register 0, being zero, to DAT being off, or to the CPU being in the access-register or home-space mode.
4. Transaction constraint.
5. Privileged-operation exception due to selected PSW-key-mask bit being zero in the problem state.
6. Completion due to length zero.

**Programming Notes:**

1. MOVE TO PRIMARY and MOVE TO SECONDARY can be used in a loop to move a variable number of bytes of any length. See the programming note under MOVE WITH KEY.

2. MOVE TO PRIMARY and MOVE TO SECONDARY should be used only when movement is between different address spaces. The performance of these instructions on most models may be significantly slower than that of MOVE WITH KEY, MOVE (MVC), or MOVE LONG. In addition, the definition of overlapping operands for MOVE TO PRIMARY and MOVE TO SECONDARY is not compatible with the more precise definitions for MOVE (MVC), MOVE WITH KEY, and MOVE LONG.

**MOVE WITH DESTINATION KEY**

\[ \text{MVC} \quad D_1(B_1), D_2(B_2) \quad \text{[SSE]} \]

The first operand is replaced by the second operand. The accesses to the destination-operand location are performed by using the key specified in general register 1, and the accesses to the source-operand location are performed by using the PSW key.

The first and second operands are of the same length, which is specified by bits 56-63 of general register 0. Bits 0-55 of general register 0 are ignored.

Bits 56-59 of general register 1 are used as the specified access key. Bits 0-55 and 60-63 of general register 1 are ignored.

The contents of general registers 0 and 1 are shown in Figure 10-32.

**Figure 10-31. Priority of Execution: MOVE TO PRIMARY and MOVE TO SECONDARY**

1. L specifies the number of bytes to the right of the first byte of each operand. Therefore, the length in bytes of each operand is 1-256, corresponding to a length code in L of 0-255.

**Figure 10-32. Register Contents of MOVE WITH DESTINATION KEY**
The fetch accesses to the second-operand location are performed by using the PSW key, and the store accesses to the first-operand location are performed by using the key specified in general register 1.

Each of the operands is processed left to right. When the operands overlap destructively in real storage, the results in the first-operand location are unpredictable. Except for this unpredictability in the case of destructive overlap, the storage-operand-consistency rules are the same as for the MOVE (MVC) instruction.

**Special Conditions**

In the problem state, the operation is performed only if the access key specified in general register 1 is valid, that is, if the corresponding PSW-key-mask bit in control register 3 is one. Otherwise, a privileged-operation exception is recognized. In the supervisor state, any value for the specified access key is valid.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2; store, operand 1)
- Privileged operation (selected PSW-key-mask bit is zero in the problem state)
- Transaction constraint

**Programming Note:** See the programming notes for the MOVE WITH SOURCE KEY instruction.

**MOVE WITH KEY**

```
MVCK D1(R1,B1),D2(B2),R3 [SS-d]
```

The first operand is replaced by the second operand. The fetch accesses to the second-operand location are performed by using the key specified in the third operand, and the store accesses to the first-operand location are performed by using the PSW key.

Bit positions 56-59 of general register R3 are used as the source access key. Bit positions 0-55 and 60-63 of the register are ignored.

General register R1 contains an unsigned binary integer called the true length. In the 24-bit or 31-bit addressing mode, the true length is in bit positions 32-63 of the register, and the contents of bit positions 0-31 of the register are ignored. In the 64-bit addressing mode, the true length is in bit positions 0-63 of the register.

The contents of the general registers just described are shown in Figure 10-33.

```
<table>
<thead>
<tr>
<th>0 8 12 16 20 32 36 47</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘D9’ R1 R3 B1 D1 B2 D2</td>
</tr>
</tbody>
</table>
```

The first and second operands are of the same length, called the effective length. The effective length is equal to the true length or 256, whichever is less. Access exceptions for the first and second operands are recognized only for that portion of the operand within the effective length. When the effective length is zero, no access exceptions are recognized for the first and second operands, and no movement takes place.

Figure 10-33. Register Contents of MOVE WITH KEY

Each storage operand is processed left to right. When the storage operands overlap, the result is obtained as if the operands were processed one byte at a time and each result byte were stored immediately after the necessary operand byte was fetched. The storage-operand-consistency rules are the same as for the MOVE (MVC) instruction.
As part of the execution of the instruction, the value of the true length is used to set the condition code. If the true length is 256 or less, including zero, the true length and effective length are equal, and condition code 0 is set. If the true length is greater than 256, the effective length is 256, and condition code 3 is set.

Special Conditions

In the problem state, the operation is performed only if the source access key is valid, that is, if the corresponding PSW-key-mask bit in control register 3 is one. Otherwise, a privileged-operation exception is recognized. In the supervisor state, any value for the source access key is valid.

Resulting Condition Code:

<p>| | | | | | | | | | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
</table>
| 0 | True length less than or equal to 256
| 1 | --
| 2 | --
| 3 | True length greater than 256

Program Exceptions:

- Access (fetch, operand 2; store, operand 1)
- Privileged operation (selected PSW-key-mask bit is zero in the problem state)
- Transaction constraint

The priority of the recognition of exceptions and condition codes is shown in Figure 10-34.

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.
7.A Access exceptions for second and third instruction halfwords.
8. Privileged-operation exception due to selected PSW-key-mask bit being zero in the problem state.
9. Completion due to length zero.
10. Access exceptions for operands.

Figure 10-34. Priority of Execution: MOVE WITH KEY

Programming Notes:

1. MOVE WITH KEY can be used in a loop to move a variable number of bytes of any length, as follows:

   LOOP   MVCK   D1(R1,B1),D2(B2),R3
   BC     8,END
   AHI   B1,256
   AHI   B2,256
   AHI   R1,-256
   B   LOOP
   END   [Any instruction]

   The above program is for execution in the 24-bit or 31-bit addressing mode. In the 64-bit addressing mode, AGHI instructions should be substituted for the AHI instructions.

   2. The performance of MOVE WITH KEY on most models may be significantly slower than that of the MOVE (MVC) and MOVE LONG instructions. Therefore, MOVE WITH KEY should not be used if the keys of the source and the target are the same.

MOVE WITH OPTIONAL SPECIFICATIONS

<table>
<thead>
<tr>
<th>MVCOS</th>
<th>D1(B1),D2(B2),R3</th>
</tr>
</thead>
<tbody>
<tr>
<td>[SSF]</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>'C8'</th>
<th>R3</th>
<th>'0'</th>
<th>B1</th>
<th>D1</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>36</td>
</tr>
</tbody>
</table>

The first operand is replaced by the second operand. Bits in general register 0 determine the address-space-control modes and protection keys that are used to access the first and second operands.

The addresses of the first and second operands are virtual.

Bits 32-47 of general register 0 contain the operand-access control for the first operand (OAC1), and bits 48-63 of general register 0 contain the operand-access control for the second operand (OAC2). The operand-access control has the following format.

<table>
<thead>
<tr>
<th>Key</th>
<th>/</th>
<th>/</th>
<th>/</th>
<th>AS</th>
<th>/</th>
<th>/</th>
<th>/</th>
<th>KA</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>4</td>
<td>8</td>
<td>10</td>
<td>14</td>
<td>15</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Specified-Access Key (Key): Bits positions 0-3 contain the specified-access key that is used to
access the operand if the specified-access-key validity bit (K) is one; otherwise, the specified-access key is ignored.

**Specified-Address-Space Control (AS):** Bit positions 8-9 contain the address-space control that is used to access the operand when the specified-address-space-control validity bit (A) is one; otherwise, the specified-address-space control is ignored. The meaning of bits 8-9 is identical to that of the address-space control in bits 16-17 of the PSW.

**Specified-Access-Key Validity Bit (K):** Bit 14 controls whether the PSW key or the specified-access key is used to access the operand. When the K bit is zero, the PSW key is used. When the K bit is one, the specified-access key is used.

**Specified-Address-Space-Control Validity Bit (A):** Bit 15 controls whether the address-space control in the current PSW or the address-space control in the specified-ASC is used to access the operand. When the A bit is zero, the address-space control in the current PSW is used. When the A bit is one, the specified-address-space control is used.

Bits 0-31 of general register 0 are ignored. Bits 4-7 and 10-14 of both operand-access controls (that is, bits 36-39, 42-45, 52-55, and 58-61 of general register 0) are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.

General register R₃ contains an unsigned binary integer called the true length. In the 24-bit or 31-bit addressing mode, the true length is in bit positions 32-63 of the register, and the contents of bit positions 0-31 of the register are ignored. In the 64-bit addressing mode, the true length is in bit positions 0-63 of the register.

The contents of the general registers just described are shown in Figure 10-35.

The first and second operands are the same length, called the effective length. The effective length is equal to the true length or 4,096, whichever is less. Access exceptions for the first and second operands are recognized only for that portion of the operand within the effective length. When the effective length is zero, no access exceptions are recognized for the first and second operands, and no movement takes place.

As part of the execution of the instruction, the value of the true length is used to set the condition code. If the true length is 4,096 or less, including zero, then the true length and effective length are equal, and condition code 0 is set. If the true length is greater than 4,096, then the effective length is 4,096, and condition code 3 is set.

No test is made for destructive overlap, and the results in the first-operand location are unpredictable when destructive overlap exists. Operands are said to overlap destructively when the first-operand real location is used as a source after data has been moved into it.

Operands do not overlap destructively if the leftmost byte of the first operand does not coincide with any of the second-operand bytes participating in the operation other than the leftmost byte of the second operand. When an operand wraps around from location $2^{24} - 1$ (or $2^{31} - 1$ or $2^{64} - 1$) to location 0, operand bytes in locations up to and including $2^{24} - 1$ (or $2^{31} - 1$ or $2^{64} - 1$) are considered to be to the left of bytes in locations from 0 up.
In the 24-bit addressing mode, wraparound is from location $2^{24} - 1$ to location 0; in the 31-bit addressing mode, wraparound is from location $2^{31} - 1$ to location 0; and, in the 64-bit addressing mode, wraparound is from location $2^{64} - 1$ to location 0.

**Special Conditions**

A special-operation exception is recognized for any of the following conditions:

- DAT is off.
- The address-space control in OAC1 designates the home-space mode, the address-space-control validity bit in OAC1 is one, and the current PSW is in the problem state (that is, bits 40-41 of general register 0 are 11 binary, bit 47 of the register is one, and bit 15 of the current PSW is one).
- The secondary-space control, bit 37 of control register 0, is zero, and either of the following is true:
  - The A bit of the OAC for either operand is zero, and bits 16-17 of the current PSW are 10 binary.
  - The A bit of the OAC for either operand is one, and the AS bits in the same OAC are 10 binary.

The secondary-space control is not examined for an operand that is accessed in the secondary-space mode as a result of access-register translation (that is, DAT is on, bits 16-17 of the current PSW are 01 binary, and the access register corresponding to the operand’s base register contains an ALET of 00000001 hex).

When MOVE WITH OPTIONAL SPECIFICATIONS is executed in the problem state, and either the first or second operand’s specified-access key (from GR0) or the implied-access key (from the PSW) is invalid, a privileged-operation exception is recognized. The validity of an access key is determined as follows:

- The specified-access key in OAC1 is invalid if the specified-access-key control, bit 46 of general register 0, is one; and the specified-access key, bits 32-35 of the register, designates a PSW-key-mask (PKM) bit position that contains zero.
- The implied-access key is invalid if both of the following conditions are true:
  - Either or both bits 46 and 62 of general register 0 are zero.
  - The PSW key, bits 8-11 of the PSW, designates a PKM bit position that contains zero.

In the supervisor state, any value for the implied- or specified-access key is valid.

**Resulting Condition Code:**

| 0 | True length less than or equal to 4,096 |
| 1 | -- |
| 2 | -- |
| 3 | True length greater than 4,096 |

**Program Exceptions:**

- Access (fetch, second operand; store first operand)
- Operation (MVCOS not installed)
- Privileged operation (selected PSW-key-mask bit is zero in the problem state)
- Special operation
- Transaction constraint

The priority of the recognition of exceptions and condition codes is shown in Figure 10-36.
Programming Notes:

1. MOVE WITH OPTIONAL SPECIFICATIONS can be used in a loop to move a variable number of bytes of any length.

2. An example of moving 16 K-bytes to the home address space from the secondary address space is shown below. The first operand is accessed using the PSW key, and the second operand is accessed using key 5.

   In the 64-bit addressing mode, AGHI instructions should be substituted for the AHI instructions.

3. The performance of MOVE WITH OPTIONAL SPECIFICATIONS may be significantly slower than that of individual MOVE (MVC) instructions.

4. When bits 46-47 and 62-63 of general register 0 are all zero, MOVE WITH OPTIONAL SPECIFICATIONS uses the key and address-space control in the current PSW to access both the first and second operands.

5. In the MVCDK, MVCK, MVCP, MVCS, and MVCSK instructions, one operand is accessed using an implied key from the PSW, and the other operand is accessed using a specified key in a register. In the problem state, only the specified key is checked for validity in the PSW-key mask (PKM).

   When MVCOS is executed in the problem state, the access keys for the first and second operands are both checked for validity in the PKM, regardless of whether the keys are implied or specified.

### MOVE WITH SOURCE KEY

\[
\text{MVCSK } D_1(B_1), D_2(B_2) \quad [\text{SSE}]
\]

The first operand is replaced by the second operand. The accesses to the source-operand location are performed by using the key specified in general register 1, and the accesses to the destination-operand location are performed by using the PSW key.

The first and second operands are of the same length, which is specified by bits 56-63 of general register 0. Bits 0-55 of general register 0 are ignored.

Bits 56-59 of general register 1 are used as the specified access key. Bits 0-55 and 60-63 of general register 1 are ignored.

The contents of general registers 0 and 1 are shown in Figure 10-37.

![Figure 10-37. Register Contents of MOVE WITH SOURCE KEY](image-url)

L specifies the number of bytes to the right of the first byte of each operand. Therefore, the length in bytes of each operand is 1-256, corresponding to a length code in L of 0-255.

The fetch accesses to the second-operand location are performed by using the key specified in general register 1, and the store accesses to the first-operand location are performed by using the PSW key.

Each of the operands is processed left to right. When the operands overlap destructively in real storage, the results in the first-operand location are unpredictable. Except for this unpredictability in the case of destructive overlap, the storage-operand-consistency rules are the same as for the MOVE (MVC) instruction.

### Special Conditions
In the problem state, the operation is performed only if the access key specified in general register 1 is valid, that is, if the corresponding PSW-key-mask bit in control register 3 is one. Otherwise, a privileged-operation exception is recognized. In the supervisor state, any value for the specified access key is valid.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2; store, operand 1)
- Privileged operation (selected PSW-key-mask bit is zero in the problem state)
- Transaction constraint

**Programming Notes:**
1. When data is to be moved alternately in both directions between two storage areas that are fetch protected by means of different keys, then MOVE WITH SOURCE KEY and MOVE WITH DESTINATION KEY can be used while leaving the PSW key unchanged; and this may be, on most models, significantly faster than using MOVE WITH KEY along with SET PSW KEY FROM ADDRESS to change the PSW key.
2. MOVE WITH SOURCE KEY and MOVE WITH DESTINATION KEY should be used only when movement is between storage areas having different keys. The performance of these instructions on most models may be significantly slower than that of the MOVE (MVC) instruction.
3. MOVE WITH SOURCE KEY or MOVE WITH DESTINATION KEY can be used in a loop to move a variable number of bytes as shown in the following example. In the example, the specified access key, the first-operand address, the second-operand address, and the length of each operand are assumed to be in general registers 1-4, respectively, at the beginning of the example. The length of each operand is treated as a 32-bit signed value, and a negative value is treated as zero.

```
LTR 4,4
BC 12.END
AH 4,-256
BC 12.LAST
LA 0,255

LOOP MVCSK 0(2),0(3)
LA 2,256(2)
LA 3,256(3)
AH 4,-256
BC 2.Loop

LAST LA 0,255(4)
MVCSK 0(2),0(3)
END [Any instruction]
```

A page-in operation is performed which transfers a 4K-byte block to the real-storage location designated by general register $R_1$ from the expanded-storage block designated by general register $R_2$.

Bits 32-63 of general register $R_2$ are a 32-bit unsigned binary integer called the expanded-storage-block number. This number designates the 4K-byte block of expanded storage which is to be transferred. If the expanded-storage-block number designates an inaccessible block in expanded storage, condition code 3 is set.

The contents of general register $R_1$ are a real address which designates a 4K-byte block in main storage. In the 24-bit-addressing mode, bits 40-51 designate the block, and bits 0-39 are ignored. In the 31-bit-addressing mode, bits 33-51 designate the block, and bits 0-32 are ignored. In the 64-bit-addressing mode, bits 0-51 designate the block. In all modes, bits 52-63 of the address are ignored.

Because it is a real address, the address designating the main-storage block is not subject to dynamic address translation. PAGE IN is not subject to key-controlled storage protection, but low-address protection does apply. PAGE IN is not subject to program-event recording for storage alteration.
A serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed.

If the page-in operation is completed with no errors, condition code 0 is set.

If the page-in operation encounters an expanded-storage data error, condition code 1 is set. For an expanded-storage data-error condition, the contents of the entire 4K-byte block in real storage is unpredictable, but this condition does not result in the generation of invalid checking-block codes in real storage.

If the expanded-storage block is not available, that is, the block is not provided or is not currently in the configuration, then condition code 3 is set, and no other action is taken.

Operation of PAGE IN in a Multiple-CPU Configuration

The accesses to main storage and to expanded storage by PAGE IN are not necessarily single-access references and are not necessarily performed in a left-to-right direction, as observed by other CPUs and by channel programs.

See also the description under PAGE OUT.

Resulting Condition Code:

0 Page-in operation completed
1 Expanded-storage data error
2 --
3 Expanded-storage block not available

Program Exceptions:

- Addressing (block designated by general register \( R_i \))
- Operation (if the expanded-storage facility is not installed)
- Privileged operation
- Protection (block designated by general register \( R_i \); low-address protection)
- Transaction constraint

PAGE OUT

\[
\text{PGOUT} \quad R_1, R_2 \quad [\text{RRE}]
\]

A page-out operation is performed which transfers a 4K-byte block from the real-storage location designated by general register \( R_1 \) to the expanded-storage block designated by general register \( R_2 \).

Bits 32-63 of general register \( R_2 \) are a 32-bit unsigned binary integer called the expanded-storage-block number. This number designates the 4K-byte block of expanded storage which is to be replaced. If the expanded-storage-block number designates an inaccessible block in expanded storage, condition code 3 is set.

The contents of general register \( R_1 \) are a real address which designates a 4K-byte block in main storage. In the 24-bit-addressing mode, bits 40-51 designate the block, and bits 0-39 are ignored. In the 31-bit-addressing mode, bits 33-51 designate the block, and bits 0-32 is ignored. In the 64-bit-addressing mode, bits 0-51 designate the block. In all modes, bits 52-63 of the address are ignored.

Because it is a real address, the address designating the main-storage block is not subject to dynamic address translation. PAGE OUT is not subject to key-controlled protection.

A serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed.

Depending on the model, after the data has been written to the expanded-storage block, a read-back-check operation may be performed to determine whether the data was written correctly. If the read-back-check operation determines that the data has been written correctly, condition code 0 is set. If the read-back-check operation encounters an expanded-storage data error, condition code 1 is set.

Most models do not perform the read-back-check operation, and, after the page-out operation is completed, condition code 0 is set.

Regardless of whether condition code 0 or condition code 1 is set, the entire 4K-byte block is written. Errors, if any, in the block after the block is written are
preserved. Thus, if a subsequent execution of PAGE IN addresses the same expanded-storage block, the expanded-storage data error will be detected and condition code 1 will be indicated.

If the expanded-storage block is not available, that is, the block is not provided or is not currently in the configuration, then condition code 3 is set, and no other action is taken.

**Operation of PAGE OUT in a Multiple-CPU Configuration**

The accesses to main storage and to expanded storage by PAGE OUT are not necessarily single-access references and are not necessarily performed in a left-to-right direction, as observed by other CPUs and by channel programs.

If two or more CPUs issue PAGE IN or PAGE OUT instructions at approximately the same instant in time, depending on the model, the operations may be performed one at a time, or the operations may be performed concurrently. Concurrent operation may occur even if the instructions address the same expanded-storage block.

When two or more PAGE OUT instructions addressing the same expanded-storage block are executed concurrently, the resulting values in the expanded-storage block for each group of bytes transferred may be from any of the instructions being executed simultaneously. The number of bytes transferred as a group depends on the model.

Similarly, for concurrent execution of a PAGE IN and a PAGE OUT instruction for the same expanded-storage block, the resulting values for each group of bytes transferred as a result of the execution of the PAGE IN instruction may be either the old or new values from the expanded-storage block.

Concurrent operation of paging instructions does not result in expanded-storage data errors.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Page-out operation completed</td>
</tr>
<tr>
<td>1</td>
<td>Expanded-storage data error</td>
</tr>
<tr>
<td>2</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Expanded-storage block not available</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Addressing (block designated by general register R)
- Operation (if the expanded-storage facility is not installed)
- Privileged operation
- Transaction constraint

### PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION

**PCKMO [RRE]**

A function specified by the function code in general register 0 is performed.

Bits 16-31 of the instruction are ignored.

Bit positions 57-63 of general register 0 contain the function code. Figure 10-38 on page 10-73 shows the assigned function codes. All other function codes are unassigned. Bit 56 of general register 0 must be zero; otherwise, a specification exception is recognized. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.
The function codes for PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION are as follows.

<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Data Block Size (bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>PCKMO-Query</td>
<td>16</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>PCKMO-Encrypt-DEA-Key</td>
<td>32</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>PCKMO-Encrypt-TDEA-128-Key</td>
<td>40</td>
<td>8</td>
</tr>
<tr>
<td>3</td>
<td>PCKMO-Encrypt-TDEA-192-Key</td>
<td>48</td>
<td>8</td>
</tr>
<tr>
<td>18</td>
<td>PCKMO-Encrypt-AES-128-Key</td>
<td>48</td>
<td>16</td>
</tr>
<tr>
<td>19</td>
<td>PCKMO-Encrypt-AES-192-Key</td>
<td>56</td>
<td>16</td>
</tr>
<tr>
<td>20</td>
<td>PCKMO-Encrypt-AES-256-Key</td>
<td>64</td>
<td>16</td>
</tr>
</tbody>
</table>

Explanation:

— Not applicable

All other function codes are unassigned.

The query function provides the means of indicating the availability of the other functions.

Figure 10-39 on page 10-73 shows the contents of general registers 0 and 1.

In the access-register mode, access register 1 specifies the address space containing the parameter block.

As observed by other CPUs and channel programs, reference to the parameter block may be multiple-access references, accesses to these storage locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

PCKMO-Query (Function Code 0)
The locations of the operands and addresses used by the instruction are as shown in Figure 10-39 on page 10-73.

The parameter block used for the function has the following format:

![Figure 10-40. Parameter Block for PCKMO-Query](image-url)
A 128-bit status word is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the PCKMO instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed.

**PCKMO-Encrypt-DEA-Key (Function Code 1)**

The locations of the operands and addresses used by the instruction are as shown in Figure 10-39 on page 10-73.

The parameter block used for the function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-7</td>
<td>Cryptographic Key (K)</td>
</tr>
<tr>
<td>8-15</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
<tr>
<td>16-23</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
<tr>
<td>24-31</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>
```

*Figure 10-41. Parameter Block for PCKMO-Encrypt-DEA-Key*

The 8-byte cryptographic key, K, in byte offsets 0-7 of the parameter block is encrypted using the DEA wrapping key. (See the section “Protection of Cryptographic Keys” on page 7-374 for the encryption algorithm.) The result is placed back in byte offsets 0-7 of the parameter block. The contents of the DEA wrapping-key verification-pattern register are placed in byte offsets 8-31 of the parameter block.

**PCKMO-Encrypt-TDEA-128-Key (Function Code 2)**

The locations of the operands and addresses used by the instruction are as shown in Figure 10-39 on page 10-73.

The parameter block used for the function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-15</td>
<td>Cryptographic Key (K)</td>
</tr>
<tr>
<td>16-31</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
<tr>
<td>32-47</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>
```

*Figure 10-42. Parameter Block for PCKMO-Encrypt-TDEA-128-Key*

The 16-byte cryptographic key, K, in byte offsets 0-15 of the parameter block is encrypted using the DEA wrapping key. (See the section “Protection of Cryptographic Keys” on page 7-374 for the encryption algorithm.) The result is placed back in byte offsets 0-15 of the parameter block. The contents of the DEA wrapping-key verification-pattern register are placed in byte offsets 16-31 of the parameter block.

**PCKMO-Encrypt-TDEA-192-Key (Function Code 3)**

The locations of the operands and addresses used by the instruction are as shown in Figure 10-39 on page 10-73.

The parameter block used for the function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-23</td>
<td>Cryptographic Key (K)</td>
</tr>
<tr>
<td>24-47</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
<tr>
<td>48-63</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>
```

*Figure 10-43. Parameter Block for PCKMO-Encrypt-TDEA-192-Key*

The 24-byte cryptographic key, K, in byte offsets 0-23 of the parameter block is encrypted using the DEA wrapping key. (See the section “Protection of Cryptographic Keys” on page 7-374 for the encryption algorithm.) The result is placed back in byte offsets 0-23 of the parameter block. The contents of the DEA wrapping-key verification-pattern register are placed in byte offsets 24-47 of the parameter block.

**PCKMO-Encrypt-AES-128-Key (Function Code 18)**

The locations of the operands and addresses used by the instruction are as shown in Figure 10-39 on page 10-73.

The parameter block used for the function has the following format:

```
<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-15</td>
<td>Cryptographic Key (K)</td>
</tr>
<tr>
<td>16-31</td>
<td>DEA Wrapping-Key Verification Pattern (WKdVP)</td>
</tr>
</tbody>
</table>
```

*Figure 10-44. Parameter Block for PCKMO-Encrypt-AES-128-Key*
The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cryptographic Key (K)</td>
<td>AES Wrapping-Key Verification Pattern (WK_aVP)</td>
<td></td>
</tr>
</tbody>
</table>

Figure 10-44. Parameter Block for PCKMO-Encrypt-AES-128-Key

The 16-byte cryptographic key, K, in byte offsets 0-15 of the parameter block is encrypted using the AES wrapping key. (See the section “Protection of Cryptographic Keys” on page 7-374 for the encryption algorithm.) The result is placed back in byte offsets 0-15 of the parameter block. The contents of the AES wrapping-key verification-pattern register are placed in byte offsets 16-47 of the parameter block.

**PCKMO-Encrypt-AES-192-Key (Function Code 19)**

The locations of the operands and addresses used by the instruction are as shown in Figure 10-39 on page 10-73.

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>16</th>
<th>24</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cryptographic Key (K)</td>
<td>AES Wrapping-Key Verification Pattern (WK_aVP)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 10-45. Parameter Block for PCKMO-Encrypt-AES-192-Key

The 24-byte cryptographic key, K, in byte offsets 0-23 of the parameter block is encrypted using the AES wrapping key. (See the section “Protection of Cryptographic Keys” on page 7-374 for the encryption algorithm.) The result is placed back in byte offsets 0-23 of the parameter block. The contents of the AES wrapping-key verification-pattern register are placed in byte offsets 24-55 of the parameter block.

**PCKMO-Encrypt-AES-256-Key (Function Code 20)**

The locations of the operands and addresses used by the instruction are as shown in Figure 10-39 on page 10-73.

The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>0</th>
<th>8</th>
<th>16</th>
<th>24</th>
<th>32</th>
<th>56</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cryptographic Key (K)</td>
<td>AES Wrapping-Key Verification Pattern (WK_aVP)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 10-46. Parameter Block for PCKMO-Encrypt-AES-256-Key

The 32-byte cryptographic key, K, in byte offsets 0-31 of the parameter block is encrypted using the AES wrapping key. (See the section “Protection of Cryptographic Keys” on page 7-374 for the encryption algorithm.) The result is placed back in byte offsets 0-31 of the parameter block. The contents of the AES wrapping-key verification-pattern register are placed in byte offsets 32-63 of the parameter block.

**Special Conditions**

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, parameter block; store, parameter block)
- Operation (if the message-security-assist-extension-3 facility is not installed)
- Privileged operation
- Specification
- Transaction constraint
**Programming Note:** Each set of PCKMO-Encrypt-DEA-Key functions and PCKMO-Encrypt-AES-Key functions can be independently disabled by an external means. When a set is disabled, functions in the set appear as if they were not installed.

**PERFORM FRAME MANAGEMENT FUNCTION**

```
PFMF R1,R2 [RRE]
```

Subject to the controls in the first-operand register, a frame-management function is performed for the storage frame designated by the second-operand address.

The contents of general register R1 are as follows:

**Frame-management function indications:** Bit positions 44-47 of general register R1 contain the frame-management function indications (FMFI), as follows:

- **Reserved:** Bits 44 and 45 are reserved and must contain zeros; otherwise, a specification exception is recognized.
- **Set-Key Control (SK):** Bit 46 controls whether the storage key for each 4K-byte block in the frame is set from bits 56-62 of general register R1. When the SK control is zero, the keys are not set; when the SK control is one, the keys are set.
- **Clear-Frame Control (CF):** Bit 47 controls whether the frame is set to zeros. When the CF control is zero, no clearing operation is performed. When the CF control is one, the frame is cleared to zeros.
- **Usage Indication (UI):** Bit position 48 of general register R1 contains the usage indication (UI). When bit 48 is zero, it indicates that the program does not anticipate immediate usage of the frame. When bit 48 is one, it indicates that program anticipates usage of the frame in the near future.

**Frame-Size Code (FSC):** Bits 49-51 of general register R1 contain the frame-size code (FSC), as follows:

<table>
<thead>
<tr>
<th>FSC</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>4K-byte frame</td>
</tr>
<tr>
<td>1</td>
<td>1M-byte frame</td>
</tr>
<tr>
<td>2</td>
<td>2 G-byte frame</td>
</tr>
<tr>
<td>3-7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Reference-Bit Update Mask (MR):** When the set-key control, bit 46 of general register R1, is one, bit 53 of general register R1 controls whether updates to the reference bit in the storage key may be bypassed, as described below. When the set-key control is zero, bit 53 of general register R1 is ignored.

**Change-Bit Update Mask (MC):** When the set-key control, bit 46 of general register R1, is one, bit 54 of general register R1 controls whether updates to the change bit in the storage key may be bypassed. When the set-key control is zero, bit 54 of general register R1 is ignored.

The handling of the MR and MC bits is identical to the handling of the corresponding bits of the M3 field of the SET STORAGE KEY EXTENDED instruction (described on page 10-126), except that general register R1 is not updated with the contents of the previous key, and the condition code is not changed.

**Key:** When the set-key control, bit 46 of general register R1, is one, bits 56-62 of the register contain the storage key to be set for each 4K-byte block in the frame, with the access-protection bits, fetch-protection bit, reference bit, and change bit in bit positions 56-59, 60, 61, and 62, respectively. When the set-key control is zero, bits 56-62 of general register R1 are ignored.

Bit positions 32-45, 55, and 63 of general register R1 are reserved and must contain zeros. When the nonquiescing key-setting facility is not installed, bit position 52 of general register R1 is also reserved and must contain zeros. If any reserved bit position in general register R1 does not contain zeros, a specification exception is recognized. When the nonquiescing key-setting facility is installed, bit position 52 of general register R1 is ignored.

General register R2 contains the real or absolute address of the storage frame upon which the frame-
management function is to be performed. When the frame-size code designates a 4K-byte block, the second-operand address is real; when the frame-size code designates a 1M-byte or 2 G-byte block the second-operand address is absolute. The handling of the address in general register $R_2$ depends on the addressing mode. In the 24-bit addressing mode, the contents of bit positions 40-51 of the register, with 12 rightmost zeros appended, are the address, and bits 0-39 and 52-63 in the register are ignored. In the 31-bit addressing mode, the contents of bit positions 33-51 of the register, with 12 rightmost zeros appended, are the address, and bits 0-32 and 52-63 in the register are ignored. In the 64-bit addressing mode, the contents of bit positions 0-51 of the register, with 12 rightmost zeros appended, are the address, and bits 52-63 in the register are ignored.

The contents of the registers just described are shown in Figure 10-47.

![Figure 10-47. Register Contents for PERFORM FRAME-MANAGEMENT FUNCTION](image)

Explanation:

- **ACC**: Access-protection bits of the storage key
- **C**: Change bit of the storage key
- **CF**: Clear-frame control
- **F**: Fetch-protection bit of the storage key
- **FMFI**: Frame-management function indication
- **FSC**: Frame-size code
- **MC**: Change-bit-update mask
- **MR**: Reference-bit-update mask
- **R**: Reference bit of the storage key
- **SK**: Set-key control
- **UI**: Usage indication

When the frame-size code is 0, the specified frame-management functions are performed for the 4K-byte frame specified by the second operand. General register $R_2$ is unmodified in this case.

When the frame-size code is 1, the specified frame-management functions are performed for one or more 4 K-byte blocks within the 1M-byte frame, beginning with the block specified by the second-operand address, and continuing to the right with each successive block up to the next 1M-byte boundary.

When the enhanced-DAT facility 2 is installed and the frame-size code is 2, the specified frame-management functions are performed for one or more 4 K-byte blocks within the 2 G-byte frame, beginning with the block specified by the second-operand address, and continuing to the right with each successive block up to the next 2 G-byte boundary. When the enhanced-DAT facility 2 is not installed, a frame-size code of 2 is reserved.

PERFORM FRAME MANAGEMENT FUNCTION is interruptible. When the frame-size code is 1 or 2, an
PERFORM FRAME MANAGEMENT FUNCTION

When the clear-frame and set-key controls are one, an interruption may also occur between the clearing and key-setting operations for an individual 4 K-byte block.

When the frame-size code is 1 or 2, processing is as follows:

- When both the clear-frame and set-key functions are specified, both functions are completed for a 4 K-byte block before proceeding to the next block.
- When an interruption occurs (other than one that follows termination), the second-operand address in general register R₃ is updated by the number of 4K-byte blocks completely processed, so the instruction, when reexecuted, resumes at the point of interruption.
- When the instruction completes without interruption, the second-operand address in general register R₂ is updated to the next 1M-byte boundary (FSC=1) or 2 G-byte boundary (FSC=2).

When the CPU is in the 24-bit addressing mode and the frame-size code is 1, bits positions 32-39 of general register R₁ are set to zeros and bits 0-31 of the register are unchanged. When the CPU is in the 24-bit addressing mode and the frame-size code is 2, a specification exception is recognized.

When the CPU is in the 31-bit addressing mode, and the frame-size code is either 1 or 2, bit position 32 of general register R₂ is set to zero and bits 0-31 of general register R₂ are unchanged.

When the clear-frame control is one, references to main storage within the second operand may be multiple-access references and are not necessarily performed in a left-to-right direction as observed by other CPUs and by channel programs. The clear operation is not subject to key-controlled protection; however, low-address protection applies regardless of whether the frame-size code designates a 4 K-byte, 1 M-byte, or 2 G-byte frame (that is, regardless of whether the second-operand address is real or absolute, respectively).

When the set-key control is one, the operation for each 4K-byte block is similar to that described in “SET STORAGE KEY EXTENDED” on page 10-126, except that when the keys for multiple blocks are set, the condition code and the contents of general register R₁ are unchanged.

A serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed, except that when the seven bits of all storage keys to be set are the same as bits 56-62 of general register R₁, or when the MR and MC bits allow all the storage keys to remain unchanged, it is unpredictable whether the serialization and checkpoint-synchronization functions are performed after the operation completes. See “SET STORAGE KEY EXTENDED” on page 10-126 for details on the cases where setting of the key may be bypassed.

When the set-key control is one, and the nonquiescing key-setting facility is not installed, a quiescing operation is performed. When the set-key control is one, and the nonquiescing key-setting facility is installed, a quiescing operation is not necessarily performed. See “Storage-Key Accesses” on page 5-118 for a discussion of the effects of quiescing on key-setting instructions, and see “Quiescing” on page 5-131 for details on the quiescing operation.

Provided that there is no other access to the storage by other CPUs or the channel subsystem, the final results of the instruction reflect the specified key value, including the specified R and C values when MR and MC are zero, respectively. Subject to this constraint, it is unpredictable whether the clear-frame or the set-key operation is performed first when both of the respective controls are one. When both the clear-frame and set-key controls are one, and either the MR or MC bit is also one, and the clear operation is performed first, the storage key that is compared with bits 56-62 of general register R₁ in the set-key operation is the key following the clear operation (that is, both the R and C bits will have been set to one by the clear operation).

Before a quiescing key-setting operation is performed, transactional execution by other CPUs in the configuration is aborted with abort code 255, condition code 2. The aborting of transactional execution affects at least those CPUs accessing the locations (transactionally or nontransactionally) for which storage keys are being set. It is unpredictable whether some or all other CPUs are affected as well.

Special Conditions
A specification exception is recognized and the operation is suppressed for any of the following conditions:

- Bits 32-45, 55, or 63 of general register R1 are not zero.
- When the nonquiescing key-setting facility is not installed, bit 52 of general register R1 is not zero.
- The frame-size code specifies a reserved value.
- The CPU is in the 24-bit addressing mode and the frame-size code is 2.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, low-address-protection only, operand 2, when the clear-frame control is one)
- Addressing (operand 2)
- Operation (enhanced-DAT facility not installed)
- Privileged operation
- Specification
- Transaction constraint

**Programming Notes:**

1. When PFMF is issued with the set-key control set to one, the program must ensure that no other CPU or channel subsystem is simultaneously accessing the storage designated by general register R2. Otherwise, unpredictable results may be observed by the other CPUs and channel subsystem, including the alteration of the block designated by general register R2.

2. Access exceptions may be recognized for the second operand, even when the clear-frame and set-key controls and the usage indication are all zero.

3. See the programming note on page 5-120 for restrictions on the use of the PFMF set-key operation.

---

**PERFORM TIMING FACILITY FUNCTION**

<table>
<thead>
<tr>
<th>PTFF</th>
<th>[E]</th>
</tr>
</thead>
<tbody>
<tr>
<td>0104</td>
<td></td>
</tr>
</tbody>
</table>

A timing facility function specified by the function code in general register 0 is performed. The condition code is set to indicate the outcome of the function. General register 1 contains the address of a parameter block in storage. PTFF query functions place information in the parameter block; PTFF control functions use information obtained from the parameter block.

As observed by other CPUs and channel programs, references to the parameter block may be multiple-access references, accesses to these storage locations are not necessarily block-concurrent, and the sequence of these accesses or references is undefined.

Bit positions 57-63 of general register 0 contain the function code. Figure 10-49 on page 10-80 shows the assigned function codes. Bit 56 of general register 0 must be zero; otherwise, a specification exception is recognized. All other bits of general register 0 are ignored.

General register 1 contains the logical address of the leftmost byte of the parameter block in storage. In the 24-bit addressing mode, the contents of bit positions 40-63 of general register 1 constitute the address, and the contents of bit positions 0-39 are ignored. In the 31-bit addressing mode, the contents of bit positions 33-63 of general register 1 constitute the address, and the contents of bit positions 0-32 are ignored. In the 64-bit addressing mode, the contents of bit positions 0-63 of general register 1 constitute the address.
Figure 10-48 on page 10-80 shows the contents of the general registers just described.

```
<table>
<thead>
<tr>
<th>Code</th>
<th>Function</th>
<th>Parm. Block Size (bytes)</th>
<th>Availability</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>PTFF-QAF</td>
<td>16</td>
<td>U</td>
</tr>
<tr>
<td>01</td>
<td>PTFF-QTO</td>
<td>32</td>
<td>U</td>
</tr>
<tr>
<td>02</td>
<td>PTFF-QSI</td>
<td>56</td>
<td>U</td>
</tr>
<tr>
<td>03</td>
<td>PTFF-QPT</td>
<td>8</td>
<td>U</td>
</tr>
<tr>
<td>04</td>
<td>PTFF-QUI</td>
<td>256</td>
<td>U</td>
</tr>
<tr>
<td>05</td>
<td>PTFF-QTOU</td>
<td>40</td>
<td>U</td>
</tr>
<tr>
<td>41</td>
<td>PTFF-STO</td>
<td>8</td>
<td>P</td>
</tr>
<tr>
<td>45</td>
<td>PTFF-STOU</td>
<td>8</td>
<td>P</td>
</tr>
</tbody>
</table>
```

Explanation:

- P: Privileged: Available only in the supervisor state.
- U: Unprivileged: Available in both the problem state and the supervisor state.

Function codes for PERFORM TIMING FACILITY FUNCTION are as follows.

- All other function codes are unassigned.
- The PTFF-QAF (Query Available Functions) function provides the means of indicating the availability of the other functions.

### Function 0: PTFF-QAF (Query Available Functions)

The parameter block used for the function has the following format:

```
<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Status Bits 0-31</th>
<th>Status Bits 32-63</th>
<th>Status Bits 64-95</th>
<th>Status Bits 95-127</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>0</td>
<td>pb.w1</td>
<td>pb.w2</td>
<td>pb.w3</td>
<td>pb.w4</td>
</tr>
</tbody>
</table>
```

A 128-bit field is stored in the parameter block. Bits 0-127 of this field correspond to function codes 0-127, respectively, of the PTFF instruction. When a bit is one, the corresponding function is installed; otherwise, the function is not installed. The availability of an installed function is indicated by the condition code returned by the attempted execution of the function.
Function 1: PTFF-QTO (Query TOD Offset)
The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Description</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>0</td>
<td>Physical Clock (0:31)</td>
<td>pb.Tu</td>
</tr>
<tr>
<td>04</td>
<td>4</td>
<td>Physical Clock (32:63)</td>
<td></td>
</tr>
<tr>
<td>08</td>
<td>8</td>
<td>TOD Offset (0:31)</td>
<td>pb.d</td>
</tr>
<tr>
<td>OC</td>
<td>12</td>
<td>TOD Offset (32:63)</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>16</td>
<td>Logical TOD Offset (0:31)</td>
<td>pb.dl</td>
</tr>
<tr>
<td>14</td>
<td>20</td>
<td>Logical TOD Offset (32:63)</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>24</td>
<td>TOD Epoch Difference (0:31)</td>
<td>pb.ed</td>
</tr>
<tr>
<td>1C</td>
<td>28</td>
<td>TOD Epoch Difference (32:63)</td>
<td></td>
</tr>
</tbody>
</table>

When the STP-hardware-based-TOD-clock-steering facility is not installed, the 64-bit physical-clock value returned (pb.Tu) is the value of the physical clock at the most recent TOD-offset-update event. When the STP-hardware-based-TOD-clock-steering facility is installed, the 64-bit physical-clock value returned is the current physical clock.

The TOD offset returned is a 64-bit signed binary integer (pb.d) that indicates the value of the TOD-offset (d). This value indicates the amount of steering that has been applied (actually in the case of offset-based TOD-clock steering, or conceptually in the case of hardware-based TOD-clock steering) to the physical clock to form the system TOD clock. The TOD epoch difference is not included in this value.

The 64-bit logical-TOD-offset value returned (pb.dl) indicates the current value of the difference between the TOD clock and the physical clock. This value includes the TOD epoch difference. Depending on the TOD clock resolution capability of the model, a model dependent number of the low order bits of bits 32:63 may be set to zero by the machine.

The 64-bit TOD epoch difference value returned (pb.ed) is the TOD epoch difference (includes both the user-specified epoch difference and the sync-check offset). Depending on the TOD clock resolution capability of the model, a model dependent number of the low order bits of bits 32:63 may be set to zero by the machine.

Function 2: PTFF-QSI (Query Steering Information)
The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Description</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>0</td>
<td>Physical Clock (0:31)</td>
<td>pb.Tu</td>
</tr>
<tr>
<td>04</td>
<td>4</td>
<td>Physical Clock (32:63)</td>
<td></td>
</tr>
<tr>
<td>08</td>
<td>8</td>
<td>Old Episode Start Time (0:31)</td>
<td>pb.old.s</td>
</tr>
<tr>
<td>OC</td>
<td>12</td>
<td>Old Episode Start Time (32:63)</td>
<td>pb.old.g</td>
</tr>
<tr>
<td>10</td>
<td>16</td>
<td>Old Episode Base Offset (0:31)</td>
<td>pb.old.b</td>
</tr>
<tr>
<td>14</td>
<td>20</td>
<td>Old Episode Base Offset (32:63)</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>24</td>
<td>Old Episode Fine-Steering Rate</td>
<td>pb.old.f</td>
</tr>
<tr>
<td>1C</td>
<td>28</td>
<td>Old Episode Gross-Steering Rate</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>32</td>
<td>New Episode Start Time (0:31)</td>
<td>pb.new.s</td>
</tr>
<tr>
<td>24</td>
<td>36</td>
<td>New Episode Start Time (32:63)</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>40</td>
<td>New Episode Base Offset (0:31)</td>
<td>pb.new.b</td>
</tr>
<tr>
<td>2C</td>
<td>44</td>
<td>New Episode Base Offset (32:63)</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>48</td>
<td>New Episode Fine-Steering Rate</td>
<td>pb.new.f</td>
</tr>
<tr>
<td>34</td>
<td>52</td>
<td>New Episode Gross-Steering Rate</td>
<td></td>
</tr>
</tbody>
</table>

When the STP-hardware-based-TOD-clock-steering facility is not installed, the 64-bit physical-clock value returned (pb.Tu) is the value of the physical clock at the most recent TOD-offset-update event. When the STP-hardware-based-TOD-clock-steering facility is installed, the 64-bit physical-clock value returned is the current physical clock.

The remaining fields are the values of the old-episode and new-episode registers.

Function 3: PTFF-QPT (Query Physical Clock)
The parameter block used for the function has the following format:

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Description</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>0</td>
<td>Physical Clock (0:31)</td>
<td>pb.Tr</td>
</tr>
<tr>
<td>04</td>
<td>4</td>
<td>Physical Clock (32:63)</td>
<td></td>
</tr>
</tbody>
</table>

The 64-bit physical-clock value returned (pb.Tr) is the current value of the physical clock. Zeros are stored for the rightmost bit positions that are not provided by the physical clock. When the clock is running, two
executions of PTFF-QPT, either on the same or different CPUs, do not necessarily return different values of the clock.

Function 4: PTFF-SUI (Query UTC Information)
The parameter block used for the function has the following format:

```
Hex Dec
00 0 UTC Information Block (UIB)
```

The UIB is described in “UTC Information Block (UIB)” on page 4-51.

Function 5: PTFF-QTOU (Query TOD Offset User)
The parameter block used for the function has the following format:

```
Hex Dec
00 0 Physical Clock (0:31) pb.Tu
04 4 Physical Clock (32:63)
08 8 TOD Offset (0:31) pb.d
0C 12 TOD Offset (32:63)
10 16 Logical TOD Offset (0:31) pb.dl
14 20 Logical TOD Offset (32:63)
18 24 TOD Epoch Difference (0:31) pb.ed
1C 28 TOD Epoch Difference (32:63)
20 32 TOD User Specified Epoch Difference (0:31) pb.edu
24 36 TOD User Specified Epoch Difference (32:63)
```

The 64-bit TOD user specified epoch difference value returned is the user-specified portion of the guest epoch difference for the current level of CPU execution. It does not include the sync-check offset portion of the guest epoch difference. When executed at the basic-machine or LPAR hypervisor level, this value is zero. When executed at the guest 1 level, this value is the guest epoch difference excluding the guest 1 sync-check offset portion of the guest 1 epoch difference. When executed at the guest 2 level, this value is the guest epoch difference excluding the guest 2 sync-check offset portion of the guest 2 epoch difference.

Function 65: PTFF-STO (Set TOD Offset)
The parameter block used for the function has the following format:

```
Hex Dec
00 0 New TOD Epoch Difference (0:31) pb.d
04 4 New TOD Epoch Difference (32:63)
```

The function specifies a value that is to replace the TOD epoch difference; no new episode is scheduled and the change takes effect immediately. The function operates only on the TOD epoch difference (D); no new episode is scheduled, and the change takes place immediately. The function operates on the combined TOD-epoch difference (D = SCO + Du) and does not modify the sync-check offset. If the sync-check offset is nonzero, a subsequent sync-check-offset correction will modify the TOD epoch difference to reflect the amount of the correction. Depending on the TOD clock resolution capability of the model, a model dependent number of the low order bits of bits 32:63 may be ignored by the machine and treated as if they were zeros.

Function 69: PTFF-STOU (Set TOD Offset User)
The parameter block used for the function has the following format:

```
Hex Dec
00 0 New TOD User Specified Epoch Difference (0:31) pb.du
04 4 New TOD User Specified Epoch Difference (32:63)
```

The function specifies a value that is to replace the user-specified portion of the TOD epoch difference; no new episode is scheduled and the change takes effect immediately. Depending on the TOD clock resolution capability of the model, a model dependent number of the low order bits of bits 32:63 may be
ignored by the machine and treated as if they were zeros.

**Special Conditions**

A privileged operation exception is recognized if a PTFF control function is issued in the problem state.

A specification exception is recognized and no other action is taken if any of the following occurs:

1. Bit 56 of general register 0 is not zero.
2. Bits 57-63 of general register 0 specify an unassigned or uninstalled function code.

**Resulting Condition Code:**

0 Requested function performed
1 --
2 --
3 Requested function not available

**Program Exceptions:**

- Access (fetch, parameter block for control functions; store, parameter block for query functions)
- Operation (if the PERFORM TIMING FACILITY FUNCTION instruction is not installed)
- Privileged operation (attempt to execute a PTFF control function in the problem state)
- Specification
- Transaction constraint

The priority of execution for the PTFF instruction is shown in Figure 10-58.

1. Access exceptions for an access to the parameter block.
2. Condition code 0 indicating successful completion.

**Programming Notes:**

1. When the STP-hardware-based-TOD-clock-steering facility is not installed, the physical time (pb.Tu) returned in the parameter block for PTFF-QTO, PTFF-QTOU, and PTFF-QSI is the current value of the physical clock, but with zeros in positions to the right of the bit position incremented concurrently with each TOD-offset-update event. This value is not necessarily unique. The same value may be returned if the PTFF instruction is issued multiple times on the same CPU or issued at approximately the same time on different CPUs.

2. When the STP-hardware-based-TOD-clock-steering facility is not installed, the 64-bit value of the physical clock at the most recent TOD-offset-update event (pb.Tu) returned by PTFF-QTO, PTFF-QTOU, and PTFF-QSI may be used by the program to ensure that all events during a short routine occurred with no intervening TOD-offset-update events. This can be accomplished by issuing one of these queries at the beginning of the routine and the other at the end and reiterating if the value of pb.Tu before and the value of pb.Tu after are different.

3. When the STP-hardware-based-TOD-clock-steering facility is installed, there are no TOD-offset-update events, and pb.Tu reports the current value of the physical clock. Steering episode changes are reflected in the old and new episode start times.

4. For Query Steering Information, pb.Tu can be used to determine whether the machine is operating in the old or new episode. When pb.new.s ≤ pb.Tu, the machine is operating in the new episode, and none of the information returned by the query has changed since the most recent TOD-offset-update event. When pb.new.s > Pb.Tr, the machine is operating in the old episode, a new episode has been scheduled and has not yet taken effect. The program should avoid any dependency on the new episode val-
ues returned in this case, as it is possible the values may change again before the new episode takes effect.

5. Two or more executions of PTFF-QPT within a short period of time, either on the same or different CPUs, do not appear to step backwards, but are not necessarily unique. Thus, it is not always possible to use the values to determine the sequence of execution.

6. The Network Time Protocol (NTP) is used extensively in the Internet. A description of NTP may be found in Request for Comments (RFC) 1305. Figure 10-60 on page 10-85 shows the value of the TOD clock and NTP timestamp for 00:00:00 (0 am), UTC time, for several dates: January 1, 1900, January 1, 1972, and for that instant in time just after each of the 26 leap seconds that will have occurred through July, 2015. Each of these leap seconds is inserted in the UTC time scale beginning at 23:59:60 UTC of the day previous to the one listed and ending at 00:00:00 UTC of the day listed. Also included are values for the beginning of each year since the most recent leap second. Figure 10-59 on page 10-84 shows the values of the TOD clock and NTP timestamp for those instants just after the leftmost bit of one or the other has changed. For instants in the future, the number of leap seconds must be applied and this value is not yet known.

<table>
<thead>
<tr>
<th>YYYY MM DD hh mm ss</th>
<th>TOD Clock (Hex)</th>
<th>NTP Timestamp (Hex)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1968 01 20 03:14:08.000000</td>
<td>7A12 0000 0000 0000</td>
<td>8000 0000 0000 0000</td>
</tr>
<tr>
<td>1971 05 11 11:56:53.685248</td>
<td>8000 0000 0000 0000</td>
<td>8637 BD05 AF6C 69B5*</td>
</tr>
<tr>
<td>2036 02 07 06:28:16.000000</td>
<td>F424 0000 0000 0000</td>
<td>0000 0000 0000 0000</td>
</tr>
<tr>
<td>2042 09 17 23:53:47.370496*</td>
<td>0000 0000 0000 0000</td>
<td>0C6F 7A0B 5ED8 D36B*–</td>
</tr>
</tbody>
</table>

Explanation:
* Value is not exact.
+ Leap seconds must be added to this value.
– Leap seconds must be subtracted from this value.

Figure 10-59. TOD Clock and NTP Timestamps When a Leftmost Bit Changes
PERFORM TOPOLOGY FUNCTION

The contents of general register R₁ specify a function code in bit positions 56-63, as illustrated in Figure 10-61.
The defined function codes are as follows:

<table>
<thead>
<tr>
<th>FC</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Request horizontal polarization.</td>
</tr>
<tr>
<td>1</td>
<td>Request vertical polarization.</td>
</tr>
<tr>
<td>2</td>
<td>Check topology-change status.</td>
</tr>
</tbody>
</table>

Undefined function codes in the range 0-255 are reserved for future extensions.

Upon completion, if condition code 2 is set, a reason code is stored in bit positions 48-55 of general register R1.

Bits 16-23 and 28-31 of the instruction are ignored.

**Operation of Function Codes 0 and 1**

When no exceptional conditions are detected, a process is initiated to place all CPUs in the configuration into the polarization specified by the function code, and condition code 0 is set. Completion of the process is asynchronous with respect to execution of the instruction and may or may not be completed when execution of the instruction completes.

Execution completes with condition code 2, and the reason code is set, for any of the following reasons:

<table>
<thead>
<tr>
<th>RC</th>
<th>Reason</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No reason specified.</td>
</tr>
<tr>
<td>1</td>
<td>The configuration is already polarized as specified by the function code.</td>
</tr>
<tr>
<td>2</td>
<td>A topology change is already in process</td>
</tr>
</tbody>
</table>

**Operation of Function Code 2:**

The topology-change-report-pending condition is checked. When a topology-change-report is not pending, condition code 0 is set. When a topology-change report is pending, condition code 1 is set.

A topology change is any alteration such that the contents of a SYSIB 15.1.2 would be different from the contents of the SYSIB 15.1.2 prior to the topology change.

A topology-change-report-pending condition is created when a topology-change process completes. A topology-change-report-pending condition is cleared for the configuration when any of the following is performed:

- Execution of PERFORM TOPOLOGY FUNCTION specifies function-code 2 that completes with condition code 1.
- Subsystem reset is performed.

**Special Conditions**

A specification exception is recognized for either of the following conditions:

- Bit positions 0-55 of general register R1 are not zeros.
- An undefined function code is specified.

**Resulting Condition Code:** When the function code is 0 or 1, the condition code is set as follows:

| 0  | Topology-change initiated |
| 1  | --                        |
| 2  | Request rejected          |
| 3  | --                        |

When the function code is 2, the condition code is set as follows:

| 0  | Topology-change-report not pending |
| 1  | Topology-change report pending    |
| 2  | --                                |
| 3  | --                                |

**Program Exceptions:**

- Operation (configuration-topology facility is not installed)
- Privileged operation
- Specification
- Transaction constraint

**Programming Note:** Further information on configuration topology may be found in “SYSIB 15.1.2 - 15.1.6 (Configuration Topology)” on page 10-150.

**PROGRAM CALL**

<table>
<thead>
<tr>
<th>PC</th>
<th>D&lt;sub&gt;2&lt;/sub&gt;</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>&quot;B218&quot;</td>
<td>0 16 20 31</td>
<td>B&lt;sub&gt;2&lt;/sub&gt; D&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
</tbody>
</table>

A program-call number specified by the second-operation address is used in a two-level or three-level lookup to locate an entry-table entry (ETE). The pro-
gram is authorized to use the ETE when the AND of the PSW-key mask in control register 3 and the authorization key mask in the ETE is nonzero or when the CPU is in the supervisor state.

When the PC-type bit, bit 128 of the ETE, is zero, an operation called basic PROGRAM CALL is performed. When the PC-type bit is one, an operation called stacking PROGRAM CALL is performed.

Basic PROGRAM CALL, in the 24-bit or 31-bit addressing mode, loads the basic-addressing-mode bit, bits 33-62 of the updated instruction address, and the problem-state bit from the PSW into bit positions 32-63 of general register 14, and it leaves bits 0-31 of this register unchanged. In the 64-bit addressing mode, bits 0-62 of the updated instruction address and the problem-state bit are placed in bit positions 0-63 of general register 14. In any addressing mode, the PSW-key mask and PASN are placed in bit positions 32-63 of general register 3, and bits 0-31 of this register remain unchanged.

Stacking PROGRAM CALL places the entire PSW contents, except with an unpredictable PER mask, and also the PSW-key mask, PASN, SASN, and EAX in a linkage-stack program-call state entry that it forms. A called-space identification, an indication of whether the resulting addressing mode is the 64-bit mode, the numeric part of the program-call number, and the contents of general registers 0-15 and access registers 0-15 also are placed in the state entry. If the ASN-and-LX-reuse facility is installed and enabled, the PASTEIN and SASTEIN also are placed in the state entry.

For basic PROGRAM CALL, the extended-addressing-mode bit, bit 31 of the PSW, must have the same value as the entry-extended-addressing-mode bit, bit 129 of the ETE; otherwise, a special-operation exception is recognized. Basic PROGRAM CALL does not change bit 31 of the PSW and, therefore, does not switch between a basic addressing mode (the 24-bit or 31-bit mode) and the extended addressing mode (the 64-bit mode). In the 24-bit or 31-bit addressing mode, basic PROGRAM CALL sets the basic-addressing-mode bit, bit 32 of the PSW, with the value of the entry-basic-addressing-mode bit, bit 32 of the ETE, and, thus, it may switch between the 24-bit and 31-bit addressing modes. In the 64-bit addressing mode, bit 32 of the PSW remains unchanged.

Stacking PROGRAM CALL, when bit 129 of the ETE is zero, sets bit 31 of the PSW to zero and sets bit 32 of the PSW with the value of bit 32 of the ETE. When bit 129 of the ETE is one, stacking PROGRAM CALL sets bits 31 and 32 of the PSW to one. Thus, stacking PROGRAM CALL can set the 24-bit, 31-bit, or 64-bit addressing mode.

When the resulting addressing mode is the 24-bit or 31-bit mode, both basic and stacking PROGRAM CALL place bits 33-62 of the entry instruction address in the ETE, which are bits 33-62 of the ETE, with 33 leftmost and one rightmost zeros appended, in bit positions 64-127 of the PSW as the new instruction address, and they place the entry-problem-state bit, bit 63 of the ETE, in bit position 15 of the PSW as the new problem-state bit. Bits 32-63 of the entry parameter in the ETE are placed in bit positions 32-63 of general register 4, and bits 0-31 of this register remain unchanged.

When the resulting addressing mode is the 64-bit mode, both basic and stacking PROGRAM CALL place bits 0-62 of the entry instruction address, bits 0-62 of the ETE, with one rightmost zero appended, in bit positions 64-127 of the PSW, and they place bit 63 of the ETE in bit position 15 of the PSW. Bits 0-63 of the entry parameter in the ETE are placed in general register 4.

Basic PROGRAM CALL ORs the entry key mask from the ETE into the PSW-key mask in control register 3. Stacking PROGRAM CALL does the same, or it replaces the PSW-key mask with the entry key mask, as determined by the PSW-key-mask control in the ETE.

Stacking PROGRAM CALL optionally replaces the PSW key in the PSW and the EAX in control register 8 from the ETE, and it sets the address-space-control bits in the PSW, as determined by control bits in the ETE.

The ETE causes a space-switching operation to occur if it contains a nonzero ASN. When the ETE contains a zero ASN, the operation is called PROGRAM CALL to current primary (PC-cp); when the ETE contains a nonzero ASN, the operation is called PROGRAM CALL with space switching (PC-ss). When space switching is specified, the new PASN is loaded into control register 4 from the ETE, and a new primary-ASTE origin (PASTE) is loaded into control register 5, also from the ETE. From the PASTE, a new primary ASCE (PASCE) and AX are
loaded into control registers 1 and 4, respectively. If ASN-and-LX reuse is enabled, a new primary ASTE instance number (PASTEIN) is loaded into control register 4, also from the PASTE.

In both PC-cp and PC-ss, the SASN and secondary ASCE (SASCE) are set equal to the original PASN and PASCE, respectively, and, if ASN-and-LX reuse is enabled, the secondary ASTE instance number (SASTEIN) in control register 3 is set equal to the original PASTEIN. However, the space-switching stacking PROGRAM CALL operation may instead set the SASN and SASCE equal to the new PASN and PASCE, respectively, and, if ASN-and-LX reuse is enabled, set the SASTEIN equal to the new PASTEIN, as determined by a control bit in the ETE.

In a PC-ss to the base space of the dispatchable unit when the dispatchable unit is subspace active, bits 0-55 and 58-63 of the new PASCE are replaced by the same bits of the ASCE in the ASTE for the subspace in which the dispatchable unit last had control. This occurs before the possible setting of the SASCE equal to the PASCE.

PROGRAM CALL PC-Number Translation

The second-operand address is not used to address data; instead, the rightmost 20 or 32 bits of the address are used as a PC number divided into two fields: a linkage index (LX) and an entry index (EX). The entry index is always the rightmost eight bits of the PC number. When the ASN-and-LX-reuse is not installed or is not enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0, the PC number is 20 bits, and the leftmost 12 bits of the number are the linkage index. In this case, the second-operand address has the following format:

Second-Operand Address when ASN-and-LX Reuse Is Not Enabled

```
  0  31
  LX EX
```

Bit 44 of the effective address has no special meaning and may be zero or one.

When the ASN-and-LX-reuse facility is installed and enabled, referred to simply by saying that ASN-and-LX reuse is enabled, the linkage index is further divided into a linkage first index (LFX) and a linkage second index (LSX). The linkage second index is always the five bits immediately on the left of the entry index. The size and format of the linkage first index depend on whether the PC number is 20 bits or 32 bits, which in turn depends on whether bit 44 of the second-operand address is zero or one, respectively. In these cases, the second-operand address has the following formats:

Second-Operand Address when ASN-and-LX Reuse Is Enabled and Bit 44 Is Zero

```
  0  31
  LX
```

```
  0  32  44  45  51  56  63
  LFX2 LSX EX
```

Second-Operand Address when ASN-and-LX Reuse Is Enabled and Bit 44 Is One

```
  0  31
  LX
```

```
  0  32  44  45  51  56  63
  LFX1 LFX2 LSX EX
```

When ASN-and-LX reuse is enabled and bit 44 of the second-operand address is zero, the PC number is 20 bits, and the linkage first index is bits 44-50, or bits 45-50 (LFX2) with a zero appended on the left. Thus, the linkage first index is seven bits of which the leftmost bit is always zero. When bit 44 is one, the PC number is 32 bits, and the linkage first index is bits 45-50 (LFX2) with bits 32-43 (LFX1) appended on the left, or 18 bits, and bit 44 is not a numeric part of the PC number. However, a linkage first table can contain at most 16,384 entries, and, therefore, the leftmost four bits of the linkage first index, bits 32-35 of the second-operand address, must always be zeros; otherwise, an LFX-translation exception is recognized.

**Linkage Index (LX):** When ASN-and-LX reuse is not enabled, bits 44-55 of the second-operand address are the linkage index and are used to select an entry from the linkage table designated by the linkage-table designation in the primary ASTE.
**Linkage First Index (LFX):** When ASN-and-LX reuse is enabled and bit 44 of the second-operand address is zero, bits 44-50 of the second-operand address are the linkage first index. When ASN-and-LX reuse is enabled and bit 44 of the second-operand address is one, bits 45-50 with bits 32-43 appended on the left are the linkage first index. In either case, the linkage first index is used to select an entry from the linkage first table designated by the linkage-first-table designation in the primary ASTE.

**Linkage Second Index (LSX):** When ASN-and-LX reuse is enabled, bits 51-55 of the second-operand address are the linkage second index and are used to select an entry from the linkage second table designated by the linkage-second-table entry.

**Entry Index (EX):** Bits 56-63 of the second-operand address are the entry index and are used to select an entry from the entry table designated by the linkage-table entry or the linkage-second-table entry.

When the PC number is 20 bits, bits 32-43 of the second-operand address are ignored. Bits 0-31 of the second-operand address are always ignored.

When ASN-and-LX reuse is enabled, the second word of the linkage-second-table entry used contains a linkage-second-table-entry sequence number (LSTESN). When this LSTESN is nonzero, it must be equal to an LSTESN specified in bit positions 0-31 of general register 15; otherwise, an LSTE-sequence exception is recognized. When ASN-and-LX reuse is not enabled (including when it is not installed) or the LSTESN in the linkage-second-table entry is zero, bits 0-31 of general register 15 are ignored.

The 32-byte entry-table entry (ETE) has the following format:

For basic PROGRAM CALL in the 24-bit or 31-bit addressing mode when bit 32 of the ETE (A) is zero (specifying the 24-bit mode), and for stacking PROGRAM CALL when bits 32 (A) and 129 (G) are zeros (specifying the 24-bit mode), bits 33-39 must be zeros; otherwise, a PC-translation-specification exception is recognized.

After the ETE has been fetched, if the current PSW specifies the problem state, the current PSW-key mask in control register 3 is tested against the AKM field in the ETE to determine whether the program is authorized to access this entry. The AKM and PSW-key mask are ANDed, and, if the result is zero, a privileged-operation exception is recognized. The PSW-key mask in control register 3 remains unchanged.

If the result of the AND of the AKM and the PSW-key mask is not zero, or if the CPU is in the supervisor state, the execution of the instruction continues.

If bit 128 of the ETE (T) is zero, the basic PROGRAM CALL operation is specified. If bit 128 of the ETE is one, the stacking PROGRAM CALL operation is specified.

**Basic PROGRAM CALL**

The following operations are performed when basic PROGRAM CALL is specified.

Bit 31 of the current PSW (the extended-addressing-mode bit) must equal bit 129 (G) of the ETE; otherwise, a special-operation exception is recognized.
PROGRAM CALL

In the 24-bit or 31-bit addressing mode, bits 97-126 of the PSW (bits 33-62 of the updated instruction address) are placed in bit positions 33-62 of general register 14, bit 32 of the PSW (the basic-addressing-mode bit) is placed in bit position 32 of the register, and bit 15 of the PSW (the problem-state bit) is placed in bit position 63 of the register. Bits 0-31 of the register remain unchanged.

In the 64-bit addressing mode, bits 64-126 of the PSW (bits 0-62 of the updated instruction address) are placed in bit positions 0-62 of general register 14, and bit 15 of the PSW (the problem-state bit) is placed in bit position 63 of the register.

In the 24-bit or 31-bit addressing mode, bits 32 and 33-62 of the ETE (A and the EIA), with a zero appended on the right of bits 33-62, are placed in PSW bit positions 32 and 97-127, respectively (the basic-addressing-mode bit and bits 33-63 of the instruction address). In the 64-bit addressing mode, bits 0-62 of the ETE, with a zero appended on the right, are placed in PSW bit positions 64-127 (the instruction address), and PSW bit 32 remains unchanged. In any addressing mode, bit 63 of the ETE (P) is placed in PSW bit position 15 (the problem-state bit).

The PSW-key mask, bits 32-47 of control register 3, is placed in bit positions 32-47 of general register 3, and the current PASN, bits 48-63 of control register 4, is placed in bit positions 48-63 of general register 3. Bits 0-31 of general register 3 remain unchanged.

Bits 96-111 of the ETE (the EKM) are ORed with the PSW-key mask, bits 32-47 of control register 3, and the result replaces the PSW-key mask in control register 3.

In the 24-bit or 31-bit addressing mode, bits 224-255 of the ETE (bits 32-63 of the entry parameter) are loaded into bit positions 32-63 of general register 4, and bits 0-31 of the register remain unchanged. In the 64-bit addressing mode, bits 192-255 of the ETE (the entry parameter), are loaded into bit positions 0-63 of general register 4.

Stacking PROGRAM CALL

The following operations are performed when stacking PROGRAM CALL is specified.

The stacking process is performed to form a linkage-stack program-call state entry and place the following information in the state entry: current PSW (with an unpredictable PER mask), PSW-key mask, PASN, SASN, EAX, called-space identification, an indication of whether the resulting addressing mode is the 64-bit mode, numeric part of the program-call number, contents of general registers 0-15, and contents of access registers 0-15, and, if ASN-and-LX reuse is enabled, PASTEIN and SASTEIN. This is described in “Stacking Process” on page 5-85. The entry-type code in the state entry is 0001101 binary.

When bit 129 of the ETE (G) is zero, bit 31 of the PSW (the extended-addressing-mode bit) is set to zero, and bit 32 of the ETE (A) is placed in bit position 32 of the PSW (the basic-addressing-mode bit). (The addressing mode is set to the 24-bit mode if bit 32 is zero or to the 31-bit mode if bit 32 is one.) When bit 129 of the ETE is one, bits 31 and 32 of the PSW are set to one. (The 64-bit addressing mode is set.)

When the resulting addressing mode is the 24-bit or 31-bit mode, bits 32-62 of the ETE (the EIA), with 33 leftmost and one rightmost zeros appended, are placed in PSW bit positions 64-127 (the instruction address). When the resulting addressing mode is the 64-bit mode, bits 0-62 of the ETE (the EIA), with one rightmost zero appended, are placed in PSW bit positions 64-127.

Bit 63 of the ETE (P) is placed in PSW bit position 15 (the problem-state bit).

When bit 131 of the ETE (K) is zero, bits 8-11 of the PSW (the PSW key) remain unchanged. When bit 131 of the ETE is one, bits 136-139 of the ETE (the EK) replace the PSW key in the PSW.

When bit 132 of the ETE (M) is zero, bits 96-111 of the ETE (the EKM) are ORed with the PSW-key mask, bits 32-47 of control register 3, and the result replaces the PSW-key mask in control register 3.

When bit 132 of the ETE is one, bits 96-111 of the ETE replace the PSW-key mask in control register 3.

When bit 133 of the ETE (E) is zero, the EAX, bits 32-47 of control register 8, remains unchanged. When bit 133 of the ETE is one, bits 144-159 of the ETE (the EEAX) replace the EAX in control register 8.
When bit 134 of the ETE (C) is zero, bits 16 and 17 of the PSW (the address-space-control bits) are set to 00 binary (primary-space mode). When bit 134 of the ETE is one, the address-space-control bits in the PSW are set to 01 binary (access-register mode).

When the resulting addressing mode is the 24-bit or 31-bit mode, bits 224-255 of the ETE (bits 32-63 of the entry parameter) are loaded into bit positions 32-63 of general register 4, and bits 0-31 of this register remain unchanged. When the resulting addressing mode is the 64-bit mode, bits 192-255 of the ETE (the entry parameter), are loaded into bit positions 0-63 of general register 4.

Key-controlled protection does not apply to references to the linkage stack, but low-address and DAT protection do apply.

**PROGRAM CALL to Current Primary (PC-cp)**

If bits 80-95 of the ETE (the ASN), are zeros, PROGRAM CALL to current primary (PC-cp) is specified, and the execution of the instruction is completed after the operations described in “PROGRAM CALL PC-Number Translation” and either “Basic PROGRAM CALL” or “Stacking PROGRAM CALL” have been performed and the following operations have been performed.

Bits 80-95 of the ETE (the ASN) are placed in bit positions 48-63 of control register 4 as the new PASN.

Bits 161-185 of the ETE, with six zeros appended on the right, are used as the real address of the ASTE designated by the new PASN. An ASX-translation exception is recognized if bit 0 of the ASTE is one.

Bits 64-127 of the ASTE (the ASCE) are placed in control register 1 as the new PASCE.

Bits 32-47 of the ASTE (the AX) are placed in bit positions 32-47 of control register 4 as the new authorization index.

If ASN-and-LX reuse is enabled, bits 352-383 of the ASTE (the ASTEIN) are placed in bit positions 0-31 of control register 4 as the new PASTEIN.

In basic PROGRAM CALL, or in stacking PROGRAM CALL when bit 135 of the ETE (S) is zero, the PASN existing before the PASN is replaced from the ETE is placed in bit positions 48-63 of control register 3 to become the current SASN, and the PASCE existing before the PASCE is replaced from the ASTE is placed in control register 7 to become the current SASCE. If ASN-and-LX reuse is enabled, the PASTEIN existing before the PASTEIN is replaced from the ASTE is placed in bit positions 0-31 of control register 3 to become the current SASTEIN. (The SASN and SASCE are set equal to the old PASN and PASCE, respectively, and, if ASN-and-LX reuse is enabled, the SASTEIN is set equal to the old PASTEIN.)

In stacking PROGRAM CALL when bit 135 of the ETE (S) is one, the SASN is replaced by the PASN after the PASN is replaced from the ETE, and the SASCE is replaced by the PASCE after the PASCE is replaced from the ASTE. If ASN-and-LX reuse is enabled, the SASTEIN is replaced by the PASTEIN after the PASTEIN is replaced from the ASTE. (The SASN and SASCE are set equal to the new PASN and PASCE, respectively, and, if ASN-and-LX reuse
is enabled, the SASTEIN is set equal to the new PASTEIN.)

The description in this paragraph applies to use of the subspace-group facility. After the new PASCE has been placed in control register 1 and the new primary-ASTE origin has been placed in control register 5, if (1) the subspace-group-control bit, bit 54, in the PASCE is one, (2) the dispatchable unit is subspace active, and (3) the primary-ASTE origin designates the ASTE for the base space of the dispatchable unit, then bits 0-55 and 58-63 of the PASCE are replaced by the same bits of the ASCE in the ASTE for the subspace in which the dispatchable unit last had control. This replacement occurs before a replacement of the SASCE in control register 7 by the PASCE. Further details are in “Subspace-Replacement Operations” on page 5-71.

The PC-ss operation is depicted in parts 1 and 4-6 of Figure 10-63 on page 10-95.

PROGRAM CALL Serialization

For both the PC-cp and PC-ss operations, a serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed. However, it is unpredictable whether or not a store into a trace-table entry or linkage-stack entry from which a subsequent instruction is fetched will be observed by the CPU that performed the store.

Special Conditions

The basic PROGRAM CALL operation can be performed successfully only when (1) the CPU is in the primary-space mode at the beginning of the operation, (2) the subsystem-linkage control, bit 0 of the linkage-table designation or linkage-first-table designation in the current primary ASN-second-table entry, is one, and (3) the extended-addressing-mode bit, bit 31 of the current PSW, equals the entry-extended-addressing-mode bit, bit 129 of the entry-table entry. Stacking PROGRAM CALL can be performed successfully only when the CPU is in the primary-space mode or access-register mode at the beginning of the operation and the subsystem-linkage control is one. In addition, PC-ss can be performed successfully only when the ASN-translation control, bit 44 of control register 14, is one. If any of these rules is violated, a special-operation exception is recognized.

When ASN-and-LX reuse is enabled and the LSTESN in the linkage-second-table entry is non-zero, that LSTESN must be equal to the LSTESN specified in bit positions 0-31 of general register 15; otherwise, an LSTE-sequence exception is recognized.

A stack-full or stack-specification exception may be recognized during the stacking process.

When, for PC-ss, the primary space-switch-event-control bit, bit 57 of control register 1, is one either before or after the execution of the instruction, a space-switch-event program interruption occurs after the operation is completed. A space-switch-event program interruption also occurs after the completion of a PC-ss operation if a PER event is reported.

The operation is suppressed on all addressing and protection exceptions.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (fetch or store, except for key-controlled protection, linkage-stack entry)
- Addressing (linkage-table or linkage-first-table designation in primary ASN-second-table entry; linkage-table entry; linkage-first-table entry; linkage-second-table entry, entry-table entry; ASN-second-table entry, PC-ss only)
- ASX translation (PC-ss only)
- EX translation
- LFX translation
- LSTE sequence
- LSX translation
- LX translation
- PC-translation specification
- Privileged operation (AND of AKM and PSW-key mask is zero in the problem state)
- Space-switch event (PC-ss only)
- Special operation
- Stack full (stacking PC only)
- Stack specification (stacking PC only)
- Subspace replacement (PC-ss only)
- Trace
- Transaction constraint
The priority of recognition of program exceptions for the instruction is shown in Figure 10-62.

<table>
<thead>
<tr>
<th>Exception Description</th>
<th>Note</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.</td>
<td></td>
</tr>
<tr>
<td>7.B Special-operation exception due to DAT being off or the CPU being in secondary-space mode or home-space mode.</td>
<td></td>
</tr>
<tr>
<td>8.A Addressing exception for access to linkage-table designation or linkage-first-table designation in primary ASN-second-table entry.</td>
<td></td>
</tr>
<tr>
<td>8.B.1 Special-operation exception due to subsystem-linkage control in linkage-table designation or linkage-first-table designation being zero. <strong>Note:</strong> The LFX-translation, LSX-translation, and LSTE-sequence exceptions can be recognized only if ASN-and-LX reuse is enabled, and the LX-translation exception cannot be recognized in that case.</td>
<td></td>
</tr>
<tr>
<td>8.B.2 Addressing exception for access to linkage-table or linkage-first-table entry, respectively, being outside table.</td>
<td></td>
</tr>
<tr>
<td>8.B.3 LX-translation or LFX-translation exception due to linkage-table or linkage-first-table entry, respectively, being outside table.</td>
<td></td>
</tr>
<tr>
<td>8.B.4 Addressing exception for access to linkage-table or linkage-first-table entry.</td>
<td></td>
</tr>
<tr>
<td>8.B.5 LX-translation or LFX-translation exception due to I bit (bit 0) in linkage-table or linkage-first-table entry, respectively, being one.</td>
<td></td>
</tr>
<tr>
<td>8.B.6 Addressing exception for access to linkage-second-table entry.</td>
<td></td>
</tr>
<tr>
<td>8.B.7 LSX-translation exception due to I bit (bit 0) in linkage-second-table entry being one.</td>
<td></td>
</tr>
<tr>
<td>8.B.8 LSTE-sequence exception due to LSTE sequence number in linkage-second-table entry being nonzero and not equal to bits 0-31 of general register 15.</td>
<td></td>
</tr>
<tr>
<td>8.B.9 EX-translation exception due to entry-table entry being outside table.</td>
<td></td>
</tr>
<tr>
<td>8.B.10 Addressing exception for access to entry-table entry.</td>
<td></td>
</tr>
<tr>
<td>8.B.11 Special-operation exception due to the CPU being in access-register mode or extended-addressing-mode bit, bit 31 of PSW, not being equal to entry-extended-addressing-mode bit, bit 129 of entry-table entry (basic PC only).</td>
<td></td>
</tr>
<tr>
<td>8.B.12 PC-translation-specification exception due to invalid combination (bits 33-39 not zeros when resulting addressing mode is 24 bit) in entry-table entry.</td>
<td></td>
</tr>
<tr>
<td>8.B.13 Privileged-operation exception due to zero result from ANDing PSW-key mask and AKM in the problem state.</td>
<td></td>
</tr>
<tr>
<td>8.B.14 Special-operation exception due to ASN-translation control, bit 44 of control register 14, being zero (PC-ss only).</td>
<td></td>
</tr>
<tr>
<td>8.B.15 Addressing exception for access to ASN-second-table entry (PC-ss only).</td>
<td></td>
</tr>
<tr>
<td>8.B.16 ASX-translation exception due to I bit (bit 0) in ASN-second-table entry being one (PC-ss only). <strong>Note:</strong> Subspace-replacement exceptions, which are not shown in detail in this figure, can occur with any priority after 8.B.16 and before 9.</td>
<td></td>
</tr>
<tr>
<td>8.B.17 Access exceptions (fetch) for entry descriptor of the current linkage-stack entry (stacking PC only). <strong>Note:</strong> Exceptions 8.B.18-8.B.23 can occur only if there is not enough remaining free space in the current linkage-stack section.</td>
<td></td>
</tr>
<tr>
<td>8.B.18 Stack-specification exception due to remaining-free-space value in current linkage-stack entry not being a multiple of 8.</td>
<td></td>
</tr>
<tr>
<td>8.B.19 Access exceptions (fetch) for second word of the trailer entry of the current section. The entry is presumed to be a trailer entry; its entry-type field is not examined (stacking PC only).</td>
<td></td>
</tr>
<tr>
<td>8.B.20 Stack-full exception due to forward-section validity bit in the trailer entry being zero (stacking PC only).</td>
<td></td>
</tr>
<tr>
<td>8.B.21 Access exceptions (fetch) for entry descriptor of the header entry of the next section (stacking PC only). This entry is presumed to be a header entry; its entry-type field is not examined.</td>
<td></td>
</tr>
</tbody>
</table>

*Figure 10-62. Priority of Execution: PROGRAM CALL (Part 2 of 4)*
Programming Note: The effective address from which a PC number is derived is subject to the addressing mode in the current PSW. Therefore, bits 0-39 of the effective address in the 24-bit addressing mode, and bits 0-32 in the 31-bit addressing mode, are treated as containing zeros.
Basic PC-cp and PC-ss in 24-Bit or 31-Bit Addressing Mode

Figure 10-63. Execution of PROGRAM CALL (Part 1 of 5).
Basic PC-cp and PC-ss in 64-Bit Addressing Mode

Entry-Table Entry

<table>
<thead>
<tr>
<th>EIA</th>
<th>P</th>
<th>AKM</th>
<th>ASN</th>
<th>EKM</th>
<th>T</th>
<th>G</th>
<th>ASTE Address</th>
<th>EP</th>
</tr>
</thead>
</table>

- **AND**
  - Privileged-Op. Exception if Zero in Problem State
  - **CR3** 32-63 before
    - **PKM** SASN
  - **CR4** before
    - **PASTEIN*** AX PASN
  - **OR**
    - **CR3** after
      - **SASTEIN*** PKM SASN
    - * if ASN-and-LX-Reuse Enabled
  - **GR3** 32-63 after
    - **PKM** PASN

- **PSW** before
  - **E=1 A=1**

- **E=1 A=1**

- **GR4** after
  - **EP**

- **PKM**

- **SASN**

- **EP**

- **GR4**

- **Yes**
  - **ASN = 0**
  - PC-cp Instruction Complete
- **No**
  - PC-ss Operations on ASTE (see part 5)

**Figure 10-63. Execution of PROGRAM CALL (Part 2 of 5).**
Stacking PC-cp and PC-ss from 24-Bit or 31-Bit Addressing Mode to 64-Bit Addressing Mode

Figure 10-63. Execution of PROGRAM CALL (Part 3 of 5).
Stacking PC-cp and PC-ss from 64-Bit Addressing Mode to 24-Bit or 31-Bit Addressing Mode

Figure 10-63. Execution of PROGRAM CALL (Part 4 of 5).
The PSW, except for the PER-mask bit, saved in the last linkage-stack state entry is restored as the current PSW. The PER mask in the current PSW remains unchanged. The contents of general registers 2-14 and access registers 2-14 also are restored from the state entry. When the entry-type code in the entry descriptor of the state entry is 0001101 binary, indicating a program-call state entry, (1) the primary ASN (PASN), secondary ASN (SASN), PSW-key mask (PKM), and extended authorization index (EAX) in the control registers also are restored from the state entry and (2) if the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0, the primary ASTE instance number (PASTEIN) and secondary ASTE instance number (SASTEIN) in the control registers also are restored from the state entry. When the entry-type code is 0001100 binary, indicating a branch state entry, the current PASN, SASN, PKM, EAX, PASTEIN, and SASTEIN remain unchanged.

The last state entry is located, and information in it is restored, as described in "Unstacking Process" on page 5-87. The state entry is logically deleted from
the linkage stack, and the linkage-stack-entry address in control register 15 is replaced by the address of the next preceding state or header entry. This also is described in “Unstacking Process”.

When the state entry is a program-call state entry, it causes a space-switching operation to occur if it contains a PASN that is not equal to the current PASN. When the state entry contains a PASN that is equal to the current PASN, the operation is called PROGRAM RETURN to current primary (PR-cp); when the state entry contains a PASN that is not equal to the current PASN, the operation is called PROGRAM RETURN with space switching (PR-ss). PASN translation occurs in PR-ss. SASN translation and authorization may occur in either PR-cp or PR-ss. The terms PR-cp and PR-ss do not apply when the state entry is a branch state entry.

When the ASN-and-LX-reuse facility is installed and enabled and PASN or SASN translation occurs, the PASTEIN or SASTEIN, respectively, saved in the state entry is compared to the ASTEIN in the located ASTE.

Key-controlled protection does not apply to accesses to the linkage stack, but low-address and DAT protection do apply.

The sections “PASN Translation,” “SASN Translation,” “SASN Authorization,” and “PROGRAM RETURN Serialization” apply only when the unstacked state entry is a program-call state entry. The functions described in those sections are not performed when the state entry is a branch state entry.

The actions involving the PASTEIN and SASTEIN occur only when ASN-and-LX reuse is enabled by the ASN-and-LX reuse control in control register 0.

PASN Translation

If the new PASN is equal to the old PASN in bit positions 48-63 of control register 4, PASN translation is not performed, the PASTEIN in control register 4 remain as restored from the state entry, and the PASCE in control register 1 and primary-ASTE origin (PASTE) in control register 5 are not changed. In this case, there is not a test of whether the new PASTEIN is equal to the old PASTEIN.

If the new PASN is not equal to the old PASN, the new PASN replaces the PASN in bit positions 48-63 of control register 4 and is translated to locate a 64-byte ASTE. The ASN table-lookup process is described in “ASN Translation” on page 3-27. The exceptions associated with ASN translation are collectively called ASN-translation exceptions. These exceptions and their priority are described in Chapter 6, “Interruptions.”

If ASN-and-LX reuse is enabled, the PASTEIN saved in bytes 180-183 of the state entry must equal the ASTEIN in bit positions 352-383 of the located ASTE; otherwise, an ASTE-instance exception is recognized.

Bits 64-127 of the ASTE are placed in control register 1 as the new PASCE.

Bits 32-47 of the ASTE are placed in bit positions 32-47 of control register 4 as the new AX. The PASN and PASTEIN in control register 4 remain as restored from the state entry.

Bits 33-57 of the ASTE address are placed in bit positions 33-57 of control register 5 as the new primary-ASTE origin, and zeros are placed in bit positions 32 and 58-63. Bits 0-31 of this register remain unchanged.

The description in this paragraph applies to use of the subspace-group facility when PASN translation has occurred. If (1) the subspace-group-control bit, bit 54, in the new PASCE is one, (2) the dispatchable unit is subspace active, and (3) the new primary-ASTE origin designates the ASTE for the base space of the dispatchable unit, then bits 0-55 and 58-63 of the new PASCE in control register 1 are replaced by the same bits of the ASCE in the ASTE for the subspace in which the dispatchable unit last had control. This replacement occurs, in the case when the new SASN is equal to the new PASN, before the SASCE is set equal to the PASCE. Further details are in “Subspace-Replacement Operations” on page 5-71.

SASN Translation

If the new SASN is equal to the new PASN, the SASCE in control register 7 is set equal to the new PASCE in control register 1. The SASTEIN, PKM, and SASN in control register 3 remain as restored from the state entry. In this case, there is not a test of whether the new SASTEIN is equal to the new PASTEIN.

If the new SASN is not equal to the new PASN, the new SASN is translated to locate a 64-byte ASTE.
If ASN-and-LX reuse is enabled, the SASTEIN saved in bytes 176-179 of the state entry must equal the ASTEIN in bit positions 352-383 of the located ASTE; otherwise, an ASTE-instance exception is recognized.

Bits 64-127 of the ASTE are placed in control register 7 as the new SASCE.

Control register 3 remains as restored from the state entry.

SASN Authorization

If the new SASN is not equal to the new PASN, the authority-table origin (ATO) from the ASTE for the new SASN is used as the base for a third table lookup. The new authorization index, bits 32-47 of control register 4, is used, after it has been checked against the authority-table length, as the index to locate the entry in the authority table. The authority-table lookup is described in “ASN Authorization” on page 3-32.

The description in this paragraph applies to use of the subspace-group facility when SASN translation and authorization have occurred. If (1) the subspace-group-control bit, bit 54, in the new SASCE is one, (2) the dispatchable unit is subspace active, and (3) the ASTE origin obtained by SASN translation designates the ASTE for the base space of the dispatchable unit, then bits 0-55 and 58-63 are replaced by the same bits of the ASCE of the ASCE in the ASTE for the subspace in which the dispatchable unit last had control. Further details are in “Subspace-Replacement Operations” on page 5-71.

PROGRAM RETURN Serialization

When the unstacked state entry is a program-call state entry, a serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed. However, it is unpredictable whether or not a store into a trace-table entry or linkage-stack entry from which a subsequent instruction is fetched will be observed by the CPU that performed the store.

Special Conditions

The instruction can be executed successfully only when the CPU is in the primary-space mode or access-register mode at the beginning of the operation. In addition, if ASN-translation is required for either the PASN or the SASN, it can only be performed when the ASN-translation control, bit 44 of control register 14, is one. If either of these rules is violated, a special-operation exception is recognized.

A stack-empty, stack-operation, stack-specification, or stack-type exception may be recognized during the unstacking process.

If ASN-and-LX reuse is enabled, the restored PAS-TEIN must equal the ASTEIN in the located ASTE if PASN translation is performed, and the restored SASTEIN must equal the ASTEIN in the located ASTE if SASN translation is performed; otherwise, an ASTE-instance exception is recognized.

When, for PR-ss, the primary space-switch-event control, bit 57 of control register 1, is one either before or after the execution of the instruction, a space-switch-event program interruption occurs after the operation is completed. A space-switch-event program interruption also occurs after the completion of a PR-ss operation if a PER event is reported.

The PSW which is to be loaded by the instruction is not checked for validity before it is loaded. However, after loading, a specification exception is recognized, and a program interruption occurs, if any of bits 0, 2-4, 12, 24-30, and 33-63 of the PSW is a one, if bits 31 and 32 are zero and one, respectively, and bits 64-96 are not all zeros, if bits 31 and 32 are one and zero, respectively. In these cases, the operation is completed, and the resulting instruction-length code is 0. The specification exception, which in this case is listed as a program exception in this instruction, is described in “Early Exception Recognition” on page 6-9.

If a space-switch event is indicated and the PSW that was loaded by the instruction is invalid because of a reason described in the preceding paragraph, it is unpredictable whether the resulting instruction-length code is 0 or 1, or 0 or 2 if EXECUTE was used, or 0 or 3 if EXECUTE RELATIVE LONG was used.

The operation is suppressed on all addressing and protection exceptions.
**Resulting Condition Code:** The code is set as specified in the new PSW loaded.

**Program Exceptions:**

- Access (fetch and store, except key-controlled protection, linkage-stack entry)
- Addressing (authority-table entry, if SASN translation occurs)
- ASN translation (if PASN or SASN translation occurs)
- ASTE instance (if ASN-and-LX reuse is enabled and PASN or SASN translation occurs)
- Secondary authority (if SASN translation occurs)
- Space-switch event
- Special operation
- Specification
- Stack empty
- Stack operation
- Stack specification
- Stack type
- Subspace replacement (if PASN or SASN translation occurs)
- Trace
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-64.

<table>
<thead>
<tr>
<th></th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.-6.</td>
<td>Exceptions with the same priority as the priority of program-interruption conditions for the general case.</td>
</tr>
<tr>
<td>7.A</td>
<td>Special-operation exception due to DAT being off or the CPU being in secondary-space mode or home-space mode.</td>
</tr>
<tr>
<td>8.A</td>
<td>Trace exceptions.</td>
</tr>
<tr>
<td>8.B.1</td>
<td>Access exceptions (fetch) for entry descriptor of the current linkage-stack entry.</td>
</tr>
<tr>
<td>8.B.2</td>
<td>Stack-type exception due to current entry not being a state entry or header entry.</td>
</tr>
<tr>
<td>8.B.3</td>
<td>Stack-operation exception due to unstack-suppression bit in the header entry being one.</td>
</tr>
<tr>
<td>8.B.4</td>
<td>Access exceptions (fetch) for second word of the header entry.</td>
</tr>
<tr>
<td>8.B.5</td>
<td>Stack-empty exception due to backward stack-entry validity bit in the header entry being zero.</td>
</tr>
<tr>
<td>8.B.6</td>
<td>Access exceptions (fetch) for entry descriptor of preceding entry, which is the entry designated by the backward stack-entry address in the current (header) entry.</td>
</tr>
<tr>
<td>8.B.7</td>
<td>Stack-specification exception due to preceding entry being a header entry.</td>
</tr>
<tr>
<td>8.B.8</td>
<td>Stack-type exception due to preceding entry not being a state entry.</td>
</tr>
<tr>
<td>8.B.9</td>
<td>Stack-operation exception due to unstack-suppression bit being one in the state entry.</td>
</tr>
<tr>
<td>8.B.10</td>
<td>Access exceptions (fetch) for the state entry, and access exceptions (store) for entry descriptor of the entry preceding the state entry.</td>
</tr>
</tbody>
</table>

**Note:** Exceptions 8.B.11-8.B.15 and the event 9 can occur only if the state entry is a program-call state entry.

<table>
<thead>
<tr>
<th></th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8.B.11</td>
<td>Special-operation exception due to the ASN-translation control, bit 44 of control register 14, being zero (if PASN or SASN translation occurs).</td>
</tr>
<tr>
<td>8.B.12</td>
<td>ASN-translation exceptions (if PASN translation occurs).</td>
</tr>
<tr>
<td>8.B.13</td>
<td>ASTE-instance exception due to new PASTEIN not being equal to ASTEIN in ASN-second-table entry located by PASN translation (if ASN-and-LX reuse enabled).</td>
</tr>
<tr>
<td>8.B.14</td>
<td>ASN-translation exceptions (if SASN translation occurs).</td>
</tr>
<tr>
<td>8.B.15</td>
<td>ASTE-instance exception due to new SASTEIN not being equal to ASTEIN in ASN-second-table entry located by SASN translation (if ASN-and-LX reuse enabled).</td>
</tr>
<tr>
<td>8.B.16</td>
<td>Secondary-authority exception due to authority-table entry being outside table (if SASN translation occurs).</td>
</tr>
</tbody>
</table>

**Note:** Subspace-replacement exceptions for replacement of bits in the PASCE, which are not shown in detail in this figure, can occur with any priority after 8.B.13 and before 9.

<table>
<thead>
<tr>
<th></th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8.B.17</td>
<td>ASN-translation exceptions (if SASN translation occurs).</td>
</tr>
</tbody>
</table>

**Figure 10-64. Priority of Execution: PROGRAM RETURN (Part 1 of 3)**
Programming Note: Because PROGRAM CALL cannot be executed successfully in the secondary-space or home-space mode, PROGRAM RETURN is not intended to load a PSW specifying one of these translation modes. PROGRAM RETURN, unlike SET ADDRESS SPACE CONTROL and SET ADDRESS SPACE CONTROL FAST, does not recognize a space-switch event because of loading a PSW that specifies the home-space mode.

PROGRAM TRANSFER

PT \( R_1, R_2 \) [RRE]

Note: In this instruction definition, the name “PROGRAM TRANSFER (WITH INSTANCE)” refers to the PROGRAM TRANSFER instruction and the PROGRAM TRANSFER WITH INSTANCE instruction.

Bits 32-63 of general register \( R_1 \) are used as the new values for the PSW-key mask, the PASN, and the SASN. Bits 32-63 or 0-63 of general register \( R_2 \), depending on the current addressing mode, are used as the new values for the problem-state bit, basic-addressing-mode bit, and instruction address in the current PSW. In the PROGRAM TRANSFER WITH INSTANCE operation, bits 0-31 of general register \( R_1 \) are an ASTEIN and are compared against the new value of the PASTEIN if the PASN is changed. In the PROGRAM TRANSFER operation, bits 0-31 of general register \( R_1 \) are ignored.

The format of general registers \( R_1 \) and \( R_2 \) are shown in Figure 10-65.

For PROGRAM TRANSFER

\[ \begin{array}{c|c|c}
0 & 16 & 24 \hline
32 & 48 & 63 \\
\hline
PSW-Key Mask & ASN \\
\end{array} \]

For PROGRAM TRANSFER WITH INSTANCE

\[ \begin{array}{c|c|c}
0 & 32 & 48 \hline
32 & 48 & 63 \\
\hline
ASTEIN & PSW-Key Mask & ASN \\
\end{array} \]

In 24-Bit or 31-Bit Addressing Mode

\[ \begin{array}{c|c|c}
0 & 32 & 33 \hline
32 & 33 & 63 \\
\hline
Instruction Address & P \\
\end{array} \]

In 64-Bit Addressing Mode

\[ \begin{array}{c|c|c}
0 & 63 \\
\hline
Instruction Address & P \\
\end{array} \]

When the contents of bit positions 48-63 of general register \( R_1 \) are equal to the current PASN, the operation is called PROGRAM TRANSFER (WITH INSTANCE) to current primary (PT-cp or PTI-cp); when the fields are not equal, the operation is called PROGRAM TRANSFER (WITH INSTANCE) with space switching (PT-ss or PTI-ss).

The contents of general register \( R_2 \) are used to update the problem-state bit and the instruction address in the current PSW and, in the 24-bit or 64-bit addressing mode.
In the 24-bit or 31-bit addressing mode, bit 32 of general register \( R_2 \) replaces the basic-addressing-mode bit, bit 32 of the current PSW, and bits 33-62 of the register, with one rightmost zero appended, replace bits 33-63 of the instruction address in the PSW, bits 97-127 of the PSW. In the 64-bit addressing mode, bits 0-62 of general register \( R_2 \), with one rightmost zero appended, replace the instruction address, and the basic-addressing-mode bit remains unchanged.

Bits 32-47 of general register \( R_1 \) are ANDed with the PSW-key mask, bits 32-47 of control register 3, and the result replaces the PSW-key mask. Bits 0-31 of general register \( R_1 \) are ignored.

In any of the PT-cp, PTI-cp, PT-ss, and PTI-ss operations, the ASN specified by bits 48-63 of general register \( R_1 \) replaces the SASN in control register 3, and the SASCE in control register 7 is replaced by the final contents of control register 1.

In the PROGRAM TRANSFER operation, if the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0, the SASTEIN in control register 3 is replaced by the final value of the PASTEIN in control register 4. This replacement occurs in the PROGRAM TRANSFER WITH INSTANCE operation regardless of the value of the ASN-and-LX-reuse control.

PROGRAM TRANSFER (WITH INSTANCE) to Current Primary (PT-cp or PTI-cp)

The PT-cp operation is depicted in part 1 of Figure 10-67 on page 10-108. The PTI-cp operation is depicted in part 1 of Figure 10-68 on page 10-110. The PT-cp or PTI-cp operation is completed when the common portion of the PROGRAM TRANSFER (WITH INSTANCE) operation, described above, is completed. The PASTEIN, authorization index, ASN, primary ASCE, and contents of control register 5 (primary-ASN-second-table-entry origin) are not changed by PT-cp or PTI-cp. In this case in the PTI-cp operation, there is not a test of whether the current PASTEIN equals the ASTEIN specified in bit positions 0-31 of general register \( R_1 \); the ASTEIN is ignored.

PROGRAM TRANSFER (WITH INSTANCE) with Space Switching (PT-ss or PTI-ss)

If the ASN in bit positions 48-63 of general register \( R_1 \) is not equal to the current PASN, a PROGRAM TRANSFER (WITH INSTANCE) with space switching (PT-ss or PTI-ss) operation is specified, and the ASN is translated by means of a two-level table lookup.

The PT-ss operation is depicted in parts 1 and 2 of Figure 10-67 on page 10-108. The PTI-ss operation is depicted in parts 1 and 2 of Figure 10-68 on page 10-110. The PT-ss or PTI-ss operation is completed as follows.

In PT-ss or PTI-ss, the contents of bit positions 48-63 of general register \( R_1 \) are used as an ASN, which is translated by means of a two-level table lookup.

Bits 48-57 of general register \( R_1 \) are a 10-bit AFX that is used to select an entry from the ASN first table. Bits 58-63 are a six-bit ASX that is used to select an entry from the ASN second table. The ASN table-lookup process is described in “ASN Translation” on page 3-27. The exceptions associated with ASN translation are collectively called “ASN-translation exceptions.” These exceptions and their priority are described in Chapter 6, “Interruptions.”

In PT-ss if the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0, the reusable-ASN bit, bit 63, in the located ASN-second-table entry (ASTE) must be zero; otherwise, a special-operation exception is recognized. In PTI-ss, regardless of the ASN-and-LX-reuse control and the reusable-ASN bit, the ASTEIN in bit positions 0-31 of general register \( R_1 \) must equal the ASTEIN in bit positions 352-383 of the ASTE; otherwise, an ASTE-instance exception is recognized.

The authority-table origin from the ASN-second-table entry (ASTE) is used as the base for a third table lookup. The current authorization index, bits 32-47 of control register 4, is used, after it has been checked against the authority-table length, as the index to
locate the entry in the authority table. The authority-
table lookup is described in “ASN Authorization” on
page 3-32.

The PT-ss or PTI-ss operation is completed by plac-
ing bits 64-127 of the ASTE in control register 1 as
the new PASCE and in control register 7 as the new
SASCE. The contents of bit positions 32-47 of the
ASTE replace the authorization index in bit positions
32-47 of control register 4. Bits 33-57 of the ASTE
address are placed in bit positions 33-57 of control
register 5 as the new primary-ASTE origin, and zeros
are placed in bit positions 32 and 58-63. Bits 0-31 of
this register remain unchanged. The ASN, bits 48-63
of general register R1, replaces the SASN and PASN
in bit positions 48-63 of control registers 3 and 4. In
PT-ss if ASN-and-LX reuse is enabled, and in PTI-ss
regardless of that enablement, the ASTEIN in the
ASTE replaces the SASTEIN and PASTEIN in bit
positions 0-31 of control registers 3 and 4.

The description in this paragraph applies to use of
the subspace-group facility. After the new PASCE
has been placed in control register 1 and the new pri-
mary-ASTE origin has been placed in control register
5, if (1) the subspace-group-control bit, bit 54, in the
PASCE is one, (2) the dispatchable unit is subspace
active, and (3) the primary-ASTE origin designates
the ASTE for the base space of the dispatchable unit,
then bits 0-55 and 58-63 of the PASCE in control reg-
ister 1 are replaced by the same bits of the ASCE in
the ASTE for the subspace in which the dispatchable
unit last had control. This replacement occurs before
a replacement of the SASCE in control register 7 by
the PASCE. Further details are in “Subspace-
Replacement Operations” on page 5-71.

**PROGRAM TRANSFER (WITH INSTANCE) Serial-
ization**

For any of the PT-cp, PTI-cp, PT-ss, and PTI-ss op-
erations, a serialization and checkpoint-synchronization
function is performed before the operation begins and again after the operation is completed. However, it is unpredictable whether or not a store
into a trace-table entry from which a subsequent
instruction is fetched will be observed by the CPU
that performed the store.

**Special Conditions**

The instruction can be executed only when the CPU
is in the primary-space mode and the subsystem-
linkage control, bit 0 of the linkage-table designation,
or linkage-first-table designation in the current pri-
mary ASN-second-table entry, is one. If the CPU is in
the real mode, secondary-space mode, access-reg-
ister mode, or home-space mode, or if the subsys-
tem-linkage control is zero, a special-operation
exception is recognized.

In PT-ss when ASN-and-LX reuse is enabled, the
reusable-ASN bit in the ASN-second-table entry
(ASTE) must be zero; otherwise, a special-operation
exception is recognized. In PTI-ss, regardless of the
ASN-and-LX-reuse control, a special-operation
exception is recognized if the controlled-ASN bit in
the ASTE is one and the CPU is in the problem state
at the beginning of the operation, and an ASTE-
instance exception is recognized if the ASTEIN in
general register R1 is not equal to the ASTEIN in the
ASTE.

Bit 63 of general register R3 is placed in the problem-
state bit position, PSW bit position 15, unless the
operation would cause PSW bit 15 to change from
one to zero (problem state to supervisor state). If
such a change would occur, a privileged-operation
exception is recognized.

In the 24-bit or 31-bit addressing mode, the instruc-
tion is completed only if bits 32-39 of general register
R2 specify a valid combination of PSW bits 32 and
97-103. If bit 32 of general register R2 is zero and bits
33-39 are not all zeros, a specification exception is
recognized.

In addition to the above requirements, when a PT-ss
or PTI-ss instruction is specified, the ASN-translation
control, bit 44 of control register 14, must be one;
otherwise, a special-operation exception is recog-
nized.

When, for PT-ss or PTI-ss, the primary space-switch-
event-control bit, bit 57 of register 1, is one either
before or after the execution of the instruction, a
space-switch-event program interruption occurs after
the operation is completed. A space-switch-event
program interruption also occurs after the completion
of a PT-ss or PTI-ss operation if a PER event is
reported.

The operation is suppressed on all addressing
exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
The priority of recognition of program exceptions for the instruction is shown in Figure 10-66.

<table>
<thead>
<tr>
<th>Exception Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.</td>
<td></td>
</tr>
<tr>
<td>7.B.1 Operation exception (PTI only, if the ASN-and-LX-reuse facility is not installed).</td>
<td></td>
</tr>
<tr>
<td>7.B.2 Special-operation exception due to DAT being off or the CPU being in secondary-space mode, access-register mode, or home-space mode.</td>
<td></td>
</tr>
<tr>
<td>8.A Trace exceptions.</td>
<td></td>
</tr>
<tr>
<td>8.B.1 Addressing exception for access to linkage-table designation or linkage-first-table designation in primary ASN-second-table entry.</td>
<td></td>
</tr>
<tr>
<td>8.B.2 Special-operation exception due to subsystem-linkage control in linkage-table designation or linkage-first-table designation being zero.</td>
<td></td>
</tr>
<tr>
<td>8.B.3 Privileged-operation exception due to attempt to set the supervisor state when in the problem state.</td>
<td></td>
</tr>
<tr>
<td>8.B.4 Specification exception due to invalid combination (bit 32 is zero and bits 33-39 not zeros) in general register R2 in 24-bit or 31-bit addressing mode.</td>
<td></td>
</tr>
</tbody>
</table>

**Programming Notes:**

1. The operation of PROGRAM TRANSFER (PT) is such that it may be used to restore the CPU to the state saved by a previous basic PROGRAM CALL operation. This restoration is accomplished by issuing PT 3,14. Though general registers 3 and 14 are not restored to their original values, the PASN, PSW-key mask, problem-state bit, and instruction address are restored, and the authorization index, PASCE, and primary-ASN-second-table-entry origin are made consistent with the restored PASN. In the 24-bit or 31-bit addressing mode, the basic-addressing-mode bit also is restored. If ASN-and-LX reuse is enabled, the PASTEIN also is made consistent with the restored PASN. Note that the SASN is not saved by PROGRAM CALL or restored by PROGRAM TRANSFER; PROGRAM TRANSFER sets the
SASN equal to the restored PASN. PROGRAM TRANSFER WITH INSTANCE is the same as PROGRAM TRANSFER except that the PAS-TEIN is made consistent regardless of ASN-and-LX-reuse enablement.

2. With proper authority, and while being executed in a common area, PROGRAM TRANSFER (WITH INSTANCE) may be used to change the primary address space to any desired space. The secondary address space is also changed to be the same as the new primary address space.

3. Unlike the RR-format branch instructions, a value of zero in the R₂ field for PROGRAM TRANSFER (WITH INSTANCE) designates general register 0, and branching occurs.

4. A program given control by a basic PROGRAM CALL operation can use EXTRACT SECONDARY ASN AND INSTANCE to obtain the ASTEIN to be used by PROGRAM TRANSFER WITH INSTANCE to return to the calling program or by SET SECONDARY ASN WITH INSTANCE to restore its secondary address space after a change of that space. This EXTRACT SECONDARY ASN AND INSTANCE instruction should be executed while the original secondary space remains continuously the secondary space; otherwise, depending on actions by the control program, EXTRACT SECONDARY ASN AND INSTANCE may return an ASTEIN that allows return to or use of a conceptually incorrect secondary space for which the ASTEIN has been changed.
Figure 10-67. Execution of PROGRAM TRANSFER (Part 1 of 2).
PT-ss

CR4 32-63

(x4096)

R1 32-63

PKM ASN

AFX ASX

(x4)

(x64)

ASN First Table

R I ASTO

(x64)

ASN-Second-Table

Special-operation exception if ASN-and-LX reuse enabled and RA is one.

R I ATO B AX ATL R ASCE ASTEIN***

(x4)

Authority Table

R P S

CR4 32-63 before

AX PASN

(x1/4)

CR4 after

PASTEIN*** AX PASN

CR3 after

SASTEIN*** See Part 1

CR1 after

PASCE

CR7 after

SASCE

CR5 32-63 after

PASTEO

0 000000

R: Address is real
*: ASTE is 64 bytes; selected fields and the last 16 bytes are not shown.
**: Bits 0-55 and 58-63 of PASCE and SASCE may be replaced from a subspace ASCE
***: Operations on the ASTE instance number performed if ASN-and-LX-reuse enabled

Figure 10-67. Execution of PROGRAM TRANSFER (Part 2 of 2).
PTI-cp and PTI-ss

PROGRAM TRANSFER WITH INSTANCE Instruction

'B99E' // // R1, R2

In 24-Bit or 31-Bit Mode

R2 32-63
A IA 33-62 P

PASCE

In 64-Bit Mode

R1 32-63
IA 0-62 P

PTI-ss (see part 2)

CR7 after
SASCE

Figure 10-68. Execution of PROGRAM TRANSFER WITH INSTANCE (Part 1 of 2).
Figure 10-68. Execution of PROGRAM TRANSFER WITH INSTANCE (Part 2 of 2).

R: Address is real
*: ASTE is 64 bytes; selected fields and the last 16 bytes are not shown.
**: Bits 0-55 and 58-63 of PASCE and SASCE may be replaced from a subspace ASCE
**PURGE ALB**

The ART-lookaside buffer (ALB) of this CPU is cleared of entries. No change is made to the contents of addressable storage or registers.

The ALB appears cleared of its original contents beginning with the execution of the next sequential instruction. The operation is not signaled to any other CPU.

A serialization function is performed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Privileged operation
- Transaction constraint

**PURGE TLB**

The translation-lookaside buffer (TLB) of this CPU is cleared of entries. No change is made to the contents of addressable storage or registers.

The TLB appears cleared of its original contents beginning with the fetching of the next sequential instruction. The operation is not signaled to any other CPU.

A serialization function is performed.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Privileged operation
- Transaction constraint

**RESET REFERENCE BIT EXTENDED**

The reference bit in the storage key for the 4K-byte block that is addressed by the contents of general register R₂ is set to zero. The contents of general register R₁ are ignored.

In the 24-bit addressing mode, bits 40-51 of general register R₂ designate a 4K-byte block in real storage, and bits 0-39 and 52-63 of the register are ignored. In the 31-bit addressing mode, bits 33-51 of general register R₂ designate a 4K-byte block in real storage, and bits 0-32 and 52-63 of the register are ignored. In the 64-bit addressing mode, bits 0-51 of general register R₂ designate a 4K-byte block in real storage, and bits 52-63 of the register are ignored.

Because it is a real address, the address designating the storage block is not subject to dynamic address translation. The reference to the storage key is not subject to a protection exception.

The remaining bits of the storage key, including the change bit, are not affected.

The condition code is set to reflect the state of the reference and change bits before the reference bit is set to zero.

**Resulting Condition Code:**

0 Reference bit zero; change bit zero
1 Reference bit zero; change bit one
2 Reference bit one; change bit zero
3 Reference bit one; change bit one

**Program Exceptions:**
- Addressing (address specified by general register R₂)
- Privileged operation
- Transaction constraint
Beginning with the block designated by the address in general register \( R_2 \), the reference bits in the storage keys of the 64 consecutive 4 K-byte blocks are inspected and reset. For each of the 64 blocks, the reference bit is placed in an ascending bit position of general register \( R_1 \), beginning with bit position 0 of the register. Subsequent to the inspection of each reference bit, the reference bit in the storage key is reset to zero.

General register \( R_2 \) designates the first of 64 blocks in absolute storage on a 64-block (256 K-byte) boundary. In the 24-bit addressing mode, bits 40-45 of the register, with six binary zeros appended on the right, designate the first block, and bits 0-39 and 46-63 of the register are ignored. In the 31-bit addressing mode, bits 33-45 of the register, with six binary zeros appended on the right, designate the first block, and bits 0-32 and 46-63 of the register are ignored. In the 64-bit addressing mode, bits 0-45 of the register, with six binary zeros appended on the right, designate the first block, and bits 46-63 of the register are ignored.

Because it is an absolute address, the address designating the first storage block is not subject to dynamic address translation. The references to the storage keys are not subject to protection exceptions.

The remaining bits of the storage keys are not affected.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Addressing (address specified by general register \( R_2 \))
- Operation (reset-reference-bits-multiple facility not installed)
- Privileged operation
- Transaction constraint

Certain contents of the current PSW and of access register and general register \( B_2 \) are replaced from three or four corresponding fields in the second operand. The size of the PSW field in the second operand, the size or number of general-register fields in the second operand, and the offsets of the fields in the second operand are specified in a parameter list that immediately follows the instruction in the instruction address space.

The instruction address space is the address space from which instructions are fetched. It is composed of real addresses if DAT is off.

The first 64 bits of the parameter list have the following format:

```
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 P R D Offset of PSW Field
0 1 3 5 1 6 3 1 Offset of AR Field Offset of GR Field 1
32 48 63 Offset of GR Field 2
64 79
```

When bits 14 (R) and 15 (D) of the parameter list are both one, the list is an additional 16 bits in length, as follows:

```
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 P R D Offset of PSW Field
0 1 3 5 1 6 3 1 Offset of AR Field Offset of GR Field 1
32 48 63 Offset of GR Field 2
64 79
```

Bit 13 of the parameter list (P) specifies the size of the PSW field in the second operand. The field is eight bytes if bit 13 is zero or 16 bytes if bit 13 is one.

Bits 14 and 15 of the parameter list (R and D) provide specifications about one or two general-register fields in the second operand, as follows:

- When bit 14 is zero, then bit 15 is ignored, the general-register field 1 in the second operand is four bytes, from which bits 32-63 of general register \( B_2 \) will be replaced, there is not a general-register field 2 in the second operand, and bits 0-31 of general register \( B_2 \) will remain unchanged.
RESUME PROGRAM

- When bit 14 is one and bit 15 is zero, then the general-register field 1 is eight bytes, from which bits 0-63 of general register $B_2$ will be replaced, and there is not a general-register field 2.

- When bits 14 and 15 are both one, then the general-register fields 1 and 2 are both four bytes, bits 32-63 of general register $B_2$ will be replaced from field 1, and bits 0-31 of the register will be replaced from field 2. (The letter “D” stands for disjoint.)

Bits 16-31 of the parameter list are an unsigned binary integer that is the offset in bytes from the beginning of the second operand to a field that has the format of an eight-byte or 16-byte PSW, depending on bit 13, and from which fields in the current PSW will be replaced. Bits 32-47 similarly are an offset to a four-byte field from which the contents of access register $B_2$ will be replaced. Bits 48-63 similarly are an offset to a four-byte or eight-byte field, depending on bits 14 and 15, from which bits 32-63 or 0-63, respectively, of general register $B_2$ will be replaced. If bits 64-79 of the parameter list exist, they similarly are an offset to a four-byte field from which bits 0-31 of general register $B_2$ will be replaced.

Bits 0-12 of the parameter list must be zeros; otherwise, a specification exception is recognized.

An eight-byte second-operand PSW field has the ESA/390 PSW format, as follows:

<table>
<thead>
<tr>
<th>16 and 17</th>
<th>Field Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>18 and 19</td>
<td>Address-space control (AS)</td>
</tr>
<tr>
<td>20-23</td>
<td>Condition code (CC)</td>
</tr>
<tr>
<td>31</td>
<td>Program mask</td>
</tr>
<tr>
<td>32</td>
<td>Extended addressing mode (EA)</td>
</tr>
<tr>
<td>64-127</td>
<td>Basic addressing mode (BA)</td>
</tr>
<tr>
<td></td>
<td>Instruction address</td>
</tr>
</tbody>
</table>

The remaining fields in the PSW field in the second operand are ignored. Specifically, there is no test for whether bit 12 is one in an eight-byte PSW or zero in a 16-byte PSW. There is also no test for whether bit 31 is zero in an eight-byte PSW.

Unassigned fields in the PSW may be assigned in the future and may then be among those restored by RESUME PROGRAM. Therefore, these fields in the PSW field in the second operand should contain zeros; otherwise, the program may not operate compatibly in the future.

When PSW bits 64-127 are replaced from an eight-byte PSW field in the second operand, they are replaced with bits 33-63 of the field, with 33 zeros appended on the left.

The fields in the second operand are fetched before the contents of access register $B_2$ and general register $B_2$ are changed.

When RESUME PROGRAM is the target of an execute-type instruction, the parameter list immediately follows the RESUME PROGRAM instruction, not the execute-type instruction.

The references to the parameter list are storage-operand fetches, not instruction fetches.

**Special Conditions**

The instruction is completed only if the bits 31, 32, and 64-127 that are to be placed in the current PSW are valid for placement in the PSW. If bits 31 and 32 are both zero and bits 64-103 are not all zeros, if bits 31 and 32 are zero and one, respectively, and bits 64-96 are not all zeros, if bits 31 and 32 are one and zero, respectively, or if bit 127 is one, a specification exception is recognized. A specification exception
may or may not result when bit 24 in the second operand is one.

The CPU must be in the supervisor state when the operation is to set the home-space mode; otherwise, a privileged-operation exception is recognized. When DAT is off, the values of bits 16 and 17 of the PSW field in the second operand are not tested.

When the CPU is in the home-space mode either before or after the operation, but not both before and after the operation, a space-switch-event program interruption occurs after the operation is completed if any of the following is true: (1) the primary space-switch-event control, bit 57 of the primary address-space-control element (ASCE) in control register 1, is one; (2) the home space-switch-event control, bit 57 of the home ASCE in control register 13, is one; or (3) a PER event is to be indicated.

The operation is suppressed on all addressing and protection exceptions.

**Resulting Condition Code:** The code is set as specified by the new condition code loaded.

**Program Exceptions:**

- Access (fetch, parameter list and operand 2)
- Privileged operation (attempt to set the home-space mode when in the problem state)
- Space-switch event
- Specification
- Trace
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-69.

| 1.-6. | Exceptions with the same priority as the priority of program-interruption conditions for the general case. |
| 8.A | Trace exceptions. |
| 8.B.1 | Access exceptions for bits 0-63 of parameter list. |

**Programming Notes:**

1. As described in “Instruction Fetching” on page 5-116, the bytes of an instruction may be fetched piecemeal, and the instruction may be fetched multiple times for a single execution. Therefore, the results are unpredictable when instructions are fetched for execution from storage that is being changed by another CPU or a channel program. This warning is particularly applicable when RESUME PROGRAM is the target of an execute-type instruction since the execute-type instruction may be refetched in order to generate, from its second operand, the address of the parameter list used by RESUME PROGRAM. If the execute-type instruction is refetched, there is not necessarily a test for whether storage still contains either the execute-type instruction or the RESUME PROGRAM instruction.

2. The storage-operand references for RESUME PROGRAM may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

**Figure 10-69. Priority of Execution: RESUME PROGRAM (Part 1 of 2)**

<table>
<thead>
<tr>
<th>SAC</th>
<th>D₂(B₂)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>B219'</td>
<td>B₂</td>
<td>D₂</td>
</tr>
</tbody>
</table>
SET ADDRESS SPACE CONTROL
FAST

SACF D_2(B_2) [S]

<table>
<thead>
<tr>
<th>B279</th>
<th>B_2</th>
<th>D_2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>

Bits 52-55 of the second-operand address are used as a code to set the address-space-control bits in the PSW. The second-operand address is not used to address data; instead, bits 52-55 form the code. Bits 0-51 and 56-63 of the second-operand address are ignored. Bits 52 and 53 of the second-operand address must be zeros; otherwise, a specification exception is recognized.

The following figure summarizes the operation of SET ADDRESS SPACE CONTROL and SET ADDRESS SPACE CONTROL FAST:

Second-Operand Address

<table>
<thead>
<tr>
<th>/ / / / / / / / / / / / / / / / / / / /</th>
<th>Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>32 52 56 63</td>
<td></td>
</tr>
</tbody>
</table>

Condition Code: The code remains unchanged.

Program Exceptions:

- Privileged operation (attempt to set the home-space mode in the problem state)
- Space-switch event
- Special operation
- Specification
- Transaction constraint

The priority of recognition of program exceptions for the instructions is shown in Figure 10-70.

Special Conditions

For SET ADDRESS SPACE CONTROL, the operation is performed only when the secondary-space control, bit 37 of control register 0, is one and DAT is on. When either the secondary-space control is zero or DAT is off, a special-operation exception is recognized. The same rules apply also to SET ADDRESS SPACE CONTROL FAST, except that whether the secondary-space control is tested is unpredictable.

When the CPU is in the home-space mode either before or after the operation, but not both before and after the operation, a space-switch-event program interruption occurs after the operation is completed if any of the following is true: (1) the primary space-switch-event control, bit 57 of the primary address-space-control element (ASCE) in control register 1, is one; (2) the home space-switch-event control, bit 57 of the home ASCE in control register 13, is one; or (3) a PER event is to be indicated.

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.


7.B Special-operation exception due to DAT being off.

7.C Special-operation exception due to the secondary-space control, bit 37 of control register 0, being zero. May be omitted for SET ADDRESS SPACE CONTROL FAST.


8. Privileged-operation exception due to attempt to set home-space mode when in problem state.

9. Specification exception due to nonzero value in bit positions 52 and 53 of second-operand address.

10. Space-switch event.

Figure 10-70. Priority of Execution: SET ADDRESS SPACE CONTROL and SET ADDRESS SPACE CONTROL FAST
Programming Notes:

1. SET ADDRESS SPACE CONTROL and SET ADDRESS SPACE CONTROL FAST are defined in such a way that the mode to be set can be placed directly in the displacement field of the instruction or can be specified from the same bit positions of a general register as those in which the mode is saved by INSERT ADDRESS SPACE CONTROL.

2. SET ADDRESS SPACE CONTROL FAST may provide better performance than SET ADDRESS SPACE CONTROL, depending on the model.

3. Because SET ADDRESS SPACE CONTROL FAST does not perform the serialization function, it does not cause copies of prefetched instructions to be discarded. To ensure predictable results after SET ADDRESS SPACE CONTROL FAST is used to switch to or from the home-space mode, the program must cause prefetched instructions to be discarded before an instruction is executed in a location that does not contain the same instruction in both the primary and home address spaces. The operations that cause prefetched instructions to be discarded are described in "Instruction Fetching" on page 5-116.

4. If a program stores into the instruction stream at a location following a subsequent SET ADDRESS SPACE CONTROL FAST instruction, and the SET ADDRESS SPACE CONTROL FAST instruction changes the translation mode either from or to the home-space mode, a copy of a prefetched instruction may be executed instead of the value that was stored. To avoid this situation, either SET ADDRESS SPACE CONTROL must be used instead of SET ADDRESS SPACE CONTROL FAST or some other means must be used to cause prefetched instructions to be discarded after the conceptual store occurs.

SET CLOCK

The current value of the TOD clock is replaced by the contents of the doubleword designated by the second-operand address, and the clock enters the stopped state.

The doubleword operand replaces the contents of the clock, as determined by the resolution of the clock. Only those bits of the operand are set in the clock that correspond to the bit positions which are updated by the clock; the contents of the remaining rightmost bit positions of the operand are ignored and are not preserved in the clock. In some models, starting at or to the right of bit position 52, the rightmost bits of the second operand are ignored, and the corresponding positions of the clock which are implemented are set to zeros. Zeros are also placed in positions to the right of bit position 63 of the clock.

After the clock value is set, the clock enters the stopped state. The clock leaves the stopped state to enter the set state and resume incrementing under control of the TOD-clock-sync control, bit 34 of control register 0, of the CPU which most recently caused the clock to enter the stopped state. When the bit is zero, the clock enters the set state at the completion of the instruction. When the bit is one, the clock remains in the stopped state until the bit is set to zero or until another CPU executes a SET CLOCK instruction affecting the clock. If an external time reference (ETR) is installed, a signal from the ETR may be used to set the set state from the stopped state. When the system is not in the interpretive-execution mode, and an external time reference (ETR) is not attached to the configuration, the TOD-clock-sync control is treated as being zero, regardless of its actual value; in this case, the clock enters the set state and resumes incrementing upon completion of the instruction.

The value of the clock is changed and the clock is placed in the stopped state only if the manual TOD-clock control of any CPU in the configuration is set to the enable-set position or the TOD-clock-control-override control, bit 42 of control register 14, is one. If the TOD-clock control of all CPUs is set to the secure position and the TOD-clock-control-override control is zero, the value and state of the clock are not changed. Whether the clock is set or remains unchanged is distinguished by condition codes 0 and 1, respectively.

When the clock is not operational, the value and state of the clock are not changed, regardless of the settings of the TOD-clock control and the TOD-clock-control-override control, and condition code 3 is set.
SET CLOCK COMPARATOR

SCKC \( D_j(B_j) \) [S]

<table>
<thead>
<tr>
<th>0</th>
<th>16</th>
<th>20</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B206'</td>
<td>( B_2 )</td>
<td>( D_2 )</td>
<td></td>
</tr>
</tbody>
</table>

The current value of the clock comparator is replaced by the contents of the doubleword designated by the second-operand address.

Only those bits of the operand are set in the clock comparator that correspond to the bit positions to be compared with the TOD clock; the contents of the remaining rightmost bit positions of the operand are ignored and are not preserved in the clock comparator.

### Special Conditions

The operand must be designated on a doubleword boundary; otherwise, a specification exception is recognized.

### Program Exceptions:

- Access (fetch, operand 2)
- Privileged operation
- Specification
- Transaction constraint

### Programming Notes:

1. SET CLOCK should be issued only while all other activity on all CPUs in the configuration has been suspended. This activity should not be resumed until after the TOD clock has entered the set state.

2. To ensure predictable operation of the CPU timer after the TOD clock enters the set state, SET CPU TIMER should be issued on all CPUs in the configuration.

3. To ensure predictable operation of clock-comparator interruptions after the TOD clock enters the set state, one of the following instructions should be issued on each CPU in the configuration: SET CLOCK COMPARATOR (SCKC), STORE CLOCK (STCK), or STORE CLOCK EXTENDED (STCKE). (Execution of STCKF does not necessarily include the interlocks required for this special situation.)

4. SET CLOCK is provided for compatibility purposes. It is recommended that, where possible, the program use the PTFF control function PTFF-STO (Set TOD Offset), rather than SET CLOCK.

---

SET CLOCK PROGRAMMABLE FIELD

SCKPF [E]

![Table with values '0107']

Bits 48-63 of general register 0 are placed in bit positions 16-31 of the TOD programmable register. Zeros are placed in bit positions 0-15 of the TOD programmable register.

### Special Conditions
Bits 32-47 of general register 0 must be zeros; otherwise, a specification exception is recognized. Bits 0-31 of general register 0 are ignored.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Privileged operation
- Specification
- Transaction constraint

**Programming Note:** The values in the TOD programmable registers of a configuration should be the same and should be unique within a multiple-configuration system.

## SET CPU TIMER

```plaintext
SPX  D(B)
  \[B208\] B2 D2 [S]
```

The current value of the CPU timer is replaced by the contents of the doubleword designated by the second-operand address.

Only those bits of the operand are set in the CPU timer that correspond to the bit positions to be updated; the contents of the remaining rightmost bit positions of the operand are ignored and are not preserved in the CPU timer.

**Special Conditions**

The operand must be designated on a doubleword boundary; otherwise, a specification exception is recognized.

The operation is suppressed on all addressing and protection exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Privileged operation
- Specification
- Transaction constraint

## SET PREFIX

```plaintext
SPX  D(B)
  \[B210\] B2 D2 [S]
```

The contents of bit positions 33-50 of the prefix register are replaced by the contents of bit positions 1-18 of the word at the location designated by the second-operand address. The ART-lookaside buffer (ALB) and translation-lookaside buffer (TLB) of this CPU are cleared of entries.

After the second operand is fetched, the value is tested for validity before it is used to replace the contents of the prefix register. Bits 1-18 of the operand with 13 zeros appended on the right and 33 zeros appended on the left are used as an absolute address of the 8K-byte new prefix area in storage. This address is treated as a 64-bit address regardless of the addressing mode specified by the current PSW. The two 4K-byte blocks within the new prefix area are accessed; if either is not available in the configuration, an addressing exception is recognized, and the operation is suppressed. The accesses to the blocks are not subject to protection; however, the accesses may cause the reference bits for the blocks to be set to ones.

If the operation is completed, the new prefix is used for any interruptions following the execution of the instruction and for the execution of subsequent instructions. The contents of bit positions 0 and 19-31 of the second operand are ignored.

The ART-lookaside buffer (ALB) and translation-lookaside buffer (TLB) are cleared of entries. The ALB and TLB appear cleared of their original contents, beginning with the fetching of the next sequential instruction.

A serialization function is performed before or after the second operand is fetched and again after the operation is completed.

**Special Conditions**

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

The operation is suppressed on all addressing and protection exceptions.
**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Addressing (new prefix area)
- Privileged operation
- Specification
- Transaction constraint

### SET PSW KEY FROM ADDRESS

```
SPKA      D2(B2)  [S]
'B20A'    B2     D2
```

The four-bit PSW key, bits 8-11 of the current PSW, is replaced by bits 56-59 of the second-operand address.

The second-operand address is not used to address data; instead, bits 56-59 of the address form the new PSW key. Bits 0-55 and 60-63 of the second-operand address are ignored.

**Special Conditions**

In the problem state, the execution of the instruction is subject to control by the PSW-key mask in control register 3. When the bit in the PSW-key mask corresponding to the PSW-key value to be set is one, the instruction is executed successfully. When the selected bit in the PSW-key mask is zero, a privileged-operation exception is recognized. In the supervisor state, any value for the PSW key is valid.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Privileged operation (selected PSW-key-mask bit is zero in the problem state)
- Transaction constraint

**Programming Notes:**
1. The format of SET PSW KEY FROM ADDRESS permits the program to set the PSW key either from the general register designated by the B2 field or from the D2 field in the instruction itself.

2. When one program requests another program to access a location designated by the requesting program, SET PSW KEY FROM ADDRESS can be used by the called program to verify that the requesting program is authorized to make this access, provided the storage location of the called program is not protected against fetching. The called program can perform the verification by replacing the PSW key with the requesting-program PSW key before making the access and subsequently restoring the called-program PSW key to its original value. Caution must be exercised, however, in handling any resulting protection exceptions since such exceptions may cause the operation to be terminated. See TEST PROTECTION and the associated programming notes for an alternative approach to the testing of addresses passed by a calling program.

### SET SECONDARY ASN

```
SSAR      R1      [RRE]
'B225'    R1      [RRE]
```

**Note:** In this instruction definition, the name “SET SECONDARY ASN (WITH INSTANCE)” refers to the SET SECONDARY ASN instruction and the SET SECONDARY ASN WITH INSTANCE instruction.

The ASN specified in bit positions 48-63 of general register R1 replaces the secondary ASN in control register 3, and the address-space-control element corresponding to that ASN replaces the SASCE in control register 7.

The contents of bit positions 48-63 of general register R1 are called the new ASN. For SET SECONDARY ASN WITH INSTANCE, bits 0-31 of the register are an STEIN and are compared against the new SASTEIN if the SASTEIN is not set equal to the PASTEIN, and bits 32-47 of the register are ignored. For
SET SECONDARY ASN, bits 0-47 of the register are ignored.

When the new ASN is equal to the current PASN, the operation is called SET SECONDARY ASN (WITH INSTANCE) to current primary (SSAR-cp or SSAIR-cp); when the fields are not equal, the operation is called SET SECONDARY ASN (WITH INSTANCE) with space switching (SSAR-ss or SSAIR-ss). The SSAR-cp and SSAR-ss operations are depicted in Figure 10-72 on page 10-124. The SSAIR-cp and SSAIR-ss operations are depicted in Figure 10-73 on page 10-125.

SET SECONDARY ASN (WITH INSTANCE) to Current Primary (SSAR-cp or SSAIR-cp)

In the SSAR-cp or SSAIR-cp operation, the new ASN is equal to the PASN. The new ASN replaces the SASN, bits 48-63 of control register 3; the PASCE in control register 1 replaces the SASCE in control register 7.

In SSAR-cp, if the ASN-and-LX-reuse facility is installed and is enabled by a one value of the ASN-and-LX-reuse control, bit 44 of control register 0, the SASTEIN in bit positions 0-31 of control register 3 is replaced by the PASTEIN in bit positions 0-31 of control register 4. This replacement occurs in SSAIR-cp regardless of the value of the ASN-and-LX-reuse control. In SSAR-cp, there is not a test of whether the current PASTEIN equals the ASTEIN in bit positions 0-31 of general register R1; the ASTEIN is ignored. The operation is completed.

SET SECONDARY ASN (WITH INSTANCE) with Space Switching (SSAR-ss or SSAIR-ss)

In the SSAR-ss or SSAIR-ss operation, the new ASN is not equal to the PASN, and the new ASN is translated by means of a two-level table lookup. Bits 0-9 of the new ASN (bits 48-57 of the register) are a 10-bit AFX which is used to select an entry from the ASN first table. Bits 10-15 of the new ASN (bits 58-63 of the register) are a six-bit ASX which is used to select an entry from the ASN second table. The two-level lookup is described in “ASN Translation” on page 3-27. The exceptions associated with ASN translation are collectively called “ASN-translation exceptions.” These exceptions and their priority are described in Chapter 6, “Interruptions.”

In SSAR-ss, if the ASN-and-LX-reuse facility is installed and is enabled by the ASN-and-LX-reuse control in control register 0, the reusable-ASN bit, bit 63, in the located ASN-second-table entry (ASTE) must be zero; otherwise, a special-operation exception is recognized. In SSAIR-ss, regardless of the ASN-and-LX-reuse control, the controlled-ASN bit, bit 62, in the ASTE must be zero in the problem state; otherwise, a special-operation exception is recognized. Also in SSAIR-ss, and regardless of the ASN-and-LX-reuse control and the reusable-ASN bit, the ASTEIN in bit positions 0-31 of general register R1 must equal the ASTEIN in bit positions 352-383 of the ASTE; otherwise, an ASTE-instance exception is recognized.

The ASN-second-table entry (ASTE) obtained as a result of the second lookup contains the address-space-control element and the authority-table origin and length associated with the ASN.

The authority-table origin from the ASTE is used as a base for a third table lookup. The current authorization index, bits 32-47 of control register 4, is used, after it has been checked against the authority-table length, as the index to locate the entry in the authority table. The authority-table lookup is described in “ASN Authorization” on page 3-32.

The new ASN, bits 48-63 of general register R1, replaces the SASN, bits 48-63 of control register 3. The address-space-control element in the ASTE replaces the SASCE in control register 7. In SSAR-ss if ASN-and-LX reuse is enabled, and in SSAIR-ss regardless of that enablement, the ASTEIN in the ASTE replaces the SASTEIN in bit positions 0-31 of control register 3.

The description in this paragraph applies to use of the subspace-group facility. After the new SASCE has been placed in control register 7, if (1) the subspace-group-control bit, bit 54, in the SASCE is one, (2) the dispatchable unit is subspace active, and (3) the ASTE obtained by ASN translation is the ASTE for the base space of the dispatchable unit, then bits 0-55 and 58-63 of the SASCE are replaced by the same bits of the ASCE in the ASTE for the subspace in which the dispatchable unit last had control. Further details are in “Subspace-Replacement Operations” on page 5-71.

SET SECONDARY ASN (WITH INSTANCE) Serialization

For any of the SSAR-cp, SSAIR-cp, SSAR-ss, and SSAIR-ss operations, a serialization and checkpoint-
synchronization function is performed before the operation begins and again after the operation is completed. However, it is unpredictable whether or not a store into a trace-table entry from which a subsequent instruction is fetched will be observed by the CPU that performed the store.

**Special Conditions**

The operation is performed only when the ASN-translation control, bit 44 of control register 14, is one and DAT is on. When either the ASN-translation-control bit is zero or DAT is off, a special-operation exception is recognized.

In SSAR-ss when ASN-and-LX reuse is enabled, the reusable-ASN bit in the ASN-second-table entry (ASTE) must be zero; otherwise, a special-operation exception is recognized. In SSAIR-ss, regardless of the ASN-and-LX-reuse control, a special-operation exception is recognized if the controlled-ASN bit in the ASTE is one and the CPU is in the problem state, and an ASTE-instance exception is recognized if the ASTEIN in general register R₁ is not equal to the ASTEIN in the ASTE.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Addressing (authority-table entry, SSAR-ss and SSAIR-ss only)
- ASN translation (SSAR-ss and SSAIR-ss only)
- ASTE instance (SSAR-ss only)
- Operation (if ASN-and-LX-reuse facility is not installed, SSAIR-ss only)
- Secondary authority (SSAR-ss and SSAIR-ss only)
- Special operation
- Subspace replacement (SSAR-ss and SSAIR-ss only)
- Trace
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-71 on page 10-122.

<table>
<thead>
<tr>
<th>Exception Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7.B.1</td>
<td>Operation exception (SSAIR only, if the ASN-and-LX-reuse facility is not installed).</td>
</tr>
<tr>
<td>7.B.2</td>
<td>Special-operation exception due to DAT being off, or the ASN-translation control, bit 44 of control register 14, being zero.</td>
</tr>
<tr>
<td>8.A</td>
<td>Trace exceptions.</td>
</tr>
<tr>
<td>8.B.1</td>
<td>ASN-translation exceptions (SSAR-ss and SSAIR-ss only).</td>
</tr>
<tr>
<td>8.B.2</td>
<td>Special-operation exception due to ASN-and-LX reuse enabled and reusable-ASN bit in ASN-second-table entry being one (SSAR-ss only).</td>
</tr>
<tr>
<td>8.B.3</td>
<td>Special-operation exception due to controlled-ASN bit in ASN-second-table entry being one in the problem state (SSAIR-ss only).</td>
</tr>
<tr>
<td>8.B.4</td>
<td>ASTE-instance exception due to ASTEIN in general register R₁ not being equal to ASTEIN in ASN-second-table entry (SSAIR-ss only).</td>
</tr>
</tbody>
</table>

**Note:** Subspace-replacement exceptions, which are not shown in detail in this figure, can occur with any priority after 8.B.4.

<table>
<thead>
<tr>
<th>Exception Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8.B.5</td>
<td>Secondary-authority exception due to authority-table entry being outside table (SSAR-ss and SSAIR-ss only).</td>
</tr>
<tr>
<td>8.B.6</td>
<td>Addressing exception for access to authority-table entry (SSAR-ss and SSAIR-ss only).</td>
</tr>
<tr>
<td>8.B.7</td>
<td>Secondary-authority exception due to S bit in authority-table entry being zero (SSAR-ss and SSAIR-ss only).</td>
</tr>
</tbody>
</table>

**Programming Note:** A program given control by a basic PROGRAM CALL operation can use EXTRACT SECONDARY ASN AND INSTANCE to obtain the ASTEIN to be used by PROGRAM TRANSFER WITH INSTANCE to return to the calling program or by SET SECONDARY ASN WITH INSTANCE to restore its secondary address space after a change of that space. This EXTRACT SECONDARY ASN AND INSTANCE instruction should be executed while the original secondary space remains continuously the secondary space; otherwise, depending on actions by the control program, EXTRACT SECONDARY ASN AND INSTANCE may
return an ASTEIN that allows return to or use of a conceptually incorrect secondary space for which the ASTEIN has been changed.
Figure 10-72. Execution of SET SECONDARY ASN

R: Address is real
*: ASTE is 64 bytes; selected fields and the last 16 bytes are not shown.
**: For SSAR-ss only, bits 0-55 and 58-63 of SASCE may be replaced from a subspace ASCE
Figure 10-73. Execution of SET SECONDARY ASN WITH INSTANCE Instruction
SET STORAGE KEY EXTENDED

SSKE R1,R2[M3] [RFF-c]

The storage key for one or more 4K-byte blocks is replaced by the value in the first-operand register. When the conditional-SSKE facility is installed, certain functions of the key-setting operation may be bypassed.

When the conditional-SSKE facility is not installed, or when the conditional-SSKE facility is installed and both the MR and MC bits of the M3 field are zero, the storage key for the 4K-byte block that is addressed by the contents of general register R2 is replaced by bits from general register R1. The instruction completes without changing the condition code.

When the conditional-SSKE facility is installed and either or both of the MR and MC bits are one, the access-control bits, fetch-protection bit, and, optionally, the reference bit and change bit of the storage key that is addressed by the contents of general register R2 are compared with corresponding bits in general register R1. If the compared bits are equal, then no change is made to the key; otherwise, selected bits of the key are replaced by the corresponding bits in general register R1. The storage key prior to any modification is inserted in general register R1, and the result is indicated by the condition code.

When the enhanced-DAT facility is installed, the above operations may be repeated for the storage keys of multiple 4K-byte blocks within the same 1MB block, subject to the control of the multiple-block control, described below.

The M3 field has the following format:

<table>
<thead>
<tr>
<th>MMMM</th>
<th>O</th>
<th>R</th>
<th>C</th>
<th>B</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 2 3</td>
<td>0</td>
<td>1</td>
<td>2</td>
<td>3</td>
</tr>
</tbody>
</table>

The bits of the M3 field are defined as follows:

- **Nonquiescing Control (NQ):** The NQ bit, bit 0 of the M3 field, controls whether a quiescing operation is performed, as described below.

- **Reference-Bit-Update Mask (MR):** The MR bit, bit 1 of the M3 field, controls whether updates to the reference bit in the storage key may be bypassed, as described below.

- **Change-Bit-Update Mask (MC):** The MC bit, bit 2 of the M3 field, controls whether updates to the change bit in the storage key may be bypassed, as described below.

- **Multiple-Block Control (MB):** The MB bit, bit 3 of the M3 field, controls whether the storage keys for multiple 4K-byte blocks of storage may be set, as described in “Setting Storage Keys in Multiple 4K-Byte Blocks” on page 10-128.

When the nonquiescing key-setting facility is not installed, bit 0 of the M3 field is ignored. When the conditional-SSKE facility is not installed, bit positions 1 and 2 of the M3 field are ignored. When the enhanced-DAT facility is not installed, bit position 3 of the M3 field is ignored.

When the conditional-SSKE facility is installed, processing is as follows:

1. When both the MR and MC bits, bits 1 and 2 of the M3 field, are zero, the instruction completes as though the conditional-SSKE facility was not installed. The storage key for the 4K-byte block that is addressed by the contents of general register R2 is replaced by bits from general register R1, and the instruction completes without changing the condition code.

2. When either or both the MR and MC bits are one, processing is as follows:

   a. Prior to any modification, the contents of the storage key for the 4K-byte block that is addressed by general register R2 are placed in bit positions 48-54 of general register R1, and bit 55 of general register R1 is set to zero. Bits 0-47 and 56-63 of the register remain unchanged.

   If an invalid checking-block code (CBC) is detected when fetching the storage key, then (a) the entire storage key for the 4K-byte block is replaced by bits 56-62 of general register R1, (b) the contents of bit positions 48-55 of general register R1 are unpredictable, and (c) the instruction completes by setting condition code 3.
b. The access-control bits and fetch-protection bit of the storage key for the designated 4K-byte block are compared with the corresponding fields in bits 56-60 of general register R1. If the respective fields are not equal, the entire storage key for the 4K-byte block is replaced by bits from general register R1, and the instruction completes by setting condition code 1.

When the access-control and fetch-protection bits in the storage key are equal to the respective bits in general register R1, processing continues as described below.

c. When both the MR and MC bits are one, the instruction completes by setting condition code 0. The storage key remains unchanged in this case.

d. When the MR bit is zero and the MC bit is one, then the reference bit of the storage key for the designated 4K-byte block is compared with bit 61 of general register R1. If the bits are equal, the instruction completes by setting condition code 0. The storage key remains unchanged in this case.

If the bits are not equal, then either (a) the entire storage key for the designated 4K-byte block is replaced by the bits in general register R1, and the instruction completes by setting condition code 1; or (b) the reference bit for the storage key is replaced by bit 62 of general register R1, the reference bit for the key is unpredictable, and the instruction completes by setting condition code 2. It is unpredictable whether condition code 1 or 2 is set.

When the enhanced-DAT facility 1 is not installed, or when the facility is installed but the multiple-block control is zero, general register R2 contains a real address. When the enhanced-DAT facility 1 is installed and the multiple-block control is one, general register R2 contains an absolute address.

In the 24-bit addressing mode, bits 40-51 of general register R2 designate a 4K-byte block in real or absolute storage, and bits 0-39 and 52-63 of the register are ignored. In the 31-bit addressing mode, bits 33-51 of general register R2 designate a 4K-byte block in real or absolute storage, and bits 0-32 and 52-63 of the register are ignored. In the 64-bit addressing mode, bits 0-51 of general register R2 designate a 4K-byte block in real or absolute storage, and bits 52-63 of the register are ignored.

Because it is a real or absolute address, the address designating the storage block is not subject to dynamic address translation. The reference to the storage key is not subject to a protection exception.

The new seven-bit storage-key value, or selected bits thereof, is obtained from bit positions 56-62 of general register R1. The contents of bit positions 0-55 and 63 of the register are ignored. When the conditional-SSKE facility is installed, and either or both the MR and MC bits are one, bit position 63 should contain a zero; otherwise, the program may not operate compatibly in the future.

A serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed, except that when the conditional-SSKE facility is installed and the resulting condition code is 0, it is unpredictable whether a serialization and checkpoint-synchronization function is performed after the operation completes.

When the nonquiescing key-setting facility is not installed, or when the facility is installed and the nonquiescing control (NQ) is zero, the following applies:

- A quiescing operation is performed.
For any store access, by any CPU or channel program, completed to the designated 4K-byte block either before or after the setting of the key by this instruction, the associated setting of the reference and change bits to one in the storage key for the block also is completed before or after, respectively, the execution of this instruction.

When the nonquiescing key-setting facility is installed and the NQ control is one, a quiescing operation is not necessarily performed. See “Storage-Key Accesses” on page 5-118 for a discussion the effects of quiescing on key-setting instructions, and see “Quiescing” on page 5-131 for details on the quiescing operation.

Setting Storage Keys in Multiple 4K-Byte Blocks
When the enhanced-DAT facility 1 is not installed, or when the facility is installed, but the multiple-block control is zero, the storage key for a single 4K-byte block is set, as described above.

When the enhanced-DAT facility 1 is installed, and the multiple-block control is one, the storage keys for multiple 4K-byte blocks within a 1M-byte block may be set, beginning with the block specified by the second-operand address, and continuing to the right with each successive block up to the next 1M-byte boundary. In this case, SET STORAGE KEY EXTENDED is interruptible, and processing is as follows:

- When an interruption occurs (other than one that follows termination), the leftmost bits of general register \( R_2 \) comprising the 4K-byte block address have been updated so the instruction, when reexecuted, resumes at the point of interruption. If either or both the MR or MC bits are one, the condition code is unpredictable; otherwise, the condition code is unchanged.

- When the instruction completes without interruption, the leftmost bits of general register \( R_2 \) comprising the 4K-byte block address have been updated to the next 1M-byte boundary. If either or both the MR or MC bits are one, condition code 3 is set; otherwise, the condition code is unchanged.

In either of the above two cases, the following applies:

- Bits 52-63 of general register \( R_2 \) remain unchanged.

Bits 48-55 of general register \( R_1 \) are unpredictable.

When multiple-block processing occurs and the \( R_1 \) and \( R_2 \) fields designate the same register, the second-operand address is placed in the register. When multiple-block processing occurs in the 24-bit or 31-bit addressing modes, the leftmost bits which are not part of the address in bit positions 32-63 of general register \( R_2 \) are set to zeros; bits 0-31 of the register are unchanged.

Before a quiescing key-setting operation is performed, transactional execution by other CPUs in the configuration is aborted with abort code 255, condition code 2. The aborting of transactional execution affects at least those CPUs accessing the locations (transactionally or nontransactionally) for which storage keys are being set. It is unpredictable whether some or all other CPUs are affected as well.

Resulting Condition Code:
When the conditional-SSKE facility is not installed, or when both the MR and MC bits of the \( M_3 \) field are zero, the condition code remains unchanged.

When the conditional-SSKE facility is installed, and either or both of the MR and MC bits are one, the condition code is set as follows:

0 Storage key not set
1 Entire storage key set
2 Partial storage key set
3 Entire storage key set; bits 48-55 of general register \( R_1 \) are unpredictable.

Program Exceptions:
- Addressing (address specified by general register \( R_2 \))
- Privileged operation
- Transaction constraint

Programming Notes:
1. The \( M_3 \) field of the instruction is considered to be optional, as indicated by the field being contained within brackets [ ] in the assembler syntax.
When the M₃ field is not specified, the assembler places zeros in that field of the instruction.

2. When setting multiple storage keys within the same 1M-byte block to the same value, use of the multiple-block control (MB, bit 3 of the M₃ field) may yield better performance than executing separate SSKE instructions for each 4K-byte block in the megabyte.

3. If the program does not rely on the setting of the reference bit, it may set the MR bit of the M₃ field to one, regardless of whether or not the conditional-SSKE facility is installed. Similarly, if the program does not rely on the setting of the change bit, it may set the MC bit of the M₃ field to one, regardless of whether or not the conditional-SSKE facility is installed. In these cases, the program cannot rely on the condition code or the key value returned in general register R₃. Conversely, if the program depends on accurate setting of the reference or change bit, then the MR and MC bits should be set to zero, such that reference and change bit recording are properly maintained when the conditional-SSKE facility is installed.

4. When SSKE is issued, the program must ensure that no channel subsystem is simultaneously altering the storage designated by general register R₂. The program also must ensure that no other CPU or channel subsystem is accessing the storage designated by general register R₂ when the nonquiescing (NQ) control is one. Otherwise, unpredictable results may be observed by the other CPUs and channel subsystem, including the alteration of the block designated by general register R₂.

5. Even when the enhanced-DAT facility 2 is installed, the multiple-block control is limited to setting keys in a 1 M-byte block; no provision is made for setting keys in a 2 G-byte block with SSKE. PERFORM FRAME MANAGEMENT FUNCTION with a set-key control of 1 and frame-size code of 2 may be used to set the keys of a 2 G-byte block. See “PERFORM FRAME MANAGEMENT FUNCTION” on page 10-76 for additional details.

6. See the programming note on page 5-120 for restrictions on the use of the nonquiescing control.

### SET SYSTEM MASK

<table>
<thead>
<tr>
<th>SSM</th>
<th>D₃(B₂)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>16</td>
</tr>
</tbody>
</table>

Bits 0-7 of the current PSW are replaced by the byte at the location designated by the second-operand address.

**Special Conditions**

When the SSM-suppression-control bit, bit 33 of control register 0, is one and the CPU is in the supervisor state, a special-operation exception is recognized.

The value to be loaded into the PSW is not checked for validity before loading. However, immediately after loading, a specification exception is recognized, and a program interruption occurs, if the contents of bit positions 0 and 2-4 of the PSW are not all zeros. In this case, the instruction is completed, and the instruction-length code is set to 2 or 3. The specification exception, which is listed as a program exception for this instruction, is described in “Early Exception Recognition” on page 6-9.

The operation is suppressed on all addressing and protection exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Privileged operation
- Special operation
- Specification
- Transaction constraint

### SIGNAL PROCESSOR

An eight-bit order code and, if called for, a 64-bit parameter are transmitted to the CPU designated by the CPU address contained in the third operand. The result is indicated by the condition code and may be
detailed by status assembled in bit positions 32-63 of the first-operand location.

The second-operand address is not used to address data; instead, bits 56-63 of the address contain the eight-bit order code. Bits 0-55 of the second-operand address are ignored. The order code specifies the function to be performed by the addressed CPU. The assignment and definition of order codes appear in “CPU Signaling and Response” on page 4-64.

The 16-bit binary number contained in bit positions 48-63 of general register R₃ forms the CPU address. Bits 0-47 of the register are ignored. When the specified order is the set-architecture or set multithreading order, the CPU address is ignored; all CPUs in the configuration are considered to be addressed. See “CPU-Address Identification” on page 4-63 for details on the CPU address.

The general register containing the 64-bit parameter in bit positions 0-63 is R₁ or R₁+1, whichever is the odd-numbered register. It depends on the order code whether a parameter is provided and for what purpose it is used.

The operands just described have the following formats:

General register designated by R₁:

```
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
```

Status

```
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
```

General register designated by R₁ or R₁+1, whichever is the odd-numbered register:

```
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
```

Parameter

```
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
```

Parameter (continued)

```
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
```

General register designated by R₃:

```
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
```

CPU Address

```
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
```

A serialization function is performed before the operation begins and again after the operation is completed.

When the order code is accepted and no nonzero status is returned, condition code 0 is set. When status information is generated by this CPU or returned by the addressed CPU, the status is placed in bit positions 32-63 of general register R₁, bits 0-31 of the register remain unchanged, and condition code 1 is set.

When the access path to the addressed CPU is busy, or the addressed CPU is operational but in a state where it cannot respond to the order code, condition code 2 is set.

When the addressed CPU is not operational (that is, it is not provided in the installation, it is not in the configuration, it is in any of certain customer-engineer test modes, or its power is off), condition code 3 is set.

**Resulting Condition Code:**

0 Order code accepted
1 Status stored
2 Busy
3 Not operational

**Program Exceptions:**

- Privileged operation
- Transaction constraint

**Programming Notes:**

1. A more detailed discussion of the condition-code settings for SIGNAL PROCESSOR is contained in “CPU Signaling and Response” on page 4-64.
2. To ensure that presently written programs will be executed properly when new facilities using additional bits are installed, only zeros should appear in the unused bit positions of the second-oper-
and address and in bit positions 32-47 of general register R3.

3. Certain SIGNAL PROCESSOR orders are provided with the expectation that they will be used primarily in special circumstances. Such orders may be implemented with the aid of an auxiliary maintenance or service processor, and, thus, the execution time may take several seconds. Unless all of the functions provided by the order are required, combinations of other orders, in conjunction with appropriate programming support, can be expected to provide a specific function more rapidly. The following orders are the only orders which are intended for frequent use:

- Conditional emergency signal
- Emergency-signal
- External-call
- Sense
- Sense-running-status

The following orders are intended for infrequent use, and performance therefore may be much slower than for frequently used orders:

- CPU reset
- Initial CPU reset
- Restart
- Set architecture
- Set multithreading
- Set prefix
- Store additional status at address
- Store status at address
- Start
- Stop
- Stop and store status

An alternative to the set-prefix order, for faster performance when the receiving CPU is not already stopped, is the use of the emergency-signal or external-call order, followed by the execution of a SET PREFIX instruction on the addressed CPU. Clearing the TLB of entries is ordinarily accomplished more rapidly through the use of the emergency-signal or external-call order, followed by execution of the PURGE TLB instruction on the addressed CPU, than by use of the set-prefix order.

---

### STORE CLOCK COMPARATOR

<table>
<thead>
<tr>
<th>STCKC</th>
<th>D2(B2)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>B207</td>
<td>B2</td>
<td>D2</td>
</tr>
</tbody>
</table>

The current value of the clock comparator is stored at the doubleword location designated by the second-operand address.

Zeros are provided for the rightmost bit positions of the clock comparator that are not compared with the TOD clock.

**Special Conditions**

The operand must be designated on a doubleword boundary; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 2)
- Privileged operation
- Specification
- Transaction constraint

---

### STORE CONTROL

<table>
<thead>
<tr>
<th>STCTL</th>
<th>R1,R3,D2(B2)</th>
<th>[RS-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>B6</td>
<td>R1 R3 B2 D2</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>STCTG</th>
<th>R1,R3,D2(B2)</th>
<th>[RSY-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>EB</td>
<td>R1 R3 B2 DL2 DH2</td>
<td>'25'</td>
</tr>
</tbody>
</table>

Bits of the set of control registers starting with control register R1 and ending with control register R3 are stored at the locations designated by the second-operand address.

For STORE CONTROL (STCTL), bits 32-63 of the control registers are stored in successive words beginning at the second-operand address, and bits 0-31 of the registers are ignored. For STORE CONTROL (STCTG), bits 0-63 of the control registers are...
stored in successive doublewords beginning at the second-operand address.

The storage area where the contents of the control registers are placed starts at the location designated by the second-operand address and continues through as many storage words, for STCTL, or doublewords, for STCTG, as the number of control registers specified. The contents of the control registers are stored in ascending order of their register numbers, starting with control register R1 and continuing up to and including control register R3, with control register 0 following control register 15. The contents of the control registers remain unchanged.

The displacement for STCTL is treated as a 12-bit unsigned binary integer. The displacement for STCTG is treated as a 20-bit signed binary integer.

Special Conditions

The second operand must be designated on a word boundary for STCTL or on a doubleword boundary for STCTG; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

Program Exceptions:

- Access (store, operand 2)
- Privileged operation
- Specification
- Transaction constraint

STORE CPU ADDRESS

STAP D j (B j) [S]

The CPU address by which this CPU is identified in a multiprocessing configuration is stored at the halfword location designated by the second-operand address.

Special Conditions

The operand must be designated on a halfword boundary; otherwise, a specification exception is recognized.

STORE CPU ID

STIDP D j (B j) [S]

Information identifying either (1) the CPU or (2) the configuration and the logical partition in which the program is being executed is stored at the doubleword location designated by the second-operand address.

The information stored has the following format:

<table>
<thead>
<tr>
<th>Bit positions 0-7</th>
<th>8-31</th>
<th>32-47</th>
<th>48-63</th>
</tr>
</thead>
<tbody>
<tr>
<td>CPU Identification Number</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Machine-Type Number</td>
<td>F</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
</tbody>
</table>

Bit positions 8-31 contain the CPU identification number, consisting of six four-bit digits. Some or all of these digits are selected from the physical serial number stamped on the CPU.

The format bit (F) in bit position 48 specifies the format of the first two digits of the CPU identification number.

When the format bit is zero, the contents of the CPU-identification-number field identifies the CPU. When the format bit is one, the CPU-identification number identifies the system configuration as opposed to an individual CPU within the configuration, and it identifies the logical partition in which the program is being executed.

Bit positions 32-47 contain the machine-type number of the CPU. Bit positions 0-7 and 49-63 contain zeros.

Special Conditions
The operand must be designated on a doubleword boundary; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Privileged operation
- Specification
- Transaction constraint

**Programming Notes:**

1. The program should allow for the possibility that the CPU identification number may contain the hexadecimal digits A-F as well as the digits 0-9.

2. When the format bit in bit position 48 of the second operand is one, the CPU-identification number identifies the system configuration as opposed to an individual CPU within the configuration, and it identifies the requesting logical partition. The CPU identity can be obtained using the STORE CPU ADDRESS or the STORE SYSTEM INFORMATION instruction.

3. In versions of *Enterprise Systems Architecture/390 Principles of Operation* prior to SA22-7201-03, the machine-type-number field was called the model-number field.

4. In ESA/390, bit positions 0-7 of the information stored contain a version code. When the version code is nonzero, it is usually indicative of the model number of the model and the number of CPUs contained in the model. In both ESA/390 and z/Architecture, the STORE SYSTEM INFORMATION instruction can be used to determine the model number and the number of CPUs in the model.

5. The CPU identification number has the hex format:
   - “Annnnn” in the basic mode, or
   - LPnnnn” in the LPAR (logically-partitioned) mode, when the format bit is zero, or
   - PPnnnn” in the LPAR mode, when the format bit is one.

   Where:
   - A is the CPU address of the CPU.
   - L is a logical CPU address.
   - P is a logical-partition identifier.
   - PP is the user partition identifier (UPID). The UPID is an eight-bit unsigned binary integer bound to a logical partition.
   - n is a digit derived from the serial number of the CPU.

The terminology above that is not defined in this publication is defined in the appropriate System Library publications for the model.

6. The format bit is always stored as a zero in the basic mode.

7. IBM eServer zSeries 800 and 900 machines always store the format bit as a zero.

8. When STORE CPU ID is executed in a virtual machine, the VM operating system replaces bits 0-7 of the information stored with FF hex. See *z/VM CP Programming Services* (SC24-6179) for additional details.

9. In order to ensure world-wide unique identification of the configuration of the issuing CPU, the STORE SYSTEM INFORMATION instruction specifying SYSIB 1.1.1, 1.2.1, or 2.2.1 should be used.

**STORE CPU TIMER**

STPT D 2(B2) [S]

The current value of the CPU timer is stored at the doubleword location designated by the second operand address.

Zeros are provided for the rightmost bit positions that are not updated by the CPU timer.

**Special Conditions**

The operand must be designated on a doubleword boundary; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Privileged operation

10-133
STORE FACILITY LIST

STFL D2(B2) [S]

A list of bits providing information about facilities is stored in the word at real address 200. The meanings of the bits are identical to the first 32 bits stored by STORE FACILITY LIST EXTENDED. Figure 4-24, “Assigned Facility Bits” on page 4-76 shows the meanings of the assigned facility bits.

The second-operand address is ignored but should be zero to permit possible future extensions.

Key-controlled and low-address protection do not apply.

Condition Code:  The code remains unchanged.

Program Exceptions:
- Privileged operation
- Specification
- Transaction constraint

Programming Note:  STORE FACILITY LIST stores only a 32-bit indication of facilities. STORE FACILITY LIST EXTENDED may be used to store the entire list of installed facilities.

STORE PREFIX

STPX D2(B2) [S]

The contents of bit positions 33-50 of the prefix register are stored in bit positions 1-18 of the word location designated by the second-operand address, and zeros are stored in bit positions 0 and 19-31 of the word.

Special Conditions

The operand must be designated on a word boundary; otherwise, a specification exception is recognized.

Condition Code:  The code remains unchanged.

Program Exceptions:
- Access (store, operand 2)
- Privileged operation
- Specification
- Transaction constraint

STORE REAL ADDRESS

STRAG D4(B4),D2(B2) [SSE]

The 64-bit real address corresponding to the second-operand virtual address is stored in the doubleword at the location designated by the first-operand address.

The virtual address specified by the B2 and D2 fields is translated by means of the dynamic-address-translation facility, regardless of whether DAT is on or off.

DAT is performed by using an address-space-control element that depends on the current value of the address-space-control bits, bits 16 and 17 of the PSW, as shown in the following table:

<table>
<thead>
<tr>
<th>PSW Bits 16 and 17</th>
<th>Address-Space-Control Element Used by DAT</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Contents of control register 1</td>
</tr>
<tr>
<td>10</td>
<td>Contents of control register 7</td>
</tr>
<tr>
<td>01</td>
<td>The address-space-control element obtained by applying the access-register-translation (ART) process to the access register designated by the B2 field</td>
</tr>
<tr>
<td>11</td>
<td>Contents of control register 13</td>
</tr>
</tbody>
</table>

ART and DAT may be performed with the use of the ART-lookaside buffer (ALB) and translation-lookaside buffer (TLB), respectively.

The resultant 64-bit real address is stored at the first-operand location.

The translated address is not inspected for boundary alignment or for addressing or protection exceptions.
The address computations for the operands are performed according to the current addressing mode, specified by bits 31 and 32 of the current PSW.

The addresses of the region-table entry or entries, if used, and of the segment-table entry and page-table entry are treated as 64-bit addresses regardless of the current addressing mode. It is unpredictable whether the addresses of these entries are treated as real or absolute addresses.

**Special Conditions**

The first operand must be designated on a double-word boundary; otherwise, a specification exception is recognized.

The operation is suppressed on all addressing exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2, except for an addressing or protection exception for the designated location; store, operand 1)
- Privileged operation
- Specification
- Transaction constraint

**Programming Note:** STORE REAL ADDRESS is contrasted to LOAD REAL ADDRESS as follows:

- In the 24-bit or 31-bit addressing mode, LOAD REAL ADDRESS (LRA) loads bits 33-63 of the real address if bits 0-32 of the address are all zeros or recognizes a special-operation exception if bits 0-32 are not all zeros. LRA in the 64-bit addressing mode, and LOAD REAL ADDRESS (LRAG) in any addressing mode, loads bits 0-63 of the real address. STORE REAL ADDRESS stores bits 0-63 of the real address in any addressing mode.

- LOAD REAL ADDRESS, for most access-exception conditions, does not recognize the conditions as exceptions but instead sets the condition code to indicate the occurrence of the conditions. STORE REAL ADDRESS recognizes all access-exception conditions as exceptions, resulting in a program interruption.

**STORE SYSTEM INFORMATION**

<table>
<thead>
<tr>
<th>STSI</th>
<th>D₂(B₂)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>'B27D'</td>
<td></td>
</tr>
</tbody>
</table>

Depending on a function code in general register 0, either an identification of the level of the configuration executing the program is placed in general register 0 or information about a component or components of a configuration is stored in a system-information block (SYSIB). When information about a component or components is requested, the information is specified by further contents of general register 0 and by contents of general register 1. The SYSIB, if any, is designated by the second-operand address.

The machine is considered to provide one, two, or three levels of configuration. The levels are:

1. The basic machine, which is the machine as if it were operating in the basic mode.
2. A logical partition, which is provided if the machine is operating in the LPAR, or logically-partitioned, mode. A logical partition is provided by the LPAR hypervisor, which is a part of the machine. A basic machine exists even when the machine is operating in the LPAR mode.
3. A virtual machine, which is provided by a virtual-machine (VM) control program that is executed either by the basic machine or in a logical partition. A virtual machine may itself execute a VM control program that provides a higher-level (more removed from the basic machine) virtual machine, which also is considered a level-3 configuration.

The terms basic mode, LPAR mode, logical partition, hypervisor, and virtual machine, and any other terms related specifically to those terms, are not defined in this publication; they are defined in the machine manuals.

A program being executed by a level-1 configuration (the basic machine) can request information about that configuration. A program being executed by a level-2 configuration (in a logical partition) can request information about the logical partition and about the underlying basic machine. A program being executed by a level-3 configuration (a virtual machine) can request information about the virtual...
machine and about the one or two underlying levels; a basic machine is always underlying, and a logical partition may or may not be between the basic machine and the virtual machine. When information about a virtual machine is requested, information is provided about the configuration executing the program and about any underlying level or levels of virtual machine.

The function code determining the operation is an unsigned binary integer in bit positions 32-35 of general register 0 and is as follows:

<table>
<thead>
<tr>
<th>Function Code</th>
<th>Information Requested</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Current-configuration-level number</td>
</tr>
<tr>
<td>1</td>
<td>Information about level 1 (the basic machine)</td>
</tr>
<tr>
<td>2</td>
<td>Information about level 2 (a logical partition)</td>
</tr>
<tr>
<td>3</td>
<td>Information about level 3 (a virtual machine)</td>
</tr>
<tr>
<td>4-14</td>
<td>None; codes are reserved</td>
</tr>
<tr>
<td>15</td>
<td>Current-configuration-level information</td>
</tr>
</tbody>
</table>

Invalid Function Code

The level of the configuration executing the program is called the current level. The configuration level specified by a nonzero function code (other than 15) is called the specified level. When the specified level is numbered higher than the current level, then the function code is called invalid, the condition code is set to 3, and no other action (including checking) is performed. Function code 15 is invalid when the configuration-topology facility is not installed.

Valid Function Code

When the function code is equal to or less than the number of the current level, or 15, it is called valid. In this case, bits 36-55 of general register 0 and bits 32-47 of general register 1 must be zero; otherwise, a specification exception is recognized. Bits 0-31 of general registers 0 and 1 always are ignored.

When the function code is 0, an unsigned binary integer identifying the current configuration level (1 for basic machine, 2 for logical partition, or 3 for virtual machine) is placed in bit positions 32-35 of general register 0, the condition code is set to 0, and no further action is performed.

When the function code is valid and nonzero, general registers 0 and 1 contain additional specifications about the information requested, as follows:

- Bit positions 56-63 of general register 0 contain an unsigned binary integer, called selector 1, that specifies a component or components of the specified configuration.
- Bit positions 48-63 of general register 1 contain an unsigned binary integer, called selector 2, that specifies the type of information requested.

The contents of general registers 0 and 1 are as follows:

**General Register 0**

<table>
<thead>
<tr>
<th>Selector 1</th>
<th>0000000000000000000000000000000000000000000000000000000000000000</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0000000000000000000000000000000000000000000000000000000000000000</td>
</tr>
</tbody>
</table>

**General Register 1**

<table>
<thead>
<tr>
<th>Selector 2</th>
<th>0000000000000000000000000000000000000000000000000000000000000000</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0000000000000000000000000000000000000000000000000000000000000000</td>
</tr>
</tbody>
</table>

When the function code is valid and nonzero, information may be stored in a system-information block (SYSIB) beginning at the second-operand location. The SYSIB is 4K bytes and must begin at a 4K-byte boundary; otherwise, a specification exception may be recognized, depending on selector 1 and selector 2 and on whether access exceptions are recognized due to references to the SYSIB (see “Special Conditions”).

Selector 1 can have values as follows:

<table>
<thead>
<tr>
<th>Selector 1</th>
<th>Information Requested</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>None; selector is reserved</td>
</tr>
<tr>
<td>1</td>
<td>Information about the configuration level specified by the function code.</td>
</tr>
<tr>
<td>2</td>
<td>Information about one or more CPUs in the specified configuration level</td>
</tr>
<tr>
<td>3-255</td>
<td>None; selectors are reserved</td>
</tr>
</tbody>
</table>

When selector 1 is 1, selector 2 can have values as follows:

**Selector 2**

<table>
<thead>
<tr>
<th>When Selector 1 Is 1</th>
<th>Information Requested</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>None; selector is reserved</td>
</tr>
<tr>
<td>1</td>
<td>Information about the specified configuration level</td>
</tr>
</tbody>
</table>
When selector 1 is 2, selector 2 can have values as follows:

<table>
<thead>
<tr>
<th>Selector 2 when Selector 1 Is 2</th>
<th>Information Requested</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>None; selector is reserved</td>
</tr>
<tr>
<td>1</td>
<td>Information about the CPU executing the program in the specified configuration level</td>
</tr>
<tr>
<td>2</td>
<td>Information about all CPUs in the specified configuration level</td>
</tr>
<tr>
<td>3-65,535</td>
<td>None; selectors are reserved</td>
</tr>
</tbody>
</table>

Only certain combinations of the function code, selector 1, and selector 2 are valid, as shown in Figure 10-74.

**SYSIB 1.1.1 (Basic-Machine Configuration)**

SYSIB 1.1.1 is illustrated in Figure 10-75:

```
0 1 1 Basic-machine configuration
1 1 2 Basic-machine CPU
1 2 2 Basic-machine CPUs
2 2 1 Logical-partition CPU
2 2 2 Logical-partition CPUs
3 2 2 Virtual-machine CPUs
15 1 2-6 Topology information of current configuration
```

**Explanation:**

- Ignored.

Figure 10-74. Valid Function-Code, Selector-1, and Selector-2 Combinations for STORE SYSTEM INFORMATION

When the specified function-code, selector-1, and selector-2 combination is invalid (is other than as shown in Figure 10-74), or if it is valid but the requested information is not available because the specified level does not implement or does not fully implement the instruction or because a necessary part of the level is uninstalled or not initialized, and provided that an exception is not recognized (see “Special Conditions”), the condition code is set to 3. When the function code is nonzero, the combination is valid, the requested information is available, and there is no exception, the requested information is stored in a system-information block (SYSIB) at the second-operand address.

Some or all of the SYSIB may be fetched before it is stored.

A SYSIB may be identified in references by means of “SYSIB fc.s1.s2,” where “fc,” “s1,” and “s2” are the values of a function code, selector 1, and selector 2, respectively.

Following sections describe the defined SYSIBs by means of figures and related text. In the figures, the offsets shown on the left are word values. “The configuration” refers to the configuration level specified by the function code (the configuration level about which information is requested).

**Note:** In the descriptions of the system-information block (SYSIB) stored by STSI, the term “CPU or core” (or briefly, “CPU/core”) indicates the applicability of the text. When the multithreading facility is not installed at the selected configuration level, certain STSI functions store information relevant to logical or physical CPU attributes. When the multithreading facility is installed at the selected configuration level, these STSI functions store information relevant to logical or physical core attributes.
STORE SYSTEM INFORMATION

<table>
<thead>
<tr>
<th>Word 0</th>
<th>Byte 0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Bit Meaning**

0  When bit 0 of byte 0 (P) is one, the type-percentage bytes, located in words 40-41, are valid. When P is zero, the bytes are stored as zeros, but have no meaning.

1-5 Bits 1-5 of byte 0 are reserved and stored as zeros.

6  When bit 6 of byte 0 (M) is zero, the multithreading facility is not installed in the basic machine configuration. When M is one, the multithreading facility is installed in the basic machine configuration.

7  Bit 7 of byte 0 (T), when one, indicates that the condition represented by the CCR and CAI fields is relatively transient.

**Reserved:** The contents of bits 1-5 of word 0, words 1-7, 13-15, and 45-63 are reserved and are stored as zeros. The contents of words 64-1023 are reserved and may be stored as zeros or may remain unchanged.

**IBM:** Byte 1 of word 0 is assigned to IBM internal use.

**Capacity-Change Reason (CCR):** When the CAI byte is nonzero, the content of byte 2 of word 0 is an 8-bit unsigned integer whose value indicates one of the following reasons which is associated with the present values contained in SYSIB 1.1.1.

**CCR Capacity-Change Reason**

0  Machine is running at nominal capacity.

1  The capacity change is due solely to the setting of a manual control, such as intentional power-save.

2  The capacity change is due to a machine-exception condition, such as detection of overheating.

3  The capacity change is due to a non-exception machine condition, such as concurrent service.

4  The capacity change is due to an exception condition external to the machine, such as detection of supplied power or cooling falling outside required tolerances.

5-255  Reserved.

When the CAI byte is zero, the CCR field is undefined, and stored as zero.

When multiple capacity-change reasons exist, CCR is set according to the following priority:

1b. External-exception condition, CCR=4.

2. Non-exception machine condition, CCR=3.


**Capacity-Adjustment Indication (CAI):** Byte 3 of word 0, when nonzero, is an 8-bit unsigned integer whose value is in the range 1-100 and represents the aggregate position of model-dependent controls. Temporary capacity changes that affect machine performance are not included; such changes include those caused by capacity-backup (CBU), on/off-capacity-on-demand (OOCoD), and capacity-planned-event (CPE) features. When zero, the indication is not reported. When in the range 1-99, some amount of reduction is indicated. When 100, the machine is operating at its normal capacity.

Primary CPUs and all secondary-type CPUs are similarly affected.

The model-capacity rating is not affected. A change in the CAI may also reflect a change in CPU-capability fields of SYSIB 1.2.2.

**Manufacturer:** Words 8-11 contain the 16-character (0-9 or uppercase A-Z) EBCDIC name of the manufacturer of the configuration. The name is left justified with trailing blanks if necessary.

**Type:** Word 12 contains the four-character (0-9) EBCDIC type number of the configuration. (This is called the machine-type number in the definition of STORE CPU ID.)

**Model-Capacity Identifier (C):** Words 16-19 contain the 16-character (0-9 or uppercase A-Z) EBCDIC model-capacity identifier of the configuration. The model-capacity identifier is left justified with trailing blanks if necessary.

**Sequence Code:** Words 20-23 contain the 16-character (0-9 or uppercase A-Z) EBCDIC sequence code of the configuration. The sequence code is right justified with leading EBCDIC zeros if necessary.

**Plant of Manufacture:** Word 24 contains the four-character (0-9 or uppercase A-Z) EBCDIC code that identifies the plant of manufacture for the configuration. The code is left justified with trailing blanks if necessary.

**Model:** When word 25 is not binary zeros, words 25-28 contain the 16-character (0-9 or uppercase A-Z) EBCDIC model identification of the configuration. The model identification is left justified with trailing blanks if necessary. (This is called the model number in programming note 4 on page 10-133 of STORE CPU ID.) When word 25 is binary zeros, the contents of words 16-19 represent both the model-capacity identifier and the model.

**Model-Permanent-Capacity Identifier (P):** When nonzero, words 29-32 contain the 16-character (0-9 or uppercase A-Z) EBCDIC model-permanent-capacity identifier of the configuration. The identifier is left justified with trailing blanks if necessary.

**Model-Temporary-Capacity Identifier (T):** When nonzero, words 33-36 contain the 16-character (0-9 or uppercase A-Z) EBCDIC model-temporary-capacity identifier of the configuration. The identifier is left justified with trailing blanks if necessary.

**Model-Capacity Rating (CR):** When nonzero, word 37 contains a 32-bit unsigned integer whose value is associated with the model capacity as identified by the model-capacity identifier. There is no formal description of the algorithm used to generate this integer.

**Model-Permanent-Capacity Rating (PR):** When nonzero, word 38 contains a 32-bit unsigned integer whose value is associated with the model-permanent capacity as identified by the model-permanent-capacity identifier. There is no formal description of the algorithm used to generate this integer.

**Model-Temporary-Capacity Rating (TR):** When nonzero, word 39 contains a 32-bit unsigned integer whose value is associated with the model-temporary capacity as identified by the model-temporary-capacity identifier. There is no formal description of the algorithm used to generate this integer.

**Type N Pctg.** Each of the byte fields in words 40-41 that is designated as a type-N percentage contains an 8-bit unsigned binary integer whose value is in the range 0-100 and represents a percentage. When nonzero, the percentage may be used to affect the use and allowed utilization of the secondary-CPU whose CPU type corresponds to the particular byte. When a byte in this range contains a value of zero, use rules of the corresponding secondary-CPU type are not overridden. The reserved bytes in word 41
are reserved for the potential addition of new second-
ary CPU types.

Nominal Model-Capacity Rating (NCR): When nonzero, word 42 contains a 32-bit unsigned integer whose value is associated with the nominal model capacity as identified by the model-capacity identifier. There is no formal description of the algorithm used to generate this integer. The NCR value equals the CR value when the CAI byte contains a value of 100. When the CAI byte is less than 100, the CR value is less than the NCR value.

Nominal Model-Permanent-Capacity Rating (NPR): When nonzero, word 43 contains a 32-bit unsigned integer whose value is associated with the nominal model-permanent capacity as identified by the model-permanent-capacity identifier. There is no formal description of the algorithm used to generate this integer. The NPR value equals the PR value when the CAI byte contains a value of 100. When the CAI byte is less than 100, the PR value is less than the NPR value.

Nominal Model-Temporary-Capacity Rating (NTR): When nonzero, word 44 contains a 32-bit unsigned integer whose value is associated with the nominal model-temporary capacity as identified by the model-temporary-capacity identifier. There is no formal description of the algorithm used to generate this integer. The NTR value equals the TR value when the CAI byte contains a value of 100. When the CAI byte is less than 100, the TR value is less than the NTR value.

Worldwide Unique Identification: Taken together, the machine type, manufacturer, plant of manufacture, and sequence code allow for worldwide unique identification of the system.

Programming Notes:

1. The fields of the SYSIB 1.1.1 are similar to those of the node descriptor described in the publication Common I/O-Device Commands and Self Description, SA22-7204. However, the contents of the SYSIB fields may not be identical to the contents of the corresponding node-descriptor fields because the SYSIB fields:
   - Allow more characters.
   - Are more flexible regarding the type of characters allowed.
   • Provide information that is justified differently within the field.
   • May not use the same method to determine the contents of fields such as the sequence-code field.

2. The model field in a node descriptor corresponds to the content of the STSI model field and not the STSI model-capacity-identifier field.

3. The model field specifies the model of the machine (i.e., the physical model); the model-capacity identifier field specifies a token that may be used to locate a statement of capacity or performance in the System Library publication for the model.

4. Each of the three model-capacity-identifier fields specifies a token that may be used to locate a statement of capacity or performance in the System Library publication for the model.

5. Each of the three model-capacity-rating fields, corresponding one-to-one with the three model-capacity-identifier fields, specifies a numeric value that may or may not represent the actual capacity of the machine.

6. The term capacity backup (CBU) represents a methodology by which spare capacity in a CPC can be used to replace capacity from another CPC within an enterprise, normally for a relatively limited period of time. Typically CBU is used when another CPC of the enterprise has failed, and the CPC operating under CBU rules is making up for the missing CPC’s capacity. However, CBU can also indicate a capacity that reflects a net reduction such that the current capacity would be less than the permanent capacity.

7. The term On/Off Capacity on Demand (On/Off CoD) represents a methodology by which spare capacity in a CPC can be made available to increase the total capacity within an enterprise, normally for a limited period of time. For example, On/Off CoD may be used to acquire additional capacity in order to handle a workload peak.

8. The content of the model-capacity identifier (C) field corresponds to the current capacity at which the central-processing complex (CPC) is operating.
9. The content of the model-permanent-capacity identifier (P) corresponds to the capacity of the CPC exclusive of temporarily-available increased capacity and temporarily-available replacement capacity.

10. The content of the model-temporary-capacity identifier (T) corresponds to the total of permanent capacity and temporarily-available increased capacity but exclusive of any temporarily-available replacement capacity.

11. When the T bit in byte 0 is one, the current capacity values and indicators are in a relatively-short period of transition and should be permitted to stabilize, that is, a result where T is zero, before any resultant action proceeds.

SYSIB 1.2.1 (Basic-Machine CPU/Core)
SYSIB 1.2.1 is illustrated in Figure 10-76:

```
<table>
<thead>
<tr>
<th>Word</th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>R</td>
<td>C</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1023</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
</tbody>
</table>
```

**Figure 10-76. Format of the SYSIB 1.2.1**

**Reserved:** The contents of words 0-19, bytes 0 and 1 of word 25, and words 26-63 are reserved and are stored as zeros. The contents of words 64-1023 are reserved and may be stored as zeros or may remain unchanged.

**Sequence Code:** Words 20-23 contain the 16-character (0-9 or uppercase A-Z) EBCDIC sequence code of the configuration. The code is right justified with leading EBCDIC zeros if necessary.

**Plant of Manufacture:** Word 24 contains the four-character (0-9 or uppercase A-Z) EBCDIC code that identifies the plant of manufacture for the configuration. The code is left justified with trailing blanks if necessary.

**CPU Address:** When the multithreading facility is not installed in the machine, bytes 2 and 3 of word 25 contain the CPU address by which this CPU is identified in a multiprocessor configuration. The CPU address is a 16-bit unsigned binary integer. The CPU address is the same as is stored by STORE CPU ADDRESS when the program is executed by a machine operating in the basic mode.

**Core Identification:** When multithreading is installed in the machine, bytes 2 and 3 of word 25 contain a 16-bit unsigned core identification, right justified in the field. The core ID field contains the core-ID portion of the value that would be stored by STORE CPU ADDRESS when executed by a machine operating in the basic mode; no thread ID is included.

**Worldwide Unique Identification:** Taken together, the machine type and manufacturer (from SYSIB 1.1.1) with the plant of manufacture and sequence code allow for worldwide unique identification of the system.

**Programming Note:** Multiple CPUs in the same configuration have the same sequence code, and it is necessary to use other information, such as the CPU address, to establish a unique CPU identity. The sequence code returned for a basic-machine CPU and a logical-partition CPU are identical and have the same value as the sequence code returned for the basic-machine configuration.

SYSIB 1.2.2 (Basic-Machine CPUs)
The general format of the SYSIB 1.2.2 is illustrated in Figure 10-77. Some fields may or may not be valid, as indicated by the contents of the format field in byte 0 of word zero.

When the multithreading facility is not installed (as indicated by bit 0 of word 1), fields labelled “CPU/Core” apply to a CPU. When the multithreading
When 64 or more words are needed to contain the information for all the CPUs, the portion of the SYSIB following the adjustment-factor list in a format-0 SYSIB or the alternate-adjustment-factor list in a format-1 SYSIB, up to and including word 1023 are reserved and may be stored as zeros or may remain unchanged.

**Format:** Byte 0 of word 0 contains an 8-bit unsigned binary integer that specifies the format of SYSIB 1.2.2.

**Alternate-CPU/Core-Capability Offset:** When the format field has a value of one, bytes 2-3 of word 0 contain a 16-bit unsigned binary integer that specifies the offset in bytes of the alternate-CPU-capability field in the SYSIB. Zeros are stored in the rightmost two bits of the ACC offset field, thus the ACC offset is a multiple of four and designates word N in Figure 10-77.

**MT Installed:** When bit 0 of the MT-installed field (byte 0 of word 1) is zero, the remainder of the field and the MT-general field are not meaningful and stored as zeros. When bit 0 of the MT-installed field is one, the remainder of the field and the MT-general field are meaningful, as described below.

**Bits** | **Meaning**
---|---
0 | When zero, the multithreading facility is not installed in the machine. When one, the multithreading facility is installed in the machine.
1-2 | Reserved (stored as zeros).
3-7 | A 5-bit unsigned integer whose value is the highest supported thread identification (TID) for a core in the machine. The value is in the range 1-31, indicating a minimum of two and a maximum of 32 CPUs per core. A specialty core may operate with this thread count.

**MT General:** The contents of byte 1 of word 1 are meaningful only when bit 0 of word 1 is one.

**Bits** | **Meaning**
---|---
0-2 | Reserved.
3-7 | A 5-bit unsigned integer whose value is the highest supported thread identification for a core comprising general CPUs. The value is in the range 0-31, indicating a minimum of one and a maximum of 32 CPUs per core.
The value is less than or equal to the value in bits 3-7 of the MT-installed field. A value of zero indicates that multithreading is not available for a general core. For a sub-capacity model, bits 3-7 of the MT-general field contain zeros.

**Primary CPU/Core Speed:** When not zero, word 4 contains a 32-bit unsigned binary integer whose value represents the dynamic speed of a primary CPU, encoded as the approximate number of CPU cycles per microsecond.

**Secondary CPU/Core Speed:** When not zero, word 5 contains a 32-bit unsigned binary integer whose value represents the dynamic speed of a secondary CPU, encoded as the approximate number of CPU cycles per microsecond.

**Nominal CPU/Core Capability:** Word 6, when not zero, is formatted and encoded the same as word 8, CPU capability, including that a lower value indicates a proportionally higher CPU capability.

When the CAI byte of SYSIB 1.1.1 is zero, the nominal CPU capability (word 6) is stored as zero. The nonzero value equals the word-8 value when the CAI byte of SYSIB 1.1.1 contains a value of 100. When the CAI byte of SYSIB 1.1.1 is nonzero and less than 100, the word-6 value indicates a CPU speed greater than the CPU speed indicated by the word-8 value.

**Secondary CPU/Core Capability:** Word 7, when not zero, is formatted and encoded the same as word 8, CPU capability, including that a lower value indicates a proportionally higher CPU capability, and specifies a secondary capability that may be applied to certain types of CPUs in the configuration.

There is no formal description of the algorithm used to generate this value, except that it is the same as the algorithm used to generate the primary CPU capability. The value is used as an indication of the capability of a CPU relative to the capability of other CPU models, and also relative to the capability of other CPU types within a model.

The capability value applies to each of the specialty CPUs/cores of one or more applicable CPU/core types in the configuration. That is, all CPUs in the configuration of an applicable type or types have the same capability. When the value is zero, all CPUs of any CPU type in the configuration have the same capability, as specified by the CPU capability.

The secondary CPU capability may or may not be the same value as the CPU-capability value.

The multiprocessing-CPU-capability-adjustment factors are also applicable to CPUs whose capability is specified by the secondary CPU capability.

**CPU/Core Capability:** Word 8 specifies the capability of one of the CPUs in the configuration.

If bits 0-8 of word 8 are zero, the word contains a 32-bit unsigned binary integer (I) in the range $1 \leq I < 2^{23}$. If bits 0-8 of word 8 are nonzero, the word contains a 32-bit binary floating point short-format number instead of an unsigned binary integer.

Regardless of encoding, the value represents the capability of one of the CPUs in the configuration, and a lower value indicates a proportionally higher CPU capability. Beyond that, there is no formal description of the algorithm used to generate this value. The value is used as an indication of the capability of the CPU relative to the capability of other CPU models.

The capability value applies to each of the general CPUs in the configuration. That is, all non-secondary CPUs in the configuration have the same capability.

**Total CPU/Core Count:** Bytes 0 and 1 of word 9 contain a 16-bit unsigned binary integer that specifies the total number of general CPUs or cores comprising general CPUs in the configuration. This number includes all general CPUs/cores in the configured state, the standby state, or the reserved state.

**Configured CPU/Core Count:** Bytes 2 and 3 of word 9 contain a 16-bit unsigned binary integer that specifies the number of general CPUs or cores comprising general CPUs that are in the configured state. A CPU/core is in the configured state when it is in the configuration and available to be used to execute programs.

**Standby CPU/Core Count:** Bytes 0 and 1 of word 10 contain a 16-bit unsigned binary integer that specifies the number of general CPUs or cores comprising general CPUs that are in the standby state. A CPU/core is in the standby state when it is in the configuration, is not available to be used to execute pro-
Reserved CPU/Core Count: Bytes 2 and 3 of word 10 contain a 16-bit unsigned binary integer that specifies the number of general CPUs or cores comprising general CPUs that are in the reserved state. A CPU/core is in the reserved state when it is in the configuration, is not available to be used to execute programs, and cannot be made available by issuing instructions to place it in the configured state. (It may be possible to place a reserved CPU in the standby or configured state by means of manual actions.)

Multiprocessing CPU/Core-Capability Adjustment Factors: Beginning with bytes 0 and 1 of word 11, the SYSIB contains a series of contiguous two-byte fields, each containing a 16-bit unsigned binary integer used to form an adjustment factor (fraction) for the value contained in the CPU-capability field. Such a fraction is developed by using the value (V) of the first two-byte field according to one of the following methods:

- If \( 0 < V \leq 100 \), a denominator of 100 is indicated which produces a fraction of \( V/100 \).
- If \( 100 < V \leq 255 \), a denominator of 255 is indicated which produces a fraction of \( V/255 \).
- If \( 255 < V \leq 65,535 \), a denominator of 65,536 is indicated which produces a fraction of \( V/65,536 \).

Thus, the fraction represented by each two-byte field is then developed by dividing the contents of a two-byte field by the indicated denominator.

The number of adjustment-factor fields is one less than the number of CPUs specified in the total-CPU-count field. The adjustment-factor fields correspond to configurations with increasing numbers of CPUs in the configured state. The first adjustment-factor field corresponds to a configuration with two CPUs in the configured state. Each successive adjustment-factor field corresponds to a configuration with a number of CPUs in the configured state that is one more than that for the preceding field.

Programming Note: The applicable MP adjustment factor is an approximation that is sensitive to the particular workload.

Alternate CPU/Core Capability: When the format field has a value of one, the location of word N is the sum of the address of the SYSIB plus the byte-offset value in the alternate-CPU-capability-offset field. If bits 0-8 of word N are zero, the word contains a 32-bit unsigned binary integer (I) in the range \( 0 \leq I < 2^{23} \) that specifies the announced capability of one of the CPUs in the configuration. If bits 0-8 of word N are nonzero, the word contains a 32-bit binary floating point short-format number instead of a 32-bit unsigned binary integer.

Regardless of encoding, a lower value indicates a proportionally higher CPU capacity. Beyond that, there is no formal description of the algorithm used to generate this value. The value is used as an indication of the announced capability of the CPU relative to the announced capability of other CPU models.

The alternate-capability value applies to each of the general CPUs or cores comprising general CPUs in the configuration. That is, all general CPUs/cores in the configuration have the same alternate capability.

Alternate Multiprocessing CPU/Core-Capability Adjustment Factors: When the format field has a value of one, the location of word N + 1 is the sum of the address of the SYSIB plus the byte-offset value in the alternate-CPU-capability-offset field plus four. Beginning with bytes 0 and 1 of word N + 1, the SYSIB contains a series of contiguous two-byte fields, each containing a 16-bit unsigned binary integer used to form an adjustment factor (fraction) for the value contained in the alternate-CPU-capability field. Such a fraction is developed by using the value (V) of the first two-byte field according to one of the following methods:

- If \( 0 < V \leq 100 \), a denominator of 100 is indicated which produces a fraction of \( V/100 \).
- If \( 100 < V \leq 255 \), a denominator of 255 is indicated which produces a fraction of \( V/255 \).
- If \( 255 < V \leq 65,535 \), a denominator of 65,536 is indicated which produces a fraction of \( V/65,536 \).

Thus, the fraction represented by each two-byte field is then developed by dividing the contents of a two-byte field by the indicated denominator.
The number of alternate-adjustment-factor fields is one less than the number of CPUs specified in the total-CPU-count field. The alternate-adjustment-factor fields correspond to configurations with increasing numbers of CPUs in the configured state. The first alternate-adjustment-factor field corresponds to a configuration with two CPUs in the configured state. Each successive alternate-adjustment-factor field corresponds to a configuration with a number of CPUs in the configured state that is one more than that for the preceding field.

**SYSIB 2.2.1 (Logical-Partition CPU/Core)**

SYSIB 2.2.1 is illustrated in Figure 10-78.

<table>
<thead>
<tr>
<th>Word</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Sequence Code</td>
</tr>
<tr>
<td>24</td>
<td>Plant of Manufacture</td>
</tr>
<tr>
<td>25</td>
<td>LCPU ID / Logical Core Identification</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
</tr>
<tr>
<td>0-63</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Figure 10-78. Format of the SYSIB 2.2.1

**Reserved:** The contents of words 0-19 and 26-63 are reserved and are stored as zeros. The contents of words 64-1023 are reserved and may be stored as zeros or may remain unchanged.

**Sequence Code:** Words 20-23 contain the 16-character (0-9 or uppercase A-Z) EBCDIC sequence code of the configuration. The code is right justified with leading EBCDIC zeros if necessary.

**Plant of Manufacture:** Word 24 contains the four-character (0-9 or uppercase A-Z) EBCDIC code that identifies the plant of manufacture for the configuration. The code is left justified with trailing blanks if necessary.

**Logical-CPU ID:** Bytes 0 and 1 of word 25 contain a 16-bit unsigned binary integer that can be used in conjunction with the logical-CPU address to distinguish the logical CPU from the other logical CPUs provided by the same LPAR hypervisor.

**Logical-CPU Address:** When the multithreading facility is not enabled in the level-2 configuration, bytes 2 and 3 of word 25 contain the logical-CPU address by which this logical CPU is identified within the level-2 configuration. The logical-CPU address is a 16-bit unsigned binary integer. The logical-CPU-address field contains the same information as is stored by STORE CPU ADDRESS when the machine is operating in the LPAR mode.

**Logical-Core Identification:** When the multithreading facility is enabled in the level-2 configuration, bytes 2 and 3 of word 25 contain a 16-bit unsigned core identification by which the core is identified within the configuration, right justified in the field.

**Worldwide Unique Identification:** Taken together, the machine type and manufacturer (from SYSIB 1.1.1) with the plant of manufacture and sequence code allow for worldwide unique identification of the system.

**Programming Note:** Multiple logical CPUs in the same level-2 configuration have the same logical-CPU sequence code, and it is necessary to use other information, such as the logical-CPU address, to establish a unique logical-CPU identity. The sequence code returned for a basic-machine CPU and a logical-partition CPU are identical and have the same value as the sequence code returned for the basic-machine configuration.

**SYSIB 2.2.2 (Logical-Partition CPUs / Cores)**

SYSIB 2.2.2 is illustrated in Figure 10-79.

When the multithreading facility is not enabled (as indicated by the PSMTID field), fields labelled with an asterisk (*) apply to a primary CPU. When the multithreading facility is enabled, fields labelled with an asterisk apply to a core comprising primary CPUs.
The number of logical CPUs/cores that are provided using dedicated level-1 CPUs/cores is specified by the dedicated-LCPU-count value in bytes 0 and 1 of word 18.

When zero, bit 0 indicates that none of the logical CPUs/cores for this level-2 configuration are provided using level-1 CPUs/cores that are dedicated to this level-2 configuration.

1 Shared: When one, bit 1 indicates that one or more of the logical CPUs/cores for this level-2 configuration are provided using level-1 CPUs/cores that can be used to provide logical CPUs/cores for other level-2 configurations. The number of logical CPUs/cores that are provided using shared level-1 CPUs/cores is specified by the shared-LCPU-count value in bytes 2 and 3 of word 18.

When zero, bit 1 indicates that none of the logical CPUs/cores for this level-2 configuration are provided using shared level-1 CPUs/cores.

2 Utilization Limit: When one, bit 2 indicates that the amount of use of the level-1 CPUs/cores that are used to provide the logical CPUs/cores for this level-2 configuration is limited.

When zero, bit 2 indicates that the amount of use of the level-1 CPUs/cores that are used to provide the logical CPUs/cores for this level-2 configuration is unlimited.

3-7 Reserved.

Total Logical-CPU/Core Count: Bytes 0 and 1 of word 9 contain a 16-bit unsigned binary integer that specifies the total number of primary logical CPUs/cores that are provided for this level-2 configuration. This number includes all of the logical CPUs/cores that are in the configured state, the standby state, or the reserved state.

Configured Logical-CPU/Core Count: Bytes 2 and 3 of word 9 contain a 16-bit unsigned binary integer that specifies the number of primary logical CPUs/cores for this level-2 configuration that are in the configured state.

A logical CPU/core is in the configured state when it is in the level-2 configuration and is available to be used to execute programs.

Standby Logical-CPU/Core Count: Bytes 0 and 1 of word 10 contain a 16-bit unsigned binary integer that specifies the number of primary logical CPUs/cores that are in the standby state for this level-2 configuration.
that specifies the number of primary logical CPUs/cores for this level-2 configuration that are in the standby state.

A logical CPU/core is in the standby state when it is in the level-2 configuration, is not available to be used to execute programs, and can be made available by issuing instructions to place it in the configured state.

Reserved Logical-CPU/Core Count: Bytes 2 and 3 of word 10 contain a 16-bit unsigned binary integer that specifies the number of primary logical CPUs/cores for this level-2 configuration that are in the reserved state.

A logical CPU/core is in the reserved state when it is in the level-2 configuration, is not available to be used to execute programs, and cannot be made available by issuing instructions to place it in the configured state. (It may be possible to place the reserved CPU/core in the standby or configured state through manual actions.)

Logical-Partition Name: Words 11-12 contain the 8-character EBCDIC name of this level-2 configuration. The name is left justified with trailing blanks if necessary.

Logical-Partition Capability Adjustment Factor (CAF): Word 13 contains a 32-bit unsigned binary integer, called an adjustment factor, with a value of 1000 or less. The adjustment factor specifies the amount of the underlying level-1-configuration capability that is allowed to be used for this level-2 configuration by the LPAR hypervisor. The fraction of level-1-configuration capability is determined by dividing the CAF value by 1000.

MT Installed: When bit 0 of the MT-installed field (byte 0 of word 16) is zero, the remainder of the field and the MT-general and PSMTID fields are not meaningful and stored as zeros. When bit 0 of the MT-installed field is one, the remainder of the field and the MT-general and PSMTID fields are meaningful, as described below.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>When zero, the multithreading facility is not installed in the level-2 configuration. When one, the multithreading facility is installed in the level-2 configuration.</td>
</tr>
<tr>
<td>1-2</td>
<td>Reserved (stored as zeros).</td>
</tr>
</tbody>
</table>

3-7 A 5-bit unsigned integer whose value is the highest supported thread identification (TID) for a core of the level-2 configuration. The value is in the range 1-31, indicating a minimum of two and a maximum of 32 CPUs per core. A specialty core may operate with this thread count.

MT General: The contents of byte 1 of word 16 are meaningful only when bit 0 the MT-installed field is one.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-2</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

3-7 A 5-bit unsigned integer whose value is the highest supported thread identification for a core comprising general CPUs. The value is in the range 0-31, indicating a minimum of one and a maximum of 32 CPUs per core. The value is less than or equal to the value in bits 3-7 of the MT-installed field. A value of zero indicates that multithreading is not available for a general core. For a sub-capacity model, bits 3-7 of the MT-general field contain zeros.

Program-Specified Maximum TID (PSMTID): The contents of byte 2 of word 16 are meaningful only when bit 0 of word 16 is one.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-2</td>
<td>Reserved (stored as zeros).</td>
</tr>
</tbody>
</table>

3-7 When the multithreading facility is enabled in the level-2 configuration, bit positions 3-7 contain the program-specified maximum thread identification as set by the SIGNAL PROCESSOR set-multithreading order; the value is copied from bit positions 59-63 of the SIGP parameter register. When the multithreading facility is not enabled in the level-2 configuration, bit positions 3-7 contain zeros.

Dedicated Logical-CPU Count/Core: Bytes 0 and 1 of word 18 contain a 16-bit unsigned binary integer that specifies the number of configured-state primary logical CPUs/cores for this level-2 configuration that are provided using dedicated level-1 CPUs/cores. (See the description of bit 0 of the logical-CPU-characteristics field.)
**Shared Logical-CPU/Core Count:** Bytes 2 and 3 of word 18 contain a 16-bit unsigned binary integer that specifies the number of configured-state primary logical CPUs/cores for this level-2 configuration that are provided using shared level-1 CPUs/cores. (See the description of bit 1 of the logical-CPU-characteristics field.)

**SYSIB 3.2.2 (Virtual-Machine CPUs / Cores)**

SYSIB 3.2.2 is illustrated in Figure 10-80:

![Figure 10-80. Format of the SYSIB 3.2.2](image)

- **Reserved:** The contents of words 0-6, bits 0-27 of word 7, and words 136-1023 are reserved and are stored as zeros.

- **Description-Block Count (DBCT):** Bits 28-31 of word 7 contain a four-bit unsigned binary integer that specifies the number (up to eight) of virtual-machine description blocks that are stored in the SYSIB beginning at word 8.

- **Virtual-Machine Description Blocks:** Words 8-135 contain from one to eight 64-byte virtual-machine description blocks, depending on the number of nested level-3 configurations, if any, and their processing characteristics.

When a level-3 configuration is provided by a virtual-machine control program and the control program is being executed by a level-3 configuration provided by another virtual-machine control program, the level-3 configurations are said to be “nested.” Level-3 configurations can be nested in this way for several levels.

The collection of nested level-3 configurations that is in the path between a program being executed by a level-3 configuration and the basic machine is called a “level-3-configuration stack.” The level-3 configurations in a stack are consecutively numbered. The level-3 configuration provided by a virtual-machine control program being executed by either a level-2 configuration or a level-1 configuration is the lowest-numbered (0) level-3 configuration in the stack. The level-3 configuration that is executing the program containing this instruction is the highest numbered (N) level-3 configuration in the stack.

If more than one virtual-machine description block is stored in words 8-135 of the SYSIB, the blocks are stored according to the following rules:

- The collection of level-3 configurations described is a contiguous subset of the total collection of level-3 configurations in the level-3-configuration stack. The subset always includes the highest-numbered level-3 configuration in the stack. One or more level-3 configurations at the bottom of the stack may not be described because STORE SYSTEM INFORMATION is not implemented by the highest of those configurations or the limit of eight description blocks would be exceeded.

- The highest-numbered level-3 configuration in the level-3-configuration stack is always described by the first description block in the SYSIB. The lowest-numbered level-3 configuration in the stack, of those that are included in the subset that is described, is described by the last description block in the SYSIB.

The contents of the SYSIB subsequent to the virtual-machine description blocks and prior to word 136 are reserved and are stored as zeros.
The virtual-machine description block is illustrated in Figure 10-81.

<table>
<thead>
<tr>
<th>Word</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Total LCPU Count*</td>
</tr>
<tr>
<td>2</td>
<td>Standby LCPU Count*</td>
</tr>
<tr>
<td>3</td>
<td>Virtual-Machine Name</td>
</tr>
<tr>
<td>4</td>
<td>Virtual-Machine CAF</td>
</tr>
<tr>
<td>5</td>
<td>Control-Program Identifier</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Explanation:

* Field applies to a primary CPU or to a core comprising primary CPUs. The CPUs may either be primary or specialty CPUs.

**Total Logical-CPU/Core Count:** Bytes 0 and 1 of word 1 contain a 16-bit unsigned binary integer that specifies the total number of primary logical CPUs/cores that are provided for this level-3 configuration. This number includes all of the primary logical CPUs/cores that are in the configured state, the standby state, and the reserved state.

**Configured Logical-CPU/Core Count:** Bytes 2 and 3 of word 1 contain a 16-bit unsigned binary integer that specifies the number of primary logical CPUs/cores for this level-3 configuration that are in the configured state.

A logical CPU/core is in the configured state when it is in the level-3 configuration and is available to be used to execute programs.

**Standby Logical-CPU/Core Count:** Bytes 0 and 1 of word 2 contain a 16-bit unsigned binary integer that specifies the number of primary logical CPUs/cores for this level-3 configuration that are in the standby state.

A logical CPU/core is in the standby state when it is in the level-3 configuration, is not available to be used to execute programs, and can be made available by issuing instructions to place it in the configured state.

**Reserved Logical-CPU/Core Count:** Bytes 2 and 3 of word 2 contain a 16-bit unsigned binary integer that specifies the number of primary logical CPUs/cores for this level-3 configuration that are in the reserved state.

A logical CPU/core is in the reserved state when it is in the level-3 configuration, is not available to be used to execute programs, and cannot be made available by issuing instructions to place it in the configured state. (It may be possible to place the logical CPU/core in the standby or configured state through manual actions.)

**Virtual-Machine Name:** Words 3-4 contain the eight-character EBCDIC name of this level-3 configuration. The name is left justified with trailing blanks if necessary.

**Virtual-Machine Capability Adjustment Factor (CAF):** Word 5 contains a 32-bit unsigned binary integer, called an adjustment factor, with a value of 1000 or less. The adjustment factor specifies the amount of the underlying level-1-, level-2-, or level-3-configuration capability that is allowed to be used for this level-3 configuration by the virtual-machine control program. The fraction of the underlying capability is determined by dividing the CAF value by 1000.

**Control-Program Identifier:** Words 6-9 contain the 16-character EBCDIC identifier of the virtual-machine control program that provides this level-3 configuration. This identifier may include qualifiers such as version number and release level. The identifier is left justified with trailing blanks if necessary.
SYSIBs 15.1.2 through 15.1.6 are illustrated in each have the following format:

```
<table>
<thead>
<tr>
<th>Word</th>
<th>Reserved</th>
<th>Length</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Mag6</td>
<td>Mag5</td>
</tr>
<tr>
<td>1</td>
<td>Mag4</td>
<td>Mag3</td>
</tr>
<tr>
<td>2</td>
<td>Mag2</td>
<td>Mag1</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td>MNest</td>
</tr>
<tr>
<td>4</td>
<td>Topology List</td>
<td></td>
</tr>
<tr>
<td>N-1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>N</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1023</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>
```

Selector 2 specifies the MNest value to which the response is limited. STSI completes with condition code 3 for the following cases:

1. If the maximum-MNest facility is installed and selector 2 exceeds the nonzero model-dependent maximum-selector-2 value.
2. If the maximum-MNest facility is not installed and selector 2 is not specified as two.

Reserved: The contents of bytes 0-1 of word 0, byte 2 of word 2, and word 3 are reserved and are stored as zeros. The contents of words N-1023 are reserved and may be stored as zeros or may remain unchanged.

Length: Bytes 2-3 of word 0 contain a 16-bit unsigned binary integer whose value is the count of bytes of the entire SYSIB 15.1.2. The length of just the topology list is determined by subtracting 16 from the length value in bytes 2-3 of word 0. N in Figure 10-83 is determined by evaluating the formula N=Length/4.

Mag1-6: Word 1 and bytes 0-1 of word 2 constitute six one-byte fields where the content of each byte indicates the maximum number of container-type topology-list entries (TLE) or CPU-type TLEs at the corresponding nesting level. CPU-type TLEs are always found only at the Mag1 level. Additionally, the Mag1 value also specifies the maximum number of CPUs that may be represented by a container-type TLE of the Mag2 level. When the value of the nesting level is greater than one, containing nesting levels above the Mag1 level are occupied only by container-type TLEs. A dynamic change to the topology may alter the number of TLEs and the number of CPUs at the Mag1 level, but the limits represented by the values of the Mag1-6 fields do not change within a model family of machines.

The topology is a structured list of entries where an entry defines one or more CPUs or else is involved with the nesting structure. The following illustrates the meaning of the magnitude fields:

- When all CPUs of the machine are peers and no containment organization exists, other than the entirety of the central-processing complex itself, the value of the nesting level is 1, Mag1 is the only nonzero magnitude field, and the number of CPU-type TLEs stored does not exceed the Mag1 value.
- When all CPUs of the machine are subdivided into peer groups such that one level of containment exists, the value of the nesting level is 2, Mag1 and Mag2 are the only nonzero magnitude fields, the number of container-type TLEs stored does not exceed the Mag2 value, and the number of CPU-type TLEs stored within each container does not exceed the Mag1 value.
- The Mag3-6 bytes similarly become used (proceeding in a right-to-left direction) when the value of the nesting level falls in the range 3-6.

M Nest: When the maximum-MNest facility is not installed, byte 3 of word 2 specifies the nesting level of the topology to which the configuration may be extended without requiring a re-IPL. The maximum MNest value is model dependent in the range 2-6; the minimum is one. If MNest is one, there is no actual TLE nesting structure, Mag1 is the only non-zero field in the Mag1-6 range, and only CPU-type TLEs are represented in the topology list. The MNest value indicates the number of nonzero magnitude values beginning with the magnitude field at byte 1 of word 2 (Mag1), proceeding left when MNest is greater than one, and with the remaining magnitude fields stored as zeros.

The value of MNest is the maximum possible nesting. No dynamic configuration change exceeds this limit.
When the maximum-MNest facility is installed, the maximum possible nesting is indicated by other means and the MNest value in byte 3 of word 2 reflects both the requested selector-2 value and the number of nonzero magnitude values beginning with the magnitude field at byte 1 of word 2 (Mag1).

**Topology List:** Words of Figure 10-83 in the range 4 through N-1 specify a list of one or more topology-list entries (TLE). Each TLE is an eight-byte or sixteen-byte field; thus N is an even number of words, and a corollary is that a TLE always starts on a doubleword boundary.

**Topology-List Entries:** The first TLE in the topology list begins at a nesting level equal to MNest-1. The entire topology list represents the configuration of the issuer of the STSI instruction specifying SYSIB 15.1.x; no outermost container TLE entry is used as it would be redundant with the entire list, and the entire configuration. Therefore, the highest nesting level may have more than a single peer container.

Figure 10-83 illustrates the container type of TLE, and Figure 10-84 illustrates the CPU type of TLE.

**Nesting Level (NL):** Byte 0 of word 0 specifies the TLE nesting level.

| NL Meaning | 00 | The TLE is a CPU-type TLE. |
| 01-05 | The TLE is a container-type TLE. The first container-type TLE stored in a topology list or a parent container has a container-ID in the range 1-255. If sibling containers exist within the same parent, they proceed in an ascending order of container IDs, that may or may not be consecutive, to a maximum value of 255. |
| 06-FF | Reserved |

Sibling TLEs have the same value of nesting level which is equivalent to either the value of the nesting level minus one of the immediate parent TLE, or the value of MNest minus one, because the immediate parent is the topology list rather than a TLE.

**Reserved, 0:** For a container-type TLE, bytes 1-3 of word 0 and bytes 0-2 of word 1 are reserved and stored as zeros. For a CPU-type TLE, bytes 1-3 of word 0 and bits 0-4 of word 1 are reserved and stored as zeros.

**Container ID:** Byte 3 of word 1 of a container-type TLE specifies an 8-bit unsigned nonzero binary integer whose value is the identifier of the container. The container ID for a TLE is unique within the same parent container.

**Fields Specific to a CPU-type TLE**

The remaining fields described below are specific to a CPU-type TLE. When the multithreading facility is not installed, or when it the facility is installed but not enabled, these fields describe one or more CPUs in the configuration having common topology attributes. When the multithreading facility is installed and enabled, these fields describe one or more cores in the configuration having common topology attributes; each core comprises a set of CPUs that have the same topology attributes.

**Dedicated (D):** Bit 5 of word 1 of a CPU-type TLE, when one, indicates that the one or more CPUs represented by the TLE are dedicated. When D is zero, the one or more CPUs of the TLE are not dedicated.

**Polarization (PP):** Bits 6-7 of word 1 of a CPU-type TLE specify the polarization value and, when polarization is vertical, the degree of vertical polarization.
also called entitlement (high, medium, low) of the corresponding CPU(s) represented by the TLE. The following values are used:

<table>
<thead>
<tr>
<th>PP</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The one or more CPUs represented by the TLE are horizontally polarized.</td>
</tr>
<tr>
<td>1</td>
<td>The one or more CPUs represented by the TLE are vertically polarized. Entitlement is low.</td>
</tr>
<tr>
<td>2</td>
<td>The one or more CPUs represented by the TLE are vertically polarized. Entitlement is medium.</td>
</tr>
<tr>
<td>3</td>
<td>The one or more CPUs represented by the TLE are vertically polarized. Entitlement is high.</td>
</tr>
</tbody>
</table>

Polarization is only significant in a logical and virtual multiprocessing configuration that uses shared host processors and addresses how the resource assigned to a configuration is applied across the CPUs of the configuration. When horizontal polarization is in effect, each CPU of a configuration is guaranteed approximately the same amount of resource. When vertical polarization is in effect, CPUs of a configuration are classified into three levels of resource entitlement: high, medium, and low.

Both subsystem reset and successful execution of the SIGP set-architecture order specifying ESA/390 mode place a configuration and all of its CPUs into horizontal polarization. The CPUs immediately affected are those that are in the configured state. When a CPU in the standby state is configured, it acquires the current polarization of the configuration and causes a topology change of that configuration to be recognized.

A dedicated CPU is either horizontally or vertically polarized. When a dedicated CPU is vertically polarized, entitlement is always high. Thus, when D is one, PP is either 00 binary or 11 binary.

**CPU Type:** Byte 1 of word 1 of a CPU-type TLE specifies an 8-bit unsigned binary integer whose value is the CPU type of the one or more CPUs represented by the TLE. The CPU-type value specifies either a primary-CPU type or any one of the possible secondary-CPU types.

**CPU-Address Origin:** When the multithreading facility is installed and enabled, the TLE represents one or more cores, each CPU of which has the same CPU type.

**CPU Mask:** Words 2-3 of a CPU-type TLE specify a 64-bit mask where each bit position represents a CPU or core. When the multithreading facility is installed and enabled, bytes 2-3 of word 1 specify a right-justified 16-bit unsigned binary integer whose value is the first core identification in the range of cores represented by the CPU mask, and whose presence is represented by the value of bit position 0 in the CPU mask.

When the multithreading facility is installed and enabled, bytes 2-3 of word 1 of a CPU-type TLE specify a 16-bit unsigned binary integer whose value is the CPU address of the first CPU in the range of CPUs represented by the CPU mask, and whose presence is represented by the value of bit position 0 in the CPU mask. The value of a CPU-address origin is the same as that stored by the STORE CPU ADDRESS (STAP) instruction when executed on the CPU represented by bit position 0 in the CPU mask.

When the multithreading facility is installed and enabled, bytes 2-3 of word 1 specify a right-justified 16-bit unsigned binary integer whose value is the first core identification in the range of cores represented by the CPU mask, and whose presence is represented by the value of bit position 0 in the CPU mask.

The CPU-address origin is evenly divisible by 64.

**CPU Mask:** Words 2-3 of a CPU-type TLE specify a 64-bit mask where each bit position represents a CPU or core. When the multithreading facility is installed and enabled, the following applies:

- The value of the CPU-address origin field plus a bit position in the CPU mask equals the CPU address for the corresponding CPU.
- When a CPU-mask bit is zero, the corresponding CPU is not represented by the TLE. Either the CPU is not in the configuration, or else it must be represented by another CPU-type TLE.
- When a CPU mask bit is one, the corresponding CPU has the modifier-attribute values specified by the TLE, is in the topology of the configuration, and is not present in any other TLE of the topology.

When the multithreading facility is installed and enabled, the following applies:

- The value of the CPU-address origin field plus a bit position in the CPU mask equals the core ID for the corresponding core.
- When a CPU-mask bit is zero, the corresponding core is not represented by the TLE. Either the core is not in the configuration or else must be represented by another CPU-type TLE.
- When a CPU-mask bit is one, the corresponding core and each of its CPUs has the modifier-attri-
bute values specified by the TLE, is in the topology of the configuration, and is not present in any other TLE of the topology.

Programming Notes:

1. The following example applies when the multithreading facility is not installed, or when the facility is installed but disabled: If the CPU-address origin is a value of 64, and bit position 15 of the CPU mask is one, CPU 79 is in the configuration and has the CPU type, polarization, entitlement, and dedication as specified by the TLE.

2. The following examples apply when the multithreading facility is installed and enabled:

   A CPU-address-origin value of 0000 hex represents a set of core IDs in the range 0 to 63, 0040 hex represents a set of core IDs in the range 64 to 127, as so forth.

   If the CPU-address origin is a value of 64, and bit position 15 of the CPU mask is one, core ID 79 is in the configuration and has the CPU type, polarization, entitlement, and dedication as specified by the TLE.

   In this example, if multithreading had been enabled with a program-specified maximum thread identification of three (that is, with four threads per core, thus a TID width of 2 bits), the CPU addresses of any CPU in the core can be determined by multiplying the core ID by four (that is, shifting it left TID-width bit positions), and adding the thread ID. Thus, the CPU addresses for core 79 are 316 - 319 (013C-013F hex).

TLE Ordering: The modifier attributes that apply to a CPU-type TLE are CPU type, polarization, entitlement, and dedication. Polarization and entitlement (for vertical polarization) are taken as a single attribute, albeit with four possible values (horizontal, vertical-high, vertical-medium, and vertical-low).

A single CPU TLE is sufficient to represent as many as 64 CPUs or cores that all have the same modifier-attribute values.

When more than 64 CPUs or cores exist, or the entire range of CPU addresses are not covered by a single CPU-address origin, and the modifier attributes are constant, a separate sibling CPU TLE is stored for each CPU-address origin, as necessary, in ascending order of CPU-address origin. Each such TLE stored has at least one CPU or core represented. The collection of one or more such CPU TLEs is called a CPU-TLE set.

When multiple CPU types exist, a separate CPU-TLE set is stored for each, in ascending order of CPU type.

When multiple polarization-and-entitlement values exist, a separate CPU-TLE set is stored for each, in descending order of polarization value and degree (vertical high, medium, low, then horizontal). When present, all polarization CPU-TLE sets of a given CPU type are stored before the first CPU-TLE set of the next CPU type.

When both dedicated and not-dedicated CPUs exist, a separate CPU-TLE set is stored for each, dedicated appearing before not-dedicated.

All TLEs are ordered assuming a depth-first traversal where the sort order from major to minor is as follows:

1. CPU type
   a. Lowest CPU-type value
   b. Highest CPU-type value

2. Polarization-Entitlement
   a. Vertical high
   b. Vertical medium
   c. Vertical low
   d. Horizontal

3. Dedication (when applicable)
   a. Dedicated
   b. Not dedicated

The ordering by CPU-address origin and modifier attributes of sibling CPU TLEs within a parent container is done according to the following list, which proceeds from highest to lowest.

1. CPU-TLE set of lowest CPU-type value, vertical high, dedicated

2. CPU-TLE set of lowest CPU-type value, vertical high, not-dedicated
3. CPU-TLE set of lowest CPU-type value, vertical medium, not-dedicated
4. CPU-TLE set of lowest CPU-type value, vertical low, not-dedicated
5. CPU-TLE set of lowest CPU-type value, horizontal, dedicated
6. CPU-TLE set of lowest CPU-type value, horizontal, not-dedicated
7. CPU-TLE set of highest CPU-type value, vertical high, dedicated
8. CPU-TLE set of highest CPU-type value, vertical high, not-dedicated
9. CPU-TLE set of highest CPU-type value, vertical medium, not-dedicated
10. CPU-TLE set of highest CPU-type value, vertical low, not-dedicated
11. CPU-TLE set of highest CPU-type value, horizontal, dedicated
12. CPU-TLE set of highest CPU-type value, horizontal, not-dedicated

**Other TLE Rules:**

1. A container-type TLE is located at nesting levels in the range 1-5.
2. A CPU-type TLE is located at nesting level 0.
3. The number of sibling container-type TLEs in a topology list or a given parent container does not exceed the value of the magnitude byte (Mag2-6) of the nesting level corresponding to the siblings.
4. The number of CPUs represented by the one or more CPU-type TLEs of the parent container does not exceed the value of the Mag1 magnitude byte.
5. The content of a TLE is defined as follows:
   - If a TLE is a container-type TLE, the content is a list that immediately follows the parent TLE, comprised of one or more child TLEs, and each child TLE has a nesting level of one less than the nesting level of the parent TLE or topology-list end.
   - If a TLE is a CPU-type TLE, the content is one or more CPUs, as identified by the other fields of a CPU TLE.
6. When the first TLE at a nesting level is a CPU entry, the maximum nesting level 0 has been reached.

**CPU Topology Overview**

With the advent of the IBM System z9 Enterprise Class and subsequent models, and even previously, machine organization into nodal structures has resulted in a non-uniform memory access (NUMA) behavior, sometimes also called “lumpiness”. The purpose of the SYSIB 15.1.2 and the PERFORM TOPOLOGY FUNCTION (PTF) instruction is to provide additional machine topology awareness to the program so that certain optimizations can be performed to improve cache-hit ratios and thereby improve overall performance.

The amount of host-CPU resource assigned to a multiprocessing (MP) guest configuration has generally been spread evenly across the number of configured guest CPUs. Such an even spread implies that no particular guest CPU or CPUs are entitled to any extra host-CPU provisioning than any other, arbitrarily-determined guest CPUs. This condition of the guest configuration, affecting all CPUs of the configuration, is called horizontal polarization.

Under horizontal polarization, assignment of a host CPU to a guest CPU is approximately the same amount of provisioning for each guest CPU. When the provisioning is not dedicated, the same host CPUs provisioning the guest CPUs also may be used to provision guest CPUs of another guest, or even other guest CPUs of the same guest configuration. When the other guest configuration is a different logical partition, a host CPU, when active in each partition, typically must access main storage more because the cache-hit ratio is reduced by having to share the caches across multiple relocation zones. If host-CPU provisioning can alter the balance such that some host CPUs are mostly, or even exclusively, assigned to a given guest configuration, and that becomes the normal behavior, then cache-hit ratios improve, as does performance. Such an uneven spread implies that one or more guest CPUs are entitled to extra host-CPU provisioning versus other, arbitrarily-determined guest CPUs that are entitled to less host-CPU provisioning. This condition of the guest configuration, affecting all CPUs of the configuration, is called vertical polarization.
The architecture categorizes vertical polarization into three levels of entitlement of provisioning, high, medium, and low:

- High entitlement guarantees approximately 100% of a host CPU being assigned to a logical/virtual CPU, and the affinity is maintained as a strong correspondence between the two. With respect to provisioning of a logical partition, when vertical polarization is in effect, the entitlement of a dedicated CPU is defined to be high.

- Medium entitlement guarantees an unspecified amount of host CPU resource (one or more host CPUs) being assigned to a logical/virtual CPU, and any remaining capacity of the host CPU is considered to be slack that may be assigned elsewhere. The best case for the available slack would be to assign it as local slack if that is possible. A less-beneficial result occurs if that available slack is assigned as remote slack. (See “CPU Slack” on page 10-155 for descriptions of the two slack terms.) It is also the case that the resource percentage assigned to a logical CPU of medium entitlement is a much softer approximation as compared to the 100% approximation of a high-entitlement setting.

- Low entitlement guarantees approximately 0% of a host CPU being assigned to a logical/virtual CPU. However, if slack is available, such a logical/virtual CPU may still receive some CPU resource.

A model of nested containers using polarization is intended to provide a level of intelligence about the machine's nodal structure as it applies to the requesting configuration, so that, generally, clusters of host CPUs can be assigned to clusters of guest CPUs, thereby improving as much as possible the sharing of storage and the minimizing of different configurations essentially colliding on the same host CPUs.

Polarization and entitlement indicate the relationship of physical CPUs to logical CPUs or logical CPUs to virtual CPUs in a guest configuration, and how the capacity assigned to the guest configuration is apportioned across the CPUs that comprise the configuration. Historically, a guest configuration has been horizontally polarized. For however many guest CPUs were defined to the configuration, the host-CPU resource assigned was spread evenly across all of the guest CPUs in an equitable, non-entitled manner. It can be said that the weight of a single logical CPU in a logical partition when horizontal polarization is in effect is approximately equal to the total configuration weight divided by the number of CPUs. However, with the introduction of the 2097 and family models, it becomes imperative to be able to spread the host-CPU resource in a different manner, which is called vertical polarization of a configuration, and then the degree of provisioning of guest CPUs with host CPUs being indicated as high, medium, or low entitlement. High entitlement is in effect when a logical/virtual CPU of a vertically-polarized configuration is entirely backed by the same host CPU. Medium entitlement is in effect when a logical/virtual CPU of a vertically-polarized configuration is partially backed by a host CPU. Low entitlement is in effect when a logical/virtual CPU of a vertically-polarized configuration is not guaranteed any host-CPU resource, other than what might become available due to slack resource becoming available.

CPU Slack

Regarding slack CPU resource, there are two kinds:

- Local slack becomes available when a logical/virtual CPU of a configuration is not using all the resource to which it is entitled and such slack is then used within the configuration of that CPU. Local slack is preferred over remote slack as better hit ratios on caches are expected when the slack is used within the configuration.

- Remote slack becomes available when a logical/virtual CPU of a configuration is not using all the resource to which it is entitled and such slack is then used outside the configuration of that CPU. Remote slack is expected to exhibit lower hit ratios on caches, but it is still better than not running a logical/virtual CPU at all.

The goal is to maximize the CPU cache hit ratios.

For a logical partition, the amount of physical-CPU resource is determined by the overall system weightings that determine the CPU resource assigned to each logical partition. For example, in a logical 3-way MP that is assigned physical-CPU resource equivalent to a single CPU, and is horizontally polarized, each logical CPU would be dispatched independently and thus receive approximately 33% physical-CPU resource. If the same configuration were to be vertically polarized, only a single logical CPU would be run and would receive approximately 100% of the assigned physical-CPU resource (high entitlement).
while the remaining two logical CPUs would not normally be dispatched (low entitlement). Such resource assignment is normally an approximation. Even a low-entitlement CPU may receive some amount of resource if only to help ensure that a program does not get stuck on such a CPU.

By providing a means for a control program to indicate that it understands polarization, and to receive an indication for each CPU of its polarization and, if vertical polarization, the degree of entitlement, the control program can make more-intelligent use of data structures that are generally thought to be local to a CPU vs. available to all CPUs of a configuration. Also, such a control program can avoid dispatching work to any low-entitlement CPU.

The actual physical-CPU resource assigned might not constitute an integral number of CPUs, so there is also the possibility of one or more CPUs in an MP vertically-polarized configuration being entitled but not to a high degree, thereby resulting in such CPUs having either medium or low vertical entitlement.

It is possible for any remaining low-entitlement CPUs to receive some amount of host-CPU resource. For example, this may occur when such a CPU is targeted, such as via a SIGP order and slack host-CPU resource is available. Otherwise, such a logical/virtual CPU might remain in an undispatched state, even if it is otherwise capable of being dispatched.

A 2-bit polarization field is defined for the CPU-type topology-list entry (TLE) of the STORE SYSTEM INFORMATION (STSI) instruction. The degree of vertical-polarization entitlement for each CPU is indicated as high, medium, or low. The assignment is not a precise percentage but rather is somewhat fuzzy and heuristic.

In addition to vertical polarization as a means of reassigning weighting to guest CPUs, another concept exists, which is the creation and management of slack capacity (also called “white space”). Slack capacity is created under the following circumstances:

- A high-vertical CPU contributes to slack when its average utilization (AU) falls below 100 percent (100-AU).
- A medium-vertical CPU that has an assigned provisioning of M percent of a host CPU contributes to slack when its average utilization (AU) falls below M percent (M-AU > 0).
- A low-vertical CPU does not contribute to slack.
- A high-vertical CPU is not a consumer of slack.
- A medium-vertical CPU may or may not be a consumer of slack.
- A low-vertical CPU is only a consumer of slack.

Depending upon its utilization and pattern of being dispatched, a horizontally-polarized CPU can be either a contributor to slack or a consumer of it.

**Programming Note:** A possible examination process of a topology list is described. Before an examination of a topology list is begun, the current-TLE pointer is initialized to reference the first or top TLE in the topology list, the prior-TLE pointer is initialized to null, and then TLEs are examined in a top-to-bottom order.

As a topology-list examination proceeds, the current-TLE pointer is advanced by incrementing the current-TLE pointer by the size of the current TLE to which it points. A container-type TLE is advanced by adding eight to the current-TLE pointer. A CPU-type TLE is advanced by adding sixteen to the current-TLE pointer. The process of advancing the current-TLE pointer includes saving its value as the prior-TLE pointer just before it is incremented. TLE examination is not performed if the topology list has no TLEs.

The examination process is outlined in the following steps:

1. If the current-TLE nesting level is zero, and the prior-TLE nesting level is null or one, the current TLE represents the first CPU-type TLE of a group of one or more CPU-type TLEs. The program should perform whatever action is appropriate for when a new group of one or more CPUs is first observed. Go to step 5.

2. If the current-TLE nesting level is zero, and the prior-TLE nesting level is zero, the current TLE represents a subsequent CPU-type TLE of a group of CPU-type TLEs that represent siblings of the CPUs previously observed in steps 1 or 2. The program should perform whatever action is appropriate for when the size of an existing sibling group of one or more CPUs is increased. Go to step 5.
3. If the current-TLE nesting level is not zero, and the prior-TLE nesting level is zero, the prior TLE represents a last or only CPU-type TLE of a group of one or more CPU-type TLEs. The program should perform whatever action is appropriate for when an existing group of one or more CPUs is completed. Go to step 5.

4. Go to step 5.

By elimination, this would be the case where the current-TLE nesting level is not zero, and the prior-TLE nesting level is not zero. If the current-TLE nesting level is less than the prior-TLE nesting level, the direction of topology-list traversal is toward a CPU-type TLE. If the current-TLE nesting level is greater than the prior-TLE nesting level, the direction of topology-list traversal is away from a CPU-type TLE. Container-type TLEs are being traversed leading to either (1) another group of CPU-type TLEs that are a separate group in the overall topology, or (2) the end of the topology list. In either case, no particular processing is required beyond advancing to the next TLE.

5. Advance to the next TLE position based upon the type of the current TLE. If the advanced current-TLE pointer is equivalent to the end of the topology list:
   a. No more TLEs of any type exist.
   b. If the prior-TLE nesting level is zero, the program should perform whatever action is appropriate for when an existing group of one or more CPUs is completed.
   c. The examination is complete.

Otherwise go to step 1.

Special Conditions

The condition code is set to 3 if the function code in bit positions 32-35 of general register 0 is greater than the current-level number.

Bits 36-55 of general register 0 and 32-47 of general register 1 must be zero; otherwise, a specification exception is recognized.

When the function code is valid and nonzero, the following special conditions apply in an unpredictable order:

- The second operand must be designated on a 4K-byte boundary; otherwise, a specification exception is recognized.
- If the function-code, selector-1, and selector-2 combination is invalid, or if it is valid but the requested information is not available, the condition code is set to 3.

Resulting Condition Code:

<table>
<thead>
<tr>
<th>0</th>
<th>Requested configuration-level number placed in general register 0 or requested SYSIB information stored</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>--</td>
</tr>
<tr>
<td>2</td>
<td>--</td>
</tr>
<tr>
<td>3</td>
<td>Requested SYSIB information not available</td>
</tr>
</tbody>
</table>

Program Exceptions:

- Access (store, operand 2, only if function code nonzero)
- Privileged operation
- Specification
- Transaction constraint

The priority of the recognition of exceptions and condition codes is shown in Figure 10-85.

1.-6. Exceptions with the same priority as the priority of program-interruption conditions for the general case.


8. Condition code 3 due to function code greater than current-level number.

9. Specification exception due to bits 36-55 of general register 0 or bits 32-47 of general register 1 not zero.

10. Condition code 0 due to function code 0.

11.A Specification exception due to second-operand address not designating a 4K-byte boundary.

Figure 10-85. Priority of Execution: STORE SYSTEM INFORMATION (Part 1 of 2)
11.B Condition code 3 due to invalid function-code, selector-1, and selector-2 combination or requested information not available.

12. Access exceptions (store) for system-information block.

13. Condition code 0 due to information stored in system-information block.

Figure 10-85. Priority of Execution: STORE SYSTEM INFORMATION (Part 2 of 2)

**Programming Note:** The storage-operand references for STORE SYSTEM INFORMATION may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

### STORE THEN AND SYSTEM MASK

<table>
<thead>
<tr>
<th>STNSM</th>
<th>D&lt;sub&gt;i&lt;/sub&gt;(B&lt;sub&gt;j&lt;/sub&gt;)&lt;sub&gt;_1&lt;/sub&gt;</th>
<th>[SI]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'AC'</td>
<td>I&lt;sub&gt;2&lt;/sub&gt; B&lt;sub&gt;1&lt;/sub&gt; D&lt;sub&gt;1&lt;/sub&gt;</td>
<td></td>
</tr>
</tbody>
</table>

Bits 0-7 of the current PSW are stored at the first-operand location. Then the contents of bit positions 0-7 of the current PSW are replaced by the logical AND of their original contents and the second operand.

**Special Conditions**

The operation is suppressed on addressing and protection exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 1)
- Privileged operation
- Transaction constraint

### STORE THEN OR SYSTEM MASK

<table>
<thead>
<tr>
<th>STOSM</th>
<th>D&lt;sub&gt;i&lt;/sub&gt;(B&lt;sub&gt;j&lt;/sub&gt;)&lt;sub&gt;_2&lt;/sub&gt;</th>
<th>[SI]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'AD'</td>
<td>I&lt;sub&gt;2&lt;/sub&gt; B&lt;sub&gt;1&lt;/sub&gt; D&lt;sub&gt;1&lt;/sub&gt;</td>
<td></td>
</tr>
</tbody>
</table>

Bits 0-7 of the current PSW are stored at the first-operand location. Then the contents of bit positions 0-7 of the current PSW are replaced by the logical OR of their original contents and the second operand.

**Special Conditions**

The value to be loaded into the PSW is not checked for validity before loading. However, immediately after loading, a specification exception is recognized, and a program interruption occurs, if the contents of bit positions 0 and 2-4 of the PSW are not all zeros. In this case, the instruction is completed, and the instruction-length code is set to 2 or 3. The specification exception, which is listed as a program exception for this instruction, is described in “Early Exception Recognition” on page 6-9.

The operation is suppressed on addressing and protection exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 1)
- Privileged operation
- Specification
- Transaction constraint

**Programming Note:** STORE THEN OR SYSTEM MASK permits the program to set selected bits in the system mask to ones while retaining the original contents for later restoration. For example, it may be necessary that a program, which has no record of the present status, disable program-event recording for a few instructions.

---

11.B Condition code 3 due to invalid function-code, selector-1, and selector-2 combination or requested information not available.

12. Access exceptions (store) for system-information block.

13. Condition code 0 due to information stored in system-information block.

**Programming Note:** The storage-operand references for STORE SYSTEM INFORMATION may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

### STORE THEN AND SYSTEM MASK

<table>
<thead>
<tr>
<th>STNSM</th>
<th>D&lt;sub&gt;i&lt;/sub&gt;(B&lt;sub&gt;j&lt;/sub&gt;)&lt;sub&gt;_1&lt;/sub&gt;</th>
<th>[SI]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'AC'</td>
<td>I&lt;sub&gt;2&lt;/sub&gt; B&lt;sub&gt;1&lt;/sub&gt; D&lt;sub&gt;1&lt;/sub&gt;</td>
<td></td>
</tr>
</tbody>
</table>

Bits 0-7 of the current PSW are stored at the first-operand location. Then the contents of bit positions 0-7 of the current PSW are replaced by the logical AND of their original contents and the second operand.

**Special Conditions**

The operation is suppressed on addressing and protection exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 1)
- Privileged operation
- Transaction constraint

**Programming Note:** STORE THEN AND SYSTEM MASK permits the program to set selected bits in the system mask to zeros while retaining the original contents for later restoration. For example, it may be necessary that a program, which has no record of the present status, disable program-event recording for a few instructions.
STORE USING REAL ADDRESS

STURA \( R_1, R_2 \) [RRE]

\[ 'B246' \]

STURG \( R_1, R_2 \) [RRE]

\[ 'B925' \]

For STORE USING REAL ADDRESS (STURA), bits 32-63 of general register \( R_1 \) are stored in the word at the real-storage location addressed by the contents of general register \( R_2 \). For STORE USING REAL ADDRESS (STURG), bits 0-63 of general register \( R_1 \) are stored in the doubleword at that real-storage location.

In the 24-bit addressing mode, bits 40-63 of general register \( R_2 \) designate the real-storage location, and bits 0-39 of the register are ignored. In the 31-bit addressing mode, bits 33-63 of general register \( R_2 \) designate the real-storage location, and bits 0-32 of the register are ignored. In the 64-bit addressing mode, bits 0-63 of general register \( R_2 \) designate the real-storage location.

Because it is a real address, the address designating the storage word or doubleword is not subject to dynamic address translation.

Special Conditions

The contents of general register \( R_2 \) must designate a location on a word boundary for STURA or on a doubleword boundary for STURG; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

Program Exceptions:

- Addressing (address specified by general register \( R_2 \))
- Privileged operation
- Protection (store, operand 2, key-controlled protection and low-address protection)
- Specification
- Transaction constraint

TEST ACCESS

TAR \( R_1, R_2 \) [RRE]

\[ 'B24C' \]

The access-list-entry token (ALET) in access register \( R_1 \) is tested for exceptions recognized during access-register translation (ART). The extended authorization index (EAX) used is bits 32-47 of general register \( R_2 \). The ALET is also tested for whether it designates the dispatchable-unit access list or the primary-space access list and for whether it is 00000000 or 00000001 hex.

When \( R_1 \) is 0, the actual contents of access register 0 are used in ART, instead of the 00000000 hex that is usually used.

Bits 0-31 and 48-63 of general register \( R_2 \) are ignored.

The operation does not depend on the translation mode — bits 5, 16, and 17 of the PSW are ignored.

When the ALET specified by means of the \( R_1 \) field is other than 00000000 or 00000001 hex, the ART process is applied to the ALET. The EAX specified by means of the \( R_2 \) field is called the effective EAX, and it is the EAX which is used by ART. When a condition exists that would normally cause one of the exceptions shown in the following table, the instruction is completed by setting condition code 3.

<table>
<thead>
<tr>
<th>Exception Name</th>
<th>Cause</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALET specification</td>
<td>ALET bits 0-6 not all zeros</td>
</tr>
<tr>
<td>ALEN translation</td>
<td>Access-list entry (ALE) outside list or invalid (bit 0 is one)</td>
</tr>
<tr>
<td>ALE sequence</td>
<td>ALE sequence number (ALESN) in ALET not equal to ALESN in ALE</td>
</tr>
<tr>
<td>ASTE validity</td>
<td>ASN-second-table entry (ASTE) invalid (bit 0 is one)</td>
</tr>
<tr>
<td>ASTE sequence</td>
<td>ASTE sequence number (ASTESN) in ALE not equal to ASTESN in ASTE</td>
</tr>
<tr>
<td>Extended authority</td>
<td>ALE private bit not zero, ALE authorization index (ALEAX) not equal to effective EAX, and secondary bit selected by effective EAX either outside authority table or zero</td>
</tr>
</tbody>
</table>
When ART is completed without one of the above conditions being present, the instruction is completed by setting condition code 1 or 2, depending on whether the effective access list is the dispatchable-unit access list or the primary-space access list, respectively. The effective access list is the dispatchable-unit access list if bit 7 of the ALET is zero, or it is the primary-space access list if bit 7 is one. ART, including the obtaining of the effective access-list designation, is described in “Access-Register-Translation Process” on page 5-60.

When the ALET is 00000000 hex, the instruction is completed by setting condition code 0. When the ALET is 00000001 hex, the instruction is completed by setting condition code 3.

Special Conditions

An addressing exception is recognized when the address used by ART to fetch the effective access-list designation or the ALE, ASTE, or authority-table entry designates a location which is not available in the configuration.

The operation is suppressed on all addressing exceptions.

Resulting Condition Code:

- 0  Access-list-entry token (ALET) is 00000000 hex
- 1  ALET designates the dispatchable-unit access list and does not cause exceptions in access-register translation (ART)
- 2  ALET designates the primary-space access list and does not cause exceptions in ART
- 3  ALET is 00000001 hex or causes exceptions in ART

Program Exceptions:

- Addressing (effective access-list designation, access-list entry, ASN-second-table entry, or authority-table entry)
- Transaction constraint

The priority of recognition of program exceptions for the instruction is shown in Figure 10-86.

<table>
<thead>
<tr>
<th></th>
<th>Exception Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1-6</td>
<td>Exceptions with the same priority as the priority of program-interruption conditions for the general case.</td>
</tr>
<tr>
<td>8.</td>
<td>Condition code 0 due to access-list-entry-token (ALET) being 00000000 hex.</td>
</tr>
<tr>
<td>9.</td>
<td>Condition code 3 due to ALET being 00000001 hex or ALET bits 0-6 not being all zeros.</td>
</tr>
<tr>
<td>10.</td>
<td>Addressing exception for access to effective access-list designation.</td>
</tr>
<tr>
<td>11.</td>
<td>Condition code 3 due to access-list entry (ALE) being outside the list.</td>
</tr>
<tr>
<td>12.</td>
<td>Addressing exception for access to ALE.</td>
</tr>
<tr>
<td>13.</td>
<td>Condition code 3 due to ALE being invalid (bit 0 is 1) or access-list-entry sequence number (ALESN) in the ALET not being equal to the ALESN in the ALE.</td>
</tr>
<tr>
<td>14.</td>
<td>Addressing exception for access to ASN-second-table entry (ASTE).</td>
</tr>
<tr>
<td>15.</td>
<td>Condition code 3 due to ASTE being invalid (bit 0 is one) or ASTE sequence number (ASTESN) in the ALE not being equal to the ASTESN in the ASTE.</td>
</tr>
<tr>
<td>16.</td>
<td>Condition code 3 due to authority-table entry being outside table.</td>
</tr>
<tr>
<td>17.</td>
<td>Addressing exception for access to authority-table entry.</td>
</tr>
<tr>
<td>18.</td>
<td>Condition code 3 due to ALE private bit not being zero, ALE authorization index (ALEAX) not being equal to effective extended authorization index (EAX), and secondary bit selected by effective EAX being zero.</td>
</tr>
<tr>
<td>19.</td>
<td>Condition code 1 if ALET bit 7 is zero; otherwise, condition code 2.</td>
</tr>
</tbody>
</table>

Figure 10-86. Priority of Execution: TEST ACCESS

Programming Notes:

1. TEST ACCESS permits a called program to check whether an ALET passed from the calling program is authorized for use by means of the
calling program's EAX. The calling program's EAX can be obtained from the last linkage-stack state entry by means of EXTRACT STACKED STATE. The called program can thus avoid performing an operation for the calling program, through the use of the called program's EAX, which the calling program is not authorized to perform by means of its own EAX.

2. When an ALET equal to 00000000 hex is passed during a program linkage performed by PROGRAM CALL with space switching (PC-ss), and the ALET conceptually designates the calling program's primary address space and the called program's secondary address space, the ALET must be changed to 00000001 hex before it is used by the called program. Condition code 0 of TEST ACCESS indicates a 00000000 hex ALET so that the ALET can be changed to 00000001 hex by the called program.

3. PROGRAM CALL to current primary (PC-cp) sets the secondary address space equal to the primary address space. PC-ss sets the secondary address space equal to the calling program's primary address space, except that stacking PC-ss sets it equal to the called program's primary address space when the secondary-ASN control in the entry-table entry used is one. In all these cases, a passed 00000001 hex ALET that conceptually designates the calling program's secondary address space is not usable by the called program, even after any transformation (unless the operation was PC-cp and the calling program's PASN and SASN are equal). This is why TEST ACCESS sets condition code 3 when the tested ALET is 00000001 hex.

4. After a PC-ss, a passed ALET that conceptually designates an entry in the primary-space access list of the calling program is not usable by the called program. This is why TEST ACCESS sets condition code 2, instead of condition code 1, when the tested ALET designates the primary-space access list.

5. The control program may manage the ASN-secondary-table entry in a way that causes a correctable ASTE-validity or ASTE-sequence exception situation to exist; that is, a situation which, if it were to cause a program interruption during access-register translation, would be corrected by the control program so that access-register translation could be completed successfully. In this case, the program should not use TEST ACCESS directly but should instead use a control-program service that uses TEST ACCESS and that corrects the situation, if possible, when condition code 3 is set. MVS/ESA provides the TESTSTART macro instruction for use instead of the direct use of TEST ACCESS.

### TEST BLOCK

<table>
<thead>
<tr>
<th>TB</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B22C'</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The storage locations and storage key of a 4K-byte block are tested for usability, and the result of the test is indicated in the condition code. The test for usability is based on the susceptibility of the block to the occurrence of invalid checking-block code.

The block tested is addressed by the contents of general register R2. The contents of general register R1 are ignored.

A complete testing operation is necessarily performed only when the initial contents of bit positions 32-63 of general register 0 are zero in the 24-bit or 31-bit addressing mode, or the initial contents of bit positions 0-63 of that register are zero in the 64-bit addressing mode. In the 24-bit or 31-bit addressing mode, the contents of bit positions 32-63 of general register 0 are set to zero at the completion of the operation, and bits 0-31 of the register always are ignored and remain unchanged. In the 64-bit addressing mode, the contents of bit positions 0-63 of the register are set to zero at the completion of the operation.

If the block is found to be usable, the 4K bytes of the block are cleared to zeros, the contents of the storage key are unpredictable, and condition code 0 is set. If the block is found to be unusable, the data and the storage key are set, as far as is possible by the model, to a value such that subsequent fetches to the area do not cause a machine-check condition, and condition code 1 is set.

In the 24-bit addressing mode, bits 40-51 of general register R2 designate a 4K-byte block in real storage, and bits 0-39 and 52-63 of the register are ignored. In the 31-bit addressing mode, bits 33-51 of the register designate the block, and bits 0-32 and 52-63 are ignored. In the 64-bit addressing mode, bits 0-51 of
the register designate the block, and bits 52-63 are ignored.

The address of the block is a real address, and the accesses to the block designated by the second-operand address are not subject to key-controlled, access-list-controlled, or DAT protection. Low-address protection does apply. The operation is terminated on addressing and protection exceptions. If termination occurs, the condition code and the contents of bit positions 32-63 of general register 0 are unpredictable in the 24-bit or 31-bit addressing mode, or the condition code and bits 0-63 of the register are unpredictable in the 64-bit addressing mode. The contents of the storage block and its associated storage key are not changed when these exceptions occur.

Depending on the model, the test for usability may be performed (1) by alternately storing and reading out test patterns to the data and storage key in the block or (2) by reference to an internal record of the usability of the blocks which are available in the configuration, or (3) by using a combination of both mechanisms.

In models in which an internal record is used, the block is indicated as unusable if a solid failure has been previously detected, or if intermittent failures in the block have exceeded the threshold implemented by the model. In such models, depending on the criteria, attempts to store may or may not occur. Thus, if block 0 is not usable, and no store occurs, low-address protection may or may not be indicated.

In models in which test patterns are used, TEST BLOCK may be interruptible. When an interruption occurs after a unit of operation, other than the last one, the condition code is unpredictable, and the contents of bit positions 32-63 of general register 0 may contain a record of the state of intermediate steps in the 24-bit or 31-bit addressing mode, or the contents of bit positions 0-63 may contain that record in the 64-bit addressing mode. When execution is resumed after an interruption, the condition code is ignored, but the record in general register 0 may be used to determine the resumption point.

If (1) TEST BLOCK is executed with an initial value other than zero in bit positions 32-63 of general register 0 in the 24-bit or 31-bit addressing mode or bit positions 0-63 in the 64-bit addressing mode, or (2) the interrupted instruction is resumed after an interruption with a value in bit positions 32-63 or 0-63 (depending on the addressing mode) of general register 0 or a value in the storage block or its associated storage key other than the corresponding value which was present at the time of the interruption, or (3) the block or its associated storage key is accessed by another CPU or by the channel subsystem during the execution of the instruction, then the contents of the storage block, its associated storage key, and bit positions 32-63 or 0-63 of general register 0 are unpredictable, along with the resultant condition-code setting.

Invalid checking-block-code errors initially found in the block or encountered during the test do not normally result in machine-check conditions. The test-block function is implemented in such a way that the frequency of machine-check interruptions due to the instruction execution is not significant. However, if, during the execution of TEST BLOCK for an unusable block, that block is accessed by another CPU (or by the channel subsystem), error conditions may be reported both to this CPU and to the other CPU (or to the channel subsystem).

A serialization function is performed before the block is accessed and again after the operation is completed (or partially completed).

**Resulting Condition Code:**

0 Block usable
1 Block not usable
2 --
3 --

**Program Exceptions:**

- Addressing (fetch and store, operand 2)
- Privileged operation
- Protection (store, operand 2, low-address protection only)
- Transaction constraint

The priority of the recognition of exceptions and condition codes is shown in Figure 10-87.

| 1.-6. | Exceptions with the same priority as the priority of program-interruption conditions for the general case. |

*Figure 10-87. Priority of Execution: TEST BLOCK (Part 1 of 2)*
Programming Notes:

1. The execution of TEST BLOCK on most models is significantly slower than that of the MOVE LONG instruction with padding; therefore, the instruction should not be used for the normal case of clearing storage.

2. The program should use TEST BLOCK at initial program loading and as part of the vary-storage-online procedure to determine if blocks of storage exist which should not be used.

3. The program should use TEST BLOCK when an uncorrected error is reported in either the data or storage key of a block. This is because in the execution of TEST BLOCK the attempt is made, as far as is possible on the model, to leave the contents of a block in a state such that subsequent prefetches or unintended references to the block do not cause machine-check conditions. The program may use the resulting condition code in this case to determine if the block can be reused. (The block could be indicated as usable if, for example, the error were an externally generated error or an indirect storage error.) This procedure should be followed regardless of whether the indirect-storage-error indication is reported.

4. The model may or may not be successful in removing the errors from a block when TEST BLOCK is executed. The program therefore should take every reasonable precaution to avoid referencing an unusable block. For example, the program should not place the page-frame real address of an unusable block in an attached and valid page-table entry.

5. On some models, machine checks may be reported for a block even though the block is not referenced by the program. When a machine check is reported for a storage-key error in a block which has been marked as unusable by the program, it is possible that SET STORAGE KEY EXTENDED may be more effective than TEST BLOCK in validating the storage key.

6. The storage-operand references for TEST BLOCK may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)

The location designated by the first-operand address is tested for protection exceptions by using the access key specified by bits 56-59 of the second-operand address.

The second-operand address is not used to address data; instead, bits 56-59 of the address form the access key to be used in testing. Bits 0-55 and 60-63 of the second-operand address are ignored.

The first-operand address is a logical address. When the CPU is in the access-register mode (when DAT is on and PSW bits 16 and 17 are 01 binary), the first-operand address is subject to translation by means of both the access-register-translation (ART) and the dynamic-address-translation (DAT) processes. ART applies to the access register designated by the B1 field, and it obtains the address-space-control element to be used by DAT. When DAT is on but the CPU is not in the access-register mode, the first-operand address is subject to translation by DAT. In this case, DAT uses the address-space-control element contained in control register 1, 7, or 13 when the CPU is in the primary-space, secondary-space, or home-space mode, respectively. When DAT is off, the first-operand address is a real address not subject to translation by either ART or DAT.

When the CPU is in the access-register mode and an address-space-control element cannot be obtained
by ART because of a condition that would normally cause one of the exceptions shown in the following table, the instruction is completed by setting condition code 3.

<table>
<thead>
<tr>
<th>Exception Name</th>
<th>Cause</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALET specification</td>
<td>Access-list-entry-token (ALET) bits 0-6 not all zeros</td>
</tr>
<tr>
<td>ALEN translation</td>
<td>Access-list entry (ALE) outside list or invalid (bit 0 is one)</td>
</tr>
<tr>
<td>ALE sequence</td>
<td>ALE sequence number (ALESN) in ALET not equal to ALESN in ALE</td>
</tr>
<tr>
<td>ASTE validity</td>
<td>ASN-second-table entry (ASTE) invalid (bit 0 is one)</td>
</tr>
<tr>
<td>ASTE sequence</td>
<td>ASTE sequence number (ASTESN) in ALE not equal to ASTESN in ASTE</td>
</tr>
<tr>
<td>Extended authority</td>
<td>ALE private bit not zero, ALE authorization index (ALEAX) not equal to extended authorization index (EAX), and secondary bit selected by EAX either outside authority table or zero</td>
</tr>
</tbody>
</table>

When the access register contains 00000000 hex or 00000001 hex, ART obtains the address-space-control element from control register 1 or 7, respectively, without accessing the access list. When the B_1 field designates access register 0, ART treats the access register as containing 00000000 hex and does not examine the actual contents of the access register.

When ART is completed successfully, the operation is continued through the performance of DAT.

When DAT is on and the first-operand address cannot be translated because of a condition that would normally cause one of the exceptions shown in the following table, the instruction is completed by setting condition code 3.

<table>
<thead>
<tr>
<th>Exception Name</th>
<th>Cause</th>
</tr>
</thead>
<tbody>
<tr>
<td>ASCE type</td>
<td>Address-space-control element (ASCE) being used is a region-second-table designation, and bits 0-10 of first-operand address not all zeros; ASCE is a region-third-table designation, and bits 0-21 of first-operand address not all zeros; or ASCE is a segment-table designation, and bits 0-32 of first-operand address not all zeros.</td>
</tr>
<tr>
<td>Region first translation</td>
<td>Region-first-table entry outside table or invalid.</td>
</tr>
<tr>
<td>Region second translation</td>
<td>Region-second-table entry outside table or invalid.</td>
</tr>
<tr>
<td>Region third translation</td>
<td>Region-third-table entry outside table or invalid.</td>
</tr>
<tr>
<td>Segment translation</td>
<td>Segment-table entry outside table or invalid</td>
</tr>
<tr>
<td>Page translation</td>
<td>Page-table entry invalid</td>
</tr>
</tbody>
</table>

When translation of the first-operand address can be completed, or when DAT is off, the storage key for the block designated by the first-operand address is tested against the access key specified in bit positions 56-59 of the second-operand address, and the condition code is set to indicate whether store and fetch accesses are permitted, taking into consideration all applicable protection mechanisms. Thus, for example, if low-address protection is active and the first-operand effective address is in the range 0-511 or 4096-4607, then a store access is not permitted. Access-list-controlled protection, DAT protection, storage-protection override, and fetch-protection override also are taken into account.

When EDAT-1 does not apply, when EDAT-1 applies but the STE-format control is zero, or when EDAT-2 applies but the RTTE-format control is zero, bits 0-4 of the storage key for the 4K-byte block corresponding to the virtual address in the first operand are examined to determine the condition code. When EDAT-1 applies and both the STE-format and AV controls in the STE are one, it is unpredictable whether bits 0-4 of the storage key or bits 48-52 of the segment-table entry used in the translation of the first operand are examined to determine the condition code. When EDAT-2 applies and both the RTTE-
format and AV controls in the RTTE are one, it is unpredictable whether bits 0-4 of the storage key or bits 48-52 of the region-third-table entry used in the translation of the first operand are examined to determine the condition code.

The contents of storage, including the change bit, are not affected. Depending on the model, the reference bit for the first-operand address may be set to one, even for the case in which the location is protected against fetching.

Special Conditions

When the CPU is in the access-register mode, an addressing exception is recognized when the address used by ART to fetch the effective access-list designation or the ALE, ASTE, or authority-table entry designates a location which is not available in the configuration.

When DAT is on, an addressing exception is recognized when the address of the region-table entry or entries, segment-table entry, or page-table entry or the operand real address after translation designates a location which is not available in the configuration. Also, a translation-specification exception is recognized when a region-table entry or the segment-table entry or page-table entry has a format error, that is, when any of the reasons listed in “Translation-Specification Exception” on page 6-44 applies. When DAT is off, only the addressing exception due to the operand real address applies.

For all of the above cases, the operation is suppressed.

Resulting Condition Code:

0  Fetching permitted; storing permitted
1  Fetching permitted; storing not permitted
2  Fetching not permitted; storing not permitted
3  Translation not available

Program Exceptions:

- Addressing (effective access-list designation, access-list entry, ASN-second-table entry, authority-table entry, region-table entry, segment-table entry, page-table entry, or operand 1)
- Privileged operation
- Translation specification
- Transaction constraint

Programming Notes:

1. TEST PROTECTION permits a program to determine the protection attributes of an address passed from a calling program without incurring program exceptions. The instruction sets a condition code to indicate whether fetching or storing is permitted at the location designated by the first-operand address of the instruction. The instruction takes into consideration all of the protection mechanisms in the machine: access-list controlled, DAT, key-controlled, and low-address protection, storage-protection override, and fetch-protection override. Additionally, since ASCE-type, region-translation, segment-translation, and page-translation-exception conditions may be a program substitute for a protection violation, these conditions are used to set the condition code rather than cause a program exception.

When the CPU is in the access-register mode, TEST PROTECTION additionally permits the program to check the usability of an access-list-entry token (ALET) in an access register without incurring program exceptions. The ALET is checked for validity (absence of an ALET-specification, ALEN-translation, and ALE-sequence-exception condition) and for being authorized for use by the program (absence of an ASTE-validity, ASTE-sequence, and extended-authority-exception condition).

2. See the programming notes under SET PSW KEY FROM ADDRESS for more details and for an alternative approach to testing the key-controlled protection attributes of addresses passed by a calling program. The approach using TEST PROTECTION has the advantage of a test which does not result in interruptions; however, the test and use are separated in time and may not be accurate if the possibility exists that the storage key of the location in question can change between the time it is tested and the time it is used.

3. In the handling of dynamic address translation, TEST PROTECTION is similar to LOAD REAL ADDRESS in that the instructions do not cause ASCE-type, region-translation, segment-translation, and page-translation exceptions. Instead, these exception conditions are indicated by means of a condition-code setting. Similarly, access-register translation sets a condition code for certain exception conditions when performed during either of the two instructions. Conditions
which result in condition codes 1, 2, and 3 for LOAD REAL ADDRESS result in condition code 3 for TEST PROTECTION. The instructions also differ in several other respects. The first-operand address of TEST PROTECTION is a logical address and thus is not subject to dynamic address translation when DAT is off. The second-operand address of LOAD REAL ADDRESS is a virtual address which is always translated.

Access-register translation applies to TEST PROTECTION only when the CPU is in the access-register mode (DAT is on), whereas it applies to LOAD REAL ADDRESS when PSW bits 16 and 17 are 01 binary regardless of whether DAT is on or off. When condition code 3 is set because of an exception condition in access-register translation, LOAD REAL ADDRESS, but not TEST PROTECTION, returns in a general register the program-interruption code assigned to the exception.

4. Condition code 3 does not necessarily indicate that the first-operand location will always be inaccessible to the program; rather it merely indicates that the current conditions prevent the instruction from determining the protection attributes of the operand. For example, in a virtual storage environment, condition code 3 may be set if the storage location has been paged out by the operating system. If the program attempts to access the location, the operating system may resolve the page-translation exception and subsequently make the location accessible to the program.

Similarly, condition code 1 does not necessarily indicate that the address cannot ever be stored into. In an operating system that implements a Posix fork function, DAT protection is used to alert the operating system of a copy-on-write event (as described in Programming Note 1 on page 3-15). Following the operating-system resolution of the copy-on-write event, the program may be given store access to the location.

The displacement for TRACE is treated as a 12-bit unsigned binary integer. The displacement for TRACG is treated as a 20-bit signed binary integer.

The trace entry is composed of an entry-type identifier, a count of the number of general registers whose partial or entire contents are placed in the entry, a field whose contents indicate whether the entry was formed by TRACE (TRACE) or TRACE (TRACG), selected bits of the TOD clock, the second operand, and the partial or entire contents of a range of general registers. For TRACE (TRACE), bits 16-63 of the TOD clock and bits 32-63 of the general registers are placed in the trace entry. For TRACE (TRACG), bits 0-79 of the clock and bits 0-63 of the registers are placed in the entry.

The general registers are stored in ascending order of their register numbers, starting with general register R1 and continuing up to and including general register R3, with general register 0 following general register 15. The trace table and the trace-entry formats are described in “Tracing” on page 4-10.

When a trace entry is made, a serialization and checkpoint-synchronization function is performed before the operation begins and again after the operation is completed. However, it is unpredictable whether or not a store into a trace-table entry from which a subsequent instruction is fetched will be observed by the CPU that performed the store. Additionally, when the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register 12 is one, it is unpredictable whether explicit tracing causes serialization to be performed.

Special Conditions
A privileged-operation exception is recognized in the problem state, even when explicit tracing is off or bit 0 of the second operand is one.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized. It is unpredictable whether the specification exception is recognized when explicit tracing is off.

It is unpredictable whether access exceptions or PER zero-address-detection events are recognized for the second operand when explicit tracing is off.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2)
- Privileged operation
- Specification
- Trace
- Transaction constraint

**Programming Notes:**

1. Bits 1-15 of the second operand are reserved for model-dependent functions and should therefore be set to zeros.

2. When the store-clock-fast facility is not installed, or when the TOD-clock-control in bit 32 of control register 0 is zero, the entire 32-bit TRACE operand is stored in bits 64-95 of the trace entry for TRACE (TRACE) and in bits 96-127 of the trace entry for TRACE (TRACG).

3. When the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register 0 is one, the following conditions apply:
   - Two executions of the instruction do not necessarily store different values in the TOD-clock bits of the trace entry.
   - The contents of bit positions 0-7 and 16-31 of the TRACE operand are stored in bits 64-71 and 80-95, respectively, of the trace entry for TRACE (TRACE) and in bits 96-103 and 112-127, respectively, of the trace entry for TRACE (TRACG).
   - Bits 72-79 of the trace entry for TRACE (TRACE) and bits 104-111 of the trace entry for TRACE (TRACG) are set to a model-dependent value.

**TRAP**

<table>
<thead>
<tr>
<th>TRAP2</th>
<th>[E]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'01FF'</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TRAP4</th>
<th>D2(B2)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B2FF'</td>
<td>B2</td>
<td>D2</td>
</tr>
</tbody>
</table>

A trap operation is performed if the CPU is in the primary-space or access-register mode and the TRAP-enabled bit in byte 47 of the dispatchable-unit control table (DUCT) is one. Otherwise, a special-operation exception is recognized.

The trap operation obtains a trap-control-block address from the DUCT and then a trap-save-area address and a trap-program address from the trap control block. State information is stored in the trap save area. Then the trap-control-block address is loaded into general register 15. Finally, the current PSW is updated by setting the basic-addressing-mode bit to one (which will leave the addressing mode as either the 31-bit mode or the 64-bit mode or will change the addressing mode from the 24-bit mode to the 31-bit mode) and the address-space-control bits to zeros (primary-space mode) and by replacing the instruction address with the trap-program address. Compatibility with the ESA/390 operation of TRAP optionally is provided.

For TRAP4, the second-operand address is not used to address data; instead, bits 33-63 of the address are stored in the trap save area.

**Dispatchable-Unit Control Table**

Bytes 44-47 (word 10) of the dispatchable-unit-control table (DUCT) are used by this instruction. The contents of those bytes are as follows:

<table>
<thead>
<tr>
<th>DUCT Bytes 44-47</th>
</tr>
</thead>
<tbody>
<tr>
<td>Trap-Control-Block Address</td>
</tr>
<tr>
<td>0</td>
</tr>
</tbody>
</table>
The fields in bytes 44-47 of the DUCT are allocated as follows:

**Trap-Control-Block Address:** Bits 1-28, with three zeros appended on the right, form the 31-bit home virtual address of the trap control block. This address is treated as a 31-bit home virtual address regardless of the current addressing mode and regardless of the current value of the address-space-control bits. This address, with a zero appended on the left, is placed in bit positions 32-63 of general register 15 after the contents of that register have been saved in the trap save area. If the current addressing mode is the 64-bit mode, bits 0-31 of general register 15 are set to zeros.

**TRAP-Enabled Bit (E):** Bit 31 specifies, when one, that the trap operation is to be performed. TRAP recognizes a special-operation exception if bit 31 is zero.

Bits 0, 29, and 30 of bytes 44-47 are ignored, but they should be zeros to permit possible future extensions.

**Trap Control Block**

The trap control block is 64 bytes aligned on a doubleword boundary. The format of the trap control block is:

```
<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td></td>
</tr>
<tr>
<td>04</td>
<td>4</td>
</tr>
<tr>
<td>08</td>
<td>8</td>
</tr>
<tr>
<td>0C</td>
<td>12</td>
</tr>
<tr>
<td>10</td>
<td>16</td>
</tr>
<tr>
<td>14</td>
<td>20</td>
</tr>
<tr>
<td>18</td>
<td>24</td>
</tr>
<tr>
<td>1C</td>
<td>28</td>
</tr>
<tr>
<td>20</td>
<td>32</td>
</tr>
<tr>
<td>3C</td>
<td>60</td>
</tr>
</tbody>
</table>
```

The fields in the trap control block are allocated as follows:

**PSW Control (P):** Bit 13 of bytes 0-3 controls the allowed value of bit 31 of the current PSW and how bits 12 and 33-127 of the current PSW are stored in the PSW-values field in the trap save area. When bit 13 is zero.

- Bit 31 of the current PSW, the extended-addressing-mode bit, must be zero; otherwise, a special-operation exception is recognized.
- A one is stored in bit position 12 of the PSW-values field even though bit 12 of the current PSW is zero.
- Bits 97-127 of the current PSW are stored in bit positions 33-63 of the PSW-values field, bits 33-96 of the current PSW are not stored, and zeros are stored in bit positions 64-127 of the PSW-values field.

When bit 13 is one:

- Bit 31 of the current PSW may be zero or one.
- Bit 12 of the current PSW is stored in bit position 12 of the PSW-values field.
- Bits 64-127 of the current PSW are stored in bit positions 64-127 of the PSW-values field.

**General-Registers Control (R):** Bit 14 of bytes 0-3 controls how the contents of the general registers are stored in the general-registers 0-15 field in the trap save area. When R is zero, bits 32-63 of the general registers are stored in consecutive four-byte locations beginning at the beginning of the general-registers 0-15 field, bits 0-31 of the registers are not stored, and the last 64 bytes of the general-registers 0-15 field remain unchanged. When R is one, bits 0-63 of the general registers are stored in consecutive eight-byte locations in the general-registers 0-15 field.

**Trap-Save-Area Address:** Bits 1-28 of bytes 12-15, with three zeros appended on the right, form the 31-bit home virtual address of the trap save area. This address is treated as a 31-bit home virtual address regardless of the current addressing mode and regardless of the current value of the address-space-control bits. Bits 0 and 29-31 of bytes 12-15 are ignored.

**Trap-Program Address:** Bits 1-31 of bytes 20-23 form the 31-bit primary virtual address of the trap program. This address is treated as a 31-bit primary virtual address regardless of the current addressing mode.

Bit positions 0-12 and 15-31 of bytes 0-3 and bytes 4-11, 16-19, and 32-63 of the trap control block are
reserved and should contain zeros. Bytes 24-31 are available for use by programming.

**Trap Save Area**

The trap save area is 256 bytes aligned on a double-word boundary.

The trap operation stores information into the trap save area as follows:

<table>
<thead>
<tr>
<th>Hex</th>
<th>Dec</th>
<th>Trap Flags</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Reserved (Zeros Stored)</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>Bits 33-63 of Second-Op Address of TRAP4</td>
</tr>
<tr>
<td>C</td>
<td>12</td>
<td>Access Register 15</td>
</tr>
<tr>
<td>10</td>
<td>16</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>32</td>
<td>PSW Values</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>General Registers 0-15</th>
</tr>
</thead>
<tbody>
<tr>
<td>A0 160</td>
</tr>
<tr>
<td>A4 164</td>
</tr>
<tr>
<td>A8 168</td>
</tr>
<tr>
<td>: : :</td>
</tr>
<tr>
<td>FC 252</td>
</tr>
</tbody>
</table>

The fields in the trap save area are allocated as follows:

**Trap Flags:** Information identifying the instruction(s) causing the trap operation is stored in byte positions 0-3. The detailed format of bytes 0-3 is as follows:

<table>
<thead>
<tr>
<th>Flag Bits</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>TRAP was target of an execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG)</td>
</tr>
<tr>
<td>1</td>
<td>TRAP is TRAP4 (not TRAP2)</td>
</tr>
<tr>
<td>2-12</td>
<td>Reserved, zeros stored</td>
</tr>
<tr>
<td>13-14</td>
<td>Instruction-length code (ILC)</td>
</tr>
<tr>
<td>15-31</td>
<td>Reserved, zeros stored</td>
</tr>
</tbody>
</table>

Bit 0 of bytes 0-3 is set to one if TRAP was the target of an execute-type instruction (EXECUTE or EXECUTE RELATIVE LONG).

Bit 1 of bytes 0-3 is set to one if TRAP is TRAP4 (not TRAP2).

Bits 13 and 14 are the instruction-length code (ILC) that specifies the length of the TRAP instruction, or the length of the execute-type instruction if TRAP was the target of an execute-type instruction.

Bits 2-12 and 15-31 are reserved and are stored as zeros.

**Bits 33-63 of Second-Operand Address of TRAP4:** For TRAP4, bits 33-63 of the second-operand address, generated under the control of the current addressing mode and with a zero appended on the left, are stored in byte positions 8-11. Only bits 33-63 of the second-operand address are stored even when the current addressing mode is the 64-bit mode. For TRAP2, all zeros are stored in byte positions 8-11.

**Access Register 15:** The contents of access register 15 are stored in byte positions 12-15.

**PSW Values:** The following description applies when the PSW control, bit 13 of bytes 0-3 of the trap control block, is one.

Certain information from the current PSW is stored in byte positions 16-31. The PSW has the following format:

<table>
<thead>
<tr>
<th>Instruction Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Instruction Address (Continued)</th>
</tr>
</thead>
<tbody>
<tr>
<td>32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63</td>
</tr>
</tbody>
</table>

Bits 0-127 of bytes 16-31 correspond one-to-one with bits 0-127 of the PSW. For some bit positions of bytes 16-31, the corresponding PSW bits are stored. For the other bit positions of bytes 16-31, unpredictable.
able values are stored. Information is stored in bytes 16-31 as follows:

<table>
<thead>
<tr>
<th>Bits</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Zero</td>
</tr>
<tr>
<td>1</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>2-4</td>
<td>Zero</td>
</tr>
<tr>
<td>5-11</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>12</td>
<td>Zero</td>
</tr>
<tr>
<td>13</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>14</td>
<td>Wait state (W)</td>
</tr>
<tr>
<td>15</td>
<td>Problem state (P)</td>
</tr>
<tr>
<td>16-17</td>
<td>Address-space control (AS)</td>
</tr>
<tr>
<td>18-19</td>
<td>Condition code (CC)</td>
</tr>
<tr>
<td>20-23</td>
<td>Program mask</td>
</tr>
<tr>
<td>25-30</td>
<td>Zero</td>
</tr>
<tr>
<td>31</td>
<td>Extended addressing mode (EA)</td>
</tr>
<tr>
<td>32</td>
<td>Basic addressing mode (BA)</td>
</tr>
<tr>
<td>33-63</td>
<td>Zero</td>
</tr>
<tr>
<td>64-127</td>
<td>Instruction address</td>
</tr>
</tbody>
</table>

In summary, bits 0, 2-4, 12, 24-30, and 33-63 are zero, bits 1, 5-11, and 13 are unpredictable, and the other bits are set with variable information from the PSW.

The wait-state, problem-state, address-space-control, condition-code, program-mask, extended-addressing-mode, and basic-addressing-mode values specify the state of the CPU before the TRAP instruction was executed. The instruction-address value is the updated instruction address, which is the address of the instruction following TRAP, or the address of the instruction following the execute-type instruction if TRAP was the target of an execute-type instruction.

When the PSW control in the trap control block is zero, the operation is as described above except as follows:

- Bit 31 of the current PSW must be zero; otherwise, a special-operation exception is recognized.
- A one is stored in bit position 12 of bytes 16-31.
- Bits 97-127 of the current PSW are stored in bit positions 33-63 of bytes 16-31, bits 33-96 of the current PSW are not stored, and zeros are stored in bit positions 64-127 of bytes 16-31 (bytes 24-31).

In this case, bytes 16-23 have the format of an ESA/390 PSW, which is as follows:

<table>
<thead>
<tr>
<th>Bits</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Zero</td>
</tr>
<tr>
<td>1</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>2-4</td>
<td>Zero</td>
</tr>
<tr>
<td>5-11</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>12</td>
<td>Zero</td>
</tr>
<tr>
<td>13</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>14</td>
<td>Wait state (W)</td>
</tr>
<tr>
<td>15</td>
<td>Problem state (P)</td>
</tr>
<tr>
<td>16-17</td>
<td>Address-space control (AS)</td>
</tr>
<tr>
<td>18-19</td>
<td>Condition code (CC)</td>
</tr>
<tr>
<td>20-23</td>
<td>Program mask</td>
</tr>
<tr>
<td>25-30</td>
<td>Zero</td>
</tr>
<tr>
<td>31</td>
<td>Extended addressing mode (EA)</td>
</tr>
<tr>
<td>32</td>
<td>Basic addressing mode (BA)</td>
</tr>
<tr>
<td>33-63</td>
<td>Zero</td>
</tr>
<tr>
<td>64-127</td>
<td>Instruction address</td>
</tr>
</tbody>
</table>

General Registers 0-15: Contents of general registers 0-15 are stored in byte positions 32-159 as described in “General-Registers Control (R)” on page 10-168. When bits 32-63 or 0-63 of the general registers are stored, they are stored in ascending order of register numbers, starting with register 0 and continuing up to and including register 15.

Bytes 160-255 always remain unchanged. Bytes 168-255 are reserved. Bytes 160-167 are available for use by programming.

Special Conditions

The CPU must be in the primary-space mode or access-register mode, and bit 31 in bytes 44-47 of the dispatchable-unit control table must be one; otherwise, a special-operation exception is recognized. A special-operation exception is also recognized if the PSW control, bit 13 of bytes 0-3 of the trap control block is zero and bit 31 of the current PSW, the extended-addressing-mode bit, is one.

All protection mechanisms apply in the usual way to the accesses to the trap control block and trap save area. Access exceptions may or may not be recognized for sections of the trap control block and trap save area that are not referenced by the TRAP instruction.

The trap-program address in the trap control block is not tested before it replaces the instruction address in the PSW. An odd address will cause a specification exception to be recognized as part of the execution of the next instruction.

The operation is suppressed on all addressing and protection exceptions.

Condition Code: The code remains unchanged.

Program Exceptions:
The priority of recognition of program exceptions for the instruction is shown in Figure 10-88.

<table>
<thead>
<tr>
<th>1.-6.</th>
<th>Exceptions with the same priority as the priority of program-interruption conditions for the general case.</th>
</tr>
</thead>
<tbody>
<tr>
<td>7.A</td>
<td>Access exceptions for second instruction halfword (TRAP4 only).</td>
</tr>
<tr>
<td>7.B</td>
<td>Special-operation exception due to the CPU not being in the primary-space mode or access-register mode.</td>
</tr>
<tr>
<td>7.C.1</td>
<td>Addressing exception for access to dispatchable-unit control table.</td>
</tr>
<tr>
<td>7.C.2</td>
<td>Special-operation exception due to bit 31 in bytes 44-47 of dispatchable-unit control table being zero.</td>
</tr>
<tr>
<td>8.A</td>
<td>Trace exceptions.</td>
</tr>
<tr>
<td>8.B.1</td>
<td>Access exceptions (fetch) for trap control block.</td>
</tr>
<tr>
<td>8.B.2</td>
<td>Special-operation exception due to PSW control in trap control block being zero and PSW bit 31 being one.</td>
</tr>
<tr>
<td>8.B.3</td>
<td>Access exceptions (store) for trap save area.</td>
</tr>
</tbody>
</table>

Figure 10-88. Priority of Execution: TRAP

**Programming Notes:**

1. It is intended that TRAP instructions will overlay instructions in an application program in order to give control to a trap program, which might be a program for performing fix-ups of data used by the application program, such as dates that may be a “Year-2000” problem. TRAP2 can overlay a two-byte instruction, and TRAP4 can overlay a four-byte instructions or the first four bytes of a six-byte instruction. The trap program is to simulate the overlaid instruction and perform fix-ups as appropriate, and it is then to return control to the application program.

2. The trap program can use the RESUME PROGRAM instruction to return control to the application program. For example, the trap program can restore the contents of all registers except access and general registers 15, and then, using those registers (or at least the general register) to address the trap save area, can restore the contents of those registers and also PSW fields from the trap save area. RESUME PROGRAM has control bits in its parameter list that allow it to restore PSW fields from a field having either the ESA/390 PSW format or the z/Architecture PSW format and to restore either bits 32-63 or 0-63 of a general register.

3. The trap control block and trap save area are in the home address space, and the trap program is in the primary address space. The trap-control-block address placed in general register 15 by TRAP can be useful to the trap program if (1) the primary address space and home address space are the same address space, (2) the trap control block and trap save area are at the same locations in the primary address space as in the home address space, or (3) the trap program can use access registers to access the home address space.

4. The storage-operand references for TRAP may be multiple-access references. (See “Storage-Operand Consistency” on page 5-123.)
Chapter 11. Machine-Check Handling

Machine-Check Detection .................................. 11-2
Correction of Machine Malfunctions ...................... 11-2
Error Checking and Correction ............................. 11-2
CPU Retry .................................................. 11-2
Effects of CPU Retry ....................................... 11-3
Checkpoint Synchronization ................................. 11-3
Handling of Machine Checks during
  Checkpoint Synchronization .............................. 11-3
  Checkpoint-Synchronization Operations ............... 11-4
  Checkpoint-Synchronization Action ...................... 11-4
Channel-Subsystem Recovery ............................... 11-5
Unit Deletion .............................................. 11-5
Handling of Machine Checks ............................... 11-5
  Validation .............................................. 11-6
Invalid CBC in Storage ................................... 11-7
  Programmed Validation of Storage ...................... 11-7
Invalid CBC in Storage Keys .............................. 11-7
Invalid CBC in Registers ................................ 11-9
Check-Stop State ......................................... 11-10
  System Check Stop .................................... 11-10
Machine-Check Interruption .............................. 11-10
  Exigent Conditions .................................. 11-10
  Repressible Conditions ............................... 11-11
  Interruption Action ................................ 11-11
  Point of Interruption ................................. 11-13
Machine-Check-Interruption Code ......................... 11-14
  Subclass ............................................. 11-14
    System Damage .................................... 11-15
    Instruction-Processing Damage ..................... 11-15
    System Recovery ................................ 11-15
    Timing-Facility Damage ............................ 11-15
    External Damage .................................. 11-16
    Degradation ..................................... 11-16
    Warning ......................................... 11-16
    Channel Report Pending ............................ 11-16
    Service-Processor Damage ......................... 11-17
    Channel-Subsystem Damage ......................... 11-17
  Subclass Modifiers .................................... 11-17
    Backed Up ....................................... 11-17
    Delayed Access Exception ......................... 11-17
    Ancillary Report .................................. 11-17
Synchronous Machine-Check-Interruption
  Conditions ............................................. 11-17
  Processing Backup .................................... 11-17
  Processing Damage .................................. 11-18

The machine-check-handling mechanism provides extensive equipment-malfunction detection to ensure the integrity of system operation and to permit automatic recovery from some malfunctions. Equipment malfunctions and certain external disturbances are reported by means of a machine-check interruption.

Storage Errors ............................................. 11-18
  Storage Error Uncorrected .............................. 11-18
  Storage Error Corrected ................................ 11-19
  Storage-Key Error Uncorrected .......................... 11-19
  Storage Degradation .................................. 11-19
  Indirect Storage Error ................................ 11-19
Machine-Check Interruption-Code Validity
  Bits ....................................................... 11-19
  PSW-MWP Validity .................................... 11-20
  PSW Mask and Key Validity ............................. 11-20
  PSW Program-Mask and Condition-Code Validity .... 11-20
  External-Damage-Code Validity ....................... 11-20
  Floating-Point-Register Validity ................. 11-20
  General-Register Validity .......................... 11-20
  Control-Register Validity ........................... 11-20
  Storage Logical Validity ............................. 11-21
  Access-Register Validity ............................. 11-21
  TOD-Programmable-Register Validity ............. 11-21
  Floating-Point-Control-Register Validity ......... 11-21
  CPU-Timer Validity .................................. 11-21
  Clock-Comparator Validity ............................ 11-21
Machine-Check Extended Interruption
  Information ............................................. 11-21
  Register-Save Areas .................................. 11-21
  External-Damage Code ................................ 11-22
  Failing-Storage Address .............................. 11-23
  Machine-Check Extended Save Area .................... 11-23
Handling of Machine-Check Conditions .................... 11-23
  Floating Interruption Conditions .................. 11-23
    Floating Machine-Check-Interruption Conditions ... 11-24
    Floating I/O Interruptions ....................... 11-24
Machine-Check Masking .................................. 11-24
  Channel-Report-Pending Subclass Mask ........... 11-24
  Recovery Subclass Mask ............................. 11-24
  Degradation Subclass Mask .......................... 11-24
  External-Damage Subclass Mask ..................... 11-24
  Warning Subclass Mask ................................ 11-25
Machine-Check Logout ................................... 11-25
Summary of Machine-Check Masking ..................... 11-25
to assist in program-damage assessment and recovery. The interruption supplies the program with information about the extent of the damage and the location and nature of the cause. Equipment malfunctions, errors, and other situations which can cause machine-check interruptions are referred to as machine checks.

Machine-Check Detection

Machine-check-detection mechanisms may take many forms, especially in control functions for arithmetic and logical processing, addressing, sequencing, and execution. For program-addressable information, detection is normally accomplished by encoding redundancy into the information in such a manner that most failures in the retention or transmission of the information result in an invalid code. The encoding normally takes the form of one or more redundant bits, called check bits, appended to a group of data bits. Such a group of data bits and the associated check bits are called a checking block. The size of the checking block depends on the model.

The inclusion of a single check bit in the checking block allows the detection of any single-bit failure within the checking block. In this arrangement, the check bit is sometimes referred to as a "parity bit." In other arrangements, a group of check bits is included to permit detection of multiple errors, to permit error correction, or both.

For checking purposes, the contents of the entire checking block, including the redundancy, are called the checking-block code (CBC). When a CBC completely meets the checking requirements (that is, no failure is detected), it is said to be valid. When both detection and correction are provided and a CBC is not valid but satisfies the checking requirements for correction (the failure is correctable), it is said to be near-valid. When a CBC does not satisfy the checking requirements (the failure is uncorrectable), it is said to be invalid.

Correction of Machine Malfunctions

Four mechanisms may be used to provide recovery from machine-detected malfunctions: error checking and correction, CPU retry, channel-subsystem recovery, and unit deletion.

Machine failures which are corrected successfully may or may not be reported as machine-check interruptions. If reported, they are system-recovery conditions, which permit the program to note the cause of CPU delay and to keep a log of such incidents.

Error Checking and Correction

When sufficient redundancy is included in circuitry or in a checking block, failures can be corrected. For example, circuitry can be triplicated, with a voting circuit to determine the correct value by selecting two matching results out of three, thus correcting a single failure. An arrangement for correction of failures of one order and for detection of failures of a higher order is called error checking and correction (ECC). Commonly, ECC allows correction of single-bit failures and detection of double-bit failures.

Depending on the model and the portion of the machine in which ECC is applied, correction may be reported as system recovery, or no report may be given.

Uncorrected errors in storage and in the storage key may be reported, along with a failing-storage address, to indicate where the error occurred. Depending on the situation, these errors may be reported along with system recovery or with the damage or backup condition resulting from the error.

CPU Retry

In some models, information about some portion of the state of the machine is saved periodically. The point in the processing at which this information is saved is called a checkpoint. The information saved is referred to as the checkpoint information. The action of saving the information is referred to as establishing a checkpoint. The action of discarding previously saved information is called invalidation of the checkpoint information. The length of the interval
between establishing checkpoints is model-dependent. Checkpoints may be established at the beginning of each instruction or several times within a single instruction, or checkpoints may be established less frequently.

Subsequently, this saved information may be used to restore the machine to the state that existed at the time when the checkpoint was established. After restoring the appropriate portion of the machine state, processing continues from the checkpoint. The process of restoring to a checkpoint and then continuing is called CPU retry.

CPU retry may be used for machine-check recovery, to effect nullification and suppression of instruction execution when certain program interruptions occur, and in other model-dependent situations.

**Effects of CPU Retry**

CPU retry is, in general, performed so that there is no effect on the program. However, change bits which have been changed from zeros to ones are not necessarily set back to zeros. As a result, change bits may appear to be set to ones for blocks which would have been accessed if restoring to the checkpoint had not occurred. If the path taken by the program is dependent on information that may be changed by another CPU or by a channel program or if an interruption occurs, then the final path taken by the program may be different from the earlier path; therefore, change bits may be ones because of stores along a path apparently never taken.

During the execution of the following instructions, CPU retry may result in condition code 3 being set with possibly incorrect data having been stored in the first operand location at or to the right of the location designated by the final address in general register R1:

- COMPRESSION CALL
- CONVERT UTF-16 TO UTF-32
- CONVERT UTF-16 TO UTF-8
- CONVERT UTF-32 TO UTF-16
- CONVERT UTF-32 TO UTF-8
- CONVERT UTF-8 TO UTF-16
- CONVERT UTF-8 TO UTF-32
- CIPHER MESSAGE
- CIPHER MESSAGE WITH CHAINING
- CIPHER MESSAGE WITH COUNTER
- CIPHER MESSAGE WITH CIPHER FEEDBACK
- CIPHER MESSAGE WITH OUTPUT FEEDBACK
- TRANSLATE ONE TO ONE
- TRANSLATE ONE TO TWO
- TRANSLATE TWO TO ONE
- TRANSLATE TWO TO TWO

During the execution of the PERFORM PSEUDO-RANDOM NUMBER OPERATION instruction’s generate operation, CPU retry may result in condition code 3 being set with possibly incorrect data having been stored in the first operand location at or to the left of the rightmost byte of the first operand (that is, to the left of the location designated by the combination of general registers R1 and R1 + 1).

The amount of data stored depends on the operation and the point in time at which CPU retry occurred. The amount of incorrect data stored will not exceed the minimum of (a) the length of the first operand, (b) the length of the second operand (for instructions having a second operand), and (c) the data processed in a single unit of operation of the instruction. In all cases, the storing will occur again, with correct data stored, if the instruction is executed again to continue processing the same operands.

**Checkpoint Synchronization**

Checkpoint synchronization consists in the following steps.

1. The CPU operation is delayed until all conceptually previous accesses by this CPU to storage have been completed, both for purposes of machine-check detection and as observed by other CPUs and by channel programs.
2. All previous checkpoints, if any, are invalidated.
3. Optionally, a new checkpoint is established.

The CPU operation is delayed until all of these actions appear to be completed, as observed by other CPUs and by channel programs.

**Handling of Machine Checks during Checkpoint Synchronization**

When, in the process of completing all previous stores as part of the checkpoint-synchronization action, the machine is unable to complete all stores successfully but can successfully restore the machine to a previous checkpoint, processing backup is reported.
When, in the process of completing all stores as part of the checkpoint-synchronization action, the machine is unable to complete all stores successfully and cannot successfully restore the machine to a previous checkpoint, the type of machine-check-interruption condition reported depends on the origin of the store. Failure to successfully complete stores associated with instruction execution may be reported as instruction-processing damage, or some less critical machine-check-interruption condition may be reported with the storage-logical-validity bit set to zero. A failure to successfully complete stores associated with the execution of an interruption, other than program or supervisor call, is reported as system damage.

When the machine check occurs as part of a checkpoint-synchronization action before the execution of an instruction, the execution of the instruction is nullified. When it occurs before the execution of an interruption, the interruption condition, if the interruption is external, I/O, or restart, is held pending. If the checkpoint-synchronization operation was a machine-check interruption, then along with the originating condition, either the storage-logical-validity bit is set to zero or instruction-processing damage is also reported. Program interruptions, if any, are lost.

Checkpoint-Synchronization Operations
All interruptions and the execution of certain instructions cause a checkpoint-synchronization action to be performed. The operations which cause a checkpoint-synchronization action are called checkpoint-synchronization operations and include:

- CPU reset
- All interruptions: external, I/O, machine check, program, restart, and supervisor call
- The BRANCH ON CONDITION (BCR) instruction with the M₁ and R₂ fields containing all ones and all zeros, respectively
- The instructions LOAD PSW, LOAD PSW EXTENDED, SET STORAGE KEY EXTENDED, and SUPERVISOR CALL
- All I/O instructions
- The instructions MOVE TO PRIMARY, MOVE TO SECONDARY, PROGRAM CALL, PROGRAM TRANSFER, SET ADDRESS SPACE CONTROL, and SET SECONDARY ASN, and PROGRAM RETURN when the state entry to be unstacked is a program-call state entry
- The four trace functions: branch tracing, ASN tracing, mode tracing, and explicit tracing, except that when the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register 0 is one, then it is unpredictable whether explicit tracing causes a checkpoint-synchronization action.

- PAGE IN and PAGE OUT

Programming Note: The instructions which are defined to cause the checkpoint-synchronization action invalidate checkpoint information but do not necessarily establish a new checkpoint. Additionally, the CPU may establish a checkpoint between any two instructions or units of operation, or within a single unit of operation. Thus, the point of interruption for the machine check is not necessarily at an instruction defined to cause a checkpoint-synchronization action.

Checkpoint-Synchronization Action
For all interruptions except I/O interruptions, a checkpoint-synchronization action is performed at the completion of the interruption. For I/O interruptions, a checkpoint-synchronization action may or may not be performed at the completion of the interruption. For all interruptions except program, supervisor-call, and exigent machine-check interruptions, a checkpoint-synchronization action is also performed before the interruption. The fetch access to the new PSW may be performed either before or after the first checkpoint-synchronization action. The store accesses and the changing of the current PSW associated with the interruption are performed after the first checkpoint-synchronization action and before the second.

For all checkpoint-synchronization instructions except BRANCH ON CONDITION (BCR), I/O instructions, and SUPERVISOR CALL, checkpoint-synchronization actions are performed before and after the execution of the instruction. For BCR, only one checkpoint-synchronization action is necessarily performed, and it may be performed either before or after the instruction address is updated. For SUPERVISOR CALL, a checkpoint-synchronization action is performed before the instruction is executed, including the updating of the instruction address in the PSW. The checkpoint-synchronization action taken after the supervisor-call interruption is considered to be part of the interruption action and not part of the instruction execution. For I/O instructions, a checkpoint-synchronization action is always performed.
before the instruction is executed and may or may not be performed after the instruction is executed.

The four trace functions — branch tracing, ASN tracing, mode tracing, and explicit tracing — cause checkpoint-synchronization actions to be performed before the trace action and after completion of the trace action, except that when the store-clock-fast facility is installed and the TRACE TOD-clock control in bit 32 of control register 0 is one, then it is unpredictable whether checkpoint-synchronization actions are performed for explicit tracing.

**Channel-Subsystem Recovery**

When errors are detected in the channel subsystem, the channel subsystem attempts to analyze and recover the internal state associated with the various channel-subsystem functions and the state of the channel subsystem and various subchannels. This process, which is called channel-subsystem recovery, may result in a complete recovery or may result in the termination of one or more I/O operations and the clearing of the affected subchannels. Special channel-report-pending machine-check-interruption conditions may be generated to indicate to the program the status of the channel-subsystem recovery.

Malfunctions associated with the I/O operations, depending on the severity of the malfunction, may be reported by means of the I/O-interruption mechanism or by means of the channel-report-pending and channel-subsystem-damage machine-check-interruption conditions.

**Unit Deletion**

In some models, malfunctions in certain units of the system can be circumvented by discontinuing the use of the unit. Examples of cases where unit deletion may occur include the disabling of all or a portion of a cache or of a translation-lookaside buffer (TLB). Unit deletion may be reported as a degradation machine-check-interruption condition.

**Handling of Machine Checks**

A machine check is caused by a machine malfunction and not by data or instructions. This is ensured during the power-on sequence by initializing the machine controls to a valid state and by placing valid CBC in the CPU registers, in the storage keys, and in main storage.

Designation of an unavailable component, such as a storage location, subchannel, or I/O device, does not cause a machine-check indication. Instead, such a condition is indicated by the appropriate program or I/O interruption or condition-code setting. In particular, an attempt to access a storage location which is not in the configuration, or which has power off at the storage unit, results in an accessing exception when detected by the CPU and does not generate a machine-check condition, even though the storage location or its associated storage key has invalid CBC. Similarly, if the channel subsystem attempts to access such a location, an I/O-interruption condition indicating program check is generated rather than a machine-check condition.

A machine check is indicated whenever the result of an operation could be affected by information with invalid CBC or when any other malfunction makes it impossible to establish reliably that an operation can be, or has been, performed correctly. When information with invalid CBC is fetched but not used, the condition may or may not be indicated, and the invalid CBC is preserved.

When a machine malfunction is detected, the action taken depends on the model, the nature of the malfunction, and the situation in which the malfunction occurs. Malfunctions affecting operator-facility actions may result in machine checks or may be indicated to the operator. Malfunctions affecting certain other operations such as SIGNAL PROCESSOR may be indicated by means of a condition code or may result in a machine-check-interruption condition.

A malfunction detected as part of an I/O operation may cause a machine-check-interruption condition, an I/O-error condition, or both. I/O-error conditions are indicated by an I/O interruption or by the appropriate condition-code setting during the execution of an I/O instruction. When the machine reports a failing-storage location detected during an I/O operation, both I/O-error and machine-check conditions may be indicated. The I/O-error condition is the primary indication to the program. The machine-check condition is a secondary indication, which is presented as system recovery together with a failing-storage address.
Certain malfunctions detected as part of I/O instructions and I/O operations are reported by means of special machine-check conditions called I/O machine-check conditions. Thus, malfunctions detected as part of an operation which is I/O related may be reported, depending on the error, in any of three ways: I/O-error condition, I/O machine-check condition, or non-I/O machine-check condition. In some cases, the definition requires the error to be reported by only one of these mechanisms; in other cases, any one, or in some cases, more than one, may be indicated.

**Programming Note:** Although the definition for machine-check conditions is that they are caused by machine malfunctions and not by data and instructions, there are certain unusual situations in which machine-check conditions are caused by events which are not machine malfunctions. Two examples follow:

1. In some cases, the channel-report-pending machine-check-interruption condition indicates a non-error situation. For example, this condition is generated at the completion of the function specified by RESET CHANNEL PATH.

2. Improper use of DIAGNOSE may result in machine-check conditions.

**Validation**

Machine errors can be generally classified as solid or intermittent, according to the persistence of the malfunction. A persistent machine error is said to be solid, and one that is not persistent is said to be intermittent. In the case of a register or storage location, a third type of error must be considered, called externally generated. An externally generated error is one where no failure exists in the register or storage location but invalid CBC has been introduced into the location by actions external to the location. For example, the value could be affected by a power transient, or an incorrect value may have been introduced when the information was placed at the location.

Invalid CBC is preserved as invalid when information with invalid CBC is fetched or when an attempt is made to update only a portion of the checking block. When an attempt is made to replace the contents of the entire checking block and the block contains invalid CBC, it depends on the operation and the model whether the block remains with invalid CBC or is replaced. An operation which replaces the contents of a checking block with valid CBC, while ignoring the current contents, is called a validation operation. Validation is used to place a valid CBC in a register or at a location which has an intermittent or externally generated error.

Validating a checking block does not ensure that a valid CBC will be observed the next time the checking block is accessed. If the failure is solid, validation is effective only if the information placed in the checking block is such that the failing bits are set to the value to which they fail. If an attempt is made to set the bits to the state opposite to that in which they fail, then the validation will not be effective. Thus, for a solid failure, validation is only useful to eliminate the error condition, even though the underlying failure remains, thereby reducing the exposure to additional reports. The locations, however, cannot be used, since invalid CBC will result from attempts to store other values at the location. For an intermittent failure, however, validation is useful to restore a valid CBC such that a subsequent partial store into the checking block will be permitted. (A partial store is a store into a checking block without replacing the entire checking block.)

When a checking block consists of multiple bytes in storage, or multiple bits in CPU registers, the invalid CBC can be made valid only when all of the bytes or bits are replaced simultaneously.

For each type of field in the system, certain instructions are defined to validate the field. Depending on the model, additional instructions may also perform validation; or, in some models, a register is automatically validated as part of the machine-check-interruption sequence after the original contents of the register are placed in the appropriate save area.

When an error occurs in a checking block, the original information contained in the checking block should be considered lost even after validation. Automatic register validation leaves the contents unpredictable. Programmed and manual validation of checking blocks causes the contents to be changed explicitly.

**Programming Note:** The machine-check-interruption handler must assume that the registers require validation. Thus, each register should be loaded, using an instruction defined to validate, before the register is used or stored.
Invalid CBC in Storage

The size of the checking block in storage depends on the model but is never more than 4K bytes.

When invalid CBC is detected in storage, a machine-check condition may occur; depending on the circumstances, the machine-check condition may be system damage, instruction-processing damage, or system recovery. If the invalid CBC is detected as part of the execution of a channel program, the error is reported as an I/O-error condition. When a CCW, indirect-data-address word, modified-indirect-data-address word, or data is prefetched from storage, is found to have invalid CBC, but is not used in the channel program, the condition is normally not reported as an I/O-error condition. The condition may or may not be reported as a machine-check-interruption condition. Invalid CBC detected during accesses to storage for other than CPU-related accesses may be reported as system recovery with storage error uncorrected indicated, since the primary error indication is reported by some other means.

When the storage checking block consists of multiple bytes and contains invalid CBC, special storage-validation procedures are generally necessary to restore or place new information in the checking block. Validation of storage is provided with the manual load-clear and system-reset-clear operations and is also provided as a program function. Programmed storage validation is done a block at a time, by executing the privileged instruction TEST BLOCK. Manual storage validation by clear reset validates all blocks which are available in the configuration.

A checking block with invalid CBC is never validated unless the entire contents of the checking block are replaced. An attempt to store into a checking block having invalid CBC, without replacing the entire checking block, leaves the data in the checking block (including the check bits) unchanged. Even when an instruction or a channel-program-input operation specifies that the entire contents of a checking block are to be replaced, validation may or may not occur, depending on the operation and the model.

Programming Note: Machine-check conditions may be reported for prefetched and unused data. Depending on the model, such situations may or may not be successfully retried. For example, a BRANCH AND LINK (BALR) instruction which specifies an R

Invalid CBC in Storage Keys

Provided that an invalid CBC does not exist in the storage key associated with a 4K-byte block, the instruction TEST BLOCK causes the entire 4K-byte block to be set to zeros with a valid CBC, regardless of the current contents of the storage. TEST BLOCK thus removes an invalid CBC from a location in storage which has an intermittent, or one-time, failure. However, if a permanent failure exists in a portion of the storage, a subsequent fetch may find an invalid CBC.

Programmed Validation of Storage

Depending on the model, each storage key may be contained in a single checking block, or the access-control and fetch-protection bits and the reference and change bits may be in separate checking blocks.

Figure 11-1 on page 11-8 describes the action taken when the storage key has invalid CBC. The figure indicates the action taken for the case when the access-control and fetch-protection bits are in one checking block and the reference and change bits are in a separate checking block. In machines where both fields are included in a single checking block, the action taken is the combination of the actions for each field in error, except that completion is permitted only if an error in all affected fields permits completion. References to main storage to which key-controlled protection does not apply are treated as if an access key of zero is used for the reference. This includes such references as channel-program references during initial program loading and implicit references, such as interruption action and DAT-table accesses.
## Action Taken on Invalid CBC

<table>
<thead>
<tr>
<th>Type of Reference</th>
<th>For Access-Control and Fetch-Protection Bits</th>
<th>For Reference and Change Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>SET STORAGE KEY EXTENDED</td>
<td>Complete; validate.</td>
<td>Complete; validate.</td>
</tr>
<tr>
<td>INSERT STORAGE KEY EXTENDED</td>
<td>PD; preserve.</td>
<td>PD; preserve.</td>
</tr>
<tr>
<td>RESET REFERENCE BIT EXTENDED</td>
<td>PD or complete; preserve.</td>
<td>PD; preserve.</td>
</tr>
<tr>
<td>INSERT VIRTUAL STORAGE KEY or TEST PROTECTION</td>
<td>PD; preserve.</td>
<td>CPF; preserve.</td>
</tr>
<tr>
<td>CPU prefetch (information not used)</td>
<td>CPF; preserve.</td>
<td>CPF; preserve.</td>
</tr>
<tr>
<td>Channel-program prefetch (information not used)</td>
<td>IPF; preserve.</td>
<td>IPF; preserve.</td>
</tr>
<tr>
<td>Fetch, nonzero access key</td>
<td>MC; preserve.</td>
<td>MC or complete; preserve.</td>
</tr>
<tr>
<td>Store¹, nonzero access key</td>
<td>MC²; preserve.</td>
<td>MC and preserve; or complete³ and correct.</td>
</tr>
<tr>
<td>Fetch, zero access key⁴</td>
<td>MC or complete; preserve.</td>
<td>MC or complete; preserve.</td>
</tr>
<tr>
<td>Store¹, zero access key²</td>
<td>MC or complete; preserve.</td>
<td>MC and preserve; or complete³ and correct.</td>
</tr>
</tbody>
</table>

### Explanation:

1. CPU virtual- and logical-address store accesses are subject to DAT protection. When the DAT-protection bit is one, the location will not be changed; however, the machine may indicate a machine-check condition if the storage key or the data itself has invalid CBC.
2. The contents of the main-storage location are not changed.
3. The contents of the reference and change bits are set to ones if the “complete” action is taken.
4. The action shown for an access key of zero is also applicable to references to which key-controlled protection does not apply.

**Complete**: The condition does not cause termination of the execution of the instruction, and, unless an unrelated condition prohibits it, the execution of the instruction is completed, ignoring the error condition. No machine-check-damage conditions are reported, but system recovery may be reported.

**Correct**: The reference and change bits are set to ones with valid CBC.

**Preserve**: The contents of the entire checking block having invalid CBC are left unchanged.

**Validate**: The entire key is set to the new value with valid CBC. When the conditional-SSKE facility is installed and either or both the MR and MC bits of the M3 field are one, condition code 3 is set when the instruction completes.

**CPF**
- Invalid CBC in the storage key for a CPU prefetch which is unused, or for instructions which do not examine the reference and change bits, may result in any of the following situations:
  - The operation is completed; no machine-check condition is reported.
  - The operation is completed; system recovery, with storage-key error uncorrected, is reported.
  - Instruction-processing damage, with or without backup and with storage-key error uncorrected, is reported.

**IPF**
- Invalid CBC in the storage key for a channel-program prefetch which is unused may result in any of the following:
  - The I/O operation is completed; no machine-check condition is reported.
  - The I/O operation is completed; system recovery, with storage-key error uncorrected, is reported.

**MC**
- Same as PD for CPU references, but a channel-subsystem reference may result in the following combinations of I/O-error conditions and machine-check conditions:
  - An I/O-error condition is reported; no machine-check condition is reported.
  - An I/O-error condition is reported; system recovery, with or without storage-key error uncorrected, is reported.

**PD**
- Instruction-processing damage, with or without backup and with or without storage-key error uncorrected, is reported.

**Note**: When storage-key error uncorrected is reported, a failing storage address may or may not also be reported.

---

*Figure 11-1. Invalid CBC in Storage Keys*
Invalid CBC in Registers

When invalid CBC is detected in a CPU register, a machine-check condition may be recognized. CPU registers include the general, floating-point, floating-point-control, access, control, vector, and TOD programmable registers, the current PSW, the prefix register, the TOD clock, the CPU timer, and the clock comparator.

When a machine-check interruption occurs, whether or not it is due to invalid CBC in a CPU register, the following actions affecting the CPU registers, other than the prefix register and the TOD clock, are taken as part of the interruption.

1. The contents of the registers are saved in assigned storage locations. Any register which is in error is identified by a corresponding validity bit of zero in the machine-check-interruption code. Malfunctions detected during register saving do not result in additional machine-check-interruption conditions; instead, the correctness of all the information stored is indicated by the appropriate setting of the validity bits.

2. On some models, registers with invalid CBC are then validated, their actual contents being unpredictable. On other models, programmed validation is required.

The prefix register and the TOD clock are not stored during a machine-check interruption, have no corresponding validity bit, and are not validated.

On those models in which registers are not automatically validated as part of the machine-check interruption, a register with invalid CBC will not cause a machine-check-interruption condition unless the contents of the register are actually used. In these models, each register may consist of one or more checking blocks, but multiple registers are not included in a single checking block. When only a portion of a register is accessed, invalid CBC in the unused portion of the same register may cause a machine-check-interruption condition. For example, invalid CBC in the right half of a floating-point register may cause a machine-check-interruption condition if a LOAD (LE) operation attempts to replace the left half, or short form, of the register.

Invalid CBC associated with the prefix register cannot safely be reported by the machine-check interruption, since the interruption itself requires that the prefix value be applied to convert real addresses to the corresponding absolute addresses. Invalid CBC in the prefix register causes the CPU to enter the check-stop state immediately.

On those models which do not validate registers during a machine-check interruption, the following instructions will cause validation of a register, provided the information in the register is not used before the register is validated. Other instructions, although they replace the entire contents of a register, do not necessarily cause validation.

General registers are validated by BRANCH AND SAVE and LOAD ADDRESS executed in the 64-bit addressing mode, by LOAD (LGR), and by LOAD (LG) and LOAD MULTIPLE (LMG) if the operand is on a doubleword boundary.

Floating-point registers are validated by LOAD (LDR) and, if the operand is on a doubleword boundary, by LOAD (LD).

The floating-point-control register is validated by LOAD FLOATING POINT CONTROL REGISTER.

Vector registers and corresponding floating-point registers are validated by VECTOR LOAD (VL) and VECTOR LOAD MULTIPLE (VLM).

Access registers are validated by LOAD ACCESS MULTIPLE. Only the even-odd access-register pairs that are included in the set of access registers specified for LOAD ACCESS MULTIPLE are validated. Thus, when a single access register is specified, or when a pair of access registers starting with an odd-numbered register is specified, no register is validated.

Control registers may be validated either singly or in groups by using the instruction LOAD CONTROL (LCTLG).

The TOD programmable register, CPU timer, clock comparator, and prefix register are validated by SET CLOCK PROGRAMMABLE REGISTER, SET CPU TIMER, SET CLOCK COMPARATOR, and SET PREFIX, respectively.

The TOD clock is validated by a SET CLOCK instruction that sets the clock.

Programming Note: Depending on the register and the model, the contents of a register may be vali-
dated by the machine-check interruption, or the model may require that a program execute a validating instruction after the machine-check interruption has occurred. In the case of the CPU timer, depending on the model, both the machine-check interruption and validating instructions may be required to restore the CPU timer to full working order.

Check-Stop State

In certain situations, it is impossible or undesirable to continue operation when a machine error occurs. In these cases, the CPU may enter the check-stop state, which is indicated by the check-stop indicator. In general, the CPU may enter the check-stop state whenever an uncorrectable error or other malfunction occurs and the machine is unable to recognize a specific machine-check-interruption condition.

The CPU always enters the check-stop state if any of the following conditions exists:

- PSW bit 13 is zero, and an exigent machine-check condition is generated.
- During the execution of an interruption due to one exigent machine-check condition, another exigent machine-check condition is detected.
- During a machine-check interruption, the machine-check-interruption code cannot be stored successfully, or the new PSW cannot be fetched successfully.
- Invalid CBC is detected in the prefix register.
- A malfunction in the receiving CPU, which is detected after accepting the order, prevents the successful completion of a SIGNAL PROCESSOR order and the order was a reset, or the receiving CPU cannot determine what the order was. The receiving CPU enters the check-stop state.

There may be many other conditions for particular models when an error may cause check stop.

When the CPU is in the check-stop state, instructions and interruptions are not executed. The TOD clock is normally not affected by the check-stop state. The CPU timer may or may not run in the check-stop state, depending on the error and the model. The start key and stop key are not effective in this state.

The CPU may be removed from the check-stop state by CPU reset.

In a multiprocessing configuration, a CPU entering the check-stop state generates a request for a malfunction-alert external interruption to all CPUs in the configuration. Except for the reception of a malfunction alert, other CPUs and the I/O system are normally unaffected by the check-stop state in a CPU. However, depending on the nature of the condition causing the check stop, other CPUs may also be delayed or stopped, and channel subsystem and I/O activity may be affected.

System Check Stop

In a multiprocessing configuration, some errors, malfunctions, and damage conditions are of such severity that the condition causes all CPUs in the configuration to enter the check-stop state. This condition is called a system check stop. The state of the channel subsystem and I/O activity is unpredictable.

Machine-Check Interruption

A request for a machine-check interruption, which is made pending as the result of a machine check, is called a machine-check-interruption condition. There are two types of machine-check-interruption conditions: exigent conditions and repressible conditions.

Exigent Conditions

Exigent machine-check-interruption conditions are those in which damage has or would have occurred such that execution of the current instruction or interruption sequence cannot safely continue. Exigent conditions include two subclasses: instruction-processing damage and system damage. In addition to indicating specific exigent conditions, system damage is used to report any malfunction or error which cannot be isolated to a less severe report.

Exigent conditions for instruction sequences can be either nullifying exigent conditions or terminating exigent conditions, according to whether the instructions affected are nullified or terminated. Exigent conditions for interruption sequences are terminating exi-
gent conditions. The terms “nullification” and “termination” have the same meanings as those used in Chapter 5, “Program Execution”, except that more than one instruction may be involved. Thus, a nullifying exigent condition indicates that the CPU has returned to the beginning of a unit of operation prior to the error. A terminating exigent condition means that the results of one or more instructions may have unpredictable values.

Repressible Conditions

Repressible machine-check-interruption conditions are those in which the results of the instruction-processing sequence have not been affected. Repressible conditions can be delayed, until the completion of the current instruction or even longer, without affecting the integrity of CPU operation. Repressible conditions are of three groups: recovery, alert, and repressible damage. Each group includes one or more subclasses.

A malfunction in the CPU, storage, or operator facilities which has been successfully corrected or circumvented internally without logical damage is called a recovery condition. Depending on the model and the type of malfunction, some or all recovery conditions may be discarded and not reported. Recovery conditions that are reported are grouped in one subclass, system recovery.

A machine-check-interruption condition not directly related to a machine malfunction is called an alert condition. The alert conditions are grouped in two subclasses: degradation and warning.

A malfunction resulting in an incorrect state of a portion of the system not directly affecting sequential CPU operation is called a repressible-damage condition. Repressible-damage conditions are grouped in five subclasses, according to the function affected: timing-facility damage, external damage, channel report pending, channel-subsystem damage, and service-processor damage.

Programming Notes:

1. Even though repressible conditions are usually reported only at normal points of interruption, they may also be reported with exigent machine-check conditions. Thus, if an exigent machine-check condition causes an instruction to be abnormally terminated and a machine-check interruption occurs to report the exigent condition, any pending repressible conditions may also be reported. The meaningfulness of the validity bits depends on what exigent condition is reported.

2. Classification of damage as either exigent or repressible does not imply the severity of the damage. The distinction is whether action must be taken as soon as the damage is detected (exigent) or whether the CPU can continue processing (repressible). For a repressible condition, the current instruction can be completed before taking the machine-check interruption if the CPU is enabled for machine checks; if the CPU is disabled for machine checks, the condition can safely be kept pending until the CPU is again enabled for machine checks.

For example, the CPU may be disabled for machine-check interruptions because it is handling an earlier instruction-processing-damage interruption. If, during that time, an I/O operation encounters a storage error, that condition can be kept pending because it is not expected to interfere with the current machine-check processing. If, however, the CPU also makes a reference to the area of storage containing the error before re-enabling machine-check interruptions, another instruction-processing-damage condition is created, which is treated as an exigent condition and causes the CPU to enter the check-stop state.

3. A repressible condition may be a floating condition. A floating repressible condition is eligible to cause an interruption on any CPU in the configuration. At the point when a CPU performs an interruption for a floating repressible condition, the condition is no longer eligible to cause an interruption on the remaining CPUs in the configuration.

Interruption Action

A machine-check interruption causes the following actions to be taken. An architectural-mode identification with the value 01 hex is stored at real location 163. The PSW reflecting the point of interruption is stored as the machine-check old PSW in the quadword at real location 352. The contents of other registers are stored in register-save areas at real locations 4608-4863, 4892-4895, 4900-4911, 4913-4919, 4928-5119, and in a machine-check extended
save area designated by the contents of real locations 4528-4535. After the contents of the registers are stored in register-save areas and extended save area, depending on the model, the registers may be validated with the contents being unpredictable. A machine-check-interruption code (MCIC) of eight bytes is stored at real locations 232-239. An external-damage code may be stored at real locations 244-247, and a failing-storage address may be stored at real locations 248-255. The new PSW is fetched from real locations 480-495. In addition, a machine-check logout may have occurred.

The machine-generated addresses used to access the old and new PSW, the MCIC, extended interruption information, and the fixed-logout area are all real addresses.

The fields in assigned storage locations that are accessed during the machine-check interruption are summarized in Figure 11-2.

<table>
<thead>
<tr>
<th>Information Stored (Fetched)</th>
<th>Starting Location*</th>
<th>Length in Bytes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Architectural-mode identification</td>
<td>163</td>
<td>1</td>
</tr>
<tr>
<td>Old PSW</td>
<td>352</td>
<td>16</td>
</tr>
<tr>
<td>New PSW (fetched)</td>
<td>480</td>
<td>16</td>
</tr>
<tr>
<td>Machine-check-interruption code</td>
<td>232</td>
<td>8</td>
</tr>
<tr>
<td>Register-save areas</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Floating-point registers 0-15</td>
<td>4608</td>
<td>128</td>
</tr>
<tr>
<td>General registers 0-15</td>
<td>4736</td>
<td>128</td>
</tr>
<tr>
<td>Floating-point control register</td>
<td>4892</td>
<td>4</td>
</tr>
<tr>
<td>TOD programmable register</td>
<td>4900</td>
<td>4</td>
</tr>
<tr>
<td>CPU timer</td>
<td>4904</td>
<td>8</td>
</tr>
<tr>
<td>Clock comparator</td>
<td>4913</td>
<td>7</td>
</tr>
<tr>
<td>Access registers 0-15</td>
<td>4928</td>
<td>64</td>
</tr>
<tr>
<td>Control registers 0-15</td>
<td>4992</td>
<td>128</td>
</tr>
<tr>
<td>Extended interruption information</td>
<td></td>
<td></td>
</tr>
<tr>
<td>External-damage code</td>
<td>244</td>
<td>4</td>
</tr>
<tr>
<td>Failing-storage address</td>
<td>248</td>
<td>8</td>
</tr>
<tr>
<td>Fixed-logout area</td>
<td>4864</td>
<td>16</td>
</tr>
</tbody>
</table>

**Explanation:**
* All locations are in real storage.

Figure 11-2. Machine-Check-Interruption Locations

When the vector facility for z/Architecture is installed, and bits 0-53 of real locations 4528-4535 are not all zeros, then other fields are stored in the machine-check extended save area. Figure 11-3 lists the fields that are stored, their offsets within the area, and their lengths. Bytes 512-1023 of the extended save area remain unchanged.

<table>
<thead>
<tr>
<th>Information Stored (Fetched)</th>
<th>Starting Location</th>
<th>Length in Bytes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vector registers 0-31</td>
<td>0</td>
<td>512</td>
</tr>
<tr>
<td>Reserved (unchanged)</td>
<td>512</td>
<td>512</td>
</tr>
</tbody>
</table>

Figure 11-3. Machine-Check Extended Save Area Locations

If the machine-check-interruption code cannot be stored successfully or the new PSW cannot be fetched successfully, the CPU enters the check-stop state.

A repressible machine-check condition can initiate a machine-check interruption only if both PSW bit 13 is one and the associated subclass mask bit, if any, in control register 14 is also one. When it occurs, the interruption does not terminate the execution of the current instruction; the interruption is taken at a normal point of interruption, and no program or supervisor-call interruptions are eliminated. If the machine check occurs during the execution of a machine function, such as a CPU-timer update, the machine-check interruption takes place after the machine function has been completed.

When the CPU is disabled for a particular repressible machine-check condition, the condition remains pending. Depending on the model and the condition, multiple repressible conditions may be held pending for a particular subclass, or only one condition may be held pending for a particular subclass, regardless of the number of conditions that may have been detected for that subclass.

When a repressible machine-check interruption occurs because the interruption condition is in a subclass for which the CPU is enabled, pending conditions in other subclasses may also be indicated by the same interruption code, even though the CPU is disabled for those subclasses. All indicated conditions are then cleared.

If a machine check which is to be reported as a system-recovery condition is detected during the execution of the interruption procedure due to a previous machine-check condition, the system-recovery condition may be combined with the other conditions, discarded, or held pending.
An exigent machine-check condition can cause a machine-check interruption only when PSW bit 13 is one. When a nullifying exigent condition causes a machine-check interruption, the interruption is taken at a normal point of interruption. When a terminating exigent condition causes a machine-check interruption, the interruption terminates the execution of the current instruction and may eliminate the program and supervisor-call interruptions, if any, that would have occurred if execution had continued. Proper execution of the interruption sequence, including the storing of the old PSW and other information, depends on the nature of the malfunction. When an exigent machine-check condition occurs during the execution of a machine function, such as a CPU-timer update, the sequence is not necessarily completed.

If, during the execution of an interruption due to one exigent machine-check condition, another exigent machine check is detected, the CPU enters the check-stop state. If an exigent machine check is detected during an interruption due to a repressible machine-check condition, system damage is reported.

When PSW bit 13 is zero, an exigent machine-check condition causes the CPU to enter the check-stop state.

Machine-check-interruption conditions are handled in the same manner regardless of whether the wait-state bit in the PSW is one or zero: a machine-check condition causes an interruption if the CPU is enabled for that condition.

Machine checks which occur while the rate control is set to the instruction-step position are handled in the same manner as when the control is set to the process position; that is, recovery mechanisms are active, and machine-check interruptions occur when allowed. Machine checks occurring during a manual operation may be indicated to the operator, may generate a system-recovery condition, may result in system damage, or may cause a check stop, depending on the model.

Every reasonable attempt is made to limit the side effects of any machine check and the associated interruption. Normally, interruptions, as well as the progress of I/O operations, remain unaffected. The malfunction, however, may affect these activities, and, if the currently active PSW has bit 13 set to one, the machine-check interruption will indicate the total extent of the damage caused, and not just the damage which originated the condition.

**Point of Interruption**

The point in the processing which is indicated by the interruption and used as a reference point by the machine to determine and indicate the validity of the status stored is referred to as the point of interruption.

Because of the checkpoint capability in models with CPU retry, the interruption resulting from an exigent machine-check-interruption condition may indicate a point in the CPU processing sequence which is logically prior to the error. Additionally, the model may have some choice as to which point in the CPU processing sequence the interruption is indicated, and, in some cases, the status which can be indicated as valid depends on the point chosen.

Only certain points in the processing may be used as a point of interruption. For repressible machine-check interruptions, the point of interruption must be after one unit of operation is completed and any associated program or supervisor-call interruption is taken, and before the next unit of operation is begun.

Exigent machine-check conditions for instruction sequences are those in which damage has or would have occurred to the instruction stream. Thus, the damage can normally be associated with a point part way through an instruction, and this point is called the point of damage. In some cases, there may be one or more instructions separating the point of damage and the point of interruption, and the processing associated with one or more instructions may be damaged. When the point of interruption is a point prior to the point of damage due to a nullifiable exigent machine-check condition, the point of interruption can be only at the same points as for repressible machine-check conditions.

In addition to the point of interruption permitted for repressible machine-check conditions, the point of interruption for a terminating exigent machine-check condition may also be after the unit of operation is completed but before any associated program or supervisor-call interruption occurs. In this case, a valid PSW instruction address is defined as that which would have been stored in the old PSW for the program or supervisor-call interruption. Since the operation has been terminated, the values in the
result fields, other than the instruction address, are unpredictable. Thus, the validity bits associated with fields which are due to be changed by the instruction stream are meaningless when a terminating exigent machine-check condition is reported.

When the point of interruption and the point of damage due to an exigent machine-check condition are separated by a checkpoint-synchronization function, the damage has not been isolated to a particular program, and system damage is indicated.

When an exigent machine-check-interruption condition occurs, the point of interruption which is chosen affects the amount of damage which must be indicated. An attempt is made, when possible, to choose a point of interruption which permits the minimum indication of damage. In general, the preference is the interruption point immediately preceding the error.

When all the status information stored as a result of an exigent machine-check-interruption condition does not reflect the same point, an attempt is made, when possible, to choose the point of interruption so that the instruction address which is stored in the machine-check old PSW is valid.

**Machine-Check-Interruption Code**

On all machine-check interruptions, a machine-check-interruption code (MCIC) is stored in the doubleword starting at real location 232. The code has the format shown in Figure 11-4.

Bits in the MCIC which are not assigned or not implemented by a particular model are stored as zeros.

### Bit Name

<table>
<thead>
<tr>
<th>Bit</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>System damage (SD)</td>
</tr>
<tr>
<td>1</td>
<td>Instruction-processing damage (PD)</td>
</tr>
<tr>
<td>2</td>
<td>System recovery (SR)</td>
</tr>
<tr>
<td>4</td>
<td>Timing-facility damage (CD)</td>
</tr>
<tr>
<td>5</td>
<td>External damage (ED)</td>
</tr>
<tr>
<td>7</td>
<td>Degradation (DG)</td>
</tr>
<tr>
<td>8</td>
<td>Warning (W)</td>
</tr>
<tr>
<td>9</td>
<td>Channel report pending (CP)</td>
</tr>
<tr>
<td>10</td>
<td>Service-processor damage (SP)</td>
</tr>
<tr>
<td>11</td>
<td>Channel subsystem damage (CK)</td>
</tr>
<tr>
<td>14</td>
<td>Backed up (B)</td>
</tr>
<tr>
<td>16</td>
<td>Storage error uncorrected (SE)</td>
</tr>
<tr>
<td>17</td>
<td>Storage error corrected (SC)</td>
</tr>
<tr>
<td>18</td>
<td>Storage-key error uncorrected (KE)</td>
</tr>
<tr>
<td>19</td>
<td>Storage degradation (DS)</td>
</tr>
<tr>
<td>20</td>
<td>PSW-MWP validity (WP)</td>
</tr>
<tr>
<td>21</td>
<td>PSW mask and key validity (MS)</td>
</tr>
<tr>
<td>22</td>
<td>PSW-program-mask and condition-code validity (PM)</td>
</tr>
<tr>
<td>23</td>
<td>PSW-instruction-address validity (IA)</td>
</tr>
<tr>
<td>24</td>
<td>Failing-storage-address validity (FA)</td>
</tr>
<tr>
<td>25</td>
<td>Vector-register validity (VR)</td>
</tr>
<tr>
<td>26</td>
<td>External-damage-code validity (EC)</td>
</tr>
<tr>
<td>27</td>
<td>Floating-point-register validity (FP)</td>
</tr>
<tr>
<td>28</td>
<td>General-register validity (GR)</td>
</tr>
<tr>
<td>29</td>
<td>Control-register validity (CR)</td>
</tr>
<tr>
<td>31</td>
<td>Storage logical validity (ST)</td>
</tr>
<tr>
<td>32</td>
<td>Indirect storage error (IE)</td>
</tr>
<tr>
<td>33</td>
<td>Access-register validity (AR)</td>
</tr>
<tr>
<td>34</td>
<td>Delayed-access exception (DA)</td>
</tr>
<tr>
<td>42</td>
<td>TOD-programmable-register validity (PR)</td>
</tr>
<tr>
<td>43</td>
<td>Floating-point-control-register validity (FC)</td>
</tr>
<tr>
<td>44</td>
<td>Ancillary report (AP)</td>
</tr>
<tr>
<td>46</td>
<td>CPU-timer validity (CT)</td>
</tr>
<tr>
<td>47</td>
<td>Clock-comparator validity (CC)</td>
</tr>
</tbody>
</table>

*Note:* All other bits of the MCIC are unassigned and stored as zeros.

**Figure 11-4. Machine-Check Interruption-Code Format**

### Subclass

Bits 0-2 and 4-11 are the subclass bits which identify the type of machine-check condition causing the interruption. At least one of the subclass bits is stored as a one. When multiple errors have occurred, several subclass bits may be set to ones.
System Damage
Bit 0 (SD), when one, indicates that damage has occurred which cannot be isolated to one or more of the less severe machine-check subclasses. When system damage is indicated, the ancillary-report bit, bit 44, is meaningful, the remaining bits in the machine-check-interruption code are not meaningful, and information stored in the register-save areas and machine-check extended-interruption fields is not meaningful.

System damage is a terminating exigent condition and has no subclass-mask bit.

Instruction-Processing Damage
Bit 1 (PD), when one, indicates that damage has occurred to the instruction processing of the CPU.

The exact meaning of bit 1 depends on the setting of the backed-up bit, bit 14. When the backed-up bit is one, the condition is called processing backup. When the backed-up bit is zero, the condition is called processing damage. These two conditions are described in “Synchronous Machine-Check-Interruption Conditions” on page 11-17.

Instruction-processing damage can be a nullifying or a terminating exigent condition and has no subclass-mask bit.

System Recovery
Bit 2 (SR), when one, indicates that malfunctions were detected but did not result in damage or have been successfully corrected. Some malfunctions detected as part of an I/O operation may result in a system-recovery condition in addition to an I/O-error condition. The presence and extent of the system-recovery capability depend on the model.

System recovery is a repressible condition. It is masked by the recovery subclass-mask bit, which is in bit position 36 of control register 14.

Programming Notes:

1. System recovery may be used to report a failing-storage address detected by a CPU prefetch or by an I/O operation.

2. Unless the corresponding validity bits are ones, the indication of system recovery does not imply storage logical validity or that the fields stored as a result of the machine-check interruption are valid.

Timing-Facility Damage
Bit 4 (CD), when one, indicates that damage has occurred to the TOD clock, CPU timer, clock comparator, or TOD programmable register, or to the CPU-timer or clock-comparator external-interruption conditions. The timing-facility-damage machine-check condition is set whenever any of the following occurs:

1. The TOD clock enters the error or not-operational state.

2. The CPU timer is damaged, and the CPU is enabled for CPU-timer external interruptions. On some models, this condition may be recognized even when the CPU is not enabled for CPU-timer interruptions. Depending on the model, the machine-check condition may be generated only as the CPU timer enters an error state. Or, the machine-check condition may be continuously generated whenever the CPU is enabled for CPU-timer interruptions, until the CPU timer is validated.

3. The clock comparator is damaged, and the CPU is enabled for clock-comparator external interruptions. On some models, this condition may be recognized even when the CPU is not enabled for clock-comparator interruptions.

Timing-facility damage may also be set along with instruction-processing damage when an instruction which accesses the TOD clock, CPU timer, or clock comparator produces incorrect results. Depending on the model, the TOD programmable register, CPU timer, or clock comparator may be validated by the interruption which reports the TOD programmable register, CPU timer, or clock comparator as invalid.

Timing-facility damage is a repressible condition. It is masked by the external-damage subclass-mask bit, which is in bit position 38 of control register 14.

Timing-facility-damage conditions for the CPU timer and the clock comparator are not recognized on most models when these facilities are not in use. The facilities are considered not in use when the CPU is disabled for the corresponding external interruptions (PSW bit 7, or the subclass-mask bits, bits 52 and 53 of control register 0, are zeros), and when the corresponding set and store instructions are not executed. Timing-facility-damage conditions that are already...
pending remain pending, however, when the CPU is disabled for the corresponding external interruption.

Timing-facility-damage conditions due to damage to the TOD clock are always recognized.

With TOD-clock steering, damage to the TOD clock is considered to be of such severity that it is undesirable to continue operation. When the TOD-clock-steering facility is installed, and damage has occurred to the TOD-clock-steering registers or the TOD clock and the damage is limited to a single CPU, then that CPU enters the check-stop state. If the TOD clock is in the not-operational state or error state, or when damage has occurred to the TOD-clock-steering registers or the TOD clock, and the damage affects all CPUs, then a system check stop occurs.

**External Damage**

Bit 5 (ED), when one, indicates that damage has occurred during operations not directly associated with processing the current instruction.

When bit 5, external damage, is one and bit 26, external-damage-code validity, is also one, the external-damage code has been stored to indicate, in more detail, the cause of the external-damage machine-check interruption. When the external damage cannot be isolated to one or more of the conditions as defined in the external-damage code, or when the detailed indication for the condition is not implemented by the model, external damage is indicated with bit 26 set to zero. The presence and extent of reporting external damage depend on the model.

External damage is a repressible condition. It is masked by the external-damage subclass-mask bit, which is in bit position 38 of control register 14.

**Degradation**

Bit 7 (DG), when one, indicates that continuous degradation of system performance, more serious than that indicated by system recovery, has occurred. Degradation may be reported when system-recovery conditions exceed a machine-preestablished threshold or when unit deletion has occurred. The presence and extent of the degradation-report capability depend on the model.

Degradation is a repressible condition. It is masked by the degradation subclass-mask bit, which is in bit position 37 of control register 14.

**Warning**

Bit 8 (W), when one, indicates that damage is imminent in some part of the system (for example, that power is about to fail, or that a loss of cooling is occurring). Whether warning conditions are recognized depends on the model.

If the condition responsible for the imminent damage is removed before the interruption request is honored (for example, if power is restored), the request does not remain pending, and no interruption occurs. Conversely, the request is not cleared by the interruption, and, if the condition persists, more than one interruption may result from the same condition.

Warning is a repressible condition. It is masked by the warning subclass-mask bit, which is in bit position 39 of control register 14.

**Channel Report Pending**

Bit 9 (CP), when one, indicates that a channel report, consisting of one or more channel-report words, has been made pending, and the contents of the channel-report words describe, in further detail, the effect of the malfunction and the results of analysis or the action performed. A channel report becomes pending when one of the following conditions has occurred:

1. Channel-subsystem recovery has been completed. The channel-subsystem recovery may have been initiated with no prior notice to the program or may have been a result of a condition previously reported to the program.

2. The function specified by RESET CHANNEL PATH has been completed.

A channel report may also become pending under other conditions.

The channel-report words which make up the channel report may be cleared, one at a time, by execution of the instruction STORE CHANNEL REPORT WORD, which is described in “I/O Instructions” on page 14-1.

Bit 9 is meaningless when channel-subsystem damage is reported.
Channel report pending is a floating repressible condition. It is masked by the channel-report-pending subclass-mask bit, which is in bit position 35 of control register 14.

**Service-Processor Damage**

Bit 10 (SP), when one, indicates that damage has occurred to the service processor. Service-processor damage may be made pending at all CPUs in the configuration, or it may be detected independently by each CPU. The presence and extent of reporting service-processor damage depend on the model.

Service-processor damage is a repressible condition and has no subclass-mask bit.

**Channel-Subsystem Damage**

Bit 11 (CK), when one, indicates that an error or malfunction has occurred in the channel subsystem, or that the channel subsystem is in the check-stop state. The channel subsystem enters the check-stop state when a malfunction occurs which is so severe that the channel subsystem cannot continue, or if power is lost in the channel subsystem.

Channel-subsystem damage is a floating repressible condition and has no subclass-mask bit.

**Subclass Modifiers**

Bits 14 (B), 34 (DA), and 44 (AP) of the machine-check-interruption code act as modifiers to the subclass bits.

**Backed Up**

Bit 14 (B), when one, indicates that the point of interruption is at a checkpoint before the point of error. This bit is meaningful only when the instruction-processing-damage bit, bit 1, is also set to one. The presence and extent of the capability to indicate a backed-up condition depend on the model.

**Delayed Access Exception**

Bit 34 (DA), when one, indicates that an access exception was detected during a storage access using DAT when no such exception was detected by an earlier test for access exceptions.

Bit 34 is a modifier to instruction-processing damage (bit 1) and is meaningful only when bit 1 of the machine-check-interruption code is one. When bit 1 is zero, bit 34 has no meaning. The presence and extent of reporting delayed access exception depend on the model.

**Programming Note:** The occurrence of a delayed access exception normally indicates that the program is using an improper procedure to update the DAT tables.

**Ancillary Report**

Bit 44 (AP), when one, indicates that a malfunction of a system component has occurred which has been recognized previously or which has affected the activities of multiple system elements such as CPUs and subchannels. When the malfunction affects the activities of multiple elements, an ancillary-report condition is recognized for all of the affected elements except one. This bit, when zero, indicates that this malfunction of a system component has not been recognized previously. This bit is meaningful for all conditions indicated by either the machine-check-interruption code or the external-damage code.

Depending on the model, recognition of an ancillary-report condition may not be provided, or it may not be provided for all system malfunctions. When ancillary-report recognition is not provided, bit 44 is set to zero.

**Synchronous Machine-Check- Interruption Conditions**

The instruction-processing damage and backed-up bits, bits 1 and 14 of the machine-check-interruption code, identify, in combination, two conditions.

<table>
<thead>
<tr>
<th>Bit 1</th>
<th>Bit 14</th>
<th>Name of Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>Processing damage</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Processing backup</td>
</tr>
</tbody>
</table>

**Processing Backup**

The processing-backup condition indicates that the point of interruption is prior to the point, or points, of error. This is a nullifying exigent condition. When all of the other CPU-related-damage subclasses and modifiers of the machine-check-interruption code are zero, and certain validity bits associated with CPU status are indicated as valid, then the machine has successfully returned to a checkpoint prior to the malfunction, and no damage has yet occurred to the CPU.
The subclass bits which must be zero for no damage to have occurred are as follows:

**MCIC**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>System damage</td>
</tr>
<tr>
<td>4</td>
<td>Timing-facility damage</td>
</tr>
</tbody>
</table>

The delayed-access-exception subclass-modifier bit, MCIC bit 34, must be zero for no damage to have occurred.

The validity bits in the machine-check-interruption code which must be one for no damage to have occurred are as follows:

**MCIC**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>PSW MWP bits</td>
</tr>
<tr>
<td>21</td>
<td>PSW mask and key</td>
</tr>
<tr>
<td>22</td>
<td>PSW program mask and condition code</td>
</tr>
<tr>
<td>23</td>
<td>PSW instruction address</td>
</tr>
<tr>
<td>25</td>
<td>Vector registers</td>
</tr>
<tr>
<td>27</td>
<td>Floating-point registers</td>
</tr>
<tr>
<td>28</td>
<td>General registers</td>
</tr>
<tr>
<td>29</td>
<td>Control registers</td>
</tr>
<tr>
<td>31</td>
<td>Storage logical validity (result fields within current checkpoint interval)</td>
</tr>
<tr>
<td>33</td>
<td>Access registers</td>
</tr>
<tr>
<td>42</td>
<td>TOD programmable register</td>
</tr>
<tr>
<td>43</td>
<td>Floating-point-control register</td>
</tr>
<tr>
<td>46</td>
<td>CPU timer</td>
</tr>
<tr>
<td>47</td>
<td>Clock comparator</td>
</tr>
</tbody>
</table>

**Programming Note:** The processing-backup condition is reported rather than system recovery to indicate that a malfunction or failure stands in the way of continued operation of the CPU. The malfunction has not been circumvented, and damage would have occurred if instruction processing had continued.

**Processing Damage**

The processing-damage condition indicates that damage has occurred to the instruction processing of the CPU. The point of interruption is a point beyond some or all of the points of damage. Processing damage is a terminating exigent condition; therefore, the contents of result fields may be unpredictable and still indicated as valid.

Processing damage may include malfunctions in program-event recording, monitor call, tracing, access-register translation, and dynamic address translation. Processing damage causes any supervisor-call-interruption condition and program-interruption condition to be discarded. However, the contents of the old PSW and interruption-code locations for these interruptions may be set to unpredictable values.

**Storage Errors**

Bits 16-18 of the machine-check-interruption code are used to indicate an invalid CBC or a near-valid CBC detected in main storage or an invalid CBC in a storage key. Bit 19, storage degradation, may be indicated concurrently with bit 17. The failing-storage-address field, when indicated as valid, identifies a location within the storage checking block containing the error, or, for storage-key error uncorrected, within the block associated with the storage key. Bit 32, indirect storage error, may be set to one to indicate that the location designated by the failing-storage address is not the original source of the error.

The storage-error-uncorrected and storage-key-error-uncorrected bits do not in themselves indicate the occurrence of damage because the error detected may not have affected a result. The portion of the configuration affected by an invalid CBC is indicated in the subclass field of the machine-check-interruption code.

Storage errors detected for a channel program, when indicated as I/O-error conditions, may also be reported as system recovery. CBC errors that occur in storage or in the storage key and that are detected on prefetched or unused data for a CPU program may or may not be reported, depending on the model.

**Storage Error Uncorrected**

Bit 16 (SE), when one, indicates that a checking block in main storage contained invalid CBC and that the information could not be corrected. The contents of the checking block in main storage have not been changed. The location reported may have been accessed or prefetched for this CPU or another CPU or a channel program, or it may have been accessed as the result of a model-dependent storage access.
Storage Error Corrected
Bit 17 (SC), when one, indicates that a checking block in main storage contained near-valid CBC and that the information has been corrected before being used. Depending on the model, the contents of the checking block in main storage may or may not have been restored to valid CBC. The location reported may have been accessed or prefetched for this CPU or for another CPU or for a channel program, or it may have been accessed as the result of a model-dependent storage access. The presence and extent of the storage-error-correction capability depend on the model. This indication may or may not be accompanied by an indication of storage degradation, bit 19 (DS).

Storage-Key Error Uncorrected
Bit 18 (KE), when one, indicates that a storage key contained invalid CBC and that the information could not be corrected. The contents of the checking block in the storage key have not been changed. The storage key may have been accessed or prefetched for this CPU or for another CPU or for a channel program, or it may have been accessed as the result of a model-dependent storage access.

Storage Degradation
Bit 19 (DS), when one, indicates that degradation of the recovery characteristics has occurred for the 4K-byte block reported by the failing-storage address.

Storage degradation indicates that although the associated storage error has been corrected, there are solid failures associated with the storage block (or with its associated key) that cause the correction process to take a substantial amount of time, and that if an additional error occurs in the block, the error may not be correctable or may go undetected. Thus, this bit indicates that use of the indicated block of storage should be avoided, if possible.

The indication of storage degradation has meaning only when failing-storage-address validity, MCIC bit 24, is also one. The presence and extent of reporting storage degradation depend on the model.

Because storage degradation is normally reported with system recovery, the recovery subclass mask, bit 36 of control register 14, should be set to one in order for storage degradation to be indicated.

Indirect Storage Error
Bit 32 (IE), when one, indicates that the physical main-storage location identified by the failing-storage address is not the original source of the error. Instead, the error originated in another level of the storage hierarchy and has been propagated to the current physical-storage portion of the storage hierarchy. Bit 32 is meaningful only when bit 16 or 18 (storage error uncorrected or storage-key error uncorrected) of the machine-check-interruption code is one. When bits 16 and 18 are both zeros, bit 32 has no meaning.

For errors originating outside the storage hierarchy, the attempt to store is rejected, and the appropriate error indication is presented. When an error is detected during implicit movement of information inside the storage hierarchy, the action is not rejected and reported in this manner because the movement may be asynchronous and may be initiated as the result of an attempt to access completely unrelated information. Instead, errors in the contents of the source during implicit moving of information from one portion of the storage hierarchy to another may be preserved in the target area by placing a special invalid CBC in the checking block associated with the target location. These propagated errors, when detected later, are reported as indirect storage errors. The original source of such an error may have been in a cache associated with an I/O processor or a CPU, or the error may have been the result of a data-path failure in transmitting data from one portion of the storage hierarchy to another. Additionally, a propagated error may be generated during the movement of data from one physical portion of storage to another as the result of a storage-reconfiguration action.

The presence and extent of reporting indirect storage error depend on the model.

Programming Note: See the programming notes under TEST BLOCK in Chapter 10, “Control Instructions” for the action which should be taken after storage errors are reported.

Machine-Check Interruption-Code Validity Bits

Bits 20-29, 31 33, 42, 43, 46, and 47 of the machine-check-interruption code are validity bits. Each bit indicates the validity of a particular field in storage. With
the exception of the storage-logical-validity bit (bit 31), each bit is associated with a field stored during the machine-check interruption. When a validity bit is one, it indicates that the saved value placed in the corresponding storage field is valid with respect to the indicated point of interruption and that no error was detected when the data was stored.

When a validity bit is zero, one or more of the following conditions may have occurred: the original information was incorrect, the original information had invalid CBC, additional malfunctions were detected while storing the information, or none or only part of the information was stored. Even though the information is unpredictable, the machine attempts, when possible, to place valid CBC in the storage field and thus reduce the possibility of additional machine checks being caused.

The validity bits for the floating-point registers, general registers, control registers, access registers, vector registers, TOD programmable register, floating-point control register, CPU timer, and clock comparator indicate the validity of the saved value placed in the corresponding save area. The information in these registers after the machine-check interruption is not necessarily correct even when the correct value has been placed in the save area and the validity bit set to one. The use of the registers and the operation of the facility associated with the control registers, floating-point control register, TOD programmable register, CPU timer, and clock comparator are unpredictable until these registers are validated. (See “Invalid CBC in Registers” on page 9.)

**PSW-MWP Validity**
Bit 20 (WP), when one, indicates that bits 12-15 of the machine-check old PSW are correct.

**PSW Mask and Key Validity**
Bit 21 (MS), when one, indicates that the system mask, PSW key, and miscellaneous bits of the machine-check old PSW are correct. Specifically, this bit covers bits 0-11, 16, 17, 24-30, and 33-63 of the PSW.

**PSW Program-Mask and Condition-Code Validity**
Bit 22 (PM), when one, indicates that the program mask and condition code of the machine-check old PSW are correct.

**PSW-Instruction-Address Validity**
Bit 23 (IA), when one, indicates that the addressing-mode and instruction-address bits, bits 31, 32, and 64-127, of the machine-check old PSW are correct.

**Failing-Storage-Address Validity**
Bit 24 (FA), when one, indicates that a correct failing-storage address has been stored at real location 248-255 after a storage-error-uncorrected, storage-key-error-uncorrected, or storage-error-corrected condition has occurred. The presence and extent of the capability to identify the failing-storage location depend on the model. When no such errors are reported, that is, bits 16-18 of the machine-check-interruption code are zeros, the failing-storage address is meaningless, even though it may be indicated as valid.

**Vector Register Validity**
Bit 25 (VR), when one, indicates that the contents of locations 0-1023 of the machine-check extended save area reflect the correct state of the vector registers 0-31 at the point of the interruption.

Bit 25 is zero when the vector facility for z/Architecture is not installed or the machine-check extended save area address formed from the contents of real locations 4528-4535 is either invalid or all zeros.

**External-Damage-Code Validity**
Bit 26 (EC), when one, and provided that bit 5, external damage, is also one, indicates that a valid external-damage code has been stored in the word at real location 244. When bit 5 is zero, bit 26 has no meaning.

**Floating-Point-Register Validity**
Bit 27 (FP), when one, indicates that the contents of the floating-point-register save area at real locations 4608-4735 reflect the correct state of the floating-point registers at the point of interruption.

**General-Register Validity**
Bit 28 (GR), when one, indicates that the contents of the general-register save area at real locations 4736-4863 reflect the correct state of the general registers at the point of interruption.

**Control-Register Validity**
Bit 29 (CR), when one, indicates that the contents of the control-register save area at real locations 4992-
5119 reflect the correct state of the control registers at the point of interruption.

**Storage Logical Validity**
Bit 31 (ST), when one, indicates that the storage locations, the contents of which are modified by the instructions being executed, contain the correct information relative to the point of interruption. That is, all stores before the point of interruption are completed, and all stores, if any, after the point of interruption are suppressed. When a store before the point of interruption is suppressed because of an invalid CBC, the storage-logical-validity bit may be indicated as one, provided that the invalid CBC has been preserved as invalid.

When instruction-processing damage is indicated but processing backup is not indicated, the storage-logical-validity bit has no meaning.

Storage logical validity reflects only the instruction-processing activity and does not reflect errors in the state of storage as the result of either I/O operations or the storing of the old PSW and other interruption information.

**Access-Register Validity**
Bit 33 (AR), when one, indicates that the contents of the access-register save area at real locations 4928-4991 reflect the correct state of the access registers at the point of interruption.

**TOD-Programmable-Register Validity**
Bit 42 (PR), when one, indicates that the contents of the TOD-programmable-register save area at real locations 4900-4903 reflect the correct state of the TOD programmable register at the point of interruption.

**Floating-Point-Control-Register Validity**
Bit 43 (FC), when one, indicates that the contents of the floating-point-control-register save area at real locations 4892-4895 reflect the correct state of the floating-point-control register at the point of interruption.

**CPU-Timer Validity**
Bit 46 (CT), when one, indicates that the CPU timer is not in error and that the contents of the CPU-timer save area at real locations 4904-4911 reflect the correct state of the CPU timer at the time the interruption occurred.

**Clock-Comparator Validity**
Bit 47 (CC), when one, indicates that the clock comparator is not in error, that the contents of the clock-comparator save area at real locations 4913-4919 reflect the correct state of the clock comparator at the time the interruption occurred, and that zeros have been stored at real location 4912.

**Programming Note:** The validity bits must be used in conjunction with the subclass bits and the backed-up bit in order to determine the extent of the damage caused by a machine-check condition. No damage has occurred to the system when all of the following are true:

- The four PSW-validity bits, the seven register-validity bits, the two timing-facility-validity bits, and the storage-logical-validity bit are all ones.
- Subclass bits 0, 4, 5, 10, and 11 are zeros.
- The instruction-processing-damage bit is zero or, if one, the backed-up bit is also one.
- The delayed-access-exception bit is zero.

**Machine-Check Extended Interruption Information**
As part of the machine-check interruption, in some cases, extended interruption information is placed in fixed areas assigned in storage. The contents of registers associated with the CPU are placed in register-save areas. For external damage, additional information is provided for some models by storing an external-damage code. When storage error uncorrected, storage error corrected, or storage-key error uncorrected is indicated, the failing-storage address is saved.

Each of these fields has associated with it a validity bit in the machine-check-interruption code. If, for any reason, the machine cannot store the proper information in the field, the associated validity bit is set to zero.

**Register-Save Areas**
As part of the machine-check interruption, the current contents of the CPU registers, except for the prefix register and the TOD clock, are stored in eight regis-
ter-save areas assigned in storage. Each of these areas has associated with it a validity bit in the machine-check-interruption code. If, for any reason, the machine cannot store the proper information in the field, the associated validity bit is set to zero.

The following are the eight sets of registers and the real locations in storage where their contents are saved during a machine-check interruption.

Locations | Registers
---|---
4608-4735 | Floating-point registers 0-15
4736-4863 | General registers 0-15
4892-4895 | Floating-point-control register
4900-4903 | TOD programmable register
4904-4911 | CPU timer
4913-4919 | Clock comparator
4928-5119 | Access registers 0-15
4992-5119 | Control registers 0-15

**External-Damage Code**

The word at real location 244 is the external-damage code. This field, when implemented and indicated as valid, describes the cause of external damage. The field is valid only when the external-damage bit and the external-damage-code-validity bit (bits 5 and 26 in the machine-check-interruption code) are both ones. The presence and extent of reporting an external-damage code depend on the model.

The external-damage code has the following format:

```
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
  0 19 24 28 31
```

**ETR Sync Check (SC):** Bit 19, when one, indicates that bits 32 through the rightmost incremented bit of a running clock are not in synchronism with the same bits of the ETR.

If the condition happens more than once before the interruption occurs, the condition is generated only once. The condition is generated for all CPUs in the configuration, and the condition for a CPU is cleared by the interruption taken by the CPU.

**STP Sync Check (SS):** Bit 24, when one, indicates that an STP-sync-check has occurred. The STP-sync-check condition is generated when the configuration is in the STP-timing mode and the timing state changes from the synchronized state to the unsynchronized or stopped state.

The machine-check condition is generated for all CPUs in the configuration, and the condition for a CPU is cleared by the interruption taken by the CPU.

**Island Condition (IC):** Bit 25, when one, indicates that an island condition has been detected. The island condition is generated when an attached server attempts to communicate over an STP link and both of the following conditions are detected:

- The servers have matching CTN IDs, and
- Both servers have valid stratum-1-configurations and the configurations do not match.

The island condition indicates that two separate CTNs may be operating with the same CTN ID.

The machine-check condition is generated for all CPUs in the configuration, and the condition for a CPU is cleared by the interruption taken by the CPU.

**CTN Configuration Change (CC):** Bit 26, when one, indicates that a CTN-configuration-change has occurred in the CTN. The conditions that cause the CTN-configuration-change condition to be generated include the following:

- A new node with a matching CTN ID has attached to this node.
- An attached node that had a matching CTN ID is no longer attached to this node
- The CTN ID for this node has changed.
- The stratum level of this node has changed, or a change in the stratum-1 or alternate-stratum-1 for the network has changed.
- STP active or maximum version number has changed.

The machine-check condition is generated for all CPUs in the configuration, and the condition for a CPU is cleared by the interruption taken by the CPU.

**STP Clock Source Error (CS):** Bit 27, when one, indicates that an STP-clock-source error has occurred. The STP-clock-source condition is generated when the configuration is in the STP-timing mode and the timing state changes from the synchronized state to the unsynchronized or stopped state.

The machine-check condition is generated for all CPUs in the configuration, and the condition for a CPU is cleared by the interruption taken by the CPU.
mode and the STP-clock-source state changes from the usable state to the not-usable state.

The machine-check condition is generated for all CPUs in the configuration, and the condition for a CPU is cleared by the interruption taken by the CPU.

Reserved: Bits 0-7, 10-16, 21-23, and 28-31 are reserved for future expansion and are always set to zero.

Failing-Storage Address

When storage error uncorrected, storage error corrected, or storage-key error uncorrected is indicated in the machine-check-interruption code, the associated address, called the failing-storage address, is stored at real locations 248-255. The field is valid only if the failing-storage-address validity bit, bit 24 of the machine-check-interruption code, is one.

In the case of storage errors, the failing-storage address may designate any byte within the checking block. For storage-key error uncorrected, the failing-storage address may designate any address within the block of storage associated with the storage key that is in error. When an error is detected in more than one location before the interruption, the failing-storage address may designate any of the failing locations. The address stored is an absolute address; that is, the value stored is the address that is used to reference storage after dynamic address translation and prefixing have been applied.

Machine-Check Extended Save Area

When the vector facility for z/Architecture is installed and bits 0-53 of real locations 4528-4535 are not all zeros, then as part of a machine check interruption, the current contents of the vector registers 0-31 are stored in a machine-check extended save area. The absolute address of the extended save area is obtained by appending 10 bits to the right of bits 0-53 of real locations 4528-4535. Storing does not occur if the address is invalid.

The extended save area has associated with it a validity bit in the machine check interruption code, bit 25 (VR). If for any reason the machine cannot store the proper information in the area, the associated validity bit is set to zero.

Figure 11-3 lists the fields that are stored, their offsets within the area, and their lengths. Bytes 512-1023 of the extended save area are unchanged.

Handling of Machine-Check Conditions

Floating Interruption Conditions

An interruption condition which is made available to any CPU in a multiprocessing configuration is called a floating interruption condition. The first CPU that accepts the interruption clears the interruption condition, and it is no longer available to any other CPU in the configuration.

Floating interruption conditions include service-signal external-interruption and I/O-interruption conditions. Two machine-check-interruption conditions, channel report pending and channel-subsystem damage, are floating interruption conditions. Additionally, floating interruption conditions include STP external-damage machine-check conditions (STP Sync Check, STP Island Condition, STP CTN Configuration Error, and STP Clock Source Error) when STP machine-check floating interruptions are enabled.

Depending on the model, some machine-check-interruption conditions associated with system recovery and warning may also be floating interruption conditions.

A floating interruption is presented to the first CPU in the configuration which is enabled for the interruption condition and can accept the interruption. A CPU cannot accept the interruption when the CPU is in the check-stop state, has an invalid prefix, is performing an unending string of interruptions due to a PSW-format error of the type that is recognized early, or is in the stopped state. However, a CPU with the rate control set to instruction step can accept the interruption when the start key is activated.

Programming Note: When a CPU enters the check-stop state in a multiprocessing configuration, the program on another CPU can determine whether a floating interruption may have been reported to the failing CPU and then lost. This can be accomplished if the interruption program places zeros in the real storage locations containing old PSWs and interruption codes after the interruption has been handled (or has
been moved into another area for later processing). After a CPU enters the check-stop state, the program on another CPU can inspect the old-PSW and interruption-code locations of the failing CPU. A nonzero value in an old PSW or interruption code indicates that the CPU has been interrupted but the program did not complete the handling of the interruption.

Floating Machine-Check-Interruption Conditions
Floating machine-check-interruption conditions are reset only by the manually initiated resets through the operator facilities. When a machine check occurs which prohibits completion of a floating machine-check interruption, the interruption condition is no longer considered a floating interruption condition, and system damage is indicated.

Floating I/O Interruptions
The detection of a machine malfunction by the channel subsystem, while in the process of presenting an I/O-interruption request for a floating I/O interruption, may be reported as channel report pending or as channel-subsystem damage. Detection of a machine malfunction by a CPU, while in the process of accepting a floating I/O interruption, is reported as system damage.

Machine-Check Masking
All machine-check interruptions are under control of the machine-check mask, PSW bit 13. In addition, some machine-check conditions are controlled by subclass masks in control register 14.

The exigent machine-check conditions (system damage and instruction-processing damage) are controlled only by the machine-check mask, PSW bit 13. When PSW bit 13 is one, an exigent condition causes a machine-check interruption. When PSW bit 13 is zero, the occurrence of an exigent machine-check condition causes the CPU to enter the check-stop state.

The repressible machine-check conditions, except channel-subsystem damage and service-processor damage, are controlled both by the machine-check mask, PSW bit 13, and by five subclass-mask bits in control register 14. If PSW bit 13 is one and one of the subclass-mask bits is one, the associated condition initiates a machine-check interruption. If a subclass-mask bit is zero, the associated condition does not initiate an interruption but is held pending. However, when a machine-check interruption is initiated because of a condition for which the CPU is enabled, those conditions for which the CPU is not enabled may be presented along with the condition which initiates the interruption. All conditions presented are then cleared.

Control register 14 contains mask bits that specify whether certain conditions can cause machine-check interruptions. It has the following format:

|   | CR | DE | EW | RM | MM | MM | ...
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td></td>
<td>35</td>
<td>36</td>
<td>37</td>
<td>38</td>
<td>39</td>
<td>40</td>
</tr>
</tbody>
</table>

Bits 35-39 of control register 14 are the subclass masks for repressible machine-check conditions. In addition, bit 32 of control register 14 is initialized to one but is otherwise ignored by the machine.

Programming Note: The program should avoid, whenever possible, operating with PSW bit 13, the machine-check mask, set to zero, since any exigent machine-check condition which is recognized during this situation will cause the CPU to enter the check-stop state. In particular, the program should avoid executing I/O instructions or allowing I/O interruptions with PSW bit 13 zero.

Channel-Report-Pending Subclass Mask
Bit 35 (CM) of control register 14 controls channel-report-pending interruption conditions. This bit is initialized to zero.

Recovery Subclass Mask
Bit 36 (RM) of control register 14 controls system-recovery interruption conditions. This bit is initialized to zero.

Degradation Subclass Mask
Bit 37 (DM) of control register 14 controls degradation interruption conditions. This bit is initialized to zero.

External-Damage Subclass Mask
Bit 38 (EM) of control register 14 controls timing-facility-damage and external-damage interruption conditions. This bit is initialized to one.
Warning Subclass Mask
Bit 39 (WM) of control register 14 controls warning interruption conditions. This bit is initialized to zero.

Machine-Check Logout

As part of the machine-check interruption, some models may place model-dependent information in the fixed-logout area. This area is 16 bytes in length and starts at real location 4864.

Summary of Machine-Check Masking

A summary of machine-check masking is given in Figure 11-5 and Figure 11-6.

<table>
<thead>
<tr>
<th>Machine-Check Condition</th>
<th>Sub-Class Mask</th>
<th>Action when CPU Disabled for Subclass</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit 0 System damage</td>
<td>-</td>
<td>Check stop</td>
</tr>
<tr>
<td>Bit 1 Instruction-processing damage</td>
<td>-</td>
<td>Check stop</td>
</tr>
<tr>
<td>Bit 2 System recovery</td>
<td>RM</td>
<td>Y</td>
</tr>
<tr>
<td>Bit 4 Timing-facility damage</td>
<td>EM</td>
<td>P</td>
</tr>
<tr>
<td>Bit 5 External damage</td>
<td>EM</td>
<td>P</td>
</tr>
<tr>
<td>Bit 7 Degradation</td>
<td>DM</td>
<td>P</td>
</tr>
<tr>
<td>Bit 8 Warning</td>
<td>WM</td>
<td>P</td>
</tr>
<tr>
<td>Bit 9 Channel report pending</td>
<td>CM</td>
<td>P</td>
</tr>
<tr>
<td>Bit 10 Service-processor damage</td>
<td>-</td>
<td>P</td>
</tr>
<tr>
<td>Bit 11 Channel-subsystem damage</td>
<td>-</td>
<td>P</td>
</tr>
</tbody>
</table>

Explanation:
- The condition does not have a subclass mask.
P Indication is held pending.
Y Indication may be held pending or may be discarded.
CM Channel-report-pending subclass mask (bit 35 of CR14).
DM Degradation subclass mask (bit 37 of CR14).
EM External-damage subclass mask (bit 38 of CR14).
RM Recovery subclass mask (bit 36 of CR14).
WM Warning subclass mask (bit 39 of CR14).

Figure 11-5. Machine-Check-Condition Masking

<table>
<thead>
<tr>
<th>Bit Description</th>
<th>Control Register 14 Bit Position</th>
<th>State of Bit on Initial CPU Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Channel-report-pending subclass mask</td>
<td>35</td>
<td>0</td>
</tr>
<tr>
<td>Recovery subclass mask</td>
<td>36</td>
<td>0</td>
</tr>
<tr>
<td>Degradation subclass mask</td>
<td>37</td>
<td>0</td>
</tr>
<tr>
<td>External-damage subclass mask</td>
<td>38</td>
<td>1</td>
</tr>
<tr>
<td>Warning subclass mask</td>
<td>39</td>
<td>0</td>
</tr>
</tbody>
</table>

Figure 11-6. Machine-Check Control-Register Bits
Chapter 12. Operator Facilities

Manual Operation ........................................ 12-1
Basic Operator Facilities ................................. 12-1
Address-Compare Controls ............................... 12-1
Alter-and-Display Controls .............................. 12-2
Architectural-Mode Controls ......................... 12-2
Architectural-Mode-Selection Controls .............. 12-3
Check-Stop Indicator .................................. 12-3
CPUs-per-Core Indicator ............................... 12-3
IML Controls ............................................ 12-3
Interrupt Key ............................................ 12-3
Load Indicator .......................................... 12-3
Load-Clear Key ......................................... 12-3
Load-Clear-List-Directed Key ......................... 12-4
Load-Normal Key ........................................ 12-4
Load-with-Dump Key ................................... 12-4
Load-Unit-Address Controls ......................... 12-4
Manual Indicator ....................................... 12-4
Power Controls ......................................... 12-4
Rate Control ............................................ 12-5
Restart Key ............................................. 12-5
Start Key ................................................. 12-5
Stop Key .................................................. 12-5
Store-Status Key ........................................ 12-5
System-Reset-Clear Key ............................... 12-6
System-Reset-Normal Key ......................... 12-6
Test Indicator ............................................ 12-6
TOD-Clock Control .................................... 12-6
Wait Indicator ............................................ 12-6
Multiprocessing Configurations ..................... 12-6
Multithreading Considerations ....................... 12-7

Manual Operation

The operator facilities provide functions for the manual operation and control of the machine. The functions include operator-to-machine communication, indication of machine status, control over the setting of the TOD clock, initial program loading, resets, and other manual controls for operator intervention in normal machine operation. A model may not implement all of the operator facilities described in this chapter.

A model may provide additional operator facilities which are not described in this chapter. Examples are the means to indicate specific error conditions in the equipment, to change equipment configurations, and to facilitate maintenance. Furthermore, controls covered in this chapter may have additional settings which are not described here. Such additional facilities and settings may be described in the appropriate System Library publication.

Most models provide, in association with the operator facilities, a console device which may be used as an I/O device for operator communication with the program; this console device may also be used to implement some or all of the facilities described in this chapter.

The operator facilities may be implemented on different models in various technologies and configurations. On some models, more than one set of physical representations of some keys, controls, and indicators may be provided, such as on multiple local or remote operating stations, which may be effective concurrently.

A machine malfunction that prevents a manual operation from being performed correctly, as defined for that operation, may cause the CPU to enter the check-stop state or give some other indication to the operator that the operation has failed. Alternatively, a machine malfunction may cause a machine-check-interruption condition to be recognized.

Basic Operator Facilities

Address-Compare Controls

The address-compare controls provide a way to stop the CPU when a preset address matches the address used in a specified type of main-storage reference.

One of the address-compare controls is used to set up the address to be compared with the storage address.

Another control provides at least two positions to specify the action, if any, to be taken when the address match occurs:
1. The normal position disables the address-compare operation.

2. The stop position causes the CPU to enter the stopped state on an address match. When the control is in this setting, the test indicator is on. Depending on the model and the type of reference, pending I/O, external, and machine-check interruptions may or may not be taken before entering the stopped state.

A third control may specify the type of storage reference for which the address comparison is to be made. A model may provide one or more of the following positions, as well as others:

1. The any position causes the address comparison to be performed on all storage references.
2. The data-store position causes address comparison to be performed when storage is addressed to store data.
3. The I/O position causes address comparison to be performed when storage is addressed by the channel subsystem to transfer data or to fetch a channel-command or indirect-data-address word. Whether references to the measurement block, interruption-response block, channel-path-status word, channel-report word, subchannel-status word, subchannel-information block, and operation-request block cause a match to be indicated depends on the model.
4. The instruction-address position causes address comparison to be performed when storage is addressed to fetch an instruction. The rightmost bit of the address setting may or may not be ignored. The match is indicated only when the first byte of the instruction is fetched from the selected location (which includes fetching the target instruction of an execute-type instruction).

Depending on the model and the type of reference, address comparison may be performed on virtual, real, or absolute addresses, and it may be possible to specify the type of address.

In a multiprocessing configuration, it depends on the model whether the address setting applies to one or all CPUs in the configuration and whether an address match causes one or all CPUs in the configuration to stop.

Depending on the model, the availability of address-compare controls may be limited by the use of program-event-recording (PER) controls; PER controls include bit 1 of the PSW and all bits of control registers 9, 10, and 11. The address-compare-control limitations are as follows:

- The setting of address-compare controls may be inhibited when any PER control is nonzero. In a multi-processing configuration, the setting of address-compare controls may be inhibited on all CPUs in the configuration when any PER control is nonzero on any CPU in the configuration.
- If address-compare controls have been set on a CPU, and any PER control is set to a nonzero value, the address-compare controls may be disabled; the address-compare controls may remain disabled even if the respective PER controls are all subsequently reset to zero. In a multi-processing configuration, the address-compare controls may be disabled on all CPUs in the configuration if any PER control is set to a nonzero value in any CPU in the configuration.

### Alter-and-Display Controls

The operator facilities provide controls and procedures to permit the operator to alter and display the contents of locations in storage, the storage keys, the general, floating-point, floating-point-control, vector, access, and control registers, the prefix, and the PSW.

Before alter-and-display operations may be performed, the CPU must first be placed in the stopped state. During alter-and-display operations, the manual indicator may be turned off temporarily, and the start and restart keys may be inoperative.

Addresses used to select storage locations for alter-and-display operations are real addresses. The capability of specifying logical, virtual, or absolute addresses may also be provided.

### Architectural-Mode Indicator

The architectural-mode indicator shows the architectural mode of operation (the ESA/390 mode, z/Architecture mode, or some other mode) selected by the last architectural-mode-selection operation and by
the last SIGNAL PROCESSOR set-architecture order or the last reset that determined the mode.

**Architectural-Mode-Selection Controls**

The architectural-mode-selection controls provide for the selection of either the ESA/390 architectural mode of operation or, possibly, some other architectural mode of operation. (The z/Architecture mode is selected from the ESA/390 mode by the SIGNAL PROCESSOR set-architecture order.) Depending on the model, the architectural-mode selection may be provided as part of the IML operation or may be a separate operation.

As part of the architectural-mode-selection process, all CPUs and the associated channel-subsystem components in a particular configuration are placed in the same architectural mode.

**Check-Stop Indicator**

The check-stop indicator is on when the CPU is in the check-stop state. Reset operations normally cause the CPU to leave the check-stop state and thus turn off the indicator. The manual indicator may also be on in the check-stop state.

**CPUs-per-Core Indicator**

When the multithreading facility is installed, the CPUs-per-core indicator is provided. When the multithreading facility is not enabled, the value of this indicator is one. When the multithreading facility is enabled, the value of this indicator is one more than value of the program-specified maximum thread identification last set by the SIGNAL PROCESSOR set-multithreading order.

**Operation Note:** Certain operator functions are addressed to a specific CPU, designated by a CPU address. When multithreading is enabled, the CPU address includes a core identification and a thread identification as described in “CPU-Address Identification” on page 4-63. The CPUs-per-core indicator can be used to determine which format of CPU address is needed when selecting a CPU to which operator functions are addressed.

**IML Controls**

The IML controls provided with some models perform initial machine loading (IML), which is the loading of licensed internal code into the machine. The IML operation, when provided, may be used to select the ESA/390 mode or, possibly, some other mode of operation.

When the IML operation is completed, the state of the affected CPUs, channel subsystem, main storage, and operator facilities is the same as if a power-on reset had been performed, except that the value and state of the TOD clock are not changed. The contents of expanded storage may have been cleared to zeros with valid checking-block code or may have remained unchanged, depending on the model.

The IML controls are effective while the power is on.

**Interrupt Key**

When the interrupt key is activated, an external-interruption condition indicating the interrupt key is generated. (See “Interrupt Key” on page 6-12.)

The interrupt key is effective when the CPU is in the operating or stopped state. It depends on the model whether the interrupt key is effective when the CPU is in the load state.

**Load Indicator**

The load indicator is on during CCW-type initial program loading, indicating that the CPU is in the load state. The indicator goes on for a particular CPU when the load-clear, load-clear-list-directed, load-normal or load-with-dump key is activated for that CPU and the corresponding operation is started. It goes off after the new PSW is loaded successfully. For details, see “Initial Program Loading” on page 4-61 and “Initial Program Loading” on page 17-16.

**Load-Clear Key**

Activating the load-clear key causes a reset operation to be performed and CCW-type initial program loading to be started by using the I/O device designated by the load-unit-address controls. Clear reset
is performed on the configuration. For details, see “Resets” on page 4-55 and “Initial Program Loading” on page 4-61.

The load-clear key is effective when the CPU is in the operating, stopped, load, or check-stop state.

**Load-Clear-List-Directed Key**

Activating the load-clear-list-directed key causes a reset operation to be performed and list-directed initial program loading to be started using the I/O device designated by the list-directed IPL parameters. Clear reset is performed on the configuration. For details, see “Resets” on page 4-55 and “List-Directed IPL” on page 17-19.

The load-clear-list-directed key is effective when the CPU is in the operating, stopped, load, or check-stop state.

**Load-Normal Key**

Activating the load-normal key causes a reset operation to be performed and CCW-type initial program loading to be started by using the I/O device designated by the load-unit-address controls. Initial CPU reset is performed on the CPU for which the load-normal key was activated, CPU reset is propagated to all other CPUs in the configuration, and a subsystem reset is performed on the remainder of the configuration. For details, see “Resets” on page 4-55 and “Initial Program Loading” on page 4-61.

The load-normal key is effective when the CPU is in the operating, stopped, load, or check-stop state.

**Load-with-Dump Key**

Activating the load-with-dump key causes a reset operation to be performed and list-directed initial program loading to be started by using the I/O devices designated by the list-directed IPL parameters. A store-status operation followed by an initial CPU reset is performed on the CPU for which the load-with-dump key was activated, CPU reset is propagated to all other CPUs in the configuration, and a subsystem reset is performed on the remainder of the configuration. For details, see “Resets” on page 4-55 and “List-Directed IPL” on page 17-19.

The load-with-dump key is effective when the CPU is in the operating, stopped, load, or check-stop state.

**Load-Unit-Address Controls**

The load-unit-address controls specify four hexadecimal digits that provide the device number used for CCW-type initial program loading. When the alternate-subchannel-set-IPL-device facility is installed the load-unit-address controls may specify an additional hexadecimal digit that provides the subchannel-set ID for CCW-type initial program loading. For details, see “Initial Program Loading” on page 4-61.

**Manual Indicator**

The manual indicator is on when the CPU is in the stopped state. Some functions and several manual controls are effective only when the CPU is in the stopped state.

**Power Controls**

The power controls are used to turn the power on and off.

The CPUs, storage, channel subsystem, operator facilities, and I/O devices may all have their power turned on and off by common controls, or they may have separate power controls. When a particular unit has its power turned on, that unit is reset. The sequence is performed so that no instructions or I/O operations are performed until explicitly specified. The controls may also permit power to be turned on in stages, but the machine does not become operational until power on is complete.

When the power is completely turned on, an IML operation is performed on models which have an IML function. A power-on reset is then initiated (see “Resets” on page 4-55). It depends on the model whether the architectural mode of operation can be selected when the power is turned on, or whether the mode-selection controls have to be used to change the mode after the power is on.
Rate Control

A model may provide the rate control, the setting of which determines the effect of the start function and the manner in which instructions are executed.

When the rate control is provided, it has at least two positions. The normal position is the process position. Another position is the instruction-step position. When the rate control is set to the process position and the start function is performed, the CPU starts operating at normal speed. When the rate control is set to the instruction-step position and the wait-state bit is zero, one instruction or, for interruptible instructions, one unit of operation is executed, and all pending allowed interruptions are taken before the CPU returns to the stopped state. When the rate control is set to the instruction-step position and the wait-state bit is one, no instruction is executed, but all pending allowed interruptions are taken before the CPU returns to the stopped state. For details, see “Stopped, Operating, Load, and Check-Stop States” on page 4-2.

The test indicator is on while the rate control is not set to the process position.

If the setting of the rate control is changed while the CPU is in the operating or load state, the results are unpredictable.

When the rate control is not provided, the CPU operates as though the rate control was in the process position, and instruction stepping is not available.

Restart Key

Activating the restart key initiates a restart interruption. (See “Restart Interruption” on page 6-54.)

The restart key is effective when the CPU is in the operating or stopped state. The key is not effective when the CPU is in the check-stop state. It depends on the model whether the restart key is effective when any CPU in the configuration is in the load state.

The effect is unpredictable when the restart key is activated while any CPU in the configuration is in the load state. In particular, if the CPU performs a restart interruption and enters the operating state while another CPU is in the load state, operations such as I/O instructions, the SIGNAL PROCESSOR instruction, and the INVALIDATE PAGE TABLE ENTRY instruction may not operate according to the definitions given in this publication.

Start Key

Activating the start key causes the CPU to perform the start function. (See “Stopped, Operating, Load, and Check-Stop States” on page 4-2.)

The start key is effective only when the CPU is in the stopped state. The effect is unpredictable when the stopped state has been entered by a reset.

Stop Key

Activating the stop key causes the CPU to perform the stop function. (See “Stopped, Operating, Load, and Check-Stop States” on page 4-2.)

The stop key is effective only when the CPU is in the operating state.

Operation Note: Activating the stop key has no effect when:
- An unending string of certain program or external interruptions occurs.
- The prefix register contains an invalid address.
- The CPU is in the load or check-stop state.

Store-Status Key

Activating the store-status key initiates a store-status operation. (See “Store Status” on page 4-62.)

The store-status key is effective only when the CPU is in the stopped state.

Operation Note: The store-status operation may be used in conjunction with a standalone dump program for the analysis of major program malfunctions. For such an operation, the following sequence would be called for:

1. Activation of the stop or system-reset-normal key
2. Activation of the store-status key (this step is unnecessary if the standalone dump program is loaded by activating the load-with-dump key)
3. Activation of the load-normal key to enter a stand-alone dump program

The system-reset-normal key must be activated in step 1 when (1) the stop key is not effective because a continuous string of interruptions is occurring, (2) the prefix register contains an invalid address, or (3) the CPU is in the check-stop state.

**System-Reset-Clear Key**

Activating the system-reset-clear key causes a clear-reset operation to be performed on the configuration. For details, see “Resets” on page 4-55.

The system-reset-clear key is effective when the CPU is in the operating, stopped, load, or check-stop state.

**System-Reset-Normal Key**

Activating the system-reset-normal key causes a CPU-reset operation and a subsystem-reset operation to be performed. In a multiprocessing configuration, a CPU reset is propagated to all CPUs in the configuration. For details, see “Resets” on page 4-55.

The system-reset-normal key is effective when the CPU is in the operating, stopped, load, or check-stop state.

**Test Indicator**

The test indicator is on when a manual control for operation or maintenance is in an abnormal position that can affect the normal operation of a program.

Setting the address-compare controls to the stop position or setting the rate control to the instruction-step position turns on the test indicator.

The test indicator may be on when one or more diagnostic functions under the control of DIAGNOSE are activated, or when other abnormal conditions occur.

The abnormal setting of a manual control causes the test indicator of the affected CPU to be turned on; however, in a multiprocessing configuration, the operation of other CPUs may be affected even though their test indicators are not turned on.

Depending on the model, if address-compare controls have been disabled due to bit position 1 of the PSW being set to one or any or all of control registers 9, 10, and 11 containing nonzero values, the test indicator may remain on even though the address-compare controls have been disabled.

**Operation Note:** If a manual control is left in a setting intended for maintenance purposes, such an abnormal setting may, among other things, result in false machine-check indications or cause actual machine malfunctions to be ignored. It may also alter other aspects of machine operation, including instruction execution, channel-subsystem operation, and the functioning of operator controls and indicators, to the extent that operation of the machine does not comply with that described in this publication.

**TOD-Clock Control**

When the TOD-clock control is not activated, that is, the control is set to the secure position, the state and value of the TOD clock are protected against unauthorized or inadvertent change by not permitting the instructions SET CLOCK or DIAGNOSE to change the state or value.

When the TOD-clock control is activated, that is, the control is set to the enable-set position, alteration of the clock state or value by means of SET CLOCK or DIAGNOSE is permitted. This setting is momentary, and the control automatically returns to the secure position.

If there is more than one physical representation of the TOD-clock control, the TOD clock is secure only if all TOD-clock controls in the configuration are set to the secure position.

**Wait Indicator**

The wait indicator is on when the wait-state bit in the current PSW is one. Instead of a wait indicator, a model may have a means of indicating a time-averaged value of the wait-state bit.

**Multiprocessing Configurations**

In a multiprocessing configuration, one of each of the following keys and controls is provided for each CPU:
Alter and display
Interrupt
Restart
Start
Stop
Store status.

On some models, a rate control may also be provided.

On some models, the load-clear, load-clear-list-directed, load-normal, load-with-dump, and load-unit-address keys are provided for each primary CPU in the configuration. On other models, a single load-clear, load-clear-list-directed, load-normal, and load-with-dump key are provided for the entire configuration and apply to the lowest-numbered primary online CPU that is not in the check-stop state.

There need not be more than one of each of the following keys and controls in a multiprocessing configuration: address compare, IML, power, system reset clear, system reset normal, and TOD clock.

One check-stop, manual, test, and wait indicator may be provided for each CPU. A load indicator is provided only on a primary CPU. Alternatively, a single set of indicators may be switched to more than one CPU.

There need not be more than one architectural-mode and CPUs-per-core indicator in a multiprocessing configuration.

In a system capable of reconfiguration, there must be a separate set of keys, controls, and indicators in each configuration.

---

**Multithreading Considerations**

A CPU address is used to identify the CPU to which CPU-specific operator functions are directed. These CPU-specific operator functions are enumerated in the section “Multiprocessing Configurations”, above. When multithreading is enabled (that is, when the CPUs-per-core indicator is greater than one), the CPU address comprises a core identification and a thread identification, as described in “CPU-Address Identification” on page 4-63.

Some models provide a control to select the primary CPU to be started following a load operation. On such a model, when the multithreading facility is enabled prior to the load operation, the operator designates an expanded-format CPU address as described in “CPU-Address Identification” on page 4-63. However, only the core-identification portion of the designated CPU address is meaningful; the operation is always targeted to the CPU having thread identification zero of the designated core.

On models that do not provide a control to select the primary CPU to be started following a load operation, the operation is targeted to the CPU having thread identification zero in the lowest-numbered operational core.

In either case, the targeted CPU is (a) the one upon which the initial-CPU reset is performed, and (b) the CPU that is started after the load operation is completed.
Input/Output (I/O) .......................... 13-1
The Channel Subsystem .................. 13-1
Subchannel Sets .......................... 13-2
Subchannels .............................. 13-2
Attachment of Input/Output Devices ...... 13-3
Channel Paths ............................ 13-3
I/O Devices .............................. 13-5
I/O Addressing ........................... 13-5
Subchannel-Set Identifier ............... 13-5
Channel-Path Identifier .................. 13-5
Subchannel Number ....................... 13-5
Device Number ........................... 13-6
Device Identifier ......................... 13-6
Fibre-Channel Extensions ............... 13-6
I/O-Command Words ....................... 13-7
Transport Command Word (TCW) .......... 13-7
Channel Program Organization .......... 13-7
CCW Channel Program .................... 13-7
TCW Channel Program .................... 13-7
Execution of I/O Operations .......... 13-8
Start-Function Initiation ............... 13-8
Subchannel Operation Modes .............. 13-9
Path Management ........................ 13-9
Channel-Program Execution .......... 13-9
Conclusion of I/O Operations .......... 13-10
Chaining When Using a CCW Channel .... 13-11
Chaining When Using a TCW Channel .... 13-11
Premature Conclusion of I/O Operations 13-12
I/O Interruptions ....................... 13-12

Input/Output (I/O)

The terms “input” and “output” are used to describe the transfer of data between I/O devices and main storage. An operation involving this kind of transfer is referred to as an I/O operation. The facilities used to control I/O operations are collectively called the channel subsystem. (I/O devices and their control units attach to the channel subsystem.) This chapter provides a brief description of the basic components and operation of the channel subsystem.

The Channel Subsystem

The channel subsystem directs the flow of information between I/O devices and main storage. It relieves CPUs of the task of communicating directly with I/O devices and permits data processing to proceed concurrently with I/O processing. The channel subsystem uses one or more channel paths as the communication link in managing the flow of information to or from I/O devices. As part of I/O processing, the channel subsystem also performs a path-management operation by testing for channel-path availability, chooses an available channel path, and initiates the performance of the I/O operation by the device.

Within the channel subsystem are subchannels. One subchannel is provided for and dedicated to each I/O device accessible to the program through the channel subsystem.

The multiple-subchannel-set facility is an optional facility. When it is installed, subchannels are partitioned into multiple subchannel sets, and each subchannel set may provide one dedicated subchannel to an I/O device. Depending on the model and the interface used, some I/O devices may only be allowed to be accessed via certain subchannel sets.

Each subchannel provides information concerning the associated I/O device and its attachment to the channel subsystem. The subchannel also provides information concerning I/O operations and other functions involving the associated I/O device. The subchannel is the means by which the channel subsystem provides information about associated I/O devices to CPUs, which obtain this information by executing I/O instructions. The actual number of subchannels provided depends on the model and the configuration; the maximum addressability is 0-65,535 in each subchannel set.

I/O devices are attached through control units to the channel subsystem by means of channel paths. Control units may be attached to the channel subsystem by more than one channel path, and an I/O device may be attached to more than one control unit. In all,
an individual I/O device may be accessible to the channel subsystem by as many as eight different channel paths via a subchannel, depending on the model and the configuration. The total number of channel paths provided by a channel subsystem depends on the model and the configuration; the maximum addressability is 0-255.

The performance of a channel subsystem depends on its use and on the system model in which it is implemented. Channel paths are provided with different data-transfer capabilities, and an I/O device designed to transfer data only at a specific rate (a magnetic-tape unit or a disk storage, for example) can operate only on a channel path that can accommodate at least this data rate.

The channel subsystem contains common facilities for the control of I/O operations. When these facilities are provided in the form of separate, autonomous equipment designed specifically to control I/O devices, I/O operations are completely overlapped with the activity in CPUs. The only main-storage cycles required by the channel subsystem during I/O operations are those needed to transfer data and control information to or from the final locations in main storage, along with those cycles that may be required for the channel subsystem to access the subchannels when they are implemented as part of nonaddressable main storage. These cycles do not delay CPU programs, except when both the CPU and the channel subsystem concurrently attempt to reference the same main-storage area.

Subchannel Sets

When the multiple-subchannel-set facility is installed, subchannels are partitioned into multiple subchannel sets. There may be up to four subchannel sets, each identified by a subchannel-set identifier (SSID). When the multiple-subchannel-set facility is not installed, there is only one subchannel set with an SSID of zero. When the multiple-subchannel-set facility is not enabled, only subchannel set zero is visible to the program. See “Multiple-Subchannel-Set Facility” on page 29 for more information on the multiple-subchannel-set facility.

Subchannels

A subchannel provides the logical appearance of a device to the program and contains the information required for sustaining a single I/O operation. The subchannel consists of internal storage that contains information in the form of a channel-program designation, channel-path identifier, device number, count, status indications, and I/O-interruption-subclass code, as well as information on path availability and functions pending or being performed. I/O operations are initiated with a device by the execution of I/O instructions that designate the subchannel associated with the device.

Each device is accessible by means of one subchannel in each channel subsystem to which it is assigned during configuration at installation time. The device may be a physically identifiable unit or may be housed internal to a control unit. For example, in certain disk-storage devices, each actuator used in retrieving data is considered to be a device. In all cases, a device, from the point of view of the channel subsystem, is an entity that is uniquely associated with one subchannel and that responds to selection by the channel subsystem by using the communication protocols defined for the type of channel path by which it is accessible.

On some models, subchannels are provided in blocks. On these models, more subchannels may be provided than there are attached devices. Subchannels that are provided but do not have devices assigned to them are not used by the channel subsystem to perform any function and are indicated by storing the associated device-number-valid bit as zero in the subchannel-information block of the subchannel.

The number of subchannels provided by the channel subsystem is independent of the number of channel paths to the associated devices. For example, a device accessible through alternate channel paths still is represented by a single subchannel. Each subchannel is addressed by using the following:

- a 16-bit binary subchannel number
- a two-bit SSID when the subchannel-set facility is installed

After I/O processing at the subchannel has been requested by the execution of START SUBCHANNEL, the CPU is released for other work, and the channel subsystem assembles or disassembles data and synchronizes the transfer of data bytes between the I/O device and main storage. To accomplish this, the channel subsystem maintains and updates an address and a count that describe the destination or
source of data in main storage. Similarly, when an I/O device provides signals that should be brought to the attention of the program, the channel subsystem transforms the signals into status information and stores the information in the subchannel, where it can be retrieved by the program.

Attachment of Input/Output Devices

Channel Paths

The channel subsystem communicates with I/O devices by means of channel paths between the channel subsystem and control units. A control unit may be accessible by the channel subsystem by more than one channel path. Similarly, an I/O device may be accessible by the channel subsystem through more than one control unit, each having one or more channel paths to the channel subsystem.

Devices that are attached to the channel subsystem by multiple channel paths configured to a subchannel, may be accessed by the channel subsystem using any of the available channel paths. Similarly, a device having the dynamic-reconnection feature and operating in the multipath mode can be initialized to operate such that the device may choose any of the available channel paths configured to the subchannel, when logically reconnecting to the channel subsystem to continue a chain of I/O operations.

The channel subsystem may contain more than one type of channel path. Examples of channel-path types used by the channel subsystem are the ESCON I/O interface, FICON I/O interface, FICON-converted I/O interface, and IBM System/360 and System/370 I/O interface. The term “serial-I/O interface” is used to refer to the ESCON I/O interface, the FICON I/O interface, and the FICON-converted I/O interface. The term “parallel-I/O interface” is used to refer to the IBM System/360 and System/370 I/O interface.

The ESCON I/O interface is described in the System Library publication IBM Enterprise Systems Architecture/390 ESCON I/O Interface, SA22-7202.

The FICON I/O interface is described in the ANSI standards document Fibre Channel - Single-Byte Command Code Sets-2 (FC-SB-2)

The IBM System/360 and System/370 I/O interface is described in the System Library publication IBM System/360 and System/370 I/O Interface Channel to Control Unit OEMI, GA22-6974.

Depending on the type of channel path, the facilities provided by the channel path, and the I/O device, an I/O operation may occur in one of three modes, frame-multiplex mode, burst mode, or byte-multiplex mode.

In the frame-multiplex mode, the I/O device may stay logically connected to the channel path for the duration of the execution of a channel program. The facilities of a channel path capable of operating in the frame-multiplex mode may be shared by a number of concurrently operating I/O devices. In this mode the information required to complete an I/O operation is divided into frames that may be interleaved with frames from I/O operations for other I/O devices. During this period, multiple I/O devices are considered to be logically connected to the channel path.

In the burst mode, the I/O device monopolizes a channel path and stays logically connected to the channel path for the transfer of a burst of information. No other device can communicate over the channel path during the time a burst is transferred. The burst can consist of a few bytes, a whole block of data, a sequence of blocks with associated control and status information (the block lengths may be zero), or status information that monopolizes the channel path. The facilities of the channel path capable of operating in the burst mode may be shared by a number of concurrently operating I/O devices.

Some channel paths can tolerate an absence of data transfer for about a half minute during a burst-mode operation, such as occurs when a long gap on magnetic tape is read. An equipment malfunction may be indicated when an absence of data transfer exceeds the prescribed limit.

In the byte-multiplex mode, the I/O device stays logically connected to the channel path only for a short interval of time. The facilities of a channel path capable of operating in the byte-multiplex mode may be shared by a number of concurrently operating I/O devices. In this mode, all I/O operations are split into short intervals of time during which only a segment of information is transferred over the channel path. During such an interval, only one device and its associated subchannel are logically connected to the channel path. The intervals associated with the con-
current operation of multiple I/O devices are sequenced in response to demands from the devices. The channel-subsystem facility associated with a subchannel exercises its controls for any one operation only for the time required to transfer a segment of information. The segment can consist of a single byte of data, a few bytes of data, a status report from the device, or a control sequence used for the initiation of a new operation.

Ordinarily, devices with high data-transfer-rate requirements operate with the channel path in the frame-multiplex mode, slower devices operate in the burst mode, and the slowest devices operate in the byte-multiplex mode. Some control units have a manual switch for setting the desired mode of operation.

An I/O operation that occurs on a parallel-I/O-interface type of channel path may occur in either the burst mode or the byte-multiplex mode depending on the facilities provided by the channel path and the I/O device. For improved performance, some channel paths and control units are provided with facilities for high-speed transfer and data streaming. See the System Library publication IBM System/360 and System/370 I/O Interface Channel to Control Unit OEMI, GA22-6974, for a description of those two facilities.

An I/O operation that occurs on a serial-I/O-interface type of channel path may occur in either the frame-multiplex mode or the burst mode. For improved performance, some control units attaching to the serial-I/O interface provide the capability to provide sense data to the program concurrent with the presentation of unit-check status, if permitted to do so by the program. (See “Concurrent Sense” on page 24.)

Depending on the control unit or channel subsystem, access to a device through a subchannel may be restricted to a single channel-path type.

The modes and features described above affect only the protocol used to transfer information over the channel path and the speed of transmission. No effects are observable by CPU or channel programs with respect to the way these programs are executed.

Control Units

A control unit provides the logical capabilities necessary to operate and control an I/O device and adapts the characteristics of each device so that it can respond to the standard form of control provided by the channel subsystem.

Communication between the control unit and the channel subsystem takes place over a channel path. The control unit accepts control signals from the channel subsystem, controls the timing of data transfer over the channel path, and provides indications concerning the status of the device.

The I/O device attached to the control unit may be designed to perform only certain limited operations, or it may perform many different operations. A typical operation is moving a recording medium and recording. To accomplish its operations, the device needs detailed signal sequences peculiar to its type of device. The control unit decodes the commands received from the channel subsystem, interprets them for the particular type of device, and provides the signal sequence required for the performance of the operation.

A control unit may be housed separately, or it may be physically and logically integrated with the I/O device, the channel subsystem, or a CPU. In the case of most electromechanical devices, a well-defined interface exists between the device and the control unit because of the difference in the type of equipment the control unit and the device require. These electromechanical devices often are of a type where only one device of a group attached to a control unit is required to transfer data at a time (magnetic-tape units or disk-access mechanisms, for example), and the control unit is shared among a number of I/O devices. On the other hand, in some electronic I/O devices, such as the channel-to-channel adapter, the control unit does not have an identity of its own.

From the programmer's point of view, most functions performed by the control unit can be merged with those performed by the I/O device. Therefore, this publication normally makes no specific mention of the control-unit function; the performance of I/O operations is described as if the I/O devices communicated directly with the channel subsystem. Reference is made to the control unit only when emphasizing a function performed by it or when describing how the sharing of the control unit among a number of devices affects the performance of I/O operations.
I/O Devices

An input/output (I/O) device provides external storage, a means of communication between data-processing systems, or a means of communication between a system and its environment. I/O devices include such equipment as magnetic-tape units, direct-access-storage devices (for example, disks), display units, typewriter-keyboard devices, printers, teleprocessing devices, and sensor-based equipment. An I/O device may be physically distinct equipment, or it may share equipment with other I/O devices.

Most types of I/O devices, such as printers, or tape devices, use external media, and these devices are physically distinguishable and identifiable. Other types are solely electronic and do not directly handle physical recording media. The channel-to-channel adapter, for example, provides for data transfer between two channel paths, and the data never reaches a physical recording medium outside main storage. Similarly, communication controllers may handle the transmission of information between the data-processing system and a remote station, and its input and output are signals on a transmission line.

In the simplest case, an I/O device is attached to one control unit and is accessible from one channel path. Switching equipment is available to make some devices accessible from two or more channel paths by switching devices among control units and by switching control units among channel paths. Such switching equipment provides multiple paths by which an I/O device may be accessed. Multiple channel paths to an I/O device are provided to improve performance or I/O availability, or both, within the system. The management of multiple channel paths to devices is under the control of the channel subsystem and the device, but the channel paths may indirectly be controlled by the program.

I/O Addressing

Four different types of I/O addressing are provided by the channel subsystem for the necessary addressing of the various components: channel-path identifiers, subchannel numbers, device numbers, and, though not visible to programs, addresses dependent on the channel-path type. When the multiple-subchannel-set facility is installed, the subchannel-set identifier (SSID) is also used in I/O addressing.

Subchannel-Set Identifier

The subchannel-set identifier (SSID) is a two-bit value assigned to each provided subchannel set.

Channel-Path Identifier

The channel-path identifier (CHPID) is a system-unique eight-bit value assigned to each installed channel path of the system. A CHPID is used to address a channel path. A CHPID is specified by the second-operand address of RESET CHANNEL PATH and used to designate the channel path that is to be reset. The channel paths by which a device is accessible are identified in the subchannel-information block (SCHIB), each by its associated CHPID, when STORE SUBCHANNEL is executed. The CHPID can also be used in operator messages when it is necessary to identify a particular channel path. A system model may provide as many as 256 channel paths. The maximum number of channel paths and the assignment of CHPIDs to channel paths depends on the system model.

Subchannel Number

A subchannel number is a 16-bit value used to address a subchannel. This value is unique within a subchannel set of a channel subsystem. The subchannel is addressed by eight I/O instructions: CANCEL SUBCHANNEL, CLEAR SUBCHANNEL, HALT SUBCHANNEL, MODIFY SUBCHANNEL, RESUME SUBCHANNEL, START SUBCHANNEL, STORE SUBCHANNEL, and TEST SUBCHANNEL. All I/O functions relative to a specific I/O device are specified by the program by designating a subchannel assigned to the I/O device. Subchannels in each subchannel set are always assigned subchannel numbers within a single range of contiguous numbers. The lowest-numbered subchannel is subchannel 0. The highest-numbered subchannel of the channel subsystem has a subchannel number equal to one less than the number of subchannels provided. A maximum of 65,536 subchannels can be provided in each subchannel set. Normally, subchannel numbers are only used in communication between the CPU program and the channel subsystem.
Device Number

Each subchannel that has an I/O device assigned to it also contains a parameter called the device number. The device number is a 16-bit value that is assigned as one of the parameters of the subchannel at the time the device is assigned to the subchannel. The device number identifies a device to the program and is unique within a subchannel set of a channel subsystem.

The device number provides a means to identify a device, independent of any limitations imposed by the system model, the configuration, or channel-path protocols. The device number is used in communications concerning the device that take place between the system and the system operator. For example, the device number is entered by the system operator to designate the input device to be used for initial program loading.

**Programming Note:** The device number is assigned at device-installation time and may have any value. However, the user must observe any restrictions on device-number assignment that may be required by the control program, support programs, or the particular control unit or I/O device.

Device Identifier

A device identifier is an address, not apparent to the program, that is used by the channel subsystem to communicate with I/O devices. The type of device identifier used depends on the specific channel-path type and the protocols provided. Each subchannel contains one or more device identifiers.

For a channel path of the parallel-I/O-interface type, the device identifier is called a device address and consists of an eight-bit value. For the ESCON I/O interface, the device identifier consists of a four-bit control-unit address and an eight-bit device address. For the FICON I/O interface, the device identifier consists of an eight-bit control-unit-image ID and an eight-bit device address. For the FICON-converted I/O interface, the device identifier consists of a four-bit control-unit address and an eight-bit device address.

The device address identifies the particular I/O device (and, on the parallel-I/O interface, the control unit) associated with a subchannel. The device address may identify, for example, a particular magnetic-tape drive, disk-access mechanism, or transmission line. Any number in the range 0-255 can be assigned as a device address.

For further information about the device identifier used with a particular channel-path type, see the appropriate publication for the channel-path type.

Fibre-Channel Extensions

The fibre-channel-extensions (FCX) facility is an optional facility that provides for the formation of a channel program that is composed of a transport-control word (TCW) that designates a transport-command-control block (TCCB) and a transport-status block (TSB). The TCCB includes a transport-command area (TCA) which contains a list of up to 30 I/O commands that are in the form of device-command words (DCWs).

The FCX-bidirectional-data-transfer facility is an additional and optional facility that provides support for TCW channel programs that specify both read and write operations. Whether a device recognizes bidirectional data transfers is determined by device-dependent means.

When a device does not recognize bidirectional data transfers, a TCW and its TCCB may specify either read or a write data transfers. When a device recognizes bidirectional data transfers, a TCW and its TCCB may, depending on the device, specify both read and write data transfers. For interruptions, the TSB contains the completion status and other information related to the TCW channel program in addition to the information in the IRB.

For some devices, the list of DCWs may be extended past what will fit in the TCA. For such devices, the TCA extension (TCAX) is specified and transferred as output data. Whether a device supports TCA extensions is determined by device-dependent means.

In addition to the IRB, the TSB contains the completion status and other information related to the TCW channel program.

The FCX facility provides the ability to directly or indirectly designate any or all of the TCCB, the input data storage area, and the output data storage area.
When a storage area is designated directly, the TCW specifies the location of a single, contiguous block of storage. When a storage area is designated indirectly, the TCW designates the location of a list of one or more transport-indirect-data-address words (TIDAWs). TIDAW lists and the storage area designated by each TIDAW in a list are restricted from crossing 4K-byte boundaries.

The FCX facility also provides an interrogate operation that may be initiated by the CANCEL SUBCHANNEL instruction to determine the state of an I/O operation.

I/O-Command Words

An I/O-command word specifies a command and contains information associated with the command. When the FCX facility is installed, there are two elemental forms of I/O command words which are the channel-command word (CCW) and the device-command word (DCW).

A CCW is 8-bytes in length and specifies the command to be executed. For commands that initiate certain operations the CCW also designates the storage area associated with the operation, the count of data bytes, the action to be taken when the command completes, and other options. All I/O devices recognize CCWs.

A DCW is 8-bytes in length and specifies the command to be executed, the count of data bytes, and other options. I/O devices that support FCX recognize DCWs.

Transport Command Word (TCW)

A TCW designates a transport-command-control block (TCCB) which contains a list of commands to be transported to and executed by an I/O device. The TCW also designates the storage areas for the commands in the TCCB as well as a transport-status block (TSB) to contain the status of the I/O operation.

Channel Program Organization

When the FCX facility is not installed, there is a single form of channel program which is the CCW channel program. When the FCX facility is installed, there is an additional form of channel program which is the TCW channel program. Both forms of channel programs are described below.

CCW Channel Program

A channel program that is composed of one or more CCWs is called a CCW channel program (CCP). Such a channel program contains one or more CCWs that are logically linked and arranged for sequential execution by the channel subsystem.

Figure 13-1 shows a conceptual example of a simple CCW channel program in program storage. This channel program contains 4 CCWs and specifies the transfer of data to or from contiguous areas of storage. The first CCW designates a control command and the remaining CCWs designate the transfer of data.

![Figure 13-1. CCW Channel Program Example](image)

TCW Channel Program

A channel program that is composed of a single TCW is called a TCW channel program. A TCW designates a transport-command-control block (TCCB) that contains from 1 to 30 DCWs.

When DCWs within the TCCB are logically linked and arranged for sequential execution. For DCWs that specify control information, the TCCB also contains the control information for those commands. The TCW also designates the storage area or areas for the DCWs that specify the transfer of data from or to the device and the location of a transport-status block (TSB) for completion status. The TCCB and the storage areas for the transfer of data may be specified as either contiguous or noncontiguous storage.
Figure 13-2 shows a conceptual example of a TCW channel program in program storage. This channel program is similar to the CCW channel program in Figure 13-1. This channel program is composed of a TCW that designates a TCCB containing 4 DCWs, all of which specify the transfer of data either to or from contiguous areas of storage. The first DCW designates a control command and the remaining DCWs designate the transfer of data. The TCW also designates a TSB for completion status.

**Execution of I/O Operations**

I/O operations are initiated and controlled by information with four types of formats: the instruction START SUBCHANNEL, transport-command words, I/O-command words, and orders. The START SUBCHANNEL instruction is executed by a CPU and is part of the CPU program that supervises the flow of requests for I/O operations from other programs that manage or process the I/O data.

When START SUBCHANNEL is executed, parameters are passed to the target subchannel requesting that the channel subsystem perform a start function with the I/O device associated with the subchannel. The channel subsystem performs the start function by using information at the subchannel, including the information passed during the execution of the START SUBCHANNEL instruction, to find an accessible channel path to the device. Once the device has been selected, the execution of an I/O operation is accomplished by the decoding and execution of a CCW by the channel subsystem and the I/O device, for CCW channel programs, or for TCW channel programs, by transporting the TCCB to the I/O device by the channel subsystem and the decoding and execution of a DCW by the device. I/O-command words, and transport-command words are fetched from main storage, although the modifier bits in the command code of a CCW DCW may specify device-dependent conditions for the execution of an operation at the device.

Operations peculiar to a device, such as rewinding tape or positioning the access mechanism on a disk drive, are specified by orders that are decoded and executed by I/O devices. Orders may be transferred to the device as modifier bits in the command code of a control command, may be transferred to the device as data during a control or write operation, or may be made available to the device by other means.

**Start-Function Initiation**

CPU programs initiate I/O operations with the instruction START SUBCHANNEL. This instruction passes the contents of an operation-request block (ORB) to the subchannel.

If the ORB specifies a CCW channel program, the contents of the ORB include the subchannel key, the address of the first CCW to be executed, and a specification of the format of the CCWs. The CCW specifies the command to be executed and the storage area, if any, to be used. If the ORB specifies a TCW channel program, the contents of the ORB include the subchannel key and the address of the TCW to be executed. The TCW designates the TCCB which contains the commands to be transported to the device for execution, the storage area or areas, if any, to be used for data transfer, and the TSB to contain the status of the I/O operation.

When the ORB contents have been passed to the subchannel, the execution of START SUBCHANNEL is complete. The results of the execution of the instruction are indicated by the condition code set in the program-status word.

When facilities become available and the ORB specifies a CCW channel program, the channel subsystem fetches the first CCW and decodes it according to the format bit specified in the ORB. If the format bit is zero, format-0 CCWs are specified. If the format bit is
one, format-1 CCWs are specified. Format-0 and format-1 CCWs contain the same information, but the fields are arranged differently in the format-1 CCW so that 31-bit addresses can be specified directly in the CCW. When facilities become available and the ORB specifies a TCW channel program, the channel subsystem fetches the designated TCW and transports the designated TCCB to the device. Storage areas designated by the TCW for the transfer of data to or from the device are 64-bit addresses.

Subchannel Operation Modes
There are two modes of subchannel operation. A subchannel enters transport mode when the FCX facility is installed and the start function is set at the subchannel as the result of the execution of a START SUBCHANNEL instruction that specifies a TCW channel program. The subchannel remains in transport mode until the start function is reset at the subchannel. At all other times, the subchannel is in command mode.

Path Management
If ORB specifies a CCW channel program and the first CCW passes certain validity tests and does not have the suspend flag specified as one or if the ORB specifies a TCW channel program and the designated TCW passes certain validity tests, the channel subsystem attempts device selection by choosing a channel path from the group of channel paths that are available for selection. A control unit that recognizes the device identifier connects itself logically to the channel path and responds to its selection.

If the ORB specifies a CCW channel program, the channel subsystem sends the command-code part of the CCW over the channel path, and the device responds with a status byte indicating whether the command can be executed. The control unit may logically disconnect from the channel path at this time, or it may remain connected to initiate data transfer.

If the ORB specifies a TCW channel program, the channel subsystem uses information in the designated TCW to transfer the TCCB to the control unit. The contents of the TCCB are ignored by the channel subsystem and only have meaning to the control unit and I/O device.

If the attempted selection does not occur as a result of either a busy indication or a path-not-operational condition, the channel subsystem attempts to select the device by an alternate channel path if one is available. When selection has been attempted on all paths available for selection and the busy condition persists, the operation remains pending until a path becomes free. If a path-not-operational condition is detected on one or more of the channel paths on which device selection was attempted, the program is alerted by a subsequent I/O interruption. The I/O interruption occurs either upon execution of the channel program (assuming the device was selected on an alternate channel path) or as a result of the execution being abandoned because path-not-operational conditions were detected on all of the channel paths on which device selection was attempted.

Channel-Program Execution
If the command is initiated at the device and command execution does not require any data to be transferred to or from the device, the device may signal the end of the operation immediately on receipt of the command code. In operations that involve the transfer of data, the subchannel is set up so that the channel subsystem will respond to service requests from the device and assume further control of the operation.

An I/O operation may involve the transfer of data to or from one storage area, designated by a single CCW or TCW or to or from a number of noncontiguous storage areas. In the latter case, generally a list of CCWs is used for the execution of the I/O operation, with each CCW designating a contiguous storage area and the CCWs are coupled by data chaining. Data chaining is specified by a flag in the CCW and causes the channel subsystem to fetch another CCW upon the exhaustion or filling of the storage area designated by the current CCW. The storage area designated by a CCW fetched on data chaining pertains to the I/O operation already in progress at the I/O device, and the I/O device is not notified when a new CCW is fetched.

Provision is made in the CCW format for the programmer to specify that, when the CCW is decoded, the channel subsystem request an I/O interruption as soon as possible, thereby notifying a CPU program that chaining has progressed at least as far as that CCW in the channel program.

To complement dynamic address translation in CPUs, CCW indirect data addressing and modified CCW indirect data addressing are provided.
When the ORB specifies a CCW channel program and CCW-indirect-data addressing is used, a flag in the CCW specifies that an indirect-data-address list is to be used to designate the storage areas for that CCW. Each time the boundary of a block of storage is reached, the list is referenced to determine the next block of storage to be used. The ORB specifies whether the size of each block of storage is 2K bytes or 4K bytes.

When the ORB specifies a CCW channel program and modified-CCW-indirect-data addressing is used, a flag in the ORB and a flag in the CCW specify that a modified-indirect-data-address list is to be used to designate the storage areas for that CCW. Each time the count of bytes specified for a block of storage is reached, the list is referenced to determine the next block of storage to be used. Unlike when indirect data addressing is used, the block may be specified on any boundary and length up to 4K, provided a data transfer across a 4K-byte boundary is not specified.

When the ORB specifies a TCW channel program and transport-indirect-data addressing is used, flags in the TCW specify whether a transport-indirect-data-address list is to be used to designate the storage areas containing the TCCB and whether a transport-indirect-data-address list is used to designate the data storage areas associated with the DCWs in the TCCB. Each time the count of bytes specified for a block of storage is reached, the corresponding transport-indirect-data-address list is referenced to determine the next storage block to be used.

CCW indirect data addressing and modified CCW indirect data addressing permit essentially the same CCW sequences to be used for a program running with dynamic address translation active in the CPU as would be used if the CPU were operating with equivalent contiguous real storage. CCW indirect data addressing permits the program to designate data blocks having absolute storage addresses up to $2^{31}$-1 independent of whether format-0 or format-1 CCWs have been specified in the ORB. Modified CCW indirect data addressing permits the program to designate data blocks having absolute storage addresses up to $2^{30}$-1, independent of whether format-0 or format-1 CCWs have been specified in the ORB.

In general, the execution of an I/O operation or chain of operations involves as many as three levels of participation:

1. Except for effects due to the integration of CPU and channel-subsystem equipment, a CPU is busy for the duration of the execution of START SUBCHANNEL, which lasts until the addressed subchannel has been passed the ORB contents.

2. The subchannel is busy for a new START SUBCHANNEL from the receipt of the ORB contents until the primary interruption condition is cleared at the subchannel.

3. The I/O device is busy from the initiation of the first operation at the device until either the subchannel becomes suspended or the secondary interruption condition is placed at the subchannel. In the case of a suspended subchannel, the device again becomes busy when the execution of the suspended channel program is resumed.

**Conclusion of I/O Operations**

The conclusion of an I/O operation normally is indicated by two status conditions: channel end and device end. The channel-end condition indicates that the I/O device has received or provided all data associated with the operation and no longer needs channel-subsystem facilities. This condition is called the primary interruption condition, and the channel end in this case is the primary status. Generally, the primary interruption condition is any interruption condition that relates to an I/O operation and that signals the conclusion at the subchannel of the I/O operation or chain of I/O operations.

The device-end signal indicates that the I/O device has concluded execution and is ready to perform another operation. This condition is called the secondary interruption condition, and the device end in this case is the secondary status. Generally, the secondary interruption condition is any interruption condition that relates to an I/O operation and that signals the conclusion at the device of the I/O operation or chain of operations. The secondary interruption condition can occur concurrently with, or later than, the primary interruption condition.

Concurrent with the primary or secondary interruption conditions, both the channel subsystem and the I/O device can provide indications of unusual situations.

The conditions signaling the conclusion of an I/O operation can be brought to the attention of the program by I/O interruptions or, when the CPUs are dis-
abled for I/O interruptions, by programmed interrogation of the channel subsystem. In the former case, these conditions cause storing of the I/O-interruption code, which contains information concerning the interrupting source. In the latter case, the interruption code is stored as a result of the execution of TEST PENDING INTERRUPTION.

When the primary interruption condition is recognized, the channel subsystem attempts to notify the program, by means of an interruption request, that a subchannel contains information describing the conclusion of an I/O operation at the subchannel. For command-mode interruptions, the information identifies the last CCW used and may provide its residual byte count, thus describing the extent of main storage used. For transport-mode interruptions, the information identifies the current TCW and the TSB associated with the channel program that contains additional status about the I/O operation, such as residual byte count. In addition to information about the channel program, both the channel subsystem and the I/O device may provide additional indications of unusual conditions as part of either the primary or the secondary interruption condition. The information contained at the subchannel may be stored by the execution of TEST SUBCHANNEL or the execution of STORE SUBCHANNEL. This information, when stored, is called a subchannel-status word (SCSW).

**Chaining When Using a CCW Channel Program**

When the ORB specifies a CCW channel program, facilities are provided for the program to initiate the execution of a chain of I/O operations with a single START SUBCHANNEL instruction. When the current CCW specifies command chaining and no unusual conditions have been detected during the operation, the receipt of the device-end signal causes the channel subsystem to fetch a new CCW. If the CCW passes certain validity tests and the suspend flag is not specified as a one in the new CCW, execution of the new command is initiated at the device. If the CCW fails to pass the validity tests, the new command is not initiated, command chaining is suppressed, and the status associated with the new CCW causes an interruption condition to be generated. If the suspend flag is specified as a one and this value is valid because of a one value in the suspend control, bit 4 of word 1 of the associated ORB, execution of the new command is not initiated, and command chaining is concluded.

Execution of the new command is initiated by the channel subsystem in the same way as in the previous operation. The ending signals occurring at the conclusion of an operation caused by a CCW specifying command chaining are not made available to the program. When another I/O operation is initiated by command chaining, the channel subsystem continues execution of the channel program. If, however, an unusual condition has been detected, command chaining is suppressed, the channel program is terminated, an interruption condition is generated, and the ending signals causing the termination are made available to the program.

The suspend-and-resume function provides the program with control over the execution of a channel program. The initiation of the suspend function is controlled by the setting of the suspend-control bit in the ORB. The suspend function is signaled to the channel subsystem during channel-program execution when the suspend-control bit in the ORB is one and the suspend flag in the first CCW or in a CCW fetched during command chaining is one.

Suspension occurs when the channel subsystem fetches a CCW with the suspend flag validly (because of a one value of the suspend-control bit in the ORB) specified as one. The command in this CCW is not sent to the I/O device, and the device is signaled that the chain of commands is concluded. A subsequent RESUME SUBCHANNEL instruction informs the channel subsystem that the CCW that caused suspension may have been modified and that the channel subsystem must refetch the CCW and examine the current setting of the suspend flag. If the suspend flag is found to be zero in the CCW, the channel subsystem resumes execution of the chain of commands with the I/O device.

**Chaining When Using a TCW Channel Program**

When the ORB specifies a TCW channel program, facilities are also provided for the program to initiate the execution of a chain of device operations with a single START SUBCHANNEL instruction. Command chaining may be specified for those DCWs designated by a single TCW. When the current DCW specifies command chaining and no unusual conditions have been detected during the operation, recognition of the successful execution of the DCW causes the next DCW in the current TCCB to be processed.
If the next DCW passes certain validity tests, execution of a new command is initiated at the device and the DCW becomes the current DCW. If the DCW fails to pass the validity tests, the new command is not initiated, command chaining is suppressed, the channel program is terminated, and the status associated with the new DCW causes an interruption condition to be generated.

Execution of the new command is initiated in the same way as in the previous operation. The ending signals occurring at the conclusion of an operation caused by a DCW that is not the last specified DCW are not made available to the program. When another I/O operation is initiated by command chaining, execution of the channel program continues. If, however, an unusual condition has been detected, command chaining is suppressed, the channel program is terminated, an interruption condition is generated, and status is made available to the program that identifies the unusual condition.

**Premature Conclusion of I/O Operations**

Channel-program execution may be terminated prematurely by CANCEL SUBCHANNEL, HALT SUBCHANNEL or CLEAR SUBCHANNEL. The execution of CANCEL SUBCHANNEL causes the channel subsystem to terminate the start function at the subchannel if the channel program has not been initiated at the device. When the start function is terminated by the execution of CANCEL SUBCHANNEL, the channel subsystem sets condition code 0 in response to the CANCEL SUBCHANNEL instruction. The execution of HALT SUBCHANNEL causes the channel subsystem to issue the halt signal to the I/O device and terminate channel-program execution at the subchannel. When channel-program execution is terminated by the execution of HALT SUBCHANNEL, the program is notified of the termination by means of an I/O-interruption request. When the subchannel is in command mode, the interruption request is generated when the device presents status for the terminated operation. When the subchannel is in transport mode, the interruption request is generated immediately. If, however, the halt signal was issued to the device during command chaining after the receipt of device end but before the next command was transferred to the device, the interruption request is generated after the device has been signaled. In the latter case, the device-status field of the SCSW will contain zeros. The execution of CLEAR SUBCHANNEL clears the subchannel of indications of the channel program in execution, causes the channel subsystem to issue the clear signal to the I/O device, and causes the channel subsystem to generate an I/O-interruption request to notify the program of the completion of the clear function.

**I/O Interruptions**

Conditions causing I/O-interruption requests are asynchronous to activity in CPUs, and more than one condition can occur at the same time. For I/O interruptions associated with subchannels, the conditions are preserved at the subchannels until cleared by TEST SUBCHANNEL or CLEAR SUBCHANNEL, or reset by an I/O-system reset.

When an I/O-interruption condition has been recognized by the channel subsystem and indicated at the subchannel, an I/O-interruption request is made pending for the I/O-interruption subclass specified at the subchannel. The I/O-interruption subclass for which the interruption is made pending is under programmed control through the use of MODIFY SUBCHANNEL. A pending I/O interruption may be accepted by any CPU that is enabled for interruptions from its I/O-interruption subclass. Each CPU has eight mask bits, in control register 6, that control the enablement of that CPU for each of the eight I/O-interruption subclasses, with the I/O mask, bit 6 in the PSW, being the master I/O-interruption mask for the CPU.

When an I/O interruption occurs at a CPU, the I/O-interruption code is stored in the I/O-communication area of that CPU, and the I/O-interruption request is cleared. For I/O interruptions associated with subchannels, the I/O-interruption code identifies the subchannel for which the interruption was pending. The conditions causing the generation of the interruption request associated with the subchannel may then be retrieved from the subchannel explicitly by TEST SUBCHANNEL or by STORE SUBCHANNEL.

A pending I/O-interruption request may also be cleared by TEST PENDING INTERRUPTION when the corresponding I/O-interruption subclass is enabled but the PSW has I/O interruptions disabled. For I/O interruptions associated with subchannels, a pending I/O interruption may also be cleared by TEST SUBCHANNEL when the CPU is disabled for I/O interruptions from the corresponding I/O-interruption subclass. A pending I/O-interruption request associated with a subchannel may also be cleared by CLEAR SUBCHANNEL. Both CLEAR SUBCHAN-
NEL and TEST SUBCHANNEL clear the preserved interruption condition at the subchannel as well. Normally, unless the interruption request is cleared by CLEAR SUBCHANNEL, the program issues TEST SUBCHANNEL to obtain subchannel information concerning the execution of the operation.
Chapter 14. I/O Instructions

I/O-Instruction Formats .......................... 14-1
I/O-Instruction Execution ......................... 14-2
Serialization .................................. 14-2
Operand Access ................................. 14-2
Condition Code ................................. 14-2
Program Exceptions ............................ 14-2
Instructions ................................. 14-2
CANCEL SUBCHANNEL ......................... 14-3
CLEAR SUBCHANNEL .......................... 14-5
HALT SUBCHANNEL .............................. 14-6
MODIFY SUBCHANNEL .......................... 14-7
RESET CHANNEL PATH ......................... 14-9
RESUME SUBCHANNEL .......................... 14-10
SET ADDRESS LIMIT ............................ 14-12
SET CHANNEL MONITOR ......................... 14-13
START SUBCHANNEL ............................ 14-15
STORE CHANNEL PATH STATUS .................. 14-16
STORE CHANNEL REPORT WORD .................. 14-17
STORE SUBCHANNEL ............................ 14-18
TEST PENDING INTERRUPTION .................... 14-19
I/O-Interrupt Code .............................. 14-20
TEST SUBCHANNEL .............................. 14-21

All the I/O instructions described here are provided for the control of channel-subsystem operations. The I/O instructions are listed in Figure 14-1 on page 14-3. All of the I/O instructions are privileged instructions.

Several I/O instructions result in the channel subsystem being signaled to perform functions asynchronous to the execution of the instructions. The description of each instruction of this type contains a section, "Associated Functions," that summarizes the asynchronous functions.

I/O-Instruction Formats

I/O instructions use the S format:

<table>
<thead>
<tr>
<th>Op Code</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>

The use of the second-operand address and general registers 1 and 2 (as implied operands) depends on the I/O instruction. Figure 14-1 on page 14-3 defines which operands are used to execute each I/O instruction. In addition, detailed information regarding operand usage appears in the description of each I/O instruction.

All I/O instructions that reference a subchannel use the contents of general register 1 as an implied operand. For these I/O instructions, general register 1 contains the subsystem-identification word (SID).

When the multiple-subchannel set (MSS) facility is installed, the format of the subsystem-identification word is as follows:

```
0 31
0 32 45 47 48 63
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 SSID1 Subchannel Number
```

Bit positions 0-31 are ignored. Bit positions 32-44 must contain zeros and bit 47 must contain 1. (Exception conditions are listed later in the section.)

Bit positions 45-46 of general register 1 contain the subchannel-set identifier (SSID) uniquely identifying a subchannel set (SS). When the multiple-subchannel-set facility is not installed, the SSID must be equal to zero. Bit positions 48-63 of general register 1 contain the binary number of the subchannel within the specified subchannel set to be used for the function specified by the instruction.

(See "Multiple-Subchannel-Set Facility" on page 17-29 for more information on SSID.)

The format of the subsystem-identification word when the MSS facility is not installed is as follows:
Bit positions 48-63 of general register 1 contain the binary number of the subchannel to be used for the function specified by the instruction. Bit positions 0-31 of general register 1 are ignored and bits 32-47 specify the binary number one.

I/O-Instruction Execution

Serialization

The execution of any I/O instruction causes a serialization and checkpoint synchronization function to occur. For a definition of the serialization of CPU operations, see “CPU Serialization” on page 128 and “Channel-Program Serialization” on page 130.

Operand Access

During the execution of an I/O instruction, the order in which fields of the operand and fields of the subchannel, if applicable, are accessed is unpredictable. It is also unpredictable whether fetch accesses are made to fields of an operand or the subchannel, as applicable, when those fields are not needed to complete the execution of the I/O instruction. (See “Relation between Operand Accesses” on page 126.)

Condition Code

During the execution of some I/O instructions, the results of certain tests are used to set one of four condition codes in the PSW. The I/O instructions for which execution can result in the setting of the condition code are listed in Figure 14-1 on page 3. The condition code indicates the result of the execution of the I/O instruction. The general meaning of the condition code for I/O instructions is given below; the meaning of the condition code for a specific instruction appears in the description of that instruction.

Condition Code 0: Instruction execution produced the expected or most probable result. (See “Deferred Condition Code (CC)” on page 9 for a description of conditions that can be encountered subsequent to the presentation of condition code 0 that result in a nonzero deferred condition code.)

Condition Code 1: Instruction execution produced the alternate or second-most-probable result, or status conditions were present that may or may not have prevented the expected result.

Condition Code 2: Instruction execution was ineffective because the designated subchannel or channel-subsystem facility was busy with a previously initiated function.

Condition Code 3: Instruction execution was ineffective because the designated element was not operational or because some condition precluded initiation of the normal function.

In situations where conditions exist that could cause more than one nonzero condition code to be set, the priority of the condition codes is as follows:

Condition code 3 has precedence over condition codes 1 and 2.

Condition code 1 has precedence over condition code 2.

Program Exceptions

The program exceptions that the I/O instructions can encounter are access, operand, privileged-operation, and specification exceptions. Figure 14-1 on page 14-3 shows the exceptions that are applicable to each of the I/O instructions. The execution of the instruction is suppressed for privileged-operation, operand, and specification exceptions. Except as indicated otherwise in the section “Special Conditions” for each instruction, the instruction ending for access exceptions is as described in “Recognition of Access Exceptions” on page 45).

Instructions

The mnemonics, format, and operation codes of the I/O instructions are given in Figure 14-1 on page 3. The figure also indicates the conditions that can cause a program interruption and whether the condition code is set.
In the detailed descriptions of the individual instructions, the mnemonic and the symbolic operand designation for the assembler language are shown with each instruction. For START SUBCHANNEL, for example, SSCH is the mnemonic and D₂(B₂) the operand designation.

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CANCEL SUBCHANNEL</td>
<td>XSCH</td>
<td>S C P OP c GS</td>
<td>B276</td>
<td>14-3</td>
</tr>
<tr>
<td>CLEAR SUBCHANNEL</td>
<td>CSCH</td>
<td>S C P OP c GS</td>
<td>B230</td>
<td>14-5</td>
</tr>
<tr>
<td>HALT SUBCHANNEL</td>
<td>HSCH</td>
<td>S C P OP c GS</td>
<td>B231</td>
<td>14-6</td>
</tr>
<tr>
<td>MODIFY SUBCHANNEL</td>
<td>MSCH</td>
<td>S C P A SP OP c GS</td>
<td>B232</td>
<td>14-7</td>
</tr>
<tr>
<td>RESET CHANNEL PATH</td>
<td>RCHP</td>
<td>S C P</td>
<td>B238</td>
<td>14-9</td>
</tr>
<tr>
<td>RESUME SUBCHANNEL</td>
<td>RSCH S</td>
<td>P OP c GS</td>
<td>B238</td>
<td>14-10</td>
</tr>
<tr>
<td>SET ADDRESS LIMIT</td>
<td>SAL S</td>
<td>P OP c G1</td>
<td>B237</td>
<td>14-12</td>
</tr>
<tr>
<td>SET CHANNEL MONITOR</td>
<td>SCHM S</td>
<td>P OP c GM</td>
<td>B233</td>
<td>14-13</td>
</tr>
<tr>
<td>START SUBCHANNEL</td>
<td>SSCH S C</td>
<td>P A SP OP c GS</td>
<td>B233</td>
<td>14-15</td>
</tr>
<tr>
<td>STORE CHANNEL PATH STATUS</td>
<td>STCPS S</td>
<td>P A SP c</td>
<td>ST B₂</td>
<td>B234</td>
</tr>
<tr>
<td>STORE CHANNEL REPORT WORD</td>
<td>STCW S</td>
<td>P A SP c</td>
<td>ST B₂</td>
<td>B235</td>
</tr>
<tr>
<td>TEST PENDING INTERRUPTION</td>
<td>TPI S</td>
<td>P A¹ SP c</td>
<td>ST B₂</td>
<td>B236</td>
</tr>
<tr>
<td>TEST SUBCHANNEL</td>
<td>TSCH</td>
<td>S C P A SP OP c GS</td>
<td>ST B₂</td>
<td>B235</td>
</tr>
</tbody>
</table>

Explanation:

* PER zero-address-detection not recognized
¢ Causes a serialization and checkpoint synchronization function.
A Access exceptions for logical addresses.
A¹ When the effective address is zero, it is not used to access storage, and no access exceptions can occur, except that access exceptions may occur during access-register translation.
B₂ B₂ field designates an access register in the access-register mode.
C Condition code is set.
G1 Instruction execution includes implied use of general register 1 as a parameter.
GM Instruction execution includes the implied use of multiple general registers.
GS Instruction execution includes the implied use of general register 1 as the subsystem-identification word.
OP Operand exception.
P Privileged-operation exception; also, restricted from transactional execution.
S S instruction format.
SP Specification exception.
ST PER storage-alteration event.

Figure 14-1. Summary of I/O Instructions

CANCEL SUBCHANNEL

XSCH [S]

The current start function, if any, is terminated at the designated subchannel if CANCEL SUBCHANNEL is applicable.

General register 1 contains a subsystem-identification word that designates the subchannel for which the current START FUNCTION, if any, is to be terminated.

If the subchannel (1) is not subchannel active, (2) is start pending, resume pending, or suspended, and (3) is performing only the start function, then the start function at the subchannel is terminated, and the subchannel is made no longer start pending, resume pending, or suspended, as appropriate. In addition, internal indications of busy are reset for the subchannel.

Condition code 0 is set to indicate that the actions described above have been taken.

If an invalid ORB field or a no-path-available condition is present for a previously initiated start function and the condition was not reported during the execution of START SUBCHANNEL, condition code 0 may
be indicated for CANCEL SUBCHANNEL provided that the subchannel is not yet status pending to report the error condition; if condition code 0 is presented, no subsequent status is generated to indicate the error condition.

During the execution of CANCEL SUBCHANNEL for a transport-mode operation, the channel subsystem may be signaled to asynchronously perform the interrogate function.

**Special Conditions**

*Condition code 1* is set, and no other action is taken, when the subchannel is status pending with any status.

*Condition code 2* is set, and no other action is taken, when CANCEL SUBCHANNEL is not applicable and the subchannel is not status pending, or when conditions exist that prevent immediate determination of internal conditions for the subchannel and the CPU has determined to end the instruction. CANCEL SUBCHANNEL is not applicable when the subchannel (1) has no function specified, (2) has a function other than the start function alone specified, (3) is not resume pending, is not start pending, and is not suspended, or (4) is subchannel active.

When the subchannel is operating in transport mode and condition code 2 is set, the CPU may signal the channel subsystem to asynchronously perform the interrogate function, and end the instruction.

*Condition code 3* is set, and no other action is taken, when the subchannel is not operational for CANCEL SUBCHANNEL. A subchannel is not operational for CANCEL SUBCHANNEL when the subchannel is not provided by the channel subsystem, has no valid device number assigned to it, or is not enabled.

CANCEL SUBCHANNEL can encounter the program exceptions described or listed below.

When the multiple-subchannel-set facility is not installed, bits 32-47 of general register 1 must contain 0001 hex; otherwise, an operand exception is recognized.

When the multiple-subchannel-set facility is installed, bits 32-44 of general register 1 must contain zeros, bits 45-46 must contain a valid value, and bit 47 must contain the value one; otherwise, an operand exception is recognized.

**Resulting Condition Code:**

- 0 Start function canceled
- 1 Status pending
- 2 CANCEL SUBCHANNEL not applicable
- 3 Not operational

**Program Exceptions:**

- Operand
- Privileged operation
- Transaction constraint

**Programming Notes:**

1. The actions taken by CANCEL SUBCHANNEL are completed during the execution of the instruction.

   If condition code 0 is presented, there is no subsequent I/O interruption resulting from the terminated I/O operation. However, the device may have signaled a busy condition while the canceled operation was start pending. In this case, the device owes a no-longer-busy signal to the channel subsystem. This may result in unsolicited device-end status before the next operation is initiated at the device.

   Condition code 2 may be presented to indicate that the CPU has determined to end the instruction because the internal conditions of the specified subchannel cannot be immediately determined. Subsequent execution of STORE SUBCHANNEL may store an SCSW indicating that CANCEL SUBCHANNEL is applicable (i.e., the subchannel is performing the start function alone, is start pending, resume pending, or suspended, and is not subchannel-active). In such a case, the program can either recognize that the I/O operation has not been terminated and allow the operation to start or the program can retry CANCEL SUBCHANNEL in an attempt to terminate the start function. However, retrying CANCEL SUBCHANNEL does not guarantee that the instruction will end with condition code 0.

   In transport mode, condition code 2 may be presented to indicate that the CPU has determined to asynchronously signal the channel subsystem to perform the interrogate function, and end the
instruction. The LPUM must contain a nonzero value for the interrogate to be initiated.

2. Upon the completion of CANCEL SUBCHANNEL with condition code 0, the subchannel is ready to accept a new start function initiated by START SUBCHANNEL.

CLEAR SUBCHANNEL

The designated subchannel is cleared, the current start or halt function, if any, is terminated at the designated subchannel, and the channel subsystem is signaled to asynchronously perform the clear function at the designated subchannel and at the associated device.

General register 1 contains a subsystem-identification word (SID) that designates the subchannel to be cleared.

If a start or halt function is in progress, it is terminated at the subchannel.

The subchannel is made no longer status pending. All activity, as indicated in the activity-control field of the SCSW, is cleared at the subchannel, except that the subchannel is made clear pending. Any functions in progress, as indicated in the function-control field of the SCSW, are cleared at the subchannel, except for the clear function that is to be performed because of the execution of this instruction.

The channel subsystem is signaled to asynchronously perform the clear function. The clear function is summarized below in the section “Associated Functions” and is described in detail in “Clear Function” on page 14.

Condition code 0 is set to indicate that the actions described above have been taken.

Associated Functions

Subsequent to the execution of CLEAR SUBCHANNEL, the channel subsystem asynchronously performs the clear function. If conditions allow, the channel subsystem chooses a channel path and attempts to issue the clear signal to the device to terminate the I/O operation, if any. The subchannel then becomes status pending. Conditions encountered by the channel subsystem that preclude issuing the clear signal to the device do not prevent the subchannel from becoming status pending (see “Clear Function” on page 14).

When the subchannel becomes status pending as a result of performing the clear function, data transfer, if any, with the associated device has been terminated. The SCSW stored when the resulting status is cleared by TEST SUBCHANNEL has the clear-function bit stored as one. If the channel subsystem can determine that the clear signal was issued to the device, the clear-pending bit is stored as zero in the SCSW. Otherwise, the clear-pending bit is stored as one, and other indications are provided that describe in greater detail the condition that was encountered. (See “Interruption-Response Block” on page 6.)

Measurement data is not accumulated, and device-connect time is not stored in the extended-status word for the subchannel, for a start function that is terminated by CLEAR SUBCHANNEL.

Special Conditions

Condition code 3 is set, and no other action is taken, when the subchannel is not operational for CLEAR SUBCHANNEL. A subchannel is not operational for CLEAR SUBCHANNEL when the subchannel is not provided in the channel subsystem, has no valid device number assigned to it, or is not enabled.

CLEAR SUBCHANNEL can encounter the program exceptions described or listed below.

When the multiple-subchannel-set facility is not installed, bits 32-47 of general register 1 must contain 0001 hex; otherwise, an operand exception is recognized.

When the multiple-subchannel-set facility is installed, bits 32-44 of general register 1 must contain zeros, bits 45-46 must contain a valid value, and bit 47 must contain the value one; otherwise, an operand exception is recognized.
Resulting Condition Code:

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Function initiated</td>
</tr>
<tr>
<td>1</td>
<td>—</td>
</tr>
<tr>
<td>2</td>
<td>—</td>
</tr>
<tr>
<td>3</td>
<td>Not operational</td>
</tr>
</tbody>
</table>

Program Exceptions:

- Operand
- Privileged operation
- Transaction constraint

HALT SUBCHANNEL

The current start function, if any, is terminated at the designated subchannel, and the channel subsystem is signaled to asynchronously perform the halt function at the designated subchannel and at the associated device.

General register 1 contains a subsystem-identification word that designates the subchannel to be halted.

If a start function is in progress, it is terminated at the subchannel.

The subchannel is made halt pending, and the halt function is indicated at the subchannel.

When HALT SUBCHANNEL is executed and the designated subchannel is subchannel-and-device active and status pending with intermediate status, the status-pending indication is eliminated (see the discussion of bits 24, 25, and 28 in “Activity Control (AC)” on page 14). The status-pending condition is reestablished as part of the halt function (see the section “Associated Functions” below).

The channel subsystem is signaled to asynchronously perform the halt function. The halt function is summarized below in the section “Associated Functions” and is described in detail in “Halt Function” on page 16.

Condition code 0 is set to indicate that the actions described above have been taken.

Associated Functions

Subsequent to the execution of HALT SUBCHANNEL, the channel subsystem asynchronously performs the halt function. If conditions allow, the channel subsystem chooses a channel path and attempts to issue the halt signal to the device to terminate the I/O operation, if any. The subchannel then becomes status pending.

When the subchannel becomes status pending as a result of performing the halt function, data transfer, if any, with the associated device has been terminated. The SCSW stored when the resulting status is cleared by TEST SUBCHANNEL has the halt-function bit stored as one. If the halt signal was issued to the device, the halt-pending bit is stored as zero. Otherwise, the halt-pending bit is stored as one, and other indications are provided that describe in greater detail the condition that was encountered. (See “Interruption-Response Block” on page 6, and “Halt Function” on page 16.)

On some models, path availability is tested as part of the halt function instead of as part of the execution of the instruction. In these models, when no channel path is available for selection, the halt signal is not issued, and the subchannel is made status pending. When the status-pending condition is subsequently cleared by TEST SUBCHANNEL, the halt-pending bit is stored as one in the SCSW.

If a status-pending condition is eliminated during the execution of HALT SUBCHANNEL, then this condition is reestablished along with the other status conditions when the completion of the halt function is indicated to the program.

The halt-pending condition may not be recognized by the channel subsystem if a status-pending condition has been generated. This situation could occur, for example, when alert status is presented or generated while the subchannel is already start pending or resume pending, or when primary status is presented during the attempt to initiate the I/O operation for the first command as specified by the start function or implied by the resume function. If recognition of the status-pending condition by the channel subsystem has occurred logically prior to recognition of the halt-pending condition, the SCSW, when cleared by TEST SUBCHANNEL, has the halt-pending bit stored as one.
If measurement data is being accumulated when a start function is terminated by HALT SUBCHANNEL, the measurement data continues to be accumulated for the subchannel and reflects the extent of subchannel and device usage required, if any, while performing the currently terminated start function. The measurement data, if any, is accumulated in the measurement block for the subchannel or placed in the extended-status word, as appropriate, when the subchannel becomes status-pending with primary or secondary status. (See “Channel-Subsystem Monitoring” on page 1.)

Special Conditions

**Condition code 1** is set, and no other action is taken, when the subchannel is status pending alone or is status pending with any combination of alert, primary, or secondary status.

**Condition code 2** is set, and no other action is taken, when the subchannel is busy for HALT SUBCHANNEL. The subchannel is busy for HALT SUBCHANNEL when a halt function or clear function is already in progress at the subchannel.

**Condition code 3** is set, and no other action is taken, when the subchannel is not operational for HALT SUBCHANNEL. A subchannel is not operational for HALT SUBCHANNEL when the subchannel is not provided in the channel subsystem, has no valid device number assigned to it, or is not enabled. On some models, a subchannel is also not operational for HALT SUBCHANNEL when no channel path is available for selection by the device. (See “Channel-Path Availability” on page 13 for a description of channel paths that are available for selection.)

HALT SUBCHANNEL can encounter the program exceptions described or listed below.

When the multiple-subchannel-set facility is not installed, bits 32-47 of general register 1 must contain 0001 hex; otherwise, an operand exception is recognized.

When the multiple-subchannel-set facility is installed, bits 32-44 of general register 1 must contain zeros, bits 45-46 must contain a valid value, and bit 47 must contain the value one; otherwise, an operand exception is recognized.

**Resulting Condition Code:**

0   Function initiated
1   Status pending with other than intermediate status
2   Busy
3   Not operational

**Program Exceptions:**

- Operand
- Privileged operation
- Transaction constraint

**Programming Note:** After the execution of HALT SUBCHANNEL, the status-pending condition indicating the completion of the halt function may be delayed for an extended period of time, for example, when the device is a magnetic-tape unit executing a rewind command.

**MODIFY SUBCHANNEL**

The information contained in the subchannel-information block (SCHIB) is placed in the program-modifiable fields at the subchannel. As a result, the program influences, for that subchannel, certain aspects of I/O processing relative to the clear, halt, resume, and start functions and certain I/O support functions.

General register 1 contains a subsystem-identification word (SID) that designates the subchannel that is to be modified as specified by certain fields of the SCHIB. The second-operand address is the logical address of the SCHIB and must be designated on a word boundary; otherwise, a specification exception is recognized.

The channel-subsystem operations that may be influenced due to placement of SCHIB information in the subchannel are:

- I/O processing (E field)
- Interruption processing (interruption parameter and ISC field)
- Path management (D, LPM, and POM fields)
• Monitoring and address-limit checking (measurement-block index, LM, and MM fields)
• Measurement-block-format control (F field)
• Extended-measurement-word-mode enable (X field)
• Concurrent-sense facility (S field)
• Measurement-block address (MBA)

Bits 0, 1, 6, and 7 of word 1, and bits 0-28 of word 6 of the SCHIB operand must be zeros, and bits 9 and 10 of word 1 must not both be ones. When the extended-I/O-measurement-block facility is installed and a format-1 measurement block is specified, bits 26-31 of word 11 must be specified as zeros. When the extended-I/O-measurement-block facility is not installed, bit 29 of word 6 must be specified as zero; otherwise, an operand exception is recognized. When the extended-I/O-measurement-word facility is not installed, or is installed but not enabled, bit 30 of word 6 must be specified as zero; otherwise, an operand exception is recognized.

Condition code 0 is set to indicate that the information from the SCHIB has been placed in the program-modifiable fields at the subchannel, except that, when the device-number-valid bit (V) at the designated subchannel is zero, then condition code 0 is set, and the information from the SCHIB is not placed in the program-modifiable fields.

Special Conditions

Condition code 1 is set, and no other action is taken, when the subchannel is status pending. (See “Status Control (SC)” on page 17.)

Condition code 2 is set, and no other action is taken, when a clear, halt, or start function is in progress at the subchannel. (See “Function Control (FC)” on page 13.)

Condition code 3 is set, and no other action is taken, when the subchannel is not operational for MODIFY SUBCHANNEL. A subchannel is not operational for MODIFY SUBCHANNEL when the subchannel is not provided in the channel subsystem.

In word 1 of the SCHIB, bits 0, 1, 6, and 7 must be zeros and, when the address-limit-checking facility is installed, bits 9 and 10 must not both be ones. In word 6 of the SCHIB, bits 0-28 must be zeros. Otherwise an operand exception is recognized.

When the extended-I/O-measurement-block facility is installed and a format-1 measurement block is specified, bits 26-31 of word 11 must be specified as zeros; otherwise, an operand exception is recognized. When the extended-I/O-measurement-block facility is not installed, bit 29 of word 6 must be specified as zero; otherwise, an operand exception is recognized. When the extended-I/O-measurement-word facility is not installed, or is installed but not enabled, bit 30 of word 6 must be specified as zero; otherwise, an operand exception is recognized.

When the multiple-subchannel-set facility is not installed, bits 32-47 of general register 1 must contain 0001 hex; otherwise, an operand exception is recognized.

When the multiple-subchannel-set facility is installed, bits 32-44 of general register 1 must contain zeros, bits 45-46 must contain a valid value, and bit 47 must contain the value one; otherwise, an operand exception is recognized.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

The execution of MODIFY SUBCHANNEL is suppressed on all addressing and protection exceptions.

Resulting Condition Code:

0 Function completed
1 Status pending
2 Busy
3 Not operational

Program Exceptions:

• Access (fetch, operand 2)
• Operand
• Privileged operation
• Specification
• Transaction constraint
Programming Notes:

1. If a device signals I/O-error alert while the associated subchannel is disabled, the channel subsystem issues the clear signal to the device and discards the I/O-error-alert indication without generating an I/O-interruption condition.

2. If a device presents unsolicited status while the associated subchannel is disabled, that status is discarded by the channel subsystem without generating an I/O-interruption condition. However, if the status presented contains unit check, the channel subsystem issues the clear signal for the associated subchannel and does not generate an I/O-interruption condition. This should be taken into account when the program uses MODIFY SUBCHANNEL to enable a subchannel. For example, the medium on the associated device that was present when the subchannel became disabled may have been replaced, and, therefore, the program should verify the integrity of that medium.

3. It is recommended that the program inspect the contents of the subchannel by subsequently issuing STORE SUBCHANNEL when MODIFY SUBCHANNEL sets condition code 0. Use of STORE SUBCHANNEL is a method for determining if the designated subchannel was changed or not. Failure to inspect the subchannel following the setting of condition code 0 by MODIFY SUBCHANNEL may result in conditions that the program does not expect to occur.

RESET CHANNEL PATH

RCHP [S]

'b23b' / / / / / / / / / / / / / / /
0 16 31

The channel-path-reset facility is signaled to perform the channel-path-reset function on the channel path designated by the contents of general register 1.

The format of general register 1 is as follows:

Channel-Path Identifier (CHPID): Bit positions 56-63 of general register 1 contain an unsigned binary integer that designates the channel path on which the channel-path-reset function is to be performed.

Bit positions in general register 1 that are shown as zeros, are reserved and must contain zeros; otherwise, an operand exception is recognized. Bit positions 0-31 of general register 1 are ignored.

If conditions allow, the channel-path-reset facility is signaled to asynchronously perform the channel-path-reset function on the designated channel path. The channel-path-reset function is summarized below in the section “Associated Functions” and is described in detail in “Channel-Path Reset” on page 13.

Condition code 0 is set to indicate that the channel-path-reset facility has been signaled.

Associated Functions

Subsequent to the execution of RESET CHANNEL PATH, the channel-path-reset facility asynchronously performs the channel-path-reset function. Certain indications are reset at all subchannels that have access to the designated channel path, and the reset signal is issued on that channel path. Any I/O functions in progress at the devices are reset, but only for the channel path on which the reset signal is received. An I/O operation or chain of I/O operations taking place in the multipath mode may be able to continue to be executed on other channel paths in the multipath group, if any. (See “Channel-Path-Reset Function” on page 80.)

The result of performing the channel-path-reset function on the designated channel path is communicated to the program by means of a channel report (see “Channel Report” on page 24).
Special Conditions

Condition code 2 is set, and no other action is taken, when, on some models, the channel-path-reset facility is busy performing the channel-path-reset function for a previous execution of the RESET CHANNEL PATH instruction.

Condition code 3 is set, and no other action is taken, when, on some models, the designated channel path is not operational for the execution of RESET CHANNEL PATH. On these models, the channel path is not operational for the execution of RESET CHANNEL PATH when the designated channel path is not physically available.

If the channel-path-reset facility is busy and the designated channel path is not physically available, it depends on the model whether condition code 2 or 3 is set.

RESET CHANNEL PATH can encounter the program exceptions described or listed below.

Bit positions 32-55 of general register 1 must contain zeros; otherwise, an operand exception is recognized. Bit positions 0-31 of general register 1 are ignored.

Resulting Condition Code:

0 Function initiated
1 —
2 Not operational
3 Not operational

Program Exceptions:

- Operand
- Privileged operation
- Transaction constraint

Programming Notes:

1. To eliminate the possibility of a data-integrity exposure for devices that have the capability of generating unsolicited device-end status, I/O operations in progress with such devices on the channel path for which RESET CHANNEL PATH is to be executed must be terminated by the execution of either HALT SUBCHANNEL or CLEAR SUBCHANNEL. Otherwise, subsequent to receiving the reset signal, the device may present an unsolicited device end that may be interpreted by the channel subsystem as a solicited device end and cause command chaining to occur.

2. If the status-verification facility is being used and RESET CHANNEL PATH is executed without first stopping all ongoing operations associated with the channel path being reset, erroneous device-status-check conditions may be detected

RESUME SUBCHANNEL

RSCH [S]

The channel subsystem is signaled to perform the resume function at the designated subchannel.

General register 1 contains a subsystem-identification word that designates the subchannel at which the resume function is to be performed.

The subchannel is made resume pending.

Logically prior to the setting of condition code 0 and only if the subchannel is currently in the suspended state, path-not-operational conditions at the subchannel, if any, are cleared.

The channel subsystem is signaled to asynchronously perform the resume function. The resume function is summarized below in the section “Associated Functions” and is described in detail in “Start Function and Resume Function” on page 20.

Condition code 0 is set to indicate that the actions described above have been taken.

Associated Functions

Subsequent to the execution of RESUME SUBCHANNEL, the channel subsystem asynchronously performs the resume function. Except when the subchannel is subchannel active, if the execution of RESUME SUBCHANNEL results in the setting of condition code 0, performance of the resume function causes execution of a currently suspended channel program to be resumed with the associated device, provided that the suspend flag for the current CCW has been set to zero by the program. If the suspend flag remains one, execution of the channel pro-
gram remains suspended. But, if the subchannel is subchannel active at the time the execution of RESUME SUBCHANNEL results in the setting of condition code 0, then it is unpredictable whether execution of the current program is resumed or whether it is found by the resume function that the subchannel has become suspended in the interim. The subchannel is found to be suspended by the resume function only if the subchannel is status pending with intermediate status when the resume-pending condition is recognized by the channel sub-system. (See “Start Function and Resume Function” on page 20.)

Special Conditions

**Condition code 1** is set, and no other action is taken, when the subchannel is status pending.

**Condition code 2** is set, and no other action is taken, when the resume function is not applicable. The resume function is not applicable when the subchannel (1) has any function other than the start function alone specified, (2) has no function specified, (3) is resume pending, or (4) does not have suspend control specified for the start function in progress.

**Condition code 3** is set, and no other action is taken, when the subchannel is not operational for the resume function. A subchannel is not operational for the resume function if the subchannel is not provided in the channel subsystem, has no valid device number assigned to it, or is not enabled.

RESUME SUBCHANNEL can encounter the program exceptions described or listed below.

When the multiple-subchannel-set facility is not installed, bits 32-47 of general register 1 must contain 0001 hex; otherwise, an operand exception is recognized.

When the multiple-subchannel-set facility is installed, bits 32-44 of general register 1 must contain zeros, bits 45-46 must contain a valid value, and bit 47 must contain the value one; otherwise, an operand exception is recognized.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Function initiated</td>
</tr>
<tr>
<td>1</td>
<td>Status pending</td>
</tr>
<tr>
<td>2</td>
<td>Function not applicable</td>
</tr>
<tr>
<td>3</td>
<td>Not operational</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Operand
- Privileged operation
- Transaction constraint

**Programming Notes:**

1. When channel-program execution is resumed from the suspended state, the device views the resumption as the beginning of a new chain of commands. When the suspension of channel-program execution occurs and the device requires that certain commands be first or appear only once in a chain of commands (for example, direct-access-storage devices), the program must ensure that the appropriate commands in the proper sequence are fetched by the channel subsystem after channel-program execution is resumed. One way the program can ensure proper sequencing of commands at the device is by allowing the I/O interruption to occur for an intermediate interruption condition due to suspension.

   It is not reliable to notify the program that the subchannel is suspended by using the PCI flag in the CCW that contains the S flag because the PCI I/O interruption may occur before the subchannel is suspended. The SCSW would indicate that an I/O operation is in progress at the subchannel and device in this case.

   The suspend flag of the target CCW should be set to zero before RESUME SUBCHANNEL is executed; otherwise, it is possible that the resume-pending condition may be recognized and the CCW refetched while the suspend flag is still one, in which case the resume-pending condition would be reset, and the execution of the channel program would be suspended. If the suspend flag of the target CCW is set to zero before the execution of RESUME SUBCHANNEL, the channel program is not suspended, provided that the subchannel is not subchannel active at the time the execution of RESUME SUBCHANNEL results in the setting of condition
code 0. If condition code 0 is set while the subchannel is still subchannel active, it is unpredictable whether the resume-pending condition is recognized by the channel subsystem or whether it is found by the resume function that the subchannel has become suspended in the interim. The subchannel is found to be suspended by the resume function only if the subchannel is status pending with intermediate status at the time the resume-pending condition is recognized. When the subchannel is suspended, the execution of TEST SUBCHANNEL, which clears the intermediate interruption condition, also clears the indication of resume pending.

2. Some models recognize a resume-pending condition only after a CCW having an S flag validly set to one is fetched. Therefore, if a subchannel is resume pending and, during the execution of the channel program, no CCW is fetched having an S flag validly set to one, the subchannel remains resume pending until the primary interruption condition is cleared by TEST SUBCHANNEL.

3. Path availability is not tested during the execution of RESUME SUBCHANNEL. Instead, path availability is tested when the channel subsystem begins performance of the resume function.

4. The contents of the CCW fetched during performance of the resume function may be different from the contents of the same CCW when it was previously fetched and contained an S flag validly set to one.

**SET ADDRESS LIMIT**

```
SAL "B237" //////////////////////////////////////////////////////////
0 16 31
```

The address-limit-checking facility is signaled to use the specified address as the address-limit value, and the specified address is passed to the facility. Depending on the model, this instruction may not be provided. When this instruction is not provided, it is checked for operand exception and privileged-operation exception, and then is suppressed.

When the address-limit-checking facility is installed, or the FCX facility is installed, the SET ADDRESS LIMIT instruction is not provided.

General register 1 contains the absolute address to be used as the address-limit value. The specified address must be on a 64K-byte boundary and may designate a maximum absolute storage address of 2,147,418,112 (7FFF0000 hex) regardless of whether the CPU is operating in the 24-bit, 31-bit, or 64-bit addressing mode. Bits 0-31 of general register 1 are ignored, and bit 32 must be zero.

General register 1 has the following format:

```
0 ////////////////////////////////////////////////////////// 31
0 Address-Limit Value
32 ////////////////////////////////////////////////////////// 63
```

Associated Functions

The value that is used by the address-limit-checking facility when determining whether to permit or prohibit a data access is called the address-limit value. The initial address-limit value is zero. The initial address-limit value is used by the address-limit-checking facility until the facility recognizes a signal, caused by the execution of SET ADDRESS LIMIT, to use a specified address. The recognition of this specified address as the new address-limit value occurs asynchronously with respect to the execution of SET ADDRESS LIMIT.

If address-limit checking is specified for a subchannel, then whether the specified address is used by the address-limit-checking facility, when determining whether to permit or prohibit a data access, depends on whether SET ADDRESS LIMIT was executed before, during, or after the execution of START SUBCHANNEL for that subchannel. If SET ADDRESS LIMIT is executed before START SUBCHANNEL, the specified address is used by the address-limit-checking facility. If SET ADDRESS LIMIT is executed during or after the execution of START SUBCHANNEL, it is unpredictable whether the specified address is used by the address-limit-checking facility for that particular start function. For a description of the manner in which address-limit checking is performed, see “Address-Limit Checking” on page 22.
Special Conditions

SET ADDRESS LIMIT can encounter the program exceptions described or listed below.

The address in general register 1 must be designated on a 64K byte boundary, and bit 32 of general register 1 must be zero; otherwise, an operand exception is recognized.

Condition Code: The code remains unchanged.

Program Exceptions:

- Operand
- Privileged operation
- Transaction constraint

SET CHANNEL MONITOR

SCHM [S]

Each of the measurement-block-update mode and device-connect-time-measurement mode of the channel subsystem is made either active or inactive, depending on the values of the measurement-mode-control bits in general register 1. If the measurement-mode-control bit for measurement-block update is one, the measurement-block origin and measurement-block key are passed to the channel subsystem.

General register 1 has the following format:

```
| 0 | 1 | MBK | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|   |   |     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
```

Ignored: Bit positions 0-31 of general register 1 are ignored.

Measurement-Block Key (MBK): Bit positions 32-35 of general register 1 contain the measurement-block key. When bit 62 is one, MBK specifies the access key that is to be used by the channel subsystem when it accesses the measurement-block area and, when the extended-I/O-measurement-block facility is installed, to access format-1 measurement blocks. Otherwise, MBK is ignored.

Measurement-Block-Update Control (M): Bit 62 of general register 1 is the measurement-mode-control bit that controls the measurement-block-update mode. When bit 62 of general register 1 is one and conditions allow, the measurement-block-update facility is signaled to asynchronously make the measurement-block-update mode active. In addition, the measurement-block-origin (MBO) address in general register 2 and the measurement-block key (MBK) in general register 1 are passed to the measurement-block-update facility.

The measurement-block origin is used to determine the location of format-0 measurement blocks; the address of format-1 measurement blocks is stored at the subchannel using MODIFY SUBCHANNEL. The measurement-block key is used to access both format-0 and format-1 measurement blocks. The asynchronous functions that are performed by the measurement-block-update facility are summarized below in the section “Associated Functions” and are described in detail in “Channel-Subsystem Monitoring” on page 1.

When bit 62 of general register 1 is zero and conditions allow, the measurement-block-update mode is made inactive if it is active or remains inactive if it is inactive. The contents of bit positions 32-35 (MBK) of general register 1 and the contents of general register 2 are ignored.

Device-Connect-Time-Measurement Control (D): Bit 63 of general register 1 is the measurement-mode-control bit (D). When bit 63 is one and conditions allow, the device-connect-time-measurement mode is made active if it is inactive or remains active if it is active. When bit 63 is zero and conditions allow, the device-connect-time-measurement mode is made inactive if it is active or remains inactive if it is inactive.

Bit positions 36-61 of general register 1 are reserved and must contain zeros; otherwise, an operand exception is recognized.

General register 2 has the following format:
**SET CHANNEL MONITOR**

**Measurement-Block-Origin (MBO) Address:**
When bit 62 (M) of general register 1 is one, bit positions 0-63 of general register 2 contain the absolute address of the measurement-block origin (MBO), which is the beginning of the measurement-block area. The MBO address is used by the channel subsystem to locate format-0 measurement blocks. The origin of the measurement-block area must be designated on a 32-byte boundary otherwise, an operand exception is recognized. When bit 62 of general register 1 is zero, the contents of general register 2 are ignored.

If the channel-subsystem timer that is used by the channel-subsystem-monitoring facilities is in the error state, the state is reset. This happens independent of the setting of the two measurement-mode-control bits. (See “Channel-Subsystem Timing” on page 2 for a description of the timing facilities.)

**Associated Functions**

When the measurement-block-update facility is signaled (by means of SET CHANNEL MONITOR) to make the measurement-block-update mode active, the functions that are performed by the facility depend on whether or not the mode is already active when the signal is generated.

If the measurement-block-update mode is inactive when the signal is generated, the mode remains inactive until the measurement-block-update facility recognizes the signal. When the measurement-block-update facility recognizes the signal, the measurement-block-update mode is made active, and the MBK that was passed when the signal was generated is used to access all measurement blocks, and the MBO that was passed when the signal was generated is used to determine the address of format-0 measurement blocks.

If the measurement-block-update mode is active when the signal is generated, the mode remains active, and the MBK and MBO associated with the execution of a previous SET CHANNEL MONITOR instruction continue to be used to control the storing of measurement data until the measurement-block-update facility recognizes the signal. When the measurement-block-update facility recognizes the signal, the MBK and MBO associated with that signal are used instead of the MBK and MBO associated with the execution of a previous SET CHANNEL MONITOR instruction. The SET CHANNEL MONITOR instruction does not affect the measurement-block address used for format-1 measurement blocks, but the MBK associated with the signal becomes the key used to access the measurement block.

In all above cases, the measurement-block-update facility recognizes the signal during, or subsequent to, the execution of the SET CHANNEL MONITOR instruction that caused the signal to be generated and logically prior to the performance of any start function that is initiated by the subsequent execution of START SUBCHANNEL for a subchannel that is enabled for measurement by this facility. If a subchannel that is enabled for measurement by this facility already has a start function in progress when the signal is generated, it is unpredictable when measurement data for that subchannel is stored by using the MBK and MBO associated with that signal.

While the measurement-block-update mode is active, performance measurements are accumulated for subchannels that are enabled for measurement-block update. Measurements for a subchannel are either accumulated in a single 32-byte format-0 measurement block within the measurement-block area, or a 64-byte format-1 measurement block pointed to by the measurement-block address at the subchannel. A subchannel is enabled for the measurement-block-update mode by setting the measurement-block-update-enable bit to one in the SCHIB and then executing the MODIFY SUBCHANNEL instruction for that subchannel. The measurement-block-format-control bit (F) at the subchannel specifies whether a format-0 or format-1 measurement block is stored for a subchannel when the measurement-block-update mode is active and the subchannel is enabled for measurement-block updates. When the F bit is zero, the MBO and MBI are used to determine the address of format-0 measurement blocks. When the F bit is one, the measurement-block-address field at the subchannel contains the address of the measurement block for the subchannel, and a format-1 measurement block is stored. The F bit and measurement-block-address field are modified using the MODIFY SUBCHANNEL instruction.

When the device-connect-time-measurement mode is active, measurements of the length of time that the
device is actively communicating with the channel subsystem during the execution of a channel program are accumulated for subchannels that are enabled for device-connect-time measurement. Measurements for a subchannel are provided in the extended-status word ESW of the IRB. A subchannel is enabled for device-connect-time-measurement mode by setting the device-connect-time-measurement-enable bit to one in the SCHIB and then executing MODIFY SUBCHANNEL for that subchannel.

For a more detailed description of the measurement-block-update mode, the format and contents of the measurement block, and the device-connect-time-measurement mode, see “Channel-Subsystem Monitoring” on page 1.

Special Conditions

SET CHANNEL MONITOR can encounter the program exceptions described or listed below.

Bits 36-61 of general register 1 must be zeros. When bit 62 (M) of general register 1 is one, the MBO address in general register 2 must be designated on a 32-byte boundary. Otherwise, an operand exception is recognized.

Condition Code: The code remains unchanged.

Program Exceptions:

- Operand
- Privileged operation
- Transaction constraint

Programming Note: When the channel subsystem is initialized, the measurement-block-update and device-connect-time-measurement modes are made inactive.

START SUBCHANNEL

<table>
<thead>
<tr>
<th>SSCH</th>
<th>D2(B2)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>\textbf{B233}</td>
<td>B2</td>
<td>D2</td>
</tr>
</tbody>
</table>

The channel subsystem is signaled to asynchronously perform the start function for the associated device, and the execution parameters that are contained in the designated ORB are placed at the designated subchannel. (See “Operation-Request Block” on page 24.)

General register 1 contains a subsystem-identification word that designates the subchannel to be started. The second-operand address is the logical address of the ORB and must be designated on a word boundary; otherwise, a specification exception is recognized.

The execution parameters contained in the ORB are placed at the subchannel.

When START SUBCHANNEL is executed, the subchannel is status pending with only secondary status, and the extended-status-word-format bit (L) is zero, the status-pending condition is discarded at the subchannel.

The subchannel is made start pending, and the start function is indicated at the subchannel. If the second operand designates a command-mode ORB, the subchannel remains in command mode. If the second operand designates a transport-mode ORB, the subchannel enters transport mode. When the subchannel enters transport mode, the LPUM is set to zero if no previous dedicated allegiance exists; otherwise the LPUM is not changed.

Logically prior to the setting of condition code 0, path-not-operational conditions at the subchannel, if any, are cleared.

The channel subsystem is signaled to asynchronously perform the start function. The start function is summarized below in the section “Associated Functions” and is described in detail in “Start Function and Resume Function” on page 20.

Condition code 0 is set to indicate that the actions described above have been taken.

Associated Functions

Subsequent to the execution of START SUBCHANNEL, the channel subsystem asynchronously performs the start function.

The contents of the ORB, other than the fields that must contain all zeros, are checked for validity. On some models, the fields of the ORB that must contain zeros are checked asynchronously, instead of during the execution of the instruction. When invalid fields are detected asynchronously, the subchannel
and alert status and with deferred condition code 1 and program check indicated. (See “Program Check” on page 25.) In this situation, the I/O operation or chain of I/O operations is not initiated at the device, and the condition is indicated by the start-pending bit being stored as one when the SCSW is cleared by the execution of TEST SUBCHANNEL. (See “Sub-channel-Status Word” on page 7).

On some models, path availability is tested asynchronously, instead of during the execution of the instruction. When no channel path is available for selection, the subchannel becomes status pending with primary and secondary status and with deferred condition code 3 indicated. The I/O operation or chain of I/O operations is not initiated at the device, and this condition is indicated by the start-pending bit being stored as one when the SCSW is cleared by the execution of TEST SUBCHANNEL.

If conditions allow, a channel path is chosen, and execution of the channel program that is designated in the ORB is initiated. (See “Start Function and Resume Function” on page 20.)

Special Conditions

**Condition code 1** is set, and no other action is taken, when the subchannel is status pending when START SUBCHANNEL is executed. On some models, condition code 1 is not set when the subchannel is status pending with only secondary status; instead, the status-pending condition is discarded.

**Condition code 2** is set, and no other action is taken, when a start, halt, or clear function is currently in progress at the subchannel (see “Function Control (FC)” on page 13).

**Condition code 3** is set, and no other action is taken, when the subchannel is not operational for START SUBCHANNEL. A subchannel is not operational for START SUBCHANNEL if the subchannel is not provided in the channel subsystem, has no valid device number associated with it, or is not enabled.

A subchannel is also not operational for START SUBCHANNEL, on some models, when no channel path is available for selection. On these models, the lack of an available channel path is detected as part of the START SUBCHANNEL execution. On other models, channel-path availability is only tested as part of the asynchronous start function.

START SUBCHANNEL can encounter the program exceptions described or listed below.

In word 1 of the command-mode ORB, bits 26-30 must be zeros, and, in word 2 of the command-mode ORB, bit 0 must be zero. Otherwise, on some models, an operand exception is recognized. On other models, an I/O-interruption condition is generated, indicating program check, as part of the asynchronous start function.

START SUBCHANNEL can also encounter the program exceptions listed below.

When the multiple-subchannel-set facility is not installed, bits 32-47 of general register 1 must contain 0001 hex; otherwise, an operand exception is recognized.

When the multiple-subchannel-set facility is installed, bits 32-44 of general register 1 must contain zeros, bits 45-46 must contain a valid value, and bit 47 must contain the value one; otherwise, an operand exception is recognized.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

The execution of START SUBCHANNEL is suppressed on all addressing and protection exceptions.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Function initiated</td>
</tr>
<tr>
<td>1</td>
<td>Status pending</td>
</tr>
<tr>
<td>2</td>
<td>Busy</td>
</tr>
<tr>
<td>3</td>
<td>Not operational</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operand 2)
- Operand
- Privileged operation
- Specification
- Transaction constraint

**STORE CHANNEL PATH STATUS**

<table>
<thead>
<tr>
<th>STCPS</th>
<th>D&lt;sub&gt;2&lt;/sub&gt;(B&lt;sub&gt;2&lt;/sub&gt;)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B23A'</td>
<td>B&lt;sub&gt;2&lt;/sub&gt;</td>
<td>D&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>
Depending on the model, this instruction may not be provided. When this instruction is not provided, it is checked for privileged operation exception and the instruction is suppressed by the machine.

A channel-path-status word of up to 256 bits is stored at the designated location.

The second-operand address is the logical address of the location where the channel-path-status word is to be stored and must be designated on a 32-byte boundary; otherwise, a specification exception is recognized.

The channel-path-status word indicates which channel paths are actively communicating with a device at the time STORE CHANNEL PATH STATUS is executed. Bit positions 0-255 correspond, respectively, to the channel paths having the channel-path identifiers 0-255. Each of the 256 bits at the designated location is set to one, set to zero, or left unchanged, as follows:

- For all channel paths in the configuration that are actively communicating with devices at the time STORE CHANNEL PATH STATUS is executed, the corresponding bits are stored as ones.
- For all channel paths that are (1) provided in the system (PIM bit in the PMCW is one) and (2) in the configuration but not currently being used by the channel subsystem in actively communicating with devices, the corresponding bits are stored as zeros.
- For all channel paths that are not provided in the system (PIM bit in the PMCW is zero), the corresponding bits either are not stored or are stored as zeros.
- For all channel paths in the configuration that are in the channel-path-terminal state or are not physically available (the corresponding PAM bit in the PMCW is zero), the corresponding bits are stored as zeros.

Special Conditions

STORE CHANNEL PATH STATUS can encounter the program exceptions described or listed below.

The second operand must be designated on a 32-byte boundary; otherwise, a specification exception is recognized.

The execution of STORE CHANNEL PATH STATUS is suppressed on all addressing and protection exceptions.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Privileged operation
- Specification
- Transaction constraint

**Programming Notes:**

1. To ensure a consistent interpretation of channel-path-status-word bits, the program should, prior to the initial use of the area, store zeros at the location where the channel-path-status word is to be stored.

**STORE CHANNEL REPORT WORD**

A CRW containing information affecting the channel subsystem is stored at the designated location.

The second-operand address is the logical address of the location where the CRW is to be stored and must be designated on a word boundary; otherwise, a specification exception is recognized.

When a malfunction or other condition affecting channel-subsystem operation is recognized, a channel report (consisting of one or more CRWs) describing the condition is made pending for retrieval and analysis by the program. The channel report contains information concerning the identity and state of a facility following the detection of the malfunction or other condition. For a description of the channel report, the CRW, and program-recovery actions related to the channel subsystem, see “Channel-Subsystem Recovery” on page 24.

When one or more channel reports are pending, the instruction causes a CRW to be stored at the designated location and condition code 0 to be set. A pending CRW can only be stored by the execution of STORE CHANNEL REPORT WORD and, once
STORE SUBCHANNEL

STORE SUBCHANNEL

STSCH D_{j(B_2)} [S]

Control and status information for the designated subchannel is stored in the designated SCHIB.

General register 1 contains a subsystem-identification word that designates the subchannel for which the information is to be stored. The second-operand address is the logical address of the SCHIB and must be designated on a word boundary; otherwise, a specification exception is recognized.

When the extended-I/O-measurement-block facility is not installed, the information that is stored in the SCHIB consists of a path-management-control word, a SCSW, and three words of model-dependent information. When the extended-I/O-measurement-block facility is installed, the information that is stored in the SCHIB consists of a path-management-control word, a SCSW, the measurement-block-address field, and one word of model-dependent information. (See “Subchannel-Information Block” on page 2.)

The execution of STORE SUBCHANNEL does not change any information at the subchannel.

Condition code 0 is set to indicate that control and status information for the designated subchannel has been stored in the SCHIB. When the execution of STORE SUBCHANNEL results in the setting of condition code 0, the information in the SCHIB indicates a consistent state of the subchannel.

Special Conditions

Condition code 3 is set, and no other action is taken, when the designated subchannel is not operational for STORE SUBCHANNEL. A subchannel is not operational for STORE SUBCHANNEL if the subchannel is not provided in the channel subsystem.

STORE SUBCHANNEL can encounter the program exceptions described or listed below.

When the multiple-subchannel-set facility is not installed, bits 32-47 of general register 1 must contain 0001 hex; otherwise, an operand exception is recognized.

1. CRW overflow conditions may occur if STORE CHANNEL REPORT WORD is not executed to clear pending channel reports. If the overflow condition is encountered, one or more channel-report words have been lost. (See “Channel-Subsystem Recovery” on page 24 for details.)

2. A pending CRW can be cleared by any CPU in the configuration executing STORE CHANNEL REPORT WORD, regardless of whether a machine-check interruption has occurred in any CPU.

Special Conditions

STORE SUBCHANNEL REPORT WORD can encounter the program exceptions described or listed below.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

The execution of STORE SUBCHANNEL REPORT WORD is suppressed on all addressing and protection exceptions.

Resulting Condition Code:

0  CRW stored
1  Zeros stored
2  —
3  —

Program Exceptions:

• Access (store, operand 2)
• Privileged operation
• Specification
• Transaction constraint

Programming Notes:

1. CRW overflow conditions may occur if STORE CHANNEL REPORT WORD is not executed to clear pending channel reports. Thus, each pending CRW is presented only once to the program.

When no channel reports are pending in the channel subsystem execution of STORE CHANNEL REPORT WORD causes zeros to be stored at the designated location and condition code 1 to be set.

Special Conditions

STORE SUBCHANNEL REPORT WORD can encounter the program exceptions described or listed below.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

The execution of STORE CHANNEL REPORT WORD is suppressed on all addressing and protection exceptions.

Resulting Condition Code:

0  CRW stored
1  Zeros stored
2  —
3  —

Program Exceptions:

• Access (store, operand 2)
• Privileged operation
• Specification
• Transaction constraint

Programming Notes:

1. CRW overflow conditions may occur if STORE CHANNEL REPORT WORD is not executed to clear pending channel reports. Thus, each pending CRW is presented only once to the program.

When no channel reports are pending in the channel subsystem execution of STORE CHANNEL REPORT WORD causes zeros to be stored at the designated location and condition code 1 to be set.

Special Conditions

STORE SUBCHANNEL REPORT WORD can encounter the program exceptions described or listed below.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

The execution of STORE CHANNEL REPORT WORD is suppressed on all addressing and protection exceptions.

Resulting Condition Code:

0  CRW stored
1  Zeros stored
2  —
3  —

Program Exceptions:

• Access (store, operand 2)
• Privileged operation
• Specification
• Transaction constraint

Programming Notes:

1. CRW overflow conditions may occur if STORE CHANNEL REPORT WORD is not executed to clear pending channel reports. Thus, each pending CRW is presented only once to the program.

When no channel reports are pending in the channel subsystem execution of STORE CHANNEL REPORT WORD causes zeros to be stored at the designated location and condition code 1 to be set.
When the multiple-subchannel-set facility is installed, bits 32-44 of general register 1 must contain zeros, bits 45-46 must contain a valid value, and bit 47 must contain the value one; otherwise, an operand exception is recognized.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SCHIB stored</td>
</tr>
<tr>
<td>1</td>
<td>—</td>
</tr>
<tr>
<td>2</td>
<td>—</td>
</tr>
<tr>
<td>3</td>
<td>Not operational</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (store, operand 2)
- Operand
- Privileged operation
- Specification
- Transaction constraint

**Programming Notes:**

1. Device status that is stored in the SCSW may include device-busy, control-unit-busy, or control-unit-end indications.

2. The information that is stored in the SCHIB is obtained from the subchannel. The STORE SUBCHANNEL instruction does not cause the channel subsystem to interrogate the addressed device.

3. STORE SUBCHANNEL may be executed at any time to sample conditions existing at the subchannel, without causing any pending status conditions to be cleared.

4. Repeated execution of STORE SUBCHANNEL without an intervening delay (for example, to determine when a subchannel changes state) should be avoided because repeated accesses of the subchannel by the CPU may delay or prohibit access of the subchannel by a channel subsystem to update the subchannel.

---

**TEST PENDING INTERRUPTION**

<table>
<thead>
<tr>
<th>TPI</th>
<th>D(B2)</th>
<th>[S]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'B236'</td>
<td>B2</td>
<td>D2</td>
</tr>
</tbody>
</table>

0  | 16  | 20  | 31  |

The I/O-interruption code for a pending I/O interruption at a subchannel is stored at the location designated by the second-operand address, and the pending I/O-interruption request is cleared.

The second-operand address, when nonzero, is the logical address of the location where the two-word I/O-interruption code, consisting of words 0 and 1, is to be stored. The second-operand address must be designated on a word boundary; otherwise, a specification exception is recognized.

If the second-operand address is zero, the three-word I/O-interruption code, consisting of words 0-2, is stored at real locations 184-195. In this case, low-address protection and key-controlled protection do not apply.

In the access-register mode when the second-operand address is zero, it is unpredictable whether access-register translation occurs for access register B2. If the translation occurs, the resulting address-space-control element is not used; that is, the interruption code still is stored at real locations 184-195.

Pending I/O-interruption requests are accepted only for those I/O-interruption subclasses allowed by the I/O-interruption-subclass mask in control register 6 of the CPU executing the instruction. If no I/O-interruption requests exist that are allowed by control register 6, the I/O-interruption code is not stored, the second-operand location is not modified, and condition code 0 is set.

If a pending I/O-interruption request is accepted, the I/O-interruption code is stored, the pending I/O-interruption request is cleared, and condition code 1 is set. The I/O-interruption code that is stored is the same as would be stored if an I/O interruption had occurred. However, PSWs are not swapped as when an I/O-interruption occurs.
The I/O-interruption code that is stored during the execution of the instruction is defined as follows:

<table>
<thead>
<tr>
<th>Word</th>
<th>Subsystem-Identification Word</th>
<th>Interruption Parameter</th>
<th>Interruption-Identification Word</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>31</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Subsystem-Identification Word (SID):
Bits 32-63 of the SID are placed in word 0.

See “I/O-Instruction Formats” in Chapter 14.

Interruption Parameter: Word 1 contains a four-byte parameter that was specified by the program and passed to the subchannel in word 0 of the ORB or the PMCW. When a device presents alert status and the interruption parameter was not previously passed to the subchannel by an execution of START SUBCHANNEL or MODIFY SUBCHANNEL, this field contains zeros.

Interruption-Identification Word: Word 2, when stored, contains the interruption-identification word, which further identifies the source of the I/O-interruption. Word 2 is stored only when the second-operand address is zero.

The interruption-identification word is defined as follows:

A bit (A)Bit 0 of the interruption-identification word specifies the type of pending I/O-interruption request that was cleared. When bit 0 is zero, the I/O-interruption request was associated with a subchannel.

I/O-Interruption Subclass (ISC): Bit positions 2-4 of the interruption-identification word contain an unsigned binary integer, in the range 0-7, that specifies the I/O-interruption subclass associated with the subchannel for which the pending I/O-interruption request was cleared.

The remaining bit positions are reserved and stored as zeros.

Reserved: Bits 8-14 and 15-31 of word 0 and all of word 1 are reserved and stored as zeros.

Special Conditions

TEST PENDING INTERRUPTION can encounter the program exceptions described or listed below.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

The execution of TEST PENDING INTERRUPTION is suppressed on all addressing and protection exceptions.

Resulting Condition Code:

<table>
<thead>
<tr>
<th></th>
<th>Interruption code not stored</th>
<th>Interruption code stored</th>
<th>—</th>
<th>—</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Program Exceptions:

- Access (store, operand 2, second-operand address nonzero only)
- Privileged operation
- Specification
- Transaction constraint

Programming Notes:

1. TEST PENDING INTERRUPTION should only be executed with a second-operand address of zero when I/O interruptions are masked off. Otherwise, an I/O-interruption code stored by the instruction may be lost if an I/O interruption occurs. The I/O-interruption code that identifies the source of an I/O interruption taken subsequent to TEST PENDING INTERRUPTION is also stored at real locations 184-195, replacing an I/O-interruption code that was stored by the instruction.

2. In the access-register mode when the second-operand address is zero, an access exception is recognized if access-register translation occurs and the access register is in error. This exception can be prevented by making the B2 field zero or by placing 00000000 hex, 00000001 hex, or any other valid contents in the access register.
Control and status information for the subchannel is stored in the designated IRB.

General register 1 contains a subsystem-identification word that designates the subchannel for which the information is to be stored. The second-operator address is the logical address of the IRB and must be designated on a word boundary; otherwise, a specification exception is recognized.

The information that is stored in the IRB consists of a SCSW, an extended-status word, and an extended-control word. (See “Interruption-Response Block” on page 6.)

If the subchannel is status pending, the status-pending bit of the status-control field is stored as one. Whether or not the subchannel is status pending has an effect on the functions that are performed when TEST SUBCHANNEL is executed.

When the subchannel is status pending and TEST SUBCHANNEL is executed, information, as described above, is stored in the IRB, followed by the clearing of certain conditions and indications that exist at the subchannel as described in Figure 14-2 on page 21. If the subchannel is in transport mode, the clearing of these conditions, specifically the start function, places the subchannel in command mode. (See Figure 14-2 on page 21. If an I/O-interruption request is pending for the subchannel, the request is cleared. Condition code 0 is set to indicate that these actions have been taken.

When the subchannel is not status pending and TEST SUBCHANNEL is executed, information (as described above) is stored in the IRB, and no conditions or indications are cleared. Condition code 1 is set to indicate that these actions have been taken.

Figure 14-2 on page 21 describes which conditions and indications are cleared by TEST SUBCHANNEL when the subchannel is status pending. All other conditions and indications at the subchannel remain unchanged.

<table>
<thead>
<tr>
<th>Field</th>
<th>Alert Status Pending</th>
<th>Int Status Pending</th>
<th>Pri Status Pending</th>
<th>Sec. Status Pending</th>
<th>Status Pending Alone</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>CM</td>
<td>TM</td>
<td>CM</td>
<td>TM</td>
<td>CM</td>
</tr>
<tr>
<td>Function Control</td>
<td>C</td>
<td>C</td>
<td>Nc</td>
<td>TM</td>
<td>C</td>
</tr>
<tr>
<td>Activity Control</td>
<td>Cp</td>
<td>Cp</td>
<td>Nr</td>
<td>Nm</td>
<td>Cp</td>
</tr>
<tr>
<td>Status Control</td>
<td>Cs</td>
<td>Cs</td>
<td>Cs</td>
<td>C</td>
<td>Cs</td>
</tr>
<tr>
<td>N Condition</td>
<td>C</td>
<td>C</td>
<td>Nr</td>
<td>Nm</td>
<td>C</td>
</tr>
<tr>
<td>Q Condition</td>
<td>–</td>
<td>C</td>
<td>–</td>
<td>C</td>
<td>–</td>
</tr>
</tbody>
</table>

Explanation:

– N/A.

CM  Command-Mode Operation
TM  Transport-Mode Operation

* Note that the rightmost column applies to status pending when it is alone. The other four status-pending conditions result in the clearing actions given. These actions apply both when a single status-pending condition occurs and when a combination of the four status-pending conditions occurs. In the combination case, all the clearing actions of the individual cases apply.

C  Cleared.
Nm  Not reset or modified by TEST SUBCHANNEL.
Cp  The resume-, start-, halt-, clear pending, and suspended conditions are cleared.
Cs  The status-pending condition is cleared.
Nc  Not changed unless function control indicates the halt function and activity control indicates suspended. If both the halt function and suspended are indicated, conditions are cleared as for status pending alone.
Nr  Not changed unless activity control indicates suspended and function control indicates the start function with or without the halt function. If the halt function is indicated, the conditions are cleared as for status pending alone. If only the start function is indicated, the resume-pending condition and the N condition are cleared.

Note: The clearing of certain subchannel conditions, places the subchannel in command mode. A subchannel in the idle state, or with the function control bits zero is considered to be in command-mode.

Figure 14-2. Conditions and Indications Cleared at the Subchannel by TEST SUBCHANNEL

Special Conditions

Condition code 3 is set, and no other action is taken, when the subchannel is not operational for TEST SUBCHANNEL. A subchannel is not operational for TEST SUBCHANNEL if the subchannel is...
not provided, has no valid device number associated with it, or is not enabled.

TEST SUBCHANNEL can encounter the program exceptions described or listed below.

When the multiple-subchannel-set facility is not installed, bits 32-47 of general register 1 must contain 00001 hex; otherwise, an operand exception is recognized.

When the multiple-subchannel-set facility is installed, bits 32-44 of general register 1 must contain zeros, bits 45-46 must contain a valid value, and bit 47 must contain the value one; otherwise, an operand exception is recognized.

The second operand must be designated on a word boundary; otherwise, a specification exception is recognized.

When the execution of TEST SUBCHANNEL is terminated on addressing and protection exceptions, the state of the subchannel is not changed.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>IRB stored; subchannel status pending</td>
</tr>
<tr>
<td>1</td>
<td>IRB stored; subchannel not status pending</td>
</tr>
<tr>
<td>2</td>
<td>—</td>
</tr>
<tr>
<td>3</td>
<td>Not operational</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (store, operand 2)
- Operand
- Privileged operation
- Specification

The priority of recognition of program exceptions for the instruction is shown in Figure 14-3.

1.-7 Exceptions with the same priority as the priority of program-interruption conditions for the general case.

8.A Specification exception due to the address specified by the second operand not being on a word boundary.

8.B Access exceptions for an access to the subchannel-status-word, extended-status-word, and extended-control-word sections of the IRB designated by the second operand.

8.C Operand exception due to an invalid field in the subsystem-identification word specified in register 1.

8.D Access exceptions for an access to the extended-measurement-word section of the IRB designated by the second operand when the extended-I/O-measurement-word mode is enabled at the designated subchannel.

**Programming Notes:**

1. Device status that is stored in the SCSW may include device-busy, control-unit-busy, or control-unit-end indications.

2. The information that is stored in the IRB is obtained from the subchannel. The TEST SUBCHANNEL instruction does not cause the channel subsystem to interrogate the addressed device.

3. When an I/O interruption occurs, it is the result of a status-pending condition at the subchannel, and typically TEST SUBCHANNEL is executed to clear the status. TEST SUBCHANNEL may also be executed at any other time to sample conditions existing at the subchannel.

4. Repeated execution of TEST SUBCHANNEL to determine when a start function has been completed should be avoided because there are conditions under which the completion of the start function may or may not be indicated. For example, if the channel subsystem is holding an interface-control-check (IFCC) condition in abeyance (for any subchannel) because another subchannel is already status pending, and if the start function being tested by TEST SUBCHANNEL has as the only path available for selection the channel path with the IFCC condition, then the start function may not be initiated until the status-pending condition in the other subchannel is cleared, allowing the IFCC condition to be indicated at the subchannel to which it applies.

5. Repeated execution of TEST SUBCHANNEL without an intervening delay, for example, to determine when a subchannel changes state,
should be avoided because repeated accesses of the subchannel by the CPU may delay or prohibit accessing of the subchannel by the channel subsystem. Execution of TEST SUBCHANNEL by multiple CPUs for the same subchannel at approximately the same time may have the same effect and also should be avoided.

6. The priority of I/O-interruption handling by a CPU can be modified by the execution of TEST SUBCHANNEL. When TEST SUBCHANNEL is executed and the designated subchannel has an I/O-interruption request pending, that I/O-interruption request is cleared, and the SCSW is stored, without regard to any previously established priority. The relative priority of the remaining I/O-interruption requests is unchanged.
Chapter 15. Basic I/O Functions

Some I/O instructions specify to the channel subsystem that a function is to be performed. Collectively, these functions are referred to as the basic I/O functions. The basic I/O functions are the clear, halt, resume, and channel-path-reset functions.
performed. This information is communicated to the program in the subchannel-information block during the execution of STORE SUBCHANNEL.

**Subchannel-Information Block**

The subchannel-information block (SCHIB) is the operand of the MODIFY SUBCHANNEL and STORE SUBCHANNEL instructions. The two rightmost bits of the SCHIB address are zeros, designating the SCHIB on a word boundary. The SCHIB contains three major fields: the path-management-control word (PMCW), the subchannel-status word (SCSW), and a model-dependent area. When the extended-I/O-measurement-block facility is installed the SCHIB also contains the measurement-block-address field. (Figure 15-1 on page 2 shows the format of the PMCW, and Figure 16-3 on page 8 shows the format of the command-mode SCSW and Figure 16-8 on page 34 shows the format of the transport-mode SCSW.)

STORE SUBCHANNEL is used to store the current PMCW, the SCSW, model-dependent data, and, when the extended-I/O-measurement-block facility is installed, the measurement-block-address field, for the designated subchannel. MODIFY SUBCHANNEL alters certain PMCW fields and, when the extended-I/O-measurement-block facility is installed, the measurement-block address in the subchannel. When the program needs to change the contents of one or more of the PMCW fields, the normal procedure is to (1) issue STORE SUBCHANNEL to obtain the current contents, (2) perform the required modifications to the PMCW field or the measurement-block-address field in main storage, and (3) issue MODIFY SUBCHANNEL to pass the new information to the subchannel. The SCHIB has the following format:

**Word**

<table>
<thead>
<tr>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Path-Management-Control Word</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>8</td>
<td>9</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td></td>
</tr>
<tr>
<td><strong>Subchannel-Status Word</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
<td>19</td>
</tr>
<tr>
<td><strong>Model-Dependent Area /</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Measurement-Block Address</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>21</td>
<td>22</td>
<td>23</td>
<td>24</td>
<td>25</td>
<td>26</td>
</tr>
<tr>
<td><strong>Model-Dependent Area</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Path-Management-Control Word**

Words 0-6 of the SCHIB contain the path-management-control word (PMCW). The PMCW has the format shown in Figure 15-1 on page 2 when the subchannel is valid (see “Device Number Valid (V)” on page 4).

The format of the PMCW is as follows:

**Word**

<table>
<thead>
<tr>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Interuption Parameter</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>8</td>
<td>9</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
</tr>
<tr>
<td>LM</td>
<td>MM</td>
<td>DT</td>
<td>V</td>
<td>P</td>
<td>E</td>
<td>D</td>
</tr>
<tr>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
<td>19</td>
<td>20</td>
</tr>
<tr>
<td>LPM</td>
<td>PNOM</td>
<td>LPUM</td>
<td>PIM</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>22</td>
<td>23</td>
<td>24</td>
<td>25</td>
<td>26</td>
<td>27</td>
</tr>
<tr>
<td>MBI</td>
<td>POM</td>
<td>PAM</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>29</td>
<td>30</td>
<td>31</td>
<td>0</td>
<td>1</td>
<td>2</td>
</tr>
<tr>
<td>CHPID-0</td>
<td>CHPID-1</td>
<td>CHPID-2</td>
<td>CHPID-3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>33</td>
<td>34</td>
<td>35</td>
<td>0</td>
<td>1</td>
<td>2</td>
</tr>
<tr>
<td>CHPID-4</td>
<td>CHPID-5</td>
<td>CHPID-6</td>
<td>CHPID-7</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>36</td>
<td>37</td>
<td>38</td>
<td>39</td>
<td>40</td>
<td>41</td>
<td>42</td>
</tr>
<tr>
<td>00000000000000000000000000000FXS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 15-1. PMCW Format

**Interruption Parameter:** Bit positions 0-31 of word 0 contain the interruption parameter that is stored as word 1 of the interruption code. The interruption parameter can be set to any value by START SUBCHANNEL and MODIFY SUBCHANNEL. The initial value of the interruption parameter is zero.

**I/O-Interruption-Subclass Code (ISC):** Bits 2-4 of word 1 are an unsigned binary integer, in the range 0-7, that corresponds to the bit position of the I/O-
interruption subclass-mask bit in control register 6 of each CPU in the configuration. The setting of that mask bit in control register 6 of a CPU controls the recognition of interruption requests relating to this subchannel by that CPU (see “Priority of Interruptions” on page 5). The ISC can be set to any value by MODIFY SUBCHANNEL. The initial value of the ISC is zero.

**Reserved:** Bits 0, 1, and 5-7 of word 1 are reserved and stored as zeros by STORE SUBCHANNEL. Bits 0, 1, 6, and 7 must be zeros when MODIFY SUBCHANNEL is executed; otherwise, an operand exception is recognized. Bit 5 of word 1 is ignored when MODIFY SUBCHANNEL is executed.

**Enabled (E):** Bit 8 of word 1, when one, indicates that the subchannel is enabled for all I/O functions. When the E bit is zero, status presented by the device is not made available to the program, and I/O instructions other than MODIFY SUBCHANNEL and STORE SUBCHANNEL that are executed for the designated subchannel cause condition code 3 to be set. The E bit can be either zero or one when MODIFY SUBCHANNEL is executed; initially, all subchannels are not enabled; IPL causes the IPL I/O device to become enabled.

**Limit Mode (LM):** When the address-limit-checking facility is installed, bits 9 and 10 of word 1 define the limit mode (LM) of the subchannel. The limit mode is used by the channel subsystem when address-limit checking is invoked for an I/O operation. (See “Address-Limit Checking” on page 22.) Address-limit checking is under the control of the address-limit-checking-control bit that is passed to the subchannel in the operation-request block (ORB) during the execution of START SUBCHANNEL. (See “Address-Limit-Checking Control (A)” on page 27.)

The definitions of the LM bits, whose values are used during data transfer, are as follows:

<table>
<thead>
<tr>
<th>Bit 9</th>
<th>Bit 10</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Initialized value. No limit checking is performed for this subchannel.</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Data address must be equal to or greater than the current address limit.</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Data address must be less than the current address limit.</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

Bit positions 9 and 10 can contain any of the first three bit combinations shown above when MODIFY SUBCHANNEL is executed. Specification of the reserved bit combination in the operand causes an operand exception to be recognized when MODIFY SUBCHANNEL is executed.

When the address-limit-checking facility is not installed, bits 9-10 of word 1 may be set as described above; however, they are ignored and are not set at the specified subchannel. When bits 9-10 are not specified as described above and MODIFY SUBCHANNEL is executed, an operand exception is recognized.

**Measurement-Mode Enable (MM):** Bits 11 and 12 of word 1 enable the measurement-block-update mode and the device-connect-time-measurement mode, respectively, of the subchannel. These bits can have any value when MODIFY SUBCHANNEL is executed; initially, neither measurement mode is
enabled. The definition of each of these bits is as follows:

**Bit 11 Measurement-Block-Update Enable:**

- 0: Initialized value. The subchannel is not enabled for measurement-block update. Storing of measurement-block data does not occur.
- 1: The subchannel is enabled for measurement-block update. If the measurement-block-update mode is active, measurement data is accumulated in the measurement block at the time channel-program execution is completed or suspended at the subchannel or completed at the device, as appropriate, provided no error conditions described by subchannel logout have been detected. (See "Measurement-Block Update" on page 2.) If the measurement-block-update mode is inactive, no measurement-block data is stored.

**Bit 12 Device-Connect-Time-Measurement Enable:**

- 0: Initialized value. The subchannel is not enabled for device-connect-time measurement. Storing of the device-connect-time interval (DCTI) in the extended-status word (ESW) does not occur.
- 1: The subchannel is enabled for device-connect-time measurement. If the device-connect-time-measurement mode is active and timing facilities are provided for the subchannel, the value of the DCTI is stored in the ESW when TEST SUBCHANNEL is executed after channel-program execution is completed or suspended at the subchannel, provided no error conditions described by subchannel logout have been detected. If the device-connect-time-measurement mode is inactive, no measurement values are stored in the ESW.

The meaning of the measurement-mode-enable bits (MM), described above, applies when the timing-facility bit for the subchannel is one. When the timing-facility bit is zero, the effect of the MM bits is changed, as described below under “Timing Facility (T)” on page 4. (For more discussion on measurement modes, see “Measurement-Block Update” on page 2 and “Device-Connect-Time Measurement” on page 10.)

**Multipath Mode (D):** Bit 13 of word 1, when one, indicates that the subchannel operates in the multipath mode when performing an I/O operation or chain of I/O operations. For proper operation in the multipath mode when more than one channel path is available for selection, the associated device must have the dynamic-reconnection feature installed and must be set up for multipath-mode operation. During performance of a start function in the multipath mode, a device is allowed to request service from the channel subsystem over any of the channel paths indicated at the subchannel as being available for selection (see “Logical-Path Mask (LPM)” on page 5 and “Path-Available Mask (PAM)” on page 7). Bit 13, when zero, indicates that the subchannel operates in single-path mode when performing an I/O operation or chain of I/O operations. In the single-path mode, the entire start function is performed by using the channel path on which the first command of the I/O operation or chain of I/O operations was accepted by the device. The D bit can be either zero or one when MODIFY SUBCHANNEL is executed; initially, the subchannel is in the single-path mode.

**Timing Facility (T):** Bit 14 of word 1, when one, indicates that the channel-subsystem-timing facility is available for the subchannel and is under the control of the two measurement-mode-enable bits (MM) and SET CHANNEL MONITOR. Bit 14, when zero, indicates that the channel-subsystem-timing facility is not available for the subchannel. When bit 14 is zero, the START SUBCHANNEL count is the only measurement data that can be accumulated in the measurement block for the subchannel. Storing of the START SUBCHANNEL count is under the control of bit 11 and SET CHANNEL MONITOR, as described above under “Measurement-Mode Enable (MM)” on page 3. Similarly, if the T bit is zero, no device-connect-time-interval (DCTI) values can be measured for the subchannel. (See “Measurement-Block Update” on page 2 and “Device-Connect-Time Measurement” on page 10.)

**Device Number Valid (V):** Bit 15 of word 1, when one, indicates that the device-number field (see below) contains a valid device number and that a device associated with this subchannel may be physically installed. Bit 15, when zero, indicates that the subchannel is not valid, there is no I/O device currently associated with the subchannel, and the contents of all other defined fields of the SCHIB are
**Device Number:** Bit positions 16-31 of word 1 contain the binary representation of the four-digit hexadecimal device number of the device that is associated with this subchannel. The device number is a system-unique parameter that is assigned to the subchannel and the associated device when the device is installed.

**Logical-Path Mask (LPM):** Bits 0-7 of word 2 indicate the logical availability of channel paths to the associated device. Each bit of the LPM corresponds one-for-one, by relative bit position, with a CHPID located in an associated byte of words 4 and 5 of the SCHIB. A bit set to one means that the corresponding channel path is logically available; a zero means the corresponding channel path is logically not available. When a channel path is logically not available, the channel subsystem does not use that channel path to initiate performance of any clear, halt, resume, or start function, except when a dedicated allegiance exists for that channel path. When a dedicated allegiance exists at the subchannel for a channel path, the logical availability of the channel path is ignored whenever a clear, halt, resume, or start function is performed. (See “Channel-Path Allegiance” on page 12). If the subchannel is idle, the logical availability of the channel path is ignored whenever the control unit initiates a request to present alert status to the channel subsystem. The logical availability of a channel path associated with the subchannel can be changed by setting the corresponding LPM bit in the SCHIB and then issuing MODIFY SUBCHANNEL, or by setting the corresponding LPM bit in the ORB and then issuing START SUBCHANNEL. Initially, each installed channel path is logically available.

**Path-Not-Operational Mask (PNOM):** Any of bits 8-15 of word 2, when one, indicates that a path-not-operational condition has been recognized on the corresponding channel path. Each bit of the PNOM corresponds one-for-one, by relative bit position, with a CHPID located in an associated byte of words 4 and 5 of the SCHIB. The channel subsystem recognizes a path-not-operational condition when, during an attempted device selection in order to perform a clear, halt, resume, or start function, the device associated with the subchannel appears not operational on a channel path that is operational for the subchannel. When a path-not-operational condition is recognized, the state of the channel path changes from operational for the subchannel to not operational for the subchannel. A channel path is operational for the subchannel if the associated device appeared operational on that channel path the last time the channel subsystem attempted device selection in order to perform a clear, halt, resume, or start function. A device appears to be operational on a channel path when the device responds to an attempted device selection. A channel path is not operational for the subchannel if the associated device appeared not operational on that channel path the last time the channel subsystem attempted device selection in order to perform a clear, halt, resume, or start function. Any of bits 8-15 of word 2, when zero, indicates that a path-not-operational condition has not been recognized on the corresponding channel path.

Initially, each of the eight possible channel paths associated with each subchannel is considered to be operational, regardless of whether the respective channel paths are installed or available; therefore, unless a path-not-operational condition is recognized during initial program loading, the PMCW, if stored, contains a PNOM of all zeros if stored prior to the execution of a CLEAR SUBCHANNEL, HALT SUBCHANNEL, RESUME SUBCHANNEL, or START SUBCHANNEL instruction.

**Programming Note:** The PNOM indicates those channel paths for which a path-not-operational condition has been recognized during the performance of the most recent clear, halt, resume, or start function. That is, the PNOM indicates which of the channel paths associated with the subchannel have made a transition from the operational to the not-operational state for the subchannel during the performance of the most recent clear, halt, resume, or start function. However, the transition of a channel path from the not-operational to the operational state for the subchannel is indicated in the POM. Therefore, the POM must be examined in order to determine whether any of the channel paths that are associated with a designated subchannel are operational for the subchannel.

Furthermore, while performing either a start function or a resume function, the transition of a channel path from the not-operational to the operational state for the subchannel is recognized by the channel subsystem only during the initiation sequence for the first command specified by the start function or implied by the resume function. Therefore, a channel path that is currently not operational for the subchannel can be used by the device associated with the subchannel when reconnecting to the channel subsystem in order to continue command chaining; however, the channel subsystem does not indicate a transition of
that channel path from the not-operational to the operational state for the subchannel in the POM.

<table>
<thead>
<tr>
<th>POM Value and Device State before Selection Attempt</th>
<th>Value of Specified Bit Subsequent to Selection Attempt</th>
<th>SCSW N Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Device State 1</td>
<td>POM</td>
<td>POM</td>
</tr>
<tr>
<td>OP</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>NOP</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>OP</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>NOP</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**Explanation:**

1. Device state as it appears on the corresponding channel path.
2. Prior to the attempted device selection during the performance of either a start function or a resume function while the subchannel is suspended, the channel subsystem clears all existing path-not-operational conditions, if any, at the designated subchannel.
3. The N bit (bit 15 of word 0 of the SCSW) is indicated to the program and the N condition is cleared at the subchannel when TEST SUBCHANNEL is executed the next time the subchannel is status pending for other than intermediate status alone provided that it is not also suspended.

**Last-Path-Used Mask (LPUM):** Bits 16-23 of word 2 indicate the channel path that was last used for communicating or transferring information between the channel subsystem and the device. Each bit of the LPUM corresponds one-for-one, by relative bit position, with a CHPID located in an associated byte of words 4 and 5 of the SCHIB.

For a subchannel operating in command mode, each bit of the LPUM is stored as zero, except for the bit that corresponds to the channel path last used, whenever one of the following occurs:

1. The first command of a start or resume function is accepted by the device (see “Activity Control (AC)” on page 14).

2. The device and channel subsystem are actively communicating when the suspend function is performed for the channel program in execution.

3. Status has been accepted from the device and is recognized as an interruption condition, or a condition has been recognized that suppresses command chaining (see “Interruption Conditions” on page 2).

4. An interface-control-check condition has been recognized (see “Interface-Control Check” on page 29), and no subchannel-logout information is currently present in the subchannel.

For a subchannel operating in transport mode, each bit of the LPUM is stored as zero, except for the bit that corresponds to the channel path last used, whenever one of the following occurs:

1. The path has been selected for transporting the TCCB for the operation.

2. Status has been accepted from the device and is recognized as an interruption condition. If the accepted status is an interrogate response, the LPUM may be different than that stored with primary or secondary status or both.

3. An interface-control-check has been recognized and no subchannel-logout information is currently present in the subchannel.

The LPUM field of the PMCW contains the most recent setting. For transport-mode operations the LPUM in the subchannel is set to zeros when the start function is set and no dedicated-allegiance condition exists for the subchannel.

**Path-Installed Mask (PIM):** Bits 24-31 of word 2 indicate which of the channel paths 0-7 to the I/O device are physically installed. The PIM indicates the validity of the channel-path identifiers (see below) for those channel paths that are physically installed. Each bit of the PIM corresponds one-for-one, by relative bit position, with a CHPID located in an associated byte of words 4 and 5 of the SCHIB. A PIM bit stored as one indicates that the corresponding channel path is installed. A PIM bit stored as zero indicates that the corresponding channel path is not installed. The PIM always reflects the full complement of installed paths to the device, regardless of how the system is configured. Therefore, some of the channel paths indicated in the PIM may not be physically available in that configuration, as indicated by the bit settings in the path-available mask (see below). The initial value of the PIM indicates all the physically installed channel paths to the device.

**Measurement-Block Index (MBI):** Bits 0-15 of word 3 form an index value used by the measure-
ment-block-update facility when the measurement-block-update mode is active (see “SET CHANNEL MONITOR” on page 13.) and the subchannel is enabled for the mode (see “Measurement-Mode Enable (MM)” on page 3).

When the measurement-block index is used, five zero bits are appended on the right, and the result is added to the measurement-block-origin address designated by SET CHANNEL MONITOR. The calculated address, called the measurement-block address, designates the beginning of a 32-byte storage area where measurement data is stored. (See “Measurement Block” on page 3.) The MBI can contain any value when MODIFY SUBCHANNEL is executed; the initial value is zero.

Programming Note: The measurement-block-origin address specified by SET CHANNEL MONITOR is used as the origin address for the measurement blocks for subchannels in all subchannel sets available to the program. However, the two-byte measurement-block-index field is capable of supporting a maximum of 65,536 unique MBI values. It is the responsibility of the program to coordinate use of the measurement-block index among subchannels and subchannel sets.

Path-Operational Mask (POM): Bits 16-23 of word 3 indicate the last known operational state of the device on the corresponding channel paths. Each bit of the POM corresponds one-for-one, by relative bit position, with a CHPID located in an associated byte of words 4 and 5 of the SCHIB. If the associated device appeared operational on a channel path the last time the channel subsystem attempted device selection in order to perform a clear, halt, resume, or start function, then the channel path is operational for the subchannel, and the bit corresponding to the channel path in the POM is one. A device appears to be operational on a channel path when the device responds to an attempted device selection. A channel path is also operational for the subchannel if MODIFY SUBCHANNEL is executed and the bit corresponding to that channel path in the POM is specified as zero.

If the device associated with the subchannel appears not operational on a channel path that is operational for the subchannel during an attempted device selection in order to perform a clear, halt, resume, or start function, then the channel subsystem recognizes a path-not-operational condition. When a path-not-operational condition is recognized, the state of the channel path changes from operational for the subchannel to not operational for the subchannel.

Programming Note: The measurement-block-origin address specified by SET CHANNEL MONITOR is used as the origin address for the measurement blocks for subchannels in all subchannel sets available to the program. However, the two-byte measurement-block-index field is capable of supporting a maximum of 65,536 unique MBI values. It is the responsibility of the program to coordinate use of the measurement-block index among subchannels and subchannel sets.

Path-Operational Mask (POM): Bits 16-23 of word 3 indicate the last known operational state of the device on the corresponding channel paths. Each bit of the POM corresponds one-for-one, by relative bit position, with a CHPID located in an associated byte of words 4 and 5 of the SCHIB. If the associated device appeared operational on a channel path the last time the channel subsystem attempted device selection in order to perform a clear, halt, resume, or start function, then the channel path is operational for the subchannel, and the bit corresponding to the channel path in the POM is one. A device appears to be operational on a channel path when the device responds to an attempted device selection. A channel path is also operational for the subchannel if MODIFY SUBCHANNEL is executed and the bit corresponding to that channel path in the POM is specified as zero.

If the device associated with the subchannel appears not operational on a channel path that is operational for the subchannel during an attempted device selection in order to perform a clear, halt, resume, or start function, then the channel subsystem recognizes a path-not-operational condition. When a path-not-operational condition is recognized, the state of the channel path changes from operational for the subchannel to not operational for the subchannel.

When the channel path is not operational for the subchannel, a path-not-operational condition cannot be recognized. Moreover, a channel path that is not operational for the subchannel may be available for selection; if the channel subsystem chooses that channel path while performing a path-management operation, and if, during the attempted device selection, the device appears to be operational again on that channel path, then the state of the channel path changes from not operational for the subchannel to operational for the subchannel.

The POM can contain any value when MODIFY SUBCHANNEL is executed. Initially, each of the eight possible channel paths associated with each subchannel is considered to be operational, regardless of whether the respective channel paths are installed or available; therefore, unless a path-not-operational condition is recognized during initial program loading, the PMCW, if stored, contains a POM of all ones if stored prior to the execution of a CLEAR SUBCHANNEL, HALT SUBCHANNEL, RESUME SUBCHANNEL, or START SUBCHANNEL instruction.

Path-Available Mask (PAM): Bits 24-31 of word 3 indicate the physical availability of installed channel paths. Each bit of the PAM corresponds one-for-one, by relative bit position, with a CHPID located in an associated byte of words 4 and 5 of the SCHIB. A PAM bit of one indicates that the corresponding channel path is physically available for use in accessing the device. A PAM bit of zero indicates that the channel path is not physically available for use in accessing the device. When a channel path is not physically available, it may, depending on the model and the extent of failure, be used during performance of the reset-channel-path function. A channel path that is physically available may become not physi-
cally available as a result of reconfiguring the system, or this may occur as a result of the performance of the channel-path-reset function. The initial value of the PAM reflects the set of channel paths by which the I/O device is physically accessible at the time of initialization.

Note: The change in the availability of a channel path affects all subchannels having access to that channel path. Whenever the setting of a PAM bit is referred to in conjunction with the availability status of a channel path, for brevity, reference is made in this chapter to a single PAM bit instead of to the respective PAM bits in all of the affected subchannels.

Channel-Path Identifiers (CHPIDs): Words 4 and 5 contain eight one-byte channel-path identifiers corresponding to channel paths 0-7 of the PIM. A CHPID is valid if the corresponding PIM bit is one. Each valid CHPID contains the identifier of a physical channel path to a control unit by which the associated I/O device may be accessed. A unique CHPID is assigned to each physical channel path in the system.

Different devices that are accessible by the same physical channel path have, in their respective subchannels, the same CHPID value. The CHPID value may, however, appear in each subchannel in different locations in the CHPID fields 0-7.

Subchannels that share an identical set of channel paths have the same corresponding PIM bits set to ones. The channel-path identifiers (CHPIDs) for these channel paths are the same and occupy the same respective locations in each SCHIB.

Reserved: Bits 0-28 of word 6 are reserved and are stored as zeros by STORE SUBCHANNEL. They must be zeros when MODIFY SUBCHANNEL is executed; otherwise, an operand exception may be recognized.

Measurement Block Format Control (F): When the extended-I/O-measurement-block facility is installed, bit 29 of word 6 specifies the format of the measurement block to be stored when the subchannel is enabled for the measurement-block-update mode, and measurement-block-update mode is active. The bit can contain any value when MODIFY SUBCHANNEL is executed. The initial value is zero. The definition of the bit is as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Measurement-Block-Format Control:</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Format-0 measurement block. Specifies that a format-0 measurement block is used when performing a measurement-block update for the subchannel. The address of the 32-byte measurement block is obtained using the MBI provided by MSCH in conjunction with the MBO provided by SCHM.</td>
</tr>
<tr>
<td>1</td>
<td>Format-1 measurement block. Specifies that a format-1 measurement block is used when performing a measurement-block update for the subchannel. The address of the 64-byte format-1 measurement block is provided by MSCH.</td>
</tr>
</tbody>
</table>

If the extended-measurement-block facility is not installed, bit 29 of word 6 of the SCHIB operand must be zero when MODIFY SUBCHANNEL is executed; otherwise, an operand exception is recognized.

Extended Measurement Word Mode Enable (X): When the extended-measurement-word facility is installed and enabled, bit 30 of word 6 enables the extended-measurement-word mode for the subchannel. Initially, the extended-measurement-word mode is not enabled. The definition of the bit is as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Measurement-Block-Word-Mode Enable:</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Initialized value. The subchannel is not enabled for extended-measurement-word mode. Storing of the extended-measurement word does not occur.</td>
</tr>
<tr>
<td>1</td>
<td>The subchannel is enabled for extended-measurement-word mode. Measurement data is stored in the extended-measurement word at the time channel-program execution is completed or suspended at the subchannel or completed at the device, as appropriate, provided no error conditions described by subchannel logout have been detected.</td>
</tr>
</tbody>
</table>

If the extended-measurement-word facility is not installed, or is installed but is not enabled, bit 30 of word 6 of the SCHIB operand must be zero when
MODIFY SUBCHANNEL is executed; otherwise, an operand exception is recognized.

**Concurrent Sense (S):** Bit 31 of word 6, when one, indicates that the subchannel is in the concurrent-sense mode. When the subchannel is in command mode and concurrent-sense mode, whenever the subchannel becomes status pending with alert status, and the status byte accepted from the device contains the unit-check indication, then the channel subsystem may attempt to retrieve sense information from the associated device and place that sense information in the extended-control word.

When the subchannel is operating in transport mode, any available sense information is provided in the TSB regardless of the setting of bit 31 of word 6.

If the concurrent-sense facility is not installed, bit 31 of word 6 of the SCHIB operand must be zero when MODIFY SUBCHANNEL is executed; otherwise, an operand exception is recognized.

**Subchannel-Status Word**
Words 7-9 of the SCHIB contain a copy of the SCSW. The format of the SCSW is described in “Subchannel-Status Word” on page 7. The SCSW is stored by the execution of either STORE SUBCHANNEL or TEST SUBCHANNEL (see “STORE SUBCHANNEL” on page 18 and “TEST SUBCHANNEL” on page 21).

**Model-Dependent Area/Measurement Block Address**
When the extended-I/O-measurement-block facility is not installed, words 10-12 of the SCHIB contain model-dependent information.

When the extended-I/O-measurement-block facility is installed, words 10-11 are defined as the measurement-block-address field. Word 12 contains model-dependent information.

When (1) the measurement-block-update mode is active (see “SET CHANNEL MONITOR” on page 13), (2) the subchannel is enabled for the mode (see “Measurement-Mode Enable (MM)” on page 3), and (3) the format-1-measurement block is specified (see “Measurement Block Format Control (F)” on page 8) at the subchannel, the measurement-block-address field contains the absolute storage address of the measurement block used by the measurement-block-update facility. The measurement-block address designates the beginning of a 64-byte storage area and must be designated on 64-byte boundary. The initial value of the measurement block address is zero.
Summary of Modifiable Fields

*Figure 15-3 on page 10 lists the initial settings for fields in a subchannel whose device-number-valid bit is one and indicates what modifies the fields.

All of the PMCW fields contain meaningful information when STORE SUBCHANNEL is executed and the designated subchannel is idle. Subchannel fields that the channel subsystem does not modify contain valid information whenever STORE SUBCHANNEL is executed, provided that the device-number-valid bit is one. The validity of the subchannel fields that are modifiable by the channel subsystem depends on the state of the subchannel at the time STORE SUBCHANNEL is executed.

<table>
<thead>
<tr>
<th>Subchannel Field</th>
<th>Initial Value</th>
<th>Program Modifies by Executing</th>
<th>Modified by Channel Subsystem</th>
</tr>
</thead>
<tbody>
<tr>
<td>Interruption parameter</td>
<td>Zeros</td>
<td>MSCH, SSCH</td>
<td>No</td>
</tr>
<tr>
<td>I/O-interruption-subclass code</td>
<td>Zeros</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Enabled (E)</td>
<td>Zero</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Limit mode (LM)</td>
<td>Zeros</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Measurement mode (MM)</td>
<td>Zeros</td>
<td>MSCH</td>
<td>Yes³</td>
</tr>
<tr>
<td>Multipath mode (D)</td>
<td>Zero</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Timing facility (T)</td>
<td>Installed value⁴</td>
<td>None</td>
<td>No</td>
</tr>
<tr>
<td>Device number valid (V)</td>
<td>Installed value⁴</td>
<td>None</td>
<td>No</td>
</tr>
<tr>
<td>Device number</td>
<td>Installed value⁴</td>
<td>None</td>
<td>No</td>
</tr>
<tr>
<td>Logical-path mask (LPM)</td>
<td>Path-installed-mask value</td>
<td>MSCH, SSCH</td>
<td>No</td>
</tr>
<tr>
<td>Path-not-operational mask (PNOM)</td>
<td>Zeros</td>
<td>CSCH, SSCH, RSCH⁵</td>
<td>Yes</td>
</tr>
<tr>
<td>Last-path-used mask (LPUM)</td>
<td>Zeros</td>
<td>CSCH</td>
<td>Yes</td>
</tr>
<tr>
<td>Path-installed mask (PIM)</td>
<td>Installed value⁴</td>
<td>None</td>
<td>No</td>
</tr>
<tr>
<td>Measurement-block index (MBI)</td>
<td>Zeros</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Path-operational mask (POM)</td>
<td>Ones</td>
<td>CSCH, MSCH, RSCH⁵</td>
<td>Yes</td>
</tr>
<tr>
<td>Path-available mask (PAM)</td>
<td>Installed values⁴,⁶</td>
<td>None</td>
<td>Yes⁵</td>
</tr>
<tr>
<td>Channel-path ID 0-7</td>
<td>Installed value⁴</td>
<td>None</td>
<td>No</td>
</tr>
<tr>
<td>Concurrent sense (S)</td>
<td>ZERO</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Subchannel-status word (SCSW)</td>
<td>Zero</td>
<td>TSCH</td>
<td>Yes</td>
</tr>
<tr>
<td>Model-dependent area</td>
<td>Zero</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Measurement-block-format control (F)</td>
<td>Zeros</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Extended-measurement-word enable (X)</td>
<td>Zeros</td>
<td>MSCH</td>
<td>No</td>
</tr>
<tr>
<td>Measurement-block address</td>
<td>Zeros</td>
<td>MSCH</td>
<td>No</td>
</tr>
</tbody>
</table>

*Figure 15-3. Modification of Subchannel Fields (Part 1 of 2)
Programming Notes:

1. System performance may be degraded if the LPM is not used to make channel paths for which a path-not-operational condition has been indicated in the PNOM logically not available.

2. If, during the performance of a start function, a channel path becomes not physically available because a channel-path failure has been recognized, continued performance of the start function may be precluded. That is, the program may or may not be notified, and the subchannel may remain in the subchannel-and-device-active state until cleared by the performance of the clear function.

3. If the same MBI is placed in more than one subchannel by the program, the channel-subsystem-monitoring facility updates the same locations with measurement data relating to more than one subchannel. In this case, the values stored in the measurement data are unpredictable. (See “Measurement-Block Update” on page 2.)

4. Modification of the I/O configuration (reconfiguration) may be accomplished in various ways depending on the model. If the reconfiguration procedure affects the physical availability of a channel path, then any change in availability can be detected by executing STORE SUBCHANNEL for a subchannel that has access to the channel path and by subsequently examining the PAM bits of the SCHIB.

5. The definitions of the PNOM, POM, and N bit are such that a path-not-operational condition is reported to the program only the first time the condition is detected by the channel subsystem after the corresponding POM bit is set to one. For example, if the POM bit for every channel path available for selection is one and the device appears not operational on all corresponding channel paths while the channel subsystem is attempting to initiate a start function at the device, the channel subsystem makes the subchannel status pending, with deferred condition code 3 and with the N bit stored as one. The PNOM in the SCHIB indicates the channel path or channel paths that appeared not operational, for which the corresponding POM bits have been set to zeros. The next START SUBCHANNEL causes the channel subsystem to again attempt device selection by choosing a channel path from among all of the channel paths that are available...
for selection. If device selection is not successful and all channel paths available for selection have again been chosen, deferred condition code 3 is set, but the N bit in the SCSW is zero. The POM contains zeros in at least those bit positions that correspond to the channel paths that are available for selection. (See “Channel-Path Availability” on page 13 for a description of the term “available for selection.”) When the N bit in the SCSW is zero, the PNOM is also zero.

6. If the program is to detect path-not-operational conditions, the PNOM should be inspected following the execution of TEST SUBCHANNEL (which results in the setting of condition code zero and the valid storing of the N bit as one) and preceding the performance of another start, resume, halt, or clear function at the subchannel.

**Working Allegiance**

**Working Allegiance for Subchannels Operating in Command Mode**

A subchannel has a working allegiance for a channel path when the subchannel is operating in command mode and becomes device active on that channel path. Once a working allegiance is established, the channel subsystem maintains the working allegiance at the subchannel for the channel path until either the subchannel is no longer device active or a dedicated allegiance is recognized, whichever occurs earlier. Unless a dedicated allegiance is recognized, a working allegiance for a channel path is extended to the set of channel paths that are available for selection if the device is specified to be operating in the multipath mode (that is, the multipath-mode bit is stored as one in the SCHIB). Otherwise, the working allegiance remains only for that channel path over which the start function was initiated.

Once a working allegiance is established for a channel path or set of channel paths, the working allegiance is not changed until the subchannel is no longer device active or until a dedicated allegiance is established. If the subchannel is operating in the single-path mode, a working allegiance is maintained only for a single path.

While a working allegiance exists at a subchannel, an active allegiance can occur only for a channel path for which the working allegiance is being maintained, unless the device is specified as operating in the multipath mode. When the device is specified as operating in the multipath mode, an active allegiance may also occur for a channel path that is not available for selection if the presentation of status by the device on that channel path causes an alert interruption condition to be recognized.

A working allegiance is cleared in any subchannel having access to a channel path if the channel path becomes not physically available.

**Working Allegiance for Subchannels Operating in Transport Mode**

A subchannel has a working allegiance for a channel path when the subchannel is operating in transport mode, becomes start pending, and the designated TCCB is transported over that channel path to the I/O device. Once a working allegiance is established, the channel subsystem maintains the working allegiance
at the subchannel for the channel path until a busy condition is encountered or the subchannel is made status pending with primary status. The working allegiance remains only for that channel path over which the start function was initiated.

While a working allegiance exists at a subchannel that is operating in transport mode, an active allegiance can occur only for the channel path for which the working allegiance is being maintained.

A working allegiance is cleared in any subchannel having access to a channel path if the channel path becomes not physically available.

**Active Allegiance**

A subchannel has an active allegiance established for a channel path no later than when active communication has been initiated on that channel path with an I/O device. The subchannel can have an active allegiance to only one channel path at a time. While the subchannel has an active allegiance for a channel path, the channel subsystem does not actively communicate with that device on any other channel path. When the channel subsystem accepts a no-longer-busy indication from the device that does not cause an interruption condition, this status does not constitute the initiation of active communication. An active allegiance at a subchannel for a channel path is terminated when the channel subsystem is no longer actively communicating with the I/O device on that channel path.

A working allegiance can become an active allegiance.

**Dedicated Allegiance**

If a channel path is physically available (that is, if the corresponding PAM bit is one), a dedicated allegiance may be recognized for that channel path. If a channel path is not physically available, a dedicated allegiance cannot be recognized for the corresponding channel path. The channel subsystem establishes a dedicated allegiance at the subchannel for a channel path when (1) the subchannel is operating in command mode, the subchannel becomes status pending with alert status, and device status containing the unit-check indication is present but (2) concurrent-sense information is not present at the subchannel. A dedicated allegiance is maintained until the subchannel is no longer start pending (unless it becomes suspended) or resume pending following performance of the next start function, clear function, or channel-path-reset function or the next resume function if applicable. If the subchannel becomes suspended, the dedicated allegiance remains until the resume function is initiated and the subchannel is no longer resume pending. Unless a clear or channel-path-reset function is performed, the subchannel establishes a working allegiance when the dedicated allegiance ends. This occurs when the subchannel becomes device active. While a dedicated allegiance exists at a subchannel for a channel path, only that channel path is available for selection until the dedicated-allegiance condition is cleared.

Dedicated allegiance does not apply to subchannels operating in transport mode. When a subchannel operating in transport mode becomes status pending with unit check indicated, the sense information has already been transferred from the I/O device into the TSB for the I/O operation.

A dedicated allegiance can become an active allegiance. While a dedicated allegiance exists, an active allegiance can only occur for the same channel path.

A currently existing dedicated allegiance is cleared at any subchannel having access to a channel path when the channel path becomes not physically available or whenever the device appears not operational on the channel path for which the dedicated allegiance exists.

**Channel-Path Availability**

When a channel path is not physically available, the channel subsystem does not use the channel path to perform any of the basic I/O functions except, in some cases, the channel-path-reset function and does not respond to any control-unit-initiated requests on that same channel path. If a channel path is not physically available, the condition is indicated by the corresponding path-available-mask PAM bit being zero when STORE SUBCHANNEL is executed (see "Path-Available Mask (PAM)" on page 7). Furthermore, if the channel path is not physically available for the subchannel designated by STORE SUBCHANNEL, then it is not physically available for any subchannel that has a device which is accessible by that channel path.
Unless a dedicated allegiance exists at a subchannel for the channel path, a channel path becomes available for selection if it is logically available and physically available, as indicated by the bits in the LPM and PAM corresponding to the channel path being stored as ones when STORE SUBCHANNEL is executed. If a dedicated allegiance exists at a subchannel for the channel path, only that channel path is available for selection, and the setting of the corresponding LPM bit is ignored. If the channel path is currently being used and a dedicated allegiance exists at the subchannel for the channel path, selection of the device is delayed until the channel path is no longer being used.

The availability status of the eight logical paths to the associated device described in Figure 15-4 on page 14 is determined by the hierarchical arrangement of the corresponding bit values contained in the PIM, PAM, and LPM and by existing conditions, if any, recognized by the channel subsystem.

<table>
<thead>
<tr>
<th>Value of Bit ‘n’</th>
<th>Channel-Path Condition</th>
<th>Channel-Path State</th>
</tr>
</thead>
<tbody>
<tr>
<td>PIM</td>
<td>PAM</td>
<td>LPM</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>-</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>-</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

Explanation:

1. Bit value is not meaningful.
2. If the channel path is recognized as being used in active communication with a device, the channel-path condition is described as active. Otherwise, its condition is described as inactive.
3. A PAM bit cannot have the value one when the corresponding PIM bit has the value zero.
4. If a dedicated allegiance exists to the channel path at the subchannel, the state of the bit is ignored, and the channel path is considered to be available for selection.
5. The channel path may appear to be active when a channel-path-terminal condition has been recognized.
6. Condition is not meaningful.

Figure 15-4. Path condition and Path-Availability Status for PIM, PAM, and LPM Values

### Clear Function

Subsequent to the execution of CLEAR SUBCHANNEL, the channel subsystem performs the clear function. Performance of the clear function consists in (1) performing a path-management operation, (2) modifying fields at the subchannel, (3) issuing the clear signal to the associated device, and (4) causing the subchannel to be made status pending, indicating the completion of the clear function.

### Clear-Function Path Management

A path-management operation is performed as part of the clear function in order to examine channel-path conditions for the associated subchannel and to attempt to choose an available channel path on which the clear signal can be issued to the associated device.

Channel-path conditions are examined in the following order:

1. If the channel subsystem is actively communicating or attempting to establish active communication with the device to be signaled, the channel path that is in use is chosen.
2. If the channel subsystem is in the process of accepting a no-longer-busy indication (which will not cause an interruption condition to be recognized) from the device to be signaled, and the associated subchannel has no allegiance to any channel path, the channel path that is in use is chosen.
3. If the associated subchannel has a dedicated allegiance for a channel path, that channel path is chosen.
4. If the associated subchannel has a working allegiance for one or more channel paths, one of those channel paths is chosen.

### Control-Unit Type

In “Clear Function” on page 14, “Halt Function” on page 16, and “Start Function and Resume Function” on page 20, reference is made to type-1, type-2, and type-3 control units. For a description of these control-unit types, see the System Library publication IBM System/360 and System/370 I/O Interface Channel to Control Unit OEMI, GA22-6974. For the purposes of this definition, all control units attaching to a serial-I/O interface are considered type-2 control units.

---

**Control-Unit Type**

In “Clear Function” on page 14, “Halt Function” on page 16, and “Start Function and Resume Function”
5. If the associated subchannel has no allegiance for any channel path, if a last-used channel path is indicated, and if that channel path is available for selection, that channel path is chosen. If that channel path is not available for selection, either no channel path is chosen or a channel path is chosen from the set of channel paths, if any, that are available for selection (as though no last-used channel path were indicated).

6. If the associated subchannel has no allegiance for any channel path, if no last-used channel path is indicated, and if there exist one or more channel paths that are available for selection, one of those channel paths is chosen.

If none of the channel-path conditions listed above apply, no channel path is chosen.

For item 4, for item 5 under the specified conditions, and for item 6, the channel subsystem chooses a channel path from a set of channel paths. In these cases, the channel subsystem may attempt to choose a channel path, provided that the following conditions do not apply:

1. A channel-path-terminal condition exists for the channel path.
2. For a parallel or ESCON channel path: Another subchannel has an active allegiance for the channel path.
   For a FICON channel path: The channel path is currently being used to actively communicate with the maximum number of subchannels that can have concurrent active communications.
3. The device to be signaled is attached to a type-1 control unit, and the subchannel for another device attached to the same control unit has an allegiance to the same channel path, unless the allegiance is a working allegiance and primary status has been accepted by that subchannel.
4. The device to be signaled is attached to a type-3 control unit, and the subchannel for another device attached to the same control unit has a dedicated allegiance to the same channel path.

Clear-Function Subchannel Modification

Path-management-control indications at the subchannel are modified during performance of the clear function. Effectively, this modification occurs after the attempt to choose a channel path, but prior to the attempt to select the device to issue the clear signal. The path-management-control indications that are modified are as follows:

1. The state of all eight possible channel paths at the subchannel is set to operational for the subchannel.
2. The last-path-used indication is reset to indicate no last-used channel path.
3. Path-not-operational conditions, if any, are reset.

Clear-Function Signaling and Completion

Subsequent to the attempt to choose a channel path and the modification of the path-management-control fields, the channel subsystem, if conditions allow, attempts to select the device to issue the clear signal. (See “Clear Signal” on page 12.) Conditions associated with the subchannel and the chosen channel path, if any, affect (1) whether an attempt is made to issue the clear signal, and (2) whether the attempt to issue the clear signal is successful. Independent of these conditions, the subchannel is subsequently set status pending, and the performance of the clear function is complete. These conditions and their effect on the clear function are described as follows:

No Attempt Is Made to Issue the Clear Signal:
The channel subsystem does not attempt to issue the clear signal to the device if any of the following conditions exist:

1. No channel path was chosen. (See “Clear-Function Path Management” on page 14.)
2. The chosen channel path is no longer available for selection.
3. A channel-path-terminal condition exists for the chosen channel path.
4. For parallel and ESCON channel paths: The chosen channel path is currently being used to actively communicate with a different device.
For FICON channel paths: The chosen channel path is currently being used to actively communicate with the maximum number of devices that can have concurrent active communications.

5. The device to be signaled is attached to a type-1 control unit, and the subchannel for another device attached to the same control unit has an allegiance to the same channel path, unless the allegiance is a working allegiance and primary status has been accepted by that subchannel.

6. The device to be signaled is attached to a type-3 control unit, and the subchannel for another device attached to the same control unit has a dedicated allegiance to the same channel path.

If any of the conditions above exist, the subchannel remains clear pending and is set status pending, and the performance of the clear function is complete.

**The Attempt to Issue the Clear Signal Is Not Successful:** When the channel subsystem attempts to issue the clear signal to the device, the attempt may not be successful because of the following conditions:

1. The control unit or device signals a busy condition when the channel subsystem attempts to select the device to issue the clear signal.

2. A path-not-operational condition is recognized when the channel subsystem attempts to select the device to issue the clear signal.

3. An error condition is encountered when the channel subsystem attempts to issue the clear signal.

If any of the conditions above exist and the channel subsystem either determines that the attempt to issue the clear signal was not successful or cannot determine whether the attempt was successful, the subchannel remains clear pending and is set status pending, and the performance of the clear function is complete.

**Programming Note:** Subsequent to the performance of the clear function, any nonzero status, except control unit end alone, that is presented to the channel subsystem by the device is passed to the program as unsolicited alert status. Unsolicited status consisting of control unit end alone or zero status is not presented to the program.

---

**Halt Function**

Subsequent to the execution of HALT SUBCHANNEL, the channel subsystem performs the halt function. Performance of the halt function consists of (1) performing a path-management operation, (2) issuing the halt signal to the associated device, and (3) causing the subchannel to be made status pending, indicating the completion of the halt function.

**Halt-Function Path Management**

A path-management operation is performed as part of the halt function to examine channel-path conditions for the associated subchannel and to attempt to choose a channel path on which the halt signal can be issued to the associated device.

Channel-path conditions are examined in the following order:

1. If the channel subsystem is actively communicating or attempting to establish active communication with the device to be signaled, the channel path that is in use is chosen.

2. If the channel subsystem is in the process of accepting a no-longer-busy indication (which will not cause an interruption condition to be recognized) from the device to be signaled, and the associated subchannel has no allegiance to any channel path, the channel path that is in use is chosen.

3. If the associated subchannel has a dedicated allegiance for a channel path, that channel path is chosen.

4. If the associated subchannel has a working allegiance for one or more channel paths, one of those channel paths is chosen.
5. If the associated subchannel has no allegiance for any channel path, if a last-used channel path is indicated, and if that channel path is available for selection, that channel path is chosen. If that channel path is not available for selection, either no channel path is chosen or a channel path is chosen from the set of channel paths, if any, that are available for selection (as though no last-used channel path were indicated).

6. If the associated subchannel has no allegiance for any channel path, if no last-used channel path is indicated, and if there exist one or more channel paths that are available for selection, one of those channel paths is chosen.

If none of the channel-path conditions listed above apply, no channel path is chosen.

For item 4, for item 5 under the specified conditions, and for item 6, the channel subsystem chooses a channel path from a set of channel paths. In these cases, the channel subsystem may attempt to choose a channel path for which the following conditions do not apply:

1. A channel-path-terminal condition exists for the channel path.
2. For a parallel or ESCON channel path: Another subchannel has an active allegiance for the channel path.
   For a FICON channel path: The channel path is currently being used to actively communicate with the maximum number of subchannels that can have concurrent active communications.
3. The device to be signaled is attached to a type-1 control unit, and the subchannel for another device attached to the same control unit has an allegiance to the same channel path, unless the allegiance is a working allegiance and primary status has been accepted by that subchannel.
4. The device to be signaled is attached to a type-3 control unit, and the subchannel for another device attached to the same control unit has a dedicated allegiance to the same channel path.

Halt-Function Signaling and Completion

Subsequent to the attempt to choose a channel path, the channel subsystem, if conditions allow, attempts to select the device to issue the halt signal. (See “Halt Signal” on page 12.)

Conditions associated with the subchannel and the chosen channel path, if any, affect (1) whether an attempt is made to issue the halt signal, (2) whether the attempt to issue the halt signal is successful, and (3) whether the subchannel is made status pending to complete the halt function. These conditions and their effect on the halt function are described as follows:

No Attempt Is Made to Issue the Halt Signal:
The channel subsystem does not attempt to issue the halt signal to the device if any of the following conditions exist:

1. No channel path was chosen. (See “Halt-Function Path Management” on page 16.)
2. The chosen channel path is no longer available for selection.
3. A channel-path-terminal condition exists for the chosen channel path.
4. The associated subchannel is status pending with other than intermediate status alone.
5. The device to be signaled is attached to a type-1 control unit, and the subchannel for another device attached to the same control unit has an allegiance to the same channel path, unless the allegiance is a working allegiance and primary status has been accepted by that subchannel.
6. The device to be signaled is attached to a type-3 control unit, and the subchannel for another device attached to the same control unit has a dedicated allegiance to the same channel path.

If the conditions described in items 3, 5, or 6 exist, the associated subchannel remains halt pending until those conditions no longer exist. When the conditions no longer exist (for the channel-path-terminal condition, when the condition no longer exists as a result of executing RESET CHANNEL PATH), the channel subsystem attempts to issue the halt signal to the device.
If any of the remaining conditions above exist, the subchannel remains halt pending and is set status pending, and the halt function is complete.

**The Attempt to Issue the Halt Signal Is Not Successful:** When the channel subsystem attempts to issue the halt signal to the device, the attempt may not be successful because of the following conditions:

1. The control unit or device signals a busy condition when the channel subsystem attempts to select the device to issue the halt signal.
2. A path-not-operational condition is recognized when the channel subsystem attempts to select the device to issue the halt signal.
3. An error condition is encountered when the channel subsystem attempts to issue the halt signal.

If the control unit or device signals a busy condition (item 1), the subchannel remains halt pending until the internal indication of busy is reset. When this event occurs, the channel subsystem again attempts to issue the halt signal to the device.

If any of the remaining conditions above exists and the channel subsystem either determines that the attempt to issue the halt signal was not successful or cannot determine whether the attempt was successful, then the subchannel remains halt pending and is set status pending, and the halt function is complete.

**The Attempt to Issue the Halt Signal Is Successful:** When the channel subsystem determines that the attempt to issue the halt signal was successful and ending status, if appropriate, has been received at the subchannel, the subchannel is no longer halt pending and is set status pending, and the halt function is complete. When the subchannel becomes status pending, the I/O operation, if any, with the associated device has been terminated. The conditions that affect the receipt of ending status at the subchannel, and the effect of the halt signal at the device are described in the following discussion.

When the subchannel is subchannel-and-device active or only device active during the performance of the halt function, the state continues until the subchannel is made status pending because (1) the device has provided ending status or (2) the channel subsystem has determined that ending status is unavailable.

When the subchannel is operating in command mode and is idle, start pending, start pending and resume pending, suspended, or suspended and resume pending, or when the halt signal is issued during command chaining after the receipt of device end but before the next command is transferred to the device, no operation is in progress at the device, and therefore no status is generated by the device as a result of receiving the halt signal. When the subchannel is neither subchannel active, nor status pending with intermediate status, and no errors are detected during the attempt to issue the halt signal to the device, an interruption condition indicating status pending alone is generated after the halt signal is issued.

When the subchannel is operating in transport mode and is start pending, an operation may or may not be in progress at the device. Regardless of whether an operation is in progress, device status is not generated.

The effect of the halt signal at the device depends partially on the subchannel operation mode, type of device, and its state. The effect of the halt signal on a device that is not active or that is performing a mechanical operation in which data is not transferred across the channel path, such as rewinding tape or positioning a disk-access mechanism, depends upon the control-unit or device model. If the device is performing a type of operation that is unpredictable in duration or in which data is transferred across the channel path, the control unit interprets the signal as one to terminate the operation. Pending status conditions at the device are not reset. When the control unit recognizes the halt signal, it immediately ceases all communication with the channel subsystem until it has reached the normal ending point. The control unit then requests selection by the channel subsystem to present any generated status.

If the subchannel is involved in the data-transfer portion of an I/O operation, data transfer is terminated during the performance of the halt function, and the device is logically disconnected from the channel path. If the halt function is addressed to a subchannel operating in command mode, performing a chain of I/O operations, and the device has already provided channel end for the current I/O operation, the channel subsystem causes the device to be discon-
nected and command chaining or command retry to be suppressed.

If the subchannel is operating in command mode, performing a chain of I/O operations with the device, and the halt signal is issued during command chaining at a point after the receipt of device end for the previous I/O operation but before the next command is transferred to the device, the subchannel is made status pending with primary and secondary status immediately after the halt signal is issued. The device-status field of the SCSW contains zeros in this case. If the halt function is addressed to a subchannel that is operating in command mode, start pending, and the halt-pending condition is recognized before initiation of the start function, initiation of the start function is not attempted, and the subchannel becomes status pending after the device has been signaled.

If the halt function is addressed to a subchannel operating in transport mode that is start pending, the halt signal is issued as follows:

- If the TCCB has been transported to the I/O device for execution, the halt signal is issued and the subchannel becomes status pending.
- If the TCCB has not been transported to the I/O device, the TCCB is not transported and the subchannel becomes status pending.

When the subchannel is not performing an I/O operation with the associated device, the device is selected, and an attempt is made to issue the halt signal as the device responds. If the subchannel is in the device-active state, the subchannel does not become status pending until it receives the device-end status from the halted device. If the subchannel is neither subchannel-and-device active nor device active, the subchannel becomes status pending immediately after selecting the device and issuing the halt signal. The SCSW for the latter case has the status-pending bit set to one (see “Status-Pending (Bit 31)” on page 19).

The termination of an I/O operation by performing the halt function may result in two distinct interruption conditions.

The first interruption condition occurs when the device generates the channel-end condition. The channel subsystem handles this condition as it would any other interruption condition from the device, except that the command address in the associated SCSW designates the point at which the I/O operation is terminated as follows:

- When a command-mode IRB is stored, the SCSW contains the address of the last-executed CCW, plus 8, and the subchannel-status bits may reflect unusual conditions that were detected.
- When a transport-mode IRB is stored, the SCSW contains the address of the current TCW, and the subchannel-status, subchannel-extended-status, and FCX bits may reflect unusual conditions that were detected.

If the halt signal was issued before all data designated for the operation had been transferred, incorrect length is indicated, subject to the control of the SLI flag in the current CCW when the subchannel is operating in command mode. The value in the count field of the associated SCSW is unpredictable. If the halt signal was issued before all data designated for the operation had been transferred, incorrect length is not indicated, when the subchannel is operating in transport mode.

The second interruption condition occurs if device-end status was not presented with the channel-end interruption condition. In this situation, the subchannel-key, command-address, and count fields of the associated SCSW are not meaningful.

When HALT SUBCHANNEL terminates an I/O operation, the method of termination differs from that used upon exhaustion of count or upon detection of programming errors to the extent that termination by HALT SUBCHANNEL is not contingent on the receipt of a service request from the associated device.

Programming Notes:

1. When, after an operation is terminated by HALT SUBCHANNEL, the subchannel is status pending with primary, primary and secondary, or secondary status, the extent of data transferred as described by the count field is unpredictable.

2. When the path that is chosen by the path-management operation has a channel-path-terminal condition associated with it, the halt function remains pending until the condition no longer exists. Until the condition is cleared, the associated subchannel cannot be used to perform I/O operations, even if other channel paths become
available for selection. CLEAR SUBCHANNEL can be executed to terminate the halt-pending condition and make the subchannel usable.

---

**Start Function and Resume Function**

The start and resume functions initiate I/O operations as described below. The start function applies to subchannels operating in either command mode or transport mode. The resume function applies only to subchannels operating in command mode.

Subsequent to the execution of START SUBCHANNEL and RESUME SUBCHANNEL, the channel subsystem performs the start and resume functions, respectively, to initiate an I/O operation with the associated device. Performance of a start or resume function consists of: (1) performing a path-management operation, (2) performing an I/O operation or chain of I/O operations with the associated device, and (3) causing the subchannel to be made status pending, indicating the completion of the start function. (Completion of a start function is described in “I/O Interruptions” on page 1.) The start function initiates the execution of a channel program that is designated in the ORB, which in turn is designated as the operand of START SUBCHANNEL, in contrast to the resume function that initiates the execution of a suspended channel program, if any, beginning at the CCW that caused suspension; otherwise, the resume function is performed as if it were a start function (see “Resume-Pending (Bit 20)” on page 14).

---

**Start-Function and Resume-Function Path Management**

A path-management operation is performed by the channel subsystem during the performance of either a start or a resume function to choose an available channel path that can be used for device selection to initiate an I/O operation with that device. The actions taken are as follows:

1. **If the subchannel is currently start pending and device active**, the start function remains pending at the subchannel until the secondary status for the previous start function has been accepted from the associated device and the subchannel is made start pending alone. When the status is accepted and does not describe an alert interruption condition, the subchannel is not made status pending, and the performance of the pending start function is subsequently initiated. If the status describes an alert interruption condition, the subchannel becomes status pending with secondary and alert status, the pending start function is not initiated, deferred condition code 1 is set, and the start-pending bit remains one. If the subchannel is currently start pending alone, the performance of the start function is initiated as described below.

2. **If a dedicated allegiance exists at the subchannel for a channel path**, the channel subsystem chooses that path for device selection. If a busy condition is encountered while attempting to select the device and a dedicated allegiance exists at the subchannel, the start function remains pending until the internal indication of busy is reset for that channel path. When the internal indication of busy is reset, the performance of the pending start function is initiated on that channel path.

3. **If no channel path is available for selection and no dedicated allegiance exists in the subchannel for a channel path**, a channel path is not chosen.

4. **If all channel paths that are available for selection have been tried and one or more of them are being used to actively communicate with other devices**, or, alternatively, if the channel subsystem has encountered either a control-unit-busy or a device-busy condition on one or more of those channel paths, or a combination of those conditions on one or more of those channel paths, the start function remains pending until a channel path, control unit, or device, as appropriate, becomes available.

5. **If (1) the start function is to be initiated on a channel path with a device attached to a type-1 control unit and (2) no other device is attached to the same control unit whose subchannel has either a dedicated allegiance to the same channel path or a working allegiance to the same channel path where primary status has not been received for that subchannel, then that channel path is chosen if it is available for selection; otherwise, that channel path is not chosen. If, however, another channel path to the device is available for selection and no allegiances exist as described above, that channel path is chosen. If no other channel path is available for selection,
the start or resume function, as appropriate, remains pending until a channel path becomes available.

6. If the device is attached to a type-3 control unit, and if at least one other device is attached to the same control unit whose subchannel has a dedicated allegiance to the same channel path, another channel path that is available for selection may be chosen, or the start function remains pending until the dedicated allegiance for the other device is cleared.

7. If a channel path has been chosen and a busy indication is received during device selection to initiate the execution of the first command of a pending CCW channel program or to transport the TCCB of a pending TCW channel program, the channel path over which the busy indication is received is not used again for that device or control unit (depending on the device-busy or control-unit-busy indication received) until the internal indication of busy is reset.

8. If, during an attempt to select the device in order to initiate the execution of the first command specified for the start or implied for the resume function for a CCW channel program, or to initiate the transportation of the TCCB for a TCW channel program, (as described in action 7 above), the channel subsystem receives a busy indication, it performs one of the following actions:
   a. If the device is specified to be operating in the multipath mode and the busy indication received is device busy, then the start or resume function remains pending until the internal indication of busy is reset. (See “Multipath Mode (D)” on page 4.)
   b. If the device is specified to be operating in the multipath mode and the busy indication received is control unit busy, or if the device is specified to be operating in the single-path mode, the channel subsystem attempts selection of the device by choosing an alternate channel path that is available for selection and continues the path-management operation until either the start or the resume function is initiated or selection of the device has been attempted on all channel paths that are available for selection. If the start or resume function has not been initiated by the channel subsystem after all channel paths available for selection have been chosen, the start or resume function remains pending until the internal indication of busy is reset.
   c. If the subchannel has a dedicated allegiance, then action 2 on page 20 applies.

9. When, during the selection attempt to transfer the first command for a CCW channel program, or to transport the TCCB for a TCW channel program, the device appears not operational and the corresponding channel path is operational for the subchannel, a path-not-operational condition is recognized, and the state of the channel path changes at the subchannel from operational for the subchannel to not operational for the subchannel (see “Path-Not-Operational Mask (PNOM)” on page 5). The path-not-operational conditions at the subchannel, if any, are preserved until the subchannel next becomes clear pending, start pending, or resume pending (if the subchannel was suspended), at which time the path-not-operational conditions are cleared. If, however, the corresponding channel path is not operational for the subchannel, a path-not-operational condition is not recognized. When the device appears not operational during the selection attempt to transfer the first command or TCCB on a channel path that is available for selection, one of the following actions occurs:
   a. If a dedicated allegiance exists for that channel path, then it is the only channel path that is available for selection; therefore, further attempts to initiate the start or resume function are abandoned, and an interruption condition is recognized.
   b. If no dedicated allegiance exists and there are alternate channel paths available for selection that have not been tried, one of those channel paths is chosen to attempt device selection and transfer the first command for a CCW channel program, or the TCCB for a TCW channel program.
   c. If no dedicated allegiance exists, no alternate channel paths are available for selection that have not been tried, and the device has appeared operational on at least one of the channel paths that were tried, the start or resume function remains pending at the subchannel until a channel path, a control unit, or the device, as appropriate, becomes available.
d. If no dedicated allegiance exists, no alternate channel paths are available for selection that have not been tried, and the device has appeared not operational on all channel paths that were tried, further attempts to initiate the start or resume function are abandoned, and an interruption condition is recognized.

10. When the subchannel is active and an I/O operation is to be initiated with a device, all device selections occur according to the LPUM indication if the multipath mode is not specified at the subchannel. For example, if command chaining is specified for a CCW channel program, the channel subsystem transfers the first and all subsequent commands describing a chain of I/O operations over the same channel path.

Interrogate Function

Subsequent to the execution of CANCEL SUBCHANNEL for a subchannel operating in transport mode, the channel subsystem performs the interrogate function. Performance of the interrogate function consists of (1) transporting the designated interrogate TCCB to the I/O device, (2) storing the interrogate TSB, and (3) causing the subchannel to become intermediate status pending with interrogate-complete status indicated.

All storage accesses used to perform the interrogate operation are made as if a storage-access key of zero is used.

Interrogate-Function Path Management

The same channel path that was used to transport the TCCB for the I/O operation being interrogated is used for the interrogate function.

Interrogate TCCB Transportation and Completion

Subsequent to determining the channel path, the channel subsystem, if conditions allow, attempts to transport the interrogate TCCB. Conditions associated with the subchannel, the interrogate TCCB, and the chosen channel path, if any, affect (1) whether an attempt is made to transport the interrogate TCCB, (2) whether the attempt to transport the interrogate TCCB is successful, and (3) whether the interrogate TSB is stored. These conditions and their effect on the interrogate function are described as follows:

**No Attempt Is Made to Transport the Interrogate TCCB:** The channel subsystem does not transport the interrogate TCCB if any of the following conditions exists:

- The subchannel is status pending with primary status indicated.
- The subchannel is idle or device active only.
- The TCCB for the I/O operation being interrogated has not been transported to the device.
- Another interrogate function is already in progress on the channel path for the I/O device.
- The interrogate-TCW-address field of the TCW for the I/O operation being interrogated contains zeros.
- The channel subsystem doesn't have the resources to process the interrogate.

**The Attempt to Transport the Interrogate TCCB or Store the Interrogate TSB is Unsuccessful:** When the channel subsystem attempts to transport the interrogate TCCB, the attempt may not be successful if any of the following conditions exists:

- The interrogate-TCW address designated by the TCW of the I/O operation being interrogated designates an unavailable storage location or does not designate the interrogate TCW on a 64-byte boundary.
- The TCCB-TIDA flag is one in the flags field of the interrogate TCW and the TCCB-address field in the interrogate TCW does not designate the first TIDAW on a quadword boundary.
- The interrogate-TSB address designated by the TCW of the I/O operation being interrogated designates an unavailable storage location or does not designate the interrogate TSB on a double-word boundary.

If any of the above conditions is true, the subchannel is made status pending with program check and interrogate-failed status indicated in the subchannel-extended-status field of the IRB.
The attempt to transport the interrogate TCCB is also not successful when a device-detected program check is recognized. In this case, interrogate-failed status is also indicated in the subchannel-extended-status field of the IRB.

If the interrogate TCCB has been sent and the corresponding interrogate response is not received within a model-dependent amount of time, an interface-control check is recognized with interrogate-failed status indicated in the subchannel-extended-status field of the IRB.

**The Attempt to Transport the Interrogate TCCB is Successful:** When the channel subsystem determines that the attempt to transport the interrogate TCCB was successful and the interrogate data has been received at the subchannel before the completion of the I/O operation being interrogated, the interrogate data is stored into the interrogate TSB, and the subchannel is made status pending with intermediate status and interrogate-complete status indicated. The status related to the operation being interrogated remains unchanged.

When the channel subsystem determines that the operation being interrogated has completed before the interrogate data has been received at the subchannel, the channel subsystem waits until the interrogate data is received. When received, the interrogate data is stored into the interrogate TSB, and the subchannel is made status pending with primary status indicated. The status related to the operation being interrogated is unchanged.

**Execution of I/O Operations**

After a channel path is chosen, the channel subsystem, if conditions allow, initiates the execution of an I/O operation with the associated device. Execution of additional I/O operations may follow the initiation and execution of the first I/O operation.

For subchannels operating in command mode, the channel subsystem can execute seven types of commands: write, read, read backward, control, sense, sense ID, and transfer in channel. Each command, except transfer in channel, initiates a corresponding I/O operation. Except for periods when channel-program execution is suspended at the subchannel (see "Suspension of CCW Channel-Program Execution" on page 73), the subchannel is active from the acceptance of the first command until the primary interruption condition is recognized at the subchannel. If the primary interruption condition is recognized before the acceptance of the first command, the subchannel does not become active. Normally, the primary interruption condition is caused by the channel-end signal or, in the case of command chaining, the channel-end signal for the last CCW of the chain. (See “Primary Interruption Condition” on page 4.) The device is active until the secondary interruption condition is recognized at the subchannel. Normally, the secondary interruption condition is caused by the device-end signal or, in the case of command chaining, the device-end signal for the last CCW of the chain. (See “Secondary Interruption Condition” on page 5.)

For subchannels operating in transport mode, the channel subsystem can transport six types of commands for execution: write, read, control, sense, sense ID, and interrogate. Each command initiates a corresponding device operation. When one or more commands are transported to the I/O device in a TCCB, the subchannel remains start pending until primary status is presented.

**Programming Notes:**

In the single-path mode, all transfers of commands, data, and status for the I/O operation or chain of I/O operations occur on the channel path over which the first command was transferred to the device.

When the device has the dynamic-reconnection feature installed, an I/O operation or chain of I/O operations may be performed in the multipath mode. To operate in the multipath mode, MODIFY SUBCHANNEL must have been previously executed for the subchannel with bit 13 of word 1 of the SCHIB specified as one. (See “Multipath Mode (D)” on page 4.) In addition, the device must be set up for the multipath mode by the execution of certain model-dependent commands appropriate to that type of device. The general procedures for handling multipath-mode operations are as follows:

1. **Setup**
   a. A set-multipath-mode type of command must be successfully executed by the device on each channel path that is to be a member of the multipath group being set up; otherwise, the multipath mode of operation may give unpredictable results at the subchannel. If,
for any reason, one or more physically available channel paths to the device are not included in the multipath group, these channel paths must not be available for selection while the subchannel is operating in the multipath mode. A channel path can be made not available for selection by having the corresponding LPM bit set to zero either in the SCHIB prior to the execution of MODIFY SUBCHANNEL or in the ORB prior to the execution of START SUBCHANNEL.

b. When a set-multipath-mode type of command is transferred to a device, only a single channel path must be logically available in order to avoid alternate channel-path selection for the execution of that start function; otherwise, device-busy conditions may be detected by the channel subsystem on more than one channel path, which may cause unpredictable results for subsequent multipath-mode operations. This type of setup procedure should be used whenever the membership of a multipath group is changed.

2. Leaving the Multipath Mode

To leave the multipath mode and continue processing in the single-path mode, either of the following two procedures may be used:

a. A disband-multipath-mode type of command may be executed for any channel path of the multipath group. This command must be followed by either (1) the execution of MODIFY SUBCHANNEL with bit 13 of word 1 of the SCHIB specified as zero, or (2) the specification of only a single channel path as logically available in the LPM. No start function may be performed at a subchannel operating in the multipath mode with multiple channel paths available for selection while the device is operating in single-path mode; otherwise, unpredictable results may occur at the subchannel for that or subsequent start functions.

b. A resign-multipath-mode type of command is executed on each channel path of the multipath group (the reverse of the setup described in item 1 on page 23). This command must be followed by either (1) the execution of MODIFY SUBCHANNEL with bit 13 of word 1 of the SCHIB specified as zero, or (2) the specification of only a single channel path as logically available in the LPM. No start function may be performed at a subchannel operating in the multipath mode with multiple channel paths available for selection while the device is operating in single-path mode; otherwise, unpredictable results may occur at the subchannel for that or subsequent start functions.

### Blocking of Data

Data recorded by an I/O device is divided into blocks. The length of a block depends on the device; for example, a block can be a card, a line of printing, or the information recorded between two consecutive gaps on magnetic tape.

The maximum amount of information that can be transferred in one I/O operation is one block. An I/O operation is terminated when the associated main-storage area is exhausted or the end of the block is reached, whichever occurs first. For some operations, such as writing on a magnetic-tape unit or at an inquiry station, blocks are not defined, and the amount of information transferred is controlled only by the program.

### Operation-Request Block

The operation-request block (ORB) is the operand of START SUBCHANNEL. The ORB specifies the parameters to be used in controlling that particular start function. These parameters include the interruption parameter, the subchannel key, the address of first CCW or the TCW, operation-control bits, priority-control numbers, and a specification of the logical availability of channel paths to the designated device.

The contents of the ORB are placed at the designated subchannel during the execution of START SUBCHANNEL, prior to the setting of condition code 0. If the execution will result in a nonzero condition code, the contents of the ORB are not placed at the designated subchannel.

The two rightmost bits of the ORB address must be zeros, placing the ORB on a word boundary; otherwise, a specification exception is recognized.

When the fibre-channel-extensions (FCX) facility is installed, the channel-program-type control (B) (word
1, bit 13) of the ORB specifies the type of channel program that is designated by the ORB. When B is zero, the ORB designates a CCW channel program. When the B is one, the ORB designates a TCW channel program. Only I/O-devices that support FCX recognize TCW channel programs.

If the contents of an ORB that designates a CCW channel program are placed at the designated subchannel during the execution of START SUBCHANNEL, the subchannel remains in command mode. Thus, such an ORB is also known as a command-mode ORB. If the contents of an ORB that designates a TCW channel program are placed at the designated subchannel during execution of START SUBCHANNEL, the subchannel enters transport mode. Thus, such an ORB is also known as a transport-mode ORB.

**Command-Mode ORB**

This section describes the command-mode ORB. The term operation-request block (ORB), in this section, means an ORB in which bit 13 of word 1 (the channel-program-type control (B)) is zero.

The format of the command-mode ORB is as follows:

<table>
<thead>
<tr>
<th>Word</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Interruption Parameter</td>
</tr>
<tr>
<td>1</td>
<td>Key: S</td>
</tr>
<tr>
<td>2</td>
<td>Channel-Program Address</td>
</tr>
<tr>
<td>3</td>
<td>CSS Priority</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Figure 15-5. Command-Mode Operation-Request Block**

The fields in the command-mode ORB are defined as follows:

**Interruption Parameter:** Bits 0-31 of word 0 are preserved unmodified in the subchannel until replaced by a subsequent START SUBCHANNEL or MODIFY SUBCHANNEL instruction. These bits are placed in word 1 of the interruption code when an I/O interruption occurs and when an interruption request is cleared by the execution of TEST PENDING INTERRUPTION.

**Subchannel Key:** Bits 0-3 of word 1 form the subchannel key for all fetching of CCWs, IDAUs, MIDAUs, and output data and for the storing of input data associated with the start function initiated by START SUBCHANNEL. This key is matched with a storage key during these storage references. For details, see the section “Key-Controlled Protection” on page 11.

**Suspend Control (S):** Bit 4 of word 1 controls the performance of the suspend function for the channel program designated in the ORB. The setting of the S bit applies to all CCWs of the channel program designated by the ORB (see “Commands and Flags for CCWs” on page 75).

When bit 4 is one, suspend control is specified, and channel-program suspension occurs when a suspend flag set to one is detected in a CCW. When bit 4 is zero, suspend control is not specified, and the presence of a suspend flag set to one in any CCW of the channel program causes a program-check condition to be recognized.

**Streaming-Mode Control (C):** Bit 5 of word 1 controls streaming-mode enablement for subchannels configured to FICON-converted-I/O-interface channel paths during performance of the specified start function. When bit 5 is zero, the streaming mode is enabled at the subchannel. When bit 5 is one, the streaming mode is disabled at the subchannel. Bit 5 is meaningful only for subchannels configured to FICON-converted-I/O-interface channel paths and is ignored for subchannels configured to other channel-path types.

When the streaming mode is enabled, the channel path considers the first command of the designated channel program to be in progress at the associated device when the channel path receives the indication that the command has been accepted at the device. In addition, the channel path's acceptance of status, under certain conditions, is recognized by the channel path without receiving acknowledgement of status acceptance from the device.

When the streaming mode is not enabled, the channel path does not consider the first command of the designated channel program to be in progress at the associated device until the appropriate channel-path response, indicating that the device-command response or status has been accepted at the channel path, is sent to the device. In addition, when the device sends status to the channel path, the channel path considers this status to be in progress at the associated device only when a subsequent START SUBCHANNEL instruction is received.
path’s acceptance of that status is not recognized at the channel path until the channel path’s confirmation of acceptance is received and acknowledged by the device.

**Modification Control (M):** Bit 6 of word 1 specifies whether modification control is required for the channel program. When bit 6 is zero, modification control is specified. When bit 6 is one, modification control is not specified.

When modification control is specified, the channel subsystem forces command synchronization with the addressed I/O device each time a command is executed and the previously executed command has the PCI and chain-command flags set to one and the chain-data and suspend flags set to zero. When this condition is recognized, the channel subsystem signals a synchronization request to the I/O device for the current command. The channel subsystem temporarily suspends command chaining and does not fetch (or refetch) the next command-chained CCW until after normal ending status is received for the synchronizing command.

When modification control is not specified, then command synchronization is not required, and the channel subsystem may transfer commands to the I/O device without waiting for status.

The M bit is meaningful only for subchannels configured to FICON-I/O-interface or FICON-converted-I/O-interface channel paths and is ignored for other subchannels configured to other channel-path types.

**Programming Notes:**

1. For FICON-I/O-interface and FICON-converted-I/O-interface channel paths, modification control provides the capability to optimize dynamically modified channel programs that use the PCI flag in the CCW to initiate channel-program modification. Specifically, it allows the program to delay the channel-subsystem fetching and transferring of commands until after status is received for the command following the command with the PCI bit set. This increases the likelihood that a program-controlled interruption will be accepted by a CPU and acted upon by the program that dynamically modifies one or more command-chained CCWs that follow the synchronizing command.

In order to increase the probability that any dynamically modified CCWs are fetched after their modification and not prior to their modification, the modifying program should be executed as soon as possible following the CPU’s acceptance of the program-controlled interruption. Additionally, the program should minimize the periods during which the configured CPUs are disabled for I/O interruptions.

For channel paths other than FICON-I/O-interface or FICON-converted-I/O-interface channel paths, command synchronization is implicit in the signaling protocol between the channel subsystem and the I/O device; therefore no explicit programming action is required to force command synchronization. Regardless, the program should still attempt to accept and process program-controlled interruptions for these channel-path types in as timely a manner as possible for the same reason as stated above.

2. In order to allow the channel subsystem to optimize the execution of channel programs for FICON-I/O-interface or FICON-converted-I/O-interface channel paths, use of the modification-control facility is discouraged except for channel programs that require dynamic modification.

**Synchronization Control (Y):** Bit 7 of word 1 specifies whether synchronization control is required for the channel program. When bit 7 is zero and the prefetch-control bit, bit 9 of word 1, is one, synchronization control is specified. When bit 7 is one and bit 9 is one, synchronization control is not specified.

When synchronization control is specified, the channel subsystem forces command synchronization with the addressed I/O device whenever the current command in execution describes an input operation and the next CCW to be fetched describes an output operation. When this condition is recognized, the channel subsystem signals a synchronization request to the I/O device when the input command is transferred. The transfer of the output command is held pending at the subchannel until normal ending status, signaling the completion of the performance of the input operation by the I/O device, is received. Upon receipt of the ending status, the channel subsystem fetches (or refetches) the data associated with the output command and transfers it to the I/O device.

When synchronization control is not specified, the channel subsystem may transfer commands of the channel program without awaiting status that would
signal the completion of the I/O operation for each command.

The Y bit is meaningful only when the subchannel is configured to FICON-I/O-interface or FICON-converted-I/O-interface channel paths and the prefetch-control bit, bit 9 of word 1, is one. The Y bit is ignored for subchannels configured to other channel-path types and when the prefetch-control bit is zero.

**CCW-Format Control (F):** Bit 8 of word 1 specifies the format of the channel-command words (CCWs) that make up the channel program designated by the channel-program-address field. When bit 8 of word 1 is zero, format-0 CCWs are specified. When bit 8 is one, format-1 CCWs are specified. (See “Channel-Command Word” on page 30 for the definition of the CCW formats.)

**Prefetch Control (P):** Bit 9 of word 1 specifies whether or not unlimited prefetching of CCWs is allowed for the channel program. When bit 9 is one, unlimited prefetching of CCWs is allowed. (Unlimited prefetching of data, IDAWs, and MIDAWs, associated with the current and prefetched CCWs is always allowed.) It is model dependent whether prefetching is actually performed.

When bit 9 of word 0 is zero, no prefetching is allowed, except in the case of data chaining on output, where the prefetching of one CCW describing a data area is allowed. When bit 9 of word 0 is zero, the synchronization-control bit, bit 7 of word 1, is ignored.

Additional controls may limit the scope of prefetching.

**Initial-Status- Interruption Control (I):** Bit 10 of word 1 specifies whether or not the channel subsystem must verify to the program that the device has accepted the first command associated with a start or resume function. When the I bit is specified as one in the ORB, then, when the subchannel becomes active, indicating that the first command has been accepted for this start or resume function, the Z bit (see “Zero Condition Code (Z)” on page 12) is set to one at this subchannel, and the subchannel becomes status pending with intermediate status. Intermediate status may also be indicated in this case when the command is accepted if the first CCW contained the PCI flag set to one.

**Address-Limit-Checking Control (A):** When the address-limit-checking facility is installed, bit 11 of word 1 specifies whether or not address-limit checking is specified for the channel program. When this bit is zero, no address-limit checking is performed for the execution of the channel program, independent of the setting of the limit-mode bits in the subchannel (see “Limit Mode (LM)” on page 3). When this bit is one, address-limit checking is allowed for the channel program, subject to the setting of the limit-mode bits in the subchannel.

When the address-limit-checking facility is not installed, the address-limit-checking-control bit (A) must be zero in the ORB when START SUBCHANNEL is executed; otherwise, an operand exception is recognized.

**Suppress-Suspended-Interruption Control (U):** Bit 12 of word 1, when one, specifies that the channel subsystem is to suppress the generation of an intermediate interruption condition due to suspension if the subchannel becomes suspended. When bit 12 is zero, the channel subsystem generates an intermediate interruption condition whenever the subchannel becomes suspended during the execution of the channel program.

**Channel-Program Type Control (B):** Bit 13 of word 1 specifies the type of channel program that is designated by the channel-program-address field. When bit 13 is zero, the channel-program-address field designates a CCW channel program. When bit 13 is one, the channel-program-address field designates a TCW channel program. If the FCX facility is not installed and this bit is one, an operand exception or program-check exception is recognized.

Bit 13 also designates the layout of the ORB. When bit 13 is zero, a command-mode ORB is specified. When bit 13 is one, a transport-mode ORB is specified.

**Format-2-IDAW Control (H):** Bit 14 of word 1 specifies the format of IDAWs for CCWs that specify indirect data addressing. When bit 14 of word 1 is one, format-2 (64-bit data address) IDAWs are provided for all CCWs that have the IDAW flag set to one in the CCW. When bit 14 of word 1 is...
zero, format-1 (31-bit data address) IDAWs are provided for all CCWs that have the IDAW flag set to one in the CCW.

Programming Note: Format-2 IDAWs and MIDAWs provide the only means by which data can be transferred directly between an I/O device and storage locations with addresses greater than 2G bytes.

2K-IDAW Control (T): Bit 15 of word 1 specifies the main-storage block size for format-2-IDAW data areas. Bit 15 is meaningful only when bit 14 (format-2 IDAW control) is one and is ignored when bit 14 is zero. When bit 15 of word 1 is one, all format-2 IDAWs designate 2K-byte storage blocks. When bit 15 of word 1 is zero, all format-2 IDAWs designate 4K-byte storage blocks.

Logical-Path Mask (LPM): Bits 16-23 of word 1 are preserved unmodified in the subchannel and specify to the channel subsystem which of the logical paths 0-7 are to be considered logically available, as viewed by the program. A bit setting of one means that the corresponding channel path is logically available; a zero specifies that the corresponding channel path is logically not available. If a channel path is specified by the program as being logically not available, the channel subsystem does not use that channel path to perform clear, halt, resume, or start functions when requested by the program, except when a dedicated-allegiance condition exists for that channel path. If a dedicated-allegiance condition exists, the setting of the LPM is ignored, and a resume, start, halt, or clear function is performed by using the channel path having the dedicated allegiance.

Incorrect-Length-Suppression Mode (L): When bit 8 of word 1 is one, then bit 24 of word 1, when one, specifies the incorrect-length-suppression mode. When the subchannel is in this mode when an immediate operation occurs (that is, when a device signals the channel-end condition during initiation of the command) and the current CCW contains a non-zero value in bit positions 16-31, indication of an incorrect-length condition is suppressed. When bit 8 of word 1 is zero, the value of bit 24 is ignored by the channel subsystem, and the subchannel is in the incorrect-length-suppression mode.

Modified-CCW-Indirect-Data-Addressing Control (D): When the modified-CCW-indirect-data-addressing facility is installed, bit 25 of word 1 specifies whether the channel program may include CCWs that specify modified-CCW-indirect-data-address lists. When bit 25 of word 1 is one, the channel program may include CCWs that specify lists of quad-words each called a modified-CCW-indirect-data-address word (MIDAW). When bit 25 of word 1 is zero, the channel program may not include CCWs that specify modified-CCW-indirect-data-address lists.

When the modified-CCW-indirect-data-addressing facility is not installed, the modified-CCW-indirect-data-addressing control must be zero in the ORB when START SUBCHANNEL is executed; otherwise, an operand exception is recognized.

ORB-Extension Control (X): Bit 31 of word 1 specifies whether the ORB is extended. When bit 31 of word 1 is zero, the ORB consists of words 0-2, and words 3-7 are ignored. When bit 31 of word 1 is one, the ORB consists of words 0-7. Words 0 and 1 are described above. Words 2-7 are described below.

Reserved: Bits 26-30 of word 1 are reserved for future use and must be set to zeros. Bit 31 of word 1 must be zero if the ORB-extension facility is not installed. Otherwise, an operand exception or program-check condition is recognized.

Channel-Program Address: Bits 1-31 of word 2 specify the absolute address of the first CCW in main storage. Bit 0 of word 2 must be zero; otherwise, either an operand exception or a program-check condition is recognized. If format-0 CCWs are specified by bit 8 of word 1, then bits 1-7 of word 2 also must be zeros; otherwise, a program-check condition is recognized.

The three rightmost bits of the channel-program address must be zeros, designating the CCW on a doubleword boundary; otherwise, a program-check condition is recognized.
If the channel-program address designates a location protected against fetching or designates a location outside the storage of the particular configuration, the start function is not initiated at the device. In this situation, the subchannel becomes status pending with primary, secondary, and alert status.

**Channel-Subsystem (CSS) Priority:** When bit 31 (X) of word 1 of the ORB is one, byte 0 of word 3 contains an unsigned binary integer, called the channel-subsystem-priority number, that is assigned to the designated subchannel and used to order the selection of subchannels when either a start function or a resume function is to be initiated for one or more subchannels that are start pending or resume pending.

The specified channel-subsystem-priority number can be any number in the range of 0 to 255. The numbers 0 and 255 designate the lowest and highest priorities, respectively.

Depending on the model and the configuration:

1. Fewer than 256 priority levels may be provided. For such models, the ORB-specified priority number may be ignored, and an alternative priority number may be implicitly assigned to the subchannel when the subchannel becomes start pending.

2. When bit 31 (X) of word 1 of the ORB is zero, an implicit priority number is assigned to the subchannel.

See “Channel-Subsystem-I/O-Priority Facility” on page 29 for details about how the priority number is assigned for both of these cases.

**Control-Unit (CU) Priority:** When bit 31 (X) of word 1 of the ORB is one, byte 2 of word 3 contains an unsigned binary integer, called the control-unit-priority number, that specifies, for an associated control unit attached by a FICON channel path, the priority level that is applied at the associated control unit for all I/O operations associated with the start function.

The specified control-unit-priority number can be any integer in the range of 1 to 255. The numbers 1 and 255 designate the lowest and highest priorities, respectively. The number 0 designates that no priority is assigned to the I/O operations associated with the start function. The handling of I/O operations when the priority number is 0 depends on the control-unit model.

Also depending on the control-unit model, fewer than 255 priority levels may be supported by the control unit. See the control-unit’s System Library publication for additional information regarding the range of priority numbers supported and how this priority number is used.

The specified control-unit-priority number is ignored if any of the following conditions exists:

1. Bit 31 (X) of word 1 is zero. In this case, a control-unit-priority number of 0 is transmitted in the associated outbound frames.

2. The designated subchannel is not associated with a control unit configured to a FICON channel path.

3. The associated control unit does not provide prioritized performance of I/O operations. In this case, the control-unit-priority number in the associated outbound frames is ignored at the control unit.

4. The channel-subsystem model does not provide for the transmission of the control-unit-priority number.

5. The channel-subsystem-I/O-priority facility is not operational due to an operator action.

**Reserved:** All fields in the ORB that are defined as either "0" or "Reserved" must contain zeros when START SUBCHANNEL is executed; otherwise, either an operand exception or a program-check condition is recognized.

**Programming Notes:**

1. Bit positions of the ORB that presently are specified to contain zeros may in the future be assigned for the control of new functions.

2. The interruption parameter may contain any information, but ordinarily the information is of significance to the program handling the I/O interruption.

**Transport-Mode ORB**

This section describes the transport-mode ORB. The term operation-request block (ORB), in this section,
means an ORB in which bit 13 of word 1 (the channel-program-type control (B)) is one.

The format of the transport-mode ORB is as follows:

<table>
<thead>
<tr>
<th>Word</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Interruption Parameter</td>
</tr>
<tr>
<td>1</td>
<td>Key: 0 0 0 0 0 0 0 0 0 0 1 0 0 LPM 0 0 0 0 0 0 X</td>
</tr>
<tr>
<td>2</td>
<td>Channel-Program Address</td>
</tr>
<tr>
<td>3</td>
<td>CSS Priority, Reserved, Rsv. for Pgm., Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

![Figure 15-6. Transport-Mode Operation-Request Block](image)

The fields in the transport-mode ORB are defined as follows:

**Interruption Parameter:**  This field has the same meaning as in the ORB that designates a CCW channel program. See “Interruption Parameter” on page 2.

**Subchannel Key:**  Bits 0-3 of word 1 form the subchannel key for all fetching of TCWs, TCCBs, TIDAWS, and output data and for the storing of input data associated with the start function initiated by START SUBCHANNEL. This key is matched with a storage key during these storage references. For details, see the section “Key-Controlled Protection” on page 11.

All storage accesses to the TSB are made as if the subchannel key is zero.

**Reserved:**  All fields in the ORB that are defined as either “0” or “Reserved” must contain zeros when START SUBCHANNEL is executed; otherwise, either an operand exception or a program-check condition is recognized.

**Channel-Program Type Control (B):**  This bit has the same meaning as in the ORB that designates a CCW channel program. For the transport-mode ORB, the value of this bit is one. See “Channel-Program Type Control (B)” on page 27.

**Logical-Path Mask (LPM):**  Bits 16-23 of word 1 are preserved unmodified in the subchannel and specify to the channel subsystem which of the logical paths 0-7 are to be considered logically available, as viewed by the program. A bit setting of one means that the corresponding channel path is logically available; a zero specifies that the corresponding channel path is logically not available. If a channel path is specified by the program as being logically not available, the channel subsystem does not use that channel path to perform clear, halt, or start functions when requested by the program.

If the LPM specifies a channel path that does not support FCX, either an operand-exception or a program check may be recognized.

**ORB-Extension Control (X):**  This field has the same meaning as in the ORB that designates a CCW channel program. See “ORB-Extension Control (X)” on page 28.

**Channel-Program Address:**  Bits 1-31 of word 2 specify the absolute address of the TCW in main storage. Bit 0 of word 2 must be zero; otherwise, either an operand exception or a program-check condition is recognized.

The six rightmost bits of the channel-program address must be zeros, designating the TCW on a 64-byte boundary; otherwise, a program-check condition is recognized.

If the channel-program address designates a location protected against fetching or designates a location outside the storage of the particular configuration, the start function is not initiated at the device. In this situation, the subchannel becomes status pending with primary, secondary, and alert status.

**Channel-Subsystem (CSS) Priority:**  This field has the same meaning as in the ORB that designates a CCW channel program. See “Channel-Subsystem (CSS) Priority” on page 29.

**Reserved for Program Use (Rsv. for Pgm.):**  Byte 2 of word 3 is reserved for program use and is not checked or used by the channel subsystem.

**Programming Note:**  See the programming notes on page 29.

**Channel-Command Word**

The channel-command word (CCW) specifies the command to be executed and, for commands initiat-
ing certain I/O operations, it designates the storage area associated with the operation, the action to be taken whenever transfer to or from the area is completed, and other options.

A channel program consists of one or more CCWs that are logically linked such that they are fetched and executed by the channel subsystem in either a sequential or a nonsequential order. Sequential (contiguous) CCWs are linked by the use of the chain-data and chain-command flags, and nonsequential (noncontiguous) CCWs are linked by a CCW specifying the transfer-in-channel command.

As each CCW is executed, it is recognized as the current CCW. A CCW becomes current (1) when it is the first CCW of a channel program and has been fetched, (2) when, during command chaining, the new CCW is logically fetched, or (3) when, during data chaining, the new CCW takes over control of the I/O operation (see “Data Chaining” on page 61). When chaining is not specified, a CCW is no longer current after TEST SUBCHANNEL clears the start-function bit in the subchannel.

The location of the first CCW of the channel program is designated in the ORB that is the operand of START SUBCHANNEL. The first CCW is fetched subsequent to the execution of the instruction. The format of the CCWs fetched by the channel subsystem is specified by bit 8 of word 1 of the ORB. Each additional CCW in the channel program is obtained when the CCW is needed. Fetching of the CCWs by the channel subsystem does not affect those locations in main storage.

CCWs have either of two different formats, format 0 or format 1. The two formats do not differ in the information contained in the CCW, but they do differ in the size of the address and the arrangement of fields within the CCW.

The formats are defined as follows:

Format-0 CCW

<table>
<thead>
<tr>
<th>Cmd Code</th>
<th>Data Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
</tr>
<tr>
<td>Flags</td>
<td>/ / / / / / /</td>
</tr>
<tr>
<td>Count</td>
<td>32 40 48 63</td>
</tr>
</tbody>
</table>

Format-1 CCW

<table>
<thead>
<tr>
<th>Cmd Code</th>
<th>Flags</th>
<th>Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>16</td>
</tr>
<tr>
<td>Data Address</td>
<td>32 63</td>
<td></td>
</tr>
</tbody>
</table>

Flags

<table>
<thead>
<tr>
<th>C</th>
<th>C</th>
<th>L</th>
<th>S</th>
<th>P</th>
<th>I</th>
<th>D</th>
<th>K</th>
<th>M</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>34</td>
<td>36</td>
<td>38</td>
<td>40</td>
<td>42</td>
<td>44</td>
<td>46</td>
<td>48</td>
</tr>
</tbody>
</table>

Format-0 CCWs can be located anywhere in the first $2^{24}$ (16M) bytes of absolute storage, and format-1 CCWs can be located anywhere in the first $2^{31}$ (2G) bytes of absolute storage.

If indirect data addressing is specified and the format-2-IDAW-control bit is zero in the ORB associated with the CCW, then:

1. Bits 30 and 31 (format 0) or 62 and 63 (format 1) of the CCW must be zeros, designating a word boundary,
2. Bit 0 of the first entry of the indirect-data-address list must be zero.
3. The MIDA flag must be zero.

If indirect data addressing is specified and the format-2-IDAW-control bit is one in the ORB associated with the CCW, then:

1. Bits 29-31 (format 0) or bits 61-63 (format 1) of the CCW must be zeros, designating a doubleword boundary.

If modified indirect data addressing is specified, then:

1. The modified-CCW-indirect-data-addressing-control bit in the ORB must be one.
2. Bits 28-31 (format 0) or bits 60-63 (format 1) of the CCW must be zeros, designating a quadword boundary.

3. The CCW SKP and IDA flags must be zero.

4. The MIDAW count field must be greater than zero.

5. The combination of the MIDAW count and data-address fields must not specify the transfer of data across a 4K-byte boundary, unless skipping is in effect for the MIDAW.

6. Reserved bits in the first entry of the modified-CCW-indirect-data-address list must be zero.

When any of these requirements is not met, a program-check condition may be recognized (see “CCW Indirect Data Addressing” on page 66 and “Modified CCW Indirect Data Addressing” on page 68). Detection of this condition during data chaining causes the I/O device to be signaled to conclude the operation. When a failure to meet these requirements is detected during command chaining or subsequent to the execution of START SUBCHANNEL, the new operation is not initiated, and an interruption condition is generated.

The contents of bit positions 40-47 of a format-0 CCW are ignored.

The fields in the CCWs are defined as follows:

**Command Code:** Bits 0-7 (both formats) specify the operation to be performed.

**Data Address:** Bits 8-31 (format 0) or bits 33-63 (format 1) designate a location in absolute storage. The designated location is the first location referred to in the area designated by the CCW. Bit 32 of a format-1 CCW must be zero; otherwise, a program-check condition is recognized. If a byte count of zero is specified, this field is not checked.

When the MIDA flag is one, the data-address field must designate an absolute storage location that is on a quadword boundary; otherwise, a program-check condition is recognized.

See “CCW Indirect Data Addressing” on page 66 and “Modified CCW Indirect Data Addressing” on page 68 for information about the specification of data addresses greater than 2G bytes.

**Chain-Data (CD) Flag:** Bit 32 (format 0) or bit 8 (format 1), when one, specifies chaining of data. The bit causes the storage area designated by the next CCW to be used with the current I/O operation. When the CD flag is one in a CCW, the chain-command and suppress-length-indication flags (see below) are ignored.

**Chain-Command (CC) Flag:** Bit 33 (format 0) or bit 9 (format 1), when one, and when the CD flag and S flag are both zeros, specifies chaining of commands. The bit causes the operation specified by the command code in the next CCW to be initiated upon the normal completion of the current operation.

**Suppress-Length-Indication (SLI) Flag:** Bit 34 (format 0) or bit 10 (format 1) controls whether an incorrect-length condition is to be indicated to the program. When this bit is one and the CD flag is zero, the incorrect-length indication is suppressed. When both the CC and SLI flags are ones and the CD flag is zero, command chaining takes place, regardless of the presence of an incorrect-length condition. This bit should be specified in all CCWs where suppression of the incorrect-length indication is desired.

**Skip (SKP) Flag:** Bit 35 (format 0) or bit 11 (format 1), when one, specifies the suppression of transfer of information to storage during a read, read-backward, sense ID, or sense operation. This bit must be zero when the MIDA flag is one; otherwise, a program-check condition is recognized.

**Program-Controlled-Interruption (PCI) Flag:** Bit 36 (format 0) or bit 12 (format 1), when one, causes the channel subsystem to generate an intermediate interruption condition when the CCW containing the bit takes control of the I/O operation. When the PCI flag bit is zero, normal operation takes place.

**Indirect-Data-Address (IDA) Flag:** Bit 37 (format 0) or bit 13 (format 1), when one, specifies indirect data addressing. This bit must be zero when the MIDA flag is one; otherwise, a program-check condition is recognized.

**Suspend (S) Flag:** Bit 38 (format 0) or bit 14 (format 1), when one, specifies suspension of channel-program execution. When valid, it causes channel-program execution to be suspended prior to the execution of the CCW containing the S flag. A one value of the S flag is valid when bit 4 of word 1 of the associated ORB is one.
**Modified-Indirect-Data-Address (MIDA) Flag:** Bit 39 (format 0) or bit 15 (format 1), when one, specifies modified indirect data addressing. This bit must be zero when the modified-CCW-indirect-data-addressing-control bit in the ORB is zero, the CCW IDA flag is one, the CCW SKP flag is one, or the channel paths associated with the subchannel do not support modified CCW indirect data addressing; otherwise, a program-check condition is recognized.

**Count:** Bits 48-63 (format 0) or bits 16-31 (format 1) specify the number of bytes in the storage area designated by the CCW.

### Transport Control Word

The transport-control word (TCW) specifies a transport-command-control block (TCCB) whose contents are to be transported to the I/O device for processing. The TCCB contains one or more device-command words (DCWs) and associated options. For a DCW that specifies a command which initiates the transfer of data (with the exception of control data contained within the TCCB), the TCW designates one or more storage areas where the data is located.

When a TCW specifies bidirectional data transfer and the designated DCWs specify write data transfers for storage areas that overlap with the storage areas for read data transfers, the results are unpredictable.

When START SUBCHANNEL is issued specifying a transport-mode ORB, the TCW designated by the ORB becomes the current TCW, the subchannel becomes start pending, and the TCCB designated by the TCW is transported to the I/O device for execution. The TCW remains the current TCW until TEST SUBCHANNEL clears the start-function indication in the subchannel.

The TCW is a 64-byte control block that is designated on a 64-byte boundary. For all operations, except for the interrogate operation, accesses to the TCW by the channel subsystem are made using the subchannel storage-access key specified in the ORB. For interrogate operations, fetch accesses to the interrogate TCW by the channel subsystem are made as if a subchannel storage-access key of zero is used. The channel subsystem does not make any store accesses to a TCW.

---

**The format of the TCW is as follows:**

<table>
<thead>
<tr>
<th>Word</th>
<th>Flags</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>F</td>
</tr>
<tr>
<td>1</td>
<td>Reserved, TCCBL, RW, Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Output-Data Address</td>
</tr>
<tr>
<td>3</td>
<td>Input-Data Address</td>
</tr>
<tr>
<td>4</td>
<td>Transport-Status-Block Address</td>
</tr>
<tr>
<td>5</td>
<td>Transport-Command-Control-Block Address</td>
</tr>
<tr>
<td>6</td>
<td>Output Count</td>
</tr>
<tr>
<td>7</td>
<td>Input Count</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Interrogate-TCW Address</td>
</tr>
</tbody>
</table>

**Format (F):** Bits 0-1 of word 0 form the TCW-format that contains a 2-bit unsigned integer value that defines the layout of the TCW. The value of this field must be zero, otherwise a program-check condition is recognized.

**Reserved:** Bits 2-7 of word 0 are reserved and must be zeros, otherwise a program-check condition is recognized.

**Reserved:** Bytes 0 and 2-3 of word 1 and words 12-14 are reserved and not checked. These fields are reserved for future extensions. Programs which place nonzero values in these fields may not operate compatibly on future models.

**Flags:** Bytes 1-3 of word 0 contain information about the TCW. The meaning of each flag bit is as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-4</td>
<td>Reserved. Bits 0-4 are reserved and must be zero, otherwise a program-check condition is recognized.</td>
</tr>
</tbody>
</table>
| 5   | Input transport-indirect-data addressing (TIDA): When bit 5 is zero and bit 14 of word 1 (the R-bit) is one, the input-data-
address field designates the absolute address of the input location. When bit 5 is one and the R-bit is one, the input-data-address field designates the absolute address of a transport-indirect-data-address word (TIDAW) or the first TIDAW in a list of TIDAWS that designate the input storage location or locations, respectively.

When the R-bit is zero, bit 5 has no meaning.

6 Transport-command-control-block TIDA: When bit 6 is zero, the transport-command-control-block-address field designates the absolute address of the transport-command-control block for the TCW. When bit 6 is one, the transport-command-control-block-address field designates the absolute address of a TIDAW or list of TIDAWS that designate the location or locations, respectively, of the transport-command-control block for the TCW.

7 Output TIDA: When bit 7 is zero and bit 15 of word 1 (the W-bit) is one, the output-data-address field designates an output location in absolute storage. When bit 7 is one and the W-bit is one, the output-data-address field designates the absolute address of a TIDAW or list of TIDAWs that designate the output location or locations, respectively.

When the W-bit is zero, bit 7 has no meaning.

8-9 TIDAW format: Bits 8-9 form a 2-bit encoded field that specifies the format of TIDAWs designated by the TCW. This field must contain zeros, otherwise a program-check condition is recognized.

10-23 Reserved. Bits 10-23 are reserved and must be zero, otherwise a program-check condition is recognized.

Transport-Command-Control-Block Length (TCCBL): Bits 8-13 of word 1, with two zeros appended on the right, specify the unsigned integer whose value, when added to 20 for unidirectional data transfers or when added to 24 for bidirectional data transfers, specifies the length of the TCCB in bytes. This field, before having 20 added to it for unidirectional data transfers or before having 24 added to it for bidirectional data transfers, must specify a length that is between 12 and 244 inclusive, otherwise a program-check condition is recognized.

Note: The TCCBL is based on the FCP additional command length and does not include the TCA header (16 bytes), and the transport-count (4 bytes) in the TCA trailer for unidirectional data transfers, nor does it include the write count (4 bytes) and read count (4 bytes) in the TCA trailer for bidirectional data transfers.

Read Operations (R): When bit 14 of word 1 is one, the input count (word 11) is valid and contains a nonzero value, indicating the number of bytes to be transferred into main storage.

Write Operations (W): When bit 15 of word 1 is one, the output count (word 10) is valid and contains a nonzero value, indicating the number of bytes to be transferred from main storage.

If the R-bit and W-bit are both one and the device does not support bidirectional data transfer, and flags bit 10 is zero, a program-check condition is recognized.

If the W-bit is one and the TCW is an interrogate TCW, a program-check condition is recognized.

Output-Data Address: When bit 15 of word 1 (the W-bit) is one and bit 7 of the flags field (the output-TIDA flag) is zero, words 2-3 designate the 64-bit output location in absolute storage. When the W-bit is one and the output-TIDA flag is one, words 2-3 designate the 64-bit location in absolute storage of a TIDAW or list of TIDAWs that designate the output storage location or locations.

When the W-bit is one and the output-TIDA flag is one, words 2-3 must designate a storage location that is on a quadword boundary, otherwise a program-check condition is recognized.

When the W-bit is zero, words 2-3 have no meaning and are ignored.

Input-Data Address: When the bit 14 of word 1 (the R-bit) is one and bit 5 of the flags field (the input-TIDA flag) is zero, words 4-5 designate the 64-bit input location in absolute storage. When the R-bit is one and the input-TIDA flag is one, words 4-5 desig-
nate the location in absolute storage of a TIDAW or list of TIDAWs that designate the input storage location(s).

When the R-bit is one and the input-TIDA flag is one, words 4-5 must designate a storage location that is on a quadword boundary, otherwise a program-check condition is recognized.

When the R-bit is zero, words 4-5 have no meaning and are ignored.

Transport-Status-Block Address: Words 6-7 designate the 64-bit location in absolute storage of the transport-status block for the TCW.

Words 6-7 must designate a storage location on a doubleword boundary, otherwise a program-check condition is recognized.

Transport-Command-Control-Block Address: If the transport-command-control-block-TIDA bit (bit 6 of the flags field) is zero, words 8-9 designate 64-bit location in absolute storage of the transport-command-control block. When the transport-command-control-block-TIDA bit is zero, the transport-command-control block is specified to reside in a contiguous area of storage. If the transport-command-control-block-TIDA bit is one, words 8-9 designate the 64-bit location in absolute storage of a TIDAW or list of TIDAWs that designate the location in absolute storage of the transport-command-control block. When the transport-command-control-block-TIDA bit is one, the transport-command-control block may be specified to reside in noncontiguous areas of storage.

When the transport-command-control-block-TIDA flag is zero, words 8-9 should designate a storage location on a doubleword boundary, otherwise, degradation of performance is possible.

When the transport-command-control-block-TIDA flag is one:

- Words 8-9 must designate a storage location on a quadword boundary, otherwise a program-check condition is recognized.
- The transport-command-control-block-address and transport-command-control-block-length fields must not specify a list of TIDAWs that cross a 4K-byte boundary, otherwise a program-check condition is recognized.
- The TIDAW-transfer-in-channel (TTIC) bit should be zero in all specified TIDAWs, otherwise degradation of performance is possible.
- The first TIDAW should designate the TCCB on a doubleword boundary; otherwise, degradation of performance is possible.

Output Count: When bit 15 of word 1 (the W-bit) is one, word 10 contains the unsigned integer total count of output bytes for the TCW.

When the W-bit is one and word 10 contains zeros, a program-check condition is recognized.

When the W-bit is one:

- The output-count value, rounded upwards to the nearest multiple of 4, plus 4, should equal the value in the transport-count field in the associated TCCB for unidirectional data transfers or the value in the write-count field in the associated TCCB for bidirectional transfer, otherwise this may lead to a device-detected-program-check condition being recognized.
- The output-count value should equal the sum of the following, otherwise this may lead to a device-detected-program-check condition being recognized.
  - The sum of count field values in all of the DCWs that specify a write command.
  - The sum of the count field values in all of the transport-command DCWs that specify the transfer of transport-command-meta information (TCMI) plus the size of the reserved fields in the TCMI. (Note that the size of a TCMI reserved field may be zero. See “Transport-Command DCW” on page 42.)
  - The count of any inserted padding and CBC bytes when flags bit 7 (the output-TIDA bit) is one as follows:
    - Four bytes for the CBC information for every TIDAW designated by the output-address field for which the insert-CBC flag bit is one.
    - The count of padding bytes added for every TIDAW designated by the output-address field for which the insert-CBC
flag bit is one. (See “Transport Indirect Data Addressing” on page 70.)

When the R-bit is one and word 11 contains zeros, a program-check condition is recognized.

When the W-bit is zero, word 10 is ignored.

**Input Count:** When bit 14 of word 1 (the R-bit) is one, word 11 contains the unsigned integer total count of input bytes for the TCW.

When the R-bit is one and word 11 contains zeros, a program-check condition is recognized.

When the R-bit is one:

- The input-count value, rounded upwards to the nearest multiple of 4, plus 4, should equal the value in the transport-count field in the associated TCCB for unidirectional transfer or the value in the read-count field in the associated TCCB for bidirectional transfer, otherwise this may lead to a device-detected-program-check condition being recognized.

- The input-count value should equal the sum of count fields in all of the DCWs that specify a read-type command in the associated TCCB and any such DCWs specified in a TCA extension, otherwise this may lead to a device-detected-program-check condition being recognized.

When the R-bit is zero, word 11 is ignored.

**Interrogate-TCW Address:** When a START SUBCHANNEL designates a TCW, word 15 of the TCW is not checked. When a CANCEL SUBCHANNEL designates a subchannel that is start pending for a TCW channel program and is not status pending, bits 1-31 of word 15 of the TCW designated by START SUBCHANNEL specify the 31-bit location in absolute storage of the interrogate-TCW that is used to initiate an interrogate operation for the subchannel. If word 15 contains zeros when CANCEL SUBCHANNEL is issued, an interrogate operation is not initiated.

When CANCEL SUBCHANNEL is issued, bit 0 of word 15 must be zero, otherwise a program-check condition is recognized with interrogate-failed status indicated. When CANCEL SUBCHANNEL is issued and bits 1-31 of word 15 do not contain zeros, bits 1-31 of word 15 must designate a storage location on a 64-byte boundary, otherwise a program-check condition is recognized with interrogate-failed status indicated.

**Transport-Command-Control Block**

The transport-command-control block (TCCB) is variable in length, contains header and trailer information, and from 1 to 30 device-command words (DCWs) that are logically linked such that they are executed by the control unit in a sequential manner.

A TCCB may reside as a single block of contiguous storage or it may reside as multiple blocks of noncontiguous storage. The TCCB-TIDA flag specifies whether the TCCB resides in contiguous storage. When the flag is zero, the TCW designates a contiguous TCCB. When the flag is one, the TCW designates one or more TIDAWs that designate the location of the TCCB in noncontiguous storage.

The transport-command-control block is designated on a doubleword boundary and has a maximum length of 264 bytes. For non-interrogate operations, fetch accesses to the TCCB by the channel subsystem are made using the subchannel storage-access key specified in the ORB. For interrogate operations, fetch accesses to the interrogate TCCB by the channel subsystem are made as if a storage-access key of zero is used. The channel subsystem does not make any store accesses to a TCCB nor does it examine its contents.
The format of the TCCB is as follows:

<table>
<thead>
<tr>
<th>Word</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Transport-Command-Area Header (TCAH)</td>
</tr>
<tr>
<td>3</td>
<td>Transport-Command Area (TCA)</td>
</tr>
<tr>
<td>N</td>
<td>Transport-Command-Area Trailer (TCAT)</td>
</tr>
</tbody>
</table>

**Transport-Command-Area Header**

The transport-command-area header (TCAH) is a 16-byte control block that contains information about the transport-command area and the operations described therein. The TCAH has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Format Control</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Service-Action Code (SAC)</td>
</tr>
<tr>
<td>3</td>
<td>Priority</td>
</tr>
</tbody>
</table>

**Format Control:** Byte 0 of word 0 is the TCCB format control. The value of this field must be 7F hex, otherwise a device-detected-program-check is recognized.

**Reserved:** Byte 1 of word 0 is reserved and must contain zeros, otherwise a device-detected-program-check condition may be recognized. Bytes 2-3 of word 0, bytes 0-2 of word 1, byte 2 of word 2, and bytes 0-3 of word 3 are reserved and should contain zeros, otherwise the channel program may not operate compatibly in the future.

**Transport-Command-Area Length (TCAL):** Byte 3 of word 1 specifies an 8-bit unsigned integer whose value, when reduced by 12, specifies the length of the TCA in bytes. The specified value must be a non-zero multiple of 4 that is between 20 and 252, inclusive, otherwise a device-detected-program-check condition may be recognized.

**Service-Action Code (SAC):** Bytes 0-1 of word 2 contain an unsigned integer value that must be either 1FFE hex or 1FFF hex. The meanings of these values is device dependent.

**Priority:** Byte 3 of word 2 contains the 8-bit unsigned binary integer priority value for the TCCB. A value of zero indicates that no priority has been assigned. Valid priority values range from 1, the lowest priority, to 255, the highest priority.

**Transport-Command Area**

The transport-command area (TCA) is a variable-length area that contains from 1 to 30 device-command words (DCWs). The length of the TCA is an integral number of words.

For DCWs that specify control data, the TCA also contains the control data associated with the commands. Each DCW that specifies control data, reduces the maximum-DCW capacity by one or more DCWs, depending on the size of the command-associated data.

For DCWs that specify input or output data, the TCW specifying the TCCB designates the associated storage area or areas (see “Input-Data Address” on page 34 and “Output-Data Address” on page 34) and the DCW designates the count of bytes to transfer.

For some devices, the list of DCWs may be extended past what will fit in the TCA. For such devices, the TCA extension (TCAX) is specified and transferred as if it were output data; however, the TCAX is treated as a logical continuation of the TCA instead of transfer data. (See “Transport-Command-Area Extension” on page 45.) A TCAX is specified by the transfer-TCA-extension DCW. (See “Transfer-TCA-Extension DCW” on page 44.)

Whether a device supports TCA extensions is determined by device-dependent means.
The maximum size of the TCA is 240 bytes. The TCA has the following format:

<table>
<thead>
<tr>
<th>Word (from the beginning of the TCA)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>1</td>
</tr>
<tr>
<td>2</td>
</tr>
<tr>
<td>N</td>
</tr>
</tbody>
</table>

*Figure 15-10. Transport-Command Area (TCA)*

**Device-Command Word**

A device-command word (DCW) specifies a command to be executed. For commands initiating certain I/O operations, it designates the count of bytes on which the operation is performed, the action to be taken whenever transfer to or from storage is completed, and other options. The storage area or areas associated with a DCW data-transfer operation are designated, depending on the operation specified by the command, by the input-data-address field or the output-data-address field of the TCW that designates the transport-control-block containing the DCW. Whether the input-data-address field or the output-data-address field of the TCW designates the storage directly or indirectly, by use of a TIDAW list, is specified by the input-TIDA and output-TIDA flags in the TCW, respectively.

For commands initiating control operations, the associated data immediately follows the command. If this data is not a multiple of 4 bytes, the field immediately following the data begins on the next word boundary that immediately follows the last byte of specified data. In the TCA, this field will be either the next DCW, if additional DCWs are specified, or the transport-command-area trailer, if additional DCWs are not specified. When the DCW is in a transport-command-area extension (TCAX), this field will be one of the following:

- The next DCW when additional DCWs are specified.
- The TCAX reserved area when present, and additional DCWs are not specified.
- The end of the TCAX when the TCAX reserved area is not present and additional DCWs are not specified.

As each DCW is executed and while it is executing it is recognized as the current DCW. A DCW becomes current when it is the first DCW of a channel program and has been selected by the I/O device for execution or when, during command chaining, the subsequent DCW takes over control of the I/O operation.

The first DCW to be executed is at offset zero of the TCA in the TCCB. Each additional DCW in the channel program is also in the TCA and is used when the DCW is needed by the I/O device.

The DCW is an 8-byte control block that is designated on an word boundary. The format of the DCW is as follows:

<table>
<thead>
<tr>
<th>Word</th>
<th>Cmd Code</th>
<th>Flags</th>
<th>Reserved</th>
<th>CD Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8 9 10 11</td>
<td>15</td>
<td>8 9 10 11</td>
<td>15</td>
</tr>
</tbody>
</table>

*Figure 15-11. Device-Command Word (DCW)*

**Command Code**: Bits 0-7 of word 0 specify the operation to be performed.

Whether a command is valid is device dependent and dependent on the value of the service-action-code field in the TCAH.

**Reserved**: Bits 8, 11-15, and 16-23 of word 0 are reserved and should contain zeros, otherwise the channel program may not operate compatibly in the future. When the FCX-incorrect-length-indication facility is not installed or the device does not support incorrect-length indication, bit 10 of word 0 is reserved and should contain zero, otherwise the
channel program may not operate compatibly in the future.

**Chain-Command (CC) Flag:** Bit 9 of word 0, when one, specifies the chaining of commands. When one, the bit causes the operation specified by the next DCW to be initiated upon normal completion of the current DCW. When the control-data count is zero, the next DCW immediately follows the DCW in the TCA or TCAX. When the control-data count is not zero, the next DCW immediately follows the control-data, rounded to a word boundary, specified for the DCW.

If bit 9 of word 0 is one in a DCW whose offset, plus 8, plus its control-data-count value leaves less than 8 bytes in the TCA and a TCAX is not specified, a device-detected-program-check condition may be recognized.

If bit 9 of word 0 is one in a DCW whose offset, plus 8, plus its control-data-count value leaves less than 8 bytes in the TCAX, a device-detected-program-check condition may be recognized.

If bit 9 of word 0 is zero in a DCW whose offset, plus 8, plus its control-data-count value leaves greater than 3 bytes remaining in the TCA, a device-detected-program-check condition may be recognized.

**Note:** When the chain-command flag is one, the next DCW location in the TCA or TCAX is determined by adding eight and the value in the CD-count field to the location of the current DCW and rounding upwards to the nearest word boundary. If the chain-command flag is one in a DCW in a TCA, the next DCW location is past the end of the TCA, and a TCAX is specified, the next DCW is at the beginning of the TCAX.

**Suppress-Length-Indication (SLI) Flag:** When the FCX-incorrect-length-indication facility is installed and the device supports incorrect-length indication, bit 10 of word 0 controls whether an incorrect-length condition is to be indicated to the program when the condition is recognized for the DCW in control as follows:

- When the SLI flag is one, incorrect-length indication is suppressed. When both the CC and SLI flags are ones, command chaining takes place, regardless of the presence of an incorrect-length condition. This bit should be specified as one in all DCWs where suppression of the incorrect-length indication is desired.

  - When the SLI flag is not one, processing of the TCA is terminated (command-chaining is terminated) and the subchannel is made status pending with incorrect length indicated in the subchannel status.

When an incorrect-length condition exists for a DCW and the SLI flag in the DCW is set to zero, data transfer occurs as follows for read operations:

  - If the DCW count is greater than the amount of data available at the device for the command, the data available at the device is transferred.

  - If the DCW count is less than the amount of data available at the device for the command, only an amount of data equal to the DCW count is transferred.

When an incorrect-length condition exists for a DCW and the SLI flag in the DCW is set one, data transfer occurs as follows for read operations:

  - If the DCW count is greater than the amount of data available at the device for the command and the DCW chain-command (CC) flag is one, the following occurs in order:

    1) The data available at the device is transferred.

    2) Pad bytes of zeros are transferred until the total amount transferred is equal to the DCW count.

  - If the DCW count is greater than the amount of data available at the device for the command and the DCW chain-command (CC) flag is zero, the following occurs in order:

    1) The data available at the device is transferred.

    2) Depending on the device, either data transfer is terminated or pad bytes of zeros are transferred until the total amount transferred is equal to the DCW count.

  - If the DCW count is less than the amount of data available at the device for the com-
mand, only an amount of data equal to the DCW count is transferred.

When an incorrect-length condition exists for a DCW, data transfer occurs as follows for write operations regardless of the setting of the SLI flag:

- If the DCW count is greater than the amount of data required by the device for the command and the DCW chain-command (CC) flag is one, the following occurs in order:
  1) The data required by the device is transferred.
  2) Data continues to be transferred until the total amount transferred is equal to the DCW count. Data not required by the device is discarded.

- If the DCW count is greater than the amount of data required by the device for the command and the DCW chain-command (CC) flag is zero, the following occurs in order:
  1) The data required by the device is transferred.
  2) Data continues to be transferred until the next intermediate CBC is specified to be inserted or until the total amount transferred is equal to the DCW count. Data not required by the device is discarded.

- For write operations, if the DCW count is less than the amount of data required by the device for the command, only the amount of data specified by the DCW count is transferred.

Whether a device supports the suppression of incorrect-length indication is determined by device-dependent means.

**Control-Data (CD) Count:** When the command-code field specifies a command that requires control data, the data for the command immediately follows the DCW and byte 3 of word 0 specifies the length of the data, in bytes. If the command code specifies a command that requires control data and byte 3 of word 0 specifies a control-data count that is less than required for the command a unit-check condition is recognized. If the command code specifies a command that requires control data and byte 3 of word 0 contains zero or contains a value that specifies data past the end of the TCA or past the end of the specified TCAX, a device-detected-program-check condition is recognized.

**Count:** Word 1 specifies the 32-bit unsigned integer count of bytes in the storage area designated by the TCW for this DCW.

**Transport-Command-Area Trailer**
The transport-command-area trailer (TCAT) contains additional information about the TCCB. When uni-directional data transfer is specified (either the R-bit or the W-bit is set to one) or no data transfer is specified (both the R-bit and W-bit in the TCW are set to zero), the TCAT is two words in length. When bidirectional data transfer is specified (both the R-bit and the W-bit in the TCW are set to one), the TCAT is three words in length. The TCAT has the following format:

**Word (from the beginning of the TCA trailer)**

<table>
<thead>
<tr>
<th>Word</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Transport Count or Write Count</td>
</tr>
<tr>
<td>2</td>
<td>Not Present or Read Count</td>
</tr>
</tbody>
</table>

*Figure 15-12. Transport-Command-Area Trailer (TCAT)*

**Reserved:** Word 0 is reserved and not checked.

**Transport Count:** When uni-directional data transfer is specified, word 1 is the transport count and specifies the 32-bit unsigned integer count of total data to be transferred.

When a read operation is specified (the TCW R-bit is one), the value in the transport-count field in the TCAT is determined as follows, otherwise a device-detected-program-check condition may be recognized:

- The count field values in the DCWs that each specify a read-type command are summed.
- The sum is rounded upwards to the nearest multiple of 4.
- The rounded sum is increased by 4 giving the transport-count value.

When a read operation is specified, the transport-count value should be equal to the value in the TCW input-count field, rounded upwards to the next multiple of 4, plus 4, otherwise a device-detected-program-check condition may be recognized.
When a write operation is specified (the W-bit in the TCW is one), the value in the transport-count field in the TCAT is determined as follows, otherwise a device-detected-program-check condition may be recognized:

- The count field values in the DCWs that each specify a write command are summed.
- The count field values in all of the transport-command DCWs that specify the transfer of transport-command-meta information (TCMI) plus the size of the reserved fields in the TCMI are added to the sum. (Note that the size of a TCMI reserved field may be zero. See “Transport-Command DCW” on page 42.)

- The total of the counts of any TIDAW-specified CBC bytes and padding bytes (see “Transport Indirect Data Addressing” on page 70) is added to the sum.
- The sum is rounded upwards to the nearest multiple of 4.
- The rounded sum is increased by 4 giving the transport-count value.

The write-count value should be equal to the value in TCW output-count field, rounded upwards to the next multiple of 4, plus 4, otherwise a device-detected-program-check condition may be recognized.

**Write Count:** When bidirectional data transfer is specified, word 1 is the write count and specifies the 32-bit unsigned integer count of total output data to be transferred. The value in the write-count field in the TCAT is determined as follows, otherwise a device-detected-program-check condition may be recognized:

- The count field values in the DCWs that each specify a write command are summed.

**Programming Note:** The following table summarizes the determination of the TCW input-count, output-
count, and the TCCB transport count values for unidirectional data transfers:

<table>
<thead>
<tr>
<th>Operation</th>
<th>TCW Input Count</th>
<th>TCW Output Count</th>
<th>TCAT Transport Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input operation (TCW R-bit is 1)</td>
<td>Sum of DCW count values in the TCA.</td>
<td>n/a</td>
<td>Sum of DCW count values in TCA, rounded to four,(^2) plus four(^2)</td>
</tr>
<tr>
<td>Output operation (TCW W-bit is 1), TIDAWS not used (TCW output-TIDA flag is 0)</td>
<td>n/a</td>
<td>Sum of DCW count values in TCA.</td>
<td>Sum of DCW count values in TCA, rounded to four,(^2) plus four(^2)</td>
</tr>
<tr>
<td>Output operation (TCW W-bit is 1), TIDAWS used (TCW output-TIDA flag is 1)</td>
<td>n/a</td>
<td>Sum of DCW count values in TCA and TCAX plus the size of the reserved areas in any specified TCMIs(^3), plus total of TIDAWS-specified CBC and padding bytes(^1)</td>
<td>Sum of DCW count values in TCA and TCAX, plus the size of the reserved areas in any specified TCMIs(^3), plus total of TIDAWS-specified CBC and padding bytes,(^1) rounded to four,(^2) plus four(^2)</td>
</tr>
</tbody>
</table>

Explanation:
1. See the description of the insert-CBC control in “Flags” on page 70.
2. The channel subsystem adds a CBC word to the end of the last data transported. Up to 3 padding bytes are added after the last data transported to ensure the added CBC word is on a word boundary.
3. Because of alignment requirements, the size of the reserved area in a TCI is either 0 or 4.

Figure 15-13. Determination of the TCAT Transport Count, TCW Input Count, and TCW Output Count for Uni-Directional Data Transfers

The following table summarizes the determination of the TCW input-count, output-count, and the TCCB read and write count values for bidirectional data transfers:

<table>
<thead>
<tr>
<th>Operation</th>
<th>TCW Input Count</th>
<th>TCW Output Count</th>
<th>TCAT Read Count</th>
<th>TCAT Write Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input operation (TCW R-bit is 1) and output operation (TCW W-bit is 1), TIDAWS not used (TCW output-TIDA flag is 0)</td>
<td>Sum of read DCW count values in the TCA and TCAX.</td>
<td>Sum of write DCW count values in the TCA, plus count values in DCWs that specify the transfer of TCI</td>
<td>Sum of read DCW count values in the TCA and TCAX, rounded to four,(^2) plus four(^2)</td>
<td>Sum of write DCW count values in the TCA and TCAX, plus count values in DCWs that specify the transfer of TCI, rounded to four,(^2) plus four(^2)</td>
</tr>
<tr>
<td>Input operation (TCW R-bit is 1) and output operation (TCW W-bit is 1), TIDAWS used (TCW output-TIDA flag is 1)</td>
<td>Sum of read DCW count values in the TCA and TCAX.</td>
<td>Sum of write DCW count values in the TCA and TCAX, plus count values in DCWs that specify the transfer of TCI, plus the size of the reserved areas in any specified TCMIs(^3), plus total of TIDAWS-specified CBC and padding bytes.(^1)</td>
<td>Sum of read DCW count values in the TCA and TCAX, rounded to four,(^2) plus four(^2)</td>
<td>Sum of write DCW count values in the TCA and TCAX, plus count values in DCWs that specify the transfer of TCI, plus the size of the reserved areas in any specified TCMIs(^3), plus total of TIDAWS-specified CBC and padding bytes,(^1) rounded to four,(^2) plus four(^2)</td>
</tr>
</tbody>
</table>

Explanation:
1. See the description of the insert-CBC control in “Flags” on page 70.
2. The channel subsystem adds a CBC word to the end of the last data transported. Up to 3 padding bytes are added after the last data transported to ensure the added CBC word is on a word boundary.
3. Because of alignment requirements, the size of the reserved area in a TCI is either 0 or 4.

Figure 15-14. Determination of the TCAT Transport Count, TCW Input Count, TCAT Read Count, and TCAT Write Count for Bidirectional Data Transfers

Transport-Command DCW
A transport-command DCW specifies a transport command that performs a device-support function associated with transport-mode operations. (See “Command Code” on page 57.) A transport-command DCW may specify control data and may also specify the transfer of transport-command-meta information (TCMI).

When a transport-command DCW specifies the transfer of TCMI to a device, the TCMI is transferred as output data. The size of the TCMI is command-
dependent and is a multiple of 4. Furthermore, the TCMI may be extended by 4 reserved bytes when all of the following are true:

- The size of the TCMI is an even multiple of 4.
- TIDAWs are used to specify the output storage areas.
- The insert-CBC flag is one in the last TIDAW used to specify the storage containing the TCMI.
- The chain-command bit is one in the transport-command DCW that specifies the TCMI.
- A subsequent DCW specifies the transfer of a TCMI or output data.

Note that when a transport command specifies the transfer of a TCMI to a device and the TCMI is extended by 4 reserved bytes because all of the preceding conditions are met, the 4 reserved bytes are not included in the data-count value in the transport-command DCW but are included in the following:

- The count value in the last TIDAW used to specify the storage containing the TCMI.
- The output-count value in the TCW.
- The transport-count value in the associated TCCB for unidirectional data transfers or the write-count value in the associated TCCB for bidirectional transfer.

The following summarizes the transport-command DCWs and identifies the specific TCMI that may be transferred to the device:

<table>
<thead>
<tr>
<th>Transport-Command DCW</th>
<th>Transport-Command-Meta Information (TCMI)</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Transfer-CBC-Offset Block TCOB</td>
<td>CBC-Offset Block (COB)</td>
<td>15-43</td>
</tr>
<tr>
<td>Transfer-TCA Extension (TTE)</td>
<td>TCA Extension (TCAX)</td>
<td>15-44</td>
</tr>
<tr>
<td>Interrogate</td>
<td>(none)</td>
<td>15-46</td>
</tr>
</tbody>
</table>

**Explanation:**
- (none) - The transport-command DCW does not transfer TCMI.

**Figure 15-15. Summary of Transport-Command DCWs**

**Transfer-CBC-Offset-Block DCW**

For write operations, the transfer-CBC-offset-block (TCOB) DCW specifies that a CBC-offset block (COB) is transported to the device. The content of the TCOB DCW is as follows:

- The output-TIDA flag (flags bit 7) in the TCW
- The command code contains the transfer-CBC-offset-block command which is a value of 60 hex.
- The chain-command flag is one.
- When the CD-count is not zero, the COB immediately follows the TCOB DCW in the TCA and the CD-count specifies the number of CBC offsets in the COB multiplied by 4.
- When the CD-count is zero, the COB is specified as TCMI in the output data, the location of the COB is specified by the output-data-address field in the TCW, and the count field specifies the number of CBC offsets in the COB multiplied by 4.

The incorrect-length condition is not recognized for the transfer-CBC-offset-block command regardless of whether the FCX-incorrect-length-indication facility is installed and supported by the device.

When a TCOB DCW is used, a device-detected program check is recognized when any of the following conditions exist:

- A TCOB DCW is specified and a write operation is not specified (that is, the W-bit in the TCW is zero).
- A TCOB DCW is the only DCW in the TCA. (That is the chain-command flag in the TCOB DCW is zero.)
- A TCOB DCW is not the first DCW in the TCA.
- More than one TCOB DCW is specified
- The control-data-count field and the count field in the TCOB DCW both contain the value zero or both contain a value that is nonzero.
- The control-data-count field contains the value zero, the count field contains a value that is nonzero, but the value in the count field is not a multiple of 4.
- The count field contains the value zero, the control-data-count field contains a value that is nonzero, but the value in the control-data-count field is not a multiple of 4.

When a TCOB is used that specifies the COB in the output data, the following must be true; otherwise, a device-detected program check may be recognized:

- The count field must be one.
The insert-CBC control must be set to one in the last or only TIDAW that is used to transfer the COB when the transfer of a TCAX or output data or both is also specified.

When there is an odd number of CBC offsets in the COB, the total of the count fields in the TIDAWs used to the transfer the COB must specify the number of CBC offsets in the COB multiplied by 4. When there is an even number of CBC offsets in the COB, the total of the count fields in the TIDAWs used to the transfer the COB must specify the number of CBC offsets in the COB multiplied by 4, plus 4.

Whether a device recognizes the TCOB command is determined by device-dependent means.

CBC-Offset Block

The CBC-offset block (COB) is a variable-length control block that contains a list of 4-byte entries, each of which identifies the offset of a CBC specified by a TIDAW to be inserted in the output data. When the COB is specified in the output data, the offset of the CBC inserted by the TIDAW that specifies the transfer of the COB is not included in the COB.

Accesses to a CBC-offset block by the channel sub-system are treated as if a storage-access key of zero is used.

The COB has the following format:

<table>
<thead>
<tr>
<th>4-Byte Entry</th>
<th>CBC Offset 0</th>
<th>CBC Offset 1</th>
<th>...</th>
<th>CBC Offset N</th>
<th>Reserved</th>
</tr>
</thead>
</table>

(When the COB is in output data.)

**CBC Offsets:** Entries 0 through N contain CBC offsets. Each CBC offset is a 4-byte field containing a 32-bit unsigned integer value that specifies the relative offset, from the beginning of the output-data area, to a CBC that is specified to be inserted by a TIDAW. When a COB is in the TCA, the beginning of the output-data area is specified by the output-data-address field of the TCW. When a COB is in the output-data, the output-data area begins immediately after the COB.

**Reserved:** When a COB is specified in the TCA, or a COB is specified in the output data and there is an odd number of CBC offsets in the COB, there are no reserved bytes.

When a COB is specified in the output data and there is an even number of CBC offsets in the COB, the 4 bytes immediately following the last CBC offset are reserved and should contain zeros, otherwise unpredictable results may result.

See “Transport-Command DCW” on page 42 for the handling of reserved bytes when calculating the DCW count, TIDAW count, TCCB write-count (for bidirectional transfers) and TCCB transport count (for unidirectional data transfers).

**Programming Note:** When a device indicates that it supports the TCOB command and TIDAWs are used that specify insert-CBC, a TCOB and COB should be used; otherwise, unpredictable results or errors may result.

**Transfer-TCA-Extension DCW**

The transfer-TCA-extension (TTE) DCW specifies that the TCA is logically extended in the output data and that the TCA extension (TCAX) is transported to the device. The content of the TTE DCW is as follows:

- The command code contains the transfer-TCA-extension command which is the value of 50 hex.
- The chain-command flag is set to one.
- The CD-count is zero.
- The count specifies the length of the TCAX as a multiple of 4.

The incorrect-length condition is not recognized for the transfer-TCA-extension command regardless of whether the FCX-incorrect-length-indication facility is installed and supported by the device.
When a TTE DCW is used, a device-detected program check is recognized when any of the following conditions exist:

- When a TCOB DCW is not specified, the TTE DCW is not the first DCW in the TCA. When a TCOB DCW is specified, the TTE DCW is not the second DCW in the TCA.
- The TTE DCW is specified and a write operation is not specified (that is, the W-bit in the TCW is zero).
- The chain-command flag in the TTE DCW is zero.
- More than one TTE DCW is specified
- The control-data-count field in the TTE DCW does not contain zero.
- The count field contains less than 8 or a value that is not a multiple of 4.
- Any of the following are true for the TCA:
  - The TCA does not contain at least one DCW that is not a transport-command DCW.
  - The TCA contains one or more DCWs that are not transport-command DCWs and the chain-command flag in the last DCW of the TCA is zero.

Whether a device recognizes the TTE command is determined by device-dependent means.

**Programming-System Note:** When a TTE DCW is used and additional TCMI and/or output data follows the TCAX, the following should be true; otherwise, a device-detected program check may be recognized:

- The output-TIDA flag (flags bit 7) in the TCW must be one.
- When TIDAWs are used for the transfer of a TCAX and for the transfer of data, the insert-CBC control must be set to one in the last or only TIDAW that is used to transfer the TCAX. When TIDAWs are used for the transfer of only the TCAX, it is not necessary to set the insert-CBC control in the last or only TIDAW.

**Transport-Command-Area Extension**

The transport-command-area extension (TCAX) is a variable-length area that is the logical continuation of the TCA. At a minimum, the TCAX contains one DCW. The length of the TCAX is an integral multiple of 4 and is specified by the TTE DCW.

For DCWs that specify control data, the TCAX also contains the control data associated with the commands.

For DCWs that specify input or output data, the associated TCW designates the associated storage area or areas (see “Input-Data Address” on page 34 and “Output-Data Address” on page 34) and the DCW designates the count of bytes to transfer.

The maximum size of the TCAX is device dependent. The TCAX has the following format:

<table>
<thead>
<tr>
<th>4-Byte Entry</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>1</td>
</tr>
<tr>
<td>2</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>N</td>
</tr>
<tr>
<td>Y</td>
</tr>
</tbody>
</table>

**Explanation:**

The size of the TCAX is $4(Y+1)$, where $Y$ is an even number that is equal to either $N$ or $N+1$.

*Figure 15-17. Transport-Command Area Extension (TCAX)*

**Device-Command Word (DCW) or Control Data for Previous DCW:** For information about DCWs and control data, see “Device-Command Word” on page 38.

**Reserved:** When the last information in the TCAX is a DCW, the end of the DCW defines the end of the meaningful information in the TCAX. When the last information in the TCAX is control data and the control data ends on a 4-byte boundary, the end of the control data defines the end of the meaningful information in the TCAX. When the last information in the TCAX is control data and the control data does not end on a 4-byte boundary, padding bytes are appended to the control data to reach a 4-byte
boundary and the end of the padding bytes define the end of the meaningful information in the TCAX.

When the size of the meaningful information in the TCAX divided by four is an odd number, there are no reserved bytes; otherwise, the four bytes immediately following the meaningful information in the TCAX are reserved and should contain zeros, otherwise unpredictable results may result.

See “Transport-Command DCW” on page 42 for the handling of reserved bytes when calculating the DCW count, TIDAW count, TCAT write-count (for bidirectional transfers) and TCAT transport count (for unidirectional data transfers).

**Interrogate TCCB**

The interrogate TCCB is a TCCB that specifies a service-action code value of 1FFF hex, contains a TCA that is at least 8 bytes in length that specifies an interrogate DCW, and may specify a read operation.

Any data that immediately follows the interrogate DCW and is specified by a nonzero CD-count in the interrogate DCW is transported to the device and may be written to a device-dependent log. Any input data that is specified by the interrogate TCW is device-dependent data and is transferred from the I/O device.

Accesses to the interrogate TCCB by the channel subsystem are treated as if a storage-access key of zero is used.

The format of the interrogate TCA is as follows:

**Interrogate DCW**

Words 0 and 1 of the interrogate TCA contain a DCW that specifies an interrogate operation. The content of the interrogate DCW is as follows:

- The command code contains the interrogate command which is a value of 40 hex.
- The CD-count field must contain a value that is not greater than 232, otherwise a device-detected-program-check condition is recognized with interrogate-failed status indicated in the subchannel-extended-status field of the IRB.
- With the exceptions of the command code, SLI flag, count and CD-count fields, all other fields in the DCW must contain zeros, otherwise a device-detected-program-check condition is recognized with interrogate-failed status indicated in the subchannel-extended-status field of the IRB.

The incorrect-length condition is not recognized for the interrogate command regardless of whether the FCX-incorrect-length-indication facility is installed and supported by the device.

**Interrogate Data**

If the CD-count of the interrogate DCW is greater than zero, interrogate data is specified. Since interrogate data is for device-dependent logging purposes only, interrogate data that is incorrectly specified does not cause any exception condition to be recognized. The interrogate data has the following format:

**Format:** Byte 0 of word 0 contains the unsigned integer value that defines the layout of the interrogate data. The value of this field should be zero, otherwise the I/O device may not recognize the layout of the interrogate data.
**Reason Code (RC):** Byte 1 of word 0 contains the unsigned integer value that indicates the reason the interrogate operation was initiated. The following values may be specified. The meaning of RC values is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Interrogate reason not specified.</td>
</tr>
<tr>
<td>1</td>
<td>Timeout: Program-detected timeout for the operation being interrogated.</td>
</tr>
<tr>
<td>2-255</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

**Reason-Code Qualifier (RCQ):** Byte 2 of word 0 contains the unsigned integer value that indicates additional information about the reason the interrogate operation was initiated.

When the reason-code field contains the value one, the meaning of RCQ values are as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Interrogate reason qualifier not specified.</td>
</tr>
<tr>
<td>1</td>
<td>Primary: The timeout was specified by the primary program.</td>
</tr>
<tr>
<td>2</td>
<td>Secondary: The timeout was specified by a secondary program.</td>
</tr>
<tr>
<td>3-255</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

When the reason-code field does not contain the value one, the reason-code-qualifier field has no meaning.

**Logical-Path Mask (LPM):** Byte 3 of word 0 contains the LPM that was used when the operation being interrogated was initiated by START SUB-CHANNEL.

**Path-Available Mask (PAM):** Byte 0 of word 1 contains the value of the PAM at the time the interrogate operation is initiated.

**Path-Installed Mask (PIM):** Byte 1 of word 1 contains the value of the PAM at the time the interrogate operation is initiated.

**Timeout:** When the RC field contains the value one or two, bytes 2-3 of word 1 contain the timeout interval used by the designated program, in unsigned integer seconds.

**Flags:** Byte 0 of word 2 contains information about the interrogate. The meaning of each flag bit is as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Multipath mode: This bit has the same setting as the multipath-mode bit (D) at the time the interrogate operation is initiated.</td>
</tr>
<tr>
<td>1</td>
<td>Program path recovery: The interrogate is issued during path recovery by the program.</td>
</tr>
<tr>
<td>2</td>
<td>Critical: The device is a critical device for the program.</td>
</tr>
<tr>
<td>3-7</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

**Reserved:** Bytes 1-3 of word 2 and word 3 are reserved.

**Time:** Words 4-5 contain the time the interrogate operation was initiated.

**Program Identifier:** Words 6-7 identify the program initiating the interrogate operation. The content of this field is program dependent.

**Program-Dependent Data:** Words 8-N contain program-dependent information.

**Programming Notes:**

1. It is assumed that the program will specify the value in the time field as UTC in the same form as the TOD clock.

2. If the interrogate operation does not complete within a model-dependent amount of time, an interface-control check condition is recognized, terminating the I/O operation being interrogated.

3. If a timeout value is specified and the timeout value is less than a device-dependent minimum, the I/O device may not write the interrogate data into its log.

**Transport Status Block**

When the TSB-valid bit in the IRB is one, the transport-status block (TSB) for the I/O operation may contain additional information about the completion of the associated TCW channel program. When the
the interrogate-complete (Q) bit in the IRB is one, the interrogate TSB may contain interrogate data.

The TSB is 64 bytes in length and is allocated on a doubleword boundary. Accesses to the TSB by the channel subsystem are treated as if a storage-access key of zero is used.

The format of the TSB is as follows:

<table>
<thead>
<tr>
<th>Word</th>
<th>Length</th>
<th>Flags</th>
<th>DCW Offset</th>
<th>Count</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>3</td>
<td>0</td>
<td>3</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

Figures 15-20, 15-21. Transport-Status Block

Transport-Status Header (TSH)
The transport-status header is a 12-byte control block that contains information about the transport status. The format of the TSH is as follows:

<table>
<thead>
<tr>
<th>Word (from the beginning of the TSB)</th>
<th>Length</th>
<th>Flags</th>
<th>DCW Offset</th>
<th>Count</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>3</td>
<td>0</td>
<td>3</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

Figures 15-20, 15-21. Transport-Status Header (TSH)

**Length:** Byte 0 of word 0 contains the unsigned binary integer length, in bytes, of the status information stored in the TSB. This length includes the TSH and the transport-status area (TSA), if present. If this value is less than 64, the difference between the length value and 64 specifies the number of bytes, at the end of the TSB, that are not used, have no meaning, and may or may not be stored.

**Flags:** Byte 1 of word 0 contains information about the TSB. The meaning of each flag bit is as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>DCW-offset field valid. When bit 0 is one, the DCW-offset field contains a DCW-offset value. When bit 0 is zero, the DCW-offset field has no meaning.</td>
</tr>
<tr>
<td>1</td>
<td>Count field valid. When bit 1 is one, the count field contains a count value. When bit 1 is zero, the count field has no meaning.</td>
</tr>
<tr>
<td>2</td>
<td>Cache miss. When flag bits 4-7 specify an I/O-status TSB and bit 2 is one, one or more I/O-device cache misses occurred during the I/O operation. When flag bits 4-7 specify an I/O-status TSB and bit 2 is zero, no cache misses occurred.</td>
</tr>
<tr>
<td>3</td>
<td>Time fields valid. When flag bits 4-7 specify an I/O-status TSB and bit 3 is one, the device-time, defer-time, queue-time, device-busy-time, and device-active-only time fields in the I/O-status TSA contain time information. When flag bits 4-7 specify an I/O-status TSB and bit 3 is zero, the contents of the device-time, defer-time, queue-time, device-busy-time, and device-active-only time fields in the I/O-status TSA have no meaning.</td>
</tr>
<tr>
<td>4</td>
<td>Reserved.</td>
</tr>
<tr>
<td>5-7</td>
<td>TSA format. Bits 5-7 form a 3-bit unsigned integer that indicates the layout of the TSA as follows:</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>TSA contents have no meaning: The other fields of the TSA do not contain meaningful data.</td>
</tr>
<tr>
<td>1</td>
<td>I/O Status TSA: The TSA contains ending status in addition to ending status in the IRB for the I/O operation.</td>
</tr>
<tr>
<td>2</td>
<td>Device-detected-program-check TSA: The TSA contains information describing the reason for the device-detected program check.</td>
</tr>
<tr>
<td>3</td>
<td>Interrogate TSA: The TSA contains interrogate response information.</td>
</tr>
</tbody>
</table>
** Reserved.

**DCW Offset:** When bit 0 of the flags field (the DCW-offset-field-valid bit) is one and the DCW-offset value is less than the size of the TCA, bytes 2-3 of word 0 contain the byte offset, from the beginning of the TCA to the DCW either partially or completely executed when the TSB is stored. When bit 0 of the flags field is one and the DCW-offset value is greater than or equal than the size of the TCA, the value in bytes 2-3 of word 0 minus the size of the TCA is the offset, from the beginning of the TCAX to the DCW either partially or completely executed when the TSB is stored.

If the channel program cannot be completed, this offset identifies the DCW for which processing could not be completed. Additional information in the IRB and TSB may be used for recovery purposes. When bit 0 of the flags field is zero, bytes 2-3 of word 0 have no meaning.

**Count:** When bit 1 of the flags field (the count-field-valid bit) is one, word 1 contains the residual count for the DCW designated by the DCW-offset field.

**Reserved:** Word 2 is reserved and contains zeros.

**Programming Note:** If the program sets the length and flags fields to zeros before initiating an operation, the program can determine whether the TSB contains meaningful information after the operation completes by checking that both the length and flags field contain nonzero values.

**I/O-Status TSA**

When the TSB-format field in the TSH contains one, the TSA has the following format:

<table>
<thead>
<tr>
<th>Word (from the beginning of the TSA)</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Device Time</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Defer Time</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Queue Time</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Device-Busy Time</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Device-Active-Only Time</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Additional Data</strong> (if present)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Figure 15-22. I/O-Status Transport-Status Area (TSA)*

**Device Time:** When bit 3 of the flags field in the TSH (the time-fields-valid flag) is one, word 0 contains the 32-bit unsigned integer total count of time intervals between when the I/O device received the information in the TCCB until the I/O device returned the information in the TSB. The resolution of the device time is such that bit 31 corresponds to one microsecond.

When bit 3 of the flags field in the TSH (the time-fields-valid flag) is zero, the contents of word 0 have no meaning.

**Defer Time:** When bit 3 of the flags field in the TSH (the time-fields-valid flag) is one, word 1 contains the 32-bit unsigned integer total count of time intervals that the I/O operation was temporarily delayed by the I/O device to perform device-dependent operations or other operations not associated with the current channel program. The resolution of the defer time is such that bit 31 corresponds to one microsecond.

When bit 3 of the flags field in the TSH (the time-fields-valid flag) is zero, the contents of word 1 have no meaning.

**Queue Time:** When bit 3 of the flags field in the TSH (the time-fields-valid flag) is one, word 2 contains the 32-bit unsigned integer total count of timer intervals that the I/O operation or portions of the operation were queued at the control unit while waiting for operations not associated with the current operation to complete. The resolution of the queue time is such that bit 31 corresponds to one microsecond.

When bit 3 of the flags field in the TSH (the time-fields-valid flag) is zero, the contents of word 2 have no meaning.

**Device-Busy Time:** When bit 3 of the flags field in the TSH (the time-fields-valid flag) is one, word 3 contains the 32-bit unsigned integer total count of time intervals that the I/O device was busy attempting to initiate a command. The resolution of the device-busy time is such that bit 31 corresponds to one microsecond.

When bit 3 of the flags field in the TSH (the time-fields-valid flag) is zero, the contents of word 3 have no meaning.

**Device-Active-Only Time:** When bit 3 of the flags field in the TSH (the time-fields-valid flag) is one,
Word 4 contains the 32-bit unsigned integer total count of time between the time that the channel-end condition existed and the time that the channel-end and device-end conditions were recognized by the device. The resolution of the device-active time is such that bit 31 corresponds to one microsecond.

When bit 3 of the flags field in the TSH (the time-fields-valid flag) is zero, the contents of word 4 have no meaning.

**Additional Data:** When the length field in the TSH contains a value greater than 32, additional data has been provided by the I/O device. The count of meaningful additional-data bytes in this field is determined by subtracting 32 from the value in the length field.

When unit check is included in the device status, any additional data provided is sense data. When unit check is not included in the device status, any additional data provided is device dependent.

**Device-Detected-Program-Check TSA**

When the TSB-format field in the TSH contains two, the TSA has the following format:

<table>
<thead>
<tr>
<th>Word (from the beginning of the TSA)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>1</td>
</tr>
<tr>
<td>4</td>
</tr>
</tbody>
</table>

**Reserved:** Bytes 0-2 of word 0 are reserved and have no meaning.

**Reason Code (RC):** Byte 3 of word 0 contains an 8-bit unsigned integer code that indicates the primary reason for the device-detected program check. The meaning of each reason code value is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No information: Byte 3 has no meaning.</td>
</tr>
</tbody>
</table>

1. **TCCB transport failure:** An invalid CBC was detected by the I/O device while transporting the TCCB. The reason-code-qualifier (RCQ) field contains additional information.

2. **Invalid CBC detected on output data:** An invalid CBC was detected while transferring output data. The RCQ field contains additional information.

3. **Incorrect TCCB length specification:** The RCQ field contains additional information.

4. **TCAH specification error:** The RCQ field contains additional information.

5. **DCW specification error:** There is an error with the DCW designated by the DCW-offset field in the TSH. The RCQ field contains additional information.

6. **Transfer-direction specification error:** The command specified by the DCW designated by the DCW-offset field in the TSH specifies a direction of data transfer that disagrees with the transfer direction specified in the TCW, or both the read-operation (R) and write-operation (W) bits in the TCW are set to one and the device does not support bidirectional data transfers. The RCQ field contains additional information.

7. **Transport-count specification error:** The RCQ field contains additional information.

8. **Two I/O operations active:** While an I/O operation is active at the device a second non-interrogate TCCB has been transported to the device for execution. The RCQ field has no meaning.

9. **CBC-offset specification error:** One or more CBC offsets in the CBC-offset block indicate that a CBC is at a location that is not recognized by the device or is not recognized for the designated DCW. The RCQ field contains additional information.
For a summary of the meanings of reason-code values and their associated reason-code-qualifier values see Figure 15-24 on page 54.

**Reason Code Qualifier (RCQ):** Words 1-4 may contain additional information about the reason for the device-detected program check as follows.

When the RC field contains the value one, only byte 0 of the RCQ field has meaning. For this case, byte 0 of the RCQ field contains an 8-bit unsigned integer code that further describes the condition indicated by the RC field and the meaning of each RCQ value is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No additional information.</td>
</tr>
<tr>
<td>1</td>
<td>TCCB transport size error: The value of the TCCBL field of the TCW that was sent to the I/O device is not equivalent to the count of bytes actually transported for the TCCB.</td>
</tr>
<tr>
<td>2</td>
<td>TCCB CBC error: An invalid CBC was detected while transferring the TCCB.</td>
</tr>
<tr>
<td>3-255</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

When the RC field contains the value two, only words 0-1 of the RCQ field have meaning as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Word 0 contains the 32-bit unsigned integer offset of the first output-data byte for which the invalid CBC was detected.</td>
</tr>
<tr>
<td>1</td>
<td>Word 1 contains the 32-bit unsigned integer offset of the last byte of the last output-data word for which the invalid CBC was detected.</td>
</tr>
<tr>
<td>2</td>
<td>Reserved-field specification error: A reserved field in the TCAH does not contain zeros.</td>
</tr>
<tr>
<td>3</td>
<td>Service-action-code-field specification error: The service-action-code field in the TCAH contains an unrecognized value or a value that is incorrect for command specified by the DCW designated by the DCW-offset field in the TSH. See “Service-Action Code (SAC)” on page 37.</td>
</tr>
<tr>
<td>4-255</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

When the RC field contains the value three, only byte 0 of the RCQ field has meaning. For this case, byte 0 of the RCQ field contains an 8-bit unsigned integer code that further describes the condition indicated by the RC field and the meaning of each RCQ value is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No additional information.</td>
</tr>
<tr>
<td>1</td>
<td>The value specified by the TCAL field is not 8 greater than the value specified by the TCCBL field in the TCW for the operation.</td>
</tr>
<tr>
<td>2</td>
<td>The value specified by the TCAL field is less than 20 or greater than 252.</td>
</tr>
<tr>
<td>3-255</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

When the RC field contains the value four, only byte 0 of the RCQ field has meaning. For this case, byte 0 of the RCQ field contains an 8-bit unsigned integer code that further describes the condition indicated by the RC field and the meaning of each RCQ value is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No additional information.</td>
</tr>
<tr>
<td>1</td>
<td>Format-field specification error: The format field contains an unrecognized value. See “Format Control” on page 37.</td>
</tr>
<tr>
<td>2</td>
<td>Reserved-field specification error: A reserved field in the TCAH does not contain zeros.</td>
</tr>
<tr>
<td>3</td>
<td>Service-action-code-field specification error: The service-action-code field in the TCAH contains an unrecognized value or a value that is incorrect for command specified by the DCW designated by the DCW-offset field in the TSH. See “Service-Action Code (SAC)” on page 37.</td>
</tr>
<tr>
<td>4-255</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

When the RC field contains the value five, only byte 0 of the RCQ field has meaning. For this case, byte 0 of the RCQ field contains an 8-bit unsigned integer code that further describes the condition indicated by the RC field and the meaning of each RCQ value is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No additional information.</td>
</tr>
<tr>
<td>1</td>
<td>Reserved-field specification error: A reserved field in the DCW does not contain zeros.</td>
</tr>
</tbody>
</table>
| 2     | Flags-field command-chaining specification error: Either of the following is true:
• The chain-command flag is one and the offset of the next DCW is such that all or part of the next DCW extends past the end of the TCA or TCAX.

• The chain-command flag is zero and more than 3 unused bytes remain in the TCA or TCAX (excluding the TCAX reserved field).

• The DCW is the last DCW in the TCA, a TCAX is not specified, and the chain-command flag is one.

• The DCW is the last DCW in the TCAX and the chain-command flag is one.

See "Chain-Command (CC) Flag" on page 39.

Control-data-count-field specification error: The CD-count field specifies control data past the end of the TCA or TCAX.

See "Control-Data (CD) Count" on page 40.

TCOB location error: The TCOB DCW is not the first DCW in the TCA

TCOB duplication error: More than one TCOB DCW is specified.

TCOB multiple-count error: The control-data-count field and the count field in the TCOB DCW both specify the value zero or both specify a nonzero value.

TCOB direction error: A TCOB DCW is specified and the write-operation (W) in the TCW is zero.

TCOB chaining error: The chain-command bit in the TCOB DCW is zero.

TCOB count-specification error: Either of the following is true:

• The count field in the TCOB is zero, the control-data-count field in the TCOB DCW is nonzero, and the count field in the TCOB specifies a value that is not an even multiple of four.

• The control-data-count field in the TCOB is zero, the count field in the TCOB DCW is nonzero, and the count field in the TCOB specifies a value that is not an even multiple of four.

TTE location error: Either of the following is true:

• A TCOB DCW is not specified and the TTE DCW is not the first DCW in the TCA.

• A TCOB DCW is specified and the TTE DCW specified is not the second DCW in the TCA.

TTE duplication error: More than one TTE DCW is specified.

TTE CD-count specification error: The control-data-count field in the TTE DCW specifies a value that is not zero.

TTE count specification error: The count field in the TTE DCW specifies a value that is less than 8 or a value that is not a multiple of 4.

TTE direction error: A TTE DCW is specified and the write-operation (W) in the TCW is zero.

TTE chaining error: The chain-command bit in the TTE DCW is zero.

TCAx specification error: A TTE DCW is specified and any of the following is true:

• The TCA does not contain at least one DCW that specifies the transfer of data (that is, at least one DCW that is not a transport-command DCW).

• The TCA contains one or more DCWs that specify the transfer of data and the chain-command flag in the last DCW of the TCA is zero.

17-255 Reserved.

When the RC field contains the value six, only byte 0 of the RCQ field has meaning. For this case, byte 0 of the RCQ field contains an 8-bit unsigned integer code that further describes the condition indicated by
the RC field and the meaning of each RCQ value is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No additional information.</td>
</tr>
<tr>
<td>1</td>
<td>Read-direction specification error: The DCW specifies an input operation, but the R-bit in the TCW used to transport the TCCB is zero.</td>
</tr>
<tr>
<td>2</td>
<td>Write-direction specification error: The DCW specifies an output operation, a TCOB operation, or a TTE operation, but the W-bit in the TCW used to transport the TCCB is zero.</td>
</tr>
<tr>
<td>3</td>
<td>Read-write-conflict specification error: Both the R-bit and the W-bit are one in the TCW used to transport the TCCB and the device does not support bidirectional data transfers.</td>
</tr>
<tr>
<td>4-255</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

When the RC field contains the value seven, only byte 0 of the RCQ field has meaning. For this case, byte 0 of the RCQ field contains an 8-bit unsigned integer code that further describes the condition indicated by the RC field and the meaning of each RCQ value is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No additional information.</td>
</tr>
<tr>
<td>1</td>
<td>Read-count specification error: The specified read-count value is incorrect for any of the following reason:</td>
</tr>
<tr>
<td></td>
<td>- For unidirectional data transfers, the TCAT transport-count specifies a value that is not equivalent to the TCW input-count value. See “Transport Count” on page 40.</td>
</tr>
<tr>
<td></td>
<td>- For bidirectional data transfers, the TCAT read-count is not equivalent to the TCW input-count value. See “Read Count” on page 41.</td>
</tr>
<tr>
<td></td>
<td>- For unidirectional data transfers, the TCAT transport-count is not equivalent to the total count of bytes specified by the DCWs in the TCA and TCAX (when specified) that specify read operations.</td>
</tr>
<tr>
<td>2</td>
<td>Write-count specification error: The specified write-count value is incorrect for any of the following reason:</td>
</tr>
<tr>
<td></td>
<td>- For unidirectional data transfers, the TCAT transport-count specifies a value that is not equivalent to the TCW output-count value. See “Transport Count” on page 40.</td>
</tr>
<tr>
<td></td>
<td>- For bidirectional data transfers, the TCAT write-count is not equivalent to the TCW output-count value. See “Write Count” on page 41.</td>
</tr>
<tr>
<td></td>
<td>- For unidirectional data transfers, the TCAT transport-count is not equivalent to the total count of bytes specified by the DCWs in the TCA and TCAX (when specified) that specify write operations.</td>
</tr>
<tr>
<td></td>
<td>- For bidirectional data transfers, the TCAT write-count is not equivalent to the total count of bytes specified by the DCWs in the TCA and TCAX that specify write operations, the transfer of a COB, and the transfer of a TCAX.</td>
</tr>
<tr>
<td>3-255</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

When the RC field contains the value nine, only words 1 of the RCQ field has meaning as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Sense Data: When the length field in the TSH contains a value greater than 32, sense data has been provided by the I/O device. The count of meaningful</td>
</tr>
</tbody>
</table>

TCAX (when specified) that specify read operations. |

- For bidirectional data transfers, the TCAT read-count is not equivalent to the total count of bytes specified by the DCWs in the TCA and in the TCAX (when specified), that specify read operations. |
sense-data bytes in this field is determined by subtracting 32 from the value in the length field.

**Summary of Reason Codes and Associated Reason-Code Qualifiers**

<table>
<thead>
<tr>
<th>Reason Code Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No information.</td>
</tr>
<tr>
<td>1</td>
<td>TCCB Transport Failure.</td>
</tr>
<tr>
<td></td>
<td><strong>Reason-Code Qualifier Byte 0 Value</strong></td>
</tr>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>2</td>
</tr>
<tr>
<td>2</td>
<td>Invalid CBC detected on output data.</td>
</tr>
<tr>
<td></td>
<td><strong>Reason-Code Qualifier</strong></td>
</tr>
<tr>
<td></td>
<td>Word 0 Value:</td>
</tr>
<tr>
<td></td>
<td>Word 1 Value:</td>
</tr>
<tr>
<td>3</td>
<td>Incorrect TCCB length specification.</td>
</tr>
<tr>
<td></td>
<td><strong>Reason-Code Qualifier Byte 0 Value</strong></td>
</tr>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>2</td>
</tr>
<tr>
<td>4</td>
<td>TCAH specification error.</td>
</tr>
<tr>
<td></td>
<td><strong>Reason-Code Qualifier Byte 0 Value</strong></td>
</tr>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>3</td>
</tr>
</tbody>
</table>

Figure 15-24 on page 54 provides a summary of the device-detected-program-check RC values and the meanings of their associated RCQ values.
<table>
<thead>
<tr>
<th>Reason Code Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>DCW specification error.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Reason-Code</strong></td>
<td><strong>Qualifier Byte 0</strong></td>
</tr>
<tr>
<td>Value</td>
<td></td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>3</td>
</tr>
<tr>
<td></td>
<td>4</td>
</tr>
<tr>
<td></td>
<td>5</td>
</tr>
<tr>
<td></td>
<td>6</td>
</tr>
<tr>
<td></td>
<td>7</td>
</tr>
<tr>
<td></td>
<td>8</td>
</tr>
<tr>
<td></td>
<td>9</td>
</tr>
<tr>
<td></td>
<td>10</td>
</tr>
<tr>
<td></td>
<td>11</td>
</tr>
<tr>
<td></td>
<td>12</td>
</tr>
<tr>
<td></td>
<td>13</td>
</tr>
<tr>
<td></td>
<td>14</td>
</tr>
<tr>
<td></td>
<td>15</td>
</tr>
<tr>
<td></td>
<td>16</td>
</tr>
<tr>
<td>6</td>
<td>Transfer-direction specification error.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Reason-Code</strong></td>
<td><strong>Qualifier Byte 0</strong></td>
</tr>
<tr>
<td>Value</td>
<td></td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>3</td>
</tr>
<tr>
<td>7</td>
<td>Transport-count specification error.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Reason-Code</strong></td>
<td><strong>Qualifier Byte 0</strong></td>
</tr>
<tr>
<td>Value</td>
<td></td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>2</td>
</tr>
<tr>
<td>8</td>
<td>Two I/O operations active.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Reason-Code</strong></td>
<td><strong>Qualifier</strong></td>
</tr>
<tr>
<td>Qualifier</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>CBC-offset-specification error.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Reason-Code</strong></td>
<td><strong>Qualifier</strong></td>
</tr>
<tr>
<td>Qualifier</td>
<td></td>
</tr>
<tr>
<td>Word 0 Value:</td>
<td>Offset of first CBC-offset entry that specifies a CBC offset that is not at a location that is recognized.</td>
</tr>
</tbody>
</table>

**Explanation:**
- Reason-code values and reason-code-qualifier values that have no meaning do not appear in this summary.
- Portions of the reason-code-qualifier field that have no meaning for a specific reason code do not appear in this summary.

*Figure 15-24. Summary of Reason-Code (RC) and Reason-Code-Qualifier (RCQ) Values in the Device-Detected-Program-Check TSA (Part 2 of 2)*
Interrogate TSA

When the TSB-format field in the TSH contains three, the TSA has the following format:

<table>
<thead>
<tr>
<th>Word (from the beginning of the TSA)</th>
<th>Format</th>
<th>Flags</th>
<th>CS</th>
<th>DS</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Figure 15-25. Interrogate Transport-Status Area (TSA)*

**Format:** Byte of word 0 contains the unsigned integer value that defines the layout of the interrogate TSA. If the value of this field is not one, the contents of the interrogate TSA are meaningless.

**Flags:** Byte 1 of word 0 contains information about the interrogate TSA. The meaning of each flag bit is as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Control-unit-state valid: When bit 0 is one, the control-unit-state field contains meaningful information. When bit 0 is zero, the control-unit-state field has no meaning.</td>
</tr>
<tr>
<td>1</td>
<td>Device-state valid: When bit 1 is one, the device-state field contains meaningful information. When bit 1 is zero, the device-state field has no meaning.</td>
</tr>
<tr>
<td>2</td>
<td>Operation-state valid: When bit 2 is one, the operation-state field contains meaningful information. When bit 2 is zero, the operation-state field has no meaning.</td>
</tr>
<tr>
<td>3-7</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

**Control-Unit State (CS):** Byte 2 of word 0 contains an 8-bit unsigned integer that indicates a current state of the control unit for the I/O device. The meaning of each value is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Busy: The control unit is busy and the device-dependent-data field may contain additional information about the busy state.</td>
</tr>
<tr>
<td>1</td>
<td>Recovery: The control unit is performing a recovery process and the device-dependent-data field may contain additional information about the recovery state.</td>
</tr>
<tr>
<td>2</td>
<td>Interrogate maximum: The control unit is executing the maximum number of interrogate operations that it supports.</td>
</tr>
<tr>
<td>3-127</td>
<td>Reserved.</td>
</tr>
<tr>
<td>128-255</td>
<td>Device-dependent meanings.</td>
</tr>
</tbody>
</table>

**Device State (DS):** Byte 3 of word 0 contains an 8-bit unsigned integer that indicates a current state of the I/O device. The meaning of this byte is:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Path-group identification: The state-dependent-information field contains information identifying a path group.</td>
</tr>
<tr>
<td>1</td>
<td>Long busy: The device is in a long-busy state. The meaning of long busy is device dependent and the device-dependent field may contain additional information about the long-busy state.</td>
</tr>
<tr>
<td>2</td>
<td>Recovery: The device is performing a recovery process and the device-dependent-data field may contain additional information about the recovery state.</td>
</tr>
<tr>
<td>3-127</td>
<td>Reserved.</td>
</tr>
<tr>
<td>128-255</td>
<td>Device-dependent meanings.</td>
</tr>
</tbody>
</table>

**Operation State (OS):** Byte 0 of word 1 contains an 8-bit unsigned integer that indicates whether an I/O operation is present at the device and, when present, the state of the operation. The meaning of this byte is as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No I/O operation is present.</td>
</tr>
</tbody>
</table>
1 An I/O operation is present and executing.
2 An I/O operation is present and waiting for completion of an I/O operation that was initiated by another configuration.
3 An I/O operation is present and waiting for completion of an I/O operation that was initiated for the same device extent.
4 An I/O operation is present and waiting to perform a device-dependent operation.
5-127 Reserved.
128-255 Device-dependent meanings.

**State-Dependent Information:** Words 2-4 may contain state-dependent information. Whether this field has meaning is designated by the CS, DS, and OS fields.

The contents of this field are device dependent. When the device places one or more bytes in this field, they are left justified.

**Device-Level Identifier:** Word 5 contains a device-dependent token that identifies the implementation level of the device.

**Device-Dependent Data:** Words 6-12 contain device dependent information. Whether this field has meaning is designated by the CS, DS, and OS fields.

When the device places one or more bytes in this field, they are left justified.

**Note:**

1. An interrogate TSA is stored only in a TSB designated by an interrogate TCW.
2. If a program-check condition is recognized for an interrogate TCCB, a device-detect-program-check TSA is stored in the TSB designated by the interrogate TCW.

**Command Code**

For CCW channel programs, the command code, bit positions 0-7 of the CCW, specifies to the channel subsystem and the I/O device the operation to be performed. For TCW channel programs, the command code, bit positions 0-7 of the DCW, specifies to the I/O device the operation to be performed.

With the exception of transport commands, the two rightmost bits or, when these bits are zeros, the four rightmost bits of the command code identify the operation to the channel subsystem. The channel subsystem distinguishes among the following operations:

- Control
- Output forward (write)
- Input forward (read, sense, sense ID)
- Input backward (read backward)
- Branching (transfer in channel)
- Interrogate
- Transport

For CCW channel programs, the channel subsystem ignores the leftmost four bits of the command code in a format-0 CCW that specifies transfer-in-channel. In a format-1 CCW that specifies transfer in channel, all bits of the command code are decoded by the channel subsystem.

For CCW channel programs, commands that initiate I/O operations (write, read, read backward, control, sense, and sense ID) cause all eight bits of the command code to be transferred to the control unit.

In command codes that initiate I/O operations, the leftmost bit positions contain modifier bits. The modifier bits specify to the device how the command is to be executed. They may, for example, cause the device to compare data received during a write operation with data previously recorded, and they may specify such attributes as recording density and parity. For the control command, the modifier bits may contain the order code specifying the control function to be performed. The meaning of the modifier bits depends on the type of I/O device and is specified in the System Library publication for the device.

The command-code assignment is listed in Figure 15-26 on page 58. The symbol x indicates that the bit position is ignored; the symbol m identifi-
fies a modifier bit.

<table>
<thead>
<tr>
<th>Code</th>
<th>Command</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxxx</td>
<td>Invalid</td>
</tr>
<tr>
<td>mmm m</td>
<td>Write¹</td>
</tr>
<tr>
<td>mmm m</td>
<td>Read²</td>
</tr>
<tr>
<td>mmm m</td>
<td>Read Backward³</td>
</tr>
<tr>
<td>mmm m</td>
<td>Control</td>
</tr>
<tr>
<td>mmm m</td>
<td>Sense</td>
</tr>
<tr>
<td>1 1 1 0</td>
<td>Sense ID</td>
</tr>
<tr>
<td>xxxx</td>
<td>Transfer in channel⁴</td>
</tr>
<tr>
<td>0 0 0 0</td>
<td>Transfer in channel⁴</td>
</tr>
<tr>
<td>mmm m</td>
<td>Invalid⁵</td>
</tr>
<tr>
<td>0 1 m m</td>
<td>Transport⁶</td>
</tr>
</tbody>
</table>

**Explanation:**
- m: Modifier bit
- x: Ignored
  - May designate control data in DCWs.
  - CCW only
  - Format-0 CCW
  - Format-1 CCW
  - Format-1 CCW with any of bits 0-3 nonzero
  - DCW only

![Figure 15-26. Command-Code Assignment](image)

Whenever the channel subsystem detects an invalid command code during the initiation of command execution for a CCW channel program, the program-check-interruption condition is generated, and channel-program execution is terminated. The command code is ignored during data chaining, unless it specifies transfer in channel.

Whenever an I/O device detects an invalid command code while executing the commands in a TCCB, a device-detected-program-check condition is recognized and channel-program execution is terminated.

### Designation of Storage Area

For CCW channel programs, the main-storage area associated with an I/O operation is defined by one or more CCWs. A CCW defines an area by specifying the address of the first byte to be transferred and the number of consecutive bytes contained in the area. The address of the first byte of data to be transferred is specified either directly in the data-address field of the CCW or indirectly in an indirect-data-address word (IDAW) or modified-indirect-data-address word (MIDAW) designated by the data-address field of the CCW. The number of bytes contained in the storage area is specified in the count field.

For TCW channel programs the main-storage area associated with an I/O operation is designated by a TCW. A TCW designates an area by specifying the address of the first byte to be transferred and the number of consecutive bytes contained in the area. The address of the first byte of data to be transferred for input operations is specified either directly in the input-data-address field of the TCW or indirectly by a transport-indirect-data-address word (TIDAW) designated by the input-data-address field of the TCW. The number of bytes contained in the storage area for input operations is specified in the input-count field. The address of the first byte of data to be transferred for output operations is specified either directly in the output-data-address field of the TCW or indirectly by a TIDAW designated by the output-data-address field of the TCW. The number of bytes contained in the storage area for output operations is specified in the output-count field. In this case, the actual number of bytes in the storage area is determined by subtracting the number of any inserted padding or CBC bytes from the output-count field value. The address of the first byte of data to be transferred into the TSB is specified in the TSB-address field of the TCW. The number of bytes contained in the storage area for the TSB is dependent on the status being returned and is a maximum of 64.

In general, for write, read, control, and sense operations, storage locations are used in ascending order of addresses. As information is transferred to or from main storage, the address from the appropriate address field is incremented, and the count from the associated count field is decremented. For command-mode operations, the read-backward operation places data in storage in a descending order of addresses, and both the count and the address are decremented. When the associated count reaches zero, the storage area defined by the CCW is exhausted.

When a subchannel is operating in transport mode, the channel subsystem may take advantage of performance optimizations and access storage locations in a non-sequential order within the storage area or areas designated by the current TCW. When a transport-mode operation is concluded, the transfer of specified data, as indicated by information in the I/O-status TSB, is complete.
Any main-storage location available to the start function can be used in the transfer of data to or from an I/O device, provided that the location is not protected against that type of reference. Format-0 CCWs can be located in any available part of the first $2^{24}$ (16M) bytes of absolute storage, and format-1 CCWs and TCWs can be located in any available part of the first $2^{31}$ (2G) bytes of absolute storage, provided that, in both cases, the location is not protected against a fetch-type reference. When the channel subsystem attempts to refer to a protected location, the protection-check condition is generated, and the device is signaled to terminate the operation.

A main-storage location is available if it is available in the configuration and access to the location is not prevented by the address-limit-checking facility. CCWs, TCWs, ISDs, TSBs, and the data they address reside in main-storage locations. If a main-storage location is not available, it is said to have an invalid address.

If the channel subsystem refers to a location that is not available, the program-check condition is generated. When the first CCW or TCW designated by the channel-program address is at an unavailable location, the start function is not initiated at the device, the status portion of the SCSW is updated with the program-check indication, the subchannel becomes status pending with primary, secondary, and alert status, and deferred condition code 1 is indicated. An invalid data address, as well as any invalid CCW address detected on chaining or subsequent to the execution of START SUBCHANNEL, causes the channel subsystem to signal the device to stop, and the I/O operation is terminated. The channel subsystem sets the incorrect-length condition if the SLI flag is not one in the CCW. No data is transferred. If the device does not request data transfer, the operation proceeds to the normal ending point.

During an output operation, the channel subsystem may fetch data from main storage before the time the I/O device requests the data. Any number of bytes specified by the current CCW or TCW may be prefetched and buffered.

When data chaining during an output operation for a CCW channel program, the channel subsystem may fetch one CCW describing a data area at any time during the execution of the current CCW. If unlimited prefetching is allowed by the setting of the prefetch-control bit in the ORB CCW channel program, any number of CCWs, IDAWs, and MIDAWs and the associated data may be prefetched by the channel subsystem. When the I/O operation uses data or CCWs from locations near the end of the available storage, such prefetching may cause the channel subsystem to refer to locations that do not exist. Invalid addresses detected during prefetching do not affect the performance of the I/O operation and do not cause error indications until the operation actually attempts to use the information. If the operation is concluded by the I/O device or by the execution of HALT SUBCHANNEL or CLEAR SUBCHANNEL before the invalid information is needed, the condition is not brought to the attention of the program.

The count field in the CCW can specify any number of bytes up to 65,535. In format-0 CCWs, the count field is always nonzero unless the command code specifies transfer in channel, in which case the count field is ignored. In format-1 CCWs, the count field may contain the value zero unless data chaining is specified or the CCW is fetched while data chaining. Whenever (1) the count field in a format-1 CCW is zero, (2) data chaining is either not specified or not in effect, and (3) data transfer is requested by the device, the device is signaled to stop, and the I/O operation is terminated. The channel subsystem sets the incorrect-length condition if the SLI flag is not one in the CCW. No data is transferred. If the device does not request data transfer, the operation proceeds to the normal ending point.

If a zero byte count is contained in a format-0 CCW that does not specify transfer in channel, or if a zero byte count is contained in a format-1 CCW that specifies data chaining or was fetched while data chaining, a program-check condition is recognized, and the subchannel is made status pending with combinations of primary, secondary, and alert status as a function of the state of the subchannel and the status received from the device.

The input-count and output-count fields in the TCW can specify any number of bytes up to $2^{32} - 8$. For input operations, the input-count field is always nonzero; otherwise, a program-check condition is recognized. For output operations, the output-count field is always nonzero; otherwise, a program-check condition is recognized.

**Note:** For a description of the storage area associated with a CCW when indirect data addressing is
used, see “CCW Indirect Data Addressing” on page 66. For a description of the storage area associated with a TCW when indirect data addressing is used, see “Transport Indirect Data Addressing” on page 70.

Programming Notes:

1. Since a format-1 CCW with a count of zero is valid, the program can use the CCW count field to specify that no data be transferred to the I/O device. If the device requests a data transfer, the device is signaled to terminate data transfer. If the SLI and chain-command flags are also specified as ones, and no unusual conditions are encountered subsequent to signaling the device to terminate data transfer, the new operation is initiated upon receipt of device end from the device.

2. If the subchannel is in the incorrect-length-suppression mode, the chain-data flag in the current CCW is zero, and the operation is performed as an immediate operation, then incorrect length is not indicated, regardless of the setting of the SLI flag.

If the subchannel is in the incorrect-length-indication mode, if the chain-data flag in the current CCW is zero, and if the operation is performed as an immediate operation, then incorrect length is indicated if the count field of the current CCW specifies a nonzero value, unless suppressed by the SLI flag of the CCW; incorrect length is not indicated, however, if the count field of the CCW specifies a value of zero.

If a new CCW that has a count field of zero is fetched during data chaining or if a CCW is fetched with the chain-data flag set to one and a count field of zero, a program-check condition is recognized by the channel subsystem.

3. Since the channel-subsystem may access storage in a non-sequential manner while a subchannel is operating in transport mode, the results may be unpredictable if the program accesses the input storage area or areas designated by a TCW before primary status is indicated.

CCW Channel Program Chaining

When the channel subsystem has completed the transfer of information specified by a CCW, it can continue performing the start function by fetching a new CCW. Such fetching of a new CCW is a form of chaining, and the CCWs belonging to such a sequence are said to be chained.

Chaining takes place between CCWs located in successive doubleword locations in storage. It proceeds in an ascending order of addresses; that is, the address of the new CCW is obtained by adding 8 to the address of the current CCW. Two chains of CCWs located in noncontiguous storage areas can be coupled for chaining purposes by a transfer-in-channel command. All CCWs in a chain apply to the I/O device that is associated with the subchannel designated by the original START SUBCHANNEL instruction.

Two types of chaining are provided for CCWs: Chaining is controlled by the chain-data (CD) and chain-command (CC) flags in conjunction with the suppress-length-indication (SLI) flag in the CCW. These flags specify the action to be taken by the channel subsystem upon the exhaustion of the current CCW and upon receipt of ending status from the device, as shown in Figure 15-27 on page 61.

The specification of chaining is effectively propagated through a transfer-in-channel command. When, in the process of chaining, a transfer-in-channel command is fetched, the CCW designated by the transfer-in-channel command is used for the type of chaining specified in the CCW preceding the transfer-in-channel command.

The CD and CC flags are ignored in a format-0 CCW specifying the transfer-in-channel command. In a format-1 CCW specifying the transfer-in-channel com-
mand, the CD and CC flags must be zeros; otherwise, a program-check condition is recognized.

### Programming Note

When bit 9 of word 1 of the ORB is one, unlimited prefetching of chained CCWs (including CCWs linked by a transfer-in-channel command) by the channel subsystem is permitted. When prefetching is allowed by the ORB, no modification of the channel program should be performed after START SUBCHANNEL is executed and before the primary interruption condition for the operation has been received unless the subchannel is currently suspended and is not resume pending.

### Data Chaining

During data chaining, the new CCW fetched by the channel subsystem defines a new storage area for the original I/O operation. If the channel path is of the parallel-I/O-interface type, the performance of the operation at the I/O device is not affected. If the channel path is of the serial-I/O-interface type, then the performance of the operation at the I/O device either is not affected or, depending on the device model, may be terminated with unit-check status. When the operation at the I/O device is not affected and all data designated by the current CCW has been transferred to main storage or to the device, data chaining causes the operation to continue, using the storage area designated by the new CCW. The contents of the command-code field of the new CCW are ignored, unless they specify transfer in channel.

Data chaining is considered to occur immediately after the last byte of data designated by the current CCW has been transferred to main storage or to the device. When the last byte of the data transfer has been placed in main storage or accepted by the device, the new CCW takes over the control of the operation. If the device sends channel end after...
exhausting the count of the current CCW but before transferring any data to or from the storage area designated by the new CCW, the SCSW associated with the concluded operation pertains to the new CCW.

If programming errors are detected in the new CCW or during its fetching, the error indication is generated, and the device is signaled to conclude the operation when it attempts to transfer data designated by the new CCW. If the device signals the channel-end condition before transferring any data designated by the new CCW, program check or protection check is indicated in the SCSW associated with the termination. The contents of the SCSW pertain to the new CCW unless the address of the new CCW is invalid, the location is protected against fetching, or programming errors are detected in an intervening transfer-in-channel command. A data address referring to a nonexistent or protected area causes an error indication only after the I/O device has attempted to transfer data to or from the invalid location.

Data chaining during an input operation causes the new CCW to be fetched when all data designated by the current CCW has been placed in main storage. On an output operation, the channel subsystem may fetch the new CCW from main storage before data chaining occurs. Any programming errors in the prefetched CCW, however, do not affect the performance of the operation until all data designated by the current CCW has been transferred to the I/O device. If the device concludes the operation before all data designated by the current CCW has been transferred, the conditions associated with the prefetched CCW are not indicated to the program. Unlimited prefetching is allowed under the control of the prefetch bit specified in the ORB. (See “Prefetch Control (P)” on page 27.) When unlimited prefetching is not allowed and an output operation is specified, only one CCW describing a data area may be prefetched. If a prefetched CCW specifies transfer in channel, only one more CCW may be fetched before the exhaustion of the current CCW.

Programming Notes:

1. If the ORB does not specify unlimited prefetching, no prefetching of CCWs is performed, except in the case of data chaining on an output operation where one CCW describing a data area may be prefetched at a time.

If the ORB for the I/O operation specifies that prefetching is allowed, any number of CCWs, IDAWs, and MIDAWs and the associated data areas may be prefetched and buffered in the channel subsystem.

The same actions for signaling errors and terminating operations take place when unlimited prefetching is allowed by the ORB as when it is not allowed. However, when unlimited prefetching is specified and an error condition is detected, both the channel subsystem and the program must recognize that the points of termination at the channel subsystem and at the I/O device may be different in terms of the channel command in execution at the point of error. The channel subsystem indicates the point of termination at the channel subsystem by storing the appropriate CCW address in word 1 of the sub-channel-status word and the point of termination at the device by storing the secondary-CCW address in word 4 of the format-0 extended-status word.

When prefetching has been specified in the ORB, the result of modifications to CCWs after START SUBCHANNEL has been executed or after self-describing channel programs have been used is unpredictable. (See note 2 for the definition of self-describing channel programs.)

2. Data chaining may be used to rearrange information as it is transferred between main storage and an I/O device. Data chaining permits blocks of information to be transferred to or from non-contiguous areas of storage, and, when used in conjunction with the skipping function, data chaining allows the program to place in main storage specified portions of a block of data.

When, during an input operation, the program specifies data chaining to a location in which data has been placed under the control of the current CCW, the channel subsystem, in fetching the next CCW, fetches the new contents of the location. This is true even if the location contains the last byte transferred under the control of the current CCW. When a channel program data-chains to a CCW placed in storage by the CCW specifying data chaining, the input block is said to be self-describing. A self-describing block contains one or more CCWs that designate storage locations and counts for subsequent data in the same input block.

The use of self-describing blocks is equivalent to the use of unchecked data. An I/O data-transfer
malfunction that affects validity of a block of information is signaled only at the completion of data transfer. The error condition normally does not prematurely terminate or otherwise affect the performance of the operation. Thus, there is no assurance that a CCW read as data is valid until the operation is completed. If the CCW thus read is in error, use of the CCW in the current operation may cause subsequent data to be placed at wrong locations in main storage with resultant destruction of its contents, subject only to the control of the protection key and the address-limit-checking facility, if used.

3. When, during data chaining, a device transfers data by using the data-streaming feature, an overrun or chaining-check condition may be recognized when a small byte-count value is specified in the CCW. The minimum acceptable number of bytes that can be specified varies as a function of the system model and system activity.

**Command Chaining**

During command chaining, the new CCW fetched by the channel subsystem specifies a new I/O operation. The channel subsystem fetches the new CCW upon the receipt of the device-end signal for the current operation. If the new CCW does not have its S flag set to one and no unusual conditions are detected, the channel subsystem initiates the new operation. The presence of the S flag set to one or unusual conditions causes command chaining to be suppressed. When command chaining takes place, the completion of the current operation does not cause an I/O interruption, and the count indicating the amount of data transferred during the current operation is not made available to the program. For operations involving data transfer, the new command always applies to the next block of data at the device.

Command chaining takes place and the new operation is initiated only if no unusual conditions have been detected in the current operation. In particular, the channel subsystem initiates a new I/O operation by command chaining upon receipt of a status byte containing only the following bit combinations: (1) device end, (2) device end and status modifier, (3) device end and channel end, and (4) device end, channel end, and status modifier. In the first two cases, channel end is signaled before device end, with all other status bits zeros. If a condition such as attention, unit check, unit exception, incorrect length, program check, or protection check has occurred, the sequence of operations is concluded, and the status associated with the current operation causes an interruption condition to be generated. The new CCW in this case is not fetched. The incorrect-length condition does not suppress command chaining if the current CCW has the SLI flag set to one.

An exception to sequential chaining of CCWs occurs when the I/O device presents the status-modifier condition with the device-end signal or channel-end and device-end signals. When command chaining is specified and no unusual conditions have been detected, or when command retry has been previously signaled and an immediate retry could not be performed, the combination of status-modifier and device-end bits causes the channel subsystem to alter the sequential execution of CCWs. If command chaining was specified, status modifier and device end cause the channel subsystem to fetch and chain to the CCW whose main-storage address is 16 higher than that of the CCW that specified chaining. If command retry was previously signaled and immediate retry could not be performed, the status causes the channel subsystem to command chain to the CCW whose storage address is 8 higher than that of the CCW for which retry was initially signaled.

When both command and data chaining are specified, the first CCW associated with the operation specifies the operation to be performed, and the last CCW specifies whether another operation follows.

**Programming Note:** Command chaining makes it possible for the program to initiate transfer of multiple blocks of data by issuing a single START SUBCHANNEL instruction. It also permits a subchannel to be set for execution of other commands, such as positioning the disk-access mechanism, and for data-transfer operations without interference by the program at the end of each operation. Command chaining, in conjunction with the status-modifier condition, permits the channel subsystem to modify the normal sequence of operations in response to signals provided by the I/O device.

**TCW Channel Program Chaining**

When the I/O device has completed a control operation or the transfer of information specified by a DCW, the device can continue by executing the next DCW that is specified. Such execution of a new DCW is a form of command chaining, and the DCWs belonging to such a sequence are said to be chained.
Command chaining is controlled by the DCW chain-command (CC) flag in the DCW. This flag specifies the action to be taken upon the exhaustion of the current DCW. Chaining takes place between successive DCWs within the TCA. When a TCAX is specified, chaining also takes place between the last DCW in the TCA and the first DCW in the TCAX, and between successive DCWs within the TCAX.

When a TCCB is transported to an I/O device and selected by the device for processing, the first DCW in the TCA becomes the current DCW and is executed by the device. When the current DCW specifies command chaining and no unusual conditions have been detected during the operation, the completion of the current DCW causes the next DCW to become the current DCW and be executed by the device. The TCA offset of the next DCW is determined by adding 8, plus the value of the control-data (CD) count field of the DCW, to the TCA offset of the current DCW and rounding upwards to the next word boundary. If a TCAX is specified and the offset of the next DCW is past the end of the TCA, chaining continues with the first DCW of the TCAX whose TCAX offset is determined by subtracting the TCA length from the calculated offset. Thus, command chaining proceeds in ascending order of TCA offsets and then TCAX offsets when a TCAX is specified.

During command chaining, the new DCW executed by the device specifies a new I/O command. When command chaining takes place, the completion of the execution of the current command does not cause an I/O interruption, and the count indicating the amount of data transferred during the current operation is not made available to the program. For operations involving data transfer, the new command always applies to the next block of data at the device.

Command chaining takes place and the new command is initiated only if no unusual conditions have been detected in the execution of the current command. In particular, the I/O device initiates a new I/O operation by command chaining upon successful completion of the current command. If a condition such as attention, unit check, unit exception, or incorrect length has occurred, the sequence of operations is concluded, and the status associated with the current operation causes an interruption condition to be generated. The new DCW in this case is not executed.

Command chaining makes it possible for the program to initiate transfer of multiple blocks of data by issuing a single START SUBCHANNEL instruction. It also permits a subchannel to be set for execution of other commands, such as positioning the disk-access mechanism, and for data-transfer operations without interference by the program at the end of each operation. For command-mode operations, command chaining, in conjunction with the status-modifier condition, permits the channel subsystem to modify the normal sequence of operations in response to signals provided by the I/O device.

**Skipping**

Skipping causes the suppression of main-storage references during an I/O operation. It is defined only for read, read-backward, sense-ID, and sense operations. Skipping is controlled by the skip flag, which can be specified individually for each CCW, MIDAW, or TIDAW. When the skip flag is one, skipping occurs; when it is zero, normal operation takes place. The setting of the skip flag is ignored in all other operations.

Skipping affects only the handling of information by the channel subsystem. The operation at the I/O device proceeds normally, and information is transferred. The channel subsystem keeps updating the count but does not place the information in main storage. Chaining is not precluded by skipping. In the case of CCW data chaining, normal operation is resumed if the skip flag in the new CCW is zero.

No checking for invalid or protected data addresses takes place during skipping.

**Programming Note:** Skipping, when combined with CCW data chaining, MIDAWs, and TIDAWs, permits the program to place in main storage specified portions of a block of information from an I/O device.

**Program-Controlled Interruption**

The program-controlled-interruption (PCI) function permits the program to cause an I/O interruption during the performance of an I/O operation. The function is controlled by the PCI flag of the CCW. Neither the value of the PCI flag nor the associated interruption request affects the performance of the current operation.

The value of the PCI flag can be one either in the first CCW designated for the current start or resume func-
tion or in a CCW fetched during chaining. If the PCI flag is one in a CCW that has become current, the subchannel becomes status pending with intermediate status, and an I/O-interruption request is generated. The point at which the subchannel becomes status pending depends on the progress of the current start or resume function as follows:

1. If the PCI flag is one in the first CCW associated with a start function or a resume function, the subchannel becomes status pending with intermediate status only after the command has been accepted.

2. If the PCI flag is one in a CCW that has become current while data chaining, the subchannel becomes status pending with intermediate status after all data designated by the preceding CCW has been transferred.

3. If the PCI flag is one in a CCW that has become current while command chaining, the subchannel becomes status pending with intermediate status as that CCW becomes current.

In all cases, if the subchannel is enabled for I/O interruptions, the point of interruption depends on the current activity in the system and may be delayed. No predictable relationship exists between the point at which the interruption request is generated because of the PCI flag and the extent to which data transfer has been completed to or from the area designated by the CCW. However, all the fields within the SCSW pertain to the same instant.

An intermediate interruption condition that is made pending because of a PCI flag remains pending during chaining if not cleared by TEST SUBCHANNEL or CLEAR SUBCHANNEL. If another CCW containing a PCI flag that is one becomes current prior to the clearing of the intermediate interruption condition, only one interruption condition is preserved.

An intermediate interruption may occur while the subchannel is subchannel-and-device active with the operation specified by the CCW causing the intermediate interruption condition or with the operation specified by a CCW that has subsequently become current. If the intermediate interruption condition is not cleared prior to the conclusion of the operation or chain of operations, the condition is indicated together with the primary interruption condition at the conclusion of the operation or chain of operations. The intermediate interruption condition may be cleared by TEST SUBCHANNEL while the subchannel is subchannel active.

If the SCSW stored by TEST SUBCHANNEL indicates that the subchannel is status pending with intermediate status and the operation or chain of operations has not been concluded (that is, the activity-control field indicates subchannel-and-device active or suspended), then the CCW-address field contains an address that is 8 higher than the address of the most recent CCW to become current and have a PCI flag that is one, or the CCW-address field contains an address that is 8 higher than the address of a CCW that has subsequently become current. Unless the SCSW also contains the primary-status bit set to one, the device-status field contains zeros, and the count is unpredictable.

Subchannel-status conditions other than PCI may be indicated when the SCSW is stored. If the subchannel is not also status pending with primary status, these conditions may or may not be indicated again. If the subchannel-status condition is detected while prefetching and the operation or chain of operations is concluded before the condition affects an operation, the condition is reset and is not indicated when the subchannel subsequently becomes status pending with primary status. If the subchannel-status condition affects an operation, the condition is indicated when the subchannel becomes status pending with primary status.

If the program-controlled-interruption condition remains pending until the operation or chain of operations is concluded at the subchannel, a single interruption request exists. When TEST SUBCHANNEL is subsequently executed, the status-control field of the SCSW stored indicates both the primary interruption condition and the intermediate interruption condition, and the PCI bit of the subchannel-status field is one.

The value of the PCI flag is inspected in every CCW except for those CCWs that specify the transfer-in-channel command. The PCI flag is ignored during initial program loading.

Programming Notes:

1. The program-controlled interruption provides a means of alerting the program to the progress of chaining during an I/O operation. It permits programmed dynamic main-storage allocation.
2. A CCW with a PCI flag set to one may, if retried because of command retry, cause multiple PCI interruptions to occur. (See “Command Retry” on page 77.)

Indirect Storage Addressing

Indirect-storage addressing (ISA) allows for storage areas designated by a channel program to be specified in noncontiguous storage. Depending on the model, more than one form of ISA facility may be installed as follows:

- CCW-indirect-data (see “CCW Indirect Data Addressing” on page 66) addressing is installed in all models.
- Modified-CCW-indirect-data (see “Modified CCW Indirect Data Addressing” on page 68) addressing may also be installed in a model.
- TCW-indirect-data-addressing (see “Transport Indirect Data Addressing” on page 70) may also be installed in a model.

Indirect-Storage Designator (ISD)

Each ISA facility description includes the definition of a facility-unique indirect-storage designator (ISD) that is used to specify a block of storage to the channel subsystem. Thus, a list of ISDs may be used to designate noncontiguous storage blocks. How the location and size of a storage block are specified and whether the specification of the storage block has boundary restrictions, size restrictions, or both is dependent on the method of ISA used. The following ISDs may be used as follows:

- Format-1 and format-2 indirect-data-address word (IDAW). See “CCW Indirect Data Addressing” on page 66.
- Modified-indirect-data-address word (MIDAW), when the modified-CCW-indirect-data-addressing facility is installed. See “Modified CCW Indirect Data Addressing” on page 68.
- Transport-indirect-data-address word (TIDAW), when the fibre-channel-extensions (FCX) facility is installed. See “Transport Indirect Data Addressing” on page 70.

CCW Indirect Data Addressing

CCW indirect data addressing permits a single channel-command word to control the transfer of data that spans noncontiguous 2K-byte or 4K-byte blocks in main storage. The use of CCW indirect data addressing also allows the program to designate data addresses above 16M bytes when using format-0 CCWs or above 2G bytes when using format-1 CCWs. CCW indirect data addressing is specified by a flag in the CCW which, when one, indicates that the data address is not used to directly address data. Instead, the address points to a list of words or doublewords, called indirect-data-address words (IDAWs), each of which contains an absolute address designating a data area in main storage.

IDAWs have either of two formats, called format 1 and format 2, as determined by the format-2-IDAW control, bit 14 of word 1 of the ORB associated with the channel program being executed. When the format-2-IDAW control is zero, the IDAW is format 1 and is a word containing a 31-bit address. When the control is one, the IDAW is format 2 and is a doubleword containing a 64-bit address. The IDAW formats are as follows:

Format-1 IDAW

<table>
<thead>
<tr>
<th>0</th>
<th>Data Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>31</td>
</tr>
</tbody>
</table>

Format-2 IDAW

<table>
<thead>
<tr>
<th>0</th>
<th>Data Address (Bytes 0-3)</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>63</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>0</th>
<th>Data Address (Bytes 4-7)</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>63</td>
</tr>
</tbody>
</table>

Bit 0 (format 1) is reserved for future use and must be zero; otherwise, a program-check condition may be recognized, as described below.

A format-1 IDAW designates a data area within a 2K-byte block of main storage and is capable of addressing storage in the range of 0 to $2^{31} - 1$.

A format-2 IDAW designates a data area within a 2K-byte or 4K-byte block of main storage, as determined by the 2K-IDAW control, bit 15 of word 1 of the ORB associated with the channel program being executed, and is capable of addressing storage in the range of 0 to $2^{64} - 1$. When the 2K-IDAW-control bit is zero, each format-2 IDAW of the designated channel
program designates a 4K-byte block of main storage. When the 2K-IDAW-control bit is one, each format-2 IDAW designates a 2K-byte data-area block. All IDAWs associated with the designated channel program must have the same IDAW format, and all of those IDAWs specify the same size of storage block.

When the indirect-data-addressing bit in the CCW is one, the data-address field of the CCW designates the location of the first IDAW to be used for data transfer for the command. Additional IDAWs, if needed for completing the data transfer for the CCW, are in successive locations in storage. The number of IDAWs required for a CCW is determined by the IDAW format as specified in the ORB, by the count field of the CCW, and by the data address in the initial IDAW. When, for example, (1) the ORB specifies format-2 IDAWs with 4K-byte blocks, (2) the CCW count field specifies 8K bytes, and (3) the first IDAW designates a location in the middle of a 4K-byte block, then three IDAWs are required.

The IDAW designated by the CCW can designate any location. Data is then transferred, for read, write, control, sense ID, and sense commands, to or from successively higher storage locations or, for a read-backward command, to successively lower storage locations, until a 2K-byte block boundary (format-1 or format-2 IDAW) or a 4K-byte block boundary (format-2 IDAW) is reached. The control of data transfer is then passed to the next IDAW. The second and any subsequent IDAWs must designate, depending on the command, the first byte, or the last byte for read backward, of a 2K-byte block (format-1 or format-2 IDAW) or a 4K-byte block (format-2 IDAW). Thus, for read, write, control, sense ID, and sense commands, such format-1 IDAWs must have zeros in bit positions 21-31, and such format-2 IDAWs must have zeros in bit positions 53-63 (2K-byte blocks) or 52-63 (4K-byte blocks). For a read-backward command, such format-1 IDAWs must have ones in bit positions 21-31, and such format-2 IDAWs must have ones in bit positions 53-63 (2K-byte blocks) or 52-63 (4K-byte blocks). If any of these rules is violated, a program-check condition is recognized.

Except for the unique restrictions on the designation of the data address by the IDAW, all other actions taken for the data address, such as for protected storage and invalid addresses, and the actions taken for data prefetching are the same as when indirect data addressing is not used.

IDAWs pertaining to the current CCW or a prefetched CCW may be prefetched. The number of IDAWs that can be prefetched cannot exceed that required to satisfy the count in the CCW that points to the IDAWs. An IDAW takes control of data transfer when the last byte has been transferred for the previous IDAW. The same actions take place as with data chaining regarding when an IDAW takes control of data transfer during an I/O operation. That is, when the count for the CCW has not reached zero, a new IDAW takes control of the data transfer when the last byte has been transferred for the previous IDAW for that CCW, even in situations where (1) channel end, (2) channel end and device end, or (3) channel end, device end, and status modifier are received prior to the transfer of any data bytes pertaining to the next IDAW.

A prefetched IDAW does not take control of an I/O operation if the count in the CCW has reached zero with the transfer of the last byte of data for the previous IDAW for that CCW. Program or access errors detected in prefetched IDAWs are not indicated to the program until the IDAW takes control of data transfer. However, when the channel subsystem detects an invalid CBC on the contents of a prefetched IDAW or its associated key, the condition may be indicated to the program, when detected, before the IDAW takes control of data transfer. For a description of the indications provided when an invalid CBC is detected on the contents of an IDAW or its associated key, see “Channel-Control Check” on page 29.

Bits 1-31 (format 1) or bits 0-63 (format 2) designate the absolute storage location of the first byte to be used in the data transfer. When format-1 IDAWs are specified, the channel subsystem forms a 64-bit absolute main-storage address by appending 33 zero bits on the left of bit 1.

When the IDAW flag of the CCW is set to one and any of the following conditions occurs:

1. Format-1 IDAWs are specified in the ORB, and the address in the CCW does not designate the first IDAW on a word boundary,
2. Format-2 IDAWs are specified in the ORB, and the address in the CCW does not designate the first IDAW on a doubleword boundary,
3. The address in the CCW designates a storage location that is not physically available,
4. Access to the storage location specified by the address in the CCW is prohibited by protection, or
5. Bit 0 (format 1 only) of the first IDAW is not zero, then, depending on the model, one of the following two actions is taken independent of the setting of the skip flag (if condition 5 above is true, action 2 must be taken).

1. The above conditions are checked before initiating the operation at the device. If any of these conditions is recognized, initiation of the I/O operation does not occur, and the subchannel is made status pending with primary, secondary, and alert status.
2. The operation is initiated at the device prior to checking for these conditions. If the device attempts to transfer data, the device is signaled to terminate the I/O operation, and the subchannel is made status pending with primary, secondary, and alert status as a function of the subchannel state and the status presented by the device.

Modified CCW Indirect Data Addressing

Modified CCW indirect data addressing (MIDA) permits a single channel-command word to control the transfer of up to 65,535 bytes of data that spans non-contiguous blocks in main storage. Each block of main storage to be transferred may be specified on any boundary and length up to 4K bytes, provided the specified block does not cross a 4K-byte boundary. The use of modified CCW indirect data addressing requires that the program designate 64-bit data addresses.

Modified CCW indirect data addressing is controlled by a flag in the ORB and specified by a flag in the CCW which, when both are one, indicates that the CCW data address is not used to directly address data. Instead, the address points to a contiguous list of up to 256 quadwords called modified-indirect-data-address words (MIDAWs), each of which contains flags, a byte count, and a 64-bit address designating a data area in absolute storage.

Use of modified CCW indirect data addressing may be restricted to certain channel-path types. If the MIDA flag in the CCW is one, specifying the use of modified CCW indirect data addressing, and the subchannel is associated with channel paths that do not support modified CCW indirect data addressing, a program check is recognized.

The MIDAW begins on a quadword boundary and has the following format:

<table>
<thead>
<tr>
<th>Reserved</th>
<th>Flags</th>
<th>Count</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Doubleword

Figure 15-28. Modified-Indirect-Data-Address Word (MIDAW)

Reserved: Bits 0-39 of the MIDAW are reserved for future use and must be zero; otherwise, a program-check condition may be recognized.

Flags: Bits 40-47 of the MIDAW contain an 8-bit flag field. The meaning of each flag bit is as follows. Bits not shown are reserved.

Bit Meaning
40 Last MIDAW: Bit 40, when one, specifies that the MIDAW is the last in the contiguous list of MIDAWs.
41 Skip: Bit 41, when one, specifies the suppression of transfer of information to main storage during a read, read-backward, sense ID, or sense operation, thus specifying that skipping is in effect. When the operation is not read, read-backward, sense ID, or sense, bit 41 is ignored and skipping is not in effect.

When skipping is in effect, no checking for invalid or protected data addresses takes place.
42 Data-transfer-interruption control: Bit 42, when one, specifies that a program-check be recognized when the device attempts to transfer data.

Count: Bits 48-63 of the MIDAW specify the number of bytes in the storage area designated by the data-address field. The count value must not be zero; otherwise a program-check condition is recognized. When skipping is in effect, the count value may be in the range of 1 - 65,535. When skipping is not in effect, the count value, in conjunction with the data address, must not specify the transfer of data that crosses a 4K-block boundary; otherwise, a program-
check condition is recognized. When the count value causes the total data transfer count to exceed that specified in the CCW count field, a program-check condition is recognized.

**Data Address:** Bits 64-127 of the MIDAW designate the 64-bit address of a location in absolute storage which is the first byte of information to be transferred. If the count field specifies zero, this field is not checked.

When modified CCW indirect data addressing is specified, the data-address field of the CCW designates the location of the first MIDAW to be used for data transfer for the CCW command. Additional MIDAWs, if needed for completing the data transfer for the CCW, are fetched from successive locations in storage. The number of MIDAWs required for a CCW is determined by the count field of the CCW in relation to the count fields in the list of MIDAWs designated by the CCW. The list must not cross a 4K-byte boundary.

If a list of two or more MIDAWs is designated for a read operation, it is unpredictable in which order the MIDAW data addresses are used to transfer information into main storage. Thus, if two or more MIDAWs in a MIDAW list designate overlapping storage areas, the results are unpredictable.

MIDAWs that specify the transfer of data (MIDAWs for which skipping is not in effect) may specify a transfer count in the range of 1 - 4096 bytes, provided the MIDAW does not specify a data transfer that crosses a 4K-byte boundary; MIDAWs that specify the suppression of the transfer of data (MIDAWs for which skipping is in effect) may specify a skip count in the range of 1 - 65,535 bytes. The total number of bytes that can be transferred or skipped or both by a single MIDAW list is limited by the CCW count field, which is a maximum of 65,535 bytes. The sum of the count fields in all of the MIDAWs in the list designated by the CCW should equal the value in the count field of the CCW; otherwise, a program-check condition may be recognized.

The MIDAW designated by the CCW can designate any location. When the MIDAW skip flag is zero and the CCW specifies the read, write, control, sense ID, or sense command, data is then transferred to or from successively higher storage locations until the number of bytes specified by the MIDAW count field have been transferred. When the MIDAW skip flag is zero and the CCW specifies the read backwards command, data is then transferred to successively lower storage locations until the number of bytes specified by the MIDAW count field have been transferred. When the MIDAW skip flag is one and the CCW specifies the read, sense ID, or sense command, skipping occurs to successively higher storage locations until the number of bytes specified by the MIDAW count field have been skipped. When the MIDAW skip flag is one and the CCW specifies the read backwards command, skipping occurs to successively lower storage locations until the number of bytes specified by the MIDAW count field have been skipped.

When the specified number of bytes have been transferred or skipped and the CCW specifies a subsequent MIDAW, the control of data transfer is then passed to the next MIDAW in the list. Like the MIDAW designated by the CCW, subsequent MIDAWs may designate any location and any length, provided the MIDAW does not specify a data transfer that crosses a 4K-byte boundary; otherwise, a program-check condition is recognized.

Exception for the unique restriction on designating a valid combination of data address and count by a MIDAW and the resulting behavior when the data-transfer-interruption control is one, all other actions taken for data addresses specified by a MIDAW, such as for protected storage and invalid addresses, and the actions taken for data prefetching, are the same as when modified CCW indirect data addressing is not used.

MIDAWs pertaining to the current CCW or a prefetched CCW may be prefetched. The number of MIDAWs that can be prefetched cannot exceed that required to satisfy the count in the CCW that designates the MIDAWs. Any MIDAWs that are prefetched for a CCW and are not used are discarded.

Similar to when CCW data chaining occurs, the action of transferring control from one MIDAW to the next is transparent to any attached device. A MIDAW takes control of data transfer when the last byte specified by the previous MIDAW has been transferred, even in situations where (1) channel end, (2) channel end and device end, or (3) channel end, device end, and status modifier are received prior to the transfer of any data bytes pertaining to the new MIDAW.

A prefetched MIDAW does not take control of an I/O operation if the count in the CCW has reached zero with the transfer of the last byte of data for the previ-
ous MIDAW. Program or access errors detected in prefetched MIDAWs are not indicated to the program until the MIDAW takes control of data transfer, even if an attempt had been made to prefetch that data. However, when the channel subsystem detects an invalid CBC on the contents of a prefetched MIDAW or its associated key, the condition may be indicated to the program, when detected, before the MIDAW takes control of data transfer. For a description of the indications provided when an invalid CBC is detected on the contents of a MIDAW or its associated key, see “Channel-Control Check” on page 29.

When a CCW specifies a MIDAW list and either the address in the CCW designates a storage location that is not physically available or the address designates a storage location to which access is prohibited by protection, then, depending on the model, one of the following two actions is taken:

- The above conditions are checked before initiating the operation at the device. If any of these conditions is recognized, initiation of the I/O operation does not occur, and the subchannel is made status pending with primary, secondary, and alert status.

- The operation is initiated at the device prior to checking for these conditions. If the device attempts to transfer data, the device is signaled to terminate the I/O operation, and the subchannel is made status pending with primary, secondary, and alert status as a function of the subchannel state and the status presented by the device.

**Transport Indirect Data Addressing**

When a designated subchannel is operating in transport mode, transport indirect data addressing (TIDA) may be used. TIDA permits a TCW to specify the transfer of data from noncontiguous blocks in main storage or to specify the transfer-command-control block (TCCB) in noncontiguous blocks of storage or both.

The use of transport indirect data addressing is controlled by flags in the TCW as follows:

When the input-TIDA flag is one in the TCW, the TCW input-data address is not used to directly address data. Instead, the TCW input-data address points to a list of transport-indirect-data-address words (TIDAWs), each of which contains flags, a byte count, and a 64-bit address designating a data area in absolute storage.

When the output-TIDA flag is one in the TCW, the TCW output-data address is not used to directly address data. Instead, the TCW output-data address points to a list of TIDAWs, each of which designates a data area in absolute storage.

When the transport-command-control-block-TIDA flag is one in the TCW, the TCW transport-command-control-block address is not used to directly address a TCCB. Instead, the TCW transport-command-control-block address points to a list of TIDAWs, each of which designates a portion of the TCCB in absolute storage.

A list of one or more TIDAWs is called a transport-indirect-data-addressing list (TIDAL).

Unless otherwise specified, TIDAWs may designate a block of main storage on any boundary and length up to 4K bytes, provided the specified block does not cross a 4K-byte boundary.

A TIDAW begins on a quadword boundary and has the following format:

```
Word   Flag       Reserved
   0       Count
   1     Address
```

*Figure 15-29. Transport-Indirect-Data-Address Word (TIDAW)*

**Flags:** Bits 0-7 of word 0 contain an 8-bit flag field. The meaning of each flag bit is as follows. Bits not described below are reserved.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Last TIDAW: Bit 0, when one, specifies that the TIDAW is the last in the contiguous list of TIDAWs.</td>
</tr>
<tr>
<td>1</td>
<td>Skip: Bit 1, when one, specifies the suppression of transfer of information to main storage during an input operation, thus specifying that skipping is in effect.</td>
</tr>
</tbody>
</table>
When the operation is an output operation, bit 1 is ignored and skipping is not in effect. When the TIDAW is being used to transport a TCCB, bit 1 is ignored and assumed to be zero.

When skipping is in effect, no checking for invalid or protected data addresses takes place.

**2** Data-transfer-interruption control: Bit 2, when one, specifies that a program-check be recognized when the TIDAW is the current TIDAW.

**3** TIDAW-transfer-in-channel (TTIC): Bit 3, when one, specifies that the TIDAW is not used to transfer data or TCCB storage. Instead, the address field designates the address of the next TIDAW to be used for the transfer of data. If bit 3 is one and the address field designates a TIDAW in which bit 3 is one, a program-check condition is recognized. If bit 3 is one and any other TIDAW flag bits are one, a program-check condition is recognized.

**4** Insert-CBC control: Bit 4, when one, specifies that the following occurs when an output operation is specified and all of the data specified by the TIDAW has been transferred:

- If the count of data bytes transferred is not a multiple of 4, up to 3 padding bytes are transferred to make the total count of data bytes, plus the count of padding bytes, a multiple of 4.
- A word of CBC information is generated and transferred to the device.

Bit 4 has no meaning for the following cases:

- When the TIDAW is being used for an input data transfer.
- When the TIDAW is being used for an output data transfer and the last-TIDAW flag, bit 0, is one.
- When the TIDAW is in a TIDAW list designated by the TCCB-address field of the TCW.

**5-7** Reserved: Bits 5-7 are reserved and must be zero, otherwise a program-check condition is recognized.

**Reserved:** Bits 8-31 are reserved for future use and must be zero; otherwise, a program-check condition may be recognized.

**Count:** Bits 32-63 specify the number of bytes to be transferred. When skipping is in effect, the count value may be in the range of 1 through \(2^{32}-8\) for a TIDAW. When skipping is not in effect and the TTIC flag, bit 3, is zero, the count value, in conjunction with the data address, must not specify the transfer of data that crosses a 4K-byte block boundary; otherwise, a program-check condition is recognized.

When a TIDAW is in the TIDAW list designated by the input-address field in the TCW, the count value specified in the TIDAW in which the last-TIDAW flag is one and the input-count value specified in the TCW must both decrement to zero for the same byte transferred, otherwise a program-check condition is recognized.

When a TIDAW is in the TIDAW list designated by the output-address field in the TCW, the count value specified in the TIDAW in which the last-TIDAW flag is one and the output-count value specified in the TCW must both decrement to zero for the same byte transferred, otherwise a program-check condition is recognized.

When a TIDAW is in the TIDAW list designated by the TCCB-address field in the TCW, the following are true:

- The count value specified in the TIDAW in which the last-TIDAW flag is one and the count of bytes specified by the TCCB-length field in the TCW must both decrement to zero for the same byte transferred, otherwise a program-check condition is recognized.
- If the TIDAW specifies the TCCB to cross a 4K-byte boundary, a program-check condition is recognized.
- If the specified count value is zero or is not evenly divisible by four, a program-check condition is recognized.

When the TTIC flag is zero, the count field must not be zero, otherwise a program-check condition is recognized. When the TTIC flag is one, the count field
must be zero, otherwise a program-check condition is recognized.

**Address:** Bits 64-127 of the TIDAW designate the 64-bit address of a location in absolute storage. When the TTIC flag is zero, this is the location of the first byte of information to be transferred. When the TTIC flag is one, this is the location of the next TIDAW to be used and must specify an address on a quadword boundary, otherwise a program-check condition is recognized.

**Input TIDAL:** When transport indirect data addressing is specified for input (the input-TIDA flag in the TCW is one), the input-address field of the TCW designates the location of the first TIDAW to be used for data transfer for the first DCW in the associated TCCB that specifies a data transfer command. Additional TIDAWs, if needed for completing the data transfer for the DCW or subsequent DCWs, are fetched from successive locations in storage. The number of TIDAWs required for an input TIDAL is variable and is a function of the following factors:

- The total number of bytes being transferred as specified by the input-count field in the TCW.
- The number of noncontiguous fragments that compose the data being transferred.
- The number of 4K-byte boundaries within those fragments.

The input TIDAL must not cross a 4K-byte boundary, otherwise a program-check condition is recognized.

If a list of two or more TIDAWs is designated for an input operation, it is unpredictable in which order the TIDAW data addresses are used to transfer information into main storage. Thus, if two or more TIDAWs in a TIDAW list designate overlapping storage areas, the results are unpredictable.

**Output TIDAL:** When transport indirect data addressing is specified for output (the output-TIDA flag in the TCW is one), the output-address field of the TCW designates the location of the first TIDAW to be used for data transfer for the first DCW in the associated TCCB that specifies a data transfer command. Additional TIDAWs, if needed for completing the data transfer for the DCW or subsequent DCWs, are fetched from successive locations in storage. The number of TIDAWs required for a TCW is determined by the output-count field of the TCW. The number of TIDAWs required for an output TIDAL is variable and is a function of the following factors:

- The total number of bytes being transferred as specified by the output-count field in the TCW.
- The number of noncontiguous fragments that compose the data being transferred.
- The number of 4K-byte boundaries within those fragments.

The output TIDAL must not cross a 4K-byte boundary, otherwise a program-check condition is recognized.

**TCCB TIDAL:** When transport indirect data addressing is specified for the TCCB (the transport-command-control-block-TIDA flag in the TCW is one), the transport-command-control-block-address field of the TCW designates the location of the first TIDAW to be used to designate the storage location of the TCCB. Additional TIDAWs, if needed for completing the TCCB, are fetched from successive locations in storage. The number of TIDAWs required for a TCCB TIDAL is variable and is a function of the following factors:

- The total number of bytes being transferred as specified by the TCCB-length field in the TCW.
- The number of noncontiguous fragments that compose the data being transferred.
- The number of 4K-byte boundaries within those fragments.

The TCCB TIDAL must not cross a 4K-byte boundary, otherwise a program-check condition is recognized.

**Additional Information**

TIDAWs that specify the transfer of data (TIDAWs for which skipping is not in effect) may specify a transfer count in the range of 1 through 4096 bytes, provided the TIDAW does not specify a data transfer that crosses a 4K-byte boundary.

TIDAWs that specify the suppression of the transfer of data may specify a skip count in the range of 1 through $2^{32} - 8$.

The total number of bytes that can be transferred or skipped or both by a single TIDAL is limited by the
TCW count field that applies to the TIDAL, which may be a maximum of $2^{32}$-8 bytes. If a TIDAL does not specify the same number of data bytes to be transferred as the count in the TCW for the TIDAL, or does not specify the same number of data bytes to transferred as that specified by the associated TCCB, a program-check condition may be recognized.

A TIDAW can designate any location. When the TIDAW skip flag is zero and a DCW specifies the read, write, control, sense ID, or sense command, data is then transferred to or from successively higher storage locations until the number of bytes specified by the TIDAW count field have been transferred. When the TIDAW skip flag is one and a DCW specifies the read, sense ID, or sense command, skipping occurs to successively higher storage locations until the number of bytes specified by the TIDAW count field have been skipped.

When the specified number of bytes have been transferred or skipped and the TCW and DCW specify a subsequent TIDAW, the control of data transfer is then passed to the next TIDAW in the list. Like the TIDAW designated by the TCW, subsequent TIDAWs may designate any location and any length, provided the TIDA does not specify a data transfer that crosses a 4K-byte boundary; otherwise, a program-check condition is recognized.

Except for the unique restriction on designating a valid combination of data address and count by a TIDAW, and the resulting behavior when the data-transfer-interruption control is one, all other actions taken for data addresses specified by a TIDAW, such as for protected storage and invalid addresses, and the actions taken for data prefetching, are the same as when transport indirect data addressing is not used.

TIDAWs pertaining to the current TCW may be prefetched. The number of TIDAWs that can be prefetched cannot exceed that required to satisfy the associated count in the TCW that designates the TIDAWs. Any TIDAWs that are prefetched for a TCW and are not used are discarded.

The action of transferring control from one TIDAW to the next is transparent to any attached device. A TIDAW takes control of data transfer when the last byte specified by the previous TIDAW has been transferred, this may occur even in situations where (1) channel end, (2) channel end and device end, or (3) channel end, device end, and status modifier are received prior to the transfer of any data bytes pertaining to the new TIDAW.

Program or access errors when fetching or prefetching TIDAWs are indicated to the program when detected. For output operations, this may preclude transporting the TCCB to the I/O device.

When the channel subsystem detects an invalid CBC on the contents of a prefetched TIDAW or its associated key, the condition may be indicated to the program, when detected, before the TIDAW takes control of data transfer. For a description of the indications provided when an invalid CBC is detected on the contents of a TIDAW or its associated key, see “Channel-Control Check” on page 29.

When a TCW specifies a TIDAL and either the address in the TCW designates a storage location that is not physically available or the address designates a storage location to which access is prohibited by protection, then, depending on the model, one of the following two actions is taken:

- The above conditions are checked before initiating the operation at the device. If any of these conditions is recognized, initiation of the I/O operation does not occur, and the subchannel is made status pending with primary, secondary, and alert status.
- The operation is initiated at the device prior to checking for these conditions. If the device attempts to transfer data, the device is signaled to terminate the I/O operation, and the subchannel is made status pending with primary, secondary, and alert status as a function of the subchannel state and any status presented by the device.

**Suspension of CCW Channel-Program Execution**

The suspend function, when used in conjunction with RESUME SUBCHANNEL, provides the program with a means to stop and restart the execution of a channel program. The initiation of the suspend function is controlled by the setting of the suspend control, bit 4 of word 1 of the command-mode ORB. The suspend function is signaled when suspend control has been specified for the subchannel in the ORB and a CCW containing an S flag set to one becomes the current CCW. The flag can be indicated either in the first
CCW of the channel program or in a CCW fetched while command chaining. The S flag is not valid and causes a program-check condition to be recognized if (1) the ORB contains the suspend-control bit set to zero, or (2) the CCW is fetched while data chaining (see “Data Chaining” on page 61, concerning the handling of programming errors detected during data chaining).

Upon recognition of the suspend function, suspension of channel-program execution occurs when the CCW becomes current (see “Channel-Command Word” on page 30, for a definition of when a CCW becomes current). If suspension occurs during command chaining, the device is signaled that command chaining is no longer in effect.

RESUME SUBCHANNEL signals that the CCW that caused channel-program suspension may have been modified, that the CCW must be refetched, and that the contents of the CCW must be examined to determine the settings of the flags. If the S flag is one, execution of that CCW does not occur. If the CCW is valid and the S flag in the CCW is zero, execution is initiated (see “RESUME SUBCHANNEL” on page 10 and “Start Function and Resume Function” on page 20).

When a valid CCW that contains an S flag validly set to one becomes the current CCW during command chaining and the resume-pending condition is not recognized, the suspend function is performed and causes the following actions to occur in the order given:

1. The device is signaled that the chain of operations has been concluded.

2. Channel-program execution is suspended at the subchannel; all prefetched IDAWs, MIDAWs, CCWs, and data are discarded; and the subchannel is set up such that the resume function can be performed when the subchannel is next recognized to be resume pending.

3. If the measurement-block-update mode is active and the subchannel is enabled for the mode, the accrued function-pending time (a function of the setting of the timing-facility bit) is added to the accumulated value in the measurement block for the subchannel. If a measurement-check condition is detected during the measurement-block update, the channel program is not started at the subchannel. The subchannel is made status pending with primary, secondary, and alert status. Deferred condition for the subchannel. (See “Channel-Subsystem Monitoring” on page 1 for more information.)

4. The subchannel is placed in the suspended state.

5. If the subchannel is not resume pending at this point, the intermediate interruption condition due to suspension is recognized if the suppress-suspended-interruption bit of the ORB is zero; otherwise, the resume function is performed.

If a measurement-check condition is detected during the measurement-block update, the channel program is terminated at the subchannel. The subchannel is made status pending with primary, secondary, and alert status, the device-status and subchannel-status fields are set to zero, and one of the measurement-check conditions is indicated in the extended-status flags of the format-0 ESW. The subchannel is not placed in the suspended state. (See “Subchannel-Control Field” on page 12.)

When a valid CCW that contains an S flag validly set to one becomes the current CCW during command chaining and the resume-pending condition is recognized, the resume function is performed instead of the suspend function.

When the first CCW of a channel program contains an S flag validly set to one and the resume-pending condition is not recognized, the suspend function is performed and causes the following actions to occur in the order given:

1. Channel-program execution is suspended prior to the selection of the device.

2. The subchannel is set up such that the resume function can be performed when the subchannel is next recognized to be resume pending.

3. If the measurement-block-update mode is active and the subchannel is enabled for the mode, the SSCH+RSCH count is incremented, and the accrued function-pending time (a function of the setting of the timing-facility bit) is added to the accumulated value in the measurement block for the subchannel. If a measurement-check condition is detected during the measurement-block update, the channel program is not started at the subchannel. The subchannel is made status pending with primary, secondary, and alert status. Deferred condition...
code one is set, and the start-pending bit remains set to one. The device-status and subchannel-status fields are set to zero, and one of the measurement-check conditions is indicated in the extended-status flags of the format-0 ESW. The subchannel is not placed in the suspended state. (See “Subchannel-Control Field” on page 12.)

4. The subchannel is placed in the suspended state.

5. If the subchannel is not resume pending at this point, the subchannel is made status pending with intermediate status due to suspension if the suppress-suspended-interruption-control bit of the ORB is zero; otherwise, the resume function is performed.

When the first CCW of a channel program contains an S flag validly set to one and the resume-pending condition is recognized, the resume function is performed instead of the suspend function.

**Programming Notes:**

1. The execution of MODIFY SUBCHANNEL and START SUBCHANNEL completes with condition code 2 set if the designated subchannel is suspended. The start function is indicated at the subchannel while the subchannel is in the suspended state.

2. In certain situations, normal resumption of the execution of a channel program that has been suspended may not be desired. Normal termination of the suspended channel-program execution may be accomplished by:
   a. Executing HALT SUBCHANNEL and designating the subchannel.
   b. Modifying the CCWs in storage such that, when channel-program execution is resumed, the command transferred to the device is a control command with all modifier bits specified as zeros (no-operation) and with the chain-command flag specified as zero; and then executing RESUME SUBCHANNEL.
   c. When an IRB indicates measurement check along with zero device status, zero subchannel status, and status pending with primary, secondary, and alert status, it may indicate that the measurement check was detected during an attempt to place the subchannel into the suspended state.

3. If the suspended interruption is suppressed, the N condition and DCTI values applicable to the preceding subchannel-active period are not made available to the program. The execution of RESUME SUBCHANNEL when the subchannel is in the suspended state causes path-not-operational conditions and the N condition to be reset to zeros. Path-not-operational conditions and the N condition are not reset when RESUME SUBCHANNEL is executed and the designated subchannel is not in the suspended state.

### Commands and Flags for CCWs

Figure 15-30 on page 75 lists the command codes for the seven CCW commands and indicates which flags are defined for each command. Except for a format-1 CCW specifying transfer in channel, the flags are ignored for all commands for which they are not defined. The flags are reserved in a format-1 CCW specifying transfer in channel and must be zeros.

<table>
<thead>
<tr>
<th>Name</th>
<th>Code</th>
<th>Flags</th>
</tr>
</thead>
<tbody>
<tr>
<td>Write</td>
<td>M M M M</td>
<td>M M 0 0 CD CC SLI PCI IDA MIDA</td>
</tr>
<tr>
<td>Read</td>
<td>M M M M</td>
<td>M M 1 0 CD CC SLI SK PCI IDA MIDA</td>
</tr>
<tr>
<td>Read backward</td>
<td>M M M M</td>
<td>1 1 0 0 CD CC SLI SK PCI IDA MIDA</td>
</tr>
<tr>
<td>Control</td>
<td>M M M M</td>
<td>M M 1 1 CD CC SLI PCI IDA MIDA</td>
</tr>
<tr>
<td>Sense</td>
<td>M M M M</td>
<td>0 1 0 0 CD CC SLI SK PCI IDA MIDA</td>
</tr>
<tr>
<td>Sense ID</td>
<td>1 1 0 0</td>
<td>0 1 0 0 CD CC SLI SK PCI IDA MIDA</td>
</tr>
<tr>
<td>Transfer in Channel</td>
<td>X X X X</td>
<td>1 0 0 0 (See note below)</td>
</tr>
</tbody>
</table>

**Explanation:**

- CC Chain command
- CD Chain data
- IDA Indirect data addressing
- M Modifier bit
- MIDA Modified indirect data addressing
- PCI Program-controlled interruption
- S Suspend
- SK Skip
- SLI Suppress-length indication
- X Ignored in a format-0 CCW; must be zero in a format-1 CCW

Note: Flags are ignored in a format-0 transfer-in-channel CCW and must be zeros in a format-1 transfer-in-channel CCW.

Figure 15-30. Command Codes and Flags for CCWs

All flags have individual significance, except for the following cases:
• The CC and SLI flags are ignored when the CD flag is set to one, and, for output forward operations the SK flag is ignored.

• The presence of the SLI flag is ignored for immediate operations involving format-0 CCWs, in which case the incorrect-length indication is suppressed regardless of the setting of the flag.

• The incorrect-length indication may be suppressed for immediate operations when executing a format-1 CCW, depending on the incorrect-length-suppression mode.

• The PCI flag is ignored during initial program loading. All flags, except the PCI flag, are ignored when the S flag is one.

• The MIDA flag is mutually exclusive from both the IDA and SKP flags. If the IDA or SKP flag is specified and the MIDA flag is specified, a program-check condition is recognized.

Programming Notes:

1. A malfunction that affects the validity of data transferred in an I/O operation is signaled at the end of the operation by means of unit check or channel-data check, depending on whether the device (control unit) or the channel subsystem detected the error. In order to make use of the checking facilities provided in the system, data read in an input operation should not be used until the end of the operation has been reached and the validity of the data has been checked. Similarly, on writing, the copy of data in main storage should not be destroyed until the program has verified that no malfunction affecting the transfer and recording of data was detected.

2. An error condition may be recognized and the I/O operation terminated when 256 or more chained commands are executed with a device and none of the executed commands result in the transfer of any data. When this condition is recognized, program check is indicated.

3. All CCWs that require suppression of incorrect-length indications must use the SLI flag.

Commands and Flags for DCWs

Figure 15-31 on page 76 lists the command codes for the eight DCW commands and indicates which flags are defined for each command.

<table>
<thead>
<tr>
<th>Name</th>
<th>Code</th>
<th>DCW Flags</th>
</tr>
</thead>
<tbody>
<tr>
<td>Write</td>
<td>m m m m m m 0 1</td>
<td>CC SLI</td>
</tr>
<tr>
<td>Read</td>
<td>m m m m m m 1 0</td>
<td>CC SLI</td>
</tr>
<tr>
<td>Control</td>
<td>m m m m m m 1 1</td>
<td>CC SLI</td>
</tr>
<tr>
<td>Sense</td>
<td>m m m m 0 1 0 0</td>
<td>CC SLI</td>
</tr>
<tr>
<td>Sense ID</td>
<td>1 1 1 0 0 1 0 0</td>
<td>CC SLI</td>
</tr>
<tr>
<td>Interrogate</td>
<td>0 1 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>Transport COB</td>
<td>0 1 1 0 0 0 0 0</td>
<td>CC SLI</td>
</tr>
<tr>
<td>Transfer TCAX</td>
<td>0 1 0 1 0 0 0 0</td>
<td>CC SLI</td>
</tr>
</tbody>
</table>

Explanation:

CC  Chain command
m  Modifier bit.
SLI  Suppress-length indication

1 Incorrect-length condition not recognized for this command; the SLI flag is ignored.

Figure 15-31. Command Codes and Flags for DCWs

Branching in CCW Channel Programs

The channel subsystem provides two methods to modify the normal sequential execution of the CCWs in a channel program. One is the transfer-in-channel (TIC) command (described in “Transfer in Channel” on page 77), which can be used to loop back to a previously executed CCW, or to connect discontiguous segments of the channel program. The other method, which uses the status-modifier device-status bit (described in the publication ESA/390 Common I/O-Device Commands, SA22-7204), allows conditions at the device to cause the channel to bypass the next CCW in the channel program.
Transfer in Channel

The next CCW is fetched from the location in absolute main storage designated by the data-address field of the CCW specifying transfer in channel. The transfer-in-channel command does not initiate any I/O operation, and the I/O device is not signaled of the execution of the command. The purpose of the transfer-in-channel command is to provide chaining between CCWs not located in adjacent doubleword locations in an ascending order of addresses. The command can occur in both data and command chaining.

Bits 29-31 (format 0) or bits 61-63 (format 1) of a CCW that specifies the transfer-in-channel command must be zeros, designating a CCW on a doubleword boundary. Furthermore, a CCW specifying transfer in channel may not be fetched from a location designated by an immediately preceding transfer in channel. When either of these errors is detected or when an invalid address is designated in the transfer-in-channel command, the program-check condition is generated. When an invalid address is designated, the protection-check condition is generated. Detection of these errors during data chaining causes the operation at the I/O device to be terminated and an interruption condition to be generated, while during command chaining it causes only an interruption condition to be generated.

The contents of the second half of the format-0 CCW, bit positions 32-63, are ignored. Similarly, the contents of bit positions 0-3 of the format-0 CCW are ignored.

Bit positions 0-3 and 8-32 of the format-1 CCW must contain zeros; otherwise, a program-check condition is generated.

Command Retry

The channel subsystem has the capability to perform command retry, a procedure that causes a command to be retried without requiring an I/O interruption. This retry is initiated by the control unit presenting either of two status-bit combinations by means of a special sequence. When immediate retry can be performed, it presents a channel-end, unit-check, and status-modifier status-bit combination, together with device end. When immediate retry cannot be performed, the presentation of device end is delayed until the control unit is prepared. When device end is presented alone, the previous command is transferred again. If device end is accompanied by status modifier, command retry is not performed, and the channel subsystem command-chains to the CCW following the one for which command retry was signaled (for information on status modifier, see the publication ESA/390 Common I/O-Device Commands, SA22-7204). When the channel subsystem is not capable of performing command retry due to an error condition, or when any status bit other than device end or device end and status modifier accompanies the requested command-retry initiation, the retry is suppressed, and the subchannel becomes status pending. The SCSW stored by TEST SUBCHANNEL contains the status provided by the I/O device.

Programming Note: The following possible results of a command retry must be anticipated by the program:

1. A CCW containing a PCI may, if retried because of command retry, cause multiple PCI interruptions to occur.
2. If a CCW used in an operation is changed before that operation has been successfully completed, the results are unpredictable.

Concluding I/O Operations before Initiation

Subsequent to the execution of START SUBCHANNEL or RESUME SUBCHANNEL for a command-mode operation and before the first command is accepted, the start function can be ended at the subchannel by CANCEL SUBCHANNEL, CLEAR SUBCHANNEL, or HALT SUBCHANNEL.
Subsequent to the execution of START SUBCHANNEL for a transport-mode operation, the start function may be ended at the subchannel by CANCEL SUBCHANNEL, CLEAR SUBCHANNEL, or HALT SUBCHANNEL before the TCCB is transported.

For both command-mode and transport-mode operations, if the I/O operation is ended by CANCEL SUBCHANNEL, there is no subsequent interruption condition from the I/O operation, and the subchannel is available for the initiation of another start function. However, the device may have signaled a busy condition while the canceled operation was start pending. In this case, the device owes a no-longer-busy signal to the channel subsystem. This may result in unsolicited device-end status before the next operation is initiated at the device. (See also “Clear Function” on page 14 and “Halt Function” on page 16.)

---

**Concluding I/O Operations during Initiation**

After the designated subchannel has been determined to be in a state such that START SUBCHANNEL can be executed, certain tests are performed on the validity of the information specified by the program and on the logical availability of the associated device. This testing occurs during or subsequent to the execution of START SUBCHANNEL and during command chaining and command retry.

A data-transfer operation is initiated at the subchannel and device only when no programming or equipment errors are detected by the channel subsystem and when the device responds with zero status during the initiation sequence. When the channel subsystem detects or the device signals any unusual condition during the initiation of a command-mode I/O operation, the command is said to be not accepted. When the channel subsystem detects or the device signals any unusual condition during the initiation of a transport-mode I/O operation, the I/O-operation initiation is said to be not accepted. For these cases, the subchannel becomes status pending with primary, secondary, and alert status. Deferred condition code 1 is set, and the start-pending bit remains set to one.

Conditions that preclude the initiation of an I/O operation are detailed in the SCSW stored by TEST SUBCHANNEL. In this situation, the device is not started, no interruption conditions are generated subsequent to TEST SUBCHANNEL, and the subchannel is idle. The device is immediately available for the initiation of another operation, provided the command was not rejected because of the busy or not-operational condition.

When an unusual condition causes a command to be not accepted during the initiation of a command-mode I/O operation by command chaining or command retry, an interruption condition is generated, and the subchannel becomes status pending with combinations of primary, secondary, and alert status as a function of the status signaled by the device. The status describing the condition remains at the subchannel until cleared by TEST SUBCHANNEL. The conditions are indicated to the program by means of the corresponding status bits in the SCSW. A path-not-operational condition recognized during command chaining is signaled to the program by means of an interface-control-check indication. The new I/O operation at the device is not started.

START SUBCHANNEL is executed independent of its associated device. Tests on most program-specified information, on device availability and unit status, and on most error conditions are performed subsequent to the execution of START SUBCHANNEL. When any conditions are detected that preclude the performance of the start function, an interruption condition is generated by the channel subsystem and placed at the subchannel, causing it to become status pending.

---

**Immediate Conclusion of Command-Mode I/O Operations**

During the initiation of an I/O operation, the device can accept the command and signal the channel-end condition immediately upon receipt of the command code. An I/O operation causing the channel-end condition to be signaled during the initiation sequence is called an *immediate operation*. Status generated by the device for the immediate command, when command chaining is not specified and command retry is not signaled, causes the subchannel to become status pending with combinations of primary, secondary, intermediate, and alert status as a result of information specified in the ORB and CCW and status presented by the device. If the immediate operation is the first operation of the channel program, deferred
condition code 1 is set and accompanies the status indications. If intermediate status is indicated, the indication can occur only as a result of the CCW having the PCI flag set to one (see “Program-Controlled Interruption” on page 64).

Whenever command chaining is specified after an immediate operation and no unusual conditions have been detected during the operation, or when command retry occurs for an immediate operation, an interruption condition is not generated. The subsequent commands in the chain are handled normally, and, usually, the channel-end condition for the last CCW generates a primary interruption condition. If device end is signaled with channel end, a secondary interruption condition is also generated.

Whenever immediate completion of an I/O operation is signaled, no data has been transferred to or from the device, and the data address in the CCW is not checked for validity. If the subchannel is in the incorrect-length-suppression mode, incorrect length is not indicated to the program, and command chaining is performed when specified. If the subchannel is in the incorrect-length-indication mode, incorrect length and command chaining are under control of the SLI and chain-command flags. The conditions that cause the incorrect-length indication to be suppressed are summarized in Figure 15-27 on page 61.

Programming Note: I/O operations for which the entire operation is specified in the command code may be performed as immediate operations. Whether the command is executed as an immediate operation depends on the operation and type of device.

Concluding I/O Operations During Data Transfer

When the subchannel has been passed the contents of an ORB, the subchannel is said to be start pending. When a command-mode I/O operation has been initiated and the command has been accepted, the subchannel becomes subchannel-and-device active. When a transport-mode I/O operation has been initiated, the subchannel remains start pending while the TCCB is transported and executed. The subchannel remains in the respective state unless (1) the channel subsystem detects an equipment malfunction, (2) the operation is concluded by the execution of CLEAR SUBCHANNEL or HALT SUBCHANNEL, or (3) status that causes a primary interruption condition to be recognized (usually channel end) is accepted from the device.

When CCW command chaining and command retry are not specified or when chaining is suppressed because of unusual conditions, the status that is recognized as primary status causes the operation at the subchannel to be concluded and an interruption condition to be generated. The status bits in the associated SCSW indicate primary status and the unusual conditions, if any. The device can present status that is recognized as primary status at any time after the initiation of the I/O operation, and the presentation of status may occur before any data has been transferred.

For operations not involving data transfer, the device normally controls the timing of the channel-end condition. The duration of data-transfer operations may be variable and may be controlled by the device or the channel subsystem.

Excluding equipment errors and the execution of the CLEAR SUBCHANNEL, HALT SUBCHANNEL, and RESET CHANNEL PATH instructions, the channel subsystem signals the device to conclude the performance of an I/O operation during data transfer whenever any of the following conditions occurs:

- The storage areas designated for the operation are exhausted or filled.
- A program-check condition is detected.
- A protection-check condition is detected.
- A CCW chaining-check condition is detected.
- A channel-control-check condition is detected that does not affect the control of the I/O operation.

The first of these conditions occurs when the channel subsystem has decremented the count to zero in the last CCW or current TCW associated with the operation. A count of zero indicates that the channel subsystem has transferred all information specified by the I/O operation. The other four conditions are due to errors and cause premature conclusion of data transfer. In either case, the conclusion is signaled in response to a service request from the device and causes data transfer to cease. If the device has no blocks defined for the operation (such as writing on...
magnetic tape), it concludes the operation and presents channel-end status.

For command-mode operations, the device can control the duration of an operation and the timing of channel end by blocking of data. On certain operations for which blocks are defined (such as reading on magnetic tape), the device does not present channel-end status until the end of the block is reached, regardless of whether the device has been previously signaled to conclude data transfer.

Checking for the validity of the CCW data address is performed only as data is transferred to or from main storage. When the initial data address in the CCW is invalid, no data is transferred during the operation, and the device is signaled to conclude the operation in response to the first service request. On writing, devices such as magnetic-tape units request the first byte of data before any mechanical motion is started, and, if the initial data address is invalid, the operation is terminated by the channel subsystem before the recording medium has been advanced. However, since the operation has been initiated at the device, the device presents channel-end status, causing the channel subsystem to recognize a primary interruption condition. Subsequently, the device also presents device-end status, causing the channel subsystem to recognize a secondary interruption condition. Whether a block at the device is advanced when no data is transferred depends on the type of device.

When CCW command chaining takes place, the subchannel is in the subchannel-and-device-active state from the time the first I/O operation is initiated at the device until the device presents channel-end status for the last I/O operation of the chain. The subchannel remains in the device-active state until the device presents the device-end status for the last I/O operation of the chain.

Any unusual conditions cause CCW command chaining to be suppressed and a primary interruption condition to be generated. The unusual conditions can be detected by either the channel subsystem or the device, and the device can provide the indications with channel end, control unit end, or device end. When the channel subsystem is aware of the unusual condition by the time the channel-end status for the operation is accepted, the chain is ended as if the operation during which the condition occurred were the last operation of the chain. The device-end status is recognized as a secondary interruption condition whether presented together with the channel-end status or separately. If the device presents unit check or unit exception together with either control unit end or device end as status that causes the channel subsystem to recognize the primary interruption condition, then the subchannel-and-device-active state of the subchannel is terminated, and the subchannel is made status pending with primary, secondary, and alert status. Intermediate status may also be indicated if an intermediate interruption condition previously existed at the subchannel for the initial-status-interruption condition or the PCI condition and that condition still remains pending at the subchannel. The channel-end status that was presented to the channel subsystem previously when command chaining was signaled is not made available to the program.

Channel-Path-Reset Function

Subsequent to the execution of RESET CHANNEL PATH, the channel-path-reset function is performed. The performance of the function consists of: (1) issuing the reset signal on the designated channel path and (2) causing a channel report to be made pending, indicating the completion of the channel-path-reset function.
Channel-Path-Reset-Function Signaling

The channel subsystem issues the reset signal on the designated channel path. As part of this operation, the following actions are taken:

1. All internal indications associated with control-unit-busy, device-busy, and allegiance conditions for the designated channel path are reset. These indications are reset at all subchannels that have access to the designated channel path. The reset function has no other effect on subchannels, including those having I/O operations in progress.

2. If the channel path fails to respond properly to the reset signal (see “I/O-System Reset” on page 13 for a detailed description) or, because of a malfunction, the reset signal could not be issued, the channel path is made physically not available at each applicable subchannel.

3. If an I/O operation is in progress at the device and the device is actively communicating on the channel path in the performance of that I/O operation when the reset signal is received on that channel path, the I/O operation is reset, and the control unit and device immediately terminate current communication with the channel subsystem. (To avoid possible misinterpretation of unsolicited device-end status, programming measures can be taken as described in programming note 2 on page 82.)

4. If an I/O operation is in progress in the multipath mode at the device and the device is not currently communicating over the channel path in the performance of that I/O operation when the reset signal is received, then the I/O operation may or may not be reset depending on whether another channel path is available for selection in the same multipath group for the device. If there is at least one other channel path in the multipath group for the device that is available for selection, the I/O operation is not reset. However, the channel path on which the system reset is received is removed from the current set of channel paths that form the multipath group. If the channel path on which the reset signal is received is the only channel path of a multipath group, or if the device is operating in the single-path mode, the I/O operation is reset.

5. The channel-path-reset function causes I/O operations to be terminated at the device as described above; however, I/O operations are never terminated at the subchannel by the channel-path-reset function.

If an I/O operation is in progress at the subchannel and the channel path designated for the performance of the channel-path-reset function is being used for that I/O operation, the subchannel may or may not accurately reflect the progress of the I/O operation up to that instant. The subchannel remains in the state that exists at the time the channel-path-reset function is performed until the state is changed because of some action taken by the program or by the device.

Channel-Path-Reset-Function-Completion Signaling

After the reset signal has been issued and an attempt has been made to issue the reset signal, or after it has been determined that the reset signal cannot be issued, the channel-path-reset function is completed. (See “Reset Signal” on page 12.)

As a result of the channel-path-reset function being performed, a channel report is made pending (see “Channel-Subsystem Recovery” on page 24) to report the results. If the channel path responds properly to the system-reset signal, the channel report indicates that the channel path has been initialized and is physically available for use. If the reset signal was issued but either the channel path failed to respond properly or the channel path was already not physically available at each subchannel having access to the channel path, the channel report indicates that the channel path has been initialized but is not physically available for use. If, because of a malfunction or because the designated channel path is not in the configuration, the reset signal could not be issued, the channel report indicates that the channel path has not been initialized and is not physically available for use.

Programming Notes:

1. If an I/O operation is in progress in the multipath mode when the channel-path-reset function is performed on a channel path of the multipath group, it is possible for the I/O operation to be
continued on a remaining channel path of the group.

2. When the performance of the channel-path-reset function causes the I/O operation at the device to be reset, unsolicited device-end status presented by the device, if any, may be erroneously interpreted by the channel subsystem to be chaining status and thus cause the channel subsystem to continue the chain of commands. If this situation occurs, then the device-end status is not made available to the program, and the device is selected again by the channel subsystem; however, the device may interpret the initiation sequence as the beginning of a new channel program instead of as command chaining. This possibility can be avoided by issuing CLEAR SUBCHANNEL or HALT SUBCHANNEL, designating the affected subchannels, prior to issuing RESET CHANNEL PATH.

3. The performance of the channel-path-reset function may, on some models, cause overruns to occur on other channel paths.

Even though reset is signaled on the designated channel path, by one or more devices may not have been reset because of a malfunction at a control unit or a malfunction at the physical channel path to the control unit.
When an I/O operation or sequence of I/O operations initiated by the execution of START SUBCHANNEL is ended, the channel subsystem and the device generate status conditions. The generation of these conditions can be brought to the attention of the program by means of an I/O interruption or by means of the execution of the TEST PENDING INTERRUPTION instruction. (During certain abnormal situations, these conditions can be brought to the attention of the program by means of a machine-check interruption. See “Channel-Subsystem Recovery” on page 24 for details.)

The status conditions, as well as an address and a count indicating the extent of the operation sequence, are presented to the program in the form
of a subchannel-status word (SCSW). The SCSW is stored in an interruption-response block (IRB) during the execution of TEST SUBCHANNEL. When a transport-mode IRB is stored, additional information describing the status of the operation is also stored in the transport-status block.

Normally an I/O operation is being performed until the device signals primary interruption status. Primary interruption status can be signaled during initiation of an I/O operation, or later. An I/O operation can be terminated by the channel subsystem performing a clear or halt function when it detects an equipment malfunction, a program check, a chaining check, a protection check, or an incorrect-length condition, or by performing a clear, halt, or channel-path-reset function as a result of the execution of CLEAR SUBCHANNEL, HALT SUBCHANNEL, or RESET CHANNEL PATH, respectively.

I/O interruptions provide a means for the CPU to change its state in response to conditions that occur at I/O devices or subchannels. These conditions can be caused by the program, by the channel subsystem, or by an external event at the device.

### Interruption Conditions

The conditions causing requests for I/O interruptions to be initiated are called I/O-interruption conditions. When an interruption condition is recognized by the channel subsystem, it is indicated at the appropriate subchannel. The subchannel is then said to be status pending. The subchannel becoming status pending causes the channel subsystem to generate an I/O-interruption request. An I/O-interruption request can be brought to the attention of the program only once.

An I/O-interruption request remains pending until it is accepted by a CPU in the configuration, is withdrawn by the channel subsystem, or is cleared by means of the execution of TEST PENDING INTERRUPTION, TEST SUBCHANNEL, or CLEAR SUBCHANNEL, or by means of subsystem reset. When a CPU accepts an interruption request and stores the associated interruption code, the interruption request is cleared. When the pending interruption is cleared by the execution of TEST PENDING INTERRUPTION, the subchannel remains status pending until the associated interruption condition is cleared when TEST SUB-CHANNEL or CLEAR SUBCHANNEL is executed or when the subchannel is reset.

An I/O-interruption condition is normally cleared by means of the execution of TEST SUBCHANNEL. If TEST SUBCHANNEL is executed, designating a subchannel that has an I/O-interruption request pending, both the interruption request and the interruption condition at the subchannel are cleared. The interruption request and the interruption condition can also be cleared by CLEAR SUBCHANNEL.

A device-end status condition generated by the I/O device and presented following the conclusion of the last I/O operation of a start function is reset at the subchannel by the channel subsystem without generating an I/O-interruption condition or I/O-interruption request if the subchannel is currently start pending and if the status contains device end either alone or accompanied by control unit end. If any other status bits accompany the device-end status bit, then the channel subsystem generates an I/O-interruption request with deferred condition code 1 indicated.

When an I/O operation is terminated because of an unusual condition detected by the channel subsystem during the command-initiation sequence, status describing the interruption condition is placed at the subchannel, causing it to become status pending. If the unusual condition is detected by the device, the device-status field of the associated SCSW identifies the condition.

When command chaining takes place, the generation of status by the device does not cause an interruption, and the status is not made available to the program.

When the channel subsystem detects any of the following interruption conditions, it initiates a request for an I/O interruption without necessarily communicating with, or having received the status byte from, the device:

- A programming error associated with the contents of the ORB passed to the subchannel by the previous execution of START SUBCHANNEL
- A suspend flag set to one in the first CCW fetched that initiates a CCW channel program execution for either START SUBCHANNEL or RESUME SUBCHANNEL, and suppress suspended interruption not specified in the command-mode ORB.
A programming error associated with the first CCW, TCW, TIDAW, TCCB fetch, data fetch, IDAW, or MIDAW.

These interruption conditions from the subchannel, except for the suspended condition, can be accompanied by other subchannel-status indications, but the device-status indications are all stored as zeros.

The channel subsystem issues the clear signal to the device when status containing unit check is presented to a subchannel that is disabled or when the device is not associated with any subchannel. However, if the presented status does not contain unit check, the status is accepted by the channel subsystem and discarded without causing the subchannel to become status pending.

An interruption condition caused by the device may be accompanied by multiple device-status conditions. Furthermore, more than one interruption condition associated with the same device can be accepted by the channel subsystem without an intervening I/O interruption. As an example, when the channel-end condition is not cleared at the device by the time device end is generated, both conditions may be cleared at the device concurrently and indicated in the SCSW together. Alternatively, channel-end status may have been previously accepted at the subchannel, and an I/O interruption may have occurred; however, the associated status-pending condition may not have been cleared by TEST SUBCHANNEL by the time device-end status was accepted at the subchannel. In this situation, the device-end status may be merged with the channel-end status without causing an additional I/O interruption. Whether an interruption condition may be merged at the subchannel with other existing interruption conditions depends upon whether the interruption condition is unsolicited or solicited.

**Unsolicited Interruption Condition:** An unsolicited interruption condition is any interruption condition that is unrelated to the performance of a clear, halt, resume, interrogate, or start function. An unsolicited interruption condition is identified at the subchannel as alert status. An unsolicited interruption condition can be generated only when the subchannel is not device active.

The subchannel and device status associated with an unsolicited interruption condition is never merged with that of any currently existing interruption condition. If the subchannel is currently status pending, the unsolicited interruption condition is held in abeyance in either the channel subsystem or the device, as appropriate, until the status-pending condition has been cleared. Whenever the subchannel is idle and zero status is presented by the device, the status is discarded.

**Solicited Interruption Condition:** A solicited interruption condition is any interruption condition generated as a direct consequence of performing or attempting to perform a clear, halt, resume, interrogate, or start function. Solicited interruption conditions include any interruption condition generated while the subchannel is either subchannel-and-device active or device active. When the subchannel is operating in transport mode, solicited interruption conditions can be generated when the subchannel is start pending. The subchannel and device status associated with a solicited interruption condition may be merged at the subchannel with that of another currently existing solicited interruption condition. Figure 16-1 on page 4 describes the interruption
condition that results from any combination of bits in the status-control field of the SCSW.

<table>
<thead>
<tr>
<th>Status-Control Field</th>
<th>Status-Control-Bit Combinations</th>
</tr>
</thead>
<tbody>
<tr>
<td>Alert</td>
<td>1 1 1 1 1 0 0 0 0 0 0 0 0 0 0</td>
</tr>
<tr>
<td>Primary</td>
<td>0 1 1 1 1 0 0 0 1 1 1 1 0 0 0 0</td>
</tr>
<tr>
<td>Secondary</td>
<td>0 0 1 1 0 1 1 0 0 1 1 0 1 1 0 0</td>
</tr>
<tr>
<td>Intermediate</td>
<td>0 0 0 1 1 1 1 1 1 0 1 1 0 1 1 0</td>
</tr>
<tr>
<td>Status pending</td>
<td>1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1</td>
</tr>
</tbody>
</table>

| Resulting interruption condition | E | S | S | S | S | - | S | S | S | S | S | - | S | S |

**Explanation:**
- Combination does not occur.
- E Unsolicited or solicited interruption condition.
- S Solicited interruption condition.
- 0 Indicates the bit stored as zero.
- 1 Indicates the bit stored as one.

*Figure 16-1. Interruption Condition for Status-Control-Bit Combinations*

**Intermediate Interruption Condition**

An intermediate interruption condition is a solicited interruption condition that indicates that an event has occurred for which the program had previously requested notification. An intermediate interruption condition is described by any of, or any combination of the following:

- solicited subchannel status
- the Z bit
- the subchannel-suspended condition
- the Q bit

An intermediate interruption condition can occur only after it has been requested by the program through the use of flags in the ORB, CCW, or a CANCEL SUBCHANNEL for a subchannel operating in transport mode that requests an interrogate operation. Depending on the state of the subchannel, the performance or suspension of the I/O operation continues, unaffected by the setting of the intermediate-status bit.

An intermediate interruption condition can be indicated only together with one of the following indications:

1. Subchannel active
2. Status pending with primary status alone
3. Status pending with primary status together with alert status or secondary status or both
4. Suspended
5. Interrogate-complete (Q-bit)

If only the intermediate-status bit and the status-pending bit of the status-control field are ones during the execution of TEST SUBCHANNEL, the device-status field is zero.

**Primary Interruption Condition**

A primary interruption condition is a solicited interruption condition that indicates the performance of the start function is completed at the subchannel. A primary interruption condition is described by the SCSW stored as a result of the execution of TEST SUBCHANNEL while the subchannel is status pending with primary status. Once the primary interruption condition is indicated at the subchannel, the channel subsystem is no longer actively participating in the I/O operation by transferring commands or data. When a subchannel is status pending with a primary interruption condition, the execution of any of the following instructions results in the setting of a nonzero condition code: HALT SUBCHANNEL, MODIFY SUBCHANNEL, RESUME SUBCHANNEL, and START SUBCHANNEL. Once the primary interruption condition is cleared by the execution of TEST SUBCHANNEL, the subchannel accepts the START SUBCHANNEL instruction. (See “START SUB-
Secondary Interruption Condition

A secondary interruption condition is a solicited interruption condition that normally indicates the completion of an I/O operation at the device. A secondary interruption condition is also generated by the channel subsystem if the start function is terminated because a solicited alert interruption condition is recognized prior to initiating the first I/O operation at the device. A secondary interruption condition is described by the SCSW stored as a result of the execution of TEST SUBCHANNEL while the subchannel is status pending with secondary status. Once the channel subsystem has accepted status from the device that causes a secondary interruption condition to be recognized, the start function is completed at the device.

Alert Interruption Condition

An alert interruption condition is either a solicited interruption condition that indicates the occurrence of an unusual condition in a halt, resume, or start function or an unsolicited interruption condition that describes a condition unrelated to the performance of a halt, resume, or start function. An alert interruption condition is described by the SCSW stored as a result of the execution of TEST SUBCHANNEL while the subchannel is status pending with alert status. An alert interruption condition may be generated by either the channel subsystem or the device. Nonzero alert status is always brought to the attention of the program.

Priority of Interruptions

All requests for an I/O interruption are asynchronous to any activity in any CPU, and interruption requests associated with more than one subchannel can exist at the same time. The priority of interruptions is controlled by two types of mechanisms — one establishes within the channel subsystem the priority among interruption requests from subchannels associated with the same I/O-interruption subclass, and another establishes within a given CPU the priority among requests from subchannels of different I/O-interruption subclasses. The channel subsystem requests an I/O interruption only after it has established priority among requests from its subchannels. The conditions responsible for the I/O-interruption requests associated with subchannels are preserved at the subchannels until cleared by a CPU's execution of TEST SUBCHANNEL or CLEAR SUBCHANNEL or I/O-system reset is performed.

The assignment of priority among requests for interruption from subchannels of the same I/O-interruption subclass is in the order that the need for interruption is recognized by the channel subsystem. The order of recognition by the channel subsystem is a function of the type of interruption condition and the type of channel path. For the parallel-I/O-interface type of channel path, the order depends on the electrical position of the device on the channel path to which it is attached. (A device’s electrical position on the parallel-I/O interface is not related to its device address.)

The assignment of priority among requests for interruption from subchannels of different I/O-interruption subclasses is made by the CPU according to the numerical value of the I/O-interruption subclass codes (with zero having highest priority), in conjunction with the I/O-interruption-subclass mask in control register 6. The numerical value of the I/O-interruption-subclass code directly corresponds to the bit position in the I/O-interruption-subclass mask in control register 6 of a CPU. If, in any CPU, an I/O-interruption-subclass-mask bit is zero, then all subchannels having an I/O-interruption-subclass code numerically equal to the associated position in the mask register are said to be masked off in the respective CPU. Therefore, a CPU accepts the highest-priority I/O-interruption request from a subchannel that has the lowest-numbered I/O-interruption subclass code that is not masked off by a corresponding bit in control register 6 of that CPU. When the highest-priority interruption request is accepted by a CPU, it is cleared so that the interruption request is not accepted by any other CPU in the configuration.

The priority of interruption handling can be modified by the execution of either TEST SUBCHANNEL or CLEAR SUBCHANNEL. When either of these instructions is executed and the designated subchannel has an interruption request pending, that interruption request is cleared, without regard to any previous established priority. The relative priority of the remaining interruption requests is unchanged.
Programming Notes:

1. The I/O-interruption subclass mask is in control register 6, which has the following format:

   <!> Hex.
   
<table>
<thead>
<tr>
<th>Word</th>
<th>Subsystem-Identification Word</th>
<th>I/O-Interruption Parameter</th>
<th>I/O-Interruption-Identification Word</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>ISC Mask</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>40</td>
<td>63</td>
<td></td>
</tr>
</tbody>
</table>

2. Control register 6 is set to all zeros during initial CPU reset.

Interruption Action

An I/O interruption can occur only when the I/O-interruption-subclass-mask bit associated with the subchannel is one and the CPU is enabled for I/O interruptions.

The interruption occurs at the completion of a unit of operation (see “Point of Interruption” on page 24). If the channel subsystem establishes the priority among requests for interruption from subchannels while the CPU is disabled for I/O interruptions, the interruption occurs immediately after the completion of the instruction enabling the CPU and before the next instruction is executed, provided that the I/O-interruption subclass-mask bit associated with the subchannel is one. Alternatively, if the channel subsystem establishes the priority among requests for interruption from subchannels while the I/O-interruption-subclass-mask bit is zero for each subchannel that is status pending, the interruption occurs immediately after the completion of the instruction that sets at least one of the I/O-interruption-subclass-mask bits to one, provided that the CPU is also enabled for I/O interruptions. This interruption is associated with the highest-priority I/O-interruption request, as established by the CPU.

If the channel subsystem has not established the priority among requests for interruption from the subchannels by the time the interruption is allowed, the interruption does not necessarily occur immediately after the completion of the instruction enabling the CPU. A delay can occur regardless of how long the interruption condition has existed at the subchannel.

The interruption causes the current PSW to be stored as the input/output old PSW at real locations 368-383 and causes the I/O-interruption code associated with the interruption to be stored at real locations 184-195 of the CPU allowing the interruption. Subsequently, a new input/output PSW is loaded from real locations 496-511 and processing resumes in the CPU state indicated by that PSW. The subchannel causing the interruption is identified by the interruption code.

The I/O-interruption code has the following format when it is stored. The code is described in “TEST PENDING INTERRUPTION” on page 19.

Hex.

<table>
<thead>
<tr>
<th>B8</th>
<th>184</th>
</tr>
</thead>
<tbody>
<tr>
<td>BC</td>
<td>188</td>
</tr>
<tr>
<td>C0</td>
<td>192</td>
</tr>
</tbody>
</table>

Programming Note: The I/O-interruption subclass code for all subchannels is set to zero by I/O-system reset. It may be set to any of the values 0-7 by the execution of MODIFY SUBCHANNEL. (The operation of the instruction is described in “MODIFY SUBCHANNEL” on page 7.)

Interruption-Response Block

The interruption-response block (IRB) is the operand of TEST SUBCHANNEL. The two rightmost bits of the IRB address are zeros, designating the IRB on a word boundary. The IRB contains three major fields: the subchannel-status word, the extended-status word, and the extended-control word. When the extended-I/O-measurement-word mode is enabled at the subchannel, the IRB contains a fourth major field, the extended-measurement word.

IRB Format

The format of the IRB stored depends upon the subchannel status. The status present at the subchannel when a TEST SUBCHANNEL instruction is executed determines whether a command-mode IRB or transport-mode IRB is stored. Bit 11 of word 0 of the IRB
is the IRB-format control bit (X). When an IRB is stored with X set to zero, a command-mode IRB is stored. (See “Command-Mode SCSW” on page 8.) When an IRB is stored with X set to one, a 3-bit format field is defined. (See “Format (FMT)” on page 35.) The format of the IRB is specified according to the table below:

<table>
<thead>
<tr>
<th>Subchannel Mode</th>
<th>Subchannel Status</th>
<th>Bit (X)</th>
<th>FMT</th>
<th>IRB Mode Stored</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command mode</td>
<td>Any subchannel status or combination of status</td>
<td>0</td>
<td>N</td>
<td>Command mode</td>
</tr>
<tr>
<td>Transport mode</td>
<td>Status-pending alone with halt function</td>
<td>1</td>
<td>Y-0</td>
<td>Transport mode</td>
</tr>
<tr>
<td></td>
<td>Status-pending alone with clear function</td>
<td>0</td>
<td>N</td>
<td>Command mode</td>
</tr>
<tr>
<td></td>
<td>Primary status with or without any other status combination</td>
<td>1</td>
<td>Y-0</td>
<td>Transport mode</td>
</tr>
<tr>
<td></td>
<td>Secondary status alone</td>
<td>0</td>
<td>N</td>
<td>Command mode</td>
</tr>
<tr>
<td></td>
<td>Intermediate status</td>
<td>1</td>
<td>Y-0</td>
<td>Transport mode</td>
</tr>
<tr>
<td></td>
<td>Alert status with secondary, without primary or intermediate status</td>
<td>0</td>
<td>N</td>
<td>Command mode</td>
</tr>
</tbody>
</table>

Explanations:
N: Format field is not defined.
Y-0: Format field is defined and its value is 0.

Figure 16-2. Summary of IRB Format as Function of Subchannel Status

The general layout of the IRB is as follows:

The length of the subchannel-status and extended-status words is 12 bytes and 20 bytes, respectively. The length of the extended-control word is 32 bytes. When the extended-control bit, bit 14 of word 0 of the SCSW, is zero, words 8-15 of the interruption-response block may or may not be stored. The length of the extended-measurement word is 32 bytes. When the conditions for storing the extended-measurement word are not met (see “Extended-Measurement Word” on page 56), words 16-23 of the interruption-response block may or may not be stored.

Subchannel-Status Word

The subchannel-status word (SCSW) provides the program indications describing the status of a subchannel and its associated device. When a transport-mode IRB is stored, additional information describing the status of the operation and the associated device may also be stored in the transport-status block associated with the operation. If performance of a halt, resume, or start function has occurred, the SCSW may describe the conditions under which the operation was concluded.

The SCSW is stored when TEST SUBCHANNEL is executed and the designated subchannel is operational. The SCSW is placed in words 0-2 of the IRB that is designated as the TEST SUBCHANNEL operand. When STORE SUBCHANNEL is executed, the SCSW is stored in words 7-9 of the subchannel-information block (described in “Subchannel-Information Block” on page 2).

Figure 16-3 on page 8 shows the summary and contents of the command-mode SCSW.
Command-Mode SCSW

The format of a command-mode SCSW is as follows:

<table>
<thead>
<tr>
<th>Word</th>
<th>Bits</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0-3</td>
<td>Subchannel Key</td>
</tr>
<tr>
<td></td>
<td>4</td>
<td>Suspend control (S)</td>
</tr>
<tr>
<td></td>
<td>5</td>
<td>ESW format (L)</td>
</tr>
<tr>
<td></td>
<td>6-7</td>
<td>Deferred condition code (CC)</td>
</tr>
<tr>
<td></td>
<td>8</td>
<td>CCW Format (F)</td>
</tr>
<tr>
<td></td>
<td>9</td>
<td>Prefetch (P)</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td>Initial-status interruption control (I)</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>IRRB-format control (X)</td>
</tr>
<tr>
<td></td>
<td>12</td>
<td>Suppressed-suspended interruption (U)</td>
</tr>
<tr>
<td></td>
<td>13</td>
<td>Zero condition (Z)</td>
</tr>
<tr>
<td></td>
<td>14</td>
<td>Extended control (E)</td>
</tr>
<tr>
<td></td>
<td>15</td>
<td>Path not operational (N)</td>
</tr>
<tr>
<td></td>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>17-19</td>
<td>Function Control (FC)</td>
</tr>
<tr>
<td></td>
<td>17</td>
<td>Start function</td>
</tr>
<tr>
<td></td>
<td>18</td>
<td>Halt function</td>
</tr>
<tr>
<td></td>
<td>19</td>
<td>Clear function</td>
</tr>
<tr>
<td></td>
<td>20-26</td>
<td>Activity Control (AC)</td>
</tr>
<tr>
<td></td>
<td>20</td>
<td>Resume pending</td>
</tr>
<tr>
<td></td>
<td>21</td>
<td>Start pending</td>
</tr>
<tr>
<td></td>
<td>22</td>
<td>Halt pending</td>
</tr>
<tr>
<td></td>
<td>23</td>
<td>Clear pending</td>
</tr>
<tr>
<td></td>
<td>24</td>
<td>Subchannel active</td>
</tr>
<tr>
<td></td>
<td>25</td>
<td>Device active</td>
</tr>
<tr>
<td></td>
<td>26</td>
<td>Suspended</td>
</tr>
<tr>
<td></td>
<td>27-31</td>
<td>Status Control (SC)</td>
</tr>
<tr>
<td></td>
<td>27</td>
<td>Alert status</td>
</tr>
<tr>
<td></td>
<td>28</td>
<td>Intermediate status</td>
</tr>
<tr>
<td></td>
<td>29</td>
<td>Primary status</td>
</tr>
<tr>
<td></td>
<td>30</td>
<td>Secondary status</td>
</tr>
<tr>
<td></td>
<td>31</td>
<td>Status pending</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Word 1</th>
<th>CCW Address</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Word 2</th>
<th>Device Status (DEVS)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-7</td>
<td>Attention</td>
</tr>
<tr>
<td>0</td>
<td>Status modifier</td>
</tr>
<tr>
<td>1</td>
<td>Control-unit end</td>
</tr>
<tr>
<td>2</td>
<td>Busy</td>
</tr>
<tr>
<td>3</td>
<td>Channel end</td>
</tr>
<tr>
<td>4-5</td>
<td>Device end</td>
</tr>
<tr>
<td>6</td>
<td>Unit check</td>
</tr>
<tr>
<td>7</td>
<td>Unit exception</td>
</tr>
<tr>
<td>8-15</td>
<td>Subchannel Status (SCHS)</td>
</tr>
<tr>
<td>8</td>
<td>Program-controlled interruption</td>
</tr>
<tr>
<td>9</td>
<td>Incorrect length</td>
</tr>
<tr>
<td>10</td>
<td>Program check</td>
</tr>
<tr>
<td>11</td>
<td>Protection check</td>
</tr>
<tr>
<td>12</td>
<td>Channel-data check</td>
</tr>
<tr>
<td>13</td>
<td>Channel-control check</td>
</tr>
<tr>
<td>14</td>
<td>Interface-control check</td>
</tr>
<tr>
<td>15</td>
<td>Chaining check</td>
</tr>
<tr>
<td>16-31</td>
<td>Count</td>
</tr>
</tbody>
</table>

Figure 16-3. Command-Mode SCSW Format

Figure 16-4. Command-Mode SCSW
The contents of the subchannel-status word (SCSW) depend on the state of the subchannel when the SCSW is stored. Depending on the state of the subchannel and the device, the specific fields of the SCSW may contain (1) information pertaining to the last operation, (2) information unrelated to the performance of an operation, (3) zeros, or (4) meaningless values. The following descriptions indicate when an SCSW field contains meaningful information for a command-mode IRB.

Subchannel Key
When the start-function bit, bit 17 of word 0, is one, bit positions 0-3 of word 0 contain the access key used during performance of the associated start function. These bits are identical with the key specified in bit positions 0-3 of word 1 of the ORB. The subchannel key is meaningful only when the start-function bit, bit 17 of word 0, is one.

Suspend Control (S)
When the start-function bit, bit 17 of word 0, is one, bit 4 of word 0, when one, indicates that the suspend function can be initiated at the subchannel. Bit 4 is meaningful only when bit 17 is one. If bit 17 is one and bit 4 is one, channel-program execution can be suspended if the channel subsystem recognizes an S flag set to one in a CCW. If bit 4 is zero, channel-program execution cannot be suspended, and, if an S flag set to one in a CCW is encountered, a program-check condition is recognized.

Extended-Status-Word Format (L)
When the status-pending bit, bit 31 of word 0, is one, bit 5 of word 0, when one, indicates that a format-0 ESW has been stored. A format-0 ESW is stored when an interruption condition containing any of the following indications is cleared by TEST SUBCHANNEL:

- Channel-data check
- Channel-control check
- Interface-control check
- Measurement-block-program check
- Measurement-block-data check
- Measurement-block-protection check
- Path verification required
- Authorization check
- Extended subchannel logout pending

The extended-status-word-format bit is meaningful whenever the subchannel is status pending. The extended-status information that is used to form a format-0 ESW is cleared at the subchannel by TEST SUBCHANNEL or CLEAR SUBCHANNEL.

Deferred Condition Code (CC)
When the start-function bit, bit 17 of word 0, is one and the status-pending bit, bit 31 of word 0, is also one, bits 6 and 7 of word 0 indicate the general reason that the subchannel was status pending when TEST SUBCHANNEL or STORE SUBCHANNEL was executed. The deferred condition code is meaningful when the subchannel is status pending with any combination of status and only when the start-function bit of the function-control field in the SCSW is one. The meaning of the deferred condition code for each value when the subchannel is status pending is given in Figure 16-5 on page 11.

The deferred condition code, if not zero, is used to indicate whether conditions have been encountered that preclude the subchannel becoming subchannel-and-device active while the subchannel is either start pending or suspended.

Deferred Condition Code 0: A normal I/O interruption has taken place.

Deferred Condition Code 1: Status is present in the SCSW that was presented by the associated device or generated by the channel subsystem subsequent to the setting of condition code 0 for START SUBCHANNEL or RESUME SUBCHANNEL. If only the alert-status bit and the status-pending bit of the status-control field of the SCSW are ones, the status present is not related to the execution of a channel program. If the intermediate-status bit, the primary-status bit, or both are ones, then the status is related to the execution of the channel program specified by the most recently executed START SUBCHANNEL instruction or implied by the most recently executed RESUME SUBCHANNEL instruction. (See “Immediate Conclusion of Command-Mode I/O Operations” on page 78.) If the secondary-status bit is one and the primary-status bit is zero, the status present is related to the channel program specified by the START SUBCHANNEL instruction or implied by the RESUME SUBCHANNEL instruction that preceded the most recently executed START SUBCHANNEL instruction.

Deferred Condition Code 2: This code does not occur and is reserved for future use.
Deferred Condition Code 3: An attempted device selection has occurred, and the device appeared not operational on all of the channel paths that were available for selection of the device.

A device appears not operational when it does not respond to a selection attempt by the channel subsystem. This occurs when the control unit is not provided in the system, when power is off in the control unit, or when the control unit has been logically switched off the channel path. The not-operational state is also indicated when the control unit is provided and is capable of attaching the device, but the device has not been installed and the control unit is not designed to recognize the device being selected as one of its attached devices. (See also “I/O Addressing” on page 5.)

A deferred condition code 3 also can be set by the channel subsystem if no channel paths to the device are available for selection. (See Figure 16-5 on page 11.)

Programming Notes:

1. If, during performance of a start function, the I/O device being selected is not installed or has been logically removed from the control unit, but the associated control unit is operational and the control unit recognizes the I/O device being selected as one of its I/O devices, the control unit, depending upon the model, either fails to recognize the address of the I/O device or considers the I/O device to be not ready. In the former case, a path-not-operational condition is recognized, subject to the setting of the path-operational mask. (See “Path-Operational Mask (POM)” on page 7.) In the latter case, the not-ready condition is indicated when the control unit responds to the selection and indicates unit check whenever the not-ready state precludes successful initiation of the operation at the I/O device. In this case, unit-check status is indicated in the SCSW, the subchannel becomes status pending with primary, secondary, and alert status, and with deferred condition code 1 indicated. (See the publication ESA/390 Common I/O-Device Commands, SA22-7204, for a description of unit-check status.) Refer to the System Library publication for the control unit to determine how the condition is indicated.

2. The deferred condition code is 1, and the status-control field contains the status-pending and intermediate-status bits or the status-pending, intermediate-status, and alert-status bits as ones when HALT SUBCHANNEL has been executed and the designated subchannel is suspended and status pending with intermediate status. If the alert-status bit is one, then subchannel-log-out information was generated as a result of attempting to issue the halt signal to the device.
When the start-function bit, bit 17 of word 0, is one, bit 8 of word 0 indicates the format of the CCWs associated with an I/O operation. The format bit is meaningful only when bit 17 is one. If bit 8 of word 0 is zero, format-0 CCWs are indicated. If it is one, format-1 CCWs are indicated. (See “Channel-Command Word” on page 30 for the description of the two CCW formats.)

### Prefetch (P)
When the start-function bit, bit 17 of word 0, is one, bit 9 of word 0 indicates whether or not unlimited prefetching of CCWs, IDAWs, MIDAWS, and associ-
ated data is allowed. The prefetch bit is meaningful only when bit 17 is one. If bit 9 is zero, prefetching of one CCW describing a data area is allowed during output-data-chaining operations and is not allowed during any other operations. If bit 9 is one, unlimited prefetching of CCWs, IDAWs, MIDAWS, and associated data is allowed. It is model dependent whether prefetching is actually performed for any or all of the CCWs, IDAWs, MIDAWS, and associated data that comprise the CCW channel program.

**Initial-Status-Interruption Control (I)**
When the start-function bit, bit 17 of word 0, is one, bit 10 of word 0, when one, indicates that the channel subsystem is to generate an intermediate interruption condition if the subchannel becomes subchannel active (see “Initial-Status-Interruption Control (I)” on page 27). Bit 10 of word 0, when zero, indicates that the subchannel becoming subchannel active is not to cause an intermediate interruption condition to be generated.

The program requests the intermediate interruption condition by means of the command-mode ORB. An I/O interruption that results from that request may be due to the channel subsystem performing either a start function or a resume function. (See “Zero Condition Code (Z)” on page 12 for details of the indication given by the channel subsystem when the intermediate interruption condition is cleared by TEST SUBCHANNEL.)

**Address-Limit-Checking Control (A)**
When the address-limit-checking facility is installed and the start-function bit, bit 17 of word 0, is one, bit 11 of word 0, when one, indicates that the channel subsystem has been requested by the program to perform address-limit checking, subject to the setting of the limit mode at the subchannel (see “Address-Limit-Checking Control (A)” on page 27). The address-limit-checking-control bit is meaningful only when bit 17 is one.

**IRB-Format Control (X)**
Bit 11 of word 0 is the IRB-format control bit (X). The value of this bit is zero for the command-mode IRB. See Figure 16-2 on page 7.

**Suppress-Suspended Interruption (U)**
When the start-function bit, bit 17 of word 0, is one, bit 12 of word 0, when one, indicates that the channel subsystem has been requested by the program to suppress the generation of a subchannel-suspended interruption condition when the subchannel is suspended (see “Suppress-Suspended-Interruption Control (U)” on page 27). When bit 12 is zero, the channel subsystem generates an intermediate interruption condition whenever the subchannel is suspended during the execution of the associated channel program. The suppress-suspended-interruption bit is meaningful only when bit 17 is one.

**Subchannel-Control Field**
The following subchannel-control-information descriptions apply to the subchannel-control field, bits 13-31 of word 0 of the SCSW.

**Zero Condition Code (Z)**
Bit 13 of word 0, when one, indicates that the subchannel has become subchannel active and the channel subsystem has recognized an initial-status-interruption condition at the subchannel. The Z bit is meaningful only when the intermediate-status bit, bit 28 of word 0, and the start-function bit, bit 17 of word 0, are both ones.

If the initial-status-interruption-control bit, bit 10 of word 1 of the command-mode ORB, is one when START SUBCHANNEL is executed, then the subchannel becoming subchannel active causes the subchannel to be made status pending with intermediate status indicating the initial-status-interruption condition. The initial-status-interruption condition remains at the subchannel until the intermediate interruption condition is cleared by the execution of TEST SUBCHANNEL or CLEAR SUBCHANNEL. If the initial-status-interruption-control bit of the command-mode ORB is zero when START SUBCHANNEL is executed, then the subchannel becoming subchannel active does not cause an intermediate interruption condition to be generated, and the initial-status-interruption condition is not recognized.

**Extended Control (E)**
Bit 14 of word 0, when one, indicates that model-dependent information or concurrent-sense information is stored in the extended-control word (ECW). When bit 14 is zero, the contents of words 0-7 of the ECW, if stored, are unpredictable. The E bit is meaningful whenever the subchannel is status pending with alert status either alone or together with primary status, secondary status, or both.
Programming Note: During the execution of TEST SUBCHANNEL, the storing of words 0-7 of the ECW is a model-dependent function subject to the setting of bit 14 as described above. Therefore, the program should always provide sufficient storage to accommodate the storing of at least a 64-byte IRB or, when the extended-I/O-measurement-word mode is enabled at the subchannel, a 96-byte IRB.

Path Not Operational (N)

Bit 15 of word 0, when one, indicates that the N condition has been recognized by the channel subsystem. The N condition, in turn, indicates that one or more path-not-operational conditions have been recognized. The channel subsystem recognizes a path-not-operational condition when, during an attempted device selection in order to perform a clear, halt, resume, or start function, the device associated with the subchannel appears not operational on a channel path that is operational for the subchannel. A channel path is operational for the subchannel if the associated device appeared operational on that channel path the last time the channel subsystem attempted device selection in order to perform a clear, halt, resume, or start function. A channel path is not operational for the subchannel if the associated device appeared not operational on that channel path the last time the channel subsystem attempted device selection in order to perform a clear, halt, resume, or start function. A device appears to be operational on a channel path when the device responds to an attempted device selection.

The N bit is meaningful whenever the status-control field contains any of the indications listed below and at least one basic I/O function is also indicated at the subchannel:

- Status pending with any combination of primary, secondary, or alert status
- Status pending alone
- Status pending with intermediate status when the subchannel is also suspended

The N condition is reset whenever the execution of TEST SUBCHANNEL results in the setting of condition code 0 and the N bit is meaningful as described above.

Notes:

1. A path-not-operational condition does not imply a malfunctioning channel path. A malfunctioning channel path causes the generation of an error indication, such as interface-control check.

2. When a path-not-operational condition has been recognized and the subchannel subsequently becomes status pending with only intermediate status, the path-not-operational condition (a) continues to be recognized until the subchannel becomes status pending with primary status or becomes suspended and (b) is indicated by storing the path-not-operational bit as a one during the execution of TEST SUBCHANNEL. When a path-not-operational condition has been recognized and the channel-program execution subsequently becomes suspended, the path-not-operational condition does not remain pending if channel-program execution is subsequently resumed. Instead, the old indication is lost, and the path-not-operational indication, if any, pertains to the attempt by the channel subsystem to resume channel-program execution.

Function Control (FC)

The function-control field indicates the basic I/O functions that are indicated at the subchannel. This field may indicate the acceptance of as many as two functions. The function-control field is contained in bit positions 17-19 of the first word of the SCSW. The function-control field is meaningful at an installed subchannel whenever the subchannel is valid (see “Device Number Valid (V)” on page 4). The function-control field contains all zeros whenever both the activity- and status-control fields contain all zeros. The meaning of the individual bits is as follows:

Start Function (Bit 17): When one, bit 17 indicates that a start function has been requested and is either pending or in progress at the subchannel. A start function is requested by the execution of START SUBCHANNEL. A start function is indicated at the subchannel when condition code 0 is set during the execution of START SUBCHANNEL. The start-function indication is cleared at the subchannel when TEST SUBCHANNEL is executed and the subchannel is either status pending alone or status pending with any combination of alert, primary, or secondary status. The start-function indication is also cleared at the subchannel during the execution of CLEAR SUBCHANNEL.
Halt Function (Bit 18): When one, bit 18 indicates that a halt function has been requested and is either pending or in progress at the subchannel. A halt function is requested by the execution of HALT SUBCHANNEL. A halt function is indicated at the subchannel when condition code 0 is set for HALT SUBCHANNEL. The halt-function indication is cleared at the subchannel when the next status-pending condition that occurs is cleared by the execution of TEST SUBCHANNEL. The next status-pending condition depends on the state of the subchannel when HALT SUBCHANNEL is executed. If the subchannel is subchannel active when HALT SUBCHANNEL is executed, then the next status-pending condition is status pending with at least primary status indicated. If the subchannel is device active when HALT SUBCHANNEL is executed, then the next status-pending condition is status pending with at least secondary status indicated. If the subchannel is suspended and status pending with intermediate status when HALT SUBCHANNEL is executed, then the next status-pending condition is status pending with intermediate status. If the subchannel is idle when HALT SUBCHANNEL is executed, then the next status-pending condition is status pending alone. The halt-function indication is also cleared at the subchannel during the execution of CLEAR SUBCHANNEL. In normal operations, this function is indicated together with bit 17; that is, there is a start function either pending or in progress that is to be halted.

Clear Function (Bit 19): When one, bit 19 indicates that a clear function has been requested and is either pending or in progress at the subchannel. A clear function is requested by the execution of CLEAR SUBCHANNEL. A clear function is indicated at the subchannel when condition code 0 is set for CLEAR SUBCHANNEL (see “CLEAR SUBCHANNEL” on page 5). The clear-function indication is cleared at the subchannel when the resulting status-pending condition is cleared by TEST SUBCHANNEL.

Activity Control (AC)
The activity-control field is contained in bit positions 20-26 of the first word of the SCSW. This field indicates the current progress of a basic I/O function previously accepted at the subchannel. By using the contents of this field, the program can determine the degree of completion of the basic I/O function. The activity-control field is meaningful at an installed subchannel whenever the subchannel is valid (see “Device Number Valid (V)” on page 4). However, if an IFCC or CCC condition is detected during the performance of a basic I/O function and that function is indicated as pending, I/O operations may or may not have been performed at the device. The activity-control bits are defined as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>Resume pending</td>
</tr>
<tr>
<td>21</td>
<td>Start pending</td>
</tr>
<tr>
<td>22</td>
<td>Halt pending</td>
</tr>
<tr>
<td>23</td>
<td>Clear pending</td>
</tr>
<tr>
<td>24</td>
<td>Subchannel active</td>
</tr>
<tr>
<td>25</td>
<td>Device active</td>
</tr>
<tr>
<td>26</td>
<td>Suspended</td>
</tr>
</tbody>
</table>

When an SCSW is stored that has the status-pending bit of the status-control field zero and all zeros in the activity-control field, the subchannel is said to be idle or in the idle state.

Note: All conditions that are represented by the bits in the function-control field and by the resume-pending, start-pending, halt-pending, clear-pending, subchannel-active, and suspended bits in the activity-control field are reset at the subchannel when TEST SUBCHANNEL is executed and the subchannel is (1) status pending alone, (2) status pending with primary status, (3) status pending with alert status, or (4) status pending with intermediate status and is also suspended.

Resume-Pending (Bit 20): When one, bit 20 indicates that the subchannel is resume pending. The channel subsystem may or may not be in the process of performing the start function. The subchannel becomes resume pending when condition code 0 is set for RESUME SUBCHANNEL. The point at which the subchannel is no longer resume pending is a function of the subchannel state existing when the resume-pending condition is recognized and the state of the device if channel-program execution is resumed.

If the subchannel is in the suspended state when the resume-pending condition is recognized, the CCW that caused the suspension is refetched, the setting of the suspend flag is examined, and one of the following actions is taken by the channel subsystem:

1. If the CCW suspend flag is one, the device is not selected, the subchannel is no longer resume pending, and the channel-program execution remains suspended.
2. If the CCW suspend flag is zero, the channel subsystem attempts to resume channel-program execution by performing a modified start function. The resumption of channel-program execution appears to the device as the initiation of a new channel-program execution. The resume function causes the channel subsystem to perform the path-management operation as if a new start function were being initiated, using the ORB parameters previously passed to the subchannel by START SUBCHANNEL with the exception that the channel-program address is the address of the CCW that caused the suspension of the channel-program execution.

The subchannel remains resume pending when, during the performance of the start function, the channel subsystem (1) determines that it is not possible to attempt to initiate the I/O operation for the first command, (2) determines that an attempt to initiate the I/O operation for the first command does not result in the command being accepted, or (3) detects an IFCC or CCC condition and is unable to determine whether the first command has been accepted. (See “Start Function and Resume Function” on page 20.)

The subchannel is no longer resume pending when any of the following events occur:

a. While performing the start function, the subchannel becomes subchannel-and-device active or device active only, or the first command is accepted with channel-end and device-end initial status and the CCW does not specify command chaining.

b. CLEAR SUBCHANNEL is executed.

c. TEST SUBCHANNEL clears any combination of primary, secondary, and alert status or clears the status-pending condition alone.

d. TEST SUBCHANNEL clears intermediate status while the subchannel is suspended.

e. CANCEL SUBCHANNEL is executed with a resulting condition code 0.

If the subchannel is not in the suspended state when the resume-pending condition is recognized, the CCW suspend flag of the most recently fetched CCW, if any, is examined, and one of the following actions is taken by the channel subsystem:

1. If a CCW has not been fetched or the suspend flag of the most recently fetched CCW is zero, the subchannel is no longer resume pending, and the resume function is not performed.

2. If the suspend flag of the most recently fetched CCW is one, the subchannel is no longer resume pending, and the CCW is refetched. The subchannel proceeds with channel-program execution if the suspend flag of the refetched CCW is zero. The subchannel suspends channel-program execution if the suspend flag of the refetched CCW is one.

Some models recognize a resume-pending condition only after a CCW having an S flag validly set to one is fetched. Therefore, if a subchannel is resume pending and, during the execution of the channel program, no CCW is fetched that has an S flag validly set to one, the subchannel remains resume pending until the primary interruption condition is cleared by TEST SUBCHANNEL.

**Start-Pending (Bit 21):** When one, bit 21 indicates that the subchannel is start pending. The channel subsystem may or may not be in the process of performing the start function. The subchannel becomes start pending when condition code 0 is set for START SUBCHANNEL. The subchannel remains start pending when, during the performance of the start function, the channel subsystem (1) determines that it is not possible to attempt to initiate the I/O operation for the first command, (2) determines that an attempt to initiate the I/O operation for the first command does not result in the command being accepted, or (3) detects an IFCC or CCC condition and is unable to determine whether the first command has been accepted. (See “Start Function and Resume Function” on page 20.)

The subchannel becomes no longer start pending when any of the following occurs:

1. While performing the start function, the subchannel becomes subchannel-and-device active or device active only, or the first command is accepted with channel-end and device-end initial status and the CCW does not specify command chaining.

2. The subchannel becomes suspended because of a suspend flag validly set to one in the first CCW.

3. CLEAR SUBCHANNEL is executed.
4. TEST SUBCHANNEL clears any combination of primary, secondary, and alert status or clears the status-pending condition alone.

5. CANCEL SUBCHANNEL is executed with a resulting condition code 0.

**Halt-Pending (Bit 22):** When one, bit 22 indicates that the subchannel is halt pending. The channel subsystem may or may not be in the process of performing the halt function. The subchannel becomes halt pending when condition code 0 is set for HALT SUBCHANNEL. The subchannel remains halt pending when, during the performance of the halt function, the channel subsystem (1) determines that it is not possible to attempt to issue the halt signal to the device, (2) determines that the attempt to issue the halt signal to the device is not successful, or (3) detects an IFCC or CCC condition and is unable to determine whether the halt signal is issued to the device. (See “Halt Function” on page 16.)

The subchannel is no longer halt pending when any of the following occurs:

1. While performing the halt function, the channel subsystem determines that the halt signal has been issued to the device.
2. CLEAR SUBCHANNEL is executed.
3. TEST SUBCHANNEL clears any combination of primary, secondary, and alert status or clears the status-pending condition alone.
4. TEST SUBCHANNEL clears intermediate status while the subchannel is suspended.

**Clear-Pending (Bit 23):** When one, bit 23 indicates that the subchannel is clear pending. The channel subsystem may or may not be in the process of performing the clear function. The subchannel becomes clear pending when condition code 0 is set for CLEAR SUBCHANNEL. The subchannel remains clear pending when, during performance of the clear function, the channel subsystem (1) determines that it is not possible to attempt to issue the clear signal to the device, (2) determines that the attempt to issue the clear signal to the device is not successful, or (3) detects an IFCC or CCC condition and is unable to determine whether the clear signal is issued to the device. (See “Clear Function” on page 14.)

The subchannel is no longer clear pending when either of the following occurs:

1. While performing the clear function, the channel subsystem determines that the clear signal has been issued to the device.
2. TEST SUBCHANNEL clears the status-pending condition alone.

**Subchannel Active (Bit 24):** When one, bit 24 indicates that the subchannel is subchannel active. A subchannel is said to be subchannel active when an I/O operation is currently being performed at the subchannel. The subchannel becomes subchannel active when the first command is accepted and the start function or resume function is not immediately concluded at the subchannel. (See “Immediate Conclusion of Command-Mode I/O Operations” on page 78.)

The subchannel is no longer subchannel active when any of the following occurs:

1. The subchannel becomes suspended.
2. The subchannel becomes status pending with primary status.
3. CLEAR SUBCHANNEL is executed.
4. The device appears not operational during performance of a halt function.

The subchannel does not become subchannel active during performance of the function specified by either a HALT SUBCHANNEL or a CLEAR SUBCHANNEL instruction.

**Device Active (Bit 25):** When one, bit 25 indicates that the subchannel is device active. A subchannel is said to be device active when an I/O operation is currently in progress at the associated device. The subchannel becomes device active when the first command is accepted.

The subchannel is no longer device active when any of the following occurs:

1. The subchannel becomes suspended.
2. The subchannel becomes status pending with secondary status.
3. CLEAR SUBCHANNEL is executed.
4. The device appears not operational during performance of a halt function.
If the subchannel is not start pending or if the status accepted from the device also describes an alert condition, the subchannel becomes status pending with secondary status. After the status has been accepted from the device, the device is capable of accepting a command for performing a new I/O operation. If the subchannel is start pending and the status is device end or device end with control unit end, then the channel subsystem discards the status and performs the start function for the new channel program. (See “Start Function and Resume Function” on page 20.) In this situation, the subchannel does not become status pending with the secondary interruption condition, and the status is not made available to the program.

The subchannel does not become device active during performance of the functions specified by either a HALT SUBCHANNEL or a CLEAR SUBCHANNEL instruction.

**Suspected (Bit 26):** When one, bit 26 indicates that the subchannel is suspended. A subchannel is said to be suspended when channel-program execution is currently suspended. The subchannel becomes suspended as part of the suspend function. (See “Suspension of CCW Channel-Program Execution” on page 73.)

The subchannel is no longer suspended when any of the following occurs:

1. As part of the resume function following the execution of RESUME SUBCHANNEL when the subchannel becomes subchannel-and-device active or device active only, or the first command is accepted for channel-end and device-end initial status, with or without status modifier, and the CCW does not specify command chaining.

2. CLEAR SUBCHANNEL is executed.

3. TEST SUBCHANNEL clears any combination of primary, secondary, and alert status or clears the status-pending condition alone.

4. TEST SUBCHANNEL clears intermediate status while the halt function is specified.

5. CANCEL SUBCHANNEL is executed with a resulting condition code 0.

**Programming Note:** When an SCSW is stored by STORE SUBCHANNEL or TEST SUBCHANNEL following CLEAR SUBCHANNEL but prior to the subchannel becoming status pending, and the subchannel-active bit, bit 24 of word 0, is stored as zero, this does not mean that data transfer has stopped for the device. The program cannot determine whether data transfer has stopped until the subchannel becomes status pending as a result of performing the clear function.

**Status Control (SC)**

The status-control field is contained in bit positions 27-31 of the first word of the SCSW. This field provides the program with a summary-level indication of the interruption condition described by either subchannel or device status, the Z bit, or, in the case of the subchannel-suspended interruption, the suspended bit, bit 26. More than one summary indication may be signaled as a result of existing conditions at the subchannel. Whenever the subchannel is enabled (see “Enabled (E)” on page 3) and at least bit 31 is one, the subchannel is said to be status pending. Whenever the subchannel is disabled, the subchannel is not made status pending. Bit 31 of SCSW word 0 is meaningful at an installed subchannel whenever the subchannel is valid (see “Device Number Valid (V)” on page 4); bits 27-30 are meaningful when bit 31 is one. The status-control bits are defined as follows:

**Alert Status (Bit 27):** When one (and when the status-pending bit is also one), bit 27 indicates an alert interruption condition exists. In such a case, the subchannel is said to be status pending with alert status. An alert interruption condition is recognized when alert status is present at the subchannel. Alert status may be subchannel status or device status. Alert status is status generated by either the channel subsystem or the device under any of the following conditions:

- The subchannel is idle (activity-control bits 20-26 and status-control bit 31 are zeros).
- The subchannel is start pending, and the status condition precludes initiation of the I/O operation.
- The subchannel is subchannel-and-device active, and the status condition has suppressed command chaining or would have suppressed command chaining if chaining had been specified (see “CCW Channel Program Chaining” on page 60).
- The subchannel is subchannel-and-device active, command chaining is not specified, the
execution of the channel program has just been concluded, and the status presented by the device is attempting to alter the sequential execution of commands (see the publication ESA/390 Common I/O-Device Commands, SA22-7204, for more information on the use of status modifier to alter the sequential execution of commands).

- The subchannel is device active only, and the status presented by the device is other than device end, control unit end, or device end and control unit end.
- The subchannel is suspended (bit 26 is one).

If the subchannel is start pending when an alert interruption condition is recognized, the subchannel becomes status pending with alert status, deferred condition code 1 is set, the start-pending bit remains one, and the performance of the pending I/O operation is not initiated.

When TEST SUBCHANNEL is executed and stores an SCSW with the alert-status bit and the status-pending bit as ones in the IRB, the alert interruption condition is cleared at the subchannel. The alert interruption condition is also cleared during the execution of CLEAR SUBCHANNEL.

Whenever alert status is present at the subchannel, it is brought to the attention of the program. Examples of alert status include attention, device end (which signals a transition from the not-ready to the ready state), incorrect length, program check, and unit check.

**Intermediate Status (Bit 28):** When one (and when the status-pending bit is also one), bit 28 indicates an intermediate interruption condition exists. In such a case, the subchannel is said to be status pending with intermediate status. Intermediate status can be indicated when the Z bit (of the subchannel-control field), the suspended bit (of the activity-control field), or the PCI bit (of the subchannel-status field) is one.

When the initial-status-interruption-control bit is one in the command-mode ORB, the subchannel becomes status pending with intermediate status (the Z bit indicated) only after the subchannel is subchannel active. If the subchannel does not become subchannel active, the Z condition is not generated.

When suspend control is specified and the generation of an intermediate interruption condition due to suspension is not suppressed in the command-mode ORB, then the subchannel can become status pending with intermediate status due to suspension if a CCW becomes current that contains the suspend flag set to one. When the suspend flag is specified in the first CCW of a channel program, channel-program execution is suspended, and the subchannel becomes status pending with intermediate status (the suspended bit indicated) before the command in the first CCW is transferred to the device. When the suspend flag is specified in a CCW fetched during command chaining, then channel-program execution is suspended, and the subchannel becomes status pending with intermediate status (the suspended bit is indicated), only after the execution of the preceding CCW is complete.

When the PCI flag is specified in a CCW, the generation of an intermediate interruption condition due to PCI depends on whether the CCW is the first CCW of the channel program. When the PCI flag is specified in the first CCW of a channel program, the subchannel becomes status pending with intermediate status (the PCI bit indicated) only after initial status is received for the first CCW of the channel program indicating the command has been accepted. When the PCI flag is specified in a CCW fetched while chaining, the subchannel becomes status pending with intermediate status (the PCI bit indicated) only after the execution of the preceding CCW is complete. If chaining occurs before an interruption condition containing PCI is cleared by TEST SUBCHANNEL, the condition is carried over to the next CCW. This carry-over occurs during both data and command chaining, and, in either case, the condition is propagated through the transfer-in-channel command.

If the subchannel is status pending with intermediate status when HALT SUBCHANNEL is executed, the intermediate interruption condition remains at the subchannel, but the interruption request, if any, is withdrawn, and the subchannel becomes no longer status-pending. The subchannel remains no longer status pending until performance of the halt function has ended. The subchannel then becomes status pending with intermediate status indicated (possibly together with any combination of primary, secondary, and alert status).

When TEST SUBCHANNEL is executed and stores an SCSW with the intermediate-status bit and the
status-pending bit as ones in the IRB, the intermediate interruption condition is cleared at the subchannel. The intermediate interruption condition is also cleared at the subchannel during the execution of CLEAR SUBCHANNEL.

**Primary Status (Bit 29):** When one (and when the status-pending bit is also one), bit 29 indicates a primary interruption condition exists. In such a case, the subchannel is said to be status pending with primary status. A primary interruption condition is a solicited interruption condition that indicates the completion of the start function at the subchannel. The primary interruption condition is described by the SCSW stored. When an I/O operation is terminated by HALT SUBCHANNEL but the halt signal is not issued to the device because the device appeared not operational, the subchannel is made status pending with primary status (and secondary status) with both the subchannel-status field and the device-status field set to zero.

When TEST SUBCHANNEL is executed and stores an SCSW with the primary-status bit and the status-pending bit as ones in the IRB, the primary interruption condition is cleared at the subchannel. The primary interruption condition is also cleared at the subchannel during the execution of CLEAR SUBCHANNEL.

**Secondary Status (Bit 30):** When one (and when the status-pending bit is also one), bit 30 indicates a secondary interruption condition exists. In such a case, the subchannel is said to be status pending with secondary status. A secondary interruption condition is a solicited interruption condition that normally indicates the completion of the I/O operation at the device. The secondary interruption condition is described by the SCSW stored.

When an I/O operation is terminated by HALT SUBCHANNEL but the halt signal is not issued to the device because the device appeared not operational, the subchannel is made status pending with secondary status (and primary status) if the subchannel is also subchannel active) with zeros for subchannel and device status.

When TEST SUBCHANNEL is executed and stores an SCSW with the secondary-status bit as one in the IRB, the secondary interruption condition is cleared at the subchannel. The secondary interruption condition is also cleared at the subchannel during the execution of CLEAR SUBCHANNEL.

**Status-Pending (Bit 31):** When one, bit 31 indicates that the subchannel is status pending and that information describing the cause of the interruption condition is available to the program. The subchannel becomes status pending whenever intermediate, primary, secondary, or alert status is generated. When HALT SUBCHANNEL is executed, designating a subchannel that is idle, the subchannel becomes status pending subsequent to performance of the halt function to notify the program that the halt function has been completed. When TEST SUBCHANNEL is executed, thus storing an SCSW with the status-pending bit as one in the IRB, the status-pending condition is cleared at the subchannel. The status-pending condition is also cleared at the subchannel during the execution of CLEAR SUBCHANNEL. When CLEAR SUBCHANNEL is executed and the designated subchannel is operational, the subchannel becomes status pending subsequent to performance of the clear function to notify the program that the clear function has been completed.

**Note:** The status-pending bit, in conjunction with the remaining bits of the status-control field, indicates the type of status condition. For example, if bits 29 and 31 are ones, the subchannel is status pending with primary status. Alternatively, if only bit 31 is one, then the subchannel is said to be status pending or status pending alone. If only bit 31 is one in the status-control field, the settings of all bits in the subchannel-status and device-status fields are unpredictable. If bit 31 is not one, then the remaining bits of the status-control field are not meaningful.

**CCW-Address Field**

Bits 1-31 of word 1 form an absolute address. The address indicated is a function of the subchannel state when the SCSW is stored, as indicated in Figure 16-6 on page 20. When the subchannel-status field indicates channel-control check, channel-data check, or interface-control check, the CCW-address field is usable for recovery purposes if the CCW-address field-validity flag in the ESW is one.

**Programming Note:** When a CCW address, either detected in the channel-program address (see “Channel-Program Address” on page 28) or generated during chaining, would cause the channel subsystem to fetch a CCW from a location greater than 2^{24} - 1 while format-0 CCWs are specified for the operation, the invalid address is stored in the CCW-address field of the SCSW without truncation. If the
invalid address causes the channel subsystem, while chaining, to fetch a CCW from a location greater than $2^{31} - 1$ while format-1 CCWs are specified for the operation, the rightmost 31 bits of the invalid address are stored in the CCW-address field.

<table>
<thead>
<tr>
<th>Subchannel State</th>
<th>CCW Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Start pending (UUUU0/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Start pending and device active (UUUU0/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Subchannel-and-device active (UUUU0/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Device active only (UUUU0/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Suspended (YYYYY/AIPSX)</td>
<td>See note 1</td>
</tr>
<tr>
<td>Status pending (10001/AIPSX) because of unsolicited alert status from the device while the subchannel was start pending</td>
<td>Channel-program address + 8</td>
</tr>
<tr>
<td>Status pending (0Y111/AIPSX) because the device appeared not operational on all paths</td>
<td>Channel-program address + 8</td>
</tr>
<tr>
<td>Status pending (10011/AIPSX) because of solicited alert status from the device while the subchannel was start pending and device active</td>
<td>Channel-program address + 8</td>
</tr>
<tr>
<td>Status pending (10111/AIPSX) because of solicited alert status generated by the channel subsystem while the subchannel was start pending or start pending and device active</td>
<td>See note 2</td>
</tr>
<tr>
<td>Status pending (01001/AIPSX) for the program-controlled-interruption condition while the subchannel was subchannel-and-device active</td>
<td>CCW + 8 of the CCW that contained the last recognized PCI, or 8 higher than a CCW that has subsequently become current</td>
</tr>
<tr>
<td>Status pending (01001/AIPSX) for the initial-status-interruption condition while the subchannel was subchannel-and-device active</td>
<td>CCW + 8 of the CCW causing the intermediate interruption condition, or a CCW that has subsequently become current</td>
</tr>
<tr>
<td>Status pending (1Y1Y1/AIPSX); termination occurred because of program check caused by one of the following conditions: Bit 24 of word 1 of the ORB set to one; incorrect-length-indication-suppression facility not installed</td>
<td>Channel-program address + 8</td>
</tr>
<tr>
<td>Unused bits in ORB not set to zeros</td>
<td>Channel-program address + 8</td>
</tr>
<tr>
<td>Invalid CCW-address specification in transfer in channel (TIC)</td>
<td>Address of TIC + 8</td>
</tr>
<tr>
<td>Invalid CCW-address specification in the channel-program address in the ORB</td>
<td>Channel-program address + 8</td>
</tr>
</tbody>
</table>

*Figure 16-6. (Part 1 of 4) CCW Address as Function of Subchannel State*
<table>
<thead>
<tr>
<th>Subchannel State</th>
</tr>
</thead>
<tbody>
<tr>
<td>Invalid CCW address in TIC</td>
</tr>
<tr>
<td>Invalid CCW address in the channel-program address in the ORB</td>
</tr>
<tr>
<td>Invalid CCW address while chaining</td>
</tr>
<tr>
<td>Invalid command code</td>
</tr>
<tr>
<td>Invalid count</td>
</tr>
<tr>
<td>Invalid IDAW-address or MIDAW-address specification</td>
</tr>
<tr>
<td>Invalid IDAW or MIDAW address in CCW</td>
</tr>
<tr>
<td>Invalid IDAW address while sequentially fetching IDAWs or invalid MIDAW address while sequentially fetching MIDAWs</td>
</tr>
<tr>
<td>Invalid data-address specification, format 1</td>
</tr>
<tr>
<td>Invalid data address in a CCW</td>
</tr>
<tr>
<td>Invalid data address while sequentially accessing storage</td>
</tr>
<tr>
<td>Invalid data address in IDAW or MIDAW</td>
</tr>
<tr>
<td>Invalid IDAW or MIDAW specification</td>
</tr>
<tr>
<td>Invalid CCW, format 0 or 1, for a CCW other than a TIC</td>
</tr>
<tr>
<td>Invalid suspend flag – CCW fetched during data chaining has suspend flag set to one</td>
</tr>
<tr>
<td>Invalid suspend flag – CCW has suspend flag set to one, but suspend control was not specified in the ORB</td>
</tr>
<tr>
<td>Invalid MIDA flag – CCW has MIDA flag set to one, but modified-CCW-indirect-data addressing was not specified in the ORB</td>
</tr>
<tr>
<td>Invalid MIDA flag – CCW has MIDA flag set to one and either the skip flag or the IDA flag or both are set to one</td>
</tr>
<tr>
<td>Invalid CCW, format 1, for a TIC</td>
</tr>
<tr>
<td>Invalid sequence – two TICs</td>
</tr>
<tr>
<td>Invalid sequence – 256 or more CCWs without data transfer</td>
</tr>
</tbody>
</table>

Status pending (1Y1Y1/AIPSX); termination occurred because of protection check detected as follows: 3

<table>
<thead>
<tr>
<th>CCW Address*</th>
</tr>
</thead>
<tbody>
<tr>
<td>On a CCW access</td>
</tr>
<tr>
<td>On data or an IDAW or a MIDAW access</td>
</tr>
</tbody>
</table>

Figure 16-6. (Part 2 of 4) CCW Address as Function of Subchannel State
<table>
<thead>
<tr>
<th>Subchannel State</th>
<th>CCW Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Status pending (1Y1Y1/AIPSX); termination occurred because of chaining check³</td>
<td>Address of current CCW + 8</td>
</tr>
<tr>
<td>Status pending (YY1Y1/AIPSX); termination occurred under count control³</td>
<td>Address of current CCW + 8⁶</td>
</tr>
<tr>
<td>Status pending (1Y1Y1/AIPSX); operation prematurely terminated by the device because of alert status³</td>
<td>Address of current CCW + 8⁶</td>
</tr>
<tr>
<td>Status pending (YYYY1/AIPSX) after termination by HALT SUB-CHANNEL and the activity-control-field bits indicated below set to ones:</td>
<td>Address of current CCW + 8⁶</td>
</tr>
<tr>
<td>Status pending alone</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Start pending³</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Device active and start pending³</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Device active</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Subchannel active and device active³</td>
<td>CCW + 8 of the last-executed CCW⁶</td>
</tr>
<tr>
<td>Suspended</td>
<td>CCW + 8 of CCW causing suspension</td>
</tr>
<tr>
<td>Suspended and resume pending</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Status pending (00001/AIPSX) after termination by CLEAR SUB-CHANNEL</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Status pending (YY1Y1/AIPSX); operation completed normally at the subchannel⁷</td>
<td>CCW + 8 of the last-executed CCW⁶</td>
</tr>
<tr>
<td>Status pending (00011/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Status pending (10001/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Status pending (00001/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Status pending (1Y111/AIPSX); command chaining suppressed because of alert status other than channel-control check or interface-control check³</td>
<td>Address of current CCW + 8⁶</td>
</tr>
<tr>
<td>Status pending (1YYY1/AIPSX) because of alert status for channel-control check or interface-control check³</td>
<td>See note 3⁶</td>
</tr>
<tr>
<td>Status pending (1Y1Y1/AIPSX) because of channel-data check³</td>
<td>See note 3⁶</td>
</tr>
</tbody>
</table>

Figure 16-6. (Part 3 of 4) CCW Address as Function of Subchannel State
Explanation:

The meaning of the notation used in this column is as follows:

A Alert status
I Intermediate status
P Primary status
S Secondary status
X Status Pending

The possible combination of status-control-bit settings is shown to the left of the "/" symbol by the use of these symbols:

0 Corresponding condition is not indicated
1 Corresponding condition is indicated
U Unpredictable. The corresponding condition is not meaningful when the subchannel is not status pending.
Y The corresponding condition is not significant and is indicated as a function of the subchannel state.

A CCW becomes current when (1) it is the first CCW of a channel program and has been fetched, (2) while command chaining, the previous CCW is no longer current and the new CCW has been fetched, or (3) in the case of data chaining, the new CCW takes over control of the I/O operation (see the section "Data Chaining" in Chapter 15, "Basic I/O Functions"). If chaining is not specified or is suppressed, a CCW is no longer current and becomes the last-executed CCW when secondary status has been accepted by the channel subsystem. During command chaining, a CCW is no longer current when device-end status has been accepted or, in the case of data chaining, when the last byte of data for that CCW has been accepted.

The subchannel may also be resume pending.

The stored address is the channel-program address (in the ORB) + 8 even though it is either invalid or protected.

The stored address is the address of the current CCW + 8 even though it is either invalid or protected.

Incorrect length is indicated as a function of the setting of the suppress-length-indication flag in the current CCW (see the section "Channel-Command Word" in Chapter 15, "Basic I/O Functions").

Notes:

1. Unless the subchannel is also resume pending, the address stored is the address of the CCW that caused suspension, plus 8. Otherwise, the address stored is unpredictable.

2. The address of the CCW is given as a function of the alert status indicated. For example, if a program-check or protection-check condition is recognized, the CCW address stored is the same as for the entry for program check or protection check, respectively, in this table. Alternatively, if alert status for interface-control check or channel-control check is indicated, the CCW address stored is either the channel-program address (in the ORB) + 8 or invalid as specified by the field-validity flags in the subchannel logout. If alert status for path-verification required is indicated, the CCW address stored is the channel-program address (in the ORB) + 8.

3. Bit 21 of the subchannel-logout information, when stored as one, indicates that the address is CCW + 8 of the last-fetched CCW if the command for the CCW has not been accepted by the device. If the command has been accepted by the device at the time the error condition is recognized, then the address stored is the address of the CCW + 8 of the last-executed CCW.

Figure 16-6. (Part 4 of 4) CCW Address as Function of Subchannel State
Device-Status Field

Device-status conditions are generated by the I/O device and are presented to the channel subsystem over the channel path. The timing and causes of these conditions for each type of device are specified in the System Library publication for the device. The device-status field is meaningful whenever the subchannel is status pending with any combination of primary, secondary, intermediate, or alert status. Whenever the subchannel is status pending with intermediate status alone, the device-status field is zero. When the subchannel-status field indicates channel-control check, channel-data check, or interface-control check, the device-status field is usable for recovery purposes if the device-status field-validity flag in the ESW is one. When the subchannel is status pending with deferred condition code 3 indicated, the contents of the device-status field are not meaningful.

If, within a system, the I/O device is accessible from more than one channel path, status related to channel-subsystem-initiated operations in the single-path mode (solicited status) is signaled over the initiating channel path. Devices operating in the multipath mode may signal solicited status over any channel path that belongs to the same path group as the initiating channel path. The handling of conditions not associated with I/O operations (unsolicited alert status), such as attention, unit exception, and device end due to transition from the not-ready to the ready state, depends on the type of device and condition and is specified in the System Library publication for the device.

The channel subsystem does not modify the status bits received from the I/O device. These bits appear in the SCSW as received over the channel path. For more information on the status bits received from the I/O device, see the publication *ESA/390 Common I/O-Device Commands*, SA22-7204.

Subchannel-Status Field

Subchannel-status conditions are detected and indicated in the SCSW by the channel subsystem. Except for the conditions caused by equipment malfunctioning, they can occur only while the channel subsystem is involved with the performance of a halt, resume, or start function. The subchannel-status field is meaningful whenever the subchannel is status pending with any combination of primary, secondary, intermediate, or alert status. Individual bits contained in the subchannel-status field may be unpredictable even when the subchannel-status field is meaningful. When the subchannel is status pending with deferred condition code 3 indicated, the contents of the subchannel-status field are not meaningful.

Program-Controlled Interruption

An intermediate interruption condition is generated after a CCW with the program-controlled-interruption (PCI) flag set to one becomes the current CCW. The I/O interruption due to the PCI flag may be delayed an unpredictable amount of time because of masking of the interruption request or other activity in the system. (See “Program-Controlled Interruption” on page 64.) When the channel subsystem recognizes an alert interruption condition due to either a channel-control-check condition or an interface-control-check condition, then any previously existing intermediate interruption condition caused by a PCI flag in a CCW may or may not be recognized by the channel subsystem.

Detection of the PCI condition does not affect the progress of the I/O operation.

Incorrect Length

Incorrect length occurs when the number of bytes contained in the storage areas assigned for the I/O operation is not equal to the number of bytes requested or offered by the I/O device. Incorrect length is indicated for one of the following reasons:

**Long Block on Input:** During a read, read-backward, or sense operation, the device attempted to transfer one or more bytes to main storage after the assigned main-storage areas were filled, or the device indicated that more data could have been transferred if the count had been larger. The extra bytes have not been placed in main storage. The count in the SCSW is zero.

**Long Block on Output:** During a write or control operation, the device requested one or more bytes from the channel subsystem after the assigned main-storage areas were exhausted, or the device indicated that more data could have been transferred if the count had been larger. The count in the SCSW is zero.

**Short Block on Input:** The number of bytes transferred during a read, read-backward, or sense opera-
tion is insufficient to fill the main-storage areas assigned to the operation. The count in the SCSW is not zero.

Short Block on Output: The device terminated a write or control operation before all information contained in the assigned main-storage areas was transferred to the device. The count in the SCSW is not zero.

The incorrect-length indication is suppressed when the current CCW has the SLI flag set to one and the CD flag set to zero. The indication does not occur for operations rejected during the initiation sequence. The indication also does not occur for immediate operations when the count field is nonzero and the subchannel is in the incorrect-length-suppression mode. The incorrect-length indication is not meaningful when the count field of the SCSW is not meaningful.

Presence of the incorrect-length condition suppresses command chaining unless the SLI flag in the CCW is one or unless the condition occurs in an immediate operation when the subchannel is in the incorrect-length-suppression mode.

Program Check
Program check occurs when programming errors are detected by the channel subsystem. The condition can be due to the following causes:

Invalid CCW-Address Specification: The channel-program address (CPA) or the transfer-in-channel command does not designate the CCW on a double-word boundary, or bit 0 of the CPA or bit 32 of a format-1 CCW specifying the transfer-in-channel command is not zero.

Invalid CCW Address: The channel subsystem has attempted to fetch a CCW from a main-storage location that is not available. An invalid CCW address can occur because the program has designated an invalid address in the channel-program-address field of the command-mode ORB or in the transfer-in-channel command or because, on chaining, the channel subsystem attempts to fetch a CCW from an unavailable location. A main-storage location is unavailable when any of the following conditions is detected:

1. The absolute CCW address does not correspond to a physical location.
2. Format-0 CCWs are specified in the ORB, and the absolute CCW address is greater than $2^{24} - 1$.
3. Format-1 CCWs are specified in the ORB, and the absolute CCW address is greater than $2^{31} - 1$

Invalid Command Code: There are zeros in the four rightmost bit positions of the command code in the CCW designated by the CPA or in a CCW fetched on command chaining. The command code is not tested for validity during data chaining.

Invalid Count, Format 0: A CCW, which is other than a CCW specifying transfer in channel, contains zeros in bit positions 48-63.

Invalid Count, Format 1: A CCW that specifies data chaining or a CCW fetched while data chaining contains zeros in bit positions 16-31.

Invalid IDAW-Address or MIDAW-Address Specification: Indirect data addressing or modified indirect data addressing is specified, and any of the following conditions is detected:

1. The ORB specifies format-1 IDAWs, the CCW specifies indirect data addressing, and the contents of the data-address field in the CCW do not designate the first IDAW on a word boundary; that is, bits 30 and 31 (format-0 CCW) or 62 and 63 (format-1 CCW) are not zeros.
2. The ORB specifies format-2 IDAWs, the CCW specifies indirect data addressing, and the contents of the data-address field in the CCW do not designate the first IDAW on a doubleword boundary; that is, bits 29-31 (format-0 CCW) or 61-63 (format-1 CCW) are not zeros.
3. The ORB specifies modified-CCW-indirect-data addressing, the CCW specifies modified-indirect-data addressing, and the contents of the data-address field in the CCW do not designate the first MIDAW on a quadword boundary.

Invalid IDAW or MIDAW Address: The channel subsystem has attempted to fetch an IDAW or MIDAW from a main-storage location that is not available. An invalid IDAW or MIDAW address can occur because the program has designated an invalid address in a CCW that specifies indirect data addressing or modified indirect data addressing, or because the channel subsystem, on sequentially fetching IDAWs or MIDAWs, attempts to fetch from...
an unavailable location. A main-storage location is unavailable when any of the following conditions is detected:

1. The absolute IDAW or MIDAW address does not correspond to a physical location.

2. Format-0 CCWs are specified in the ORB, and the absolute IDAW or MIDAW address is greater than $2^{24} - 1$.

3. Format-1 CCWs are specified in the ORB, and the absolute IDAW or MIDAW address is greater than $2^{31} - 1$.

**Invalid Data-Address Specification:** Bit 32 of a format-1 CCW is not zero.

**Invalid Data Address:** When any of the following conditions is detected, an invalid data address is recognized by the channel subsystem.

1. Use of the data address has caused the channel subsystem to attempt to wrap from the maximum storage address to zero.

2. Use of the data address has caused the channel subsystem to attempt to wrap from zero to the maximum storage address during a read-backward operation.

3. The channel subsystem has attempted to transfer data to a storage location that is unavailable.

An invalid data address can occur because the program has designated an unavailable location in a CCW or in an IDAW or MIDAW, or because the channel subsystem, on sequentially accessing storage, attempted to access an unavailable location. A main-storage location is unavailable when any of the following conditions is detected:

1. The absolute address of the location does not correspond to a physical location.

2. Format-0 CCWs are specified in the ORB, indirect data addressing is not specified in the CCW, and the absolute address is greater than $2^{24} - 1$.

3. Format-1 CCWs are specified in the ORB, indirect data addressing is not specified in the CCW, and the absolute address is greater than $2^{31} - 1$.

4. Format-1 IDAWs are specified in the ORB, indirect data addressing is specified in the CCW, and the absolute address is greater than $2^{31} - 1$.

5. When the address-limit-checking facility is installed, the absolute address is outside the addressing range specified by SET ADDRESS LIMIT, and the limit mode at the subchannel is active.

**Note:** The maximum storage address is determined as a function of the CCW and IDAW formats used or MIDAWs used. When neither an IDAW nor a MIDAW is used, the maximum storage address is a function of the CCW format specified, as follows:

1. When 24-bit (format 0) CCWs are specified, the maximum storage address recognized by the channel subsystem is $2^{24} - 1$.

2. When 31-bit (format 1) CCWs are specified, the maximum storage address recognized by the channel subsystem is $2^{31} - 1$.

When an IDAW is used, the maximum storage address is a function of the IDAW format specified, as follows:

1. When 31-bit (format 1) IDAWs are specified, the maximum storage address recognized by the channel subsystem is $2^{31} - 1$.

2. When 64-bit (format 2) IDAWs are specified, the maximum storage address recognized by the channel subsystem is $2^{64} - 1$.

When a MIDAW is used, the maximum storage address recognized by the channel subsystem is $2^{64} - 1$.

**Invalid IDAW or MIDAW Specification:** When any of the following conditions is detected, an invalid IDAW specification is recognized by the channel subsystem:

1. Bit 0 of a format-1 IDAW is not zero.

2. A second or subsequent format-1 IDAW does not designate the location of the beginning byte of a 2K-byte block or, for read-backward operations, the location of the ending byte of a 2K-byte block.

3. A second or subsequent format-2 IDAW does not designate the location of the beginning byte of a 2K-byte or 4K-byte block, as required by the 2K-IDAW control in the ORB, or, for read-backward operations, the location of the ending byte of a 2K-byte or 4K-byte block.
When bit 0 of a format-1 IDAW is not zero, the subchannel is made status pending with program-check indicated only after the I/O device attempts to transfer data, just as when an invalid data address that refers to a nonexistent data area is detected. If the device ends the operation prior to the transfer of data, no error condition is reported. See “CCW Indirect Data Addressing” in Chapter 15 for additional information about the reporting of program-check conditions.

When any of the following conditions is detected, an invalid MIDAW specification is recognized by the channel subsystem:

1. One or more bits defined as reserved in the MIDAW are not zero.
2. The MIDAW count field contains zeros.
3. The combination of the MIDAW data-address and count fields specify data addresses that cross a 4K-byte block boundary, unless skipping is in effect for the MIDAW.
4. The MIDAW in control has its last-MIDAW flag set to zero and the sum of the count values of the previous MIDAWs in the MIDAW list (MIDAL) and the MIDAW in control is greater than or equal to the count value in the CCW.
5. The MIDAW in control has its last-MIDAW flag set to one and the sum of the count values in the previous MIDAWs in the MIDAL and the MIDAW in control do not equal the count value in the CCW.
6. The MIDAW in control is a second or subsequent MIDAW whose address is on a 4K-byte boundary.

**Invalid CCW, Format 0:** A CCW other than a CCW specifying transfer in channel does not contain a zero in bit position 39.

**Invalid CCW, Format 1:** A CCW other than a CCW specifying transfer in channel does not contain a zero in bit position 15, or a CCW specifying transfer in channel does not contain zeros in bit positions 0-3 and 8-31.

**Invalid Suspend Flag:** A format-0 or format-1 CCW fetched during data chaining, other than a CCW specifying transfer in channel, does not contain a zero in bit position 38 or 14, respectively. A CCW other than a CCW specifying transfer in channel does not contain a zero in bit position 38 for a format-0 CCW or bit position 14 for a format-1 CCW, and suspend control was not specified by bit 4 of word 1 of the ORB.

**Invalid MIDAW Flag:** When either of the following conditions is detected, an invalid MIDAW flag condition is recognized by the channel subsystem.

1. Bit 39 (format 0) or bit 15 (format 1) of the CCW is one, specifying modified CCW indirect data addressing; however, modified CCW indirect data addressing was not specified by bit 25 of word 1 of the ORB.
2. Bit 39 (format 0) or bit 15 (format 1) of the CCW is one, specifying modified CCW indirect data addressing, and bit 35 (format 0) or bit 11 (format 1) of the CCW is one, specifying skip.
3. Bit 39 (format 0) or bit 15 (format 1) of the CCW is one, specifying modified CCW indirect data addressing, and bit 37 (format 0) or bit 13 (format 1) of the CCW is one, specifying indirect data addressing.
4. Bit 39 (format 0) or bit 15 (format 1) of the CCW is one, specifying modified CCW indirect data addressing, and the designated subchannel is not associated with channel paths that support modified CCW indirect data addressing.

**Invalid ORB Format:** One or more reserved bit positions in the operation-request block (ORB) is not zero. (See “Operation-Request Block” on page 24 for more information.) If the incorrect-length-indication-suppression facility is not installed, then bit 24 of word 1 of the command-mode ORB must also be zero.

**Invalid Sequence:** The channel subsystem has fetched two successive CCWs both of which specify transfer in channel, or, depending on the model, a sequence of 256 or more CCWs with command chaining specified was executed by the channel subsystem and did not result in the transfer of any data to or from an I/O device.

Detection of the program-check condition during the initiation of an operation at the device causes the operation to be suppressed and the subchannel to be made status pending with primary, secondary, and alert status. When the condition is detected after the
I/O operation has been initiated at the device, the device is signaled to conclude the operation the next time the device requests or offers a byte of data or status. In this situation, the subchannel is made status pending as a function of the status received from the device. The program-check condition causes command chaining and command retry to be suppressed.

**Protection Check**

Protection check occurs when the channel subsystem attempts a storage access that is prohibited by the protection mechanism. Protection applies to the fetching of CCWs, IDAWs, MIDAWs, and output data and to the storing of input data. The subchannel key provided in the ORB is used as the access key for storage accesses associated with an I/O operation.

Detection of the protection-check condition during the fetching of the first CCW, IDAW, or MIDAW causes the operation to be suppressed and the subchannel to be made status pending with primary, secondary, and alert status. When protection check is detected after the I/O operation has been initiated at the device, the device is signaled to conclude the operation after the available data logically prior to the protection check has been transferred. However, if an access violation occurs when the channel subsystem is in the process of fetching either a new IDAW, MIDAW, or a new CCW while data chaining, and if the device signals the channel-end condition before transferring any data designated by the new CCW, IDAW or MIDAW, then the status is accepted, and the subchannel becomes status pending with primary and alert status and with protection check indicated. Other indications may accompany the protection-check indication as a function of the operation specified by the CCW, the status received from the device, and the current state of the subchannel. The protection-check condition causes command chaining and command retry to be suppressed.

**Channel-Data Check**

Channel-data check indicates that an uncorrected storage error has been detected in regard to data, contained in main storage, that is currently used in the performance of an I/O operation. The condition may be indicated when detected, even if the data is not used when prefetched. Channel-data check is indicated when data or the associated key has an invalid checking-block code (CBC) in main storage when that data is referenced by the channel subsystem.

On an input operation, when the channel subsystem attempts to store less than a complete checking block, and invalid CBC is detected on the checking block in storage, the contents of the location remain unchanged and with invalid CBC. On an output operation, whenever channel-data check is indicated, no bytes from the checking block with invalid CBC are transferred to the device.

During a storage access, the maximum number of bytes that can be transferred is model dependent. If a channel-data-check condition is recognized during that storage access, the number of bytes transferred to or from storage may not be detectable by the channel subsystem. Consequently, the number of bytes transferred to or from storage may not be correctly reflected by the residual count. However, the residual count that is stored in the SCSW, when used in conjunction with the storage-access code and the CCW address, designates a byte location within the block of main storage in which the channel-data-check condition was recognized.

A condition indicated as channel-data check causes the current operation, if any, to be terminated. The subchannel becomes status pending with primary and alert status, or with primary, secondary, and alert status, as a function of the status received from the device. The count and address fields of the SCSW stored by TEST SUBCHANNEL pertain to the operation terminated. The extended-status-word-format bit is one, and subchannel-logout information is stored in the ESW, when TEST SUBCHANNEL is executed.

Whenever the channel-data-check condition pertains to prefetched data, the failing-storage-address-validity flag, bit 6 of the ERW, is one. An address of a location within the checking block for which the channel-data-check condition is generated is stored in the ESW failing-storage-address field.

Uncorrectable storage or key errors detected on prefetched data while the subchannel is start pending cause the operation to be canceled before initiation at the device. In this case, the subchannel is made status pending with primary, secondary, and alert status, with channel-data check indicated, and with the ESW failing-storage address stored.

Whenever channel-data check is indicated, no measurement data for the subchannel is stored.
Channel-Control Check

Channel-control check is caused by any machine malfunction affecting channel-subsystem controls. The condition includes invalid CBC on a CCW, an IDAW, a MIDAW, or the respective associated key. The condition may be indicated when an invalid CBC is detected on a prefetched CCW, IDAW, MIDAW, or the respective associated key, even if that CCW, IDAW, or MIDAW is not used.

Channel-control check may also indicate that an error has been detected in the information transferred to or from main storage during an I/O operation. However, when this condition is detected, the error has occurred inboard of the channel path: in the channel subsystem or in the path between the channel subsystem and main storage.

Detection of the channel-control-check condition causes the current operation, if any, to be terminated immediately. The subchannel is made status pending with primary and alert status or with primary, secondary, and alert status as a function of the type of termination, the current subchannel state, and the device status presented, if any. When the channel subsystem recognizes a channel-control-check condition, any previously existing intermediate interruption condition caused by a PCI flag in a CCW may or may not be recognized by the channel subsystem. The count and data-address fields of the SCSW stored by TEST SUBCHANNEL pertain to the operation terminated. The extended-status-word-format bit is one, and subchannel-logout information is stored in the ESW, when TEST SUBCHANNEL is executed.

Whenever the channel-control-check condition pertains to an invalid CBC detected on a prefetched CCW, a prefetched IDAW, a prefetched MIDAW, or the key associated with the prefetched CCW, the prefetched IDAW, or the prefetched MIDAW, an extended-report word with bit 6 set to one, and the failing-storage address, are stored in the ESW when TEST SUBCHANNEL is executed.

Channel-control-check conditions encountered while prefetching when the subchannel is start pending cause the operation to be canceled before initiation at the device. In this case, the subchannel is made status pending with primary, secondary, and alert status, with channel-control check indicated, and with a failing-storage address that will be stored in the ESW.

If a subchannel is halt pending and the channel subsystem encounters a channel-control-check condition while performing the halt function for that subchannel, the subchannel remains halt pending unless the channel subsystem can determine that the halt signal was issued. The subchannel remains halt pending even if the channel subsystem was attempting to issue the halt signal and is unable to determine if the halt signal was issued.

If a subchannel is start pending or resume pending and the channel subsystem encounters a channel-control-check condition while performing the start function for that subchannel, the subchannel remains start pending or resume pending unless the channel subsystem can determine that the first command was accepted. The subchannel remains start pending or resume pending even if the channel subsystem was attempting to initiate the I/O operation for the first command and is unable to determine if the command was accepted. If the channel subsystem is unable to determine whether the first command was accepted, the subchannel is made status pending with at least alert and primary status.

In some situations in which a channel-subsystem malfunction exists, the channel-control-check condition may be reported as a machine-check condition.

Whenever channel-control check is indicated, no measurement data for the subchannel is stored.

Programming Note: If the status-control field of the SCSW indicates that the subchannel is status pending with alert status but the field-validity flags of the SCSW indicate that the device-status field is not usable for error-recovery purposes, the program should (1) assume that the channel-control-check condition occurred while the channel subsystem was accepting alert status from the device and (2) take the appropriate action for alert status, even though the status itself has been lost.

Interface-Control Check

Interface-control check indicates that an invalid signal has occurred on the channel path. The condition is detected by the channel subsystem and usually indicates malfunctioning of an I/O device. Interface-control check can occur for any of the following reasons:

1. A data or status byte received from a device while the subchannel is subchannel-and-device
active or device active has an invalid checking-block code.

2. The status byte received from a device while the subchannel is idle, start pending, suspended, or halt pending has an invalid checking-block code.

3. A device responded with an address other than the address designated by the channel subsystem during initiation of an operation.

4. During command chaining, the device appeared not operational.

5. A signal from an I/O device either did not occur or occurred at an invalid time or had an invalid duration.

6. The channel subsystem recognized the I/O-error-alert condition (see “I/O-Error Alert (A)” on page 50).

7. ESW bit 26, indicating device-status check, is set to one.

Detection of an interface-control check during a CCW-type IPL I/O operation on a machine that retries IPL I/O operations on an alternate channel path causes the channel subsystem to terminate operations on the current channel path and to retry the IPL I/O operation on another logically-available channel path to the designated device, if one is available, without causing the subchannel to become status-pending. (See “CCW-type IPL” on page 17 for additional information.) In all other cases and when an interface-control check has been detected for a CCW-type IPL operation on all logically-available channel paths to the designated device, detection of the interface-control-check condition causes the current operation, if any, to be terminated immediately, and the subchannel is made status pending with alert status, primary and alert status, secondary and alert status, or primary, secondary, and alert status as a function of the type of termination, the current subchannel state, and the device status presented, if any. When the channel subsystem recognizes an interface-control-check condition, any previously existing intermediate interruption condition caused by a PCI flag in a CCW may or may not be recognized by the channel subsystem. The extended-status-word-format bit is one, and subchannel-logout information is stored in the ESW, when TEST SUBCHANNEL is executed.

If a subchannel is halt pending and the channel subsystem encounters an interface-control-check condition while performing the halt function for that subchannel, the subchannel remains halt pending unless the channel subsystem can determine that the halt signal was issued. The subchannel remains halt pending even if the channel subsystem was attempting to issue the halt signal and is unable to determine if the halt signal was issued.

If a subchannel is start pending or resume pending and the channel subsystem encounters an interface-control-check condition while performing the start function for that subchannel, the subchannel remains start pending or resume pending unless the channel subsystem can determine that the first command was accepted. The subchannel remains start pending or resume pending even if the channel subsystem was attempting to initiate the I/O operation for the first command and is unable to determine if the command was accepted. If the channel subsystem is unable to determine whether the first command was accepted, the subchannel is made status pending with at least alert and primary status.

If, while initiating a signaling sequence with the channel subsystem for the purpose of presenting status or transferring data, the device presents an address with invalid parity, the error condition is not made available to the program since the identity of the device and associated subchannel are unknown.

Whenever interface-control check is indicated, no measurement data for the subchannel is stored.

**Programming Note:** If the status-control field of the SCSW indicates that the subchannel is status pending with alert status but the field-validity flags of the SCSW indicate that the device-status field is not usable for error-recovery purposes, the program should (1) assume that the interface-control-check condition occurred while the channel subsystem was accepting alert status from the device and (2) take the appropriate action for alert status, even though the status itself has been lost.

**Chaining Check**

Chaining check is caused by channel-subsystem overrun during data chaining on input operations. The condition occurs when the I/O-data rate is too high for the particular resolution of data addresses. Chaining check cannot occur on output operations.
Detection of the chaining-check condition causes the I/O device to be signaled to conclude the operation. It causes command chaining to be suppressed.

**Count Field**

Bit positions 16-31 of word 2 contain the residual count. The count is to be used in conjunction with the original count specified in the last CCW and, depending upon existing conditions (see Figure 16-7 on page 32), indicates the number of bytes transferred to or from the area designated by the CCW. The count field is meaningful whenever the subchannel is status pending with primary status that consists of either (1) device status only or (2) device status together with subchannel status of incorrect length only, PCI only, or both.

In Figure 16-7 on page 32, the contents of the count field are listed for all cases where the subchannel is start pending, subchannel-and-device active, device active, suspended, or status pending.
<table>
<thead>
<tr>
<th>Subchannel State (^1)</th>
<th>Count (^2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Start pending (UUU0/AIPSX) (^2)</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Start pending and status pending (10YY/AIPSX) (^2)</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Start pending and status pending (00111/AIPSX) because the device appeared not operational on all paths (^2)</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Start pending and device active (UUU0/AIPSX) (^2)</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Suspended (YYYY/AIPSX) (^2)</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Subchannel-and-device active (UUU0/AIPSX) (^2)</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Device active (UUU0/AIPSX)</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Status pending (01001/AIPSX) because of program-controlled-interruption condition or initial-status interruption</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Status pending (1Y1Y1/AIPSX); termination occurred because of:</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Program check</td>
<td>See note 1</td>
</tr>
<tr>
<td>Protection check</td>
<td>See note 2</td>
</tr>
<tr>
<td>Chaining check</td>
<td>No change</td>
</tr>
<tr>
<td>channel-control check</td>
<td>See note 1</td>
</tr>
<tr>
<td>Interface-control check</td>
<td>See note 2</td>
</tr>
<tr>
<td>Channel-data check</td>
<td>See note 2</td>
</tr>
<tr>
<td>Status pending (YY1Y1/AIPSX); termination occurred under count control (^2)</td>
<td>Correct</td>
</tr>
<tr>
<td>Status pending (Y0011/AIPSX) (^2)</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Status pending (1Y1Y1/AIPSX) (^2)</td>
<td>Correct; residual count of last used CCW</td>
</tr>
<tr>
<td>Status pending (1Y111/AIPSX) because of alert status (^2)</td>
<td>Correct; residual count of last used CCW</td>
</tr>
<tr>
<td>Status pending (YYYY1/AIPSX) after termination by HALT SUBCHANNEL (^2)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Status pending (00001/AIPSX) after termination by CLEAR SUBCHANNEL</td>
<td>Not meaningful (^3)</td>
</tr>
<tr>
<td>Status pending (YY1Y1/AIPSX); operation completed normally at the subchannel (^2)</td>
<td>Correct; indicates the residual count</td>
</tr>
<tr>
<td>Status pending (1Y111/AIPSX) command chaining terminated because of alert status (^2)</td>
<td>Correct; original count of CCW specifying the new I/O operation</td>
</tr>
<tr>
<td>Status pending (10001/AIPSX) because of alert status</td>
<td>Not meaningful (^3)</td>
</tr>
</tbody>
</table>

Figure 16-7. (Part 1 of 2) Contents of Count Field in SCSW
Explanation:

In situations where more than a single condition exists because of, for example, alert status that is described by program check and unit check, the entry appearing first in the table takes precedence.

The meaning of the notation used in this column is as follows:

A  Alert status
I  Intermediate status
P  Primary status
S  Secondary status
X  Status Pending

The allowed combinations of status-control-bit settings is shown to the left of the "/" symbol by the use of these symbols:

0  Corresponding condition is not indicated
1  Corresponding condition is indicated
U  Unpredictable. The corresponding condition is not meaningful when the subchannel is not status pending.
Y  The corresponding condition is not significant and is indicated as a function of the subchannel state.

Notes:

1. The count is unpredictable unless IDAW/MIDAW check is indicated, in which case the count may not correctly reflect the number of bytes transferred to or from main storage but will (when used in conjunction with the CCW address) designate a byte location within the page in which the channel-control-check condition was recognized.

2. During a storage access, the maximum number of bytes that can be stored by a channel subsystem is model dependent. If a channel-data-check condition is recognized during that access, the number of bytes transferred to or from storage may not be detectable by the channel subsystem. Consequently, the number of bytes transferred to or from storage may not be correctly reflected by the residual count. However, the residual count that is stored when used in conjunction with the storage-access code and the CCW address designates a byte location within the page in which the channel-data-check condition was recognized.

Figure 16-7. (Part 2 of 2) Contents of Count Field in SCSW
Transport-Mode SCSW

The format of a transport-mode SCSW is as follows:

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-3 Subchannel Key</td>
<td></td>
</tr>
<tr>
<td>4 Reserved</td>
<td></td>
</tr>
<tr>
<td>5 ESW format (L)</td>
<td></td>
</tr>
<tr>
<td>6-7 Deferred condition code (CC)</td>
<td></td>
</tr>
<tr>
<td>8-10 Format (FMT)</td>
<td></td>
</tr>
<tr>
<td>11 IRB-Format control (X)</td>
<td></td>
</tr>
<tr>
<td>12 Interrogate-complete (Q)</td>
<td></td>
</tr>
<tr>
<td>13 Reserved</td>
<td></td>
</tr>
<tr>
<td>14 Extended control (E)</td>
<td></td>
</tr>
<tr>
<td>15 Path not operational (N)</td>
<td></td>
</tr>
<tr>
<td>16 Reserved</td>
<td></td>
</tr>
<tr>
<td>17-19 Function Control (FC)</td>
<td></td>
</tr>
<tr>
<td>17 Start function</td>
<td></td>
</tr>
<tr>
<td>18 Halt function</td>
<td></td>
</tr>
<tr>
<td>19 Clear function</td>
<td></td>
</tr>
<tr>
<td>20-26 Activity Control (AC)</td>
<td></td>
</tr>
<tr>
<td>20 Reserved</td>
<td></td>
</tr>
<tr>
<td>21 Start pending</td>
<td></td>
</tr>
<tr>
<td>22 Halt pending</td>
<td></td>
</tr>
<tr>
<td>23 Clear pending</td>
<td></td>
</tr>
<tr>
<td>24 Reserved</td>
<td></td>
</tr>
<tr>
<td>25 Device active</td>
<td></td>
</tr>
<tr>
<td>26 Reserved</td>
<td></td>
</tr>
</tbody>
</table>

Figure 16-9. Transport-Mode SCSW  (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>27-31 Status Control (SC)</td>
<td></td>
</tr>
<tr>
<td>27 Alert status</td>
<td></td>
</tr>
<tr>
<td>28 Intermediate status</td>
<td></td>
</tr>
<tr>
<td>29 Primary status</td>
<td></td>
</tr>
<tr>
<td>30 Secondary status</td>
<td></td>
</tr>
<tr>
<td>31 Status pending</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Word 1</th>
<th>TCW Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-31 TCW Address</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Word 2</th>
<th>Device Status (DEVS)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-7 Device Status (DEVS)</td>
<td></td>
</tr>
<tr>
<td>0 Attention</td>
<td></td>
</tr>
<tr>
<td>1 Status modifier</td>
<td></td>
</tr>
<tr>
<td>2 Control-unit end</td>
<td></td>
</tr>
<tr>
<td>3 Busy</td>
<td></td>
</tr>
<tr>
<td>4 Channel end</td>
<td></td>
</tr>
<tr>
<td>5 Device end</td>
<td></td>
</tr>
<tr>
<td>6 Unit check</td>
<td></td>
</tr>
<tr>
<td>7 Unit exception</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Word 2</th>
<th>Subchannel Status (SCHS)</th>
</tr>
</thead>
<tbody>
<tr>
<td>8-15 Subchannel Status (SCHS)</td>
<td></td>
</tr>
<tr>
<td>8 Reserved</td>
<td></td>
</tr>
<tr>
<td>9 Incorrect length</td>
<td></td>
</tr>
<tr>
<td>10 Program check</td>
<td></td>
</tr>
<tr>
<td>11 Protection check</td>
<td></td>
</tr>
<tr>
<td>12 Channel-data check</td>
<td></td>
</tr>
<tr>
<td>13 Channel-control check</td>
<td></td>
</tr>
<tr>
<td>14 Interface-control check</td>
<td></td>
</tr>
<tr>
<td>15 Channel-subsystem retry failed</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Word 2</th>
<th>FCX Status (FCXS)</th>
</tr>
</thead>
<tbody>
<tr>
<td>16-23 FCX Status (FCXS)</td>
<td></td>
</tr>
<tr>
<td>16 Reserved</td>
<td></td>
</tr>
<tr>
<td>17 Reserved</td>
<td></td>
</tr>
<tr>
<td>18 Reserved</td>
<td></td>
</tr>
<tr>
<td>19 Reserved</td>
<td></td>
</tr>
<tr>
<td>20 Reserved</td>
<td></td>
</tr>
<tr>
<td>21 Reserved</td>
<td></td>
</tr>
<tr>
<td>22 Reserved</td>
<td></td>
</tr>
<tr>
<td>23 TSB Valid</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Word 2</th>
<th>Subchannel-Extended Status (SCHXS)</th>
</tr>
</thead>
<tbody>
<tr>
<td>24-31 Subchannel-Extended Status (SCHXS)</td>
<td></td>
</tr>
<tr>
<td>24 Interrogate-Failed (F)</td>
<td></td>
</tr>
<tr>
<td>25-31 Subchannel-Extended-Status Qualifier (SESO)</td>
<td></td>
</tr>
</tbody>
</table>

Figure 16-9. Transport-Mode SCSW  (Continued)
The following descriptions indicate when an SCSW field contains meaningful information for a transport-mode IRB.

**Subchannel Key**
This bit has the same meaning as in the command mode SCSW. (See “Subchannel Key” on page 9).

**Reserved**
SCSW bits 4, 13, 16, 20, 24, and 26 of word 0, bits 0 of word 1, and bits 1, 8, 15, and 16-22 of word 2 are reserved and stored as zeros.

**Extended-Status-Word Format (L)**
This bit has the same meaning as in the command-mode SCSW. (See “Extended-Status-Word Format (L)” on page 9).

**Deferred Condition Code (CC)**
This field has the same meaning as in the command-mode SCSW. (See “Deferred Condition Code (CC)” on page 9).

**Format (FMT)**
Bits 8-10 of word 0 are the IRB-format field that contains a 3-bit, unsigned integer whose value specifies the layout of the IRB, when the IRB-format control bit (X), is set to one.

<table>
<thead>
<tr>
<th>FMT</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Transport-Mode IRB</td>
</tr>
<tr>
<td>1-7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**IRB-Format Control (X)**
Bit 11 of word 0 is the IRB-format control bit. The value of this bit is one for the transport-mode IRB. (See Figure 16-2 on page 7).

**Interrogate Complete (Q)**
Bit 12 of word 0 is the interrogate-complete bit (Q). When one, Q indicates that the interrogate operation has completed successfully, and the subchannel is made status-pending with intermediate interruption status. If the pending intermediate interruption condition has not been cleared by TEST SUBCHANNEL by the time the primary interruption condition for the original interrogated operation is presented at the subchannel, both conditions may be merged and indicated together in the SCSW.

**Subchannel-Control Field**
The subchannel-control information is contained in bit positions 13-31 of the first word of the SCSW.

**Extended Control (E)**
Bit 14 of word 0, when one, indicates that model-dependent information is stored in the extended-control word (ECW). When bit 14 is zero, the contents of words 0-7 of the ECW are unpredictable. The E bit is meaningful whenever the subchannel is status pending with alert status either alone or together with primary status, secondary status, or both. The concurrent sense information has no meaning when a transport-mode IRB is stored.

**Path Not Operational (N)**
This bit has the same meaning as in the command-mode SCSW. See “Path Not Operational (N)” on page 13.

**Function Control (FC)**
The function-control field indicates the basic I/O functions that are indicated at the subchannel. This field may indicate the acceptance of as many as two functions. The function-control field is contained in bit positions 17-19 of the first word of the SCSW. The function-control field is meaningful at an installed subchannel whenever the subchannel is valid (see “Function Control (FC)” on page 13). The function-control field contains all zeros whenever both the activity- and status-control fields contain all zeros. The meaning of the individual bits is as follows:

**Start Function (Bit 17):** This bit has the same meaning as in the command-mode SCSW. (See “Start Function (Bit 17)” on page 7).

**Halt Function (Bit 18):** When one, bit 18 indicates that a halt function has been requested and is either pending or in progress at the subchannel. A halt function is requested by the execution of HALT SUBCHANNEL. A halt function is indicated at the subchannel when condition code 0 is set for HALT SUBCHANNEL. The halt-function indication is cleared at the subchannel when the next status-pending condition that occurs is cleared by the execution of TEST SUBCHANNEL. The next status-pending condition depends on the state of the subchannel when HALT SUBCHANNEL is executed. If the subchannel is start pending or device active when HALT SUBCHANNEL is executed, then the
The activity-control field is meaningful at an installed subchannel whenever the subchannel is valid (see “Device Number Valid (V)” on page 4). However, if an IFCC or CCC condition is detected during the performance of a basic I/O function and that function is indicated as pending, I/O operations may or may not have been performed at the device. The activity-control bits are defined as follows:

**Start Pending (Bit 21):** This bit has the same meaning as in the command-mode SCSW with the exception that the subchannel remains start pending until a primary interruption condition is generated. (See “Start-Pending (Bit 21)” on page 15).

**Halt Pending (Bit 22):** This bit has the same meaning as in the command-mode SCSW. (See “Halt-Pending (Bit 22)” on page 16).

**Clear Pending (Bit 23):** This bit has the same meaning as in the command-mode SCSW. (See “Clear-Pending (Bit 23)” on page 16).

**Device Active (Bit 25):** When one, bit 25 indicates that the subchannel is device active. A subchannel is said to be device active when an I/O operation is currently in progress at the associated device. The subchannel becomes device active, only when primary status is presented without secondary.

The status-control field is contained in bit positions 27-31 of word 0 of the SCSW. This field provides the program with a summary-level indication of the interruption condition described by either subchannel or device status or the Q bit. More than one summary indication may be signaled as a result of existing conditions at the subchannel. Whenever the subchannel is enabled (see “Enabled (E)” on page 3) and at least bit 31 is one, the subchannel is said to be status pending. Whenever the subchannel is disabled, the subchannel is not made status pending. Bit 31 of SCSW word 0 is meaningful at an installed subchannel whenever the subchannel is valid (see “Device Number Valid (V)” on page 4); bits 27-30 are meaningful when bit 31 is one. The status-control bits are defined as follows:

**Alert Status (Bit 27):** This bit has the same meaning as in the command-mode SCSW with the exception that a command-mode IRB is stored when alert status is presented with secondary status. (See “Alert Status (Bit 27)” on page 17).

**Intermediate Status (Bit 28):** Intermediate status can be indicated when the interrogate operation associated with the TCW is completed, and the Q-bit (interrogate-complete) is one.

**Primary Status (Bit 29):** This bit has the same meaning as in the command-mode SCSW. (See “Primary Status (Bit 29)” on page 19).

**Secondary Status (Bit 30):** This bit has the same meaning as in the command-mode SCSW. (See “Secondary Status (Bit 30)” on page 19).

**Status Pending (Bit 31):** This bit has the same meaning as in the command-mode SCSW. (See “Status-Pending (Bit 31)” on page 19).

**TCW Address Field**

Bits1-31 of word 1 form an absolute address of a TCW. The TCW address indicated is the address of the current TCW when the subchannel becomes pending with primary interruption. When the subchannel-status field indicates channel-control check, channel-data check, program check or interface-control check, the TCW-address field is usable for recov-
ery purposes if the TCW-address field-validity flag in
the ESW is one.

<table>
<thead>
<tr>
<th>Subchannel State</th>
<th>TCW Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Start pending (UUUU0/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Start pending and device active (UUUU0/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Subchannel-and-device active (UUUU0/AIPSX)</td>
<td>N/A</td>
</tr>
<tr>
<td>Device active only (UUUU0/AIPSX)</td>
<td>Unpredictable</td>
</tr>
<tr>
<td>Suspended (YYYYY/AIPSX)</td>
<td>N/A</td>
</tr>
<tr>
<td>Status pending (10001/AIPSX) because of unsolicited</td>
<td>Address of current TCW3</td>
</tr>
<tr>
<td>status from the device while the subchannel was</td>
<td></td>
</tr>
<tr>
<td>start pending</td>
<td></td>
</tr>
<tr>
<td>Status pending (0Y111/AIPSX) because the device</td>
<td>Address of current TCW3</td>
</tr>
<tr>
<td>appeared not operational on all paths</td>
<td></td>
</tr>
<tr>
<td>Status pending (10011/AIPSX) because of solicited</td>
<td>Address of current TCW3</td>
</tr>
<tr>
<td>alert status from the device while the subchannel</td>
<td></td>
</tr>
<tr>
<td>was start pending and device active</td>
<td></td>
</tr>
<tr>
<td>Status pending (10111/AIPSX) because of solicited</td>
<td>See note 2</td>
</tr>
<tr>
<td>alert status generated by the channel subsystem</td>
<td></td>
</tr>
<tr>
<td>while the subchannel was start pending and device</td>
<td></td>
</tr>
<tr>
<td>active</td>
<td></td>
</tr>
<tr>
<td>Status pending (01001/AIPSX) for the program-</td>
<td>N/A</td>
</tr>
<tr>
<td>controlled-interruption condition while the subchannel</td>
<td></td>
</tr>
<tr>
<td>was subchannel-and-device active</td>
<td></td>
</tr>
<tr>
<td>Status pending (01001/AIPSX) for the initial-status-</td>
<td>N/A</td>
</tr>
<tr>
<td>interruption condition while the subchannel was</td>
<td></td>
</tr>
<tr>
<td>subchannel-and-device active</td>
<td></td>
</tr>
<tr>
<td>Status pending (01001/AIPSX) for the intermediate/</td>
<td>Address of current TCW3</td>
</tr>
<tr>
<td>interrogate</td>
<td></td>
</tr>
<tr>
<td>Status pending (1Y1Y1/AIPSX); termination occurred</td>
<td></td>
</tr>
<tr>
<td>because of program check caused by one of the</td>
<td></td>
</tr>
<tr>
<td>following conditions:</td>
<td></td>
</tr>
<tr>
<td>Bit 24 of word 1 of the ORB set to one; incorrect-</td>
<td>N/A</td>
</tr>
<tr>
<td>length-indication-suppression facility not installed</td>
<td></td>
</tr>
<tr>
<td>Unused bits in ORB not set to zeros</td>
<td>Address of current TCW3</td>
</tr>
<tr>
<td>Invalid TCW-address specification in the channel-</td>
<td>Address of invalid TCW</td>
</tr>
<tr>
<td>program address in the ORB</td>
<td></td>
</tr>
<tr>
<td>Invalid TCW address in the channel-program address in</td>
<td>Address of invalid TCW</td>
</tr>
<tr>
<td>the ORB</td>
<td></td>
</tr>
<tr>
<td>Invalid TCW address while DCW data chaining</td>
<td>N/A</td>
</tr>
<tr>
<td>Invalid TCW count or TIDAW count</td>
<td>Address of invalid TCW</td>
</tr>
<tr>
<td>Invalid TIDAW-address specification</td>
<td>Address of invalid TCW</td>
</tr>
<tr>
<td>Invalid TIDAW address in TCW</td>
<td>Address of invalid TCW</td>
</tr>
<tr>
<td>Invalid TIDAW address while sequentially fetching</td>
<td>N/A</td>
</tr>
<tr>
<td>TIDAWs</td>
<td></td>
</tr>
<tr>
<td>Invalid data-address specification</td>
<td>Address of invalid TCW</td>
</tr>
<tr>
<td>Invalid data address in a TCW</td>
<td>Address of invalid TCW</td>
</tr>
<tr>
<td>Invalid data address while sequentially accessing</td>
<td>Address of current TCW</td>
</tr>
<tr>
<td>storage</td>
<td></td>
</tr>
<tr>
<td>Invalid data address in TIDAW</td>
<td>Address of current TCW</td>
</tr>
</tbody>
</table>

Figure 16-10. (Part 1 of 3) TCW Address as Function of Subchannel State
<table>
<thead>
<tr>
<th>Subchannel State</th>
<th>TCW Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Invalid TSB-address specification</td>
<td>Address of current TCW</td>
</tr>
<tr>
<td>Invalid TSB address</td>
<td>Address of current TCW</td>
</tr>
<tr>
<td>Invalid TCCB address specification</td>
<td>Address of current TCW</td>
</tr>
<tr>
<td>Invalid TCCB address</td>
<td>Address of current TCW</td>
</tr>
<tr>
<td>Device-detected program checks</td>
<td>Address of current TCW</td>
</tr>
</tbody>
</table>

Status pending (1Y1Y1/AIPSX); termination occurred because of protection check detected as follows:

- On a TCW access: Address of protected TCW
- On data or an TIDAW access: Address of current TCW

Status pending (1Y1Y1/AIPSX); termination occurred because of chaining check: N/A

Status pending (YY1Y1/AIPSX); termination occurred under count control: Address of current TCW

Status pending (1Y1Y1/AIPSX); operation prematurely terminated by the device because of alert status: Address of current TCW

Status pending (YYYY1/AIPSX) after termination by HALT SUBCHANNEL and the activity-control-field bits indicated below set to ones:

- Status pending alone: Unpredictable
- Start pending: Unpredictable
- Device active and start pending: Unpredictable
- Device active: Unpredictable

Status pending (00001/AIPSX) after termination by CLEAR SUBCHANNEL: Unpredictable

Status pending (YYYY1/AIPSX); operation completed normally at the subchannel: Address of current TCW

Status pending (00011/AIPSX): Unpredictable

Status pending (10001/AIPSX): Unpredictable

Status pending (00001/AIPSX): Unpredictable

Status pending (1Y111/AIPSX); command chaining suppressed because of alert status other than channel-control check or interface-control check: N/A

Status pending (1YYY1/AIPSX) because of alert status for channel-control check or interface-control check: See note 3

Status pending (1Y1Y1/AIPSX) because of channel-data check: Address of current TCW

Status pending (1Y1Y1/AIPSX) because of channel-subsystem retry failed: Address of current TCW

**Explanation:**

1 The meaning of the notation used in this column is as follows:
   - A Alert status
   - I Intermediate status
   - P Primary status
   - S Secondary status
   - X Status Pending

---

*Figure 16-10. (Part 2 of 3) TCW Address as Function of Subchannel State (Continued)*
Device-Status Field

The device-status field is contained in bit positions 0-7 of word 2 of the SCSW. Each bit of the device-status field has the same meaning as in the command-mode SCSW. See “Device-Status Field” on page 24 for details.

Subchannel-Status Field

The subchannel-status field is contained in bit positions 8-15 of word 2 of the SCSW. Subchannel-status conditions are detected and indicated in the SCSW by the channel subsystem. Except for the conditions caused by equipment malfunctioning, they can occur only while the channel subsystem is involved with the performance of a halt or start function. The subchannel-status field is meaningful whenever the subchannel is status pending with any combination of primary, secondary, intermediate, or alert status. When the subchannel is status pending with deferred condition code 3 indicated, the contents of the subchannel-status field are not meaningful. The following subchannel-status conditions are described:

Incorrect Length
Incorrect length occurs when the number of bytes contained in the storage areas assigned for the I/O operation is not equal to the number of bytes requested or offered by the I/O device.

When the FCX-incorrect-length-indication facility is not installed and an incorrect-length condition is detected, the processing of the transport-mode channel program is terminated with program-check status.

When the FCX-incorrect-length-indication facility is installed, the device supports incorrect-length indication, incorrect-length-indication is not being suppressed, and an incorrect-length condition is detected, incorrect length is indicated for one of the following reasons:

Long Block on Input: During a read or sense operation, the device attempted to transfer one or more bytes to main storage after the assigned main-storage areas were filled, or the device indicated that more data could have been transferred if the count had been larger. The extra bytes have not been placed in main storage. The count in the TSB header (TSH) is zero.

Long Block on Output: During a write operation, the device requested one or more bytes from the channel subsystem after the assigned main-storage areas were exhausted, or the device indicated that more data could have been transferred if the count had been larger. The count in the TSH is zero.
Short Block on Input: The number of bytes transferred during a read or sense operation is insufficient to fill the main-storage areas assigned to the operation. The count in the TSH is not zero.

Short Block on Output: The device terminated a write before all of the information contained in the assigned main-storage areas was transferred to the device. The count in the TSH is not zero.

The incorrect-length indication is suppressed when the current DCW has the SLI flag set to one. The incorrect-length indication is not meaningful when the count field of the TSH is not meaningful.

Presence of the incorrect-length condition suppresses command chaining unless the SLI flag in the DCW is one.

Program Check
Program check occurs when programming errors are detected by the channel subsystem. For a transport-mode operation, programming errors may also be detected by the I/O device and are reported as program checks. When a program check condition is recognized, additional information may be available in the “Subchannel-Extended-Status Qualifier (SESQ)” section of the subchannel-extended-status field when a program check is indicated.

Whenever the program-check condition pertains to the fetching of data, the failing-storage-address validity flag, bit 6 of the ERW, is one. An address of a location within the checking block for which the program-check condition is generated is stored in the ESW failing-storage-address field.

A program check condition can be due to any of the following reasons:

Invalid TCW Specification: When any of the following conditions is detected, an invalid TCW specification is recognized:

1. A reserved field that is checked for zeros in the TCW does not contain zeros.
2. A nonzero value is specified in the TCW format field.
3. The read and write bits in the TCW are both one, bit 10 of the TCW flags field is zero, and either or both of the following are true.
4. The TCCB-length field in a TCW specifies a length that is less than 12 or greater than 244.

Invalid TCW-Address Specification: An invalid TCW address specification can occur because the TCW address is not designated on a 64-byte boundary.

Invalid TCW Address: The channel-subsystem has attempted to fetch a TCW from a main-storage location that is not available. An invalid TCW address can occur because the program has designated an invalid address in the TCW address field of the transport-mode ORB, when the B-bit (channel-program-type control), is one. A main-storage location is unavailable when the absolute TCW address does not correspond to a physical location.

Invalid TCW Counts: When any of the following conditions is detected by the channel subsystem, an invalid TCW byte count is recognized:

1. The write-bit is one in the TCW and the value in the TCW output-count field is zero.
2. The read-bit is one in the TCW and the value in the TCW input-count field is zero.

Invalid TSB-Address Specification: An invalid transport-status-block address specification can occur if the content of the transport-status-block-address field specified in the TCW does not designate a storage location on a doubleword boundary.

Invalid TSB Address: The channel-subsystem has attempted to store a TSB to a main-storage location that is not available. An invalid transport-status-block address can occur because the program has designated an unavailable location in a TCW, or the channel-subsystem has attempted to store the transport status to a main-storage location that is not available. A main-storage location is unavailable when the absolute address of the location does not correspond to a physical location.

Invalid TCCB Address: The channel-subsystem has attempted to fetch a TCCB from a main-storage location that is not available. An invalid transport-command-control-block address can occur because
the program has designated an unavailable location in a TCW, or has specified a transport-command-control-block address and a length which caused a list of TIDAW to cross a 4K-byte when the transport-command-control-block-TIDA flag in the TCW is one. A main-storage location is unavailable when the absolute address of the location does not correspond to a physical location. **Invalid TIDAW-Address Specification:** Transport-indirect data addressing is specified, and any of the following conditions is detected:

1. A write operation is requested, the output-TIDA flag in a TCW is one, and the contents of the output-data-address field in the TCW do not designate a storage location on a quadword boundary.

2. A read operation is requested, the input-TIDA flag in a TCW is one, and the contents of the input-data-address field in the TCW do not designate a storage location on a quadword boundary.

3. The transport-command-control-block-TIDA flag in the TCW is one, and the contents of the transport-command-control-block-address do not designate a storage location on a quadword boundary.

**Invalid Data Address:** An invalid data address can occur because the program has designated an unavailable location specified by a TCW or a TIDAW. When any of the following conditions is detected, an invalid data address is recognized by the channel subsystem:

1. The channel-subsystem has attempted to access a main-storage location that is not available. A main-storage location is unavailable when the absolute address of the location does not correspond to a physical location.

2. The channel subsystem, on sequentially accessing storage for a data fetch or data store, attempted to access an unavailable location.

3. Use of the data address has caused the channel subsystem to attempt to wrap from the maximum storage address to zero.

**Invalid TIDAW Specification:** When the use of TIDAW is specified, an invalid TIDAW specification is recognized when any of the following conditions is detected by the channel subsystem:

1. Any of the bits defined as reserved in the TIDAW are not zero.

2. The TIDAW-transfer-in-channel flag (TTIC) in a TIDAW is one, and one or more other flag bits are also one.

3. The TTIC points to a TIDAW in which the TTIC flag is one.

4. The TIDAW count field contains zeros when the TTIC flag is zero.

5. The combination of a TIDAW data-address and count fields specify data that crosses a 4K-byte block boundary, when skipping is not in effect.

6. The count value specified in the TIDAW in which the last-TIDAW flag is one and the value for either input-count or output-count specified in a TCW did not both decrement to zero for the same byte of data transferred.

7. For a read operation only, the TIDAW in control has its data-transfer-interruption control flag set to one when data transfer was attempted by the device.

8. The TIDAW is in the TIDAW list designated by the TCCB-address field in the TCW and the count field of the TIDAW contains either a value that is zero or a value that is not evenly divisible by four.

**Invalid TIDAW Address:** The channel-subsystem has attempted to fetch a TIDAW from a main-storage location that is not available. An invalid TIDAW address can occur because the program has designated an invalid address in a TCW that specifies TIDAW addressing, or because the channel subsystem, on sequentially fetching TIDAWs, attempts to fetch from an unavailable location. A main-storage location is unavailable when the absolute address of the location does not correspond to a physical location. **Storage-Requests Limit Exceeded:** The use of TIDAWs is specified, and the model-dependent maximum number of storage requests required to satisfy the transfer of a block of data has been reached.

**Max Data-Count Exceeded:** The model-dependent maximum count of data for a single transport-control area (TCA) has been reached or exceeded for the current operation.
**Device-Detected Program Check:** Device-detected program checks are errors detected during a transport-mode operation by the I/O device and the channel-subsystem is requested to present a program-check condition. When a device-detected-program-check condition is recognized, additional information is available in the subchannel-extended-status field, and the TSB is stored with a transport-status-area format of two. (See device-detected-program check in chapter 15.)

**Protection Check**
Protection check occurs when the channel subsystem attempts a storage access that is prohibited by the protection mechanism. A protection check condition is indicated as a result of a storage operation that detects any of the following errors:

1. Protection applies to the fetching of TCW.
2. Protection applies to the fetching of TCCB.
3. Protection applies to the fetching of TIDAWs.
4. Protection applies to the fetching of output data.
5. Protection applies to the storing of input data.

The subchannel key provided in the transport-mode ORB is used as the access key for storage accesses associated with an I/O operation except for the TSB store.

Detection of the protection-check condition during the fetching of a TCW, TCCB, or a TIDAW would cause the operation to be suppressed and the subchannel to be made status pending with primary, secondary, and alert status. When protection check is detected after the I/O operation has been initiated at the device, the device may be signaled to conclude the operation. Other indications may accompany the protection-check indication as a function of the operation specified by the TCW, the status received from the device, on a read operation, and the current state of the subchannel. The protection-check condition may or may not cause the execution of subsequent DCWs in a TCCB to be suppressed.

Whenever the protection-check condition pertains to the fetching of data, the failing-storage-address validity flag, bit 6 of the ERW, is one. An address of a location within the checking block for which the protection-check condition is generated is stored in the ESW failing-storage-address field.

Additional information may be available in the “Subchannel-Extended-Status Qualifier (ESQ)” section of the subchannel-extended-status field when a protection check condition check is indicated.

**Channel-Data Check**
Channel-data check indicates that an uncorrected storage error has been detected in regard to data, contained in main storage, that is currently used in the performance of an I/O operation. Channel-data check is indicated when data has an invalid checking-block code (CBC) in main storage when that data is referenced by the channel subsystem.

On an input operation, when the channel subsystem attempts to store less than a complete checking block, and invalid CBC is detected on the checking block in storage, the contents of the location remain unchanged and with invalid CBC. On an output operation, whenever channel-data check is indicated, no bytes from the checking block with invalid CBC are transferred to the device.

During a storage access, the maximum number of bytes that can be transferred is model dependent. If a channel-data-check condition is recognized during that storage access, the number of bytes transferred to or from storage may not be detectable by the channel subsystem. Consequently, the number of bytes transferred to or from storage may not be correctly reflected by the residual count. When a channel-data-check condition is recognized during a storage access, the channel subsystem stores the address where the storage exception is encountered.

A condition indicated as channel-data check causes the current operation, if any, to be terminated. The subchannel becomes status pending with primary, secondary and alert status, as a function of the status received from the device. The TCW address field of the SCSW stored by TEST SUBCHANNEL pertain to the operation terminated. The extended-status-word-format bit is one, and subchannel-logout information is stored in the ESW, when TEST SUBCHANNEL is executed.

Whenever the channel-data-check condition pertains to the fetching of data, the failing-storage-address-validity flag, bit 6 of the ERW, is one. An address of a location within the checking block for which the channel-data-check condition is generated is stored in the ESW failing-storage-address field.
Uncorrectable storage or key errors detected during data access causes the operation to be terminated. In this case the subchannel is made status pending with primary, secondary, and alert status, with channel-data check indicated, and with the ESW failing-storage address stored.

Whenever channel-data check is indicated, no measurement data for the subchannel is stored. The transport-status block may or may not be stored. Additional information may be available in the “Subchannel-Extended-Status Qualifier (SESQ)” section of the subchannel-extended-status field.

**Channel-Control Check**

Channel-control check is caused by any machine malfunction affecting channel-subsystem controls. The condition may be indicated when an invalid CBC is detected on a TCW, TIDAW, TCCB, TSB, or the respective associated key.

Channel-control check may also indicate that an error has been detected in the information transferred to or from main storage during an I/O operation. However, when this condition is detected, the error has occurred inboard of the channel path: in the channel subsystem or in the path between the channel subsystem and main storage.

Detection of the channel-control-check condition causes the current operation, if any, to be terminated immediately. The subchannel is made status pending with primary and alert status or with primary, secondary, and alert status as a function of the type of termination, the current subchannel state, and the device status presented, if any. When the channel subsystem recognizes a channel-control-check condition, any previously existing intermediate interruption condition may or may not be recognized by the channel subsystem.

Whenever the channel-control-check condition pertains to an invalid CBC detected on fetching a TCW or a TCCB, or a TIDAW or storing a TSB, an extended-report word with bit 6 set to one, and the failing-storage address, are stored in the ESW when TEST SUBCHANNEL is executed.

Channel-control-check conditions encountered while fetching when the subchannel is start pending cause the operation to be terminated. In this case, the subchannel is made status pending with primary, secondary, and alert status, with channel-control check indicated, and with a failing-storage address that is stored in the ESW.

If a subchannel is halt pending and the channel subsystem encounters a channel-control-check condition while performing the halt function for that subchannel, the subchannel remains halt pending unless the channel subsystem can determine that the halt signal was issued. The subchannel remains halt pending even if the channel subsystem was attempting to issue the halt signal and is unable to determine if the halt signal was issued.

If a subchannel is start pending and the channel subsystem encounters a channel-control-check condition while performing the start function for that subchannel, the subchannel is made status pending with at least alert and primary status.

In some situations in which a channel-subsystem malfunction exists, the channel-control-check condition may be reported as a machine-check condition.

Whenever channel-control check is indicated, no measurement data for the subchannel is stored. The transport-status block may or may not be stored. Additional information may be available in the “Subchannel-Extended-Status Qualifier (SESQ)” section of the subchannel-extended-status field.

**Interface-Control Check**

Interface-control check indicates that an invalid signal has occurred on the channel path. The condition is detected by the channel subsystem and usually indicates malfunctioning of an I/O device. Interface-control check can occur for any of the following reasons:

1. A data or status byte received from a device has an invalid checking-block code.
2. A signal from an I/O device either did not occur or occurred at an invalid time.
3. ESW bit 26, indicating device-status check, is set to one.
4. A failed interrogate function or a recovery operation.
5. The TCW residual count did not match the residual count in the response from the device.

When the channel subsystem recognizes an interface-control-check condition, any previously existing
intermediate interruption condition may or may not be recognized by the channel subsystem. The extended-status-word-format bit is one, and sub-channel-logout information is stored in the ESW, when TEST SUBCHANNEL is executed.

If a subchannel is halt pending and the channel subsystem encounters an interface-control-check condition while performing the halt function for that subchannel, the subchannel remains halt pending unless the channel subsystem can determine that the halt signal was issued. The subchannel remains halt pending even if the channel subsystem was attempting to issue the halt signal and is unable to determine if the halt signal was issued.

If a subchannel is start pending and the channel subsystem encounters an interface-control-check condition while performing the start function for that subchannel, the subchannel is made status pending with at least alert and primary status.

Whenever interface-control check is indicated, no measurement data for the subchannel is stored. The transport-status block may or may not be stored. Additional information may also be available in the “Subchannel-Extended-Status Qualifier (SESQ)” section of the subchannel-extended-status field.

Channel-Subsystem Retry Failed
Channel-subsystem retry failed indicates that internal channel-subsystem conditions exist that prevent the fetching of the TCCB, a TIDAW, or data. The channel subsystem retried the fetch and the retry failed.

FCX-Status Field
The FCX-status field is contained in bit positions 16-23 of word 2 of the SCSW. This field contains channel specific status information returned by the I/O device.

**TSB Valid (Bit 23)**: Bit 23, when set to one, indicates that additional status information for the I/O operation designated by the subchannel is available in the transport-status block. When zero, the contents of the transport-status block do not contain any additional status information for the completed I/O operation.

**Subchannel-Extended-Status Field**

The subchannel-extended-status field is contained in bit positions 24-31 of word 2 of the SCSW. This field may contain information used to further qualify the reason for any of the following conditions, when indicated in the subchannel-status: interface-control check, channel-control check, channel-data check, program check, and protection check. If none of these bits are active in the subchannel-status byte, the fields of the subchannel-extended-status contain no meaningful information. When more than one condition is indicated, the interface-control check takes priority over the other conditions.

**Interrogate Failed (F)**: Bit 24 is the interrogate-failed operation bit. When set to one, the F bit indicates that an interrogate operation failed because of a program check, channel-control check, or interface-control check.

**Subchannel-Extended-Status Qualifier (SESQ)**: Bits 25-31 are the subchannel-extended-status qualifier and contain an unsigned integer value. When the subchannel-status field indicates program check, interface-control check, protection check, data check, or channel-control check, bits 25-31 may contain additional information as follows:

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
<th>IFCC</th>
<th>CCC</th>
<th>CDC</th>
<th>PGC</th>
<th>PTC</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No status available for the exception condition indicated.</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
<tr>
<td>1</td>
<td>Storage-request limit exceeded, a model-dependent number of storage requests has been exceeded for the requested block of data.</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>X</td>
<td>-</td>
</tr>
</tbody>
</table>

*Figure 16-11. Subchannel-Extended Status Qualifiers*
<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
<th>IFCC</th>
<th>CCC</th>
<th>CDC</th>
<th>PGC</th>
<th>PTC</th>
</tr>
</thead>
</table>
| 2     | Program check when all of the following conditions are met:  
(1) The TCW read or write data count did not go to zero and either the incorrect-length indication facility is not installed or incorrect-length indication is not supported by the device.  
(2) CE only or CE and DE only status was received, or unit-check with CE or CE and DE status was received.  
(3) The operation is not an interrogate, transfer-COB, or transfer-TCA operation. | -    | -   | -   | X   | -   |
| 3     | Transport mode not supported by the I/O device.                                                                                                                                                              | -    | -   | -   | X   | -   |
| 4     | Transport mode not supported on the selected channel path.                                                                                                                                                  | -    | -   | -   | X   | -   |
| 5     | Reserved                                                                                                                                                                                                  | -    | -   | -   | -   | -   |
| 6     | Program check on the TCW: An invalid TCW was detected.                                                                                                                                                     | -    | -   | -   | X   | -   |
| 7     | A device-detected program check condition exists due to indeterminate cause.                                                                                                                                | -    | -   | -   | X   | -   |
| 8     | A device-detected program check condition exists.                                                                                                                                                           | -    | -   | -   | X   | -   |
| 9     | Program check on a TIDAW: An invalid TIDAW was detected.                                                                                                                                                   | -    | -   | -   | X   | -   |
| 10-31 | Reserved.                                                                                                                                                                                                  | -    | -   | -   | -   | -   |
| 32    | TCW access exception: An exception was detected on while fetching a TCW.                                                                                                                                   | - X  | - X | - X | X   | X   |
| 33    | TSB access exception: An exception was detecting while storing a TSB.                                                                                                                                      | - X  | - X | - X | -   | -   |
| 34    | TCCB access exception: An exception was detected while fetching a TCCB.                                                                                                                                   | - X  | - X | - X | X   | X   |
| 35    | TIDAW access exception: An exception was detected while fetching a TIDAW.                                                                                                                                   | - X  | - X | - X | X   | X   |
| 36    | Data access exception: An exception was detected while storing or fetching data.                                                                                                                               | -    | - X | X   | X   | X   |
| 37-63 | Reserved.                                                                                                                                                                                                  | -    | -   | -   | -   | -   |
| 64    | An invalid CBC error on read data                                                                                                                                                                            | X    | -   | -   | -   | -   |
| 65    | Reserved                                                                                                                                                                                                  | -    | -   | -   | -   | -   |
| 66    | A link protocol error condition has occurred.                                                                                                                                                               | X    | -   | -   | -   | -   |
| 67    | A failed device-level recovery operation.                                                                                                                                                                  | X    | -   | -   | -   | -   |
| 68    | IFCC occurred because a device-level recovery operation failed. A program, protection or data check may also be set to one in the Subchannel status.                                                             | X    | -   | -   | -   | -   |
| 69    | The residual count between the TCW and the response from the device are not the same.                                                                                                                       | X    | -   | -   | -   | -   |
| 70    | An invalid CBC was detected on the status portion of the transport response from the device.                                                                                                                  | X    | -   | -   | -   | -   |
| 71    | An invalid CBC was detected on the TSB transported from the device.                                                                                                                                      | X    | -   | -   | -   | -   |
| 72-127| Reserved.                                                                                                                                                                                                  | -    | -   | -   | -   | -   |

Figure 16-11. Subchannel-Extended Status Qualifiers (Continued)
<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
<th>IFCC</th>
<th>CCC</th>
<th>CDC</th>
<th>PGC</th>
<th>PTC</th>
</tr>
</thead>
<tbody>
<tr>
<td>X</td>
<td>Applicable</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-</td>
<td>Not applicable</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IFCC</td>
<td>Interface-control check</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CCC</td>
<td>Channel-control check</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CDC</td>
<td>Channel-data check</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PGC</td>
<td>Program check</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PTC</td>
<td>Protection check</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Explanation:**

- **X**: Applicable
- **-**: Not applicable

**IFCC**: Interface-control check

**CCC**: Channel-control check

**CDC**: Channel-data check

**PGC**: Program check

**PTC**: Protection check

**Footnotes:**

- **a**: The failing-storage-address (FSA) field in the ESW is valid and contains the address of the TIDAW which was determined to be invalid.
- **b**: The FSA field is valid and contains the address of the current TCW.
- **c**: The FSA field is valid and contains the address of the TSB designated by the current TCW.
- **d**: The FSA field is valid and contains the address of the TCCB designated (directly or indirectly) by the TCW.
- **e**: The FSA field is valid and contains the address of the TIDAW for which the exception was detected.
- **f**: The FSA field is valid and contains the address of the input or output data designated (directly or indirectly) by the TCW.

**Note:** If the FSA field is valid for any SESQ value other than those identified by footnotes a-f, the FSA field contains the address of the current TCW.

*Figure 16-11. Subchannel-Extended Status Qualifiers (Continued)*
The extended-status word (ESW) provides additional information to the program about the subchannel and its associated device. The ESW is placed in words 3-7 of the IRB designated by the second operand of TEST SUBCHANNEL when TEST SUBCHANNEL is executed and the subchannel designated is operational. If the subchannel is status pending or status pending with any combination of primary, secondary, intermediate, or alert status (except as noted in the next paragraph) when TEST SUBCHANNEL is executed, the ESW may have any of the following types of extended-status format:

**Format 0** Subchannel logout in word 0, an ERW in word 1, a failing-storage address or zeros in words 2 and 3, and a secondary-CCW address or zeros in word 4.

**Format 1** Zeros in bytes 0, 2, and 3 of word 0, the LPUM in byte 1 of word 0, an ERW in word 1, and zeros in words 2-4.

**Format 2** Zeros in byte 0, the LPUM in byte 1, and the device-connect time in bytes 2 and 3 of word 0; an ERW in word 1; zeros in words 2-4.

**Format 3** Zeros in byte 0, the LPUM in byte 1, and unpredictable values in bytes 2 and 3 of word 0; an ERW in word 1; zeros in words 2-4.

Words 0-4 of the ESW contain unpredictable values if any of the following conditions is met:

1. The subchannel is not status pending.
2. The subchannel is status pending alone, and the extended-status-word-format bit is zero.
3. The subchannel is status pending with intermediate status alone for other than the intermediate interruption condition due to suspension.

The type of extended-status format stored depends upon conditions existing at the subchannel at the time TEST SUBCHANNEL is executed. The conditions under which each of the types of formats is stored are described in the remainder of this section.

**Extended-Status Format 0**

The ESW stored by TEST SUBCHANNEL is a format-0 ESW when the extended-status-word-format bit, bit 5 of word 0 of the SCSW, is one and the subchannel is status pending with any combination of status as defined in Figure 16-12 on page 51. In this case, subchannel-logout information and an ERW are stored in the extended-status word. Subchannel logout provides detailed model-independent information relating to a subchannel and describing equipment errors detected by the channel subsystem. The information is provided to aid the recovery of an I/O operation, a device, or both. Whenever subchannel logout is provided, the error conditions relate only to the subchannel reporting the error. If I/O operations involving other subchannels have been affected by the error condition, those subchannels also provide similar subchannel-logout information. An extended-report word provides additional information relating to the cause of the malfunction.

A format-0 ESW has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Subchannel Logout</td>
</tr>
<tr>
<td>1</td>
<td>Extended-Report Word</td>
</tr>
<tr>
<td>2</td>
<td>Failing-Storage Address or ESLD</td>
</tr>
<tr>
<td>3</td>
<td>Secondary-CCW Address or Zeros</td>
</tr>
<tr>
<td>4</td>
<td></td>
</tr>
</tbody>
</table>

**Subchannel Logout**

The subchannel logout has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ESF</td>
</tr>
<tr>
<td>1</td>
<td>LPUM</td>
</tr>
<tr>
<td>2</td>
<td>R</td>
</tr>
<tr>
<td>3</td>
<td>FVF</td>
</tr>
<tr>
<td>4</td>
<td>SA</td>
</tr>
<tr>
<td>5</td>
<td>TC</td>
</tr>
<tr>
<td>6</td>
<td>DE</td>
</tr>
<tr>
<td>7</td>
<td>EA</td>
</tr>
<tr>
<td>8</td>
<td>SC</td>
</tr>
</tbody>
</table>

**Extended-Status Flags (ESF):** Any of bits 1-7, when one, specifies that an error-check condition has been detected by the channel subsystem. The following indications are provided in the ESF field:

**Key Check.** Bit 1, when one, indicates that the channel subsystem, when accessing data, when attempting to update the measurement block, or when attempting to fetch either a CCW, an IDAW, MIDAW, TCW, TCCB, TIDAW, or when accessing a TSB, has detected an invalid checking-block code (CBC) on the associated storage key. The channel-data-check bit, bit 12 of word 2 of the
SCSW, the measurement-block data-check bit, bit 3 of word 0 of the ESW, the CCW-check bit, bit 5 of word 0 of the ESW, or the IDAW/MIDAW-check bit, bit 6 of word 0 of the ESW, identifies the source of the key error.

**Note:** This condition may be indicated to the program when an invalid checking-block code on a key is detected but the data, CCW, IDAW, TIDAW, or MIDAW then is not used after being prefetched. In this case, the failing-storage-address-validity bit, bit 6 of the ERW, is one, indicating that the address of a location within the storage block having the key is stored in words 2 and 3 of the ESW.

**Measurement-Block Program Check.** Bit 2, when one, indicates that the channel subsystem, in attempting to update the measurement block, has either detected an invalid absolute address when combining the measurement-block origin with the measurement-block index for this subchannel or has detected an invalid measurement-block address at the subchannel.

**Measurement-Block Data Check.** Bit 3, when one, indicates that a malfunction has been detected involving the data of the measurement block in main storage. (See “Measurement Block” on page 3.) Measurement-block data check is indicated when the measurement block is updated and an invalid checking-block code (CBC) is detected on the storage used to contain the measurement data or on the associated key. When invalid CBC on the associated key is detected, the key-check bit, bit 1 of the ESF field, is also stored as one.

**Measurement-Block Protection Check.** Bit 4, when one, indicates that the channel subsystem, when attempting to update the measurement block, has been prohibited from accessing the measurement block because the storage key does not match the measurement-block key (see “Measurement Block” on page 3.) The key provided by SET CHANNEL MONITOR is used for the access of storage associated with measurement-block-update operations (see “SET CHANNEL MONITOR” on page 13.).

**Note:** Whenever any of the measurement-check conditions is indicated by bits 2-4, the channel subsystem sets the subchannel measurement-block-update-enable bit to zero, disabling the storing of measurement data for the subchannel (see “Measurement-Mode Enable (MM)” on page 3).

**CCW Check.** When a command-mode IRB is stored, bit 5, when one, indicates that an invalid CBC on the contents of the CCW or its associated key has been detected. When either of these conditions is detected, the I/O operation is terminated, the subchannel becomes status pending with primary and alert status, the extended-status-word-format bit in the SCSW is stored as one, and channel-control check is indicated in the subchannel-status field. The subchannel also becomes status pending with secondary status as a function of the type of termination or status received from the device. When invalid CBC on the associated key is detected, the key-check bit, bit 1 of the ESF field, is also stored as one.

When a transport-mode IRB is stored, bit 5 is reserved and set to zero.

**Note:** This condition may be indicated to the program when an invalid checking-block code on a prefetched CCW is detected but the CCW is not used. In this case, the failing-storage-address-validity bit, bit 6 of the ERW, is one, indicating that the address of a location having the invalid CBC is stored in words 2 and 3 of the ESW.

**IDAW/MIDAW Check.** When a command-mode IRB is stored, bit 6, when one, indicates that an invalid CBC on the contents of an IDAW or MIDAW or its associated key has been detected. When either of these conditions is detected, the I/O operation is terminated with the device, the subchannel becomes status pending with primary and alert status, the extended-status-word-format bit in the SCSW is one, and channel-control check is indicated in the subchannel-status field. The subchannel also becomes status pending with secondary status as a function of the type of termination or status received from the device. When invalid CBC on the associated key is detected, the key-check bit, bit 1 of the ESF field, is also one.

When a transport-mode IRB is stored, bit 6 is reserved and set to zero.

**Note:** This condition may be indicated to the program when an invalid checking-block code on the contents of a prefetched IDAW or MIDAW is detected but the IDAW or MIDAW is not used. In this case, the failing-storage-address-validity bit,
bit 6 of the ERW, is one, indicating that the address of a location having the invalid CBC is stored in words 2 and 3 of the ESW. Detection of a channel-data-check condition does not cause the CCW-check and IDAW/MIDAW-check bits to be stored as ones.

Reserved. Bit 7 is stored as zero.

Last-Path-Used Mask (LPUM): Bits 8-15 indicate the channel path that was last used for communicating or transferring information between the channel subsystem and the device. When a command-mode IRB is stored, the bit corresponding to the channel path in use is set whenever any of the following occurs:

1. The first command of a start-subchannel function is accepted by the device (see “Activity Control (AC)” on page 14).
2. The device and channel subsystem are actively communicating when the channel subsystem performs the suspend function for the channel program in execution.
3. The channel subsystem accepts status from the device that is recognized as an interruption condition, or a condition has been recognized that suppresses command chaining (see “Interruption Conditions” on page 2).
4. The channel subsystem recognizes an interface-control-check condition (see “Interface-Control Check” on page 29), and no subchannel-logoff information is currently present at the subchannel.

When a transport-mode IRB is stored, each bit of the LPUM is stored as zero, except for the bit that corresponds to the channel path last used, whenever one of the following occurs:

1. The path has been selected for transporting the TCCB for the operation.
2. The channel subsystem accepts status from the device that is recognized as an interruption condition. If the accepted status is an interrogate response, the LPUM may be different than that stored with primary or secondary status, or both.
3. The channel subsystem recognizes an interface-control-check condition (see “Interface-Control Check” on page 29), and no subchannel-logoff information is currently present at the subchannel.

The LPUM field contains the most recent setting and is valid whenever the ESW contains information in one of the formats 0-3 (see “Extended-Status Word” on page 47) and the SCSW is stored. When subchannel-logoff information is present in the ESW, a zero LPUM-field-validity flag indicates that the LPUM setting is not consistent with the other subchannel-logoff indications.

Ancillary Report (R): Bit 16, when one, indicates that a malfunction of a system component has occurred that has been recognized previously or that has affected the activities of multiple subchannels. When the malfunction affects the activities of multiple subchannels, an ancillary-report condition is recognized for all of the affected subchannels except one. This bit, when zero, indicates that this malfunction of a system component has not been recognized previously. This bit is meaningful only when a channel-control check, channel-data check, or an interface-control check is indicated in bit positions 12-14 of word 2 of the SCSW.

Depending on the model, recognition of an ancillary-report condition may not be provided or it may not be provided for all system malfunctions that affect subchannel activity. When ancillary-report recognition is not provided, bit 16 is set to zero.

Field-Validity Flags (FVF): Bits 17-21 indicate the validity of the information stored in the corresponding fields of either the SCSW or the extended-status word. When the validity bit is one, the corresponding field has been stored and is usable for recovery purposes. When the validity bit is zero, the corresponding field is not usable.

This bit-significant field has meaning when channel-data check, channel-control check, or interface-control check is indicated in the SCSW. When these checks are not indicated, this field, as well as the termination-code and sequence-code fields, has no meaning. Furthermore, when these checks are not indicated, the last-path-used-mask, device-status, and the TCW address or the CCW-address fields are all valid. The fields are defined as follows:

17 Last-path-used mask
18 Termination code
19 Sequence code
20 Device status
CCW address or TCW address

Storage-Access Code (SA): Bits 22-23 indicate the type of storage access that was being performed by the channel subsystem at the time of error. The SA field pertains only to the access of storage for the purpose of fetching or storing data during the performance of an I/O operation. This encoded field has meaning only when channel-data check, channel-control check, or interface-control check is indicated in the subchannel status. The access-code assignments are as follows:

00 Access type unknown
01 Read
10 Write
11 Read backward for a command-mode operation.

Termination Code (TC): Bits 24 and 25 indicate the type of termination that has occurred. This encoded field has meaning only when channel-data check, channel-control check, or interface-control check is indicated in the SCSW. The types of termination are as follows:

00 Halt signal issued
01 Stop, stack, or normal termination
10 Clear signal issued
11 Reserved

When at least one channel check is indicated in the SCSW but the termination-code-field-validity flag is zero, it is unpredictable which, if any, termination has been signaled to the device. If more than one channel-check condition is indicated in the SCSW, the device may have been signaled one or more termination codes that are the same or different. In this situation, if the termination-code-field-validity flag is one, the termination code indicates the most severe of the terminations signaled to the device. The termination codes, in order of increasing severity, are: stop, stack, or normal termination (01); halt signal issued (00); and clear signal issued (10)

Device-Status Check (D): When the status-verification facility is installed, bit 26, when one, indicates that the subchannel logout in the ESW resulted from the channel subsystem detecting device status that had valid CBC but that contained a combination of bits that was inappropriate when the status byte was presented to the channel subsystem. When the device-status-check bit is one, the interface-control-check status bit is set to one. If, additionally, bit 20 of the subchannel-logout field has been stored as one, then the status byte in error has been stored in the device-status field of the SCSW. If the status-verification facility is not installed, bit 26 is stored as zero.

Secondary Error (E): Bit 27, when one, indicates that a malfunction of a system component that may or may not have been directly related to any activity involving subchannels or I/O devices has occurred. Subsequent to this occurrence, the activity related to this subchannel and the associated I/O device was affected and caused the subchannel to be set status pending with either channel-control check or interface-control check.

I/O-Error Alert (A): Bit 28, when one, indicates that subchannel logout in the ESW resulted from the signaling of I/O-error alert. The I/O-error-alert signal indicates that the control unit or device has detected a malfunction that must be reported to the channel subsystem. The channel subsystem, in response, issues a clear signal and, except as described in the next paragraph, causes interface-control check to be set and extended-status-format-0 (logout) information to be stored in the ESW.

When I/O-error alert is signaled and the subchannel has previously been set disabled or no subchannel is associated with the device, the clear signal is issued to the device, and the I/O-error-alert indication is ignored by the channel subsystem.

Sequence Code (SC): When a command-mode IRB is stored, bits 29-31 identify the I/O sequence in progress at the time of error. The sequence code pertains only to I/O operations initiated by the execution of START SUBCHANNEL or RESUME SUBCHANNEL. This encoded field has meaning only when channel-data check, channel-control check, or interface-control check is indicated in the SCSW.

When a transport-mode IRB is stored, and the validity bit corresponding to the sequence-code field is one, bits 29-31 are stored as zeros.

The sequence-code assignments are:

000 Reserved
001 A nonzero command byte has been sent by the channel subsystem, but a response has not yet been analyzed by the channel subsystem. This code is set during the initiation sequence.
Figure 16-12 defines the relationship between indications provided as subchannel-logout data and the appropriate SCSW bits.

Extended-Report Word

The extended-report word (ERW) provides information to the program describing specific conditions that may exist at the device, subchannel, or channel subsystem. The ERW is stored whenever the extended-status word is stored. When the extended-status-word-format bit, bit 5 of word 0 of the SCSW, and the extended-control bit, bit 14 of word 0 of the SCSW, are both zeros, the ERW contains all zeros. When the extended-status-word-format bit or the extended-control bit or both are ones, the ERW has the following format:

Extended-Report Word

<table>
<thead>
<tr>
<th>Subchannel-Logout Condition Indicated</th>
<th>CDC</th>
<th>CCC</th>
<th>IFCC</th>
</tr>
</thead>
<tbody>
<tr>
<td>Key check</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>Measurement-block-program check</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Measurement-block-data check</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Measurement-block-protection check</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CCW check</td>
<td>Y</td>
<td></td>
<td></td>
</tr>
<tr>
<td>IDAW/MIDAW check</td>
<td>Y</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Last-path-used mask</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>Field-validity flags</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>Termination code</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>Device-status check</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Secondary error</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>I/O-error alert</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sequence code</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Explanation:

1. No relationship.

2. When more than one SCSW indication is signaled, the subchannel-logout conditions that are valid are the logical OR for each of the respective SCSW indications.

3. Only one measurement-block check may be indicated in a specific subchannel logout.

4. This field has a field-validity flag.

5. This field has a field-validity flag.

CCC Channel-control check.

CDC Channel-data check.

IFCC Interface-control check.

V Bit setting valid.

Reserved.

Reserved.

Reserved.
**Request Logging Only (L):** Bit 1, when one, requests that the program only record information about the condition that caused the extended-status word to be stored.

**Extended-Subchannel-Logout Pending (E):** Bit 2, when one, and when the extended-status-word-format bit, bit 5 of word 0 of the SCSW, is also one, indicates that an extended-subchannel logout is pending and that words 2-3 of the ESW contain the extended-subchannel-logout descriptor.

Bit 2 is set to zero when bit 6 is set to one.

When an ERW is stored with bits 2 and 6 both set to zero, zeros are stored in words 2 and 3 of the ESW.

**Authorization Check (A):** Bit 3, when one, indicates that the start or resume function was terminated because the channel subsystem has been placed in the isolated state in which pending I/O operations are not initiated and I/O operations currently being performed either are in the process of being terminated or have been terminated.

**Path Verification Required (P):** Bit 4, when one, indicates that the program must verify the identity of the device. The LPUM, when valid, indicates the channel path for which device verification is to be performed. When a valid LPUM is not available, the identity of the device must be verified for each available channel path.

**Channel-Path Timeout (T):** Bit 5, when one, indicates that, during a signaling sequence, an appropriate signal from the device did not occur within a predetermined time interval. Bit 5 is meaningful when the extended-status-word-format bit, bit 5 of word 0 of the SCSW, and the interface-control-check bit, bit 14 of word 0 of the SCSW, are both ones.

**Failing-Storage-Address Validity (F):** Bit 6, when one, and when the extended-status-word-format bit, bit 5 of word 0 of the SCSW, is also one, indicates that the channel subsystem has detected an invalid CBC on a CCW, a data location, an IDAW, a MIDAW, a TCW, TCCB, a TIDAW, a TSB or on the respective associated key and has stored, in words 2 and 3 of the ESW, the absolute address of a location associated with the invalid CBC.

Bit 6 is set to zero when bit 2 is set to one.

When an ERW is stored with bits 2 and 6 both set to zero, zeros are stored in words 2 and 3 of the ESW.

**Concurrent Sense (S):** When a command-mode IRB is stored, bit 7, when one, indicates that the concurrent-sense facility has placed sense information accepted from the device in the extended-control word and has stored a value, in bit positions 10-15 of the ERW, that specifies the number of sense bytes that have been stored in the extended-control word. When bit 7 is one, bit 14 of word 0 of the SCSW is also one.

When a transport-mode IRB is stored, bit 7 is reserved and set to zero.

**Concurrent-Sense Count (SCNT):** When bit 7 is one, bit positions 10-15 contain a value, in the range 1-32, that specifies the number of sense bytes stored into the extended-control word by the concurrent-sense facility. When bit 7 is zero, bit positions 10-15 contain zeros.

**Secondary-CCW-Address Validity (C):** When a command-mode IRB is stored, bit 8, when one, and when the extended-status-word-format bit, bit 5 of word 0 of the SCSW, is also one, indicates that the channel subsystem has detected an error condition that precludes the continued performance of an I/O operation. When prefetching applies (bit 9 of word 1 of the ORB is one) and certain error conditions identified by channel-control check, channel-data check, or interface-control check are recognized by the channel subsystem, situations may exist where the termination point of execution of the channel program differs between the channel subsystem and the I/O device. To properly identify the termination points, bit 8 is set to one, and a second CCW address (secondary-CCW address) is provided in the ESW and designates the last CCW executed at the device. When the validity bit is zero for the previously mentioned errors, the channel subsystem was unable to determine the termination point of the control-unit execution, and the secondary-CCW-address field contains zeros.

Bit 8 is not set to one unless the program has permitted prefetching by setting the prefetch-control bit, bit 9 of word 1 of the ORB, to one for the channel program in execution.

When a transport-mode IRB is stored, bit 8 is reserved and set to zero.
Failing-Storage-Address Format (R): Bit 9 indicates the format of the failing-storage address when the failing-storage-address validity bit, bit 6 of the ERW, is one. When bit 6 is zero, bit 9 is not meaningful and is stored as zero. When bit 6 is one and bit 9 is zero, a format-1 failing-storage address is stored in words 2 and 3 of the ESW. When bit 6 is one and bit 9 is one, a format-2 failing-storage address is stored in words 2 and 3. See “Failing-Storage Address” below for a description of format-1 and format-2 addresses.

Failing-Storage Address
Words 2 and 3 of the extended-status contain a 24-, 31-, or 64-bit absolute address. When the failing-storage-address-validity flag, bit 6 of the ERW, is one, words 2 and 3 contain either a format-1 failing-storage address or a format-2 failing-storage address. When bit 6 is one, the failing-storage-address field designates a byte location within the invalid checking block associated with an invalid CBC for a CCW, data location, IDAW, MIDAW, TCW, TCCB, TIDAW, TSB, or their respective associated key.

When a transport-mode IRB is stored, and the failing-storage-address validity flag, bit 6 of the ERW, is one, the failing-storage address contains the absolute address associated with the reported failing condition.

When an error condition is detected and a command-mode IRB is stored, the form of the address stored in words 2 and 3 depends on the format-2-IDAW control, bit 14 of word 1 of the ORB, and on the MIDA control, bit 25 of word 1 of the ORB, as follows:

1. When the format-2-IDAW control is zero, specifying that fullword IDAWs containing 31-bit addresses are used, and the modified-CCW-indirect-data-addressing-control is zero, a format-1 address is stored, and the failing-storage-address-format bit, bit 9 of the ERW, is stored as zero.

2. When either the format-2-IDAW control is one, specifying that doubleword IDAWs containing 64-bit addresses are used, or the modified-CCW-indirect-data-addressing-control is one, or both are one, a format-2 address is stored, and the failing-storage-address-format bit is stored as one.

When an error condition is detected and a transport-mode IRB is stored, a format-2 failing-storage address is stored. A format-2 failing-storage address is stored for a transport-mode IRB when a program-check, protection check, channel-data check or channel-control check condition is indicated by the subchannel status.

When a format-1 address is stored, bits 1-31 of word 2 form the address associated with the reported error condition, and bit 0 of word 2 and all of word 3 are stored as zeros. When a format-2 address is stored, bits 0-31 of word 2 followed by bits 0-31 of word 3 form the 64-bit address associated with the reported error condition.

Extended-Subchannel-Logout Descriptor (ESLD)
When the extended-status-word-format (L) bit, bit 5 of SCSW word 0, is one and the extended-subchannel-logout pending (E) flag, bit 2 of the ERW, is one, an extended-subchannel-logout descriptor is provided in words 2-3 of the ESW. The ESLD identifies the logout and the channel path for which the extended-subchannel logout is pending.

Secondary-CCW Address
When the subchannel-status field indicates channel-control check, channel-data check, or interface-control check and the secondary-CCW-address-validity flag, bit 8 of word 1, is one, bits 1-31 of word 4 form an absolute address of the last CCW executed by the I/O device at the point the reported check condition caused channel-program termination. When provided, the secondary-CCW address may be used for recovery purposes. When the secondary-CCW-address-validity flag is zero, this field contains zeros.

When a transport-mode IRB is stored and the subchannel-status field indicates channel-control check, channel-data check, or interface-control check, word 4 is reserved and contains zeros.

Extended-Status Format 1
The ESW stored by TEST SUBCHANNEL is a format-1 ESW when all of the following conditions are met:

1. The extended-status-word-format bit, bit 5 of word 0 of the SCSW, is zero.
2. The subchannel status-control field has the status-pending bit, bit 31 of word 0 of the SCSW, set to one, together with:
   a. The primary-status bit, bit 29 of word 0 of the SCSW, alone,
   b. The primary-status bit and other status-control bits, or
   c. The intermediate-status bit, bit 28 of word 0 of the SCSW, and the suspended bit, bit 26 of word 0 of the SCSW.

3. At least one of the following conditions is indicated:
   a. The device-connect-time-measurement mode is inactive.
   b. The channel-subsystem-timing facility is not available for the subchannel.
   c. The subchannel is not enabled for the device-connect-time-measurement mode.

Zeros are stored in bytes 0, 2, and 3 of word 0, and the LPUM is stored in byte 1 of word 0; an ERW is stored in word 1; zeros are stored in words 2-4.

The device-connect-time-measurement mode is made inactive when SET CHANNEL MONITOR is executed and bit 31 of general register 1 is zero.

A format-1 ESW has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>Zeros</th>
<th>LPUM</th>
<th>Zeros</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Last-Path-Used Mask (LPUM):** For a definition of the LPUM, see “Last-Path-Used Mask (LPUM)” on page 49.

**Extended-Report Word (ERW):** For a definition of the ERW, see “Extended-Report Word” on page 51.

### Extended-Status Format 2

The ESW stored by TEST SUBCHANNEL is a format-2 ESW when all of the following conditions are met:

1. The extended-status-word-format bit, bit 5 of word 0 of the SCSW, is zero.
2. The channel-subsystem-timing facility is available for the subchannel.
3. The subchannel is enabled for the device-connect-time-measurement mode.
4. The device-connect-time-measurement mode is active.
5. The subchannel status-control field has the status-pending bit, bit 31 of word 0 of the SCSW, set to one, together with:
   a. The primary-status bit, bit 29 of word 0 of the SCSW, alone,
   b. The primary-status bit and other status-control bits, or
   c. The intermediate-status bit, bit 28 of word 0 of the SCSW, and the suspended bit, bit 26 of word 0 of the SCSW.

Zeros are stored in byte 0 of word 0, the LPUM is stored in byte 1 of word 0, and the device-connect time is stored in bytes 2 and 3 of word 0; an ERW is stored in word 1; zeros are stored in words 2-4.

### A format-2 ESW has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>Zeros</th>
<th>LPUM</th>
<th>DCTI</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Last-Path-Used Mask (LPUM):** For a definition of the LPUM, see “Last-Path-Used Mask (LPUM)” on page 49.

**Device-Connect-Time Interval (DCTI):** Bit positions 16-31 contain the binary count of time increments accumulated by the channel subsystem during
the time that the channel subsystem and the device were actively communicating and the subchannel was subchannel active for a command-mode operation, or start pending for a transport-mode operation. The time increment of the DCTI is 128 microseconds.

If the above conditions for the storing of the DCTI value in the ESW are met but the device-connect-time-measurement mode was made active by SET CHANNEL MONITOR subsequent to the execution of START SUBCHANNEL for this subchannel, the DCTI value stored is greater than or equal to zero and less than or equal to the correct DCTI value.

**Note:** The DCTI value stored in the ESW is the same as that used to update the corresponding measurement-block data for the subchannel if the measurement-block-update mode is in use for the subchannel. If the measurement-block-update mode for the channel subsystem is active and the subchannel is enabled for the device-connect-time-measurement mode but no DCTI value is stored in the ESW (because of the presence of subchannel-logout information), or if the DCTI is zero, then nothing is added to the corresponding measurement-block data.

**Extended-Report Word (ERW):** For a definition of the ERW, see “Extended-Report Word” on page 51.

---

**Extended-Status Format 3**

The ESW stored by TEST SUBCHANNEL is a format-3 ESW when the extended-status-word-format bit, bit 5 of word 0 of the SCSW, is zero and the subchannel is status pending with (1) secondary status, alert status, or both when primary status is not also present, or (2) intermediate status when the subchannel is not suspended. Zeros are stored in byte 0 of word 0, and the LPUM is stored in byte 1 of word 0. Bytes 2 and 3 of word 0 contain unpredictable values; an ERW is stored in word 1; zeros are stored in words 2-4.

A format-3 ESW has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>Zeros</th>
<th>LPUM</th>
<th>X00000000000000X</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Last-Path-Used Mask (LPUM):** For a definition of the LPUM, see “Last-Path-Used Mask (LPUM)” on page 49.

An “X” in the format indicates the bit may be zero or one.

**Extended-Report Word (ERW):** For a definition of the ERW, see “Extended-Report Word” on page 51.

Figure 16-13 on page 55 summarizes the conditions at the subchannel under which each type of information is stored in the ESW.

---

**Subchannel Conditions When IRB is stored**

<table>
<thead>
<tr>
<th>Subchannel-Status Word</th>
<th>Path-Management-Control Word</th>
<th>Extended-Status Word (ESW), Word 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Status-Control Field</td>
<td>Device-Connect-Time-Mgmt Mode</td>
<td>Device-Connect-Time-Mgmt-Mode-Enable Bit</td>
</tr>
<tr>
<td>AIPSX</td>
<td>L Bit</td>
<td>Suspended Bit</td>
</tr>
<tr>
<td>00001</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>01001</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td><strong>1</strong></td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td><strong>0</strong></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1*001</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>****</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**Explanation:**

- Defined to be not meaningful when X is zero.
- Bits may be zeros or ones.
- Information not relevant in this situation.
- Alert status.
- Accumulated device-connect-time-interval (DCTI) value stored in bytes 2 and 3.
- Intermediate status.
- Extended-status-word format.
- Last-path-used mask (LPUM) stored in byte 1.
- Primary status.
- Subchannel-logout information stored in word 0.
- Secondary status.
- No format defined.
- Status pending.
- Zeros are stored as zeros.

**Figure 16-13. Information Stored in ESW**
Extended-Control Word

The extended-control word, which is words 8-15 of an interruption-response block (see “Interruption-Response Block” on page 6), provides additional information to the program describing conditions that may exist at the channel subsystem, subchannel, or device. The extended-control (E) bit, bit 14 of word 0 of the SCSW, when one, indicates that model-dependent information or concurrent-sense information has been stored in the extended-control word.

The information provided in the extended-control word is as follows:

<table>
<thead>
<tr>
<th>SCSW Bits</th>
<th>ERW</th>
<th>ECW Words 0-7</th>
</tr>
</thead>
<tbody>
<tr>
<td>5 14</td>
<td>10-15</td>
<td>0-7</td>
</tr>
<tr>
<td>0 0 0 Zeros Unpredictable</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 1 0   (1) Concurrent-sense information²</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 1 1   (1) Concurrent-sense information²</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 0 0 Zeros Unpredictable²</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 1 0 Zeros Model-dependent information²</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 1 1   (1) Concurrent-sense information²</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Explanation:
1. If stored, the value of these words is unpredictable.
2. Unused bits in the model-dependent information are stored as zeros.
3. Bit positions 10-15 contain a value equal to the number of sense bytes returned.
4. Unused bytes in the concurrent-sense information are stored as zeros.
5. The combination of SCSW bit 5 as 0, SCSW bit 14 as one, and ERW bit 7 as zero does not occur.

Extended-Measurement Word

The extended-measurement word (EMW) provides I/O measurement information to the program for the most recent start or resume operation performed at the subchannel. When the extended-I/O-measurement-word facility is installed and enabled, the EMW is conditionally stored in words 16-23 of the IRB designated by the second operand of TEST SUBCHANNEL when TEST SUBCHANNEL is executed. The EMW is stored by TEST SUBCHANNEL when all of the following conditions are met:

1. The extended-status-word-format (L) bit (bit 5, word 0 of the SCSW) is zero.
2. The channel-subsystem-timing facility is available for the subchannel, as indicated by the timing facility bit (T) at the subchannel.
3. The extended-I/O-measurement-word-mode enable bit (X) at the subchannel is one.
4. The subchannel status-control field has the status-pending bit (bit 31, word 0 of the SCSW) set to one, together with:
   a. The primary-status bit (bit 29, word 0 of the SCSW) alone, or
   b. The primary-status bit and other status-control bits, or
   c. The secondary-status bit (bit 29, word 0 of the SCSW) alone, or
   d. The intermediate-status bit (bit 28, word 0 of the SCSW) and the suspended bit (bit 26, word 0 of the SCSW).

Words 16-23 of the IRB contain unpredictable values when the extended-I/O-measurement-word facility is installed and enabled but the conditions listed above are not met.

When the extended-I/O-measurement-word facility is not installed, or the facility is installed but not enabled, words 16-23 of the IRB are not accessed by the channel subsystem.

The format of the extended-measurement word is shown below:

<table>
<thead>
<tr>
<th>Word</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
<tr>
<td>1</td>
</tr>
<tr>
<td>2</td>
</tr>
<tr>
<td>3</td>
</tr>
<tr>
<td>4</td>
</tr>
<tr>
<td>5</td>
</tr>
<tr>
<td>6</td>
</tr>
<tr>
<td>7</td>
</tr>
</tbody>
</table>

Each field in the EMW, when valid, contains a 32 bit binary count in which each increment of the count represents a value of 0.5 microseconds. A value of 00000000 hex represents a time period of zero seconds; the maximum value of FFFFFFFF hex represents approximately 35.79 minutes.
The accuracy of each of the measurement fields stored by the measurement facility is undefined and may vary depending on the resolution of timers implemented at the channel subsystem, the types of channels used to perform the operation, the capabilities of control units accessed during the operation, and the overall length of the I/O operation that was performed. The maximum value of FFFFFFFF hex is stored if a counter overflows; the program is not alerted when an overflow occurs.

Device-Connect Time: Bit positions 0-31 of word 0 contain the measured device-connect time for the operation. The device-connect time is the sum of the time intervals measured whenever the device is logically connected to a channel path while the subchannel is subchannel active for a command-mode operation, or start-pending for a transport-mode operation, and the device is actively communicating with the channel path, as defined in the section “Device-Connect Time” on page 4.

Function-Pending Time: Bit positions 0-31 of word 1 contain the SSCH- or RSCH-function-pending time for the operation. Function-pending time is the time interval between acceptance of the start function (or resume function if the subchannel is in the suspended state) at the subchannel and acceptance of the first command associated with the initiation or resumption of channel-program execution at the device, as defined in the section “Function-Pending Time” on page 4.

Device-Disconnect Time: Bit positions 0-31 of word 2 contain the device-disconnect time for the operation. Device-disconnect time is the sum of the time intervals measured whenever the device is logically disconnected from the channel subsystem while the subchannel is subchannel-active for a command-mode operation, or start-pending for a transport-mode operation, as defined in the section “Device-Disconnect Time” on page 5.

Control-Unit-Queuing Time: Bit positions 0-31 of word 3 contain the control-unit-queuing time for the operation. Control-unit-queuing time is the sum of the time intervals measured by the control unit whenever the device is logically disconnected from the channel subsystem during an I/O operation while the device is busy with an operation initiated from a different system, as defined in the section “Control-Unit-Queuing Time” on page 5.

Device-active-only time: Bit positions 0-31 of word 4 contain the device-active-only time for the operation. For a command-mode operation, device-active-only time is the sum of the time intervals when the subchannel is device-active but not subchannel-active at the end of an I/O operation or chain of I/O operations initiated by a start function or resume function, as defined in section “Device-Active-Only Time” on page 6. When a transport-mode IRB is stored, device-active-only time is the sum of the times that the I/O device was active executing device command and the time interval between when channel-end and device-end status were presented.

Device-busy time: Bit positions 0-31 of word 5 contain the device-busy time for the operation. When a command-mode IRB is stored, the device-busy time is the sum of the time intervals when the device is found to be device busy during an attempt to initiate a start function or resume function at the subchannel, as defined in the section “Device-Busy Time” on page 6. When a transport-mode IRB is stored, device-busy time is the sum of the times that the I/O device was busy attempting to initiate a command and the device busy time accumulated by the channel subsystem.

Initial Command Response Time: Bit positions 0-31 of word 6 contain the initial-command-response time for the operation. When a command-mode IRB is stored, initial-command-response time for an operation is the time interval beginning from when the first command of the channel program is sent to the device until the device indicates it has accepted the command. When a transport-mode IRB is stored, the initial-command-response time, is the time interval difference between when a TCCB is sent to the I/O device until the response is received from the I/O device, minus the time from when the control unit receives the TCCB until the channel subsystem receives the response from the control unit.
Chapter 17. I/O Support Functions

The I/O support functions are those functions of the channel subsystem that are not directly related to the initiation or control of I/O operations. The following I/O support functions are described in this chapter:

- Channel-subsystem monitoring
- Signals and resets
- Externally initiated functions
- Status verification
- Address-limit checking
- Configuration alert
- Incorrect-length-indication suppression
- Concurrent sense
- Channel-subsystem recovery
- I/O-priority facility
- Restore-subchannel facility
- Multiple-subchannel-set facility

Channel-Subsystem Monitoring

Monitoring facilities are provided in the channel subsystem so that the program can retrieve measured values on performance for a designated subchannel. The use of these facilities is under program control by means of the execution of the SET CHANNEL MONITOR instruction and the MODIFY SUBCHANNEL instruction.

The principal components of the channel-subsystem-monitoring facilities are the channel-subsystem-timing facility, measurement-block-update facility, and device-connect-time-measurement facility. The measurement-block-update facility and device-connect-time-measurement facility both use the channel-subsystem-timing facility but otherwise are logically distinct and operate independent of one another.
Other components of the channel-subsystem-monitoring facilities are the control-unit-queueing-measurement facility, the control-unit-defer-time facility, the device-active-only-measurement facility, the initial-command-response-measurement facility, the extended-I/O-measurement-block facility, and the extended-I/O-measurement-word facility. These enhance the measurements of the measurement-block-update facility if they are available as described in later sections, where each of the facilities that constitute the channel-subsystem-monitoring facilities is described in this chapter.

**Channel-Subsystem Timing**

The channel-subsystem-timing facility provides the channel subsystem with the capability of measuring the elapsed time required for performing several different phases of the processing of a start function initiated by START SUBCHANNEL. These elapsed-time measurements are used by both the measurement-block-update facility and the device-connect-time-measurement facility to provide subchannel performance information to the program.

While every channel subsystem has a channel-subsystem-timing facility, it may or may not be provided for use with all subchannels. Subchannels for which the facility is provided have the timing-facility bit, bit 14 of word 1, stored as one in the associated subchannel-information block. (See “Timing Facility (T)” on page 4.) If the channel-subsystem-timing facility is not provided for the subchannel, the subchannel's timing-facility bit is stored as zero.

Subchannels that do not have the channel-subsystem-timing facility provided are those for which the characteristics of the associated device, the manner in which it is attached to the channel subsystem, or the channel-subsystem resources required to support the device are such that use of the channel-subsystem-timing facility is precluded.

The channel-subsystem-timing facility consists of at least one channel-subsystem timer and the associated logic and storage required for computing and recording the elapsed-time intervals for use by the two measurement facilities. The aspects of the channel-subsystem-timing facility that are of importance to the program are described below.

**Channel-Subsystem Timer**

Each channel-subsystem timer is a binary counter that is not accessible to the program. The channel-subsystem timer provides a minimum timer resolution of 128 microseconds. A timer resolution of 1.0 microseconds is provided when FICON-I/O-interface channel paths are supported. When incrementing the channel-subsystem timer causes a carry out of the leftmost bit position, the carry is ignored, and counting continues from zero. No indications are generated as a result of the overflow.

Just as every CPU has access to a TOD clock, every channel subsystem has access to at least one channel-subsystem timer. When multiple channel-subsystem timers are provided, synchronization among these timers is also provided, creating the effect that all the timing facilities of the channel subsystem share a single timer. Synchronization among these timers may be supplied either through some TOD clock or independently by the channel subsystem.

If the TOD clocks are not synchronized, the elapsed times measured by the channel-subsystem-timing facility may have unpredictable values for some or all of the subchannels, depending on the model and on the particular channel-subsystem timer and the way the associated devices are physically attached to the system. The values are unpredictable for those devices attached to the system by separately configurable channel paths whose associated CPU TOD clocks are not synchronized.

**Synchronization:** If either the measurement-block-update mode or the device-connect-time-measurement mode is active and any of the channel-subsystem timers is found to be out of synchronization, a channel-subsystem-timer-sync check is recognized, and a channel report is generated to alert the program (see “Channel-Subsystem Recovery” on page 24). If neither of these modes is active, the lack of synchronization is not recognized.

**Measurement-Block Update**

The measurement-block-update facility provides the program with the capability of accumulating performance information for subchannels that are enabled for the measurement-block-update mode when the measurement-block-update mode is active. A subchannel is enabled for the measurement-block-update mode by setting bit 11 of word 1 of the SCHIB operand to one and then issuing MODIFY SUB-
CHANNEL. The measurement-block-update mode is made active by the execution of SET CHANNEL MONITOR when bit 62 of general register 1 is one.

When the measurement-block-update mode is active and the subchannel is enabled for the measurement-block-update mode, information is accumulated in a measurement block associated with the subchannel. A measurement block is either a 32-byte area (format-0 measurement block) or a 64-byte area (format-1 measurement block) in main storage that is associated with a subchannel for the purpose of accumulating measurement data.

For format-0 measurement blocks, the program specifies a contiguous area of absolute storage, referred to as the measurement-block area, and subdivides this area into 32-byte blocks, one block for each subchannel for which measurement data is to be accumulated. The measurement-block-update facility uses the measurement-block index contained at the subchannel in conjunction with the measurement-block origin established by the execution of SET CHANNEL MONITOR to compute the absolute address of the measurement block associated with a subchannel.

For format-1 measurement blocks, the program provides a 64-byte contiguous area of absolute storage for the subchannel. The measurement-block-update facility uses the measurement-block address provided in the SCHIB during the execution of the MODIFY SUBCHANNEL instruction.

Measurement data is stored in the measurement block associated with the subchannel each time an I/O operation or chain of I/O operations initiated by a START SUBCHANNEL instruction or RESUME SUBCHANNEL instruction is suspended or completed at the device. The completion of an I/O operation or chain of I/O operations at the device is normally determined when secondary status is accepted from the device.

The measurement data accumulated in the format-0 and format-1 measurement blocks by the measurement-block-update facility is described in the following section, “Measurement Block”.

**Measurement Block**

A measurement block is either a 32-byte area (format-0 measurement block) at a location designated by the program by its use of a measurement-block-origin address in conjunction with the measurement-block index, or a 64-byte area (format-1 measurement block) at a location designated by the measurement-block address provided in the SCHIB during the execution of the MODIFY SUBCHANNEL instruction.

The measurement block contains the accumulated values of the measurement data described below. When the measurement-block-update mode is active and the subchannel is enabled for measurement-block update, the measurement-block-update facility accumulates the values for the measurement data that accrue during the performance of an I/O operation or chain of I/O operations initiated by START SUBCHANNEL.

When the I/O operation or chain of I/O operations is suspended or completed and no error condition is encountered, the accrued values are added to the accumulated values in the measurement block for that subchannel. If an error condition is detected and subchannel-logout information is stored in the extended-status word (ESW), the accrued values are not added to the accumulated values in the measurement block for the subchannel, and the two count fields in the measurement block are not incremented.

If (1) any of the accrued time values is detected to exceed the internal storage provided for containing these values, (2) the control unit cannot provide an accurate queuing time or defer time for the current operation, or (3) the channel subsystem successfully recovers from certain error conditions, none of the accrued values is added to the measurement block for the subchannel, and the sample count in the measurement block is not incremented, but the SSCH+RSCH count in the block is incremented.

References to the measurement block by the measurement-block-update facility, in order to accumulate measurement data at the suspension or completion of an I/O function, are single-access references and appear to be word concurrent as observed by CPUs.

The measurement-block-update facility updates all fields in the measurement block that are required to be updated for a suspended I/O operation prior to putting the subchannel into the suspended state. The measurement-block-update facility updates all fields in the measurement block that are required to be updated for a completed I/O operation prior to making the subchannel status pending with secondary status or, if the subchannel is start pending for a sub-
sequent operation, prior to initiating the start function.

A format-0 measurement block is stored when the measurement-block-format-control bit at the subchannel is zero; a format-1 measurement block is stored when the measurement-block-format-control bit at the subchannel is one.

The format-0 measurement block has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>SSCH+RSCH Count</th>
<th>Sample Count</th>
<th>Device-Connect Time</th>
<th>Function-Pending Time</th>
<th>Device-Disconnect Time</th>
<th>Control-Unit-Queuing Time</th>
<th>Device-Active-Only Time</th>
<th>Device-Busy Time</th>
<th>Initial Command Response Time</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The format-1 measurement block has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>SSCH+RSCH Count</th>
<th>Sample Count</th>
<th>Device-Connect Time</th>
<th>Function-Pending Time</th>
<th>Device-Disconnect Time</th>
<th>Control-Unit-Queuing Time</th>
<th>Device-Active-Only Time</th>
<th>Device-Busy Time</th>
<th>Initial Command Response Time</th>
<th>Interrupt Delay Time</th>
<th>I/O Priority Delay Time</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0-31</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**SSCH+RSCH Count:** Bits 0-15 of word 0 in the format-0 measurement block and bits 0-31 of word 0 in the format-1 measurement block are used as a binary counter. During the performance of a start function for which measurement-block update is active, when (1) the secondary status condition is recognized or (2) the suspend function is performed, the counter is incremented by one, and the measurement data is stored. The counter wraps around from the maximum value to 0. The program is not alerted when counter overflow occurs.

If the measurement-block-update mode is active and the subchannel is enabled for measuring, the SSCH+RSCH count is incremented even when the lack of measured values for an individual start function precludes the updating of the remaining fields of the measurement block or when the timing-facility bit for the subchannel is zero. The SSCH+RSCH count is not incremented if the measurement-block-update mode is inactive, if the subchannel is not enabled for the measurement-block update, or if subchannel-log-out information has been generated for the start function.

**Sample Count:** Bits 16-31 of word 0 in the format-0 measurement block and bits 0-31 of word 1 in the format-1 measurement block are used as a binary counter. During the performance of a start function, when the measurement-block-update facility obtains the accrued values of the measurement data for an individual start function, even when the measurement-block-update mode is active and the subchannel is enabled for that mode, the control unit may also signal that it was not able to accumulate an accurate queuing time. In these situations, the sample-count field is not incremented.

The counter wraps around from the maximum value to 0. The program is not alerted when counter overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel.

The System Library publication for the system model specifies the conditions, if any, that preclude the updating of the sample count and time-accumulation fields of the measurement block.

**Device-Connect Time:** Bit positions 0-31 of word 1 in the format-0 measurement block and bit positions 0-31 of word 2 in the format-1 measurement block contain the accumulation of measured device-connect-time intervals. The device-connect-time interval...
(DCTI) is the sum of the time intervals measured whenever the device is logically connected to a channel path while the subchannel is subchannel active and the device is actively communicating with the channel path. The device-connect time does not include the intervals when a device is logically connected to a channel path but is not actively communicating with the channel. The device reports the accumulation of time intervals when the device is logically connected but not actively communicating with the channel path as control-unit-defer time. The control-unit-defer time is not included in the device-connect-time measurement but, instead, is added to the accrued device-disconnect-time measurement for the operation.

The time intervals are stored using a resolution of 128 microseconds. The accumulated value is modulo approximately 152.71 hours, and the program is not alerted when an overflow occurs. This field is not updated if (1) the channel-subsystem-timing facility is not provided for the subchannel, (2) the measurement-block-update mode is inactive, or (3) any of the time values accrued for the current start function has been detected to exceed the internal storage in which it was accrued.

Accumulation of device-connect-time intervals for a subchannel and storing this data in the ESW are not affected by whether the measurement-block-update mode is active. (See “Device-Connect-Time Measurement” on page 10.)

Function-Pending Time: Bit positions 0-31 of word 2 in the format-0 measurement block and bit positions 0-31 of word 3 in the format-1 measurement block contain the accumulated SSCH- and RSCH-function-pending time. Function-pending time is the time interval between acceptance of the start function (or resume function if the subchannel is in the suspended state) at the subchannel and acceptance of the first command associated with the initiation or resumption of channel-program execution at the device.

When channel-program execution is suspended because of a suspend flag in the first CCW of a channel program, the suspension occurs prior to transferring the first command to the device. In this case, the function-pending time accumulated up to that point is added to the value in the function-pending-time field of the measurement block. Function-pending time is not accrued while the subchannel is suspended. Function-pending time begins to be accrued again, in this case, when RESUME SUBCHANNEL is subsequently executed while the designated subchannel is in the suspended state.

The function-pending-time interval is stored using a resolution of 128 microseconds. The accumulated value is modulo approximately 152.71 hours, and the program is not alerted when an overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel.

Device-Disconnect Time: Bit positions 0-31 of word 3 in the format-0 measurement block and bit positions 0-31 of word 4 in the format-1 measurement block contain the accumulated device-disconnect time. Device-disconnect time is the sum of the time intervals measured whenever the device is logically disconnected from the channel subsystem while the subchannel is subchannel active. The device-disconnect time also includes the sum of control-unit-defer-time intervals reported by the device during the I/O operation.

Device-disconnect time is not accrued while the subchannel is in the suspended state. Device-disconnect time begins to be accrued again, in this case, on the first device disconnection after channel-program execution has been resumed at the device (the subchannel is again subchannel active).

The device-disconnect-time interval is stored using a resolution of 128 microseconds. The accumulated value is modulo approximately 152.71 hours; the program is not alerted when an overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel.

The device-disconnect time does not include the interval between the primary status condition and the secondary status condition at the end of an I/O operation when the subchannel is no longer subchannel active but the I/O device is active. If the channel subsystem provides the device-active-only measurement facility, this time is accumulated in the device-active-only-time field of the measurement block.

Control-Unit-Queuing Time: Bit positions 0-31 of word 4 in the format-0 measurement block and bit positions 0-31 of word 5 in the format-1 measurement block contain the accumulated control-unit-queuing time. Control-unit-queuing time is the sum of the time intervals measured by the control unit whenever the device is logically disconnected from the channel subsystem during an I/O operation while the
device is busy with an operation initiated from a different system.

Control-unit-queuing time is not accrued while the subchannel is in the suspended state. Control-unit-queuing time may be accrued for the channel program after the subchannel becomes subchannel active following a successful resumption.

The control-unit-queuing-time field is updated such that bit 31 represents 128 microseconds. The accumulated value is modulo approximately 152.71 hours; the program is not alerted when an overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel or if the control unit does not provide a queuing time.

**Device-Active-Only Time:** Bit positions 0-31 of word 5 in the format-0 measurement block and bit positions 0-31 of word 6 in the format-1 measurement block contain the accumulated device-active-only time. Device-active-only time is the sum of the time intervals when the subchannel is device active but not subchannel active at the end of an I/O operation or chain of I/O operations initiated by a start function or resume function.

Device-active-only time is not accumulated when the subchannel is device active during periods when the subchannel is active; such time is accumulated as device-connect time or device-disconnect time, as appropriate.

The device-active-only-time field is updated such that bit 31 represents 128 microseconds. The accumulated value is modulo approximately 152.71 hours; the program is not alerted when an overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel.

**Device-Busy Time:** When the extended-I/O-measurement-block facility is installed, bit positions 0-31 of word 6 in the format-0 measurement block, and bit positions 0-31 of word 7 in the format-1 measurement block contain the accumulated device-busy time. Device-busy time is the sum of the time intervals when the subchannel is device busy during an attempt to initiate a start function or resume function at the subchannel.

The device-busy-time field is updated such that bit 31 represents 128 microseconds. The accumulated value is modulo approximately 152.71 hours; the program is not alerted when an overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel.

**Initial-Command-Response Time:** Bit positions 0-31 of word 7 in the format-0 measurement block, and bit positions 0-31 of word 8 in the format-1 measurement block contain the accumulated initial-command-response time for the subchannel.

The initial-command-response time for a start or resume function is the time interval beginning from when the first command of the channel program is sent to the device until the device indicates it has accepted the command.

The initial-command-response time is stored at a resolution of 128 microseconds. The accumulated value is modulo approximately 152.71 hours; the program is not alerted when an overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel or if the initial-command-response-measurement facility is not installed.

**Control-Unit-Defer Time:** Control-unit-defer time is the sum of the time intervals measured by the control unit whenever the device is logically connected to the channel subsystem during an I/O operation but is not actively communicating with the channel because of device-dependent delays in channel-program execution. The control-unit-defer time is not stored in the measurement block as a separate measurement field but is used in the calculation of device-connect-time measurement and device-disconnect-time measurement for an operation.

Control-unit-defer time, if provided by a control unit, is accrued while the device is logically connected to the channel. The time is reported to the channel when channel-end status is presented that causes a device disconnection or terminates the I/O operation. Control-unit-defer time is subtracted from the device-connect-time measurement and is added to the device-disconnect-time measurement reported for the operation.

**Interrupt-Delay Time:** When the interrupt-delay-measurement facility is installed, bit positions 0-31 of word 9 in the format-1 measurement block contain the accumulated interrupt-delay time for the subchannel. Interrupt-delay time is the time interval from when a subchannel is made status pending with pri-
mary status to when the status is cleared by TSCH. When the interrupt-delay-measurement facility is not installed, bit positions 0-31 of word 9 in the format-1 measurement block are not updated and contain zeros.

The interrupt-delay time is accumulated in the measurement block when a measurement-block update is performed on a subsequent SSCH since the interrupt-delay time is not known when the measurement block is updated for the current SSCH. Consequently, the interrupt-delay time contains the accumulated interrupt-delay time for SSCH operations completed prior to the last completed SSCH operation.

The interrupt-delay time is stored using a resolution of 128 microseconds. The accumulated value is modulo approximately 152.71 hours and the program is not alerted when an overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel.

**I/O-Priority-Delay Time:** Bit positions 0-31 of word 10 in the format-1 measurement block contain the accumulated I/O-priority-delay time for the subchannel. The I/O-priority-delay time is that portion of the queue time that can be attributed to delay due to I/O-priority management performed by the control unit. The measurement applies only to TCW I/O operations and is reported in the additional data area of the TSB according to device-dependent definition. If the control unit does not support I/O-priority management or if there is no I/O-priority delay, bit positions 0-31 of word 10 in the format-1 measurement block are not updated.

The I/O-priority-delay time is stored using a resolution of 128 microseconds. The accumulated value is modulo approximately 152.71 hours, and the program is not alerted when an overflow occurs. This field is not updated if the channel-subsystem-timing facility is not provided for the subchannel.

**Programming Note:** This time is a direct measurement of the effect of the software setting I/O priorities for the I/O executed at the control unit for all I/O devices. Times will vary depending if priorities are kept low for some work. Software uses the time to validate the correctness of the algorithms used for I/O priority management.

**Reserved:** The remaining words of the measurement block, along with any words associated with facilities that are not provided by the channel subsystem or the subchannel, are reserved for future use. They are not updated by the measurement-block-update facility.

**Programming Note:** It is possible for the program to fetch a portion of a measurement block immediately prior to, or during, a measurement block update by the measurement-block-update facility. To ensure that a consistent measurement block is fetched, the program should not fetch measurement data for a subchannel during the time from when a start or resume function is initiated at the subchannel until the operation is suspended or completes with secondary status.

**Measurement-Block Format**

The measurement block is stored as either a format-0 measurement block or a format-1 measurement block. The format-0 measurement block is a 32-byte area (format-0 measurement block) at a location designated by the program using the measurement-block origin in conjunction with the measurement-block index. The format-1 measurement block is a 64-byte area (format-1 measurement block) at a location designated by the measurement-block address provided in the SCHIB during the execution of the MODIFY SUBCHANNEL instruction. The measurement-block-format-control bit at the subchannel indicates whether a format-0 or format-1 measurement block is stored when measurement-block-update mode is active and enabled at the subchannel.

**Measurement-Block Origin**

The measurement-block origin is the beginning of the measurement-block area in main storage, used to store format-0 measurement blocks. The absolute address of the measurement-block origin, specified on a 32-byte boundary, is passed in general register 2 to the measurement-block-update facility when SET CHANNEL MONITOR is executed with bit 62 of general register 1 set to one.

**Measurement-Block Address**

The measurement-block address is set at the subchannel through the execution of MODIFY SUBCHANNEL. The measurement block address specifies the absolute address of the beginning of the 64-byte area to be used for accumulating format-1 measurement-block parameters for that subchannel.

**Programming Note:** The initial value of the measurement-block address is zero. The program is
responsible for setting the measurement-block address to the proper value prior to enabling the subchannel for the measurement-block-update mode for format-1 measurement blocks and making the mode active.

**Measurement-Block Key**

Bits 32-35 of general register 1 form the four-bit access key to be used for subsequent measurement-block updates when SET CHANNEL MONITOR causes the measurement-block-update mode to be made active. The measurement-block key is passed to the measurement-block-update facility whenever the measurement-block-update mode is made active. The key is used for format-0 and format-1 measurement block updates.

**Measurement-Block Index**

The measurement-block index is set in the subchannel through the execution of MODIFY SUBCHANNEL. The measurement-block index specifies which 32-byte measurement block, relative to the measurement-block origin, is to be used for accumulating the format-0 measurement-block parameters for that subchannel. The location of the format-0 measurement block of a subchannel is computed by the measurement-block-update facility by appending five rightmost zeros to the measurement-block index of the subchannel and adding the result to the measurement-block origin. The result is the absolute address of the 32-byte format-0 measurement block for that subchannel. When the computed measurement-block address exceeds $2^{31}$, a measurement-block program-check condition is recognized, and measurement-block updating does not occur for the preceding subchannel-active period.

**Programming Note:** The initial value of the measurement-block index is zero. The program is responsible for setting the measurement-block index to the proper value prior to enabling the subchannel for the measurement-block-update mode and making the mode active. To ensure predictable results for the measured parameters in the measurement block, each subchannel for which measured parameters are to be accumulated must have a different value for its measurement-block index.

**Measurement-Block-Update Mode**

The measurement-block-update mode is made active by the execution of SET CHANNEL MONITOR with bit 62 of general register 1 set to one. If bit 62 of general register 1 is zero when SET CHANNEL MONITOR is executed, the mode is made inactive. When the measurement-block-update mode is made active, the contents of general register 2 are passed to the measurement-block-update facility as the absolute address of the measurement-block origin and is used to calculate the address of format-0 measurement blocks. The measurement-block origin is not used for format-1 measurement blocks. The MBK is also passed to the measurement-block-update facility as the access key to be used when updating either format-0 or format-1 measurement blocks for each subchannel. When the measurement-block-update mode is active, the measurement-block-update facility accumulates measurements in individual measurement blocks for subchannels whose measurement-block-update-enable bit is one. (See the section “Measurement Block” on page 3 for a description of the measured parameters.)

If the measurement-block-update mode is already active when SET CHANNEL MONITOR is executed, the values for the measurement-block origin and measurement-block key that are used for a subchannel enabled for measuring by the measurement-block-update facility are dependent upon whether SET CHANNEL MONITOR is executed prior to, during, or subsequent to the execution of START SUBCHANNEL for that subchannel. If SET CHANNEL MONITOR is executed prior to START SUBCHANNEL, the current measurement-block origin and measurement-block key are in control. If SET CHANNEL MONITOR is executed during or subsequent to execution of START SUBCHANNEL, it is unpredictable whether the measurement-block origin and measurement-block key that are in control are old or current.

**Measurement-Block-Format Control**

Bit 29, word 6, of the SCHIB is the measurement-block-format-control bit. This bit provides the capability of specifying whether a format-0 or format-1 measurement block is stored on a subchannel basis. The initial value of the bit is zero. When MODIFY SUBCHANNEL is executed with the measurement-block-format-control bit in the SCHIB operand set to one, the format-1 measurement block is specified for the subchannel. If the measurement-block-update mode is active and enabled at the subchannel, the measurement-block-update facility stores a format-1 measurement-block for the subchannel, starting with the next START SUBCHANNEL issued to that sub-
channel. Similarly, if MODIFY SUBCHANNEL is ex-
ecuted with measurement-block-format-control bit of
the SCHIB operand set to zero by the program, the
measurement-block-update facility stores a format-0
measurement-block for the subchannel, starting with
the next START SUBCHANNEL issued to that sub-
channel.

Measurement-Block-Update Enable
Bit 11 of word 1 of the SCHIB is the measure-
ment-block-update-enable bit. This bit provides the capa-
bility of controlling the accumulation of measure-
ment-block parameters on a subchannel basis. The
initial value of the enable bit is zero. When MODIFY
SUBCHANNEL is executed with the enable bit set to
one in the SCHIB, the subchannel is enabled for the
measurement-block-update mode. If the measure-
ment-block-update mode is active, the measurement-
block-update facility accumulates measurement-
block parameters for the subchannel, starting with
the next START SUBCHANNEL issued to that sub-
channel. Conversely, if MODIFY SUBCHANNEL is
executed with bit 11 of word 1 of the SCHIB operand
set to zero by the program, the subchannel is dis-
abled for the measurement-block-update mode, and
no additional measurement-block parameters are
accumulated for that subchannel.

Control-Unit-Queuing Measurement
The control-unit-queuing-measurement facility allows
the channel subsystem to accept queuing times from
control units and, in conjunction with the measure-
ment-block-update facility, to accumulate those times
in the measurement block.

The System Library publication for the control-unit
model specifies its ability to supply queuing time. If a
control-unit model is capable of supplying queuing time,
the publication specifies the conditions that pre-
vent the control unit from accumulating an accurate
control-unit-queuing time.

Control-Unit-Defer Time
The control-unit-defer-time facility allows the channel
subsystem to accept defer times from control units
and, in conjunction with the measurement-block-
update facility, to modify the device-connect and
device-disconnect times reported in the measure-
ment block to reflect the defer time. The control-unit-
defer time is subtracted from the device-connect-time
measurement and is added to the device-disconnect-
time measurement reported for an I/O operation.

The System Library publication for the control-unit
model specifies its ability to supply defer time. If a
control-unit model is capable of supplying defer time,
the publication specifies the conditions that prevent
the control unit from accumulating an accurate con-

Device-Active-Only Measurement
The device-active-only-measurement facility permits
the channel subsystem to report the times that the
device is disconnected between primary status and
secondary status at the end of an I/O operation or
chain of I/O operations.

The measurement-block updates are performed at
the time that secondary status is accepted from the
I/O device, in order that the device-active time
between primary status and secondary status can be
reported.

If the subchannel is start pending when secondary
status is accepted from the I/O device and the mea-
surement-block update is to be performed, the mea-
surement-block update is performed prior to
performing the start function. If measurement-block
errors occur, they are reported to the program along
with the secondary status instead of performing the
start function.

Initial-Command-Response
Measurement
The initial-command-response-measurement facility
allows the channel subsystem to calculate initial-
command-response time for I/O operations and, in
conjunction with the measurement-block-update
facility, to accumulate those times in the measure-
ment block. The initial-command-response time is
accumulated in word 7 of the measurement block.

Time-Interval-Measurement Accuracy
On some models, when time intervals are to be mea-
sured and condition code 0 is set for START SUB-
CHANNEL (or RESUME SUBCHANNEL in the case
of a suspended subchannel), a period of latency may
occur prior to the initiation of the function-pending
time measurement. The System Library publication
for the system model specifies the mean latency
value and variance for each of the measured time
intervals.
Programming Notes:

1. Excessive delays may be encountered by the channel subsystem when attempting to update measurement data if the program is concurrently accessing the same measurement-block area. A programming convention should ensure that the storage block designated by SET CHANNEL MONITOR is made read-only while the measurement-block-update mode is active.

2. To ensure that programs written to support measurement functions are executed properly, the program should initialize all the measurement blocks to zeros prior to making the measurement-block-update mode active. Only zeros should appear in the reserved and unused words of the measurement blocks.

3. When the incrementing of an accumulated value causes a carry to be propagated out of bit position 0, the carry is ignored, and accumulating continues from zero on.

Device-Connect-Time Measurement

The device-connect-time-measurement facility provides the program with the capability of retrieving the length of time that a device is actively communicating with the channel subsystem while executing a channel program. The measured length of time that the device spends actively communicating on a channel path during the execution of a channel program is called the device-connect-time interval (DCTI). Control-unit-defer time is not included in the DCTI.

If timing facilities are provided for the subchannel, the DCTI value is passed to the program in the extended-status word (ESW) at the completion of the operation when the primary-status condition is cleared by TEST SUBCHANNEL and when TEST SUBCHANNEL clears an intermediate-status condition alone while the subchannel is suspended. The DCTI value passed in the ESW pertains to the previous subchannel-active period. The passing of the DCTI in the ESW is under program control by the SET CHANNEL MONITOR device-connect-time-measurement mode-control bit and the corresponding enable bit in the subchannel. However, the DCTI value is not stored in the ESW if the I/O function initiated by START SUBCHANNEL is terminated because of an error condition that is described by subchannel logout. See the section “Extended-Status Format 0” on page 47. In this case, the extended-status bit (L) of the SCSW is stored as one, indicating that the ESW contains logout information describing the error condition. See the section “Extended-Status Word” on page 47 for the description of the logout information. If the accrued DCTI value exceeded 8.388608 seconds during the previous subchannel-active period, then the maximum value (FFFF hex) is passed in the ESW.

Device-Connect-Time-Measurement Mode

The device-connect-time-measurement mode is made active by the execution of SET CHANNEL MONITOR when bit 63 of general register 1 is one. If bit 63 of general register 1 is zero when SET CHANNEL MONITOR is executed, the mode is made inactive, and DCTIs are not passed to the program. When timing facilities are provided for the subchannel, the device-connect-time-measurement mode is active, and the subchannel is enabled for the mode, the DCTI value is passed to the program in the ESW stored when TEST SUBCHANNEL (1) clears the primary-interruption condition with no logout information indicated in the SCSW (extended-status-word-format bit is zero) or (2) clears the intermediate-status condition alone while the subchannel is suspended.

If a start function is currently being executed with a subchannel enabled for the device-connect-time-measurement mode when SET CHANNEL MONITOR makes this mode active for the channel subsystem, the value of the DCTI stored under the appropriate conditions may be zero, a partial result, or the full and correct value, depending on the model and the progress of the start function at the time the mode was activated.

Provision of the DCTI value in the measurement-block area is not affected by whether the device-connect-time-measurement mode is active.

Device-Connect-Time-Measurement Enable

Bit 12 of word 1 of the SCHIB is the device-connect-time-measurement-mode-enable bit. This bit provides the program with the capability of selectively controlling the storing of DCTI values for a subchannel when the device-connect-time-measurement mode is active. The initial value of the enable bit is zero. When this enable bit is one in the SCHIB and MODIFY SUBCHANNEL is executed, the subchan-
nel is enabled for the device-connect-time-measurement mode. If the device-connect-time-measurement mode is active, the device-connect-time-measurement facility begins providing DCTI values for the subchannel, starting with the next START SUB-CHANNEL issued to the subchannel. In this situation, the DCTI values are provided in the ESW (see the section “Extended-Status Format 2” on page 54). Similarly, if MODIFY SUBCHANNEL is executed with bit 12 of word 1 of the SCHIB operand set to zero by the program, the subchannel is disabled for the device-connect-time-measurement mode, and no further DCTI values are passed to the program for that subchannel.

**Extended Measurement Word**

The extended-I/O-measurement-word facility provides the program with the capability of retrieving measurement information for a channel program. The measurement information is stored into the extended-measurement word (EMW) in the Interruption Response Block when the extended-measurement-word enable bit is one at the subchannel. See the section “Extended-Measurement Word” on page 56 in Chapter 16, “I/O Interruptions,” for the description of the extended-measurement word.

When the extended-measurement-word is enabled for the subchannel, measurement values are passed to program in the EMW when TEST SUBCHANNEL clears a primary-status condition, secondary-status condition alone, or an intermediate-status condition alone while the subchannel is suspended. The measurement values stored in the EMW pertain to the previous subchannel-active and device-active period. Measurement values are not stored in the EMW if the I/O function initiated by START SUBCHANNEL is terminated because of an error condition that is described by subchannel logout (see the section “Extended-Status Format 0” on page 47). In this case, the extended-status bit (L) of the SCSW is stored as one, indicating that the ESW contains logout information describing the error condition. See the section “Extended-Status Word” on page 47 for the description of the logout information. If any of the accrued measurement values exceeded the maximum value capable of being measured during the previous subchannel-active and device-active period, then the maximum value is stored for that value in the EMW.

**Extended-Measurement-Word Enable**

Bit 30 of word 6 of the SCHIB is the extended-measurement-word enable bit. This bit provides the program with the capability of selectively controlling the storing of measurement values for a subchannel. The initial value of the enable bit is zero. When this enable bit is one in the SCHIB and MODIFY SUBCHANNEL is executed, the subchannel is enabled for the extended-measurement-word and the extended-measurement-word facility begins providing measurement values for the subchannel starting with the next START SUBCHANNEL issued to the subchannel. Similarly, if MODIFY SUBCHANNEL is executed with bit 30, word 6, of the SCHIB operand set to zero by the program, the subchannel is disabled for the extended-measurement-word and no further measurement values are passed to the program for that subchannel.

**Signals and Resets**

During system operation, it may become necessary to terminate an I/O operation or to reset either the I/O system or a portion of the I/O system. (The I/O system consists of the channel subsystem plus all of the attached control units and devices.) Various signals and resets are provided for this purpose. Three signals are provided for the channel subsystem to notify an I/O device to terminate an operation or perform a reset function or both. Two resets are provided to cause the channel subsystem to reinitialize certain information contained either at the I/O device or at the channel subsystem.

**Signals**

The request that the channel subsystem initiate a signaling sequence is made by one of the following:

1. The program’s issuance of the CLEAR SUB-CHANNEL, HALT SUBCHANNEL, or RESET CHANNEL PATH instruction
2. The I/O device’s signaling of I/O-error alert
3. The channel subsystem itself, upon detecting certain error conditions or equipment malfunctions

The three signals are the halt signal, the clear signal, and the reset signal.
Halt Signal
The halt signal is provided so the channel subsystem can terminate an I/O operation. The halt signal is issued by the channel subsystem as part of the halt function performed subsequent to the execution of HALT SUBCHANNEL. The halt signal is also issued by the channel subsystem when certain error conditions are encountered.

For the parallel-I/O-interface type of channel path, the halt signal results in the channel subsystem using the interface-disconnect sequence control defined in the System Library publication IBM System/360 and System/370 I/O Interface Channel to Control Unit OEMI, GA22-6974.

For the ESCON-I/O-interface type of channel path, the halt signal results in the channel subsystem using the cancel function defined in the System Library publication IBM Enterprise Systems Architecture/390 ESCON I/O Interface, SA22-7202.

For the FICON-I/O-interface type of channel path and the subchannel is operating in command-mode, the halt signal results in the channel subsystem using the cancel function defined in the ANSI standards document Fibre Channel - Single-Byte Command Code Sets-2 (FC-SB-2).

For the FICON-I/O-interface type of channel path with the subchannel is operating in transport mode, the halt signal results in the channel subsystem using the transport-mode abort-sequence function.

Clear Signal
The clear signal is provided so the channel subsystem can terminate an I/O operation and reset status and control information contained at the device. The clear signal is issued as part of the clear function performed subsequent to the execution of CLEAR SUBCHANNEL. The clear signal is also issued by the channel subsystem when certain error conditions or equipment malfunctions are detected by the I/O device or the channel subsystem.

For the parallel-I/O-interface type of channel path, the clear signal results in the channel subsystem using the selective-reset sequence control defined in the System Library publication IBM System/360 and System/370 I/O Interface Channel to Control Unit OEMI, GA22-6974.

For the ESCON-I/O-interface type of channel path, the clear signal results in the channel subsystem using the selective-reset function defined in the System Library publication IBM Enterprise Systems Architecture/390 ESCON I/O Interface, SA22-7202.

For the FICON-I/O-interface type of channel path and the subchannel is operating in command-mode, the clear signal results in the channel subsystem using the selective-reset function defined in the ANSI standards document Fibre Channel - Single-Byte Command Code Sets-2 (FC-SB-2).

For the FICON-I/O-interface type of channel path with the subchannel is operating in transport mode, the clear signal results in the channel subsystem using the selective-reset function.

When the subchannel is operating in command mode, if an I/O operation is in progress at the device and the device is actively communicating over a channel path in the performance of that I/O operation when a clear signal is received on that channel path, the device disconnects from that channel path upon receiving the clear signal. Data transfer and any operation using the facilities of the control unit are immediately concluded, and the I/O device is not necessarily positioned at the beginning of a block. Mechanical motion not involving the use of the control unit, such as rewinding magnetic tape or positioning a disk-access mechanism, proceeds to the normal stopping point, if possible. The device may appear busy until termination of the mechanical motion or the inherent cycle of operation, if any, whereupon it becomes available. Status information in the device and control unit is reset, but an interruption condition may be generated upon the completion of any mechanical operation.

Reset Signal
The reset signal is provided so the channel subsystem can reset all I/O devices on a channel path. The reset signal is issued by the channel subsystem as part of the channel-path-reset function performed subsequent to the execution of RESET CHANNEL PATH. The reset signal is also issued by the channel subsystem as part of the I/O-system-reset function.

For the parallel-I/O-interface type of channel path, the reset signal results in the channel subsystem using the system-reset sequence control defined in the System Library publication IBM System/360 and
For the ESCON-I/O-interface type of channel path, the reset signal results in the channel subsystem using the system-reset function defined in the System Library publication IBM Enterprise Systems Architecture/390 ESCON I/O Interface, SA22-7202.

For the FICON-I/O-interface type of channel path, the reset signal results in the channel subsystem using the system-reset function defined in the ANSI standards document Fibre Channel - Single-Byte Command Code Sets-2 (FC-SB-2).

Resets

Two resets are provided so the channel subsystem can reinitialize certain information contained at either the I/O device or the channel subsystem. The request that the channel subsystem initiate one of the reset functions is made by one of the following:

1. The program's issuance of the RESET CHANNEL PATH instruction
2. The operator's activation of a system-reset-clear or system-reset-normal key or a load-clear or load-normal key
3. The channel subsystem itself upon detecting certain error conditions or equipment malfunctions

The resets are channel-path reset and I/O-system reset.

Channel-Path Reset

The channel-path-reset facility provides a mechanism to reset certain indications that pertain to a designated channel path at all associated subchannels. Channel-path reset occurs when the channel subsystem performs the channel-path-reset function initiated by the RESET CHANNEL PATH function. (See "RESET CHANNEL PATH" on page 9.) All internal indications of dedicated allegiance, control unit busy, and device busy that pertain to the designated channel path are cleared in all subchannels, and reset is signaled on that channel path.

The receipt of the reset signal by control units attached to that channel path causes all operations in progress and all status, mode settings, and allegiance, pertaining to that channel path, of the control unit and its attached devices to be reset. (See also the description of the system-reset-signal actions in "I/O-System Reset" on page 13.)

The results of the channel-path-reset function on the designated channel path are communicated to the program by means of a subsequent machine-check-interruption condition generated by the channel subsystem (see "Channel-Subsystem Recovery" on page 24).

I/O-System Reset

The I/O-system-reset function is performed when the channel subsystem is powered on, when initial program loading is initiated manually (see "Initial Program Loading" on page 16), and when the system-reset-clear or system-reset-normal key is activated. The I/O-system-reset function cannot be initiated under program control; it must be initiated manually. I/O-system reset may fail to complete due to malfunctions detected at the channel subsystem or on a channel path. I/O-system reset is performed as part of subsystem reset, which also resets all floating interruption requests, including pending I/O interruptions. (See "Subsystem Reset" on page 60.) Detailed descriptions of the effects of I/O-system reset on the various components of the I/O system appear later in this chapter.

I/O-system reset provides a means for placing the channel subsystem and its attached I/O devices in the initialized state. I/O-system reset affects only the channel-subsystem configuration in which it is performed, including all channel-subsystem components configured to that channel subsystem. I/O-system reset has no effect on any system components that are not part of the channel-subsystem configuration that is being reset. The effects of I/O-system reset on the configured components of the channel subsystem are described in the following sections.

Channel-Subsystem State: I/O-system reset causes the channel subsystem to be placed in the initialized state, with all the channel-subsystem components in the states described in the following sections. All operations in progress are terminated and reset, and all indications of prior conditions are reset. These indications include status information, interruption conditions (but not pending interruptions), dedicated-allegiance conditions, pending channel reports, and all internal information regarding prior conditions and operations. In the initialized state, the channel subsystem has no activity in progress and is...
Control Units and Devices: I/O-system reset causes a reset signal to be sent on all configured channel paths, including those which are not physically available (as indicated by the PAM bit being zero) because of a permanent error condition detected earlier. When the reset signal is received by a control unit, control-unit functions in progress, control-unit status, control-unit allegiance, and control-unit modes for the resetting channel path are reset. Device operations in progress, device status, device allegiance, and the device mode for the resetting channel path are also reset. Control-unit and device mode, allegiance, status, and I/O functions in progress for other channel paths are not affected.

For devices that are operating in the single-path mode, an operation can be in progress for, at most, one channel path. Therefore, if the reset signal is received on that channel path, the operation in progress is reset. Devices that have the dynamic-reconnection feature and are operating in the multipath mode, however, have the capability to establish an allegiance to a group of channel paths during an I/O operation, where all the channel paths of the path group are configured to the same channel subsystem. If an operation is in progress for a device that is operating in the multipath mode and the reset signal is received on one of the channel paths of that path group, then the operation in progress is reset for the resetting channel path only. Although the operation in progress cannot continue on the resetting channel path, it can continue on the other channel paths of the path group, subject to the following restrictions:

1. If the device is actively communicating with the channel subsystem on a channel path when it receives the reset signal on that channel path, then the operation is reset unconditionally, regardless of path groups.

2. If the operation is in progress in the multipath mode but the path group consists only of the resetting channel path only. Although the operation in progress cannot continue on the resetting channel path, it can continue on the other channel paths of the path group, subject to the following restrictions:

3. Except as noted in item 2, if the operation in progress is currently in a disconnected state (device not actively communicating with the channel subsystem) or is active on another channel path of a path group, system reset has no effect upon the continued performance of the operation.

A control unit is completely reset after the reset signal has been received on all its channel paths, provided no new activity is initiated at the control unit between the receipt of the first and last reset signal. “Completely reset” means that the current operation, if any, at the control unit is terminated and that control-unit allegiance, control-unit status, and the control-unit mode, if any, are reset.

An I/O device is completely reset after the reset signal has been received on all channel paths of all control units by which the device is accessible, provided no new activity is initiated at the device between the receipt of the first and last reset signal. “Completely reset” means that the current operation, if any, at the device is terminated and that device allegiance, device status, and the device mode are reset.

In summary, system reset always causes an operation in progress to be reset for the channel path on which the reset signal is received. If the resetting channel path is the only channel path for which the operation is in progress, then the operation is completely reset. If a device is actively communicating on a channel path over which the reset signal is received, then the operation in progress is unconditionally and completely reset.

The reset signal is not received by control units and devices on channel paths from which the control unit has been partitioned. A control unit is partitioned from a channel path by means of an enable/disable switch on the control unit for each channel path by which it is accessible. Multi-tagged, unsolicited status, if any, remains pending at the control unit for such a channel path in this case. However, from the point of view of the program, the control unit and device appear to be completely reset if the reset signal is received by the control unit on all the channel paths by which it is currently accessible.

The resultant reset state of individual control units and devices is described in the System Library publication for the control unit.

Channel Paths: I/O-system reset causes a reset signal to be sent on all configured channel paths and causes the channel subsystem to be placed in the reset and initialized state, as described in the previous sections. As a result of these actions, all communication between the channel subsystem and its
attached control units and devices is terminated and the components reset, and all configured channel paths are made quiescent or are deconfigured.

**Subchannels:** I/O-system reset causes all operations on all subchannels to be concluded. Status information, all interruption conditions (but not pending interruptions), dedicated-allegiance conditions, and internal indications regarding prior conditions and operations in all subchannels are reset, and all valid subchannels are placed in the initialized state.

In the initialized state, the subchannel parameters of all valid subchannels are set to their initial values. The initial values of the following subchannel parameters are zeros:

- Interruption parameter
- I/O-interruption-subclass code (ISC)
- Enabled
- Limit mode when the address-limit-checking facility is installed
- Measurement mode
- Multipath mode
- Path-not-operational mask
- Last-path-used mask
- Measurement-block index
- Concurrent sense

The initial values of the following subchannel parameters are assigned as part of the installation procedure for the device associated with each valid subchannel:

- Timing facility
- Device number
- Logical-path mask (same value as path-installed mask)
- Path-installed mask
- Path-available mask
- Channel-path ID 0-7

The values assigned may depend upon the particular system model and the configuration; dependencies, if any, are described in the System Library publication for the system model. Programming considerations may further constrain the values assigned.

The initial value of the path-operational mask is all ones.

The device-number-valid bit is one for all subchannels having an assigned I/O device.

The initial value of the model-dependent area of the subchannel-information block is described in the System Library publication for the system model.

The initial value of the subchannel-status word and extended-status word is all zeros.

The initialized state of the subchannel is the state specified by the initial values for the subchannel parameters described above. The description of the subchannel parameters can be found in “Subchannel-Information Block” on page 2, “Subchannel-Status Word” on page 7, and “Extended-Status Word” on page 47.

**Channel-Path-Reset Facility:** I/O-system reset causes the channel-path-reset facility to be reset. A channel-path-reset function initiated by RESET CHANNEL PATH, either pending or in progress, is overridden by I/O-system reset. The machine-check-interruption condition, which normally signals the completion of a channel-path-reset function, is not generated for a channel-path-reset function that is pending or in progress at the time I/O-system reset occurs.

**Address-Limit-Checking Facility:** When the address-limit-checking facility is installed, I/O-system reset causes the address-limit-checking facility to be reset. The address-limit value is initialized to all zeros and validated.

**Channel-Subsystem-Monitoring Facilities:** I/O-system reset causes the channel-subsystem-monitoring facilities to be reset. The measurement-block-update mode and the device-connect-time-measurement mode, if active, are made inactive. The measurement-block origin and the measurement-block key are both initialized to zeros and validated.

**Pending Channel Reports:** I/O-system reset causes pending channel reports to be reset.

**Channel-Subsystem Timer:** I/O-system reset does not necessarily affect the contents of the channel-subsystem timer. In models that provide channel-subsystem-timer checking, I/O-system reset may cause the channel-subsystem timer to be validated.

**Pending I/O Interruptions:** I/O-system reset does not affect pending I/O interruptions. However, during subsystem reset, I/O interruptions are cleared concurrently with the performance of I/O-system reset. (See “Subsystem Reset” on page 60.)
Externally Initiated Functions

I/O-system reset, which is an externally initiated function, is described in “I/O-System Reset” on page 13.

Initial Program Loading

Initial program loading (IPL) provides a manual means for causing a program to be read from a designated device and for initiating the execution of that program.
Some models may provide additional controls and indications relating to IPL; this additional information is specified in the System Library publication for the model.

There are two types of IPL: CCW-type IPL and list-directed IPL. CCW-type IPL is provided by all machine configurations. List-directed IPL may be provided, depending on the model.

**CCW-type IPL**

CCW-type IPL is initiated manually by setting the load-unit-address controls to a four-digit number to designate an input device and by subsequently activating the load-clear or load-normal key.

Activating the load-clear or load-normal key sets the architectural mode to the ESA/390 mode. For ease of reference, the additional elements of the description of ESA/390 IPL are given below.

Activating the load-clear key causes a clear reset to be performed on the configuration.

Activating the load-normal key causes an initial reset to be performed on this CPU, CPU reset to be propagated to all other CPUs in the configuration, and a subsystem reset to be performed on the remainder of the configuration.

In the loading part of the operation, after the resets have been performed, this CPU enters the load state. This CPU does not necessarily enter the stopped state during performance of the reset. The load indicator is on while the CPU is in the load state.

Subsequently, if conditions allow, a read operation is initiated from the designated input device and associated subchannel. The read operation is performed as if a START SUBCHANNEL instruction were executed that designated (1) the subchannel corresponding to the device number specified by the load-unit-address controls and (2) an ORB containing all zeros, except for a byte of all ones in the logical-path-mask field. The ORB parameters are interpreted by the channel subsystem as follows:

- **Interruption parameter:** All zeros
- **Subchannel key:** All zeros
- **Suspend control:** Zero (suspension not allowed)
- **CCW format:** Zero
- **CCW prefetch:** Zero (prefetching not allowed)

- **Initial-status-interruption control:** Zero (no request)
- **Address-limit-checking control:** Zero (no checking), when the address-limit-checking facility is installed
- **Suppress suspended interruption:** Zero (suppression not allowed)
- **Channel-program-type control:** Zero (CCW channel program), when the FCX-facility is installed
- **Logical-path mask:** Ones (all channel paths logically available)
- **Incorrect-length-suppression mode:** Zero (ignored because format-0 CCWs are specified)
- **Channel-program address:** Absolute address 0

The first CCW to be executed is not fetched from storage. Instead, the effect is as if an implied format-0 CCW, beginning in absolute location 0 and having the following detailed format, were executed:

```
Loc.  0 00000010000000000000000000000000 4 01100000
    8 16 31
```

In the illustration above, the CCW specifies a read command with the modifier bits zeros, a data address of 0, a byte count of 24, the chain-command flag one, the suppress-invalid-length-indication flag one, the chain-data flag zero, the program-controlled-interruption (PCI) flag zero, the indirect-data-address (IDA) flag zero, and the suspend flag zero. The CCW fetched, as a result of command chaining, from location 8 or 16, as well as any subsequent CCW in the IPL sequence, is interpreted the same as a CCW in any I/O operation, except that any PCI flags that are specified in the IPL channel program are ignored.

At the time the subchannel is made start pending for the IPL read, it is also enabled, which ensures proper handling of subsequent status from the device by the channel subsystem and facilitates subsequent I/O operations using the IPL device. (Except for the subchannel used by the IPL I/O operation, each subchannel must first be made enabled by MODIFY SUBCHANNEL before it can accept a start function or any status from the device.)

When the IPL subchannel becomes status pending for the last operation of the IPL channel program, no I/O-interruption condition is generated. Instead, the
subsystem ID is stored in absolute locations 184-187, zeros are stored in absolute locations 188-191, and the subchannel is cleared of the pending status as if TEST SUBCHANNEL had been executed but without storing information usually stored in an IRB. If the subchannel-status field that would normally have been stored is all zeros and the device-status field that would normally have been stored contains only the channel-end indication, with or without the device-end indication, the IPL I/O operation is considered to be completed successfully. If the device-end status for the IPL I/O operation is provided separately after channel-end status, it causes an I/O-interruption condition to be generated.

If an interface-control check is detected during execution of the IPL channel program, some models may re-initiate the same channel program on another channel path. The other path chosen is any logically-available channel path to the designated device on which the IPL channel program has not previously been initiated during the current IPL operation. (See programming note 6 on page 19 for additional information.)

When the IPL I/O operation is completed successfully, a new PSW is loaded from absolute locations 0-7. If the PSW loading is successful and no malfunctions are recognized that preclude the completion of IPL, then the CPU leaves the load state, and the load indicator is turned off. If the rate control is set to the process position, the CPU enters the operating state, and CPU operation proceeds under control of the new PSW. If the rate control is set to the instruction-step position, the CPU enters the stopped state, with the manual indicator on, after the new PSW has been loaded.

If the IPL I/O operation or the PSW loading is not completed successfully, the CPU remains in the load state, and the load indicator remains on.

IPL does not complete when any of the following occurs

- No subchannel contains a valid device number equal to the IPL device number specified by the load-unit-address controls.
- A malfunction is detected in the CPU, main storage, or channel subsystem that precludes the completion of IPL.
- Unsolicited alert status is presented by the device subsequent to the subchannel becoming start pending for the IPL read and before the IPL subchannel becomes subchannel active. The IPL read operation is not initiated in this case.
- There were no available channel paths to the IPL device.
- On every available channel path to the IPL device, either the IPL device appeared not operational or an interface-control check was detected.
- The IPL device presented a status byte containing indications other than channel end, device end, status modifier, control unit end, control unit busy, device busy, or retry status during the IPL I/O operation. Whenever control unit end, control unit busy, or device busy is presented in the status byte, normal path-management actions are taken.
- A subchannel-status indication other than PCI was generated during the IPL I/O operation, except that on some models, detection of an interface-control check may cause the I/O operation to be retried on another available channel path to the IPL device.
- The PSW loaded from absolute locations 0-7 has a PSW-format error of the type that is recognized early.

Except in the cases of no corresponding subchannel for the device number entered or a machine malfunction, the subsystem ID of the IPL device is stored in absolute locations 184-187; otherwise, the contents of these locations are unpredictable. In all cases of unsuccessful IPL, the contents of absolute locations 0-7 are unpredictable.

Subsequent to a successful IPL, the subchannel parameters contain the normal values as if an actual START SUBCHANNEL had been executed, designating the ORB as described above.

**Programming Notes:**

1. The information read and placed at absolute locations 8-15 and 16-23 may be used as CCWs for reading additional information during the IPL I/O operation: the CCW at location 8 may specify reading additional CCWs elsewhere in storage, and the CCW at location 16 may specify the
transfer-in-channel command, causing transfer to these CCWs.

2. The status-modifier bit has its normal effect during the IPL I/O operation, causing the channel subsystem to fetch and chain to the CCW whose address is 16 higher than that of the current CCW. This applies also to the initial chaining that occurs after completion of the read operation specified by the implicit CCW.

3. The PSW that is loaded at the completion of the IPL operation may be provided by the first eight bytes of the IPL I/O operation or may be placed at absolute locations 0-7 by a subsequent CCW.

4. Activating the load-normal key implicitly specifies the use of the first 24 bytes of main storage and the eight bytes at absolute locations 184-191. Since the remainder of the IPL program may be placed in any part of storage, it is possible to preserve such areas of storage as may be helpful in debugging or recovery. The IPL program should not be placed in the low 512 bytes of storage since that area is reserved as described in a programming note under “Compatibility between z/Architecture and ESA/390” on page 31. When the load-clear key is activated, the IPL program starts with a cleared machine in a known state, except that information on external storage remains unchanged.

5. When the PSW at absolute location 0 has bit 14 set to one, the CPU is placed in the wait state after the IPL operation is completed. At that point, the load and manual indicators are off, and the wait indicator is on.

6. When the program receives control after the machine leaves the load state during IPL, the last-path-used mask (LPUM) in the subchannel-information block (SCHIB) for the IPL device should be saved. The program should use this saved LPUM as the logical-path mask (LPM) in the ORB until the program reaches the point in its initialization where it has the ability to process and recover from interface-control checks, and verify that all of the channel paths associated with the subchannel are connected to the same device.

When multiple paths are associated with the subchannel of the IPL device, it is possible that mis-cabling of one or more of the paths can cause the program initialization to proceed on different devices. This affects the integrity of the IPL process. The program should ensure that all paths are connected to the same device, but this typically is not possible before program initialization completes. Thus the use of the saved LPUM ensures that all I/O operations to the IPL device during program initialization are executed on the same device, allowing postponement of the checking of the paths.

Using the saved LPUM also helps to ensure that the channel subsystem will not select a path on which errors would prevent completion of the program initialization, since the path indicated in the LPUM has demonstrated its functionality. On some models, using the saved LPUM also ensures that the path selection will not re-select a path on which an interface-control check was detected while the machine was in the load state.

List-Directed IPL

List-directed IPL supports the use of I/O devices which are not accessed by CCWs. List-directed IPL may be provided for a logical partition or virtual machine, depending on the model and the amount of memory available to the logical partition or virtual machine. The terms logical partition and virtual machine are not defined in this publication. The term logical partition is defined in the System Library publications. The term virtual machine is defined in the virtual-machine product manuals.

List-directed IPL is initiated by activating the load-clear-list-directed or load-with-dump key. Prior to activating either of these keys, the list-directed-IPL parameters are entered using a model-dependent console. List-directed-IPL parameters include the following information:

- Information which identifies the I/O device from which a program is to be loaded. This I/O device is referred to as the load device.
- Information which identifies a location on a load device from which a program will be loaded.
- Information to be used by the program which will be loaded from the load device.

The list-directed-IPL parameters required by a specific machine and the means by which they are entered are specified in the System Library publications.
After the list-directed-IPL parameters have been entered, the load-clear-list-directed or load-with-dump key for a particular CPU is activated. In the description which follows, the term “this CPU” refers to the CPU in the configuration for which the load-clear-list-directed key was activated.

Activating the load-clear-list-directed key causes a clear reset to be performed on all of the CPUs in the configuration.

Activating the load-with-dump key causes a store-status operation to be performed on this CPU. After the store-status operation, an initial-CPU-reset operation is performed on this CPU, CPU reset is propagated to all other CPUs in the configuration, and a subsystem reset is performed on the remainder of the configuration.

In the loading part of the operation, after the resets have been performed, the operations listed below are performed.

- If the rate control is not in the process position, it is forced into the process position.
- If the list-directed IPL operation was initiated by activating the load-with-dump key, the contents of a model-dependent number of contiguous logical-partition or virtual-machine storage locations starting with absolute location 0 are stored in a model-dependent holding area. The data stored includes the contents of all storage locations into which the program will be loaded from the load device. See Programming Note 4 for additional information.
- The program to be loaded from the load device is loaded into logical-partition or virtual-machine storage at the locations specified on the load device.
- A system IPL-parameter block used by the machine during list-directed IPL is placed in storage in the format shown in Figure 17-2 on page 20. The absolute address of the first byte of the system IPL-parameter block is stored in absolute address locations 20-23. An XML document containing the system IPL parameters immediately follows the last byte of the system IPL-parameter block. (See “Extensible Markup Language (XML) 1.0,” available from “World Wide Web Consortium” (www.w3c.org) for information regarding XML.)

The system IPL-parameter block has the following format:

<table>
<thead>
<tr>
<th>Word</th>
<th>Length</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>n</td>
</tr>
</tbody>
</table>

![Figure 17-2. System IPL-Parameter Block](image)

Bits 0-31 of word 0 of the system IPL-parameter block contains a length field. The length field contains a 32-bit binary number representing the number of bytes occupied by the system IPL-parameter block. Words 1 through n contain the system IPL parameters.

If no errors occur during the operations listed above, then if a subchannel is associated with the IPL-device, the subsystem-identification word is stored in absolute locations 184-187; otherwise zeros are stored in absolute locations 184-187. Additionally, zeros are stored in absolute locations 188-191, and a new PSW is loaded from absolute locations 0-7. If the PSW loading is successful and if no malfunctions are recognized which preclude execution of the program which was loaded from the load device, then operation proceeds under control of the new PSW.

If errors occur during the operations listed above, or if the PSW loading is not successful, then this CPU remains in the operating state. See the appropriate System Library publications for additional information.

When list-directed IPL was initiated by activating the load-clear-list-directed key, the state of the machine resources at the time when the loaded program is initiated is the same as it was immediately after the clear reset was performed except as indicated below. For a description of the state of the machine resources immediately after the clear reset was performed, see “Resets” on page 55.

- This CPU is in the operating state. The contents of the ALB and TLB for this CPU are unpredictable.
- The PSW for this CPU is set to the contents of absolute storage locations 0-7.
Main storage locations into which the program was loaded from the load device contain the program which was loaded, except for absolute storage locations 20-23 and 184-191. Absolute storage locations 20-23 contain the absolute address of the system IPL-parameter block; storage locations starting with this absolute address contain the system IPL-parameter block, immediately followed by an XML document containing the same system IPL parameters. If a subchannel is associated with the IPL device, then absolute storage locations 184-187 contain the subsystem-identification word for the IPL-device and absolute storage locations 188-191 contain zeros; otherwise, absolute storage locations 184-191 contain zeros. The contents of all other storage locations are unpredictable.

The ACC and F bits of the storage keys associated with all main storage locations are set to zero. The R and C bits of the storage keys associated with the first 4 K-byte block of storage, the blocks of storage containing the XML document and IPL-parameter list, and the blocks of storage containing the loaded program are set to one. The R and C bits of the storage keys associated with all other blocks of storage are unpredictable.

The TOD clock is unaffected by initial-program loading.

When list-directed IPL was initiated by activating the load-with-dump key, the state of the machine resources when control is passed to the loaded program is as follows:

- The I/O system has been reset.
- The state of all CPUs in the configuration except for this CPU is the same as it was immediately after the CPUs were reset.
- This CPU is in the operating state. The contents of all registers, the ALB, and the TLB for this CPU are unpredictable.
- The PSW for this CPU is set to the contents of absolute storage locations 0-7.
- The contents of all main storage locations which were not stored in the model-dependent holding area are unchanged from the time when the load-with-dump key was activated.
- The contents of all main storage locations which were stored in the model-dependent holding area are unpredictable except as follows:
  - Main storage locations into which the program was loaded from the load device contain the program which was loaded, except for absolute storage locations 20-23.
  - Absolute storage locations 20-23 contain the absolute address of the system IPL-parameter block; storage locations starting with this absolute address contain the system IPL-parameter block, immediately followed by an XML document containing the system IPL parameters.
  - If a subchannel is associated with the IPL device, then absolute storage locations 184-187 contain the subsystem-identification word for the IPL-device and absolute storage locations 188-191 contain zeros; otherwise, absolute storage locations 184-191 contain zeros.
- The storage keys associated with the blocks of main storage which were stored in the model-dependent holding area are unpredictable. The storage keys associated with all other blocks of main storage are in the same state as they were immediately after the CPUs were reset.
- The TOD clock is unaffected by initial-program loading.

List-directed IPL does not complete if any of the following occurs:

- A malfunction is detected in the CPU, channel subsystem, or main storage which precludes the completion of IPL.
- The list-directed IPL parameters did not contain sufficient information to identify the load device or the program on the load device.
- An I/O device designated by the list-directed-IPL parameters is not in the machine configuration.
- The I/O device designated by the list-directed-IPL parameters is a CCW-type device and is not supported by list-directed IPL.
- The I/O device appeared not operational.
• The amount of storage in the logical partition or virtual machine is insufficient to allow list-directed IPL to complete.

• The PSW to be loaded from locations 0-7 has a PSW-format error of the type that is recognized early.

Programming Notes:

1. The executable portion of the program loaded during list-directed IPL should be located in absolute storage starting at absolute storage locations 8192 and higher. This is necessary in order to avoid use of the architecturally assigned storage locations. See “Assigned Storage Locations” on page 68.

2. When the address indicated by storage locations 20-23 is above 16 MB, it is necessary for the machine to be in 31-bit addressing mode in order to access the IPL-parameter list and XML document.

3. When list-directed IPL is initiated by activation of the load-clear-list-directed key, the program loaded from the load device is typically an operating-system loader. In this case, the load device may also contain the operating system to be loaded by the operating-system loader. See the applicable operating-system manuals for additional information.

4. When list-directed IPL is initiated by activation of the load-with-dump key, the contents of storage which are affected by the IPL operation are stored in a model-dependent holding area so that they can be retrieved by the program which was loaded from the load device. The program loaded from the load device is typically an O/S-specific system dump program which stores the retrieved data onto a dump device. This process ensures that the contents of storage affected by the IPL operation are preserved for analysis during subsequent debug operations. See the applicable operating system manuals for additional information.

Reconfiguration of the I/O System

Reconfiguration of the I/O system is handled in a model-dependent manner. For example, changes may be made under program control, by using the model-dependent DIAGNOSE instruction; or manually, by using system-operator configuration controls; or by using a combination of DIAGNOSE and manual controls. The method used depends on the system model. The System Library publication for the system model specifies how the changes are made. The partitioning of channel paths because of reconfiguration is indicated by the setting of the PAM bits in the SCHIB stored when STORE SUBCHANNEL is executed (see “Path-Available Mask (PAM)” on page 7).

Status Verification

The status-verification facility provides the channel subsystem with a means of indicating that a device has presented a device-status byte that has valid CBC but that contained a combination of bits that was inappropriate when the status byte was presented to the channel subsystem. The indication provided to the program in the ESW by the channel subsystem is called device-status check. When the channel subsystem recognizes a device-status-check condition, an interface-control-check condition is also recognized. For a summary of the status combinations considered to be appropriate or inappropriate, see the System Library publications IBM Enterprise Systems Architecture/390 ESCON I/O Interface, SA22-7202, and IBM System/360 and System/370 I/O Interface Channel to Control Unit OEMI, GA22-6974, and the ANSI standards document Fibre Channel - Single-Byte Command Code Sets-2 (FCSB-2).

Address-Limit Checking

The address-limit-checking facility may be installed on a model and when installed provides a storage-protection mechanism for I/O data accesses to storage that augments key-controlled protection. The address-limit-checking facility is not installed when the FCX facility is installed. When address-limit checking is used, absolute storage is divided into two parts by a program-controlled address-limit value. I/O data accesses can then be optionally restricted to only one of the two parts of absolute storage by the limit mode at each subchannel. The address-limit constraint applies at a higher priority than key-controlled protection, that is, I/O data accesses to the part of main storage that is protected by address-limit checking are prevented even when the subchannel key is zero or matches the key in storage. Address-
limit checking does not apply to the fetching of CCWs, IDAWs and MIDAWs.

The address-limit-checking facility consists of the following elements:

- The I/O instruction SET ADDRESS LIMIT.
- The limit mode at each subchannel.
- The address-limit-checking-control bit in the ORB.

The execution of SET ADDRESS LIMIT passes the contents of general register 1 to the address-limit-checking facility to be used as the address-limit value. Bits 32 and 48-63 of general register 1 must be zeros to designate a valid absolute address on a 64K-byte boundary; otherwise, an operand exception is recognized, and the execution of the instruction is suppressed.

The limit mode at each subchannel indicates the manner in which address-limit checking is to be performed. The limit mode is set by placing the desired value in bit positions 9 and 10 of word 1 in the SCHIB and executing MODIFY SUBCHANNEL. The settings of these bits in the SCHIB have the following meanings:

00 No limit checking (initialized value).
01 Data address must be equal to or greater than the current address limit.
10 Data address must be less than the current address limit.
11 Reserved. This combination of limit-mode bits causes an operand exception to be recognized when MODIFY SUBCHANNEL is executed.

During the performance of the start function, an attempt to access an absolute storage location for data that is protected by an address limit (either high or low) is recognized as an address-limit violation, and the access is not allowed. A program-check condition is recognized, and channel-program execution is terminated, just as when an attempt is made to access an invalid address.

**Configuration Alert**

The configuration-alert facility provides a detection mechanism for devices that are not associated with a subchannel in the configuration. The configuration-alert facility notifies the program, by means of a channel report, that a device which is not associated with a subchannel has attempted to communicate with the program.

Each device must be assigned to a subchannel during an installation procedure; otherwise, the channel subsystem is unable to generate an I/O-interruption condition for the device. This is because the I/O-interruption code contains the subchannel number that identifies the particular device causing the I/O-interruption condition. When a device that is not associated with a subchannel attempts to communicate with the channel subsystem, the configuration-alert facility generates a channel report in which the unassociated device is identified. For a description of the means by which the program is notified of a pending channel report and how the information in the channel report is retrieved, see “Channel Report” on page 24.

**Incorrect-Length-Indication Suppression**

The incorrect-length-indication-suppression facility allows the indication of incorrect length for immediate operations to be suppressed in the same manner when using format-1 CCWs as when using format-0 CCWs. When the incorrect-length-indication-suppression facility is installed, bit 24 of word 1 of the ORB specifies whether the channel subsystem is to suppress the indication of incorrect length for an immediate operation when format-1 CCWs are used or whether this indication will remain under the control of the SLI flag of the current CCW (as is the case
for CCWs not executed as immediate operations). This bit provides the capability for a channel program to operate in the same manner regarding the indication of incorrect length regardless of whether format-0 or format-1 CCWs are used.

**Concurrent Sense**

The concurrent-sense facility provides a mechanism whereby sense information that is provided by the device can be presented by the channel subsystem to the program in the same command-mode IRB that contains the unit-check indication when the subchannel is in the concurrent-sense mode. The concurrent-sense mode is made active at a subchannel for which the concurrent-sense facility is applicable when MODIFY SUBCHANNEL is executed and bit 31 of word 6 of the SCHIB operand is set to one. The concurrent-sense facility is applicable to subchannels that are operating in command-mode and are associated with channel paths by which the channel subsystem can attempt to retrieve sense information from the device without requiring program intervention.

The concurrent-sense facility is not applicable when a subchannel is operating in transport mode. When a transport-mode IRB is presented that contains the unit-check indication, the associated sense information is found in the TSB for the associated TCW channel program. Therefore, the concurrent sense facility is not necessary with FCX.

**Channel-Subsystem Recovery**

The channel subsystem provides various methods for extensive detection of malfunctions and other conditions to ensure the integrity of channel-subsystem operation and to achieve automatic recovery of some malfunctions.

The method used to report a particular malfunction or other condition is dependent upon the severity of the malfunction or other condition and the degree to which the malfunction or other condition can be isolated. A malfunction or other condition in the channel subsystem may be indicated to the program by information being stored by one of the following methods:

1. Information is provided in the IRB describing a condition that has been recognized by either the channel subsystem or device that must be brought to the attention of the program. Generally, this information is made available to the program by the execution of TEST SUBCHANNEL, which is usually executed in response to the occurrence of an I/O interruption. (See “ Interruption Action” on page 6, for a definition of the information stored, as well as “ Interruptions” on page 1.)

2. Information is provided in a channel report describing a machine malfunction affecting the identified facility associated with the channel subsystem. This information is made available to the program by the execution of STORE CHANNEL REPORT WORD, which is usually executed in response to the occurrence of a machine-check interruption. (See “ Machine-Check Handling” on page 1 for a description of the machine-check-interruption mechanism and the contents of the machine-check-interruption code.)

3. Information is provided in a channel report describing a malfunction or other condition affecting a collection of channel-subsystem facilities. This information is made available to the program as indicated in item 2.

4. Information is provided in the machine-check-interruption code (MCIC) describing a malfunction affecting the continued operational integrity of the channel subsystem. (See “ Channel-Subsystem Damage” on page 17.)

5. Information is provided in the MCIC describing a malfunction affecting the continued operational integrity of a process or of the system. (See “ Instruction-Processing Damage” on page 15 and “ System Damage” on page 15.)

Channel reports are used to report malfunctions or other conditions only when the use of the I/O-interruption facility is not appropriate and in preference to reporting channel-subsystem damage, instruction-processing damage, or system damage.

**Channel Report**

When a malfunction or other condition affecting elements of the channel subsystem has been recognized, a channel report is generated. The performance of recovery actions by the program or
by external means may be required to gain recovery from the error condition. The channel report indicates the source of the channel report and the recovery state to the extent necessary for determining the proper recovery action. A channel report consists of one or more channel-report words (CRWs) that have been generated from an analysis of the malfunction or other condition. The inclusion of two or more CRWs within a channel report is indicated by the chaining flag being stored as one in all of the CRWs of the channel report except the last one in the chain.

When a channel report is made pending by the channel subsystem for retrieval and analysis by the program (by means of the execution of STORE CHANNEL REPORT WORD), a malfunction or other condition that affects the normal operation of one or more of the channel-subsystem facilities has been recognized. If the channel report that is made pending is an initial channel report, a machine-check-interruption condition is generated that indicates one or more CRWs are pending at the channel subsystem. A channel report is initial either if it is the first channel report to be generated after the most recent I/O-system reset or if no previously generated reports are pending and the last STORE CHANNEL REPORT WORD instruction that was executed resulted in the setting of condition code 1, indicating that no channel report was pending. When the machine-check interruption occurs and bit 9 of the machine-check-interruption code (channel report pending) is one, a channel report is pending. If the program clears the first CRW of a channel report before the associated machine-check interruption has occurred, some models may reset the machine-check-interruption condition, and the associated machine-check interruption does not occur. A machine-check interruption indicating that a channel report is pending occurs only if the machine-check mask (PSW bit 13) and the channel-report-pending subclass mask, bit 3 of control register 14, are both ones.

If the channel report that is made pending is not an initial channel report, a machine-check-interruption condition is not generated. The CRW that is presented to the program in response to the first STORE CHANNEL REPORT WORD instruction that is executed after a machine-check interruption may or may not be part of the initial channel report that caused the machine-check condition to be generated. A pending channel-report word is cleared by any CPU executing STORE CHANNEL REPORT WORD, regardless of whether a machine-check interruption has occurred in any CPU. If a CRW is not pending and STORE CHANNEL REPORT WORD is executed, condition code 1 is set, and zeros are stored at the location designated by the second-operand address. During the execution of STORE CHANNEL REPORT WORD as a result of receiving a machine-check interruption, condition code 1 may be set, and zeros may be stored because (1) the related channel report has been cleared by another CPU or (2) a malfunction occurred during the generation of a channel report. In the latter case, if, during a subsequent attempt, a valid channel report can be made pending, an additional machine-check-interruption condition is generated.

When a channel report consists of multiple chained CRWs, they are presented to the program in the same order that they are placed in the chain by the channel subsystem as a result of consecutive executions of STORE CHANNEL REPORT WORD. If, for example, the first CRW of a chain is presented to the program as a result of executing STORE CHANNEL REPORT WORD, the CRW that is presented as a result of the next execution of STORE CHANNEL REPORT WORD is the second CRW of the same chain and not a CRW that is part of another channel report.

Channel reports are not presented to the program in any special order, except for channel reports whose first or only CRW indicates the same reporting-source code and the same reporting-source ID. These channel reports are presented to the program in the same order that they are generated by the channel subsystem, but they are not necessarily presented consecutively. For example, suppose the channel subsystem generates channel reports A, B, and C, in that order. The first CRW of channel reports B and C indicates the same reporting-source code and the same reporting-source ID. Channel report B is presented to the program before channel report C is presented, but channel report A may be presented after channel report B and before channel report C.

Programming Notes:

1. The information that is provided in a single CRW may be made obsolete by another CRW that is subsequently generated for the same channel-subsystem facility. Therefore, the information that is provided in one channel report should be interpreted in light of the information provided by all of the channel reports that are pending at a given instant.
2. A machine-check-interruption condition is not always generated when a channel report is made pending. The conditions that result in a machine-check-interruption condition being generated are described earlier in this section.

3. After a machine-check interruption has occurred with bit 9 of the machine-check-interruption code set to one, STORE CHANNEL REPORT WORD should be issued repeatedly until all of the pending channel reports have been cleared and condition code 1 has been set.

4. A CRW-overflow condition can occur if the program does not issue successive STORE CHANNEL REPORT WORD instructions in a timely manner after the machine-check interruption occurs.

5. The number of CRWs that can be pending at the same time is model dependent. During the existence of an overflow condition, CRWs that would have otherwise been made pending are lost and are never presented to the program.

Channel-Report Word

The channel-report word (CRW) provides information to the program that can be used to facilitate the recovery of an I/O operation, a device, or some element of the channel subsystem, such as a channel path or subchannel.

The format of the CRW is as follows:

```
   Solicited CRW (S): Bit 1, when one, indicates a solicited CRW. A CRW is considered by the channel subsystem to be solicited if it is made pending as the direct result of some action that is taken by the program. When bit 1 is zero, the CRW is unsolicited and has been made pending as the result of an action taken by the channel subsystem that is independent of the program.

   Overflow (R): Bit 2, when one, indicates that a CRW-overflow condition has been recognized since this CRW became pending and that one or more CRWs have been lost. This bit is one in the CRW that has most recently been set pending when the overflow condition is recognized. When bit 2 is zero, a CRW-overflow condition has not been recognized.

   A CRW that is part of a channel report is not made pending, even though the overflow condition does not exist, if an overflow condition prevented a previous CRW of that report from being made pending.

   Chaining (C): Bit 3, when one, and when the overflow flag is zero, indicates chaining of associated CRWs. Chaining of CRWs is indicated whenever a malfunction or other condition is described by more than a single CRW. The chaining flag is zero if the channel report is described by a single CRW or if the CRW is the last CRW of a channel report.

   The chaining flag is not meaningful if the overflow bit, bit 2, is one.

   Reporting-Source Code (RSC): Bits 4-7 identify the channel-subsystem facility that is associated with the channel report. Some facilities are further identified in the reporting-source-identification field (see below). The following combinations of bits identify the facilities:

<table>
<thead>
<tr>
<th>Bits</th>
<th>Facility</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 1 0</td>
<td>Monitoring facility</td>
</tr>
<tr>
<td>0 0 1 1</td>
<td>Subchannel</td>
</tr>
<tr>
<td>0 1 0 0</td>
<td>Channel Path</td>
</tr>
<tr>
<td>1 0 0 1</td>
<td>Configuration-alert facility</td>
</tr>
<tr>
<td>1 0 1 1</td>
<td>Channel subsystem</td>
</tr>
</tbody>
</table>

   All other bit combinations in the reporting-source-code field are reserved.

   Ancillary Report (A): Bit 8, when one, indicates that a malfunction of a system component has occurred that was recognized previously or which has affected the activity of multiple channel-subsystem facilities. When the malfunction affects the activity of multiple channel-subsystem facilities, an ancillary-report condition is recognized for all of the affected facilities except one. This bit, when zero, indicates that this malfunction of a system component was not recognized previously. This bit is meaningful for all channel reports.

   Depending on the model, recognition of an ancillary-report condition may not be provided, or it may not be provided for all system malfunctions that affect chan-
nel-subsystem facilities. When ancillary-report recognition is not provided, bit 8 is set to zero.

**Error-Recovery Code (ERC):** Bits 10-15, when zero, indicate that the channel subsystem has error information regarding the channel-subsystem facility identified in the reporting-source code, and that the program can now request that information. Otherwise, bit positions 10-15 contain the error-recovery code that defines the recovery state of the channel-subsystem facility identified in the reporting-source code. This field, when used in conjunction with the reporting-source code, can be used by the program to determine whether the identified facility has already been recovered and is available for use or whether recovery actions are still required. The following error-recovery codes are defined:

<table>
<thead>
<tr>
<th>Bits</th>
<th>State</th>
</tr>
</thead>
<tbody>
<tr>
<td>000000</td>
<td>Event-information pending</td>
</tr>
<tr>
<td>000001</td>
<td>Available</td>
</tr>
<tr>
<td>000010</td>
<td>Initialized</td>
</tr>
<tr>
<td>000011</td>
<td>Temporary error</td>
</tr>
<tr>
<td>000100</td>
<td>Installed parameters initialized</td>
</tr>
<tr>
<td>000101</td>
<td>Terminal</td>
</tr>
<tr>
<td>000110</td>
<td>Permanent error with facility not initialized</td>
</tr>
<tr>
<td>000111</td>
<td>Permanent error with facility initialized</td>
</tr>
<tr>
<td>001000</td>
<td>Installed parameters modified</td>
</tr>
<tr>
<td>001010</td>
<td>Installed parameters restored</td>
</tr>
</tbody>
</table>

**Explanation:**

1. Installed-parameters restored is presented only if reporting of the installed-parameters-restored CRW is enabled in the restore-subchannel facility.

All other bit combinations in the error-recovery-code field are reserved.

The specific meaning of each error-recovery code depends on the particular reporting-source code that accompanies it in a CRW. The error-recovery codes are defined as follows:

- **Event-Information Pending:** Event information for the identified facility is available for retrieval by the program. This CRW does not indicate the state of the identified facility.

- **Available:** The identified facility is in the same state that the program would expect if the CRW had not been generated.

- **Initialized:** The identified facility is in the same state that existed immediately following the I/O-system reset that was part of the most recent system IPL.

- **Temporary Error:** The identified facility is not operating in a normal manner or has recognized the occurrence of an abnormal event. It is expected that subsequent actions either will restore the facility to normal operation or will record the appropriate information describing the abnormal event.

- **Installed Parameters Initialized:** This state is the same as the initialized state, except that one or more parameters that are associated with the facility and that are not modifiable by the program may have been changed.

On some models that do not implement the restore-subchannel facility, or in the absence of enablement by the program of reporting of the installed-parameters-restored CRW by the restore-subchannel facility, the installed-parameters-initialized CRW may be reported as a result of the channel subsystem’s recovery of the facility designated by the reporting-source ID.

- **Terminal:** The identified facility is in a state such that an operation that was in progress can neither be completed nor terminated in the normal manner.

- **Permanent Error with Facility Not Initialized:** The identified facility is in a state of malfunction, and the channel subsystem has not caused a reset function to be performed for that facility.

- **Permanent Error with Facility Initialized:** The identified facility is in a state of malfunction, and the channel subsystem has caused or may have caused a reset function to be performed for that facility.

- **Installed Parameters Modified:** One or more parameters of the specified facility have been changed.

- **Installed Parameters Restored:** This state is the same as the initialized state, except that one or more parameters that are associated with the facility and that are not modifiable by the program may have been changed from their most recent values back to their initialized values as a result of the channel subsystem’s recovery of the facility.

**Reporting-Source ID (RSID):** Bit positions 16-31 contain the reporting-source ID, which may, depending upon the condition that caused the channel report...
and the reporting-source code, either further identify
the affected channel-subsystem facility or provide
additional information describing the condition that
cased the channel report. The RSID field has the
following format as a function of the bit settings of the
reporting-source code.

<table>
<thead>
<tr>
<th>Reporting-Source Code</th>
<th>Reporting-Source ID Bits 16-31</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0 1 0</td>
<td>0000 0000 0000 0000</td>
</tr>
<tr>
<td>0 0 1 1</td>
<td>xxxx xxxx xxxx xxxx</td>
</tr>
<tr>
<td>0 0 1 1</td>
<td>0000 0000 00ss 0000</td>
</tr>
<tr>
<td>0 1 0 0</td>
<td>0000 0000 yyyy yyyy</td>
</tr>
<tr>
<td>1 0 0 1</td>
<td>0000 0000 yyyy yyyy</td>
</tr>
</tbody>
</table>

Note:

<table>
<thead>
<tr>
<th>Bit Positions</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxxx xxxx xxxx xxxx</td>
<td>Subchannel Number</td>
</tr>
<tr>
<td>ss</td>
<td>Subchannel-set ID when the MSS facility is installed and the CRW is chained immediately following a CRW for a subchannel.</td>
</tr>
<tr>
<td>yyyy yyyy</td>
<td>Channel-path ID (CHPID)</td>
</tr>
</tbody>
</table>

When the MSS facility is installed an additional CRW is chained to every channel report for subchannels. The content of this chained CRW is identical to the original CRW except for the RSID field. In this chained CRW, bit positions 10-11 of the RSID field contain the SSID identifying the subchannel set.

### Report-Subchannel Facility

The report-subchannel facility may be available on a model implementing z/Architecture. This facility provides the means for the channel subsystem to recover a damaged subchannel and report the recovery to the program by means of a CRW. When the facility is installed and reporting of the installed-parameters-restored CRW is enabled in the report-subchannel facility, the channel subsystem may recover the damaged subchannel and make a CRW pending that indicates installed-parameters restored.

In some models that do not implement the report-subchannel facility, the channel subsystem may nevertheless recover a damaged subchannel, and make a CRW pending that indicates installed-parameters initialized.

### Extended-Subchannel-Logout Facility

When the extended-subchannel-logout facility is installed and enabled, all fibre-channel (FC) channel paths can create extended-subchannel logouts, under applicable error conditions, and generate I/O interruptions that indicate such a logout is pending retrieval. The extended-subchannel logouts are stored in and retrieved from a model-dependent number of extended-subchannel-logout buffers associated with each channel path supported by the facility.

When TEST SUBCHANNEL for a subchannel that specifies an FC channel path stores an interruption-response block (IRB) containing a format-0 ESW in which the extended-subchannel-logout-pending (E) bit is 1, an extended-subchannel logout is pending for the specified subchannel. Words 2-3 of the format-0 ESW contain the extended-subchannel-logout descriptor (ESLD) that identifies the logout and the channel path for which the logout is pending.

When all the buffers for a given channel contain pending extended-subchannel logouts, the logouts will remain pending for a model-dependent time interval. If, during that time interval, a subsequent condition occurs that warrants a new extended-subchannel logout, that logout is not made and is lost. If the time interval has been exceeded and the program has not used the ESLD to retrieve a pending logout, the logout may be removed from the buffer or the buffer may be reused to contain a subsequent logout. When a logout is removed from a buffer and the buffer is not reused, the ESLD is no longer recognized as a valid logout identifier. When a buffer is reused, the ESLD may be recognized as a valid logout identifier albeit for a logout different from the logout for which the original I/O interruption was generated.
Channel-Subsystem-I/O-Priority Facility

The channel-subsystem-I/O-priority facility provides a means by which the program can establish a priority relationship, at the channel subsystem, among the subchannels that are placed into the start-pending state when START SUBCHANNEL is executed and condition code 0 is indicated. For I/O-subchannels that are configured to fibre-channel channel paths (FICON and FICON-converted channel paths), it also provides a means by which the program can establish a priority relationship for I/O operations at the fibre-channel-attached control units.

The program assigns the desired channel-subsystem priority and control-unit priority by specifying the desired priority numbers in the ORB extension when START SUBCHANNEL is executed.

The channel-subsystem-priority number specified in the ORB is used by the channel subsystem to determine the order in which start-pending and resume-pending subchannels are selected when the channel subsystem attempts to initiate a start function or a resume function. See the section “Start Function and Resume Function” on page 20 for details about these functions. In general, I/O subchannels that are in the start-pending or resume-pending state and have a higher priority number are selected for start-function or resume-function initiation by the channel subsystem before start-pending or resume-pending subchannels that have a lower priority number. The specific priority selection algorithm used by the channel subsystem for this purpose depends on the model. Additionally, the channel subsystem also applies a fairness selection algorithm in conjunction with the priority selection algorithm when selecting I/O subchannels. The specific fairness selection algorithm also depends on the model. For all models, the channel-subsystem priority and fairness selection algorithms are always applied to I/O subchannels that are either start pending or resume pending. Some models may also apply both algorithms to subchannels that are either clear pending or halt pending. See a model's System-Library publication for a description of the priority and fairness selection algorithms that the model provides and whether these algorithms are also applied to clear-pending or halt-pending subchannels.

The control-unit-priority number specified in the ORB is used by control units attached to fibre-channel channel paths in order to determine the priority of the execution of CCWs at the control unit. See “Control-Unit (CU) Priority:” on page 29 for additional information.

Number of Channel-Subsystem-Priority Levels

Depending on the model, fewer than 256 channel-subsystem-priority levels may be provided by the channel subsystem. Each priority level that the model provides is designated by an eight-bit unsigned binary integer. The lowest provided channel-subsystem-priority level is designated by the integer 0, and each succeeding higher priority level is designated by the next-higher sequential integer. For example, if the model provides 16 priority levels, they are numbered 0-15, respectively, from the lowest priority level to the highest priority level.

Multiple-Subchannel-Set Facility

The multiple-subchannel-set (MSS) facility increases the maximum number of subchannels that can be configured to a program. When the MSS facility is not provided, a single set of subchannels, in the range 0-65,535 may be provided for a program. When the MSS facility is provided, a maximum of four sets of subchannels may be provided for a program. Each subchannel set provides from one to 64K subchannels in the range 0 to 65,535. A two-bit unsigned binary integer, in the range of 0-3, called the subchannel-set identifier (SSID) is used to specify each provided subchannel set. The default subchannel set for a program is SSID 0. The initialized state of the MSS facility is disabled, in this state the MSS facility functions are not provided to programs executing in logical partitions.

When the MSS facility is provided, a subchannel is specified by a unique address formed by the concatenation of:

1. The subchannel-set identifier (SSID) of the subchannel-image set to which the designated subchannel-image is configured,

2. The subchannel number of the subchannel-image being accessed.
Chapter 18. Hexadecimal-Floating-Point Instructions

HFP Arithmetic . . . . . . . . . . . . . . . . . . . . . . . . . 18-1
HFP Number Representation . . . . . . . . . . . . . . . . . 18-1
Normalization . . . . . . . . . . . . . . . . . . . . . . . . . . . 18-2
HFP Data Formats . . . . . . . . . . . . . . . . . . . . . . . . 18-2
HFP Short Format . . . . . . . . . . . . . . . . . . . . . . . . 18-4
HFP Long Format . . . . . . . . . . . . . . . . . . . . . . . . 18-4
HFP Extended Format . . . . . . . . . . . . . . . . . . . . . 18-4
Instructions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18-5
ADD NORMALIZED . . . . . . . . . . . . . . . . . . . . . . . 18-8
ADD UNNORMALIZED . . . . . . . . . . . . . . . . . . . . 18-9
COMPARE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18-10
CONVERT FROM FIXED . . . . . . . . . . . . . . . . . . 18-11
CONVERT TO FIXED . . . . . . . . . . . . . . . . . . . . . . 18-11
DIVIDE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18-12
HALVE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18-13
LOAD AND TEST . . . . . . . . . . . . . . . . . . . . . . . 18-13
LOAD COMPLEMENT . . . . . . . . . . . . . . . . . . . . . . . 18-14
LOAD FP INTEGER . . . . . . . . . . . . . . . . . . . . . . . . 18-15
LOAD LENGTHENED . . . . . . . . . . . . . . . . . . . . . . 18-15
LOAD NEGATIVE . . . . . . . . . . . . . . . . . . . . . . 18-16
LOAD POSITIVE . . . . . . . . . . . . . . . . . . . . . . . . 18-16
LOAD ROUNDED . . . . . . . . . . . . . . . . . . . . . . . . . 18-17
MULTIPLY . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18-17
MULTIPLY AND ADD . . . . . . . . . . . . . . . . . . . . . . . 18-19
MULTIPLY AND SUBTRACT . . . . . . . . . . . . . . . . . 18-19
MULTIPLY AND ADD UNNORMALIZED . . . . . . . . . 18-20
MULTIPLY UNNORMALIZED . . . . . . . . . . . . . . . . 18-22
SQUARE ROOT . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18-23
SUBTRACT NORMALIZED . . . . . . . . . . . . . . . . . 18-24
SUBTRACT UNNORMALIZED . . . . . . . . . . . . . . . . 18-25

HFP Arithmetic

HFP Number Representation

A hexadecimal-floating-point (HFP) number consists of a sign bit, a hexadecimal fraction, and an unsigned seven-bit binary integer called the characteristic. The characteristic represents a signed exponent and is obtained by adding 64 to the exponent value (excess-64 notation). The range of the characteristic is 0 to 127, which corresponds to an exponent range of -64 to +63. The magnitude of an HFP number is the product of its fraction and the number 16 raised to the power of the exponent that is represented by its characteristic. The number is positive or negative depending on whether the sign bit is zero or one, respectively.

The fraction of an HFP number is treated as a hexadecimal number because it is considered to be multiplied by a number which is a power of 16. The name, fraction, indicates that the radix point is assumed to be immediately to the left of the leftmost fraction digit.

When an HFP operation would cause the result exponent to exceed 63, the characteristic wraps around from 0 to 127, and an HFP-exponent-underflow condition exists. The result characteristic is then too large by 128, except that a zero characteristic is produced when a true zero is forced.

A true zero is an HFP number with a zero characteristic and zero fraction. A true zero may arise as the normal result of an arithmetic operation because of the particular magnitude of the operands. For HFP operations, the result is forced to be a positive true zero when:

1. An HFP exponent underflow occurs and the HFP-exponent-underflow mask bit in the PSW is zero.
2. The result fraction of a normalized or unnormalized addition or subtraction operation is zero and the HFP-significance mask bit in the PSW is zero.
3. The operand of the CONVERT FROM FIXED instruction is zero.
4. The dividend in the DIVIDE instruction has a zero fraction.
5. The operand of the HALVE, LOAD FP INTEGER, or SQUARE ROOT instruction has a zero fraction.
6. One or both operands of a multiplication operation has a zero fraction.
When a program interruption for HFP exponent underflow occurs, a true zero is not forced; instead, the fraction and sign remain correct, and the characteristic is too large by 128. When a program interruption for HFP significance occurs, the fraction remains zero, the sign is positive, and the characteristic remains correct.

The sign of a sum, difference, product, quotient, square root, the result of CONVERT FROM FIXED, or the result of LOAD FP INTEGER with a zero fraction is positive. The sign for a zero fraction resulting from other HFP operations is established from the operand sign, the same as for nonzero fractions.

**Normalization**

A quantity can be represented with the greatest precision by an HFP number of a given fraction length when that number is normalized. A normalized HFP number has a nonzero leftmost hexadecimal fraction digit. If one or more leftmost fraction digits are zeros, the number is said to be unnormalized.

Unnormalized numbers are normalized by shifting the fraction left, one digit at a time, until the leftmost hexadecimal digit is nonzero and reducing the characteristic by the number of hexadecimal digits shifted. A number with a zero fraction cannot be normalized; either its characteristic remains unchanged or its characteristic is made zero when the result is forced to be a true zero.

Addition and subtraction with extended operands, as well as the MULTIPLY, DIVIDE, CONVERT FROM FIXED, HALVE, LOAD FP INTEGER, and SQUARE ROOT operations, are performed only with normalization. Addition and subtraction with short or long operands may be specified as either normalized or unnormalized. For all other operations, the result is produced without normalization.

With unnormalized operations, leftmost zeros in the result fraction are not eliminated. The result may or may not be in normalized form, depending upon the original operands.

In both normalized and unnormalized operations, the initial operands need not be in normalized form. The operands for multiply, divide, and square-root operations are normalized before the arithmetic process. For other normalized operations, normalization takes place when the intermediate arithmetic result is changed to the final result.

When the intermediate result of addition, subtraction, or rounding causes the fraction to overflow, the fraction is shifted right by one hexadecimal-digit position, and the value one is supplied to the vacated leftmost digit position. The fraction is then truncated to the final result length, while the characteristic is increased by one. This adjustment is made for both normalized and unnormalized operations.

Figure 18-1 on page 18-3 summarizes, for all instructions producing HFP results, the handling of zero results and whether normalization occurs for nonzero results.

**Programming Note:** Up to three leftmost bits of the fraction of a normalized number may be zeros, since the nonzero test applies to the entire leftmost hexadecimal digit.

**HFP Data Formats**

HFP numbers have a 32-bit (short) format, a 64-bit (long) format, or a 128-bit (extended) format. Numbers in the short and long formats may be designated as operands both in storage and in the floating-point registers, whereas operands having the extended format can be designated only in the floating-point registers.

In all formats, the first bit (bit 0) is the sign bit (S). The next seven bits are the characteristic. In the short and long formats, the remaining bits constitute the fraction, which consists of six or 14 hexadecimal digits, respectively.
### Instruction Table

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Nonzero Result Normalized</th>
<th>Zero Result Forced to True Zero</th>
<th>Zero Result Made Positive</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>Short and Long</td>
<td>Extended</td>
</tr>
<tr>
<td>ADD NORMALIZED</td>
<td>Yes</td>
<td>Y/N</td>
<td></td>
</tr>
<tr>
<td>ADD UNNORMALIZED</td>
<td>No</td>
<td>Y/N</td>
<td>–</td>
</tr>
<tr>
<td>CONVERT BFP TO HFP¹</td>
<td>Yes</td>
<td>Y/N</td>
<td>–</td>
</tr>
<tr>
<td>CONVERT FROM FIXED</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>DIVIDE</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>HALVE</td>
<td>Yes</td>
<td>Yes</td>
<td>–</td>
</tr>
<tr>
<td>LOAD¹</td>
<td>No</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>LOAD AND TEST</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
</tr>
<tr>
<td>LOAD COMPLEMENT</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
</tr>
<tr>
<td>LOAD FP INTEGER</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>LOAD LENGTHENED</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
</tr>
<tr>
<td>LOAD NEGATIVE</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
</tr>
<tr>
<td>LOAD POSITIVE</td>
<td>No</td>
<td>No</td>
<td>Yes</td>
</tr>
<tr>
<td>LOAD ROUNDED</td>
<td>No</td>
<td>No</td>
<td>–</td>
</tr>
<tr>
<td>LOAD ZERO¹</td>
<td>–</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>MULTIPLY</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>MULTIPLY AND ADD</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORMALIZED</td>
<td>No</td>
<td>–</td>
<td>No</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT</td>
<td>Yes</td>
<td>Yes</td>
<td>–</td>
</tr>
<tr>
<td>MULTIPLY UNNORMALIZED</td>
<td>No</td>
<td>–</td>
<td>No</td>
</tr>
<tr>
<td>PERFORM FLOATING-POINT OPERATION¹</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>SQUARE ROOT</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>STORE¹</td>
<td>No</td>
<td>No</td>
<td>–</td>
</tr>
<tr>
<td>SUBTRACT NORMALIZED</td>
<td>Yes</td>
<td>Y/N</td>
<td>Y/N</td>
</tr>
<tr>
<td>SUBTRACT UNNORMALIZED</td>
<td>No</td>
<td>Y/N</td>
<td>–</td>
</tr>
</tbody>
</table>

**Explanation:**

- Not applicable.
- Floating-point-support instruction.

Y/N When the HFP-significance mask bit (PSW bit 23) is zero, a true zero is forced. When the HFP-significance mask bit is one, the characteristic remains unchanged, and a program interruption for HFP significance occurs.

*Figure 18-1. Normalization and Zero Handling for Instructions with HFP Results*
An extended HFP number has a 28-digit fraction and consists of two long HFP numbers that are called the high-order and low-order parts. The high-order part may be any long HFP number. The fraction of the high-order part contains the leftmost 14 hexadecimal digits of the 28-digit fraction. The characteristic and sign of the high-order part are the characteristic and sign of the extended HFP number. If the high-order part is normalized, the extended number is considered normalized. The fraction of the low-order part contains the rightmost 14 digits of the 28-digit fraction. The sign and characteristic of the low-order part of an extended operand are ignored.

When a result is generated in the extended format and placed in a register pair, the sign of the low-order part is made the same as that of the high-order part, and, unless the result is a true zero, the low-order characteristic is made 14 less than the high-order characteristic. The subtraction of 14 would cause the low-order characteristic to become less than zero, the characteristic is made 128 greater than its correct value. (Thus, the subtraction is performed modulo 128.) HFP exponent underflow is indicated only when the high-order characteristic underflows.

When an extended result is made a true zero, both the high-order and low-order parts are made a true zero.

The range covered by the magnitude (M) of a normalized HFP number depends on the format.

In the short format:
\[ 16^{-65} \leq M \leq (1 - 16^{-6}) \times 16^{63} \]

In the long format:
\[ 16^{-65} \leq M \leq (1 - 16^{-14}) \times 16^{63} \]

In the extended format:
\[ 16^{-65} \leq M \leq (1 - 16^{-28}) \times 16^{63} \]

In all formats, approximately:
\[ 5.4 \times 10^{-79} \leq M \leq 7.2 \times 10^{75} \]

Although the final result of an HFP operation has six hexadecimal fraction digits in the short format, 14 fraction digits in the long format, and 28 fraction digits in the extended format, intermediate results have one additional hexadecimal digit on the right. This digit is called the guard digit. The guard digit may increase the precision of the final result because it participates in addition, subtraction, and comparison operations and in the left shift that occurs during normalization.

The entire set of HFP operations with normalized results is available for short, long, and extended operands in register-register versions; and for short and long operands in register-storage versions. Most instructions generate a result that has the same format as the source operands, except that there are multiplication operations which can generate a long product from short operands or an extended product from long operands. Other exceptions are instructions which convert operands from one floating-point format to another or between floating-point and fixed-point (binary-integer) formats.

**Programming Notes:**

1. In the absence of an HFP exponent overflow or HFP exponent underflow, the long HFP number constituting the low-order part of an extended result correctly expresses the value of the low-order part of the extended result when the characteristic of the high-order part is 14 or higher. This applies also when the result is a true zero. When the high-order characteristic is less than 14 but the number is not a true zero, the low-
order part, when considered as a long HFP number, does not express the correct characteristic value.

2. The entire fraction of an extended result participates in normalization. The low-order part alone may or may not appear to be a normalized long HFP number, depending on whether the 15th digit of the normalized 28-digit fraction is nonzero or zero.

Instructions

The HFP instructions and their mnemonics and operation codes are listed in Figure 18-2 on page 18-5. The figure indicates, in the column labeled “Characteristics”, the instruction format, when the condition code is set, the instruction fields that designate access registers, and the exceptional conditions in operand designations, data, or results that cause a program interruption.

All HFP instructions are subject to the AFP-register-control bit, bit 45 of control register 0. The AFP-register-control bit must be one when an AFP register is specified as an operand location; otherwise, an AFP-register data exception, DXC 1, is recognized.

Mnemonics for the HFP instructions have an R as the last letter when the instruction is in the RR, RRE, or RRF format. Certain letters are used for HFP instructions to represent operand-format length and normalization, as follows:

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD NORMALIZED (extended HFP)</td>
<td>AXR RR C</td>
<td>σ^7/3 SP Da EU EO LS</td>
<td>36</td>
<td>18-8</td>
</tr>
<tr>
<td>ADD NORMALIZED (long HFP)</td>
<td>AD RX-a C</td>
<td>σ^7/3 A Da EU EO LS</td>
<td>6A</td>
<td>18-8</td>
</tr>
<tr>
<td>ADD NORMALIZED (long HFP)</td>
<td>ADR RR C</td>
<td>σ^7/3 Da EU EO LS</td>
<td>2A</td>
<td>18-8</td>
</tr>
<tr>
<td>ADD NORMALIZED (short HFP)</td>
<td>AE RX-a C</td>
<td>σ^7/3 A Da EU EO LS</td>
<td>B2</td>
<td>18-8</td>
</tr>
<tr>
<td>ADD NORMALIZED (short HFP)</td>
<td>AER RR C</td>
<td>σ^7/3 Da EU EO LS</td>
<td>7A</td>
<td>18-8</td>
</tr>
<tr>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>AW RX-a C</td>
<td>σ^7/3 A Da EO LS</td>
<td>3A</td>
<td>18-8</td>
</tr>
<tr>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>AWR RR C</td>
<td>σ^7/3 Da EO LS</td>
<td>7E</td>
<td>18-9</td>
</tr>
<tr>
<td>ADD UNNORMALIZED (short HFP)</td>
<td>AU RX-a C</td>
<td>σ^7/3 A Da EO LS</td>
<td>3E</td>
<td>18-9</td>
</tr>
<tr>
<td>ADD UNNORMALIZED (short HFP)</td>
<td>AUR RR C</td>
<td>σ^7/3 Da EO LS</td>
<td>B369</td>
<td>18-10</td>
</tr>
<tr>
<td>COMPARE (extended HFP)</td>
<td>CXR RRE C</td>
<td>σ^7/3 SP Da</td>
<td>B2</td>
<td>18-9</td>
</tr>
<tr>
<td>COMPARE (long HFP)</td>
<td>CD RX-a C</td>
<td>σ^7/3 Da</td>
<td>69</td>
<td>18-10</td>
</tr>
<tr>
<td>COMPARE (long HFP)</td>
<td>CDR RR C</td>
<td>σ^7/3 Da</td>
<td>29</td>
<td>18-10</td>
</tr>
<tr>
<td>COMPARE (short HFP)</td>
<td>CE RX-a C</td>
<td>σ^7/3 Da</td>
<td>B2</td>
<td>18-10</td>
</tr>
<tr>
<td>COMPARE (short HFP)</td>
<td>CER RR C</td>
<td>σ^7/3 Da</td>
<td>39</td>
<td>18-10</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to extended HFP)</td>
<td>CXFRR RRE</td>
<td>σ^7/3 SP Da</td>
<td>B3B6</td>
<td>18-11</td>
</tr>
</tbody>
</table>

Note: In the detailed descriptions of the individual instructions, the mnemonic and the symbolic operand designation for the assembler language are shown with each instruction. For a register-to-register operation using COMPARE (short), for example, CER is the mnemonic and R1,R2 the operand designation.

Programming Notes:

1. The following additional HFP instructions are available when the HFP-multiply-and-add/subtract facility is installed:
   - MULTIPLY AND ADD (MAD, MADR, MAE, MAER)
   - MULTIPLY AND SUBTRACT (MSD, MSDR, MSE, MSER)

2. The following additional HFP instructions are available when the HFP-unnormalized-extensions facility is installed:
   - MULTIPLY AND ADD UNNORMALIZED (MAY, MAYH, MAYHR, MAYL, MAYLR, MAYR)
   - MULTIPLY UNNORMALIZED (MY, MYH, MYHR, MYL, MYLR, MYR)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT FROM FIXED (32 to long HFP)</td>
<td>CDFR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to short HFP)</td>
<td>CEFR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to extended HFP)</td>
<td>CXGR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>N</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to long HFP)</td>
<td>CDGR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>N</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to short HFP)</td>
<td>CEGR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>N</td>
</tr>
<tr>
<td>CONVERT TO FIXED (extended HFP to 32)</td>
<td>CFXR</td>
<td>RRF-e</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>CONVERT TO FIXED (extended HFP to 64)</td>
<td>CGXR</td>
<td>RRF-e</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>CONVERT TO FIXED (long HFP to 32)</td>
<td>CFDR</td>
<td>RRF-e</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>CONVERT TO FIXED (long HFP to 64)</td>
<td>CGDR</td>
<td>RRF-e</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>CONVERT TO FIXED (short HFP to 32)</td>
<td>CFRER</td>
<td>RRF-e</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>CONVERT TO FIXED (short HFP to 64)</td>
<td>CGER</td>
<td>RRF-e</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>DIVIDE (extended HFP)</td>
<td>CXR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>DIVIDE (long HFP)</td>
<td>DDX</td>
<td>RX-a</td>
<td>(a^*)</td>
<td>A</td>
</tr>
<tr>
<td>DIVIDE (short HFP)</td>
<td>DEER</td>
<td>RR</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>HALVE (long HFP)</td>
<td>HDRE</td>
<td>RR</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>HALVE (short HFP)</td>
<td>HER</td>
<td>RR</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>LOAD AND TEST (extended HFP)</td>
<td>LTXR</td>
<td>RRE</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD AND TEST (long HFP)</td>
<td>LTD</td>
<td>RR</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (extended HFP)</td>
<td>LCXR</td>
<td>RRE</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (long HFP)</td>
<td>LDDR</td>
<td>RR</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (short HFP)</td>
<td>LCEER</td>
<td>RR</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD FP INTEGER (extended HFP)</td>
<td>FIXR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>SP</td>
</tr>
<tr>
<td>LOAD FP INTEGER (long HFP)</td>
<td>FIDR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>LOAD FP INTEGER (short HFP)</td>
<td>FIRER</td>
<td>RR</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended HFP)</td>
<td>LXD</td>
<td>RXE</td>
<td>(a^*)</td>
<td>A</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended HFP)</td>
<td>LXE</td>
<td>RXE</td>
<td>(a^*)</td>
<td>A</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to extended HFP)</td>
<td>LXE</td>
<td>RXE</td>
<td>(a^*)</td>
<td>A</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to long HFP)</td>
<td>LEDR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to long HFP)</td>
<td>LEDR</td>
<td>RRE</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>LOAD NEGATIVE (extended HFP)</td>
<td>LNXR</td>
<td>RRE</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD NEGATIVE (long HFP)</td>
<td>LNR</td>
<td>RR</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD NEGATIVE (short HFP)</td>
<td>LNER</td>
<td>RR</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD POSITIVE (extended HFP)</td>
<td>LPXR</td>
<td>RRE</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD POSITIVE (long HFP)</td>
<td>LPDR</td>
<td>RR</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD POSITIVE (short HFP)</td>
<td>LPER</td>
<td>RR</td>
<td>C</td>
<td>(a^*)</td>
</tr>
<tr>
<td>LOAD ROUNDED (extended to long HFP)</td>
<td>LDXR</td>
<td>RR</td>
<td>(a^*)</td>
<td>SP</td>
</tr>
<tr>
<td>LOAD ROUNDED (extended to short HFP)</td>
<td>LDR</td>
<td>RR</td>
<td>(a^*)</td>
<td>SP</td>
</tr>
<tr>
<td>LOAD ROUNDED (long to extended HFP)</td>
<td>LDR</td>
<td>RR</td>
<td>(a^*)</td>
<td>SP</td>
</tr>
<tr>
<td>LOAD ROUNDED (long to short HFP)</td>
<td>LDR</td>
<td>RR</td>
<td>(a^*)</td>
<td>SP</td>
</tr>
<tr>
<td>MULTIPY (extended HFP)</td>
<td>MXR</td>
<td>RR</td>
<td>(a^*)</td>
<td>SP</td>
</tr>
<tr>
<td>MULTIPY (long HFP)</td>
<td>MDR</td>
<td>RR</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>MULTIPY (short HFP)</td>
<td>MDR</td>
<td>RR</td>
<td>(a^*)</td>
<td>SP</td>
</tr>
<tr>
<td>MULTIPLY (long HFP)</td>
<td>MD</td>
<td>RX-a</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
<tr>
<td>MULTIPLY (short HFP)</td>
<td>MD</td>
<td>RX-a</td>
<td>(a^*)</td>
<td>Da</td>
</tr>
</tbody>
</table>

Figure 18-2. Summary of HFP Instructions (Part 2 of 4)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>MULTIPPLY (short HFP)</td>
<td>MEER</td>
<td>$\sigma^7$</td>
<td>Da EU EO</td>
<td>B337 18-17</td>
</tr>
<tr>
<td>MULTIPLY (short to long HFP)</td>
<td>MDE</td>
<td>$\sigma^7$ A</td>
<td>Da EU EO</td>
<td>B3  18-18</td>
</tr>
<tr>
<td>MULTIPLY (short to long HFP)</td>
<td>MDER</td>
<td>$\sigma^7$</td>
<td>Da EU EO</td>
<td>3C  18-17</td>
</tr>
<tr>
<td>MULTIPLY (short to long HFP)</td>
<td>ME</td>
<td>$\sigma^7$ A</td>
<td>Da EU EO</td>
<td>B3  18-18</td>
</tr>
<tr>
<td>MULTIPLY (short to long HFP)</td>
<td>MER</td>
<td>$\sigma^7$</td>
<td>Da EU EO</td>
<td>3C  18-18</td>
</tr>
<tr>
<td>MULTIPLY AND ADD (long HFP)</td>
<td>MAD</td>
<td>$\sigma^7$ A</td>
<td>Da EU EO</td>
<td>B3  18-19</td>
</tr>
<tr>
<td>MULTIPLY AND ADD (short HFP)</td>
<td>MADER</td>
<td>$\sigma^7$</td>
<td>Da EU EO</td>
<td>B33E 18-19</td>
</tr>
<tr>
<td>MULTIPLY AND ADD (short HFP)</td>
<td>MEA</td>
<td>$\sigma^7$ A</td>
<td>Da EU EO</td>
<td>B3E  18-19</td>
</tr>
<tr>
<td>MULTIPLY AND ADD (short HFP)</td>
<td>MERA</td>
<td>$\sigma^7$</td>
<td>Da EU EO</td>
<td>B3E  18-19</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORM. (long to ext. HFP)</td>
<td>MAY</td>
<td>$\sigma^7$ A</td>
<td>Da</td>
<td>B33A 18-20</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORM. (long to ext. HFP)</td>
<td>MAYH</td>
<td>$\sigma^7$</td>
<td>Da</td>
<td>B33C 18-20</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORM. (long to ext. HFP)</td>
<td>MAYHR</td>
<td>$\sigma^7$ A</td>
<td>Da</td>
<td>B33E 18-20</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORM. (long to ext. HFP)</td>
<td>MAYL</td>
<td>$\sigma^7$</td>
<td>Da</td>
<td>B33E 18-20</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORM. (long to ext. HFP)</td>
<td>MAYLR</td>
<td>$\sigma^7$ A</td>
<td>Da</td>
<td>B33E 18-20</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT (long HFP)</td>
<td>MSD</td>
<td>$\sigma^7$ A</td>
<td>Da EU EO</td>
<td>B3  18-19</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT (short HFP)</td>
<td>MDSR</td>
<td>$\sigma^7$</td>
<td>Da EU EO</td>
<td>B33F 18-19</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT (short HFP)</td>
<td>MSEE</td>
<td>$\sigma^7$ A</td>
<td>Da EU EO</td>
<td>B3E  18-19</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT (short HFP)</td>
<td>MSER</td>
<td>$\sigma^7$</td>
<td>Da EU EO</td>
<td>B3F  18-19</td>
</tr>
<tr>
<td>MULTIPLY UNNORM. (long to ext. high HFP)</td>
<td>MYHR</td>
<td>$\sigma^7$ A</td>
<td>Da</td>
<td>B33D 18-22</td>
</tr>
<tr>
<td>MULTIPLY UNNORM. (long to ext. low HFP)</td>
<td>MYL</td>
<td>$\sigma^7$</td>
<td>Da</td>
<td>B33F 18-22</td>
</tr>
<tr>
<td>MULTIPLY UNNORM. (long to ext. low HFP)</td>
<td>MYLR</td>
<td>$\sigma^7$ A</td>
<td>Da</td>
<td>B33F 18-22</td>
</tr>
<tr>
<td>MULTIPLOY UNNORMALIZED (long to ext. HFP)</td>
<td>MY</td>
<td>$\sigma^7$ A SP</td>
<td>Da</td>
<td>B33B 18-22</td>
</tr>
<tr>
<td>MULTIPLOY UNNORMALIZED (long to ext. HFP)</td>
<td>MYR</td>
<td>$\sigma^7$</td>
<td>Da</td>
<td>B33B 18-22</td>
</tr>
<tr>
<td>SQUARE ROOT (extended HFP)</td>
<td>SOXR</td>
<td>$\sigma^7$ SP</td>
<td>Da SQ</td>
<td>B336 18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (long HFP)</td>
<td>SQD</td>
<td>$\sigma^7$ A</td>
<td>Da SQ</td>
<td>B35  18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (long HFP)</td>
<td>SQDR</td>
<td>$\sigma^7$</td>
<td>Da SQ</td>
<td>B244 18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (short HFP)</td>
<td>SOE</td>
<td>$\sigma^7$ A</td>
<td>Da SQ</td>
<td>B34D 18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (short HFP)</td>
<td>SOER</td>
<td>$\sigma^7$</td>
<td>Da SQ</td>
<td>B245 18-23</td>
</tr>
<tr>
<td>SUBTRACT NORMALIZED (extended HFP)</td>
<td>SXR</td>
<td>$\sigma^7$ SP</td>
<td>Da EU EO LS</td>
<td>37  18-24</td>
</tr>
<tr>
<td>SUBTRACT NORMALIZED (long HFP)</td>
<td>SD</td>
<td>$\sigma^7$ A</td>
<td>Da EU EO LS</td>
<td>B2  18-24</td>
</tr>
<tr>
<td>SUBTRACT NORMALIZED (long HFP)</td>
<td>SDR</td>
<td>$\sigma^7$</td>
<td>Da EU EO LS</td>
<td>2B  18-24</td>
</tr>
<tr>
<td>SUBTRACT NORMALIZED (short HFP)</td>
<td>SE</td>
<td>$\sigma^7$ A</td>
<td>Da EU EO LS</td>
<td>B2  18-24</td>
</tr>
<tr>
<td>SUBTRACT NORMALIZED (short HFP)</td>
<td>SER</td>
<td>$\sigma^7$</td>
<td>Da EU EO LS</td>
<td>3B  18-24</td>
</tr>
<tr>
<td>SUBTRACT UNNORMALIZED (long HFP)</td>
<td>SW</td>
<td>$\sigma^7$ A</td>
<td>Da EO LS</td>
<td>B2  18-25</td>
</tr>
<tr>
<td>SUBTRACT UNNORMALIZED (long HFP)</td>
<td>SWR</td>
<td>$\sigma^7$</td>
<td>Da EO LS</td>
<td>2F  18-25</td>
</tr>
<tr>
<td>SUBTRACT UNNORMALIZED (short HFP)</td>
<td>SU</td>
<td>$\sigma^7$ A</td>
<td>Da EO LS</td>
<td>B2  18-25</td>
</tr>
<tr>
<td>SUBTRACT UNNORMALIZED (short HFP)</td>
<td>SUR</td>
<td>$\sigma^7$</td>
<td>Da EO LS</td>
<td>3F  18-25</td>
</tr>
</tbody>
</table>

**Explanation:**

- $\sigma^7$ Restricted from transactional execution when the effective allow-floating-point-operation control is zero.
- $\sigma^3$ Restricted in the constrained transactional-execution mode; a transaction-constraint program exception may be recognized.
- A Access exceptions for logical addresses.
- B2 B2 field designates an access register in the access-register mode.
- C Condition code is set.
- Da AFP-register data exception.
- EO HFP-exponent-overflow exception.
- EU HFP-exponent-underflow exception.

*Figure 18-2. Summary of HFP Instructions  (Part 3 of 4)*
ADD NORMALIZED

Mnemonic1 R1,R2 [RR]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Mnemonic2 R1,D2(X2,B2) [RX-a]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
</tr>
<tr>
<td>31</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The second operand is added to the first operand, and the normalized sum is placed at the first-operand location.

Addition of two HFP numbers consists in characteristic comparison, fraction alignment, and signed fraction addition. The characteristics of the two operands are compared, and the fraction accompanying the smaller characteristic is aligned with the other fraction by a right shift, with its characteristic increased by one for each hexadecimal digit of shift until the two characteristics agree.

When a fraction is shifted right during alignment, the leftmost hexadecimal digit shifted out is retained as a guard digit. The fraction that is not shifted is considered to be extended with a zero in the guard-digit position. When no alignment shift occurs, both operands are considered to be extended with zeros in the guard-digit position. The fractions with signs are then added algebraically to form a signed intermediate sum.

The intermediate-sum fraction consists of seven (short format), 15 (long format), or 29 (extended format) hexadecimal digits, including the guard digit, and a possible carry. If a carry is present, the sum is shifted right one digit position so that the carry becomes the leftmost digit of the fraction, and the characteristic is increased by one.

If the addition produces no carry, the intermediate-sum fraction is shifted left as necessary to eliminate any leading hexadecimal zero digits resulting from the addition, provided the fraction is not zero. Zeros are supplied to the vacated rightmost digits, and the characteristic is reduced by the number of hexadecimal digits of shift. The fraction thus normalized is then truncated on the right to six (short format), 14 (long format), or 28 (extended format) hexadecimal digits. In the extended format, a characteristic is generated for the low-order part, which is 14 less than the high-order characteristic.

The sign of the sum is determined by the rules of algebra, unless all digits of the intermediate-sum fraction are zero, in which case the sign is made plus.
An HFP-exponent-overflow exception exists when a carry from the leftmost position of the intermediate-sum fraction would cause the characteristic of the normalized sum to exceed 127. The operation is completed by making the result characteristic 128 less than the correct value, and a program interruption for HFP exponent overflow occurs. The result is normalized, and the sign and fraction remain correct. For extended results, the characteristic of the low-order part remains correct.

An HFP-exponent-underflow exception exists when the characteristic of the normalized sum would be less than zero and the fraction is not zero. If the HFP-exponent-underflow mask bit in the PSW is one, the operation is completed by making the result characteristic 128 greater than the correct value, and a program interruption for HFP exponent underflow occurs. The result is normalized, and the sign and fraction remain correct. If the HFP-exponent-underflow mask bit in the PSW is zero, a program interruption for HFP exponent underflow occurs. The result is normalized, and the sign and fraction remain correct. For extended results, HFP exponent underflow is not recognized when the low-order characteristic is less than zero but the high-order characteristic is equal to or greater than zero.

The result fraction is zero when the intermediate-sum fraction, including the guard digit, is zero. With a zero result fraction, the action depends on the setting of the HFP-significance mask bit in the PSW. If the HFP-significance mask bit in the PSW is one, no normalization occurs, the intermediate and final result characteristics are the same, and a program interruption for HFP significance occurs. If the HFP-significance mask bit in the PSW is zero, the program interruption does not occur; instead, the result is made a positive true zero.

For AXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Result is zero</td>
</tr>
<tr>
<td>1</td>
<td>Result is less than zero</td>
</tr>
<tr>
<td>2</td>
<td>Result is greater than zero</td>
</tr>
<tr>
<td>3</td>
<td>--</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Access (fetch, operand 2 of AE and AD only)
- Data with DXC 1, AFP register
- HFP exponent overflow
- HFP exponent underflow
- HFP significance
- Specification (AXR only)
- Transaction constraint

**Programming Notes:**

1. An example of the use of the ADD NORMALIZED instruction (AE) is given in Appendix A.
2. Interchanging the two operands in an HFP addition does not affect the value of the sum.
3. The ADD NORMALIZED instruction normalizes the sum but not the operands. Thus, if one or both operands are unnormalized, precision may be lost during fraction alignment.

**ADD UNNORMALIZED**

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>AUR</td>
<td>'3E'</td>
<td>Short HFP</td>
</tr>
<tr>
<td>AWR</td>
<td>'2E'</td>
<td>Long HFP</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>AU</td>
<td>'7E'</td>
<td>Short HFP</td>
</tr>
<tr>
<td>AW</td>
<td>'6E'</td>
<td>Long HFP</td>
</tr>
</tbody>
</table>

The second operand is added to the first operand, and the unnormalized sum is placed at the first-operand location.

The execution of ADD UNNORMALIZED is identical to that of ADD NORMALIZED, except that:

1. When no carry is present after the addition, the intermediate-sum fraction is truncated to the proper result-fraction length without a left shift to eliminate leading hexadecimal zeros and without the corresponding reduction of the characteristic.
2. HFP exponent underflow cannot occur.
3. The guard digit does not participate in the recognition of a zero result fraction. A zero result frac-
tion is recognized when the fraction (that is, the intermediate-sum fraction, excluding the guard digit) is zero.

**Resulting Condition Code:**

0  Result fraction zero
1  Result less than zero
2  Result greater than zero
3  --

**Program Exceptions:**

- Access (fetch, operand 2 of AU and AW only)
- Data with DXC 1, AFP register
- HFP exponent overflow
- HFP significance
- Transaction constraint

**Programming Notes:**

1. An example of the use of the ADD UNNORMALIZED instruction (AU) is given in Appendix A.

2. Except when the result is made a true zero, the characteristic of the result of ADD UNNORMALIZED is equal to the greater of the two operand characteristics, increased by one if the fraction addition produced a carry, or set to zero if HFP exponent overflow occurred.

---

**COMPARE**

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>R1,R2</th>
<th>[RR]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
<td>R2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic1 Op Code Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CER '39' Short HFP</td>
</tr>
<tr>
<td>CDR '29' Long HFP</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2 R1,R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
</tr>
<tr>
<td>0</td>
<td>16</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2 Op Code Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CXR 'B369' Extended HFP</td>
</tr>
</tbody>
</table>

**COMPARE**

<table>
<thead>
<tr>
<th>Mnemonic3 R1,D2(X2,B2) [RX-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
</tr>
<tr>
<td>---------</td>
</tr>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic3 Op Code Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CE  '79' Short HFP</td>
</tr>
<tr>
<td>CD  '69' Long HFP</td>
</tr>
</tbody>
</table>

The first operand is compared with the second operand, and the condition code is set to indicate the result.

The comparison is algebraic and follows the procedure for normalized subtraction, except that the difference is discarded after setting the condition code and both operands remain unchanged. When the difference, including the guard digit, is zero, the operands are equal. When a nonzero difference is positive or negative, the first operand is high or low, respectively.

An HFP-exponent-overflow, HFP-exponent-underflow, or HFP-significance exception cannot occur.

For CXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Operands equal
1  First operand low
2  First operand high
3  --

**Program Exceptions:**

- Access (fetch, operand 2 of CE and CD only)
- Data with DXC 1, AFP register
- Specification (CXR only)
- Transaction constraint

**Programming Notes:**

1. Examples of the use of the COMPARE instruction (CDR) are given in Appendix A.

2. An exponent inequality alone is not sufficient to determine the inequality of two operands with the same sign, because the fractions may have different numbers of leading hexadecimal zeros.

3. Numbers with zero fractions compare equal even when they differ in sign or characteristic.
CONVERT FROM FIXED

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
<th>Result</th>
</tr>
</thead>
<tbody>
<tr>
<td>CEFR</td>
<td>'B3B4'</td>
<td>32-bit binary-integer operand, short HFP result</td>
<td></td>
</tr>
<tr>
<td>CDFR</td>
<td>'B3B5'</td>
<td>32-bit binary-integer operand, long HFP result</td>
<td></td>
</tr>
<tr>
<td>CXFR</td>
<td>'B3B6'</td>
<td>32-bit binary-integer operand, extended HFP result</td>
<td></td>
</tr>
<tr>
<td>CEGR</td>
<td>'B3C4'</td>
<td>64-bit binary-integer operand, short HFP result</td>
<td></td>
</tr>
<tr>
<td>CDGR</td>
<td>'B3C5'</td>
<td>64-bit binary-integer operand, long HFP result</td>
<td></td>
</tr>
<tr>
<td>CXGR</td>
<td>'B3C6'</td>
<td>64-bit binary-integer operand, extended HFP result</td>
<td></td>
</tr>
</tbody>
</table>

The fixed-point second operand is converted to the HFP format, and the normalized result is placed at the first-operand location.

A nonzero result is normalized. A zero result is made a positive true zero.

The second operand is a signed binary integer that is located in the general register designated by \( R_2 \). A 32-bit operand is in bit positions 32-63 of the register.

The result is normalized and rounded toward zero (truncated) before it is placed at the first-operand location.

For CXFR and CXGR, the \( R_1 \) field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC 1, AFP register
- Specification (CXFR and CXGR)
- Transaction constraint

CONVERT TO FIXED

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CEFR</td>
<td>'B3B8'</td>
<td>Short HFP operand, 32-bit binary-integer result</td>
</tr>
<tr>
<td>CFDR</td>
<td>'B3B9'</td>
<td>Long HFP operand, 32-bit binary-integer result</td>
</tr>
<tr>
<td>CFXR</td>
<td>'B3BA'</td>
<td>Extended HFP operand, 32-bit binary-integer result</td>
</tr>
<tr>
<td>CGER</td>
<td>'B3C8'</td>
<td>Short HFP operand, 64-bit binary-integer result</td>
</tr>
<tr>
<td>CGDR</td>
<td>'B3C9'</td>
<td>Long HFP operand, 64-bit binary-integer result</td>
</tr>
<tr>
<td>CGXR</td>
<td>'B3CA'</td>
<td>Extended HFP operand, 64-bit binary-integer result</td>
</tr>
</tbody>
</table>

The HFP second operand is rounded to an integer value and then converted to the fixed-point format. The result is placed at the first-operand location.

The result is a signed binary integer that is placed in the general register designated by \( R_1 \). For instructions that produce a 32-bit result, the result replaces bits 32-63 of the register, and bits 0-31 of the register remain unchanged.

The second operand is rounded to an integer value by rounding as specified by the modifier in the \( M_3 \) field:

**\( M_3 \) Effective Rounding Method**
- 0 Round toward 0
- 1 Round to nearest with ties away from 0
- 4 Round to nearest with ties to even
- 5 Round toward 0
- 6 Round toward \(+\infty\)
- 7 Round toward \(-\infty\)

For details on rounding see the section “Rounding Methods” on page 9-13.

A modifier other than 0, 1, or 4-7 is invalid.

The sign of the result is the sign of the second operand, except that a zero result has a plus sign.

If the rounded result would have a value exceeding the range that can be represented in the result format, the largest (in magnitude) representable num-
The number of the same sign as the source is placed at the target location, and condition code 3 is set.

HFP exponent underflow is not recognized because small values are rounded to one (with the appropriate sign) or to zero, depending on the rounding mode.

The M3 field must designate a valid modifier; otherwise, a specification exception is recognized. For CFXR and CGXR, the R2 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Source was zero  
1  Source was less than zero  
2  Source was greater than zero  
3  Special case

**Program Exceptions:**

- Data with DXC 1, AFP register  
- Specification  
- Transaction constraint

**DIVIDE**

<table>
<thead>
<tr>
<th>Operation</th>
<th>Mnemonic</th>
<th>M1</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>DER '3D'</td>
<td>DER</td>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
<tr>
<td>DDR '2D'</td>
<td>DDR</td>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Operation</th>
<th>Mnemonic</th>
<th>M2</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>DXR 'B2D'</td>
<td>DXR</td>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

The first operand (the dividend) is divided by the second operand (the divisor), and the normalized quotient is placed at the first-operand location. No remainder is preserved.

HFP division consists in characteristic subtraction and fraction division. The operands are first normalized to eliminate leading hexadecimal zeros. The difference between the dividend and divisor characteristics of the normalized operands, plus 64, is used as the characteristic of an intermediate quotient.

All dividend and divisor fraction digits participate in forming the fraction of the intermediate quotient. The intermediate-quotient fraction can have no leading hexadecimal zeros, but a right shift of one digit position may be necessary, with this causing an increase of the characteristic by one. The fraction is then truncated to the proper result-fraction length.

An HFP-exponent-overflow exception exists when the characteristic of the final quotient would exceed 127 and the fraction is not zero. The operation is completed by making the result characteristic 128 less than the correct value, and a program interruption for HFP exponent overflow occurs. The result is normalized, and the sign and fraction remain correct. If, for extended results, the low-order characteristic would also exceed 127, it too is decreased by 128.

An HFP-exponent-underflow exception exists when the characteristic of the final quotient would be less than zero and the fraction is not zero. If the HFP-exponent-underflow mask bit in the PSW is one, the operation is completed by making the result characteristic 128 greater than the correct value, and a program interruption for HFP exponent underflow occurs. The result is normalized, and the sign and fraction remain correct. If the HFP-exponent-underflow mask bit in the PSW is zero, a program interruption does not occur; instead, the operation is completed by making the result a positive true zero. For extended results, HFP exponent underflow is not recognized when the low-order characteristic is less than zero but the high-order characteristic is equal to or greater than zero.

HFP exponent underflow does not occur when the characteristic of an operand becomes less than zero during normalization of the operands or when the intermediate-quotient characteristic is less than zero, as long as the final quotient can be represented with the correct characteristic.
When the divisor fraction is zero, an HFP-divide exception is recognized. This includes the case of division of zero by zero.

When the dividend fraction is zero but the divisor fraction is nonzero, the quotient is made a positive true zero. No HFP exponent overflow or HFP exponent underflow occurs.

The sign of the quotient is the exclusive or of the operand signs, except that the sign is always plus when the quotient is made a positive true zero.

For DXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of DE and DD only)
- Data with DXC 1, AFP register
- HFP divide
- HFP exponent overflow
- HFP exponent underflow
- Specification (DXR only)
- Transaction constraint

**Programming Note:** Examples of the use of the DIVIDE instruction (DER) are given in Appendix A.

### HALVE

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>R&lt;sub&gt;1&lt;/sub&gt;R&lt;sub&gt;2&lt;/sub&gt;</th>
<th>[RR]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R&lt;sub&gt;1&lt;/sub&gt;</td>
<td>R&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

**Mnemonic** | **Op Code** | **Operands**
---|---|---
HER | '34' | Short HFP
HDR | '24' | Long HFP

The second operand is divided by 2, and the normalized quotient is placed at the first-operand location.

The fraction of the second operand is shifted right one bit position, placing the contents of the rightmost bit position in the leftmost bit position of the guard digit, and a zero is supplied to the leftmost bit position of the fraction. The intermediate result, including the guard digit, is then normalized, and the final result is truncated to the proper length.

An HFP-exponent-underflow exception exists when the characteristic of the final result would be less than zero and the fraction is not zero. If the HFP-exponent-underflow mask bit in the PSW is one, the operation is completed by making the result characteristic 128 greater than the correct value, and a program interruption for HFP exponent underflow occurs. The result is normalized, and the sign and fraction remain correct. If the HFP-exponent-underflow mask bit in the PSW is zero, a program interruption does not occur; instead, the operation is completed by making the result a positive true zero.

When the fraction of the second operand is zero, the result is made a positive true zero, and no HFP exponent underflow occurs.

The sign of the result is the same as that of the second operand, except that the sign is always plus when the quotient is made a positive true zero.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC 1, AFP register
- HFP exponent underflow
- Transaction constraint

**Programming Notes:**

1. An example of the use of the HALVE instruction (HDR) is given in Appendix A.

2. With short and long operands, the halve operation is identical to a divide operation with the number 2 as divisor. Similarly, the result of HDR is identical to that of MD or MDR with one-half as a multiplier, and the result of HER is identical to that of MEE or MEER with one-half as a multiplier.

### LOAD AND TEST

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>R&lt;sub&gt;1&lt;/sub&gt;R&lt;sub&gt;2&lt;/sub&gt;</th>
<th>[RR]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R&lt;sub&gt;1&lt;/sub&gt;</td>
<td>R&lt;sub&gt;2&lt;/sub&gt;</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

**Mnemonic** | **Op Code** | **Operands**
---|---|---
LTR | '32' | Short HFP
LTD | '22' | Long HFP
LOAD COMPLEMENT

Mnemonic2   $R_1, R_2$   [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>$R_1$</th>
<th>$R_2$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

Mnemonic2   Op Code   Operands

LTXR 'B362' Extended HFP

The second operand is placed at the first-operand location, and its sign and magnitude are tested to determine the setting of the condition code. The condition code is set the same as for a comparison of the second operand with zero.

For short and long operands, the second operand is placed unchanged in the first-operand location.

For extended operands, the high-order sign and the entire fraction of the source are placed unchanged in the result, and the low-order sign is set equal to the high-order sign. If the extended-operand fraction is nonzero, the high-order characteristic is placed unchanged in the result high-order characteristic, and the low-order characteristic is set to 14 less than the high-order characteristic, modulo 128. If the extended-operand fraction is zero, the result is made a true zero with the same sign as the source (the high-order and low-order sign bits of the result are the same as the high-order sign bit of the source).

For LTXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Resulting Condition Code:

0 Result is zero
1 Result is less than zero
2 Result is greater than zero
3 --

Program Exceptions:

- Data with DXC 1, AFP register
- Specification (LTXR only)
- Transaction constraint

Programming Note: When, for LTER and LTDR, the same register is designated as the first-operand and second-operand location, the operation is equivalent to a test without data movement.

LOAD COMPLEMENT

Mnemonic1   $R_1, R_2$   [RR]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>$R_1$</th>
<th>$R_2$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

Mnemonic1   Op Code   Operands

LCER '33' Short HFP
LCDR '23' Long HFP

Mnemonic2   $R_1, R_2$   [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>$R_1$</th>
<th>$R_2$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

Mnemonic2   Op Code   Operands

LCXR 'B363' Extended HFP

The second operand is placed at the first-operand location with the sign bit inverted.

The sign bit is inverted even if the operand is zero. For all operand lengths, the source fraction is placed unchanged in the result.

For short and long operands, the source characteristic is placed unchanged in the result.

For extended operands, the low-order sign is set equal to the high-order sign. If the extended-operand fraction is nonzero, the high-order characteristic is placed unchanged in the result high-order characteristic, and the low-order characteristic is set to 14 less than the high-order characteristic, modulo 128. If the extended-operand fraction is zero, the result is made a true zero with the sign inverted from the source (the high-order and low-order sign bits of the result are inverted from the high-order sign bit of the source).

For LCXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Resulting Condition Code:

0 Result is zero
1 Result is less than zero
2 Result is greater than zero
3 --

Program Exceptions:

- Data with DXC 1, AFP register
- Specification (LCXR only)
- Transaction constraint
LOAD FP INTEGER

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>FIER</td>
<td>'B377'</td>
<td>Short HFP</td>
</tr>
<tr>
<td>FIDR</td>
<td>'B37F'</td>
<td>Long HFP</td>
</tr>
<tr>
<td>FIXR</td>
<td>'B367'</td>
<td>Extended HFP</td>
</tr>
</tbody>
</table>

The second operand is truncated (rounded toward zero) to an integer value in the same floating-point format, and the normalized result is placed at the first-operand location.

A nonzero result is normalized. A zero result is made a positive true zero.

For FIXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC 1, AFP register
- Specification (FIXR only)
- Transaction constraint

**Programming Notes:**
1. LOAD FP INTEGER truncates (rounds toward zero) an HFP number to an integer value. These integers, which remain in the HFP format, should not be confused with binary integers, which use a fixed-point format.
2. If the HFP operand has a large enough exponent so that it is already an integer, the result value remains the same, except that an unnormalized operand is normalized, and an operand with a zero fraction is changed to a positive true zero.

LOAD LENGTHENED

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>Mnemonic2</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>LDER</td>
<td>R1,R2</td>
<td>'B324'</td>
<td>Short HFP operand 2, long HFP operand 1</td>
</tr>
<tr>
<td>LXDR</td>
<td>R1,D2(X2,B2)</td>
<td>'B325'</td>
<td>Long HFP operand 2, extended HFP operand 1</td>
</tr>
<tr>
<td>LXER</td>
<td>R1,D2(X2,B2)</td>
<td>'B326'</td>
<td>Short HFP operand 2, extended HFP operand 1</td>
</tr>
<tr>
<td>LDE</td>
<td>R1,X2</td>
<td>'ED24'</td>
<td>Short HFP operand 2, long HFP operand 1</td>
</tr>
<tr>
<td>LXD</td>
<td>R1,X2</td>
<td>'ED25'</td>
<td>Long HFP operand 2, extended HFP operand 1</td>
</tr>
<tr>
<td>LXE</td>
<td>R1,X2</td>
<td>'ED26'</td>
<td>Short HFP operand 2, extended HFP operand 1</td>
</tr>
</tbody>
</table>

The second operand is extended to a longer format, and the result is placed at the first-operand location.

For all operand lengths, the source fraction is extended with zeros and placed in the result. The sign bit of the result is set the same as the sign of the source even when the result is made a true zero.

For long results, the source characteristic is placed unchanged in the result.

For extended results, the low-order sign is set equal to the high-order sign. If the fraction is nonzero, the source characteristic is placed unchanged in the result high-order characteristic, and the low-order characteristic is set to 14 less than the high-order characteristic, modulo 128. If the fraction is zero, the result is made a true zero with the same sign as the source (the high-order and low-order sign bits of the result are the same as the sign bit of the source).

For LXD, LXDR, LXE, and LXER, the R1 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
LOAD NEGATIVE

Mnemonic1  R1, R2  [RR]

Op Code  R1  R2
0 8 12 15

Mnemonic1  Op Code  Operands
LNER  '31'  Short HFP
LNDR  '21'  Long HFP

Mnemonic2  R1, R2  [RRE]

Op Code  R1  R2
0 16 24 28 31

Mnemonic2  Op Code  Operands
LNXR  'B361'  Extended HFP

The second operand is placed at the first-operand location with the sign bit made one.

The sign bit is made one even if the operand is zero. For all operand lengths, the source fraction is placed unchanged in the result.

For short and long operands, the source characteristic is placed unchanged in the result.

For extended operands, the low-order sign is set equal to the high-order sign. If the extended-operand fraction is nonzero, the high-order characteristic is placed unchanged in the result high-order characteristic, and the low-order characteristic is set to 14 less than the high-order characteristic, modulo 128. If the extended-operand fraction is zero, the result is made a negative true zero (the high-order and low-order sign bits of the result are set to one).

For LNXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Resulting Condition Code:

0  Result is zero
1  Result is less than zero
2  --
3  --

Program Exceptions:

- Data with DXC 1, AFP register
- Specification (LNXR only)
- Transaction constraint

LOAD POSITIVE

Mnemonic1  R1, R2  [RR]

Op Code  R1  R2
0 8 12 15

Mnemonic1  Op Code  Operands
LPEN  '30'  Short HFP
LPDR  '20'  Long HFP

Mnemonic2  R1, R2  [RRE]

Op Code  R1  R2
0 16 24 28 31

Mnemonic2  Op Code  Operands
LNXR  'B360'  Extended HFP

The second operand is placed at the first-operand location with the sign bit made zero.

For all operand lengths, the sign bit is made zero, and the source fraction is placed unchanged in the result.

For short and long operands, the source characteristic is placed unchanged in the result.

For extended operands, the low-order sign is set equal to the high-order sign. If the extended-operand fraction is nonzero, the high-order characteristic is placed unchanged in the result high-order characteristic, and the low-order characteristic is set to 14 less than the high-order characteristic, modulo 128. If the extended-operand fraction is zero, the result is made a positive true zero (the high-order and low-order sign bits of the result are set to zero).

For LPXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Resulting Condition Code:

0  Result is zero
1  --
2  Result is greater than zero
3  --
**Program Exceptions:**

- Data with DXC 1, AFP register
- Specification (LPXR only)
- Transaction constraint

**LOAD ROUNDED**

Mnemonic 1: \texttt{R1,R2} [RR]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>0</th>
<th>8</th>
<th>12</th>
<th>15</th>
</tr>
</thead>
</table>

**Mnemonic 1 Op Code**

- LDR '35' Long HFP operand 2, short HFP operand 1
- LDXR '25' Extended HFP operand 2, long HFP operand 1

The above mnemonics are alternatives to the following older mnemonics that are less descriptive of operand lengths:

- LER '35' Long HFP operand 2, short HFP operand 1
- LRDR '25' Extended HFP operand 2, long HFP operand 1

The sign of the result is the same as the sign of the second operand. There is no normalization to eliminate leading zeros.

An HFP-exponent-overflow exception exists when shifting the fraction right would cause the characteristic to exceed 127. The operation is completed by making the result characteristic 128 less than the correct value, and a program interruption for HFP exponent overflow occurs. The result is normalized, and the sign and fraction remain correct.

HFP-exponent-underflow and HFP-significance exceptions cannot occur.

For LDXR (or LRDR) and LEXR, the \texttt{R2} field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC 1, AFP register
- HFP exponent overflow
- Specification (LDXR, LEXR, LRDR)
- Transaction constraint

**Programming Note:** The sign of the rounded result is the same as the sign of the operand, even when the result is zero.

**MULTIPLY**

Mnemonic 1: \texttt{R1,R2} [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>0</th>
<th>16</th>
<th>24</th>
<th>28</th>
<th>31</th>
</tr>
</thead>
</table>

**Mnemonic 1 Op Code**

- MEER 'B337' Short HFP multiplier and multiplicand, long HFP product
- MXR '26' Extended HFP multiplier and multiplicand, long HFP product
- MDER '3C' Short HFP multiplier and multiplicand, long HFP product
- MXDR '27' Extended HFP multiplier and multiplicand, long HFP product

The sign of the result is the same as the sign of the second operand. There is no normalization to eliminate leading zeros.

If rounding causes a carry out of the leftmost hexadecimal digit position of the fraction, the fraction is shifted right one digit position so that the carry becomes the leftmost digit of the fraction, and the characteristic is increased by one.

The intermediate fraction is then truncated to the proper result-fraction length. For LDR and LEXR, the result replaces the leftmost 32 bits of the target register, and the rightmost 32 bit positions of the target register remain unchanged. For LDXR, the 64-bit result is placed in a floating-point register, not a floating-point register pair.
The above mnemonic MDER is an alternative to the following older mnemonic that is less descriptive of operand lengths:
MER ‘3C’ Short HFP multiplier and multiplicand, long HFP product

Mnemonic3 R1, D2(X2, B2) [RXE]
0 8 12 16 20 32 40 47

Mnemonic3 Op Code Operands
MEE ‘ED37’ Short HFP

Mnemonic4 R1, D2(X2, B2) [RX-a]
Op Code R1 X2 B2 D2
0 8 12 16 20 31

Mnemonic4 Op Code Operands
MD ‘6C’ Long HFP
MDE ‘7C’ Short HFP multiplier and multiplicand, long HFP product
MXD ‘67’ Long HFP multiplier and multiplicand, extended HFP product

The above mnemonic MDE is an alternative to the following older mnemonic that is less descriptive of operand lengths:
ME ‘7C’ Short HFP multiplier and multiplicand, long HFP product

The normalized product of the second operand (the multiplier) and the first operand (the multiplicand) is placed at the first-operand location.

Multiplication of two HFP numbers consists in exponent addition and fraction multiplication. The operands are first normalized to eliminate leading hexadecimal zeros. The sum of the characteristics of the normalized operands, less 64, is used as the characteristic of the intermediate product.

The fraction of the intermediate product is the exact product of the normalized operand fractions. If the intermediate-product fraction has one leading hexadecimal zero digit, the fraction is shifted left one digit position, bringing the contents of the guard-digit position into the rightmost position of the result fraction, and the intermediate-product characteristic is reduced by one. The fraction is then truncated to the proper result-fraction length.

For MDE and MDER, the multiplier and multiplicand fractions have six hexadecimal digits; the product fraction has the full 14 digits of the long format, with the two rightmost fraction digits always zeros. For MEE and MEER, the multiplier and multiplicand fractions have six digits, and the final product fraction is truncated to six digits; the result, as for all short-format results, replaces the leftmost 32 bits of the target register, and the rightmost 32 bit positions of the target register remain unchanged.

For MD and MDR, the multiplier and multiplicand fractions have 14 digits, and the final product fraction is truncated to 14 digits. For MXD and MXDR, the multiplier and multiplicand fractions have 14 digits, with the multiplicand occupying the high-order part of the first operand; the final product fraction contains 28 digits and is an exact product of the operand fractions. For MXR, the multiplier and multiplicand fractions have 28 digits, and the final product fraction is truncated to 28 digits.

An HFP-exponent-overflow exception exists when the characteristic of the final product would exceed 127 and the fraction is not zero. The operation is completed by making the result characteristic 128 less than the correct value, and a program interruption for HFP exponent overflow occurs. The result is normalized, and the sign and fraction remain correct. If, for extended results, the low-order characteristic would also exceed 127, it too is decreased by 128.

HFP exponent overflow is not recognized when the intermediate-product characteristic is initially 128 but is brought back within range by normalization.

An HFP-exponent-underflow exception exists when the characteristic of the final product would be less than zero and the fraction is not zero. If the HFP-exponent-underflow mask bit in the PSW is one, the operation is completed by making the result characteristic 128 greater than the correct value, and a program interruption for HFP exponent underflow occurs. The result is normalized, and the sign and fraction remain correct. If the HFP-exponent-underflow mask bit in the PSW is zero, a program interruption does not occur; instead, the operation is completed by making the result a positive true zero. For extended results, HFP exponent underflow is not recognized when the low-order characteristic is less than zero but the high-order characteristic is equal to or greater than zero.

HFP exponent underflow does not occur when the characteristic of an operand becomes less than zero during normalization of the operands, as long as the final product can be represented with the correct characteristic.
If either or both operand fractions are zero, the result is made a positive true zero, and no HFP exponent overflow or HFP exponent underflow occurs.

The sign of the product is the exclusive or of the operand signs, except that the sign is always plus when the result is made a true zero.

The \( R_1 \) field for MXD, MXDR, and MXR, and the \( R_2 \) field for MXR must designate valid floating-point-register pairs. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of MDE, MEE, MD, and MXD only)
- Data with DXC 1, AFP register
- HFP exponent overflow
- HFP exponent underflow
- Specification (MXD, MXDR, MXR)
- Transaction constraint

**Programming Notes:**

1. An example of the use of the MULTIPLY instruction (MDR) is given in Appendix A.
2. Interchanging the two operands in an HFP multiplication does not affect the value of the product.

**MULTIPLY AND ADD**

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>R_1R_2R_3 [RRD]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R_1 R_3 R_2</td>
</tr>
<tr>
<td>0</td>
<td>16 20 24 28 31</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAER</td>
<td>'B32E'</td>
<td>Short HFP</td>
</tr>
<tr>
<td>MADR</td>
<td>'B33E'</td>
<td>Long HFP</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2</th>
<th>R_1R_2D_2(X_2B_2) [RXF]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R_2 X_2 B_2 D_2 R_1 Op Code</td>
</tr>
<tr>
<td>0</td>
<td>8 12 16 20 32 36 40 47</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAE</td>
<td>'ED2E'</td>
<td>Short HFP</td>
</tr>
<tr>
<td>MAD</td>
<td>'ED3E'</td>
<td>Long HFP</td>
</tr>
</tbody>
</table>

The third operand is multiplied by the second operand, and then the first operand is added to or subtracted from the product. The sum or difference is placed at the first-operand location. The MULTIPLY AND ADD and MULTIPLY AND SUBTRACT operations may be summarized as:

\[ \text{op}_1 = \text{op}_3 \pm \text{op}_2 \]

The third and second HFP operands are multiplied, forming an intermediate product, and the first operand is then added (or subtracted) algebraically to (or from) the intermediate product, forming an intermediate result. The exponent and fraction of the intermediate product and intermediate result are maintained exactly. The intermediate result, if nonzero, is normalized and truncated to the operand format and then placed at the first-operand location.

The sign of the result is determined by the rules of algebra, unless the intermediate-result fraction is zero, in which case the result is made a positive true zero.

An HFP-exponent-overflow exception exists when the characteristic of the normalized result would exceed 127 and the fraction is not zero. The operation is completed by making the result characteristic 128 less than the correct value, and a program interruption for HFP exponent overflow occurs. The result is normalized, and the sign and fraction remain correct.

HFP exponent overflow is not recognized on intermediate values, provided the normalized result can be represented with the correct characteristic.
An HFP-exponent-underflow exception exists when the characteristic of the normalized result would be less than zero and the fraction is not zero. If the HFP-exponent-underflow mask bit in the PSW is one, the operation is completed by making the result characteristic 128 greater than the correct value, and a program interruption for HFP exponent underflow occurs. The result is normalized, and the sign and fraction remain correct. If the HFP-exponent-underflow mask bit in the PSW is zero, a program interruption does not occur; instead, the operation is completed by making the result a positive true zero.

HFP exponent underflow is not recognized on input operands and intermediate values, provided the normalized result can be represented with the correct characteristic.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of MAE, MAD, MSE, MSD)
- Data with DXC 1, AFP register
- HFP exponent overflow
- HFP exponent underflow
- Operation (if the HFP multiply-add/subtract facility is not installed)
- Transaction constraint

**Programming Note:** MULTIPLY AND ADD (SUBTRACT) differs from MULTIPLY followed by ADD (SUBTRACT) NORMALIZED in the following ways:

1. The product is maintained to full precision, and overflow and underflow are not recognized on the product.

2. The HFP-significance exception is not recognized for MULTIPLY AND ADD (SUBTRACT).

3. ADD (SUBTRACT) NORMALIZED maintains only a single guard digit and does not prenormalize input operands; thus, in some cases, an unnormalized input operand may cause loss of precision in the result. MULTIPLY AND ADD (SUBTRACT) maintains the entire intermediate sum (difference), which is normalized before the truncation operation is performed; thus, unnormalized operands do not cause any additional loss of precision.

4. On most models, the execution time of MULTIPLY AND ADD (SUBTRACT) is less than the combined execution time of MULTIPLY followed by ADD (SUBTRACT) NORMALIZED. The performance of MULTIPLY AND ADD (SUBTRACT) may be severely degraded in the case of unnormalized input operands.

### MULTIPLY AND ADD UNNORMALIZED

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1, R3, R2</td>
<td>[RRD]</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R3</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>20</td>
<td>24</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAYR 'B33A'</td>
<td>Long HFP sources, extended HFP result</td>
<td></td>
</tr>
<tr>
<td>MAYHR 'B33C'</td>
<td>Long HFP sources, high-order part of extended HFP result</td>
<td></td>
</tr>
<tr>
<td>MAYLR 'B338'</td>
<td>Long HFP sources, low-order part of extended HFP result</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1, R3, D2(X2, B2)</td>
<td>[RXF]</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
<th>R3</th>
<th>R4</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>24</td>
<td>28</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAY 'ED3A'</td>
<td>Long HFP sources, extended HFP result</td>
<td></td>
</tr>
<tr>
<td>MAYH 'ED3C'</td>
<td>Long HFP sources, high-order part of extended HFP result</td>
<td></td>
</tr>
<tr>
<td>MAYL 'ED38'</td>
<td>Long HFP sources, low-order part of extended HFP result</td>
<td></td>
</tr>
</tbody>
</table>

The second and third HFP operands are multiplied, forming an intermediate product; the first operand (addend) is then added algebraically to the intermediate product to form an intermediate sum; the intermediate-sum fraction is truncated on the left or on the right, if need be, to form an intermediate extended result. All (or a part) of the intermediate extended result is placed in the floating-point-register pair (or floating-point register) designated by the R1 field. The operands, intermediate values, and results are not normalized to eliminate leading hexadecimal zeros.

The MULTIPLY AND ADD UNNORMALIZED operations may be summarized as:

\[ t_1 \leftarrow op_2 \cdot op_3 + op_1 \]

Multiplication of two HFP numbers consists in exponent addition and fraction multiplication. The sum of the characteristics of the second and third operands, less 64, is used as the characteristic of the high-
order part of the intermediate product; this value is independent of whether the result fraction is zero. The characteristic of the intermediate product is maintained correctly and does not wrap.

In all cases, the second- and third-operand fractions have 14 digits; the intermediate-product fraction contains 28 digits and is an exact product of the operand fractions. The intermediate-product fraction is not inspected for leading hexadecimal zero digits and is used without shifting in the subsequent addition.

In all cases, the first operand is located in the floating-point register designated by the R₁ field and the first-operand fraction has 14 digits.

Addition of two HFP numbers consists in characteristic comparison, fraction alignment, and signed fraction addition. The characteristics of the intermediate product and the addend are compared. If the characteristics are equal, no alignment is required. If the characteristic of the addend is smaller than the characteristic of the product, the fraction of the addend is aligned with the product fraction by a right shift, with its characteristic increased by one for each hexadecimal digit of shift. If the characteristic of the addend is larger than the characteristic of the product, the fraction of the addend is aligned with the product fraction by a left shift, with its characteristic decreased by one for each hexadecimal digit of shift. Shifting continues until the two characteristics agree. All hexadecimal digits shifted out are preserved and participate in the subsequent addition.

After alignment, the fractions with signs are then added algebraically to form a signed intermediate sum. The fraction of the intermediate sum is maintained exactly. The intermediate-sum fraction is not inspected for leading hexadecimal zero digits and is not shifted. Only those 28 hexadecimal digits of the intermediate-sum fraction which are aligned with the 28 hexadecimal digits of the intermediate-product fraction are used as the fraction of the intermediate extended-result.

The high-order characteristic of the intermediate extended result is set to the characteristic of the intermediate product, modulo 128. The low-order characteristic of the intermediate extended result is set to 14 less than the high-order characteristic, modulo 128. Wrap-around of the characteristic is independent of whether the result fraction is zero.

The sign of the result is determined by the rules of algebra, unless the entire intermediate-sum fraction is zero, in which case the sign of the result is made positive.

For MAY and MAYR, the entire intermediate extended result is placed in the floating-point register-pair designated by the R₁ field; the R₁ field may designate either the lower-numbered or higher-numbered register of a floating-point-register pair. For MAYH and MAYHR, the high-order part of the intermediate extended result is placed in the floating-point register designated by the R₁ field and the low-order part is discarded. For MAYL and MAYLR, the low-order part of the intermediate extended result is placed in the floating-point register designated by the R₁ field and the high-order part is discarded.

HFP-exponent-overflow and HFP-exponent-underflow exceptions are not recognized. Characteristics of the intermediate extended result wrap-around modulo 128 and no exception is reported.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of MAYH, MAY, and MAYL only)
- Data with DXC 1, AFP register
- Operation (if the HFP-unnormalized-extensions facility is not installed)
- Transaction constraint

**Programming Notes:**

1. While performance of MULTIPLY AND ADD may be severely degraded for the case of unnormalized input operands, this is not the case for MULTIPLY AND ADD UNNORMALIZED.

2. MULTIPLY AND ADD UNNORMALIZED can be used to efficiently perform multiple precision arithmetic on numbers of any arbitrary size. This is accomplished by organizing the numbers into big digits of 52 bits each, with each big digit maintained as an integer in the HFP long format. Using a radix of $2^{52}$ and big digits which can hold up to 56 bits provides a redundant representation. This redundant representation permits multiplication and addition using a “carry save” technique and permits maximum utilization of the floating-point pipeline.
3. By setting the multiplier to an integer value of 1 with the proper characteristic, the multiplicand can be scaled by any power of 16 and then added to the addend. This permits, for example, adding the “carry” from one stage of a multiplication to the “sum” of the next stage to the left. In the same manner, the “sum” of one stage can be scaled to be added to the “carry” of the stage to the right.

4. In the first round of a multiply and accumulate, the step of clearing the accumulated value to zero, may be avoided by using the MULTIPLY UNNORMALIZED instead of MULTIPLY AND ADD UNNORMALIZED.

5. For additional notes concerning the unnormalized operations see the programming notes under the MULTIPLY UNNORMALIZED instruction.

MULTIPLY UNNORMALIZED

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>R1, R3, R2 [RRD]</th>
<th>Op Code</th>
<th>R1</th>
<th>R3</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>MYR</td>
<td>'B33B'</td>
<td>Long HFP multiplier and multiplicand, extended HFP product</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MYHR</td>
<td>'B33D'</td>
<td>Long HFP multiplier and multiplicand, high-order part of extended HFP product</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MYLR</td>
<td>'B339'</td>
<td>Long HFP multiplier and multiplicand, low-order part of extended HFP product</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2</th>
<th>R1, X2, B2, D2 [RXF]</th>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>MY</td>
<td>'ED3B'</td>
<td>Long HFP multiplier and multiplicand, extended HFP product</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MYH</td>
<td>'ED3D'</td>
<td>Long HFP multiplier and multiplicand, high-order part of extended HFP product</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MYL</td>
<td>'ED39'</td>
<td>Long HFP multiplier and multiplicand, low-order part of extended HFP product</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The second and third HFP operands are multiplied, forming an intermediate product, which, in turn, is used to form an intermediate extended result. All (or a part) of the intermediate extended result is placed in the floating-point-register pair (or floating-point register) designated by the R1 field. The operands, intermediate values, and results are not normalized to eliminate leading hexadecimal zeros.

Multiplication of two HFP numbers consists in exponent addition and fraction multiplication. The sum of the characteristics of the second and third operands, less 64, is used as the characteristic of the high-order part of the intermediate product; this value is independent of whether the result fraction is zero. The characteristic of the intermediate product is maintained correctly and does not wrap.

The high-order characteristic of the intermediate extended result is set to the characteristic of the intermediate product, modulo 128. The low-order characteristic of the intermediate extended result is set to 14 less than the high-order characteristic, modulo 128. Wrap-around of the characteristic is independent of whether the result fraction is zero.

In all cases, the second- and third-operand fractions have 14 digits; the intermediate-product fraction contains 28 digits and is an exact product of the operand fractions. The intermediate-product fraction is not inspected for leading hexadecimal zero digits and is used without shifting as the fraction of the intermediate extended result.

The sign of the result is the exclusive or of the operand signs, including the case when the result fraction is zero.

For MY and MYR, the entire intermediate extended result is placed in the floating-point-register pair designated by the R1 field. For MYH and MYHR, the high-order part of the intermediate extended result is placed in the floating-point register designated by the R1 field and the low-order part is discarded. For MYL and MYLR, the low-order part of the intermediate extended result is placed in the floating-point register designated by the R1 field and the high-order part is discarded.

HFP-exponent-overflow and HFP-exponent-underflow exceptions are not recognized. Characteristics of the intermediate extended result wrap-around modulo 128 and no exception is reported.

The R1 field for MY and MYR must designate a valid floating-point-register pair. Otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.
Program Exceptions:

- Access (fetch, operand 2 of MYH, MY, and MYL only)
- Data with DXC 1, AFP register
- Operation (if the HFP-unnormalized-extensions facility is not installed)
- Specification (MY and MYR)
- Transaction constraint

Programming Notes:

1. The formal definition of Long HFP numbers is in terms of a 14-digit fraction and a signed exponent in "excess-64 notation". But, without change in function, these numbers can also be described as having a 14-digit integer and a signed exponent in “excess-78 notation”. When using the unnormalized instructions, the programmer may find it more convenient to consider these values in the later terms rather than the former. Thus, in these terms, MULTIPLY UNNORMALIZED multiplies two 14-digit integers to produce a 28-digit integer result. The characteristic of the low-order part is the sum of the operand characteristics less 78 and the high-order characteristic is set 14 larger than the low-order part. When considered as described above, MULTIPLY UNNORMALIZED provides the exact 28-digit integer product of two 14-digit integers.

2. Rather than using MY (or MYR) to provide the entire 28-digits in a floating-point-register pair, the programmer may find it more convenient to issue two separate instructions, MYH and MYL (or MYHR and MYLR), to place the high-order part and low-order part in any floating-point register. It is expected that on most machines, the performance of these two approaches is essentially the same.

3. The MULTIPLY UNNORMALIZED instruction format designates three operand locations and can be used to produce a product without overlaying the source operands. In many cases this saves an extra load.

### SQUARE ROOT

**Mnemonic1**

\[
\text{R}_1, \text{R}_2 \quad \text{[RRE]}
\]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

**Mnemonic2**

\[
\text{R}_1, \text{D}_2(\text{X}_2, \text{B}_2) \quad \text{[RXE]}
\]

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
</tr>
</tbody>
</table>

**Op Code**

\[
\begin{array}{cccccc}
0 & 8 & 12 & 16 & 20 & 32 \\
0 & 12 & 16 & 20 & 32 & 40 \\
0 & 16 & 20 & 24 & 28 & 31 \\
0 & 20 & 24 & 28 & 32 & 40 \\
0 & 24 & 28 & 32 & 36 & 40 \\
0 & 28 & 32 & 36 & 40 & 47 \\
\end{array}
\]

- SQER 'B245' Short HFP
- SQDR 'B244' Long HFP
- SQXR 'B336' Extended HFP
- SOE 'ED34' Short HFP
- SQD 'ED35' Long HFP

The normalized and rounded square root of the second operand is placed at the first-operand location.

When the fraction of the second operand is zero, the sign and characteristic of the second operand are ignored, and the operation is completed by placing a positive true zero at the first-operand location.

If the second operand is less than zero, an HFP-square-root exception is recognized.

If the second operand is normalized and greater than zero, the characteristic, fraction, and sign of the result are produced as follows:

- The result characteristic is one-half of the sum of the operand characteristic and either 64, if the operand characteristic is even, or 65, if it is odd.
- If the operand characteristic is odd, the operand fraction is shifted right one digit position, the rightmost digit entering the guard-digit position.
- An intermediate-result fraction is produced by computing without rounding the square root of the operand fraction, after any right shift as described. The intermediate-result fraction consists of the 29 most significant hexadecimal digits of the square-root result in the extended format, 15 in the long format, or seven in the short format, where all three formats include a guard digit on the right.
- A one is added to the leftmost bit of the guard digit of the intermediate result, any carry is prop-
agated to the left, and the guard digit is dropped to produce the result fraction.

- The result sign is made plus.

If the second operand is unnormalized and greater than zero, the operand is first normalized. The operation then proceeds as for normalized operands.

For SQXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2 of SQE and SQD only)
- Data with DXC 1, AFP register
- HFP square root
- Specification (SQXR only)
- Transaction constraint

**Programming Notes:**

1. The use of the SQUARE ROOT instruction with short operands (SQER) is illustrated by the examples in the following table:

<table>
<thead>
<tr>
<th>Operand (hex)</th>
<th>Decimal Value</th>
<th>Result (hex)</th>
<th>Decimal Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>42 190000</td>
<td>25.0</td>
<td>41 500000</td>
<td>5.0</td>
</tr>
<tr>
<td>40 400000</td>
<td>0.250</td>
<td>40 800000</td>
<td>0.50</td>
</tr>
<tr>
<td>40 800000</td>
<td>0.50</td>
<td>40 B504F3</td>
<td>0.7071...</td>
</tr>
<tr>
<td>41 800000</td>
<td>8.0</td>
<td>41 2D413D</td>
<td>2.8284...</td>
</tr>
</tbody>
</table>

2. The result fraction is correctly normalized without any further left or right shifts of the intermediate-result fraction and without any further exponent adjustment. Rounding cannot cause a carry out of the leftmost digit.

3. Although a characteristic greater than 127 or less than zero may temporarily be generated during the operation, the result characteristic is always within the representable range, and no HFP exponent overflow or underflow occurs.

Specifically, the smallest nonzero operand in the long format consists of a one bit, preceded on the left by 63 zeros. This operand is an unnormalized number with a value of $16^{-78}$, and its square root is $16^{-39}$. The normalized representation of this result has a characteristic of 26 (decimal). Similarly, the square root of the largest representable operand has a characteristic of 96 (decimal). The instruction, therefore, cannot produce a nonzero result with a characteristic outside the range of 26 to 96.

### Subtract Normalized

**Mnemonic1**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
</table>

**Mnemonic2**

| Op Code | R1 | X2 | B2 | D2 |

The second operand is subtracted from the first operand, and the normalized difference is placed at the first-operand location.

The execution of SUBTRACT NORMALIZED is identical to that of ADD NORMALIZED, except that the second operand participates in the operation with its sign bit inverted.

For SXR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

| 0  | Result is zero |
| 1  | Result is less than zero |
| 2  | Result is greater than zero |
| 3  | -- |

**Program Exceptions:**

- Access (fetch, operand 2 of SE and SD only)
- Data with DXC 1, AFP register
- HFP exponent overflow
- HFP exponent underflow
- HFP significance
- Specification (SXR only)
- Transaction constraint
SUBTRACT UNNORMALIZED

Mnemonic1  R1,R2  [RR]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

Mnemonic2  R1,D2(X2,B2)  [RX-a]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>

The second operand is subtracted from the first operand, and the unnormalized difference is placed at the first-operand location.

The execution of SUBTRACT UNNORMALIZED is identical to that of ADD UNNORMALIZED, except that the second operand participates in the operation with its sign bit inverted.

**Resulting Condition Code:**

0  Result fraction zero
1  Result less than zero
2  Result greater than zero
3  --

**Program Exceptions:**

- Access (fetch, operand 2 of SU and SW only)
- Data with DXC 1, AFP register
- HFP exponent overflow
- HFP significance
- Transaction constraint
Chapter 19. Binary-Floating-Point Instructions

Binary-Floating-Point Facility ................. 19-1
Floating-Point-Control (FPC) Register ........ 19-2
BFP Arithmetic .................................. 19-2
BFP Data Formats ............................... 19-2
  BFP Short Format .................. 19-2
  BFP Long Format ................. 19-2
  BFP Extended Format ............ 19-2
Biased Exponent ............................... 19-2
Significand .................................... 19-3
Values of Nonzero Numbers ................. 19-3
Classes of BFP Data ......................... 19-4
  Zeros ....................................... 19-4
  Subnormal Numbers ................. 19-4
  Normal Numbers ..................... 19-4
Infinities ...................................... 19-4
Signaling and Quiet NaNs ................. 19-4
BFP-Format Conversion ....................... 19-5
BFP Rounding ................................. 19-5
BFP Comparison ............................... 19-5
Remainder .................................... 19-5
IEEE Exceptions .............................. 19-7
Summary of Rounding And Range Actions ... 19-8
Result Figures ................................. 19-9
  Data-Exception Codes (DXC) and  
  Abbreviations ............................. 19-10
  Instructions ............................... 19-11
    ADD ..................................... 19-15
    COMPARE ................................ 19-17
    COMPARE AND SIGNAL .............. 19-18
    CONVERT FROM FIXED ............ 19-19
    CONVERT FROM LOGICAL .......... 19-21
    CONVERT TO FIXED .................. 19-22
    CONVERT TO LOGICAL .............. 19-25
    DIVIDE .................................. 19-27
    DIVIDE TO INTEGER ............... 19-28
    LOAD AND TEST ....................... 19-31
    LOAD COMPLEMENT .................... 19-31
    LOAD FP INTEGER ..................... 19-32
    LOAD LENGTHENED .................... 19-33
    LOAD NEGATIVE ....................... 19-34
    LOAD POSITIVE ....................... 19-35
    LOAD ROUNDED ......................... 19-35
    MULTIPLY ............................... 19-37
    MULTIPLY AND ADD ................. 19-38
    MULTIPLY AND SUBTRACT .......... 19-38
    SQUARE ROOT ......................... 19-40
    SUBTRACT ............................... 19-40
    TEST DATA CLASS ..................... 19-41

Binary-Floating-Point Facility

The binary-floating-point (BFP) facility provides instructions to operate on binary (radix-2) floating-point data.

BFP provides a number of important advantages over hexadecimal floating point (HFP):

- Greater precision and exponent range (except for numbers in the short format where HFP has the greater range).
- Automatic rounding to the nearest value for all arithmetic operations. There are directed-rounding options that may be used instead.
- Special entities of “infinity” and “Not-a-Number” (NaN), which are accepted and handled by arithmetic operations in a reasonable fashion. They provide better defaults for exponent overflow and invalid operations (such as division of zero by zero). This allows most programs to continue running without hiding such errors and without using specialized exception handlers.
- Exponent underflow gives “subnormal” numbers as the default, which provides more consistent results than the abrupt result of zero produced by the HFP instructions.
- The greater exponent range makes exponent overflow and underflow in correctly written programs very unlikely, so that programmers may often be able to ignore these conditions.
- Both mask and flag bits are provided for all IEEE exceptions. The mask bits enable or disable interruptions. When interruptions are disabled, the flag bits keep track of exceptions during execution so that warning messages may be issued.
- Programs can be migrated from and to workstations and other systems using different architectures and still give consistent results, provided that floating-point operations on the other sys-
tems also conform to ANSI/IEEE Standard 754-2008 (see Reference [17.] on page xxviii). This does not mean, however, that bit-wise compatible results can be guaranteed, because the standard allows implementation flexibility, especially in the presence of exceptions.

Programming Note: The bit representation of the BFP data formats in storage is defined to be left-to-right in a manner that is uniform for all numeric operands in the z/Architecture architecture. Although the format diagrams in ANSI/IEEE Standard 754-2008 appear to use the same left-to-right bit sequence, the standard only defines the meaning of the bits without specifying how they appear in storage; the storage arrangement is left to the implementation. Several implementations in fact use other sequences; this may affect programs which are dependent on the bit representation of floating-point data in storage.

Floating-Point-Control (FPC) Register

The floating-point-control (FPC) register is a 32-bit register that contains mask bits, flag bits, a data-exception code, and two rounding-mode fields. The FPC register is described in the section “Floating-Point-Control (FPC) Register” on page 9-9. An overview of the FPC register is shown in Figure 9-5 on page 9-9. Details are shown in Figure 9-6 on page 9-9, Figure 9-7 on page 9-10, and in Figure 9-8 on page 9-10. (In Figure 9-6 on page 9-9, the abbreviations “IM” and “SF” are based on the terms “inter-ruption mask” and “status flag,” respectively.)

The bits of the FPC register are often referred to as, for example, FPC 1.0, meaning bit 0 of byte 1 of the register.

BFP Arithmetic

BFP Data Formats

Binary-floating-point data may be represented in any of three formats: short, long, or extended.

<table>
<thead>
<tr>
<th>BFP Short Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>S Exponent+127</td>
</tr>
<tr>
<td>Fraction (23 bits)</td>
</tr>
<tr>
<td>0 1</td>
</tr>
<tr>
<td>9 31</td>
</tr>
</tbody>
</table>

Figure 19-1. BFP Short Format (4 bytes)

When an operand in the BFP short format is loaded into a floating-point register, it occupies the left half of the register, and the right half remains unchanged.

<table>
<thead>
<tr>
<th>BFP Long Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>S Exponent + 1023</td>
</tr>
<tr>
<td>Fraction (52 bits)</td>
</tr>
<tr>
<td>0 1</td>
</tr>
<tr>
<td>12 31</td>
</tr>
</tbody>
</table>

Figure 19-2. BFP Long Format (8 bytes)

When an operand in the BFP long format is loaded into a floating-point register, it occupies the entire register.

<table>
<thead>
<tr>
<th>BFP Extended Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>S Exponent + 16383</td>
</tr>
<tr>
<td>Fraction (112 bits)</td>
</tr>
<tr>
<td>0 1</td>
</tr>
<tr>
<td>16 31</td>
</tr>
</tbody>
</table>

Figure 19-3. BFP Extended Format (16 bytes)

An operand in the BFP extended format occupies a register pair. The sign and biased exponent are in the leftmost 16 bits of the lower-numbered register of the pair and are followed by the leftmost 48 bits of the fraction. The rightmost 64 bits of the fraction are in the higher-numbered register of the pair.

The properties of the three formats are tabulated in Figure 19-4 on page 19-3.

Biased Exponent

For each format, the bias that is used to allow all exponents to be expressed as unsigned numbers is shown in the Figure 19-4 on page 19-3. Biased exponents are similar to the characteristics of the HFP format, except that special meanings are attached to
biased exponents of all zeros and all ones, which are discussed in the section “Classes of BFP Data” on page 19-4.

**Significand**

In each format, the binary point of a BFP number is considered to be to the left of the leftmost fraction bit. To the left of the binary point there is an implied unit bit, which is considered to be one for normal numbers and zero for zeros and subnormal numbers. The fraction with the implied unit bit appended on the left is the significand of the number.

The value of a normal BFP number is the significand multiplied by the radix 2 raised to the power of the unbiased exponent. The value of a subnormal BFP number is the significand multiplied by the radix 2 raised to the power of the minimum exponent.

A value of one in the rightmost bit position of the significand in each format is sometimes referred to as one ulp (unit in the last place).

**Values of Nonzero Numbers**

The values of nonzero numbers in the various formats are shown in Figure 19-5.

---

<table>
<thead>
<tr>
<th>Property</th>
<th>Format</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Format length (bits)</td>
<td>Short</td>
<td>32</td>
</tr>
<tr>
<td>Biased-exponent length (bits)</td>
<td></td>
<td>8</td>
</tr>
<tr>
<td>Fraction length (bits)</td>
<td></td>
<td>23</td>
</tr>
<tr>
<td>Precision (p)</td>
<td></td>
<td>24</td>
</tr>
<tr>
<td>Maximum left-units-view (LUV) exponent (Emax)</td>
<td></td>
<td>127</td>
</tr>
<tr>
<td>Minimum left-units-view (LUV) exponent (Emin)</td>
<td></td>
<td>-126</td>
</tr>
<tr>
<td>Left-units-view (LUV) bias</td>
<td></td>
<td>127</td>
</tr>
<tr>
<td>Nmax</td>
<td></td>
<td>$3.4 \times 10^{38}$</td>
</tr>
<tr>
<td>Nmin</td>
<td></td>
<td>$1.2 \times 10^{-38}$</td>
</tr>
<tr>
<td>Dmin</td>
<td></td>
<td>$1.4 \times 10^{-45}$</td>
</tr>
</tbody>
</table>

**Explanation:**

- Value is approximate.
- Dmin Smallest (in magnitude) representable subnormal number.
- Nmax Largest (in magnitude) representable finite number.
- Nmin Smallest (in magnitude) representable normal number.

Figure 19-4. Summary of BFP Data Formats

Figure 19-5. Values of Nonzero Numbers

<table>
<thead>
<tr>
<th>Number Class</th>
<th>Format</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Normal</td>
<td>Short</td>
<td>$±2^{32} \times (1.f)$</td>
</tr>
<tr>
<td></td>
<td>Long</td>
<td>$±2^{64} \times (1.f)$</td>
</tr>
<tr>
<td></td>
<td>Extended</td>
<td>$±2^{128} \times (1.f)$</td>
</tr>
<tr>
<td>Subnormal</td>
<td>Short</td>
<td>$±2^{12} \times (0.f)$</td>
</tr>
<tr>
<td></td>
<td>Long</td>
<td>$±2^{128} \times (0.f)$</td>
</tr>
<tr>
<td></td>
<td>Extended</td>
<td>$±2^{128} \times (0.f)$</td>
</tr>
</tbody>
</table>

**Explanation:**

- e Biased exponent (shown in decimal).
- f Fraction (in binary).

Programming Note: ANSI/IEEE Standard 754-2008 specifies minimum requirements for the extended format but does not include details. The BFP extended format meets these requirements, far exceeding them in the area of precision.
Classes of BFP Data

There are six classes of BFP data, which include numeric and related nonnumeric entities. Each data item consists of a sign, an exponent, and a significand. The exponent is biased such that all biased exponents are nonnegative unsigned numbers and the minimum biased exponent is zero. The significand consists of an explicit fraction and an implicit unit bit to the left of the binary point. The sign bit is zero for plus and one for minus.

All nonzero finite numbers permitted by a given format have a unique BFP representation. There are no unnormalized numbers, which numbers might allow multiple representations for the same values, and there are no unnormalized arithmetic operations. Tiny numbers of a magnitude below the minimum normal number in a given format are represented as subnormal numbers, but those values are also represented uniquely. The implied unit bit of a normal number is one, and that of a subnormal number or a zero is zero.

The six classes of BFP data are summarized in Figure 19-6 on page 19-4.

### Zeros
Zeros have a biased exponent of zero and a zero fraction. The implied unit bit is zero. A +0 is distinct from -0, except that comparison treats them as equal.

### Subnormal Numbers
Subnormal numbers are numbers which are smaller than the smallest normal number and greater than zero in magnitude. They have a biased exponent of zero and a nonzero fraction. The biased exponent is treated arithmetically as if it were one, which causes the exponent to be the minimum exponent. The implied unit bit is zero. (In ANSI/IEEE Standard 754-2008, subnormal numbers were called “denormalized numbers”.)

### Normal Numbers
Normal numbers have a biased exponent greater than zero but less than all ones. The implied unit bit is one, and the fraction may have any value. (In some early documentation, normal numbers were called “normalized numbers”.)

### Infinities
An infinity is represented by a biased exponent of all ones and a zero fraction. Infinities can participate in most arithmetic operations and give a consistent result, usually infinity. In comparisons, +∞ compares greater than any finite number, and -∞ compares less than any finite number.

### Signaling and Quiet NaNs
A NaN (not-a-number) entity is represented by a biased exponent of all ones and a nonzero fraction. NaNs are produced in place of a numeric result after an invalid operation when there is no interruption. NaNs may also be used by the program to flag special operands, such as the contents of an uninitialized storage area.

There are two types of NaNs, signaling and quiet. A signaling NaN (SNaN) is distinguished from the corresponding quiet NaN (QNaN) by the leftmost fraction bit: zero for the SNaN and one for the QNaN. A special QNaN is supplied as the default result for an IEEE-invalid-operation exception; it has a plus sign and a leftmost fraction bit of one, with the remaining fraction bits being set to zeros.

Normally, QNaNs are just propagated during computations so that they will remain visible at the end. An

### Data Class

<table>
<thead>
<tr>
<th>Data Class</th>
<th>Sign</th>
<th>Biased Exponent</th>
<th>Unit Bit*</th>
<th>Fraction</th>
</tr>
</thead>
<tbody>
<tr>
<td>Zero</td>
<td>±</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Subnormal numbers</td>
<td>±  ** 0**</td>
<td>0</td>
<td>Not 0</td>
<td></td>
</tr>
<tr>
<td>Normal numbers</td>
<td>±</td>
<td>Not 0, not all ones</td>
<td>1</td>
<td>Any</td>
</tr>
<tr>
<td>Infinity</td>
<td>±</td>
<td>All ones</td>
<td>—</td>
<td>0</td>
</tr>
<tr>
<td>Quiet NaN</td>
<td>±</td>
<td>All ones</td>
<td>—</td>
<td>F0=0, Fr=any</td>
</tr>
</tbody>
</table>
| Signaling NaN   | ±    | All ones        | —         | F0=0, Fr

**Explanation:**

- Does not apply.
- The unit bit is implied.
- The biased exponent is treated arithmetically as if it had the value one.
- F0 Leftmost bit of fraction.
- Fr Remaining bits of fraction.
- NaN Not-a-number.

Figure 19-6. Classes of BFP Data

The instruction TEST DATA CLASS may be used to determine the class of a BFP operand.
SNaN operand causes an IEEE-invalid-operation exception. If the IEEE-invalid-operation mask (FPC 0.0) is zero, the result is the corresponding QNaN, which is produced by setting the leftmost fraction bit to one, and the IEEE-invalid-operation flag (FPC 1.0) is set to one. If the IEEE-invalid-operation mask (FPC 0.0) is one, the operation is suppressed, and a data exception for IEEE-invalid operation occurs.

**Programming Notes:**

1. The program can generate and assign meanings to any nonzero fraction values of a NaN. The CPU propagates those values unchanged, except that an SNaN is changed to the corresponding QNaN if the IEEE-invalid-operation mask bit is zero, and conversion to a narrower format may truncate significant bits on the right.

2. ANSI/IEEE Standard 754-2008 requires SNaNs to signal the invalid-operation exception for the arithmetic, comparison, and conversion operations that are part of the standard, but it makes it an implementation option whether copying an SNaN without a change of format signals the exception. In the appendix, the standard also makes it an implementation option whether SNaNs should signal the invalid-operation exception for the recommended functions of copying the sign, reversing the sign, and testing the data class of a datum.

The above functions generally correspond to the instructions LOAD, LOAD COMPLEMENT, LOAD NEGATIVE, LOAD POSITIVE, and TEST DATA CLASS. These instructions do not signal the invalid-operation exception but, instead, treat SNaNs like any other data; giving an exception would be disruptive when the intention is to include SNaNs. TEST DATA CLASS does not give an exception since it is the instruction with which to test for the presence of SNaNs.

3. LOAD AND TEST signals the invalid-operation exception when the operand is an SNaN. This instruction, in conjunction with the above instructions, gives the program the choice of either option permitted by ANSI/IEEE Standard 754-2008.

4. Load-type instructions which change the precision signal the invalid-operation exception when the operand is an SNaN, as this is required by ANSI/IEEE Standard 754-2008.

---

**BFP-Format Conversion**

BFP format conversion is described in the section “IEEE Same-Radix Format Conversion” on page 9-23.

**BFP Rounding**

BFP rounding is described in the section “IEEE Rounding” on page 9-13.

**BFP Comparison**

BFP comparison is described in the section “IEEE Comparison” on page 9-24.

**Remainder**

The instruction DIVIDE TO INTEGER produces two floating-point results, an exact integer quotient and the corresponding remainder. The remainder is defined as follows:

Let

\[ a = \text{Dividend} \]
\[ b = \text{Divisor} \]
\[ q = \text{Exact quotient} (a \div b) \]
\[ r = \text{Remainder} \]

in the selected floating-point format. Then

\[ r = a - b \cdot n \]

where \( n \) is an integer. If \( q \) is an integer, then \( n \) equals \( q \). Otherwise, \( n \) is obtained by rounding \( q \) according to a final-quotient-rounding method.

When the final-quotient-rounding method is round to nearest with ties to even or round toward zero, the remainder is exact for any finite dividend and any nonzero divisor. The remainder cannot overflow.

If the integer quotient has a value that lies outside the range of the operand format, a scaled result is provided.

In certain cases where the number of bits in the integer quotient exceeds or may exceed the maximum number of bits provided in the precision of the operand format, partial results are produced, and more
than one execution of the instruction is required to obtain the final result; this may be done with a simple instruction loop.

Partial results are produced when the precise quotient is not an integer and the two integers closest to this precise quotient cannot both be represented exactly in the precision of the quotient. This situation exists when the precise quotient is greater than $2^P$, where $P$ is the precision of the operand format, and the remainder is not zero. When the remainder is zero, then the quotient is an integer, and the number of bits required to represent the quotient is never more than the precision of the target.

**Programming Note:** The remainder result of DIVIDE TO INTEGER with a final-quotient-rounding method of round to nearest with ties to even corresponds to the `Remainder` function in ANSI/IEEE Standard 754-2008. This function is similar to the `MOD` function found in some languages and to the mathematical `modulo` function, but they are not the same. They differ in the definition of $n$:

- **Remainder** $n$ is $q$ rounded to nearest with ties to even.
- **modulo** $n$ is $q$ rounded toward $-\infty$.
- **MOD** $n$ is $q$ rounded toward 0.

Another important difference is that implementations of modulo and MOD may put range restrictions on the result because they may simply use the DIVIDE instruction and accept its range restrictions.

The MOD definition provides an exact result, as does Remainder, but the modulo definition may result in rounding errors.

The differences between the various methods may be illustrated by the simple example of computing $a$ divided by $b$ to obtain an integer quotient $n$, where $a$ is a series of integers, and $b$ is +4 or -4. Figure 19-7 shows the results for the three definitions.

<table>
<thead>
<tr>
<th>a</th>
<th>Remainder</th>
<th>MOD</th>
<th>modulo</th>
</tr>
</thead>
<tbody>
<tr>
<td>-8 -7 -6 -5 -4 -3 -2 -1 -0 +0 +1 +2 +3 +4 +5 +6 +7 +8</td>
<td>b=+4: n</td>
<td>b=+4: n</td>
<td>b=+4: n</td>
</tr>
<tr>
<td>-2 -2 -2 -1 -1 -1 -1 -0 -0 -0 +0 +0 +0 +1 +1 +1 +2 +2</td>
<td>r</td>
<td>r</td>
<td>r</td>
</tr>
<tr>
<td>-0 +1 +2 -1 -0 1 2 -1 -0 +0 +1 +2 -1 +0 +1 -2 +1 +0</td>
<td>r</td>
<td>r</td>
<td>r</td>
</tr>
<tr>
<td>b=-4: n</td>
<td>b=-4: n</td>
<td>b=-4: n</td>
<td>b=-4: n</td>
</tr>
<tr>
<td>+2 +2 +2 +1 +1 +1 +0 +0 +0 -0 -0 -1 -1 -1 -2 -2 -2</td>
<td>r</td>
<td>r</td>
<td>r</td>
</tr>
<tr>
<td>-0 +1 +2 -1 -0 +1 -2 -1 -0 +0 +1 -2 +1 +0 +1 -2 +1 +0</td>
<td>r</td>
<td>r</td>
<td>r</td>
</tr>
</tbody>
</table>

**Explanation:**
- $a$ Dividend.
- $b$ Divisor.
- $n$ Integer quotient.
- $r$ Result (Remainder, MOD, or modulo).

*Figure 19-7. Comparison of Remainder with MOD and Modulo*

The result of Remainder lies in the range of zero to one-half the divisor, inclusive, in magnitude. A zero result is defined to have the sign of the dividend. A zero divisor is invalid.
The modulo and MOD results can both be computed from the Remainder result; the reverse may not be true, because of rounding errors and, depending on the implementation, range restrictions.

An extreme example of the rounding error that can occur with the modulo definition is the following, where the result is restricted to two significant decimal digits:

\[
\text{modulo}(0.01,-95) = -94.99, \text{ which rounds to } -95 \\
\text{Remainder}(0.01,-95) = 0.01
\]

The properly rounded modulo result is completely wrong since it is equal to the divisor instead of being smaller in magnitude. The Remainder result is exact and can be used to compute the theoretical result of modulo.

Remainder is included as an arithmetic operation because of its usefulness in argument reduction when computing elementary transcendental functions. Thus, \( \text{SIN}(X) \) can be computed to full precision for any value of \( X \) in degrees by first reducing the argument to \( \text{Remainder}(X,360) \).

**IEEE Exceptions**

The IEEE exceptions for the BFP instructions are described in the section “IEEE Exceptions” on page 9-18.
## Summary of Rounding And Range Actions

Figure 19-8 summarizes the BFP rounding and range actions.

<table>
<thead>
<tr>
<th>Range of (v)</th>
<th>Case</th>
<th>Nontrap Result ((r)) when Effective Rounding Method Is</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>To Nearest with ties to even</td>
</tr>
<tr>
<td>(v &lt; -N_{max}), (g &lt; -N_{max})</td>
<td>Overflow</td>
<td>(-\infty^1)</td>
</tr>
<tr>
<td>(v &lt; -N_{max}), (g = -N_{max})</td>
<td>Normal</td>
<td>(-N_{max})</td>
</tr>
<tr>
<td>(-N_{max} \leq v \leq -N_{min})</td>
<td>Normal</td>
<td>(g)</td>
</tr>
<tr>
<td>(-N_{min} &lt; v \leq -D_{min})</td>
<td>Tiny</td>
<td>(d^*)</td>
</tr>
<tr>
<td>(-D_{min} &lt; v &lt; -D_{min}/2)</td>
<td>Tiny</td>
<td>(-D_{min})</td>
</tr>
<tr>
<td>(-D_{min}/2 \leq v &lt; 0)</td>
<td>Tiny</td>
<td>(-0)</td>
</tr>
<tr>
<td>(v = 0)</td>
<td>Exact zero difference(^2)</td>
<td>(+0)</td>
</tr>
<tr>
<td>(0 &lt; v \leq +D_{min}/2)</td>
<td>Tiny</td>
<td>(+0)</td>
</tr>
<tr>
<td>(+D_{min}/2 &lt; v &lt; +D_{min})</td>
<td>Tiny</td>
<td>(+D_{min})</td>
</tr>
<tr>
<td>(+D_{min} \leq v &lt; +N_{min})</td>
<td>Tiny</td>
<td>(d^*)</td>
</tr>
<tr>
<td>(+N_{min} \leq v \leq +N_{max})</td>
<td>Normal</td>
<td>(g)</td>
</tr>
<tr>
<td>(+N_{max} &lt; v, g = +N_{max})</td>
<td>Normal</td>
<td>(+N_{max})</td>
</tr>
<tr>
<td>(+N_{max} &lt; v, +N_{max} &lt; g)</td>
<td>Overflow</td>
<td>(+\infty^1)</td>
</tr>
</tbody>
</table>

**Explanation:**

1. This situation cannot occur.
2. The rounded value, in the extreme case, may be \(N_{min}\). In this case, the exceptions are underflow, inexact and incremented.
3. The nontrap result \(r\) is considered to have been incremented.
4. The exact-zero-difference case applies only to ADD, SUBTRACT, MULTIPLY AND ADD, and MULTIPLY AND SUBTRACT. For all other BFP operations, a zero result is detected by inspection of the source operands without use of the \(R(v)\) function.
5. The denormalized value. The value derived when the precise intermediate value (\(v\)) is rounded to the format of the target, including both precision and bounded exponent range. Except as explained in note \(^*\), this is a subnormal number.
6. The precision-rounded value. The value derived when the precise intermediate value (\(v\)) is rounded to the precision of the target, but assuming an unbounded exponent range.
7. Precise intermediate value. This is the value, before rounding, assuming unbounded precision and an unbounded exponent range. For LOAD ROUNDED, \(v\) is the source value (\(a\)).
8. Smallest (in magnitude) representable subnormal number in the target format.
9. Largest (in magnitude) representable finite number in the target format.
10. Smallest (in magnitude) representable normal number in the target format.

---

Figure 19-8. Action for \(R(v)\): Rounding and Range Function (Part 1 of 2)
Concise descriptions of the results produced by many of the BFP instructions are made by means of figures which contain columns and rows representing all possible combinations of BFP data class for the source operands of an instruction. The information shown at the intersection of a row and a column is one or more symbols representing the result or results produced for that particular combination of source-operand data classes. Explanations of the symbols used are contained in each figure. In many cases, the explanation of a particular result is in the form of a cross reference to another figure. In many cases, the information shown at the intersection consists of several symbols separated by commas. All such results are produced unless one of the results is a program interruption. In the case of a program interruption, the operation is suppressed or completed as shown in Figure 19-10 on page 19-11.

### Result Figures

| Case     | Is r Inexact (r|v|) | Overflow Mask (FPC 0.2) | Underflow Mask (FPC 0.3) | IEEE Inexact Exception Control (X|C|) | Inexact Mask (FPC 0.4) | Is r Incremented (I|>l|v|) | Is g Inexact (g|>l|v|) | Is g Incremented (I|>l|v|) | Results                        |
|----------|----------------|------------------------|--------------------------|--------------------------|------------------------|------------------------|------------------------|------------------------|--------------------------------|
| Overflow | Yes            | 0                      | –                        | 1                        | –                      | –                      | –                      | –                      | T(r), SFo=1                  |
| Overflow | Yes            | 0                      | –                        | 0                        | 0                      | –                      | –                      | –                      | T(r), SFo=1, SFx=1           |
| Overflow | Yes            | 0                      | –                        | 0                        | 1                      | No                     | –                      | –                      | T(r), SFo=1, PIDx(08)        |
| Overflow | Yes            | 0                      | –                        | 0                        | 1                      | Yes                    | –                      | –                      | T(r), SFo=1, PIDy(0C)         |
| Overflow | Yes            | 1                      | –                        | –                        | –                      | –                      | –                      | No                     | No1 Tw(g|>l|v|), PIDo(20)         |
| Overflow | Yes            | 1                      | –                        | –                        | –                      | –                      | –                      | Yes                    | No Tw(g|>l|v|), PIDo(28)        |
| Overflow | Yes            | 1                      | –                        | –                        | –                      | Yes                    | Yes                   | Yes                   | Tw(g|>l|v|), PIDo(2C)           |
| Normal   | No             | –                      | –                        | –                        | –                      | –                      | –                      | –                      | T(r)                          |
| Normal   | Yes            | –                      | –                        | 1                        | –                      | –                      | –                      | No                     | No1 Tw(g|>l|v|), PIDo(10)       |
| Normal   | Yes            | –                      | –                        | 0                        | 0                      | –                      | –                      | –                      | T(r), SFx=1                  |
| Normal   | Yes            | –                      | –                        | 0                        | 1                      | No                     | –                      | –                      | T(r), PIDx(08)               |
| Normal   | Yes            | –                      | –                        | 0                        | 1                      | Yes                    | –                      | –                      | T(r), PIDy(0C)               |
| Tiny     | No             | –                      | 0                        | –                        | –                      | –                      | –                      | –                      | T(r)                          |
| Tiny     | No             | –                      | 1                        | –                        | –                      | –                      | –                      | No1                    | No1 Tw(g|>l|v|), PIDo(10)       |
| Tiny     | Yes            | –                      | 0                        | 1                        | –                      | –                      | –                      | –                      | T(r), SFu=1                  |
| Tiny     | Yes            | –                      | 0                        | 0                        | 0                      | –                      | –                      | –                      | T(r), SFu=1, SFx=1           |
| Tiny     | Yes            | –                      | 0                        | 0                        | 1                      | No                     | –                      | –                      | T(r), SFu=1, PIDx(08)        |
| Tiny     | Yes            | –                      | 0                        | 0                        | 1                      | Yes                    | –                      | –                      | T(r), SFu=1, PIDy(0C)         |
| Tiny     | Yes            | –                      | 1                        | –                        | –                      | –                      | –                      | No                     | No1 Tw(g|>l|v|), PIDo(10)       |
| Tiny     | Yes            | –                      | 1                        | –                        | –                      | Yes                   | No                    | Yes                   | Tw(g|>l|v|), PIDu(18)           |
| Tiny     | Yes            | –                      | 1                        | –                        | –                      | Yes                   | Yes                   | Yes                   | Tw(g|>l|v|), PIDu(1C)           |

**Explanation:**
- The results do not depend on this condition or mask bit.
- This condition is true by virtue of the state of some condition to the left of this column.
- The IEEE-inexact-exception control (X|C|) is defined only if the floating-point extension facility is installed.
- Scale factor. For overflow, \( v = 2^{+}\). For underflow, \( v = 2^{-}\). The unsigned scaling exponent (\( \alpha \)) depends on the type of operation and operand format. For all BFP operations except LOAD ROUNDED, \( \alpha \) depends on the target format and is 192 for short, 1536 for long, and 24576 for extended. For LOAD ROUNDED, \( \alpha \) depends on the source format, and is 512 for long and 8192 for extended.
- The precision-rounded value. The value derived when the precise intermediate value (\( v \)) is rounded to the precision of the target, but assuming an unbounded exponent range.
- Nontrap result as defined in Part 1 of this figure.
- Precise intermediate value. This is the value, before rounding, assuming unbounded precision and unbounded exponent range.
- Program interruption for data exception, condition c, with DXC of h in hex. See Figure 19-10 on page 19-11.
- IEEE overflow flag, FPC 1.2.
- IEEE underflow flag, FPC 1.3.
- IEEE inexact flag, FPC 1.4.
- The value \( x \) is placed at the target operand location. For all operations except BFP LOAD ROUNDED, the scaled result is in the format and length of the target and rounded to the precision of the target. For LOAD ROUNDED, the scaled result is in the format and length of the source, but rounded to the precision of the target.

**Figure 19-8. Action for R(\( v \)): Rounding and Range Function (Part 2 of 2)**
Data-Exception Codes (DXC) and Abbreviations

Figure 19-9 shows IEEE exceptions and flag abbreviations that are used in the result figures, and it explains the symbols “Xi:” and “Xz:” that are used in the figures. Bits 0-4 (i, z, o, u, and x) of the eight-bit data-exception code (DXC) in byte 2 of the FPC register are trap flags and correspond to the same bits in bytes 0 and 1 of the register (IEEE masks and IEEE flags). The trap flag for an exception, instead of the IEEE flag, is set to one when an interruption for the exception is enabled by the corresponding IEEE mask bit. Bit 5 of byte 2 (y) is used in conjunction with bit 4, inexact (x), to indicate that the result has been incremented in magnitude.

<table>
<thead>
<tr>
<th>Exception</th>
<th>FPC Mask Bit</th>
<th>IEEE Flag</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>Abbr.</td>
<td>FPC Bit</td>
</tr>
<tr>
<td>IEEE invalid operation</td>
<td>Xi</td>
<td>0.0</td>
</tr>
<tr>
<td>IEEE division by zero</td>
<td>Xz</td>
<td>0.1</td>
</tr>
<tr>
<td>IEEE overflow</td>
<td>Xo</td>
<td>0.2</td>
</tr>
<tr>
<td>IEEE underflow</td>
<td>Xu</td>
<td>0.3</td>
</tr>
<tr>
<td>IEEE inexact</td>
<td>Xx</td>
<td>0.4</td>
</tr>
</tbody>
</table>

Explanation:
1. The symbol “Xi:” followed by a list of results in a figure indicates that, when FPC 0.0 is zero, then instruction execution is completed by setting SFi (FPC 1.0) to one and producing the indicated results; and when FPC 0.0 is one, then instruction execution is suppressed, the data exception code (DXC) is set to 80 hex, and a program interruption for a data exception occurs.
2. The symbol “Xz:” followed by a list of results in a figure indicates that, when FPC 0.1 is zero, then instruction execution is completed by setting SFz (FPC 1.1) to one and producing the indicated results; and when FPC 0.1 is one, then instruction execution is suppressed, the data exception code (DXC) is set to 40 hex, and a program interruption for a data exception occurs.

Figure 19-10 on page 19-11 shows the various DXCs that can be indicated, the associated instruction endings, and abbreviations that are used for the DXCs in the result figures. (The abbreviation “PID” stands for “program interruption for a data exception.”)
Instructions

The BFP instructions and their mnemonics and operation codes are listed in Figure 19-11 on page 19-12.

The figure indicates, in the column labeled “Characteristics”, the instruction format, when the condition code is set, the instruction fields that designate access registers, and the exceptional conditions in operand designations, data, or results that cause a program interruption.

All BFP instructions are subject to the AFP-register-control bit, bit 45 of control register 0. For the BFP instructions to be executed successfully, the AFP-register-control bit must be one; otherwise, a BFP-instruction data exception, DXC 2, is recognized.

Mnemonics for the BFP instructions are distinguished from the corresponding HFP instructions by a B in the mnemonic. Mnemonics for the BFP instructions have an R as the last letter or the letter next to the last letter when the instruction is in the RRE or RRF format. Mnemonics for the BFP instructions have an A as the last letter when the instruction is an alternate instruction, which uses additional modifier fields not available to the original instruction. Certain letters are used for BFP instructions to represent operand-format length, as follows:

Note: In the detailed descriptions of the individual instructions, the mnemonic and the symbolic operand designation for the assembler language are shown with each instruction. For a register-to-register operation using COMPARE (short), for example, CEBR is the mnemonic and R1,R2 the operand designation.

Programming Note: The floating-point extension facility includes the following BFP features:

- The following new BFP instructions are added:
  - CONVERT FROM LOGICAL (CXLFBFR, CDLFBFR, CELFBFR, CXLGBFR, CDLGBFR, and CELGBFR).
  - CONVERT TO LOGICAL (CLFXBR, CLFDBR, CLFEBFR, CLGXBR, CLGDBR, and CLGEBR)
- One new value of the effective rounding method field is assigned to support the round to prepare for shorter precision rounding method for CONVERT TO FIXED, DIVIDE TO INTEGER, and LOAD FP INTEGER.
- An IEEE-inexact-exception control (XxC) is added to CONVERT TO FIXED and LOAD FP INTEGER.
• An effective rounding method field and an IEEE-inexact-exception control (XxC) are added to CONVERT FROM FIXED and LOAD ROUNDED.

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD (extended BFP)</td>
<td>AXBR</td>
<td>RRE C o(^{-3}) SP Db Xi Xo Xu Xx</td>
<td>B34A</td>
<td>19-15</td>
</tr>
<tr>
<td>ADD (long BFP)</td>
<td>ADB</td>
<td>RXE C o(^{-3}) A Db Xi Xo Xu Xx</td>
<td>B2</td>
<td>19-15</td>
</tr>
<tr>
<td>ADD (short BFP)</td>
<td>AEBR</td>
<td>RXE C o(^{-3}) A Db Xi Xo Xu Xx</td>
<td>B5</td>
<td>19-15</td>
</tr>
<tr>
<td>ADD (short BFP)</td>
<td>AEB</td>
<td>RXE C o(^{-3}) A Db Xi Xo Xu Xx</td>
<td>B5</td>
<td>19-15</td>
</tr>
<tr>
<td>COMPARE (extended BFP)</td>
<td>CXBR</td>
<td>RRE C o(^{-3}) SP Db Xi</td>
<td>B349</td>
<td>19-17</td>
</tr>
<tr>
<td>COMPARE (long BFP)</td>
<td>CDBR</td>
<td>RXE C o(^{-3}) A Db Xi</td>
<td>B5</td>
<td>19-17</td>
</tr>
<tr>
<td>COMPARE (long BFP)</td>
<td>CDB</td>
<td>RXE C o(^{-3}) A Db Xi</td>
<td>B5</td>
<td>19-17</td>
</tr>
<tr>
<td>COMPARE (short BFP)</td>
<td>CEBR</td>
<td>RXE C o(^{-3}) A Db Xi</td>
<td>B5</td>
<td>19-17</td>
</tr>
<tr>
<td>COMPARE (short BFP)</td>
<td>CEB</td>
<td>RXE C o(^{-3}) A Db Xi</td>
<td>B5</td>
<td>19-17</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (extended BFP)</td>
<td>KXBR</td>
<td>RRE C o(^{-3}) SP Db Xi</td>
<td>B348</td>
<td>19-18</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (long BFP)</td>
<td>KBDR</td>
<td>RXE C o(^{-3}) A Db Xi</td>
<td>B5</td>
<td>19-18</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (long BFP)</td>
<td>KDBR</td>
<td>RXE C o(^{-3}) A Db Xi</td>
<td>B5</td>
<td>19-18</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (short BFP)</td>
<td>KEBR</td>
<td>RXE C o(^{-3}) A Db Xi</td>
<td>B5</td>
<td>19-18</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (short BFP)</td>
<td>KEB</td>
<td>RXE C o(^{-3}) A Db Xi</td>
<td>B5</td>
<td>19-18</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to extended BFP)</td>
<td>CXFBR</td>
<td>RRE C o(^{-3}) SP Db</td>
<td>B396</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to long BFP)</td>
<td>CDFBR</td>
<td>RRE C o(^{-3}) Db</td>
<td>B395</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to extended BFP)</td>
<td>CXFBRA</td>
<td>RRF-e F o(^{-3}) SP Db</td>
<td>B396</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to long BFP)</td>
<td>CDFBRA</td>
<td>RRF-e F o(^{-3}) Db</td>
<td>B395</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to short BFP)</td>
<td>CEFBR</td>
<td>RRE C o(^{-3}) Db Xx</td>
<td>B394</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to short BFP)</td>
<td>CEFRA</td>
<td>RRF-e F o(^{-3}) SP Db</td>
<td>B394</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to extended BFP)</td>
<td>CXGBR</td>
<td>RRE N o(^{-3}) SP Db</td>
<td>B367</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to long BFP)</td>
<td>CDGBR</td>
<td>RRE N o(^{-3}) Db Xx</td>
<td>B357</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to long BFP)</td>
<td>CDGBRA</td>
<td>RRF-e F o(^{-3}) SP Db</td>
<td>B367</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to short BFP)</td>
<td>CEGBR</td>
<td>RRE N o(^{-3}) Db Xx</td>
<td>B357</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to short BFP)</td>
<td>CEGBRA</td>
<td>RRF-e F o(^{-3}) SP Db</td>
<td>B367</td>
<td>19-19</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to extended BFP)</td>
<td>CXLGBR</td>
<td>RRF-e F o(^{-3}) SP Db</td>
<td>B392</td>
<td>19-21</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to long BFP)</td>
<td>CDLGBR</td>
<td>RRF-e F o(^{-3}) Db Xx</td>
<td>B391</td>
<td>19-21</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to short BFP)</td>
<td>CELGBR</td>
<td>RRF-e F o(^{-3}) Db Xx</td>
<td>B390</td>
<td>19-21</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to extended BFP)</td>
<td>CXLGBRA</td>
<td>RRF-e F o(^{-3}) SP Db</td>
<td>B392</td>
<td>19-21</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to long BFP)</td>
<td>CDLGBRA</td>
<td>RRF-e F o(^{-3}) Db Xx</td>
<td>B391</td>
<td>19-21</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to short BFP)</td>
<td>CELGBRA</td>
<td>RRF-e F o(^{-3}) Db Xx</td>
<td>B390</td>
<td>19-21</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (extended BFP to 32)</td>
<td>CFXBRA</td>
<td>RRF-e C o(^{-3}) SP Db Xx</td>
<td>B39A</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (extended BFP to 32)</td>
<td>CFXBRA</td>
<td>RRF-e C o(^{-3}) SP Db Xx</td>
<td>B39A</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (extended BFP to 64)</td>
<td>CGXBR</td>
<td>RRF-e C N o(^{-3}) SP Db Xx</td>
<td>B39A</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (extended BFP to 64)</td>
<td>CGXBRA</td>
<td>RRF-e C F o(^{-3}) SP Db Xx</td>
<td>B39A</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (long BFP to 32)</td>
<td>CFDBR</td>
<td>RRF-e C o(^{-3}) SP Db Xi Xx</td>
<td>B399</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (long BFP to 32)</td>
<td>CFDBRA</td>
<td>RRF-e C F o(^{-3}) SP Db Xi Xx</td>
<td>B399</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (long BFP to 64)</td>
<td>CGDBR</td>
<td>RRF-e C N o(^{-3}) SP Db Xi Xx</td>
<td>B39A</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (long BFP to 64)</td>
<td>CGDBRA</td>
<td>RRF-e C F o(^{-3}) SP Db Xi Xx</td>
<td>B39A</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (short BFP to 32)</td>
<td>CFEBR</td>
<td>RRF-e C o(^{-3}) SP Db Xi Xx</td>
<td>B398</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (short BFP to 32)</td>
<td>CFEBRA</td>
<td>RRF-e C F o(^{-3}) SP Db Xi Xx</td>
<td>B398</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (short BFP to 64)</td>
<td>CGEBR</td>
<td>RRF-e C N o(^{-3}) SP Db Xi Xx</td>
<td>B39A</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO FIXED (short BFP to 64)</td>
<td>CGEBRA</td>
<td>RRF-e C F o(^{-3}) SP Db Xi Xx</td>
<td>B39A</td>
<td>19-22</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (extended BFP to 32)</td>
<td>CLFXBR</td>
<td>RRF-e C o(^{-3}) SP Db Xi Xx</td>
<td>B39E</td>
<td>19-25</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (extended BFP to 64)</td>
<td>CLGXBRA</td>
<td>RRF-e C F o(^{-3}) SP Db Xi Xx</td>
<td>B39E</td>
<td>19-25</td>
</tr>
</tbody>
</table>

Figure 19-11. Summary of BFP Instructions (Part 1 of 3)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT TO LOGICAL (long BFP to 32)</td>
<td>CLFDBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xx</td>
<td>B39D</td>
<td>19-25</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (long BFP to 64)</td>
<td>CLGDBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xx</td>
<td>B3AD</td>
<td>19-25</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (short BFP to 32)</td>
<td>CLFEBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xx</td>
<td>B30C</td>
<td>19-25</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (short BFP to 64)</td>
<td>CLGEBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xx</td>
<td>B3A1</td>
<td>19-25</td>
</tr>
<tr>
<td>DIVIDE (extended BFP)</td>
<td>DXBR</td>
<td>( \alpha^7,9 ) A Db Xi Xz Xo Xx</td>
<td>B2</td>
<td>19-27</td>
</tr>
<tr>
<td>DIVIDE (long BFP)</td>
<td>DDBR</td>
<td>( \alpha^7,9 ) A Db Xi Xz Xo Xx</td>
<td>B31D</td>
<td>19-27</td>
</tr>
<tr>
<td>DIVIDE (short BFP)</td>
<td>DDBR</td>
<td>( \alpha^7,9 ) A Db Xi Xz Xo Xx</td>
<td>B31D</td>
<td>19-27</td>
</tr>
<tr>
<td>DIVIDE (short BFP)</td>
<td>DEBR</td>
<td>( \alpha^7,9 ) Db Xi Xz Xo Xx</td>
<td>B2</td>
<td>19-27</td>
</tr>
<tr>
<td>DIVIDE TO INTEGER (long BFP)</td>
<td>DIDBR</td>
<td>( \alpha^7,9 ) Db Xi Xz Xo Xx</td>
<td>B30B</td>
<td>19-28</td>
</tr>
<tr>
<td>LOAD AND TEST (extended BFP)</td>
<td>LTXBR</td>
<td>( \alpha^7,9 ) Db Xi</td>
<td>B341</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD AND TEST (long BFP)</td>
<td>LTDBR</td>
<td>( \alpha^7,9 ) Db Xi</td>
<td>B311</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD AND TEST (short BFP)</td>
<td>LTEBR</td>
<td>( \alpha^7,9 ) Db Xi</td>
<td>B312</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (extended BFP)</td>
<td>LCXBR</td>
<td>( \alpha^7,9 ) SP Db</td>
<td>B33B</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (long BFP)</td>
<td>LCDBR</td>
<td>( \alpha^7,9 ) Db</td>
<td>B313</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (short BFP)</td>
<td>LCEBR</td>
<td>( \alpha^7,9 ) Db</td>
<td>B303</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD FP INTEGER (extended BFP)</td>
<td>FIXBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xx</td>
<td>B347</td>
<td>19-32</td>
</tr>
<tr>
<td>LOAD FP INTEGER (long BFP)</td>
<td>FIDBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xx</td>
<td>B35F</td>
<td>19-32</td>
</tr>
<tr>
<td>LOAD FP INTEGER (short BFP)</td>
<td>FIEBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xx</td>
<td>B357</td>
<td>19-32</td>
</tr>
<tr>
<td>LOAD FP INTEGER (short BFP)</td>
<td>FIEBRA</td>
<td>( \alpha^7,9 ) SP Db Xi Xx</td>
<td>B357</td>
<td>19-32</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>LXDBR</td>
<td>( \alpha^7,9 ) A SP Db Xi</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>LXDBR</td>
<td>( \alpha^7,9 ) SP Db Xi</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to extended BFP)</td>
<td>LXEBR</td>
<td>( \alpha^7,9 ) A SP Db Xi</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to extended BFP)</td>
<td>LXEBR</td>
<td>( \alpha^7,9 ) SP Db Xi</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to long BFP)</td>
<td>LDEB</td>
<td>( \alpha^7,9 ) Db Xi</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD NEGATIVE (long BFP)</td>
<td>LNDBR</td>
<td>( \alpha^7,9 ) Db</td>
<td>B311</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD NEGATIVE (short BFP)</td>
<td>LNEBR</td>
<td>( \alpha^7,9 ) Db</td>
<td>B301</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD POSITIVE (long BFP)</td>
<td>LPDBR</td>
<td>( \alpha^7,9 ) Db</td>
<td>B2</td>
<td>19-35</td>
</tr>
<tr>
<td>LOAD POSITIVE (short BFP)</td>
<td>LPEBR</td>
<td>( \alpha^7,9 ) Db</td>
<td>B2</td>
<td>19-35</td>
</tr>
<tr>
<td>LOAD ROUNDED (long to extended BFP)</td>
<td>LDXBRA</td>
<td>( \alpha^7,9 ) SP Db Xi Xo Xx</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD ROUNDED (long to extended BFP)</td>
<td>LDXBRA</td>
<td>( \alpha^7,9 ) SP Db Xi Xo Xx</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD ROUNDED (short to extended BFP)</td>
<td>LEXBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xo Xx</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD ROUNDED (short to extended BFP)</td>
<td>LEXBR</td>
<td>( \alpha^7,9 ) SP Db Xi Xo Xx</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD ROUNDED (short to long BFP)</td>
<td>LEDBR</td>
<td>( \alpha^7,9 ) Db Xi Xo Xx</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD ROUNDED (short to long BFP)</td>
<td>LEDBRA</td>
<td>( \alpha^7,9 ) Db Xi Xo Xx</td>
<td>B2</td>
<td>19-34</td>
</tr>
<tr>
<td>MULTIPLY (extended BFP)</td>
<td>MXBR</td>
<td>( \alpha^7,9 ) Db Xi Xo Xx</td>
<td>B2</td>
<td>19-37</td>
</tr>
<tr>
<td>MULTIPLY (long BFP)</td>
<td>MDBR</td>
<td>( \alpha^7,9 ) Db Xi Xo Xx</td>
<td>B2</td>
<td>19-37</td>
</tr>
<tr>
<td>MULTIPLY (short BFP)</td>
<td>MEEB</td>
<td>( \alpha^7,9 ) Db Xi Xo Xx</td>
<td>B2</td>
<td>19-37</td>
</tr>
<tr>
<td>MULTIPLY (short BFP)</td>
<td>MEEBR</td>
<td>( \alpha^7,9 ) Db Xi Xo Xx</td>
<td>B2</td>
<td>19-37</td>
</tr>
<tr>
<td>MULTIPLY (short to long BFP)</td>
<td>MDBR</td>
<td>( \alpha^7,9 ) Db Xi Xo Xx</td>
<td>B2</td>
<td>19-37</td>
</tr>
<tr>
<td>MULTIPLY (short to long BFP)</td>
<td>MDEB</td>
<td>( \alpha^7,9 ) Db Xi Xo Xx</td>
<td>B2</td>
<td>19-37</td>
</tr>
</tbody>
</table>

Figure 19-11. Summary of BFP Instructions (Part 2 of 3)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>MULTIPPLY AND ADD (long BFP)</td>
<td>MADB RXF</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B2</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPPLY AND ADD (long BFP)</td>
<td>MADBR RRD</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B3</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPPLY AND ADD (short BFP)</td>
<td>MAEB RXF</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B2</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPPLY AND ADD (short BFP)</td>
<td>MAEBR RRD</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B3</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPPLY AND SUBTRACT (long BFP)</td>
<td>MSDB RXF</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B1</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPPLY AND SUBTRACT (long BFP)</td>
<td>MSDBR RRD</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B3</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPPLY AND SUBTRACT (short BFP)</td>
<td>MSEB RXF</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B1</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPPLY AND SUBTRACT (short BFP)</td>
<td>MSEBR RRD</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B3</td>
<td>19-38</td>
</tr>
<tr>
<td>SQUARE ROOT (extended BFP)</td>
<td>SQXBR RRE</td>
<td>$\alpha^{0} A$ SP Db Xi Xx</td>
<td>B3</td>
<td>19-40</td>
</tr>
<tr>
<td>SQUARE ROOT (long BFP)</td>
<td>SQDB RXE</td>
<td>$\alpha^{0} A$ Db Xi Xx</td>
<td>B2</td>
<td>19-40</td>
</tr>
<tr>
<td>SQUARE ROOT (long BFP)</td>
<td>SQDBR RRE</td>
<td>$\alpha^{0} A$ Db Xi Xx</td>
<td>B3</td>
<td>19-40</td>
</tr>
<tr>
<td>SQUARE ROOT (short BFP)</td>
<td>SQEB RXE</td>
<td>$\alpha^{0} A$ Db Xi Xx</td>
<td>B2</td>
<td>19-40</td>
</tr>
<tr>
<td>SQUARE ROOT (short BFP)</td>
<td>SQEBR RRE</td>
<td>$\alpha^{0} A$ Db Xi Xx</td>
<td>B3</td>
<td>19-40</td>
</tr>
<tr>
<td>SUBTRACT (extended BFP)</td>
<td>SXBR RRE C</td>
<td>$\alpha^{0} A$ SP Db Xi Xo Xu Xx</td>
<td>B3</td>
<td>19-40</td>
</tr>
<tr>
<td>SUBTRACT (long BFP)</td>
<td>SDB RXE C</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B2</td>
<td>19-40</td>
</tr>
<tr>
<td>SUBTRACT (long BFP)</td>
<td>SDBR RRE C</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B3</td>
<td>19-40</td>
</tr>
<tr>
<td>SUBTRACT (short BFP)</td>
<td>SEB RXE C</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B2</td>
<td>19-40</td>
</tr>
<tr>
<td>SUBTRACT (short BFP)</td>
<td>SEBR RRE C</td>
<td>$\alpha^{0} A$ Db Xi Xo Xu Xx</td>
<td>B3</td>
<td>19-40</td>
</tr>
<tr>
<td>TEST DATA CLASS (extended BFP)</td>
<td>TCXB RXE C</td>
<td>$\alpha^{0} A$ SP Db</td>
<td>B2</td>
<td>19-41</td>
</tr>
<tr>
<td>TEST DATA CLASS (long BFP)</td>
<td>TCDB RXE C</td>
<td>$\alpha^{0} A$ Db</td>
<td>B2</td>
<td>19-41</td>
</tr>
<tr>
<td>TEST DATA CLASS (short BFP)</td>
<td>TCEB RXE C</td>
<td>$\alpha^{0} A$ Db</td>
<td>B2</td>
<td>19-41</td>
</tr>
</tbody>
</table>

**Explanation:**

- $c^{0}$: Restricted from transactions execution when the effective allow-floating-point-operation control is zero.
- $c^{9}$: Restricted in the constrained transactional-execution mode; a transaction-constraint program exception may be recognized.
- A: Access exceptions for logical addresses.
- B2: B2 field designates an access register in the access-register mode.
- C: Condition code is set.
- Db: BFP-instruction data exception.
- F: Floating-point extension facility
- N: Instruction is new in z/Architecture as compared to ESA/390.
- RRD: RRD instruction format.
- RRE: RRE instruction format.
- RRF: RRF instruction format.
- RXE: RXE instruction format.
- RXF: RXF instruction format.
- SP: Specification exception.
- Xi: IEEE invalid-operation exception.
- Xo: IEEE overflow exception.
- Xu: IEEE underflow exception.
- Xx: IEEE inexact exception.
- Xz: IEEE division-by-zero exception.

*Figure 19-11. Summary of BFP Instructions  (Part 3 of 3)*
ADD

Mnemonic1 \( R_1, R_2 \) \([RRE]\)

<table>
<thead>
<tr>
<th>Op Code</th>
<th>16</th>
<th>24</th>
<th>28</th>
<th>31</th>
</tr>
</thead>
</table>

Mnemonic1 Op Code Operands
AEBR 'B30A' Short BFP
ADBR 'B31A' Long BFP
AXBR 'B34A' Extended BFP

Mnemonic2 \( R_1, D_2(X_2, B_2) \) \([RXE]\)

<table>
<thead>
<tr>
<th>Op Code R_1</th>
<th>X_2</th>
<th>B_2</th>
<th>D_2</th>
<th>Op Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
</tr>
</tbody>
</table>

Mnemonic2 Op Code Operands
AEB 'ED0A' Short BFP
ADB 'ED1A' Long BFP

The second operand is added to the first operand, and the sum is placed at the first-operand location.

If both operands are finite numbers, they are added algebraically, forming an intermediate sum. The intermediate sum, if nonzero, is rounded to the operand format according to the current BFP rounding mode. The sum is then placed at the result location.

The sign of the sum is determined by the rules of algebra. This also applies to a result of zero:

- If the result of rounding a nonzero intermediate sum is zero, the sign of the zero result is the sign of the intermediate sum.
- If the sum of two operands with opposite signs is exactly zero, the sign of the result is plus in all rounding methods except round toward \(-\infty\), in which method the sign is minus.
- The sign of the sum \(x\) plus \(x\) is the sign of \(x\), even when \(x\) is zero.

If one operand is an infinity and the other is a finite number, the result is that infinity. If both operands are infinities of the same sign, the result is the same infinity. If the two operands are infinities of opposite signs, an IEEE-invalid-operation exception is recognized.

See Figure 19-13 on page 19-16 for a detailed description of the results of this instruction. (Figure 19-12 is referred to by Figure 19-13.)

For AXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Value of Result ( r )</th>
<th>Condition Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>( r = 0 )</td>
<td>0</td>
</tr>
<tr>
<td>( r &lt; 0 )</td>
<td>1</td>
</tr>
<tr>
<td>( r &gt; 0 )</td>
<td>2</td>
</tr>
</tbody>
</table>

**IEEE Exceptions:**

- Invalid operation
- Overflow
- Underflow
- Inexact

**Program Exceptions:**

- Access (fetch, operand 2 of AEB and ADB only)
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification (AXBR only)
- Transaction constraint

**Programming Note:** Interchanging the two operands in a BFP addition does not affect the value of the sum when the result is numeric. This is not true, however, when both operands are QNaNs, in which case the result is the first operand; or when both operands are SNaNs and the IEEE-invalid-operation mask bit in the FPC register is zero, in which case the result is the QNaN derived from the first operand.
### Results for ADD (a+b) when Second Operand (b) Is

<table>
<thead>
<tr>
<th>First Operand (a) Is</th>
<th>Results for ADD (a+b) when Second Operand (b) Is</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞</td>
<td>T(=∞), cc1</td>
</tr>
<tr>
<td>-Nn</td>
<td>T(=∞), cc1</td>
</tr>
<tr>
<td>-Dn</td>
<td>T(=∞), cc1</td>
</tr>
<tr>
<td>-0</td>
<td>T(=∞), cc1</td>
</tr>
<tr>
<td>+0</td>
<td>T(=∞), cc1</td>
</tr>
<tr>
<td>+Dn</td>
<td>T(=∞), cc1</td>
</tr>
<tr>
<td>+Nn</td>
<td>T(=∞), cc1</td>
</tr>
<tr>
<td>+∞</td>
<td>T(=∞), cc1</td>
</tr>
<tr>
<td>QNaN</td>
<td>T(b), cc3</td>
</tr>
<tr>
<td>SNaN</td>
<td>Xi: T(b*), cc3</td>
</tr>
</tbody>
</table>

#### Explanation:

- The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
- Condition code is set to n.
- Condition code is set according to the resultant sum. See Figure 19-12 on page 19-15.
- Default NaN.
- Subnormal number.
- Normal number.
- Rounding and range action is performed on the value v. See Figure 19-8 on page 19-8.
- Exact zero-difference result. See Figure 19-8 on page 19-8.
- The value x is placed at the target operand location.
- IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

**Figure 19-13. Results: ADD**
COMPARE

Mnemonic1 R1,R2 [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Mnemonic1 Op Code Operands
CEBR 'B309' Short BFP
CDBR 'B319' Long BFP
CXBR 'B349' Extended BFP

Mnemonic2 R1,D2(X2,B2) [RXE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>32</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>36</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>40</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>44</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>48</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Mnemonic2 Op Code Operands
CEB 'ED09' Short BFP
CDB 'ED19' Long BFP

The first operand is compared with the second operand, and the condition code is set to indicate the result.

If both operands are finite numbers, the comparison is algebraic and follows the procedure for BFP subtraction, except that the difference is discarded after setting the condition code, and both operands remain unchanged. If the difference is exactly zero with either sign, the operands are equal; this includes zero operands (so +0 equals -0). If a nonzero difference is positive or negative, the first operand is high or low, respectively.

\[ +\infty \text{ compares greater than any finite number, and all finite numbers compare greater than } -\infty. \] Two infinity operands of like sign compare equal.

Numeric comparison is exact, and the condition code is determined for finite operands as if range and precision were unlimited. No overflow or underflow exception can occur.

If either or both operands are QNaNs and neither operand is an SNaN, the comparison result is unordered, and condition code 3 is set.

If either or both operands are SNaNs, an IEEE-invalid-operation exception is recognized. If the IEEE invalid-operation mask bit is one, a program interrupt for a data exception with DXC 80 hex (IEEE invalid operation) occurs. If the IEEE-invalid-operation mask bit is zero, the IEEE-invalid-operation flag bit is set to one, and instruction execution is completed by setting condition code 3.

See Figure 19-14 on page 19-18 for a detailed description of the results of this instruction.

For CXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Resulting Condition Code:

0 Operands equal
1 First operand low
2 First operand high
3 Operands unordered

IEEE Exceptions:

- Invalid operation

Program Exceptions:

- Access (fetch, operand 2 of CEB and CDB only)
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification (CXBR only)
- Transaction constraint

Programming Notes:

1. COMPARE may be used to implement those comparisons which are required by ANSI/IEEE Standard 754-2008 to not recognize an exception when the result is unordered due to a QNaN.

2. ANSI/IEEE Standard 754-2008 requires that it be possible to compare BFP operands in different formats. To accomplish this, LOAD LENGTH-ENED may be used before COMPARE to convert the shorter operand to the same format as the longer.
COMPARE AND SIGNAL

Mnemonic1 R1.R2 [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>01 6 24 28 31</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Mnemonic1 Op Code Operands
KEBR 'B308' Short BFP
KDBR 'B318' Long BFP
KXBR 'B348' Extended BFP

Mnemonic2 R1,D2(X2,B2) [RXE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>06 12 16 20 24 32 40 47</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Mnemonic2 Op Code Operands
KEB 'ED08' Short BFP
KDB 'ED18' Long BFP

The first operand is compared with the second operand, and the condition code is set to indicate the result. The operation is the same as for COMPARE except that QNaN operands cause an IEEE-invalid-operation exception to be recognized. Thus, QNaN operands are treated as if they were SNaNs.

See Figure 19-16 on page 19-19 for a detailed description of the results of this instruction.

For KXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Resulting Condition Code:

0 Operands equal
1 First operand low
2 First operand high
3 Operands unordered

IEEE Exceptions:

- Invalid operation

Program Exceptions:

- Access (fetch, operand 2 of KEB and KDB only)
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification (KXBR only)
- Transaction constraint

Programming Notes:

1. COMPARE AND SIGNAL may be used to implement those comparisons which are required by ANSI/IEEE Standard 754-2008 to recognize an exception when the result is unordered due to a QNaN.
2. ANSI/IEEE Standard 754-2008 requires that it be possible to compare BFP operands in different formats. To accomplish this, LOAD LENGTH-ENED may be used before COMPARE AND SIGNAL to convert the shorter operand to the same format as the longer.

<table>
<thead>
<tr>
<th>First Operand (a) Is</th>
<th>Results for COMPARE AND SIGNAL (a:b) when Second Operand (b) Is</th>
</tr>
</thead>
<tbody>
<tr>
<td>(-\infty)</td>
<td>-(\infty) (\text{NaN}) (0) (+0) (+\infty) (\text{NaN})</td>
</tr>
<tr>
<td>-(\text{Fn})</td>
<td>cc0 cc1 cc1 cc1 cc1 cc1 (\text{Xi: cc3})</td>
</tr>
<tr>
<td>(0)</td>
<td>cc2 C(a:b) cc1 cc1 cc1 cc1 (\text{Xi: cc3})</td>
</tr>
<tr>
<td>+(0)</td>
<td>cc0 cc2 cc0 cc0 cc0 cc0 (\text{Xi: cc3})</td>
</tr>
<tr>
<td>+(\text{Fn})</td>
<td>cc2 cc2 cc2 cc2 cc2 cc2 (\text{Xi: cc3})</td>
</tr>
<tr>
<td>(\text{NaN})</td>
<td>(\text{Xi: cc3}) (\text{Xi: cc3}) (\text{Xi: cc3}) (\text{Xi: cc3}) (\text{Xi: cc3}) (\text{Xi: cc3})</td>
</tr>
</tbody>
</table>

**Explanation:**

ccn Condition code is set to n.
C(a:b) Basic compare results. See Figure 19-15 on page 19-18
\(\text{Fn}\) Finite nonzero number (includes both subnormal and normal).
\(\text{Xi}\): IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

**Figure 19-16. Results: COMPARE AND SIGNAL**

**CONVERT FROM FIXED**

<table>
<thead>
<tr>
<th>Mnemonic1 Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CEFBR 'B394'</td>
<td>32-bit binary-integer operand, short BFP result</td>
</tr>
<tr>
<td>CDFBR 'B395'</td>
<td>32-bit binary-integer operand, long BFP result</td>
</tr>
<tr>
<td>CXFBR 'B396'</td>
<td>32-bit binary-integer operand, extended BFP result</td>
</tr>
<tr>
<td>CEGBR 'B3A4'</td>
<td>64-bit binary-integer operand, short BFP result</td>
</tr>
<tr>
<td>CDGBR 'B3A5'</td>
<td>64-bit binary-integer operand, long BFP result</td>
</tr>
<tr>
<td>CXGBR 'B3A6'</td>
<td>64-bit binary-integer operand, extended BFP result</td>
</tr>
</tbody>
</table>

The fixed-point second operand is converted to the BFP format, and the result is placed at the first-operand location.

The second operand is a signed binary integer that is located in the general register designated by \(R_2\). A 32-bit operand is in bit positions 32-63 of the register.

When the floating-point extension facility is installed, the converted result is rounded by rounding as specified by the modifier in the \(M_3\) field:

- **\(M_3\) Effective Rounding Method**
  - 0 According to current BFP rounding mode
  - 1 Round to nearest with ties away from 0
  - 3 Round to prepare for shorter precision
  - 4 Round to nearest with ties to even
  - 5 Round toward 0
6  Round toward $+\infty$
7  Round toward $-\infty$

An M₃ modifier other than 0, 1, or 3-7 is invalid. The M₃ field must designate a valid modifier; otherwise, a specification exception is recognized.

When the M₃ modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

When the floating-point extension facility is not installed and bits 16-19 of the instruction contain a value of zero, the converted result is rounded according to the current BFP rounding mode. When the floating-point extension facility is not installed and bits 16-19 of the instruction contain a nonzero value, it is undefined whether a specification exception is recognized or an unpredictable rounding method is performed.

When the floating-point extension facility is installed, bit 1 of the M₄ field is the IEEE-inexact-exception control (XxC). Bits 0, 2, and 3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

When the floating-point extension facility is not installed and if bits 20-23 of the instruction are zeros, recognition of IEEE-inexact exception is not suppressed; when the floating-point extension facility is not installed and if bits 20-23 of the instruction contain a nonzero value, then it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

See Figure 19-17 on page 19-21 for a detailed description of the results of this instruction.

For CXFBR, CXFBRA, CXGBR, and CXGBRA, the R₁ field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Inexact (CEFBR, CEFBRA, CDGBR, CDGBRA, CEGBR, CEGBRA)

**Program Exceptions:**
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification
- Transaction constraint

**Programming Note:** Unassigned bits in the M₄ field are reserved for future extensions and should be set to zeros; otherwise the program may not operate compatibly in the future.
CONVERT FROM LOGICAL

Mnemonic | R1,M3,R2,M4 | [RRF-e]
---|---|---
0 | 16 20 24 28 31

Op Code | M3 | M4 | R1 | R2
---|---|---|---|---
CONVERT FROM FIXED
LOAD AND TEST
LOAD LENGTHENED
LOAD ROUNDED
SQUARE ROOT

Results for Instructions with a Single Operand (a) when Operand (a) Is

| a | -F0 | -0 | +0 | +F0 | +∞ | QNaN | SNaN |
---|---|---|---|---|---|---|---|
-∞ | - | Rf(a) | - | T(+0) | Rf(a) | - | - |
T(-∞) | T(-0) | T(+0) | T(-0) | T(+0) | T(+∞) | T(a) | Xi: T(a*1) |
T(a) | T(+0) | T(a) | T(±0) | R(a) | T(+∞) | T(a) | Xi: T(a*1) |
R(a) | T(+0) | T(a) | T(+0) | R(a) | T(+∞) | T(a) | Xi: T(a*1) |
Xi: T(dNaN) | T(dNaN) | T(-0) | T(+0) | R(±a) | T(+∞) | T(a) | Xi: T(a*) |

Explanation:

- This situation cannot occur.
- The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
- The operand is extended to the longer format by appending zeros on the right before it is placed at the target operand location.
- The NaN is shortened to the target format by truncating the rightmost bits.
- Default NaN.
- Finite nonzero number (includes both subnormal and normal).
- Rounding and range action is performed on the value v. See Figure 19-8 on page 19-9.
- The value a is converted to the precise intermediate value floating-point number v, and then action R(v) is performed.
- The value x is placed in the target operand location.
- IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

Figure 19-17. Results: Single-Operand Instructions

CONVERT FROM LOGICAL

Mnemonic | R1,M3,R2,M4 | [RRF-e]
---|---|---
0 | 16 20 24 28 31

Op Code | M3 | M4 | R1 | R2
---|---|---|---|---
CELFB = 'B390' 32-bit binary-integer operand, short BFP result
CDLFBR = 'B391' 32-bit binary-integer operand, long BFP result
CXLFBR = 'B392' 32-bit binary-integer operand, extended BFP result
CELGBR = 'B3A0' 64-bit binary-integer operand, short BFP result
CDLGBR = 'B3A1' 64-bit binary-integer operand, long BFP result
CXLGBR = 'B3A2' 64-bit binary-integer operand, extended BFP result

The fixed-point second operand is converted to the BFP format, and the result is placed at the first-operand location.

The second operand is an unsigned binary integer that is located in the general register designated by R2. A 32-bit operand is in bit positions 32-63 of the register.

The converted result is rounded by rounding as specified by the modifier in the M4 field:

M3 Effective Rounding Method
0 According to current BFP rounding mode
1 Round to nearest with ties away from 0
3 Round to prepare for shorter precision
4 Round to nearest with ties to even
5 Round toward 0
6 Round toward +∞
7 Round toward -∞

An M3 modifier other than 0, 1, or 3-7 is invalid.

When the M3 modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

The M3 field must designate a valid modifier; otherwise, a specification exception is recognized. For CXLFBR and CXLGBR, the R1 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

Bit 1 of the M4 field is the IEEE-inexact-exception control (XxC). Bits 0, 2, and 3 are ignored. If XxC is
zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

The result always has a plus sign.

See Figure 19-17 on page 19-21 for a detailed description of the results of this instruction.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Inexact (CELFBR, CDLGBR, CELGBR)

**Program Exceptions:**
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Operation (if the floating-point extension facility is not installed)
- Specification
- Transaction constraint

**Programming Notes:**
1. Unassigned bits in the M₄ field are reserved for future extensions and should be set to zeros; otherwise the program may not operate compatibly in the future
2. Using either the round toward 0 or the round toward $-\infty$ rounding method produces the same result.

### CONVERT TO FIXED

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>R₁, M₃, R₂</th>
<th>[RRF-e]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>M₃</td>
<td>/ / /</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic1 Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFEBR 'B398'</td>
<td>Short BFP operand, 32-bit binary-integer result</td>
</tr>
<tr>
<td>CFDBR 'B399'</td>
<td>Long BFP operand, 32-bit binary-integer result</td>
</tr>
<tr>
<td>CFXBR 'B39A'</td>
<td>Extended BFP operand, 32-bit binary-integer result</td>
</tr>
<tr>
<td>CGEBR 'B3A8'</td>
<td>Short BFP operand, 64-bit binary-integer result</td>
</tr>
<tr>
<td>CGDBR 'B3A9'</td>
<td>Long BFP operand, 64-bit binary-integer result</td>
</tr>
<tr>
<td>CGXBR 'B3AA'</td>
<td>Extended BFP operand, 64-bit binary-integer result</td>
</tr>
</tbody>
</table>

The BFP second operand is rounded to an integer value and then converted to the fixed-point format. The result is placed at the first-operand location.

The result is a signed binary integer that is placed in the general register designated by R₁. For instructions that produce a 32-bit result, the result replaces bits 32-63 of the register, and bits 0-31 of the register remain unchanged.

If the second operand is a finite number, it is rounded to an integer value by rounding as specified by the modifier in the M₃ field:

**M₃ Effective Rounding Method**
- 0 According to current BFP rounding mode
- 1 Round to nearest with ties away from 0
- 3 Round to prepare for shorter precision
- 4 Round to nearest with ties to even
- 5 Round toward 0
- 6 Round toward $+\infty$
- 7 Round toward $-\infty$

An M₃ modifier other than 0, 1, or 3-7 is invalid. If the floating-point extension facility is not installed, an M₃ modifier of 3 is also invalid.

When the M₃ modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

The sign of the result is the sign of the second operand, except that a zero result has a plus sign.
When the floating-point extension facility is installed, bit 1 of the M₄ field is the IEEE-inexact-exception control (XxC). Bits 0, 2, and 3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

When the floating-point extension facility is not installed and if bits 20-23 of the instruction are zeros, recognition of IEEE-inexact exception is not suppressed; when the floating-point extension facility is not installed and if bits 20-23 of the instruction contain a nonzero value, it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

See Figure 19-18 for a detailed description of the results of this instruction.

<table>
<thead>
<tr>
<th>Operand (a)</th>
<th>Is n Inexact (n≠a)</th>
<th>Inv.-Op. Mask (FPC 0.0)</th>
<th>IEEE Inexact Exception Control (XxC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Is n Incremented (In&gt;lal)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>No 0 0 1³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, SFx±1, cc3 †</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3, PIDx(08) †</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3, PIDx(08) †</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3, PIDx(08) †</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3, PIDx(08) †</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3, PIDx(08) †</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3, PIDx(08) †</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3, PIDx(08) †</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>-∞ &lt; a &lt; MN, n &lt; MN</td>
<td>Yes 0 0 0³</td>
<td>Yes 0 0 1³</td>
<td>T(MN), SFi±1, cc3, PIDx(08) †</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 19-18. Results: CONVERT TO FIXED
If the M₃ field designates any of the following invalid modifier values: 2 and 8-15, then a specification exception is recognized. When the floating-point extension facility is not installed, if the M₃ field designates the invalid value 3, it is undefined whether a specification exception is recognized or an unpredictable rounding method is performed.

For CFXBR, CFXBRA, CGXBR and CGXBRA, the R₂ field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

| 0 | Source was zero |
| 1 | Source was less than zero |
| 2 | Source was greater than zero |
| 3 | Special case |

**IEEE Exceptions:**

- Invalid operation
- Inexact

**Program Exceptions:**

- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification
- Transaction constraint

**Programming Note:** Unassigned bits in the M₄ field are reserved for future extensions and should be set to zeros; otherwise the program may not operate compatibly in the future.
CONVERT TO LOGICAL

Mnemonic | R1 R2 M3 M4 | [RRF-e]
---|---|---
Op Code | M3 M4 R1 R2

0 | 16 20 24 28 31

Mnemonic | Op Code | Operands
---|---|---
CLFEBR | 'B39C' | Short BFP operand, 32-bit binary-integer result
CLFDBR | 'B39D' | Long BFP operand, 32-bit binary-integer result
CLFXBR | 'B39E' | Extended BFP operand, 32-bit binary-integer result
CLGEBR | 'B3AC' | Short BFP operand, 64-bit binary-integer result
CLGDBR | 'B3AD' | Long BFP operand, 64-bit binary-integer result
CLGXBR | 'B3AE' | Extended BFP operand, 64-bit binary-integer result

The BFP second operand is rounded to an integer value and then converted to the fixed-point format. The result is placed at the first-operand location.

The result is an unsigned binary integer that is placed in the general register designated by R1. For instructions that produce a 32-bit result, the result replaces bits 32-63 of the register, and bits 0-31 of the register remain unchanged.

If the second operand is a finite number, it is rounded to an integer value by rounding as specified by the modifier in the M3 field. When the M3 modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

Bit 1 of the M4 field is the IEEE-inexact-exception control (XxC). Bits 0, 2, and 3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

The M3 field must designate a valid modifier; otherwise, a specification exception is recognized. For CLFXBR and CLGXBR, the R2 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

See Figure 19-19 for a detailed description of the results of this instruction.

**Resulting Condition Code:**

0 Source was zero
1 Source was less than zero
2 Source was greater than zero
3 Special case

**IEEE Exceptions:**

- Invalid operation
- Inexact

**Program Exceptions:**

- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Operation (if the floating-point extension facility is not installed)
- Specification
- Transaction constraint

**Programming Note:** Unassigned bits in the M4 field are reserved for future extensions and should be set to zeros; otherwise the program may not operate compatibly in the future.
<table>
<thead>
<tr>
<th>Operand (a)</th>
<th>Is n Inexact (na)</th>
<th>Inv.-Op. Mask (FPC 0.0)</th>
<th>IEEE Inexact Exception Control (XxC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Is n Incremented (ln&gt;lal)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞ ≤ a &lt; 0, n &lt; 0</td>
<td>--</td>
<td>0</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>T(0), SFi←1, cc3</td>
</tr>
<tr>
<td>-∞ ≤ a &lt; 0, n &lt; 0</td>
<td>--</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>--</td>
<td>T(0), SFi←1, SFx←1, cc3 †</td>
</tr>
<tr>
<td>-∞ ≤ a &lt; 0, n &lt; 0</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>PIDi(80)</td>
</tr>
<tr>
<td>-∞ ≤ a &lt; 0, n = 0</td>
<td>--</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>T(0), cc1</td>
</tr>
<tr>
<td>-∞ ≤ a &lt; 0, n = 0</td>
<td>--</td>
<td>--</td>
<td>0</td>
<td>0</td>
<td>--</td>
<td>T(0), SFx←1, cc1</td>
</tr>
<tr>
<td>-∞ ≤ a &lt; 0, n = 0</td>
<td>--</td>
<td>--</td>
<td>0</td>
<td>1</td>
<td>--</td>
<td>T(0), cc1, PIDx(08)</td>
</tr>
<tr>
<td>0</td>
<td>No †</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>T(0), cc0</td>
</tr>
<tr>
<td>0</td>
<td>No †</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>T(0), cc0</td>
</tr>
<tr>
<td>0 &lt; a ≤ MU</td>
<td>No</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>T(I), cc2</td>
</tr>
<tr>
<td>0 &lt; a ≤ MU</td>
<td>Yes</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>T(I), cc2</td>
</tr>
<tr>
<td>0 &lt; a ≤ MU</td>
<td>Yes</td>
<td>--</td>
<td>0</td>
<td>0</td>
<td>--</td>
<td>T(I), SFx←1, cc2</td>
</tr>
<tr>
<td>0 &lt; a ≤ MU</td>
<td>Yes</td>
<td>--</td>
<td>0</td>
<td>1</td>
<td>No</td>
<td>T(I), cc2, PIDx(08)</td>
</tr>
<tr>
<td>0 &lt; a ≤ MU</td>
<td>Yes</td>
<td>--</td>
<td>0</td>
<td>1</td>
<td>Yes</td>
<td>T(I), cc2, PIDy(0C)</td>
</tr>
<tr>
<td>MU &lt; a &lt; +∞, n = MU</td>
<td>--</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>T(MU), cc2</td>
</tr>
<tr>
<td>MU &lt; a &lt; +∞, n = MU</td>
<td>--</td>
<td>--</td>
<td>0</td>
<td>0</td>
<td>--</td>
<td>T(MU), SFx←1, cc2</td>
</tr>
<tr>
<td>MU &lt; a &lt; +∞, n = MU</td>
<td>--</td>
<td>--</td>
<td>0</td>
<td>1</td>
<td>--</td>
<td>T(MU), cc2, PIDx(08)</td>
</tr>
<tr>
<td>MU &lt; a &lt; +∞, n &gt; MU</td>
<td>--</td>
<td>0</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>T(MU), SFi←1, cc3</td>
</tr>
<tr>
<td>MU &lt; a &lt; +∞, n &gt; MU</td>
<td>--</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>--</td>
<td>T(MU), SFi←1, SFx←1, cc3 †</td>
</tr>
<tr>
<td>MU &lt; a &lt; +∞, n &gt; MU</td>
<td>--</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>--</td>
<td>T(MU), SFi←1, cc3, PIDx(08) †</td>
</tr>
<tr>
<td>MU &lt; a &lt; +∞, n &gt; MU</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>PIDi(80)</td>
</tr>
<tr>
<td>NaN</td>
<td>--</td>
<td>0</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>T(0), SFi←1, cc3</td>
</tr>
<tr>
<td>NaN</td>
<td>--</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>--</td>
<td>T(0), SFi←1, SFx←1, cc3 †</td>
</tr>
<tr>
<td>NaN</td>
<td>--</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>--</td>
<td>T(0), SFi←1, cc3, PIDx(08) †</td>
</tr>
<tr>
<td>NaN</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>PIDi(80)</td>
</tr>
</tbody>
</table>

Explanation:

- The results do not depend on this condition or mask bit.
- † This condition is true by virtue of the state of some condition to the left of this column.
- † Result differs from DFP CONVERT TO LOGICAL. The DFP instruction combines two cases as it does not recognize inexact for this case and does not test the inexact mask.
- ccn Condition code is set to n.
- f The value n converted to a fixed-point result.
- n The value derived when the source value (a) is rounded to a floating-point integer using the effective rounding method.
- MU Maximum unsigned number representable in the target fixed-point format.
- PIDc(h) Program interruption for data exception, condition c, with DXC of h in hex. Figure 19-10 on page 19-11.
- SFi IEEE invalid-operation flag, FPC 1.0.
- SFx IEEE inexact flag, FPC 1.4.
- T(x) The value x is placed at the target operand location.

Figure 19-19. Results: CONVERT TO LOGICAL
DIVIDE

Mnemonic1 R1,R2 [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>0</th>
<th>16</th>
<th>24</th>
<th>28</th>
<th>31</th>
</tr>
</thead>
</table>

Mnemonic1 Op Code Operands
DEBR "B30D" Short BFP
DDBR "B31D" Long BFP
DXBR "B34D" Extended BFP

Mnemonic2 R1,D1(X2,B2) [RXE]

|---------|----|----|----|----|---------|

Mnemonic2 Op Code Operands
DEB "ED0D" Short BFP
DDB "ED1D" Long BFP

The first operand (the dividend) is divided by the second operand (the divisor), and the quotient is placed at the first-operand location. No remainder is preserved.

If the divisor is nonzero and both the dividend and divisor are finite numbers, the first operand is divided by the second operand to form an intermediate quotient. The intermediate quotient, if nonzero, is rounded to the target format according to the current BFP rounding mode.

When the dividend is a finite number and the divisor is infinity, the result is zero.

The sign of the quotient, if the quotient is numeric, is the exclusive or of the operand signs. This includes the sign of a zero or infinite quotient.

If the divisor is zero but the dividend is a finite number, an IEEE-division-by-zero exception is recognized. If the dividend and divisor are both zero, or if both are infinity, regardless of sign, an IEEE-invalid-operation exception is recognized.

See Figure 19-20 on page 19-27 for a detailed description of the results of this instruction.

For DXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

### Results for DIVIDE (a+b) when Divisor (b) Is

<table>
<thead>
<tr>
<th>Dividend (a)</th>
<th>-∞</th>
<th>-Fn</th>
<th>-0</th>
<th>+0</th>
<th>+Fn</th>
<th>+∞</th>
<th>QNaN</th>
<th>SNaN</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞</td>
<td>X: T(dNaN)</td>
<td>T(+∞)</td>
<td>T(∞)</td>
<td>T(∞)</td>
<td>T(∞)</td>
<td>X: T(dNaN)</td>
<td>T(b)</td>
<td>X: T(b*)</td>
</tr>
<tr>
<td>-Fn</td>
<td>T(+0)</td>
<td>R(a+b)</td>
<td>X: T(+)</td>
<td>X: T(+)</td>
<td>R(a+b)</td>
<td>T(0)</td>
<td>T(b)</td>
<td>X: T(b*)</td>
</tr>
<tr>
<td>-0</td>
<td>T(+0)</td>
<td>T(+0)</td>
<td>X: T(dNaN)</td>
<td>X: T(dNaN)</td>
<td>T(0)</td>
<td>T(0)</td>
<td>T(b)</td>
<td>X: T(b*)</td>
</tr>
<tr>
<td>+0</td>
<td>T(0)</td>
<td>T(0)</td>
<td>X: T(dNaN)</td>
<td>X: T(dNaN)</td>
<td>T(0)</td>
<td>T(0)</td>
<td>T(b)</td>
<td>X: T(b*)</td>
</tr>
<tr>
<td>+Fn</td>
<td>T(0)</td>
<td>R(a+b)</td>
<td>X: T(+)</td>
<td>X: T(+)</td>
<td>R(a+b)</td>
<td>T(+)</td>
<td>T(b)</td>
<td>X: T(b*)</td>
</tr>
<tr>
<td>+∞</td>
<td>X: T(dNaN)</td>
<td>T(∞)</td>
<td>T(∞)</td>
<td>T(∞)</td>
<td>X: T(dNaN)</td>
<td>T(b)</td>
<td>X: T(b*)</td>
<td></td>
</tr>
<tr>
<td>QNaN</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
</tr>
<tr>
<td>SNaN</td>
<td>X: T(a*)</td>
<td>X: T(a*)</td>
<td>X: T(a*)</td>
<td>X: T(a*)</td>
<td>X: T(a*)</td>
<td>X: T(a*)</td>
<td>X: T(a*)</td>
<td>X: T(a*)</td>
</tr>
</tbody>
</table>

Explanation:
- The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
- Finite nonzero number (includes both subnormal and normal).
- R(v) Rounding and range action is performed on the value v. See Figure 19-8 on page 19-8.
- T(x) The value x is placed at the target operand location.
- Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.
- Xz: IEEE division-by-zero exception. The results shown are produced only when FPC 0.1 is zero.

IEEE Exceptions:
- Underflow
- Inexact

Figure 19-20. Results: DIVIDE

---

**IEEE Exceptions:**
- Invalid operation
- Division by zero
- Overflow
Program Exceptions:

- Access (fetch, operand 2 of DEB and DDB only)
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification (DXBR only)
- Transaction constraint

DIVIDE TO INTEGER

Mnemonic R₃,R₃,R₂,M₄ [RRF-b]

Op Code R₃ M₄ R₁ R₂

Mnemonic Op Code Operands
DIEB 'B353' Short BFP
DIDB 'B35B' Long BFP

The first operand (the dividend) is divided by the second operand (the divisor). An integer quotient in BFP form is produced and placed at the third-operand location. The remainder replaces the dividend at the first-operand location. The first, second, and third operands must be in different registers. The condition code indicates whether partial or final results have been produced.

The remainder result is

\[ r = a - b \cdot n \]

where \( a \) is the dividend, \( b \) the divisor, and \( n \) an integer obtained by rounding the precise quotient

\[ q = a \div b. \]

The first-operand result is \( r \) with the sign determined by the above expression. The third-operand result is \( n \) with a sign that is the exclusive or of the dividend and divisor signs.

If the precise quotient is not an integer and the two integers closest to this precise quotient cannot both be represented exactly in the precision of the quotient, then a partial quotient and partial remainder are formed. (In all other cases, a final quotient and final remainder are formed.) This partial quotient \( n \) and the corresponding partial remainder

\[ r = a - b \cdot n \]

are used as the results. The sign of a partial remainder is the same as the sign of the dividend. The sign of a partial quotient is the exclusive or of the dividend and divisor signs.

If the remainder is zero, then the precise quotient is an integer and can be represented exactly in the precision of the quotient.

The \( M₄ \) field, called the modifier field, specifies rounding of the final quotient. This rounding is called the “final-quotient-rounding method” as contrasted to the “current BFP rounding mode” specified by the BFP rounding-mode bits in the FPC register. The final quotient is rounded according to the final-quotient-rounding method. The final-quotient-rounding method affects only the final quotient; partial quotients are rounded toward zero.

Since the partial quotient is rounded toward zero, the partial remainder is always exact. For the final-quotient-rounding methods of round toward 0, round to nearest with ties to even, and round to nearest with ties away from 0, the final remainder is exact. For the final-quotient-rounding methods of round toward +∞ and round toward −∞, the final remainder may not be exact.

The final quotient is rounded to an integer by rounding as specified by the modifier in the \( M₄ \) field:

\[ M₄ \text{ Final-Quotient-Rounding Method} \]

0 According to current BFP rounding mode
1 Round to nearest with ties away from 0
3 Round to prepare for shorter precision
4 Round to nearest with ties to even
5 Round toward 0
6 Round toward +∞
7 Round toward −∞

When the floating-point extension facility is installed, a modifier of 2 and 8-15 is invalid. If the floating-point extension facility is not installed, a modifier of 2-3 and 8-15 is invalid.

When the modifier field is zero, rounding of the final quotient is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

Underflow is recognized only on the final remainder, not on the partial remainder.
For the final-quotient-rounding methods of round toward \( +\infty \), round toward \( -\infty \), and round to prepare for shorter precision, the final remainder may not be exact. When, in these cases, the final remainder is inexact, it is rounded according to the current BFP rounding mode specified in the FPC register.

The sign of a zero quotient is the exclusive or of the divisor and dividend signs.

A zero remainder has the sign of the dividend.

See Figure 19-21 on page 19-29 for a detailed description of the results of this instruction.

If the quotient exponent is greater than the largest exponent that can be represented in the operand format, the correct remainder or partial remainder still is produced, and the third-operand result is the correct value, but with the exponent reduced by 192 or 1536 for short or long operands, respectively. The condition code indicates this out-of-range condition.

If the \( M_4 \) field designates any of the following invalid modifier values: 2 and 8-15, then a specification exception is recognized. When the floating-point extension facility is not installed, if the \( M_4 \) field designates the invalid value \( 3 \), it is undefined whether a specification exception is recognized or an unpredictable rounding method is performed.

The \( R_1 \), \( R_2 \), and \( R_3 \) fields must designate different registers; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

- 0 Remainder final; normal quotient
- 1 Remainder final; quotient overflow or \( \text{NaN} \)
- 2 Remainder partial; normal quotient
- 3 Remainder partial; quotient overflow

**IEEE Exceptions:**

- Invalid operation
- Underflow
- Inexact

### Figure 19-21. Results: DIVIDE TO INTEGER (Part 1 of 2)

<table>
<thead>
<tr>
<th>Dividend ( (a) )</th>
<th>Results for DIVIDE TO INTEGER ((a + b)) when Divisor ((b)) Is</th>
<th>(-\infty)</th>
<th>(-Fn)</th>
<th>(-0)</th>
<th>(+0)</th>
<th>(+Fn)</th>
<th>(+\infty)</th>
<th>(\text{QNaN})</th>
<th>(\text{SNaN})</th>
</tr>
</thead>
<tbody>
<tr>
<td>(-\infty)</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>T(b), cc1</td>
<td>Xi: T(b*), cc1</td>
<td></td>
</tr>
<tr>
<td>(-Fn)</td>
<td>T(a, +0), cc0</td>
<td>D(a, b)</td>
<td>X: T(dNaN), cc1</td>
<td>X: T(dNaN), cc1</td>
<td>D(a, b)</td>
<td>T(a, -0), cc0</td>
<td>T(b), cc1</td>
<td>Xi: T(b*), cc1</td>
<td></td>
</tr>
<tr>
<td>(-0)</td>
<td>T(-0, +0), cc0</td>
<td>T(-0, +0), cc0</td>
<td>X: T(dNaN), cc1</td>
<td>X: T(dNaN), cc1</td>
<td>T(-0, -0), cc0</td>
<td>T(-0, -0), cc0</td>
<td>T(b), cc1</td>
<td>Xi: T(b*), cc1</td>
<td></td>
</tr>
<tr>
<td>(+0)</td>
<td>T(+0, -0), cc0</td>
<td>T(+0, -0), cc0</td>
<td>X: T(dNaN), cc1</td>
<td>X: T(dNaN), cc1</td>
<td>T(+0, +0), cc0</td>
<td>T(+0, +0), cc0</td>
<td>T(b), cc1</td>
<td>Xi: T(b*), cc1</td>
<td></td>
</tr>
<tr>
<td>(+Fn)</td>
<td>T(a, -0), cc0</td>
<td>D(a, b)</td>
<td>X: T(dNaN), cc1</td>
<td>X: T(dNaN), cc1</td>
<td>D(a, b)</td>
<td>T(a, +0), cc0</td>
<td>T(b), cc1</td>
<td>Xi: T(b*), cc1</td>
<td></td>
</tr>
<tr>
<td>(+\infty)</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>Xi: T(dNaN), cc1</td>
<td>T(b), cc1</td>
<td>Xi: T(b*), cc1</td>
<td></td>
</tr>
<tr>
<td>(\text{QNaN})</td>
<td>T(a), cc1</td>
<td>T(a), cc1</td>
<td>T(a), cc1</td>
<td>T(a), cc1</td>
<td>T(a), cc1</td>
<td>T(a), cc1</td>
<td>T(a), cc1</td>
<td>T(a), cc1</td>
<td></td>
</tr>
<tr>
<td>(\text{SNaN})</td>
<td>Xi: T(a*), cc1</td>
<td>Xi: T(a*), cc1</td>
<td>Xi: T(a*), cc1</td>
<td>Xi: T(a*), cc1</td>
<td>Xi: T(a*), cc1</td>
<td>Xi: T(a*), cc1</td>
<td>Xi: T(a*), cc1</td>
<td>Xi: T(a*), cc1</td>
<td></td>
</tr>
</tbody>
</table>

**Explanation:**

- The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
- Condition code is set to \( n \).
- D(a, b) Basic divide-to-integer results. See Part 2 of this figure.
- Fn Finite nonzero number (includes both subnormal and normal).
- T(r, q) Results \( r \) (the remainder) and \( q \) (the quotient) are placed in target operands 1 and 3, respectively.
- T(x) Value \( x \) is placed in both target operands 1 and 3.
- Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.
| $|q| < 2^P$ | $r = 0$ | Case | Is $r$ | Is $r$ | Underflow Mask (FPC 0.3) | Inexact mask (FPC 0.4) | Quotient Overflow | Is $r$ | Incremented | Results for $D(a,b)$ |
|---|---|---|---|---|---|---|---|---|---|---|
| Yes | Yes | Final | No | No | - | - | No | No | T($r,n$), cc0 |
| Yes | No | Final | No | No | - | - | No | No | T($r,n$), cc0 |
| Yes | No | Final | Yes | No | 0 | - | No | No | T($r,n$), cc0 |
| Yes | No | Final | Yes | No | 1 | - | No | No | T($r,n$), pidu(10) |
| Yes | No | Final | No | Yes | - | 0 | No | No | T($r,n$), sfx$\leftarrow 1$, cc0 |
| Yes | No | Final | No | Yes | - | 1 | No | No | T($r,n$), cc0, pidx(08) |
| Yes | No | Final | No | Yes | - | 1 | No | No | T($r,n$), cc0, pidy(0C) |
| No | Yes | Final | No | No | - | - | No | No | T($r,n$), cc0 |
| No | Yes | Final | No | No | - | - | Yes | No | T($r,n$), cc1 |
| No | No | Partial | -$^z$ | No | - | - | No | No | T($r,n$), cc2 |
| No | No | Partial | -$^z$ | No | - | - | Yes | No | T($r,n$), cc3 |

**Explanation:**

1. The results do not depend on this condition or mask bit.
2. This condition is true by virtue of the state of some condition to the left of this column. That is, when $|q| < 2^P$, there cannot be a quotient overflow; the cases of remainder is zero, tiny, or inexact are mutually exclusive; and when $r$ is exact, it is not incremented.
3. Underflow is not recognized for a partial remainder.
4. Each entry of this column is derived from the entries of the two left columns, and helps determine the specific rounding method used in some columns on the right and determine the resulting condition code setting.
5. Scale factor. For overflow, $\Psi = 2^{+\alpha}$. For underflow, $\Psi = 2^{-\alpha}$. The unsigned scaling exponent ($\alpha$) depends on the operand format and is 192 for short and 1536 for long.
6. The absolute value of $q$, where $q$ is the precise intermediate value of $a \cdot b$ before rounding, assuming unbounded precision and unbounded exponent range.
7. Condition code is set to 0 (remainder final; normal quotient).
8. Condition code is set to 1 (remainder final; quotient overflow).
9. Condition code is set to 2 (remainder partial; normal quotient).
10. Condition code is set to 3 (remainder partial; quotient overflow).
11. Integer quotient. $n = q$, rounded toward 0 for partial results and rounded according to the final-quotient-rounding method for final results. The sign of the integer quotient, including the cases of partial and final, scaled value, and zero, is the exclusive or of the signs of the dividend ($a$) and divisor ($b$).
12. Remainder. $r = a \cdot b \cdot n$. A partial remainder is always exact; no rounding is necessary. The sign of a partial remainder is always the same as the sign of the dividend ($a$). A final remainder is rounded according to the current BFP rounding mode (if necessary) specified in the FPC register. The sign of a zero remainder is the same as the sign of the dividend ($a$). The sign of a nonzero final remainder is determined by the rules of algebra.
13. Precision of the operand, which depends on the target format: $P = 24$ for short and 53 for long.
14. Program interruption for data exception, condition $c$, with DXC of $h$ in hex. See Figure 19-10 on page 19-11.
15. IEEE invalid-operation flag, FPC 1.0.
16. IEEE underflow flag, FPC 1.3.
17. IEEE inexact flag, FPC 1.4.
18. Results $r$ (the remainder) and $n$ (the integer quotient) are placed in target operands 1 and 3, respectively.

**Program Exceptions:**

- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification
- Transaction constraint

**Programming Notes:**

1. The Remainder operation, as defined in ANSI/IEEE Standard 754-2008, is produced by issuing DIVIDE TO INTEGER in an iterative loop, with the $M_4$ field set to 4.
2. The rounding specifications of round to nearest with ties to even, round toward 0, and round toward \(-\infty\) permit the instruction to be used directly to produce the Remainder, MOD, and modulo functions, respectively.

3. When DIVIDE TO INTEGER is used in an iterative loop, all quotients are produced in BFP format but may be considered as portions of a multiple-precision fixed-point number.

4. In the case when the resulting remainder is subnormal, ANSI/IEEE Standard 754-2008 requires that if traps are implemented and the underflow mask is one, then an underflow trap must occur. To accomplish this, DIVIDE TO INTEGER recognizes underflow on the final remainder but not on the partial remainder. Since in all cases when underflow exists on the partial remainder it will also exist on the final remainder, recognizing underflow on only the final remainder avoids two underflow traps to be reported for what ANSI/IEEE Standard 754-2008 considers a single Remainder operation.

**LOAD AND TEST**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>R1, R2</th>
<th>[RRE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R1</td>
<td>R2</td>
</tr>
</tbody>
</table>

The second operand is placed at the first-operand location, and its sign and magnitude are tested to determine the setting of the condition code. The condition code is set the same as for a comparison of the second operand with zero.

The second operand is placed unchanged at the first-operand location. If the second operand is an SNaN, an IEEE-invalid-operation exception is recognized; if there is no interruption, the result is the corresponding QNaN.

See Figure 19-17 on page 19-21 for a detailed description of the results of this instruction.

For LTXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**LOAD COMPLEMENT**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCEBR</td>
<td>'B303'</td>
<td>Short BFP</td>
</tr>
<tr>
<td>LCDBR</td>
<td>'B313'</td>
<td>Long BFP</td>
</tr>
<tr>
<td>LTXBR</td>
<td>'B343'</td>
<td>Extended BFP</td>
</tr>
</tbody>
</table>

The second operand is placed at the first-operand location with the sign bit inverted.

The sign bit is inverted even if the operand is zero. The rest of the second operand is placed unchanged at the first-operand location. The sign is inverted for any operand, including a QNaN or SNaN, without causing an IEEE exception.

For LTXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

| 0 | Result is zero |
| 1 | Result is less than zero |
| 2 | Result is greater than zero |
| 3 | Result is a NaN |

**IEEE Exceptions:**

- Invalid operation

**Program Exceptions:**

- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification (LTXBR only)
- Transaction constraint

**Programming Note:** LOAD AND TEST signals invalid operation when the operand is an SNaN. TEST DATA CLASS may be used to test an operand if signaling is not desired.
**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 2, BFP instruction
- Specification (LCXBR only)
- Transaction constraint

**Programming Note:** LOAD COMPLEMENT does not signal invalid operation when the operand is an SNaN. LOAD AND TEST may be used in conjunction with this instruction if signaling is desired.

### LOAD FP INTEGER

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>Op Code</th>
<th>R1, R2, M3</th>
<th>[RRF-e]</th>
</tr>
</thead>
<tbody>
<tr>
<td>FIEBR</td>
<td>'B357'</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FIDBR</td>
<td>'B35F'</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FIXBR</td>
<td>'B347'</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2</th>
<th>Op Code</th>
<th>R1, R2, M3, M4</th>
<th>[RRF-e]</th>
</tr>
</thead>
<tbody>
<tr>
<td>FIEBRA</td>
<td>'B357'</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FIDBRA</td>
<td>'B35F'</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FIXBRA</td>
<td>'B347'</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The second operand is rounded to an integer value in the same floating-point format, and the result is placed at the first-operand location.

The second operand, if a finite number, is rounded to an integer value as specified by the modifier in the M3 field:

**M3 Effective Rounding Method**
- 0: According to current BFP rounding mode
- 1: Round to nearest with ties away from 0
- 2: Round to prepare for shorter precision
- 3: Round to nearest with ties to even
- 4: Round toward 0
- 5: Round toward \(+\infty\)
- 6: Round toward \(-\infty\)

An M3 modifier other than 0, 1, or 3-7 is invalid. If the floating-point extension facility is not installed, an M3 modifier of 3 is also invalid.

When the M3 modifier field is zero, rounding is controlled by the current BFP rounding mode in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

In the absence of an interruption, if the second operand is an infinity or a QNaN, the result is that operand; if the second operand is an SNaN, the result is the corresponding QNaN.

The sign of the result is the sign of the second operand, even when the result is zero.

When the floating-point extension facility is installed, bit 1 of the M4 field is the IEEE-inexact-exception control (XxC). Bits 0, 2, and 3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

When the floating-point extension facility is not installed and if bits 20-23 of the instruction are zeros, recognition of IEEE-inexact exception is not suppressed; when the floating-point extension facility is not installed and if bits 20-23 of the instruction contain a nonzero value, it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

See Figure 19-22 on page 19-33 for a detailed description of the results of this instruction.

If the M3 field designates any of the following invalid modifier values: 2 and 8-15, then a specification exception is recognized. When the floating-point extension facility is not installed, if the M3 field designates the invalid value 3, it is undefined whether a specification exception is recognized or an unpredictable rounding method is performed.

For FIXBRA and FIXBRA, the R fields must designate valid floating-point-register pairs. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid operation
- Inexact

**Program Exceptions:**
- Data with DXC 2, BFP instruction
Programming Notes:

1. **LOAD FP INTEGER** rounds a BFP number to an integer value. These integers, which remain in the BFP format, should not be confused with binary integers, which have a fixed-point format.

2. If the BFP operand is a finite number with a large enough exponent so that it is already an integer, the result value remains the same.

3. Unassigned bits in the M4 field are reserved for future extensions and should be set to zeros; otherwise the program may not operate compatibly in the future.

| Operand (a) | Is n Inexact (n≠a) | Inv.-Op. Mask (FPC 0.0) | IEEE Inexact Exception Control (XxC)² | Inexact Mask (FPC 0.4) | Is n Incremented (|n|>|a|) | Results |
|-------------|--------------------|-------------------------|---------------------------------------|------------------------|---------------------------|---------|
| -∞          | No¹                | –                       | –                                     | –                      | –                         | T(−∞)   |
| -Fn         | No                 | –                       | –                                     | –                      | –                         | T(n)    |
| -Fn         | Yes                | –                       | 1                                     | –                      | –                         | T(n)    |
| -Fn         | Yes                | –                       | 0                                     | 0                      | –                         | T(n), SFx<1 |
| -Fn         | Yes                | –                       | 0                                     | 1                      | No                        | T(n), PIDx(08) |
| -Fn         | Yes                | –                       | 0                                     | 1                      | Yes                       | T(n), PIDy(0C) |
| 0           | No¹                | –                       | –                                     | –                      | –                         | T(0)    |
| +0          | No¹                | –                       | –                                     | –                      | –                         | T(+0)   |
| +Fn         | No                 | –                       | –                                     | –                      | –                         | T(n)    |
| +Fn         | Yes                | –                       | 1                                     | –                      | –                         | T(n)    |
| +Fn         | Yes                | –                       | 0                                     | 0                      | –                         | T(n), SFx<1 |
| +Fn         | Yes                | –                       | 0                                     | 1                      | No                        | T(n), PIDx(08) |
| +∞          | No¹                | –                       | –                                     | –                      | –                         | T(+∞)   |
| QNaN        | No                 | –                       | –                                     | –                      | –                         | T(a)    |
| SNaN        | No¹                | 0                       | –                                     | –                      | –                         | T( a*), SFx<1 |
| SNaN        | No¹                | 1                       | –                                     | –                      | –                         | PIDy(08) |

Explanation:

- The results do not depend on this condition or mask bit.
- The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
- This condition is true by virtue of the state of some condition to the left of this column.
- XxC is defined only if the Floating-point extension facility is installed.
- The value derived when the source value, a, is rounded to a floating-point integer using the effective rounding mode.
- Fn Finite nonzero number (includes both subnormal and normal).
- PIDc(h) Program interruption for data exception, condition c, with DXC of h in hex. See Figure 19-10 on page 19-11.
- SFi IEEE invalid-operation flag, FPC 1.0.
- SFx IEEE inexact flag, FPC 1.4.
- T(x) The value x is placed at the target operand location.

*Figure 19-22. Results: LOAD FP INTEGER*
LOAD NEGATIVE

The second operand is converted to a longer format, and the result is placed at the first-operand location.

When the second operand is a finite number, the value of the second operand is placed in the target format. The exponent of the second operand is converted to the corresponding exponent in the result format, and the fraction is extended by appending zeros on the right.

If the second operand is an infinity, the result is an infinity of the same sign. If the second operand is an SNaN, an IEEE-invalid-operation exception is recognized; if there is no interruption, the result is the corresponding QNaN with the fraction extended.

The sign of the result is the same as the sign of the source.

See Figure 19-17 on page 19-21 for a detailed description of the results of this instruction.

For LXDB, LXDBR, LXEB, and LXEBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Resulting Condition Code:

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Result is zero</td>
</tr>
<tr>
<td>1</td>
<td>Result is less than zero</td>
</tr>
<tr>
<td>2</td>
<td>--</td>
</tr>
<tr>
<td>3</td>
<td>Result is a NaN</td>
</tr>
</tbody>
</table>

IEEE Exceptions: None.

Program Exceptions:

- Data with DXC 2, BFP instruction
- Specification (LNXBR only)
- Transaction constraint

Programming Note: LOAD NEGATIVE does not signal invalid operation when the operand is an SNaN. LOAD AND TEST may be used in conjunction with this instruction if signaling is desired.
LOAD POSITIVE

Mnemonic | R1, R2 | [RRE]
----------|--------|------

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

Mnemonic | Op Code | Operands
----------|---------|------
LPEBR     | 'B300'  | Short BFP
LPDBR     | 'B310'  | Long BFP
LPXBR     | 'B340'  | Extended BFP

The second operand is placed at the first-operand location with the sign bit made zero.

The sign bit is made zero, and the rest of the second operand is placed unchanged at the first-operand location. The sign is set for any operand, including a QNaN or SNaN, without causing an IEEE exception.

For LPXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Resulting Condition Code:

0  Result is zero
1  --
2  Result is greater than zero
3  Result is a NaN

IEEE Exceptions:  None.

Program Exceptions:

- Data with DXC 2, BFP instruction
- Specification (LPXBR only)
- Transaction constraint

Programming Note: LOAD POSITIVE does not signal invalid operation when the operand is an SNaN. LOAD AND TEST may be used in conjunction with this instruction if signaling is desired.

LOAD ROUNDED

Mnemonic | R1, R2 | [RRE]
----------|--------|------

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

Mnemonic1 | Op Code | Operands
-----------|---------|------
LEDBR     | 'B344'  | Long BFP source, short BFP target, short or long BFP result
LDXBR     | 'B345'  | Extended BFP source, long BFP target, long or extended BFP result
LEXBR     | 'B346'  | Extended BFP source, short BFP target, short or extended BFP result

Mnemonic2 | R1, M3, R1, M4 | [RRF-e]
-----------|-----------------|------

<table>
<thead>
<tr>
<th>Op Code</th>
<th>M3</th>
<th>M4</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
<td>28</td>
<td>31</td>
</tr>
</tbody>
</table>

Mnemonic2 | Op Code | Operands
-----------|---------|------
LEDBRA    | 'B344'  | Long BFP source, short BFP target, short or long BFP result
LDXBR     | 'B345'  | Extended BFP source, long BFP target, long or extended BFP result
LEXBRA    | 'B346'  | Extended BFP source, short BFP target, short or extended BFP result

The second operand, in the format of the source, is rounded to the precision of the target, and the result is placed at the first-operand location.

When the floating-point extension facility is installed, the second operand, if a finite number, is rounded by rounding as specified by the modifier in the M3 field:

M3 Effective Rounding Method
0  According to current BFP rounding mode
1  Round to nearest with ties away from 0
3  Round to prepare for shorter precision
4  Round to nearest with ties to even
5  Round toward 0
6  Round toward +\infty
7  Round toward -\infty

An M3 modifier other than 0, 1, or 3-7 is invalid. The M3 field must designate a valid modifier; otherwise, a specification exception is recognized.

When the M3 modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.
When the floating-point extension facility is not installed and bits 16-19 of the instruction contain a value of zero, the second operand is rounded according to the current BFP rounding mode. When the floating-point extension facility is not installed and bits 16-19 of the instruction contain a nonzero value, it is undefined whether a specification exception is recognized or an unpredictable rounding method is performed.

In the absence of IEEE-trap action for overflow or underflow, the result is in the format and length of the target. However, when an IEEE overflow or an IEEE underflow is recognized and the corresponding mask bit is one, the operation is completed by producing a scaled result in the same format and length as the source but rounded to the precision of the target. For LEDBR, LEDBRA, LEXBR and LEXBRA, the result has at most 23 significand fraction bits; for LDXBR and LDXBRA, the result has at most 52 significand fraction bits.

A short-format result replaces the leftmost 32 bits of the target register, and the rightmost 32 bit positions of the target register remain unchanged. A long-format result is placed in a floating-point register, and the other register of the floating-point register pair, if any, remains unchanged. An extended-format result is placed in a floating-point register pair.

The sign of the result is the same as the sign of the second operand.

When the floating-point extension facility is installed, bit 1 of the M4 field is the IEEE-inexact-exception control (XxC). Bits 0, 2, and 3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

When the floating-point extension facility is not installed and if bit 21 of the instruction is zero, recognition of IEEE-inexact exception is not suppressed; when the floating-point extension facility is not installed and if bit 21 of the instruction is one, then it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

See Figure 19-17 on page 19-21 for a detailed description of the results of this instruction.

For LDXBR, LDXBRA, LEXBR, and LEXBRA, the R1 and R2 fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid operation
- Overflow
- Underflow
- Inexact

**Program Exceptions:**
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification
- Transaction constraint

**Programming Notes:**
1. The sign of the rounded result is the same as the sign of the operand, even when the result is zero.
2. The R1 field for LDXBR, LDXBRA, LEXBR, and LEXBRA must designate a valid floating-point-register pair since in certain cases the result is in the extended format. In normal operation for LDXBR, LDXBRA, LEXBR and LEXBRA, the result format is long or short, respectively, and this result replaces the leftmost 32 bits or 64 bits of the target-register pair. However, when an IEEE overflow or an IEEE underflow is recognized and the corresponding mask bit is one, the operation is completed by placing a result in the extended format at the target location. Thus, the program must take into account the fact that these instructions sometimes update both registers of the pair.
3. Unassigned bits in the M4 field are reserved for future extensions and should be set to zeros; otherwise the program may not operate compatibly in the future.
MULTIPLY

Mnemonic1  R1, R2  [RRE]

Op Code  [ ]  R1  R2

0  16  24  28  31

Mnemonic1  Op Code  Operands
MEEBR  'B317'  Short BFP
MDBR  'B31C'  Long BFP
MXBR  'B34C'  Extended BFP
MDEBR  'B30C'  Short BFP multiplier and multiplicand, long BFP product
MXDBR  'B307'  Long BFP multiplier and multiplicand, extended BFP product

Mnemonic2  R1, D2(X2, B2)  [RXE]

Op Code  [ ]  R1  X2  B2  D2

0  8  12  16  20  32  40  47

Mnemonic2  Op Code  Operands
MEEB  'ED17'  Short BFP
MDB  'ED1C'  Long BFP
MDEB  'ED0C'  Short BFP multiplier and multiplicand, long BFP product
MXDB  'ED07'  Long BFP multiplier and multiplicand, extended BFP product

The product of the second operand (the multiplier) and the first operand (the multiplicand) is placed at the first-operand location.

The two BFP operands, if finite numbers, are multiplied, forming an intermediate product. For MDEB, MDEBR, MXDB, and MXDBR, the intermediate product is converted to the longer target format; the result cannot overflow or underflow and is exact. For MDB, MDBR, MEEB, MEEBR, and MXBR, the result is rounded to the operand format according to the current BFP rounding mode. For MEEB and MEEBR, the result, as for all short-format results, replaces the leftmost 32 bits of the target register, and the rightmost 32 bit positions of the target register remain unchanged.

The sign of the product, if the product is numeric, is the exclusive or of the operand signs. This includes the sign of a zero or infinite product.

If one operand is a zero and the other an infinity, an IEEE-invalid-operation exception is recognized.

See Figure 19-23 on page 19-38 for a detailed description of the results of this instruction.

The R1 field for MXDB, MXDBR, and MXBR, and the R2 field for MXBR, must designate valid floating-point-register pairs. Otherwise, a specification exception is recognized.

Condition Code:  The code remains unchanged.

IEEE Exceptions:

- Invalid operation
- Overflow (MDB, MDBR, MEEB, MEEBR, MXBR)
- Underflow (MDB, MDBR, MEEB, MEEBR, MXBR)
- Inexact (MDB, MDBR, MEEB, MEEBR, MXBR)

Program Exceptions:

- Access (fetch, operand 2 of MDEB, MEEB, MDB, and MXDB only)
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification (MXDB, MXDBR, MXBR)
- Transaction constraint

Programming Note: Interchanging the two operands in a BFP multiplication does not affect the value of the product when the result is numeric. This is not true, however, when both operands are QNaNs, in which case the result is the first operand; or when both operands are SNaNs and the IEEE-invalid-operation mask bit in the FPC register is zero, in which case the result is the QNaN derived from the first operand.
MULTIPLY AND ADD

**Mnemonic1** | **R_{1},R_{2},R_{3}** | **[RRD]**
---|---|
**Op Code** | **R_{1}** | **////** | **R_{3}** | **R_{2}**

**Mnemonic1 Op Code** | **Operands**
---|---
MAEBR | 'B30E' | Short BFP
MADBR | 'B31E' | Long BFP

**Mnemonic2** | **R_{1},R_{3},D_{2}(X_{2},B_{2})** | **[RXF]**
---|---|
**Op Code** | **R_{3}** | **X_{2}** | **B_{2}** | **D_{2}** | **R_{1}** | **////** | **Op Code**

**Mnemonic2 Op Code** | **Operands**
---|---
MSEB | 'ED0E' | Short BFP
MSDB | 'ED1E' | Long BFP

**MULTIPLY AND SUBTRACT**

**Mnemonic1** | **R_{1},R_{2},R_{3}** | **[RRD]**
---|---|
**Op Code** | **R_{1}** | **////** | **R_{3}** | **R_{2}**

**Mnemonic1 Op Code** | **Operands**
---|---
MAEBR | 'B30F' | Short BFP
MSDBR | 'B31F' | Long BFP

The third operand is multiplied by the second operand, and then the first operand is added to or subtracted from the product. The sum or difference is placed at the first-operand location. The MULTIPLY AND ADD and MULTIPLY AND SUBTRACT operations may be summarized as:

\[ \text{op}_1 = \text{op}_2 \times \text{op}_3 \pm \text{op}_1 \]

When the operands are finite numbers, the third and second BFP operands are multiplied, forming an intermediate product, and the first operand is then added (or subtracted) algebraically to (or from) the intermediate product, forming an intermediate sum. The intermediate sum, if nonzero, is rounded to the operand format according to the current BFP rounding mode and then placed at the first-operand location. The exponent and fraction of the intermediate product are maintained exactly; rounding and range checking occur only on the intermediate sum.

See Figure 19-24 for a detailed description of the results of MULTIPLY AND ADD. The results of MUL-
MULTIPLY AND SUBTRACT are the same, except that the first operand, if numeric, participates in the operation with its sign bit inverted. When the first operand is a NaN, it participates in the operation with its sign bit unchanged.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid operation
- Overflow
- Underflow
- Inexact

**Program Exceptions:**
- Access (fetch, operand 2 of MAEB, MADB, MSEB, MSDB)
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Transaction constraint

**Programming Note:** MULTIPLY AND ADD and MULTIPLY AND SUBTRACT produce a precise intermediate value, and a single rounding operation is performed after the addition or subtraction. This definition is consistent with the Power architecture, and, in certain applications, can be used to great advantage, especially in algorithms used in math libraries.
**SQUARE ROOT**

**Mnemonic1** R1,R2 | [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>0 16 24 28 31</th>
</tr>
</thead>
</table>

**Mnemonic1 Op Code Operands**

SQEBR 'B314' Short BFP
SQDBR 'B315' Long BFP
SQXBR 'B316' Extended BFP

**Mnemonic2** R1,D2(X2,B2) | [RXE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>0 8 12 16 20 32 40 47</th>
</tr>
</thead>
</table>

**Mnemonic2 Op Code Operands**

SQEB 'ED14' Short BFP
SQDB 'ED15' Long BFP

The square root of the second operand is placed at the first-operand location.

The result rounded according to the current BFP rounding mode is placed at the first-operand location.

If the second operand is a positive finite number, the result is the square root of that number with a plus sign. If the operand is a zero of either sign, the result is a zero of the same sign. If the operand is +\(\infty\), the result is +\(\infty\).

If the second operand is less than zero, an IEEE-invalid-operation exception is recognized.

See Figure 19-17 on page 19-21 for a detailed description of the results of this instruction.

For SQXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**

- Invalid operation
- Inexact

---

**SUBTRACT**

**Mnemonic1** R1,R2 | [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>0 16 24 28 31</th>
</tr>
</thead>
</table>

**Mnemonic1 Op Code Operands**

SEBR 'B30B' Short BFP
SDBR 'B31B' Long BFP
SXBR 'B34B' Extended BFP

**Mnemonic2** R1,D2(X2,B2) | [RXE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>0 8 12 16 20 32 40 47</th>
</tr>
</thead>
</table>

**Mnemonic2 Op Code Operands**

SEB 'ED0B' Short BFP
SDB 'ED1B' Long BFP

The second operand is subtracted from the first operand, and the difference is placed at the first-operand location.

The execution of SUBTRACT is identical to that of ADD, except that the second operand, if numeric, participates in the operation with its sign bit inverted. When the second operand is a NaN, it participates in the operation with its sign bit unchanged. See Figure 19-13 on page 19-16 for the detailed results of ADD.

For SXBR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0 Result is zero
1 Result is less than zero
2 Result is greater than zero
3 Result is a NaN

**IEEE Exceptions:**
• Invalid operation
• Overflow
• Underflow
• Inexact

**Program Exceptions:**

- Access (fetch, operand 2 of SEB and SDB only)
- Data with DXC 2, BFP instruction
- Data with DXC for IEEE exception
- Specification (SXBR only)
- Transaction constraint

**TEST DATA CLASS**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCEB</td>
<td>ED10</td>
<td>Short BFP</td>
</tr>
<tr>
<td>TCDB</td>
<td>ED11</td>
<td>Long BFP</td>
</tr>
<tr>
<td>TCXB</td>
<td>ED12</td>
<td>Extended BFP</td>
</tr>
</tbody>
</table>

The class and sign of the first operand are examined to select one bit from the second-operand address. Condition code 0 or 1 is set according to whether the selected bit is zero or one, respectively.

The second-operand address is not used to address data; instead, the rightmost 12 bits of the address, bits 52-63, are used to specify 12 combinations of BFP data class and sign. Bits 0-51 of the second-operand address are ignored.

As shown in Figure 19-25, BFP operands are divided into six classes: zero, normal number, subnormal number, infinity, quiet NaN, and signaling NaN.

One or more of the second-operand-address bits may be set to one. If the second-operand-address bit corresponding to the class and sign of the first operand is one, condition code 1 is set; otherwise, condition code 0 is set.

<table>
<thead>
<tr>
<th>BFP Operand Class</th>
<th>Bit Used when Sign Is</th>
</tr>
</thead>
<tbody>
<tr>
<td>Zero</td>
<td>+</td>
</tr>
<tr>
<td>Normal number</td>
<td>+ 54</td>
</tr>
<tr>
<td>Subnormal number</td>
<td>+ 56</td>
</tr>
<tr>
<td>Infinity</td>
<td>+ 58</td>
</tr>
<tr>
<td>Quiet NaN</td>
<td>- 60</td>
</tr>
<tr>
<td>Signaling NaN</td>
<td>- 62</td>
</tr>
</tbody>
</table>

Figure 19-25. Second-Operand-Address Bits for TEST DATA CLASS

Operands, including SNaNs and QNaNs, are examined without causing an IEEE exception.

For TCXB, the R1 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0  Selected bit is 0 (no match)
1  Selected bit is 1 (match)
2  --
3  --

**IEEE Exceptions:** None.

**Program Exceptions:**

- Data with DXC 2, BFP instruction
- Specification (TCXB only)
- Transaction constraint

**Programming Notes:**

1. TEST DATA CLASS provides a way to test an operand without risk of an exception or setting the IEEE flags.
2. The bits used to specify the combinations of data class and sign are not all the same for BFP and DFP. Specifically, DFP TEST DATA CLASS uses bits 54 and 55 for subnormal number, and bits 56 and 57 for normal number.
Chapter 20. Decimal-Floating-Point Instructions

Decimal-Floating-Point Facility .......................... 20-1
DFP Arithmetic ........................................... 20-2
Finite Floating-Point Number ......................... 20-2
  Cohort .................................................. 20-2
  Quantum ............................................... 20-2
Preferred Quantum ................................. 20-2
Scaled Preferred Quantum ............... 20-3
Delivered Quantum ............................... 20-3
Special Quantum-Handling Operations .... 20-3
DFP Data Formats ...................................... 20-3
  DFP Short Format ................................. 20-3
  DFP Long Format ................................. 20-3
  DFP Extended Format ......................... 20-4
Sign .................................................... 20-4
Combination .......................................... 20-4
Encoded Trailing Significand ................ 20-5
Values of Finite Numbers ............... 20-5
  Significand ...................................... 20-5
DFP Significant Digits ....................... 20-5
Canonical Declets .................................. 20-6
DFP Canonical Data ................................ 20-6
Classes of DFP Data .............................. 20-6
  Zeros .............................................. 20-6
Subnormal Numbers ......................... 20-6
Normal Numbers .................................... 20-7
Infinities ............................................. 20-7
  Signaling and Quiet NaNs ........................ 20-7
  Canonicalization .............................. 20-7
DFP-Format Conversion ......................... 20-7
DFP Rounding ......................................... 20-7
DFP Comparison ....................................... 20-7
DFP Formatting Instructions ............... 20-7
  Signed-Packed-Decimal Format .............. 20-8
  Unsigned-Packed-Decimal Format .......... 20-8
Zoned-Decimal Format ....................... 20-8
IEEE Exceptions ................................. 20-9
Summary of Preferred Quantum ........ 20-9
Summary of Rounding And Range Actions . 20-10
Result Figures ........................................ 20-14

Data-Exception Codes (DXC) and
Abbreviations ...................................... 20-14
Instructions ........................................... 20-15
  ADD .............................................. 20-18
  COMPARE ....................................... 20-20
  COMPARE AND SIGNAL ............................. 20-22
  COMPARE BIASED EXPONENT ...................... 20-22
  CONVERT FROM FIXED .......................... 20-23
  CONVERT FROM LOGICAL ...................... 20-24
  CONVERT FROM PACKED ...................... 20-25
  CONVERT FROM SIGNED PACKED ............. 20-27
  CONVERT FROM UNSIGNED PACKED .......... 20-27
  CONVERT FROM ZONED .......................... 20-28
  CONVERT TO FIXED ............................ 20-28
  CONVERT TO LOGICAL ....................... 20-31
  CONVERT TO PACKED ...................... 20-32
  CONVERT TO SIGNED PACKED ............ 20-34
  CONVERT TO UNSIGNED PACKED .......... 20-34
  CONVERT TO ZONED .......................... 20-35
  DIVIDE ........................................ 20-36
  EXTRACT BIASED EXPONENT .................. 20-38
  EXTRACT SIGNIFICANCE .................... 20-38
  INSERT BIASED EXPONENT .................. 20-39
  LOAD AND TEST .............................. 20-40
  LOAD FP INTEGER ......................... 20-41
  LOAD LENGTHENED .......................... 20-44
  LOAD ROUNDED ............................... 20-45
  MULTIPLIER ................................. 20-46
  QUANTIZE ...................................... 20-48
  REROUND ...................................... 20-51
  SHIFT SIGNIFICAND LEFT .................. 20-53
  SHIFT SIGNIFICAND RIGHT ................ 20-53
  SUBTRACT ..................................... 20-54
  TEST DATA CLASS .......................... 20-55
  TEST DATA GROUP .......................... 20-56
  Densely Packed Decimal (DPD) ............ 20-57
  Decimal-to-DPD Mapping .................. 20-57
  DPD-to-Decimal Mapping .................. 20-57

Decimal-Floating-Point Facility

The decimal-floating-point (DFP) facility provides instructions to operate on decimal (radix-10) floating-point data. The facility was designed in cooperation with the IEEE floating-point working group.

Additionally, this facility was designed to support a common library for various systems. This facility in both the z/architecture and Power architectures supports the same data formats, the same rounding methods, the same functions, and the same exceptions.

DFP has a number of important characteristics:
The DFP computational model, a high-level overview of the computational steps, is described in the section "IEEE Computational Operations" of Chapter 9, "Floating-Point Overview and Support Instructions." Detailed definitions of rounding methods and IEEE exceptions supported by DFP are also described in the section.

**DFP Arithmetic**

**Finite Floating-Point Number**

A finite floating-point number has three components: a sign, an exponent, and a significand. The magnitude of a finite number is the product of significand multiplied by the radix raised to the power of the exponent. The number is positive or negative depending on whether the sign bit is zero or one, respectively.

**Cohort**

Finite decimal-floating-point (DFP) numbers are not necessarily normalized; that is, the leftmost significand digit may be zero. This allows some values to have multiple representations; each with a different combination of the significand and the exponent. The set of different representations for a value of the same sign is called a cohort; and each representation in a cohort is called a cohort member. A positive zero and a negative zero have the same value but are in different cohorts.

**Quantum**

For a DFP finite number, the magnitude of a value of one in the rightmost digit position of the significand is called the quantum. Each cohort member of a cohort uses a different quantum to represent the same value. Regardless of whether the left-units view or right-units view is taken, the quantum of a cohort member is the same.

**Preferred Quantum**

For operations that produce a DFP result, when, in the absence of a trap overflow or a trap underflow, the delivered value is a finite number, a value, called the preferred quantum, is defined to select a cohort member to represent the delivered value. The preferred quantum for each of these operations is shown in Figure 20-4 on page 20-9. When the delivered value is exact, the preferred quantum depends on the

---

- It produces results consistent with decimal arithmetic as taught in elementary school.
- It recognizes the quantum of a finite number, maintains quantum information through arithmetic operations, and provides special operations to extract, compare, and adjust the quantum.
- It provides greater exponent range than hexadecimal-floating-point (HFP) and binary-floating-point (BFP) while maintaining comparable precision.
- It provides greater precision and better space efficiency than provided by the decimal-arithmetic instructions and the packed-decimal format as described in Chapter 8, “Decimal Instructions.”
- It supports IEEE flags, exceptions, and special entities of “infinity” and “Not-a-Number” (NaN).
- It supports eight automatic rounding methods. For DFP computational instructions, an explicit rounding method can be specified in a modifier field in the instruction.
- It facilitates production of DFP results with a precision other than any supported format precision and with the effect of single rounding.
- It provides operations for conversion between fixed-point and DFP formats.
- It provides operations for conversion between packed-decimal and DFP formats.
- It provides three-operand nondestructive arithmetic operations by permitting different target-operand registers from source-operand registers.

The DFP facility uses the same 16 floating-point registers as those used by HFP and BFP. A set of radix-independent floating-point-support instructions can be used to load, store, or change the sign of a DFP operand. These instructions are defined in Chapter 9, “Floating-Point Overview and Support Instructions.”

The DFP facility uses the same floating-point-control (FPC) register as that used by BFP. The bits of the FPC register are often referred to as, for example, FPC1.0, meaning bit 0 of byte 1 of the register. The description of the FPC register, including the DFP-rounding-mode field, and the instructions that operate on the FPC register are provided in Chapter 9, “Floating-Point Overview and Support Instructions.”

---

**Finite decimal-floating-point (DFP) numbers are not necessarily normalized; that is, the leftmost significand digit may be zero. This allows some values to have multiple representations; each with a different combination of the significand and the exponent. The set of different representations for a value of the same sign is called a cohort; and each representation in a cohort is called a cohort member. A positive zero and a negative zero have the same value but are in different cohorts.**
operation. When the delivered value is inexact, the preferred quantum is the smallest quantum of the cohort members, unless otherwise stated.

**Scaled Preferred Quantum**

For operations that produce a DFP result, when a trap overflow or a trap underflow occurs, a scaled preferred quantum is used to select a cohort member to represent the delivered value. The scaled preferred quantum is obtained by scaling the preferred quantum using the same scale factor as that used to obtain the delivered value.

**Delivered Quantum**

Normally, when the delivered value is a finite number, the result is selected from the cohort for the delivered value in the target format. However, in case of a trap overflow or trap underflow for LOAD ROUNDED, the result is selected from a subset of the cohort for the delivered value in the source format. This subset of the cohort consists of cohort members that have the number of DFP significand digits equal to or less than the precision of the target format.

In the absence of a trap overflow or trap underflow, if the delivered value is a finite number, the cohort member with the quantum closest to the preferred quantum is selected.

In case of a trap overflow or trap underflow, the cohort member with the quantum closest to the scaled preferred quantum is selected.

**Special Quantum-Handling Operations**

Special operations are provided to handle the quantum: COMPARE BIASED EXPONENT can be used to compare two quanta; EXTRACT BIASED EXPONENT can be used to determine the quantum of a finite number; and QUANTIZE can be used to adjust the quantum of a finite number.

**Programming Notes:**

1. Many financial applications and commercial databases use scaled integer representation of decimal data. Calculations are carried out by using integer arithmetic and scaling factors are tracked separately; the scaling factor is often an attribute of a column in the database.

This computational model can be supported by DFP by allowing the integer part of decimal data to map into the significand with a right-units view and the scaling factor to map into the quantum.

2. The term coefficient is used in some other documents to mean an integer value in significand; that is, significand in right-units view.

**DFP Data Formats**

Decimal-floating-point data may be represented in any of three data formats: short, long, or extended.

The contents of each data format represent encoded information. Special codes are assigned to distinguish finite numbers from NaNs and infinities.

For finite numbers, a biased exponent is used in the format. For each format, a different bias is used for right-units-view (RUV) exponents from that for left-units-view (LUV) exponents. The biased exponents are unsigned numbers and all biases are shown in Figure 20-3 on page 20-6. The biased exponent is encoded with the leftmost digit (LMD) of the significand in the combination field. The remaining digits of the significand are encoded in the encoded trailing-significand field.

**DFP Short Format**

When an operand in the DFP short format is loaded into a floating-point register, it occupies the left half of the register, and the right half remains unchanged.

**DFP Long Format**

When an operand in the DFP long format is loaded into a floating-point register, it occupies the entire register.
An operand in the DFP extended format occupies a register pair. The leftmost 64 bits occupy the entire lower-numbered register of the pair and the rightmost 64 bits occupy the entire higher-numbered register.

The properties of the three formats are tabulated in Figure 20-3 on page 20-6.

**Sign**
The sign bit is in bit 0 of each format, and is zero for plus and one for minus.

**Combination**
For finite numbers, this field contains the biased exponent and the leftmost digit of the significand; for NaNs and infinities, this field contains codes to identify them.

When bits 1-5 of the format are in the range of 00000 - 11101, the operand is a finite number. The two leftmost bits of the biased exponent and the leftmost digit of the significand are encoded in bits 1-5 of the format. Bit 6 through the end of the combination field contain the rest of the biased exponent.

When bits 1-5 of the format field are 11110, the operand is an infinity. All bits in the combination field to the right of bit 5 of the format constitute the reserved field for infinity. A nonzero value in the reserved field is accepted in a source infinity; the reserved field is set to zero in a resultant infinity.

When bits 1-5 of the format are 11111, the operand is a NaN and bit 6, called the SNaN bit, further distinguishes QNaN from SNaN. If bit 6 is zero, then it is QNaN; otherwise, it is SNaN. All bits in the combination field to the right of bit 6 of the format constitute the reserved field for NaN. A nonzero value in the reserved field is accepted in a source NaN; the reserved field is set to zero in a resultant NaN.

---

### DFP Extended Format

<table>
<thead>
<tr>
<th>Bits</th>
<th>Combination</th>
<th>Encoded Trailing Significand</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>31</td>
<td></td>
<td></td>
</tr>
<tr>
<td>32</td>
<td></td>
<td></td>
</tr>
<tr>
<td>33</td>
<td></td>
<td></td>
</tr>
<tr>
<td>34</td>
<td></td>
<td></td>
</tr>
<tr>
<td>35</td>
<td></td>
<td></td>
</tr>
<tr>
<td>36</td>
<td></td>
<td></td>
</tr>
<tr>
<td>37</td>
<td></td>
<td></td>
</tr>
<tr>
<td>38</td>
<td></td>
<td></td>
</tr>
<tr>
<td>39</td>
<td></td>
<td></td>
</tr>
<tr>
<td>40</td>
<td></td>
<td></td>
</tr>
<tr>
<td>41</td>
<td></td>
<td></td>
</tr>
<tr>
<td>42</td>
<td></td>
<td></td>
</tr>
<tr>
<td>43</td>
<td></td>
<td></td>
</tr>
<tr>
<td>44</td>
<td></td>
<td></td>
</tr>
<tr>
<td>45</td>
<td></td>
<td></td>
</tr>
<tr>
<td>46</td>
<td></td>
<td></td>
</tr>
<tr>
<td>47</td>
<td></td>
<td></td>
</tr>
<tr>
<td>48</td>
<td></td>
<td></td>
</tr>
<tr>
<td>49</td>
<td></td>
<td></td>
</tr>
<tr>
<td>50</td>
<td></td>
<td></td>
</tr>
<tr>
<td>51</td>
<td></td>
<td></td>
</tr>
<tr>
<td>52</td>
<td></td>
<td></td>
</tr>
<tr>
<td>53</td>
<td></td>
<td></td>
</tr>
<tr>
<td>54</td>
<td></td>
<td></td>
</tr>
<tr>
<td>55</td>
<td></td>
<td></td>
</tr>
<tr>
<td>56</td>
<td></td>
<td></td>
</tr>
<tr>
<td>57</td>
<td></td>
<td></td>
</tr>
<tr>
<td>58</td>
<td></td>
<td></td>
</tr>
<tr>
<td>59</td>
<td></td>
<td></td>
</tr>
<tr>
<td>60</td>
<td></td>
<td></td>
</tr>
<tr>
<td>61</td>
<td></td>
<td></td>
</tr>
<tr>
<td>62</td>
<td></td>
<td></td>
</tr>
<tr>
<td>63</td>
<td></td>
<td></td>
</tr>
<tr>
<td>64</td>
<td></td>
<td></td>
</tr>
<tr>
<td>65</td>
<td></td>
<td></td>
</tr>
<tr>
<td>66</td>
<td></td>
<td></td>
</tr>
<tr>
<td>67</td>
<td></td>
<td></td>
</tr>
<tr>
<td>68</td>
<td></td>
<td></td>
</tr>
<tr>
<td>69</td>
<td></td>
<td></td>
</tr>
<tr>
<td>70</td>
<td></td>
<td></td>
</tr>
<tr>
<td>71</td>
<td></td>
<td></td>
</tr>
<tr>
<td>72</td>
<td></td>
<td></td>
</tr>
<tr>
<td>73</td>
<td></td>
<td></td>
</tr>
<tr>
<td>74</td>
<td></td>
<td></td>
</tr>
<tr>
<td>75</td>
<td></td>
<td></td>
</tr>
<tr>
<td>76</td>
<td></td>
<td></td>
</tr>
<tr>
<td>77</td>
<td></td>
<td></td>
</tr>
<tr>
<td>78</td>
<td></td>
<td></td>
</tr>
<tr>
<td>79</td>
<td></td>
<td></td>
</tr>
<tr>
<td>80</td>
<td></td>
<td></td>
</tr>
<tr>
<td>81</td>
<td></td>
<td></td>
</tr>
<tr>
<td>82</td>
<td></td>
<td></td>
</tr>
<tr>
<td>83</td>
<td></td>
<td></td>
</tr>
<tr>
<td>84</td>
<td></td>
<td></td>
</tr>
<tr>
<td>85</td>
<td></td>
<td></td>
</tr>
<tr>
<td>86</td>
<td></td>
<td></td>
</tr>
<tr>
<td>87</td>
<td></td>
<td></td>
</tr>
<tr>
<td>88</td>
<td></td>
<td></td>
</tr>
<tr>
<td>89</td>
<td></td>
<td></td>
</tr>
<tr>
<td>90</td>
<td></td>
<td></td>
</tr>
<tr>
<td>91</td>
<td></td>
<td></td>
</tr>
<tr>
<td>92</td>
<td></td>
<td></td>
</tr>
<tr>
<td>93</td>
<td></td>
<td></td>
</tr>
<tr>
<td>94</td>
<td></td>
<td></td>
</tr>
<tr>
<td>95</td>
<td></td>
<td></td>
</tr>
<tr>
<td>96</td>
<td></td>
<td></td>
</tr>
<tr>
<td>97</td>
<td></td>
<td></td>
</tr>
<tr>
<td>98</td>
<td></td>
<td></td>
</tr>
<tr>
<td>99</td>
<td></td>
<td></td>
</tr>
<tr>
<td>100</td>
<td></td>
<td></td>
</tr>
<tr>
<td>101</td>
<td></td>
<td></td>
</tr>
<tr>
<td>102</td>
<td></td>
<td></td>
</tr>
<tr>
<td>103</td>
<td></td>
<td></td>
</tr>
<tr>
<td>104</td>
<td></td>
<td></td>
</tr>
<tr>
<td>105</td>
<td></td>
<td></td>
</tr>
<tr>
<td>106</td>
<td></td>
<td></td>
</tr>
<tr>
<td>107</td>
<td></td>
<td></td>
</tr>
<tr>
<td>108</td>
<td></td>
<td></td>
</tr>
<tr>
<td>109</td>
<td></td>
<td></td>
</tr>
<tr>
<td>110</td>
<td></td>
<td></td>
</tr>
<tr>
<td>111</td>
<td></td>
<td></td>
</tr>
<tr>
<td>112</td>
<td></td>
<td></td>
</tr>
<tr>
<td>113</td>
<td></td>
<td></td>
</tr>
<tr>
<td>114</td>
<td></td>
<td></td>
</tr>
<tr>
<td>115</td>
<td></td>
<td></td>
</tr>
<tr>
<td>116</td>
<td></td>
<td></td>
</tr>
<tr>
<td>117</td>
<td></td>
<td></td>
</tr>
<tr>
<td>118</td>
<td></td>
<td></td>
</tr>
<tr>
<td>119</td>
<td></td>
<td></td>
</tr>
<tr>
<td>120</td>
<td></td>
<td></td>
</tr>
<tr>
<td>121</td>
<td></td>
<td></td>
</tr>
<tr>
<td>122</td>
<td></td>
<td></td>
</tr>
<tr>
<td>123</td>
<td></td>
<td></td>
</tr>
<tr>
<td>124</td>
<td></td>
<td></td>
</tr>
<tr>
<td>125</td>
<td></td>
<td></td>
</tr>
<tr>
<td>126</td>
<td></td>
<td></td>
</tr>
<tr>
<td>127</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

---

Figure 20-1 summarizes the encoding and layout of the combination field. In the figure, the biased exponent of a finite number is the concatenation of two parts: (1) two leftmost bits are derived from bits 1-5 of the format, and (2) the remaining bits in the combination field. For example, if the combination field of the DFP short format contains 10101010101 binary, it represents a biased exponent of 10010101 binary and a leftmost significand digit of 5.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Bit 6</th>
<th>Type</th>
<th>Biased Exponent</th>
<th>LMD</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>0001</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>0010</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>0011</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>0100</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>0101</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>0110</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>0111</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>1000</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1001</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1010</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1011</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1100</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1101</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1110</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1111</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1000</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1001</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1010</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1011</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1100</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1101</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1110</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1111</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1000</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>1001</td>
<td>m</td>
<td>Finite number</td>
<td>00</td>
<td>RBE</td>
</tr>
<tr>
<td>1010</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1011</td>
<td>m</td>
<td>Finite number</td>
<td>01</td>
<td>RBE</td>
</tr>
<tr>
<td>1100</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1101</td>
<td>m</td>
<td>Finite number</td>
<td>10</td>
<td>RBE</td>
</tr>
<tr>
<td>1110</td>
<td>r</td>
<td>Infinity¹</td>
<td>--</td>
<td>--</td>
</tr>
<tr>
<td>1111</td>
<td>0</td>
<td>QNaN²</td>
<td>--</td>
<td>--</td>
</tr>
</tbody>
</table>

---

1. Infinity
2. QNaN

Figure 20-1. The Combination Field
### Encoded Trailing Significand
This field contains an encoded decimal number, which represents digits in the trailing significand. The trailing significand contains all significand digits, except the leftmost digit. For infinities, nonzero trailing-significand digits are accepted in a source infinity; all trailing-significand digits in a resultant infinity are set to zeros, unless otherwise stated. For NaNs, this field contains diagnostic information called the payload.

The encoded trailing-significand field is a multiple of 10-bit blocks called declets. The number of declets depends on the format. Each declet represents three decimal digits in a 10-bit value. This is described in the section, “Densely Packed Decimal (DPD)” on page 20-57.

### Values of Finite Numbers
The values of finite numbers in the various formats are shown in Figure 20-2.

#### Figure 20-1. The Combination Field (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Bit</th>
<th>Type</th>
<th>Biased Exponent</th>
<th>LMD</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
</tr>
<tr>
<td>11111</td>
<td>1</td>
<td>NaN</td>
<td>--</td>
<td>--</td>
</tr>
</tbody>
</table>

**Explanation:**
- `--` Not applicable.
- `|` Concatenation.
- `1` All bits in the combination field to the right of bit 5 of the format constitute the reserved field for infinity.
- `2` All bits in the combination field to the right of bit 6 of the format constitute the reserved field for NaN.
- LMD Leftmost digit of the significand.
- `m` Bit 6 is a part of the remaining biased exponent.
- RBE Remaining biased exponent. It includes all bits in the combination field to the right of bit 5 of the format.
- `r` Bit 6 is a reserved bit for infinity.

#### Figure 20-2. Values of Finite Numbers

**Programming Note:** The RUV exponent, Q, is related to the LUV exponent, E, as follows:

\[ Q = E - p + 1 \]

where \( p \) is the format precision.

### Significand
Hereafter, the term significand is used to mean the following:

1. For finite numbers, the significand contains all trailing significand digits padded on the left with the leftmost digit of significand derived from the combination field.

2. For infinities and NaNs, the significand contains all trailing significand digits padded on the left with a zero digit.

### DFP Significant Digits
For a finite number, the DFP significant digits begin with the leftmost nonzero significand digit and end with the rightmost significand digit.

For a finite number, the number of DFP significant digits is the difference of subtracting the number of leading zeros from the format precision. The number of leading zeros is the number of zeros in the significand to the left of the leftmost nonzero digit.

**Programming Note:** The number of DFP significant digits of the value zero is zero.
Canonical Declets

The trailing significand digits in a DFP data format are encoded by representing three decimal digits with a 10-bit declet. Of the 1024 possible declets, 1000 canonical declets are produced in resultant DFP operands, and 24 noncanonical declets are not produced as DFP results. Both canonical and noncanonical declets are accepted in source DFP operands. The encoding of a canonical declet or noncanonical declet is described in the section, “Densely Packed Decimal (DPD)” on page 20-57.

DFP Canonical Data

A finite number is canonical when all declets are canonical declets.

An infinity is canonical when the reserved field is zero and all digits in the trailing significand are zeros.

A NaN is canonical when the reserved field is zero and all declets are canonical declets.

Programming Note: To ensure compatibility with future extensions and interchangeability between software routines, only DFP canonical data should be used.

Classes of DFP Data

There are six classes of DFP data: zero, subnormal number, normal number, infinity, signaling NaN, and quiet NaN. The zero, subnormal number, and normal number data classes are collectively called finite numbers. The instruction TEST DATA CLASS may be used to determine the class of a DFP operand.

Zeros

Zeros have a zero significand and any representable value in the biased exponent. A +0 is distinct from a -0 and zeros with different biased exponents are distinct, except that comparison treats them as equal.

Subnormal Numbers

Subnormal numbers are numbers which are smaller than Nmin and larger than zero in magnitude.

<table>
<thead>
<tr>
<th>Property</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>Format length (bits)</td>
<td>Short</td>
</tr>
<tr>
<td></td>
<td>32</td>
</tr>
<tr>
<td>Combination length (bits)</td>
<td>11</td>
</tr>
<tr>
<td>Encoded Trailing significand length (bits)</td>
<td>20</td>
</tr>
<tr>
<td>Precision (p)</td>
<td>7</td>
</tr>
<tr>
<td>Maximum left-units-view (LUV) exponent (Emax)</td>
<td>96</td>
</tr>
<tr>
<td>Minimum left-units-view (LUV) exponent (Emin)</td>
<td>-95</td>
</tr>
<tr>
<td>Left-units-view (LUV) bias</td>
<td>95</td>
</tr>
<tr>
<td>Maximum right-units-view (RUV) exponent (Qmax)</td>
<td>90</td>
</tr>
<tr>
<td>Minimum right-units-view (RUV) exponent (Qmin)</td>
<td>-101</td>
</tr>
<tr>
<td>Right-units-view (RUV) bias</td>
<td>101</td>
</tr>
<tr>
<td>Maximum biased exponent</td>
<td>191</td>
</tr>
<tr>
<td>Nmax</td>
<td>((10^7 - 1) \times 10^{369})</td>
</tr>
<tr>
<td>Nmin</td>
<td>(1 \times 10^{-95})</td>
</tr>
<tr>
<td>Dmin</td>
<td>(1 \times 10^{-101})</td>
</tr>
</tbody>
</table>

Explanation:

Dmin Smallest (in magnitude) subnormal number.
Nmax Largest (in magnitude) normal number.
Nmin Smallest (in magnitude) normal number.

Figure 20-3. Summary of DFP Formats
Normal Numbers
Normal numbers are numbers whose magnitude is between Nmin and Nmax inclusively.

Infinities
An infinity is represented by 11110 binary in bits 1-5 of the data format. Infinities can participate in most arithmetic operations and give a consistent result, usually infinity. In comparisons, \( +\infty \) compares greater than any finite number, and \( -\infty \) compares less than any finite number. All \( +\infty \) are compared equal and all \( -\infty \) are compared equal.

Signaling and Quiet NaNs
A NaN (Not-a-Number) is represented by 11111 binary in bits 1-5 of the data format. NaNs are produced in place of a numeric result after an invalid operation when there is no interruption. NaNs may also be used by the program to flag special operands, such as the contents of an uninitialized storage area.

There are two types of NaNs, signaling and quiet. A signaling NaN (SNaN) is distinguished from a quiet NaN (QNaN) by bit 6, the SNaN bit, of the data format: zero for the QNaN and one for the SNaN. A special QNaN, called the default QNaN, is supplied as the nontrap result for an IEEE-invalid-operation exception; it has a plus sign, and the SNaN bit, the reserved field, and the payload are set to zeros.

Normally, source QNaNs are canonicalized to become the resultant QNaN that has the same sign and payload as the source during operations so that they will remain visible at the end. (See the section “Canonicalization” on page 20-7 for details.) An SNaN operand causes an IEEE invalid-operation exception, unless otherwise stated. When the exception is recognized for a SNaN, the nontrap result is the corresponding QNaN, which is produced by setting the SNaN bit in the source SNaN to zero and then the converted QNaN is canonicalized, and the IEEE-invalid-operation flag (FPC 1.0) is set to one.

Canonicalization
For operations that are defined to produce a DFP result, the result placed at the target operand location is canonical, unless otherwise stated.

Programming Notes:
1. The following instructions may produce a noncanonical infinity as the result:
   - INSERT BIASED EXPONENT
   - LOAD LENGTHENED
   - LOAD ROUNDED
   - SHIFT SIGNIFICAND LEFT
   - SHIFT SIGNIFICAND RIGHT

Infinities produced as a DFP result have the reserved field set to zero and have canonical declets in the encoded trailing-significand field. However, the infinity produced by the above instructions does not necessarily have zeros in all digits in the trailing significand. Such an infinity is not canonical.

2. Only canonical operands should be used, as it is possible that some libraries or software routines reject noncanonical operands.

3. Except for INSERT BIASED EXPONENT, if only canonical source operands are used, the result is canonical. INSERT BIASED EXPONENT may produce a noncanonical result even if all source operands are canonical. Special precautions should be taken to avoid producing a noncanonical result from INSERT BIASED EXPONENT.

DFP-Format Conversion
DFP format conversion is described in the section “IEEE Same-Radix Format Conversion” of Chapter 9, “Floating-Point Overview and Support Instructions.”

DFP Rounding
DFP rounding is described in the section “IEEE DFP Rounding” of Chapter 9, “Floating-Point Overview and Support Instructions.”

DFP Comparison
DFP comparison is described in the section “IEEE Comparison” of Chapter 9, “Floating-Point Overview and Support Instructions.”

DFP Formatting Instructions
A set of instructions are provided to compose and decompose DFP data. These instructions do not recognize any IEEE exceptions. They are:

- CONVERT FROM PACKED
Conversion of data between character strings in an external format and the DFP format may be performed in several steps. At certain steps, for finite numbers, the significand is kept in the packed-decimal format and the biased exponent in the fixed-point format. See Chapter 8, “Decimal Instructions,” for a detailed description of the zoned and packed-decimal formats.

It takes 17 packed-decimal digits to hold the 16 significand digits and one sign of a long DFP format; it takes 35 packed-decimal digits for an extended DFP format. To facilitate the conversion, the significand is divided into pieces and only one piece contains the sign. Each piece fits into a register or a register pair, and each piece is converted separately. To support this piecemeal conversion, two formats, signed-packed-decimal and unsigned-packed-decimal, are used to hold the pieces.

To facilitate the conversion between packed-decimal format data in memory and the DFP format, the CONVERT FROM PACKED and CONVERT TO PACKED instructions are provided. It takes up to 9 bytes to hold the 16 significand digits and one sign digit of a long DFP format. It takes up to 18 bytes to hold the 34 significand digits and one sign digit for an extended DFP format. Any unused digits in a packed-decimal format operand of CONVERT FROM PACKED must be zero.

For a zoned-decimal format, it takes 16 bytes to hold the 16 significand digits and one sign digit of a long DFP format; it takes 34 bytes for an extended DFP format. To facilitate the conversion, the CONVERT FROM ZONED and CONVERT TO ZONED instructions are provided.

Signed-Packed-Decimal Format
In the signed-packed-decimal format, each byte contains two 4-bit decimal digits (D), except for the rightmost byte, which contains a 4-bit sign (S) to the right of a 4-bit decimal digit.

When a signed-packed-decimal operand resides in a general register (GR), the operand is 64 bits (15 digits and sign), as shown below.

<table>
<thead>
<tr>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
</tr>
</thead>
</table>
| 0 | 4 | 8 | 12 | 16 | 20 | 24 | 28 | 32 | 36 | 40 | 44 | 48 | 52 | 56 | 60 | 63

When a signed-packed-decimal operand resides in a general-register pair, the leftmost 64 bits of the operand occupy the even-numbered register of the pair and the rightmost 64 bits occupy the odd-numbered register, as shown below.

| D | D | D | D | D | D | D | D | D | D | D | D | D | D | D |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0 | 4 | 8 | 12 | 16 | 20 | 24 | 28 | 32 | 36 | 40 | 44 | 48 | 52 | 56 | 60 | 63

Unsigned-Packed-Decimal Format
In the unsigned-packed-decimal format, each byte contains two 4-bit decimal digits (D) and there is no sign.

When an unsigned-packed-decimal operand resides in a general register, the operand is 64 bits (16 digits), as shown below.

<table>
<thead>
<tr>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
</tr>
</thead>
</table>
| 0 | 4 | 8 | 12 | 16 | 20 | 24 | 28 | 32 | 36 | 40 | 44 | 48 | 52 | 56 | 60 | 63

When an unsigned-packed-decimal operand resides in a general-register pair, the leftmost 64 bits of the operand occupy the even-numbered register of the pair and the rightmost 64 bits occupy the odd-numbered register, as shown below.

<table>
<thead>
<tr>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
<th>D</th>
</tr>
</thead>
</table>
| 0 | 4 | 8 | 12 | 16 | 20 | 24 | 28 | 32 | 36 | 40 | 44 | 48 | 52 | 56 | 60 | 63

Zoned-Decimal Format
In the unsigned zoned-decimal format, each byte contains two fields, a zone field in the leftmost four bit positions and a decimal digit in the rightmost four bit positions. The signed zoned-decimal format is similar to the unsigned zoned-decimal format except that the...
zone field of the rightmost byte instead contains a 4-bit sign. A zoned-decimal operand is a storage operand. See “Zoned Format” on page 8-1 for more details.

**IEEE Exceptions**

The IEEE exceptions for the DFP instructions are described in the section “IEEE Exceptions” on page 9-18. This also includes the quantum exception.

**Summary of Preferred Quantum**

Figure 20-4 summarizes all preferred quanta.

<table>
<thead>
<tr>
<th>Operations</th>
<th>Delivered value</th>
<th>Preferred Quantum</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD</td>
<td>Exact</td>
<td>The smaller quantum of the two source operands†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>CONVERT FROM FIXED</td>
<td>Exact</td>
<td>One†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL</td>
<td>Exact</td>
<td>One†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>CONVERT FROM PACKED</td>
<td>—</td>
<td>One</td>
</tr>
<tr>
<td>CONVERT FROM SIGNED PACKED</td>
<td>—</td>
<td>One</td>
</tr>
<tr>
<td>CONVERT FROM UNSIGNED PACKED</td>
<td>—</td>
<td>One</td>
</tr>
<tr>
<td>CONVERT FROM ZONED</td>
<td>—</td>
<td>One</td>
</tr>
<tr>
<td>DIVIDE</td>
<td>Exact</td>
<td>The quantum of the dividend divided by the quantum of the divisor†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>INSERT BIASED EXPONENT</td>
<td>—</td>
<td>The quantum corresponds to the requested biased exponent</td>
</tr>
<tr>
<td>LOAD AND TEST</td>
<td>—</td>
<td>The quantum of the source operand</td>
</tr>
<tr>
<td>LOAD FP INTEGER</td>
<td>Exact</td>
<td>The larger value of one and the quantum of the source operand</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>One</td>
</tr>
<tr>
<td>LOAD LENGTHENED</td>
<td>Exact*</td>
<td>The quantum of the source operand</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>LOAD ROUNDED</td>
<td>Exact</td>
<td>The quantum of the source operand†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>PERFORM FLOATING POINT OPERATION (DPQC=0)‡</td>
<td>Exact</td>
<td>The largest quantum of cohort members†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>PERFORM FLOATING POINT OPERATION (DPQC=1)‡</td>
<td>Exact</td>
<td>One†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>MULTIPLY</td>
<td>Exact</td>
<td>The product of the quanta of the two source operands†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
<tr>
<td>QUANTIZE</td>
<td>Exact</td>
<td>The requested quantum</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The requested quantum</td>
</tr>
<tr>
<td>REROUND</td>
<td>Exact</td>
<td>See the instruction description</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The quantum that corresponds to the requested significance</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND LEFT</td>
<td>—</td>
<td>The quantum of the source operand</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND RIGHT</td>
<td>—</td>
<td>The quantum of the source operand</td>
</tr>
<tr>
<td>SUBTRACT</td>
<td>Exact</td>
<td>The smaller quantum of the two source operands†</td>
</tr>
<tr>
<td></td>
<td>Inexact</td>
<td>The smallest quantum of cohort members</td>
</tr>
</tbody>
</table>

**Explanation:**

* This is true due to a condition to the left of the column.
— For these operations, the concept of exact result or inexact result does not apply.
† If the delivered value cannot be represented with the preferred quantum, it is represented with the quantum closest to the preferred quantum.
‡ Applicable only when the operation-type code is 01 hex (PFPO Convert Floating-Point Radix).
DPQC DFP preferred quantum control.

*Figure 20-4. Summary of Preferred Quantum*
Summary of Rounding And Range Actions

Figure 20-5 on page 20-10 and Figure 20-6 on page 20-11 summarizes rounding and range actions.

<table>
<thead>
<tr>
<th>Range of v</th>
<th>Case</th>
<th>Nontrap Result (r) when Effective Rounding Method Is</th>
</tr>
</thead>
<tbody>
<tr>
<td>v &lt; -Nmax, g &lt; -Nmax</td>
<td>Overflow</td>
<td>-\infty, -\infty, -\infty, -\infty, -Nmax, -Nmax, -Nmax</td>
</tr>
<tr>
<td>v &lt; -Nmax, g = -Nmax</td>
<td>Normal</td>
<td>-Nmax, -Nmax, -Nmax, --, --, -Nmax, -Nmax, -Nmax</td>
</tr>
<tr>
<td>-Nmax &lt; v ≤ -Nmin</td>
<td>Normal</td>
<td>g, g, g, g, g, g, g, g</td>
</tr>
<tr>
<td>-Nmin &lt; v ≤ -Dmin</td>
<td>Tiny</td>
<td>d#, d#, d#, d#, d#, d#, d, d</td>
</tr>
<tr>
<td>-Dmin &lt; v &lt; -Dmin/2</td>
<td>Tiny</td>
<td>-Dmin, -Dmin, -Dmin, -Dmin, -Dmin, -Dmin, -0, -0</td>
</tr>
<tr>
<td>v = -Dmin/2</td>
<td>Tiny</td>
<td>-0, -0, -0, -Dmin, -Dmin, -Dmin, -0, -0</td>
</tr>
<tr>
<td>-Dmin/2 &lt; v &lt; 0</td>
<td>Tiny</td>
<td>-0, -0, -0, -Dmin, -Dmin, -Dmin, -0, -0</td>
</tr>
<tr>
<td>v = 0</td>
<td>EZD</td>
<td>+0, +0, +0, +0, +Dmin, +0, +Dmin, +Dmin</td>
</tr>
<tr>
<td>0 &lt; v &lt; +Dmin/2</td>
<td>Tiny</td>
<td>+0, +0, +0, +0, +Dmin, +0, +Dmin, +Dmin</td>
</tr>
<tr>
<td>v = +Dmin/2</td>
<td>Tiny</td>
<td>+0, +0, +0, +0, +Dmin, +0, +Dmin, +Dmin</td>
</tr>
<tr>
<td>+Dmin/2 &lt; v &lt; +Dmin</td>
<td>Tiny</td>
<td>+Dmin, +Dmin, +Dmin, +Dmin, +Dmin, +Dmin, +Dmin, +Dmin</td>
</tr>
<tr>
<td>+Dmin ≤ v &lt; +Nmin</td>
<td>Tiny</td>
<td>d#, d#, d#, d#, d, d#, d#, d</td>
</tr>
<tr>
<td>+Nmin ≤ v ≤ +Nmax</td>
<td>Normal</td>
<td>g, g, g, g, g, g, g, g</td>
</tr>
<tr>
<td>+Nmax &lt; v, g = +Nmax</td>
<td>Normal</td>
<td>+Nmax, +Nmax, +Nmax, --, +Nmax, +Nmax, --, +Nmax</td>
</tr>
<tr>
<td>+Nmax &lt; v, +Nmax &lt; g</td>
<td>Overflow</td>
<td>+\infty, +\infty, +\infty, +\infty, +Nmax, +Nmax, +\infty, +Nmax</td>
</tr>
</tbody>
</table>

Explanation:
---
- This situation cannot occur.
- The rounded value, in the extreme case, may be Nmin. In this case, the exceptions are underflow, inexact and incremented.
- The nontrap result r is considered to have been incremented.
- d The value derived when the precise intermediate value (v) is rounded to the format of the target, including both precision and bounded exponent range. Except as explained in note *, this is a subnormal number.
- g The precision-rounded value. The value derived when the precise intermediate value (v) is rounded to the precision of the target, but assuming an unbounded exponent range.
- v Precise intermediate value. This is the value, before rounding, assuming unbounded precision and an unbounded exponent range. For LOAD ROUNDED, v is the source value.
- EZD Exact zero difference. The case applies only to ADD and SUBTRACT. For all other DFP operations, a zero result is detected by inspection of the source operands without use of the R(v) function.
- Dmin Smallest (in magnitude) representable subnormal number in the target format.
- Nmax Largest (in magnitude) representable finite number in the target format.
- Nmin Smallest (in magnitude) representable normal number in the target format.
- RNTA Round to nearest with ties away from 0.
- RNTZ Round to nearest with ties to even.
- RFS Round to prepare for shorter precision.
- RM Round toward -\infty.
- RP Round toward +\infty.
- RZ Round toward 0.

Figure 20-5. Action for R(v): Rounding and Range Actions
| Case          | Is r inexact (r
|---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| Results                      |
|---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------------------|
| Overflow      | Yes\(^1\)      | 0              | —              | 0              | 0              | Yes\(^1\)      | 0              | 0              | —              | —              | T(r), SFo ← 1, SFx ← 1, SFq ← 1 |
| Overflow      | Yes\(^1\)      | 0              | —              | 0              | 0              | Yes\(^1\)      | 1              | —              | —              | —              | T(r), SFo ← 1, SFx ← 1 |
| Overflow      | Yes\(^1\)      | 0              | —              | 1              | —              | Yes\(^1\)      | 0              | 0              | —              | —              | T(r), SFo ← 1, SFq ← 1 |
| Overflow      | Yes\(^1\)      | 0              | —              | 1              | —              | Yes\(^1\)      | 1              | —              | —              | —              | T(r), SFo ← 1, SFx ← 1 |
| Overflow      | Yes\(^1\)      | 0              | —              | 0              | 0              | Yes\(^1\)      | 0              | 1              | —              | —              | T(r), SFo ← 1, SFq ← 1 |
| Overflow      | Yes\(^1\)      | 0              | —              | 0              | 1              | No\(^1\)       | —              | —              | —              | —              | T(r), SFo ← 1, PIDq(04) |
| Overflow      | Yes\(^1\)      | 1              | —              | —              | —              | No\(^1\)       | —              | —              | —              | —              | T(r), SFo ← 1, PIDq(04) |
| Overflow      | Yes\(^1\)      | 1              | —              | —              | —              | No\(^1\)       | —              | —              | —              | —              | T(r), SFo ← 1, PIDq(04) |
| Normal        | No             | —              | —              | —              | —              | Yes            | 0              | 0              | —              | —              | T(r), SFq ← 1 |
| Normal        | No             | —              | —              | —              | —              | Yes            | 1              | —              | —              | —              | T(r)                            |
| Normal        | No             | —              | —              | —              | —              | Yes            | 0              | 1              | —              | —              | T(r), PIDq(04) |
| Normal        | Yes            | —              | —              | 0              | 0              | Yes\(^1\)      | 0              | 0              | —              | —              | T(r), SFx ← 1, SFq ← 1 |
| Normal        | Yes            | —              | —              | 0              | 0              | Yes\(^1\)      | 1              | —              | —              | —              | T(r), SFx ← 1 |

**Explanation:**

— The results do not depend on this condition or mask bit.
1 This condition is true by virtue of the state of some condition to the left of this column.
2 The quantum exception mask bit and the quantum exception control are defined only when the floating-point extension facility is installed.
3 This column specifies whether a QX is recognized by considering all columns to the left of this column and the existence of the quantum exception condition. The specification in this column does not include the effects of the quantum-exception mask bit and the quantum-exception control.
\(\Psi\) Scale factor. For overflow, \(\Psi=2^\alpha\). For underflow, \(\Psi=2^{-\alpha}\). The unscaled scaling exponent (\(\alpha\)) depends on the type of operation and operand format. For all DFP operations except LOAD ROUNDED, \(\alpha\) depends on the target format and is 576 for long, and 9216 for extended. For LOAD ROUNDED, \(\alpha\) depends on the source format and is 192 for long and 3072 for extended.
\(g\) The precision-rounded value. The value derived when the precise intermediate value (v) is rounded to the precision of the target, but assuming an unbounded exponent range.
\(r\) Nontrap result as defined in Part 1 of this figure.
\(v\) Precise intermediate value. This is the value, before rounding, assuming unbounded precision and unbounded exponent range.
\(PIDc(h)\) Program interruption for data exception, condition c, with DXC of h in hex. See Figure 20-8 on page 20-15.
\(PIDq(04)\) DXC 04 is defined only when the floating-point extension facility is installed.
\(QX\) Quantum exception. This exception is defined only when the floating-point extension facility is installed.
\(SFo\) IEEE overflow flag, FPC 1.2.
\(SFq\) Quantum-exceptio status flag, FPC 1.5. This flag is defined only when the floating-point extension facility is installed.
\(SFu\) IEEE underflow flag, FPC 1.3.
\(SFx\) IEEE inexact flag, FPC 1.4.
\(T(x)\) The value x is placed at the target operand location.
\(Tw(x)\) The scaled result x is placed at the target operand location. For all DFP operations except LOAD ROUNDED, the scaled result is in the format and length of the target and rounded to the precision of the target. For LOAD ROUNDED, the scaled result is in the format and length of the source, but rounded to the precision of the target.

*Figure 20-6. (Part 1 of 3) Rounding and Range Actions*
<table>
<thead>
<tr>
<th>Case</th>
<th>Is r inexact (tr,v)</th>
<th>Overflow Mask (FPC 0.2)</th>
<th>Underflow Mask (FPC 0.3)</th>
<th>IEEE Inexact Exception Control (XEC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Is r inexact (tr,v)</th>
<th>Quantum Exception Control (XEC)</th>
<th>Quantum Mask (FPC 0.5)</th>
<th>Is g inexact (tg,v)</th>
<th>Is g incremented (tg-&gt;v)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>Normal</td>
<td>Yes</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), SFq ← 1</td>
</tr>
<tr>
<td>Normal</td>
<td>Yes</td>
<td>—</td>
<td>—</td>
<td>1</td>
<td>Yes</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r)</td>
</tr>
<tr>
<td>Normal</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>0</td>
<td>Yes</td>
<td>1</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), SFx ← 1, PIDq(04)</td>
</tr>
<tr>
<td>Normal</td>
<td>Yes</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), PIDq(04)</td>
</tr>
<tr>
<td>Normal</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>No</td>
<td>—</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>T(r), PIDx(08)</td>
</tr>
<tr>
<td>Normal</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>No</td>
<td>—</td>
<td>Yes</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), PIDy(0C)</td>
</tr>
<tr>
<td>Tiny</td>
<td>No</td>
<td>—</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r)</td>
</tr>
<tr>
<td>Tiny</td>
<td>No</td>
<td>—</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), SFq ← 1</td>
</tr>
<tr>
<td>Tiny</td>
<td>No</td>
<td>—</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r)</td>
</tr>
<tr>
<td>Tiny</td>
<td>No</td>
<td>—</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), PIDq(04)</td>
</tr>
<tr>
<td>Tiny</td>
<td>No</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>T(r), PIDq(04)</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>0</td>
<td>Yes</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), SFu ← 1, SFq ← 1</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>0</td>
<td>Yes</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), SFu ← 1, SFx ← 1</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>Yes</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), SFu ← 1, SFq ← 1</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>Yes</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), SFu ← 1</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>0</td>
<td>Yes</td>
<td>0</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(r), SFu ← 1, PIDq(04)</td>
</tr>
</tbody>
</table>

**Explanation:**

The results do not depend on this condition or mask bit.

1. This condition is true by virtue of the state of some condition to the left of this column.
2. This column specifies whether a QX is recognized by considering all columns to the left of this column and the existence of the quantum exception condition. The specification in this column does not include the effects of the quantum-exception mask bit and the quantum-exception control.
3. This condition is true by virtue of the state of some condition to the left of this column.

**Legend:**

- **tr**, **v**: Non-trap result as defined in Part 1 of this figure.
- **XEC**: Programm interruption for data exception, condition c, with DXC of h in hex. See Figure 20-8 on page 20-15.
- **PIDc(h)**: DXC 04 is defined only when the floating-point extension facility is installed.
- **QU**: Quantum exception. This exception is defined only when the floating-point extension facility is installed.
- **SFo**: IEEE overflow flag, FPC 1.2.
- **SFq**: Quantum-exception status flag, FPC 1.5. This flag is defined only when the floating-point extension facility is installed.
- **SFu**: IEEE underflow flag, FPC 1.3.
- **SFx**: IEEE inexact flag, FPC 1.4.
- **T(x)**: The value x is placed at the target operand location.
- **Tw(x)**: The scaled result x is placed at the target operand location. For all DFP operations except LOAD ROUNDED, the scaled result is in the format and length of the target and rounded to the precision of the target. For LOAD ROUNDED, the scaled result is in the format and length of the source, but rounded to the precision of the target.

Figure 20-6. (Part 2 of 3) Rounding and Range Actions
<table>
<thead>
<tr>
<th>Case</th>
<th>Is r inexact (r(\neq v))</th>
<th>Overflow Mask (FPC 0.2)</th>
<th>Underflow Mask (FPC 0.3)</th>
<th>IEEE Inexact Exception Control (XQC)</th>
<th>Is g (\neq v) recognized (^2)</th>
<th>Quantum Exception Control (^2) (XqC)</th>
<th>Quantum Mask (^2) (FPC 0.5)</th>
<th>Is g Incremented (g(\neq v))</th>
<th>Is r Incremented (r(\neq v))</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>No(^1)</td>
<td>—</td>
<td>—</td>
<td>No(^1)</td>
<td>—</td>
<td>T(r), SFu (\leftrightarrow) 1, PIDx(08)</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>No(^1)</td>
<td>—</td>
<td>—</td>
<td>Yes(^1)</td>
<td>—</td>
<td>T(r), SFu (\leftrightarrow) 1, PIDy(0C)</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>No(^1)</td>
<td>—</td>
<td>—</td>
<td>No(^1)</td>
<td>—</td>
<td>Tw(g + (\Psi)), PIDu(10)</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>No(^1)</td>
<td>—</td>
<td>—</td>
<td>Yes(^1)</td>
<td>—</td>
<td>Tw(g + (\Psi)), PIDux(18)</td>
</tr>
<tr>
<td>Tiny</td>
<td>Yes</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>No(^1)</td>
<td>—</td>
<td>—</td>
<td>Yes(^1)</td>
<td>—</td>
<td>Tw(g + (\Psi)), PIDuy(1C)</td>
</tr>
</tbody>
</table>

**Explanation:**

— The results do not depend on this condition or mask bit.

1 This condition is true by virtue of the state of some condition to the left of this column.

2 The quantum exception mask bit and the quantum exception control are defined only when the floating-point extension facility is installed.

3 This column specifies whether a QX is recognized by considering all columns to the left of this column and the existence of the quantum exception condition. The specification in this column does not include the effects of the quantum exception mask bit and the quantum exception control.

\(\Psi\) Scale factor. For overflow, \(\Psi=2^{12}\). For underflow, \(\Psi=2^{-12}\). The unsigned scaling exponent (\(\alpha\)) depends on the type of operation and operand format. For all DFP operations except LOAD ROUNDED, \(\alpha\) depends on the target format and is 576 for long, and 9216 for extended. For LOAD ROUNDED, \(\alpha\) depends on the source format and is 192 for long and 3072 for extended.

\(g\) The precision-rounded value. The value derived when the precise intermediate value (\(v\)) is rounded to the precision of the target, but assuming an unbounded exponent range.

\(r\) Nontrap result as defined in Part 1 of this figure.

\(v\) Precise intermediate value. This is the value, before rounding, assuming unbounded precision and unbounded exponent range.

PIDc(h) Program interruption for data exception, condition c, with DXC of h in hex. See Figure 20-8 on page 20-15.

PIDq(04) DXC 04 is defined only when the floating-point extension facility is installed.

QX Quantum exception. This exception is defined only when the floating-point extension facility is installed.

SFo IEEE overflow flag, FPC 1.2.

SFq Quantum-exception status flag, FPC 1.5. This flag is defined only when the floating-point extension facility is installed

SFu IEEE underflow flag, FPC 1.3.

SFx IEEE inexact flag, FPC 1.4.

T(x) The value x is placed at the target operand location.

Tw(x) The scaled result x is placed at the target operand location. For all DFP operations except LOAD ROUNDED, the scaled result is in the format and length of the target and rounded to the precision of the target. For LOAD ROUNDED, the scaled result is in the format and length of the source, but rounded to the precision of the target.

Figure 20-6. (Part 3 of 3) Rounding and Range Actions
Result Figures

Concise descriptions of the results produced by many of the DFP instructions are made by means of figures which contain columns and rows representing all possible combinations of DFP data class for the source operands of an instruction. The information shown at the intersection of a row and a column is one or more symbols representing the result or results produced for that particular combination of source-operand data classes. Explanations of the symbols used are contained in each figure. In many cases, the explanation of a particular result is in the form of a cross-reference to another figure. In many cases, the information shown at the intersection consists of several symbols separated by commas. All such results are produced unless one of the results is a program interruption. In the case of a program interruption, the operation is suppressed or completed as shown in Figure 20-8 on page 20-15.

Data-Exception Codes (DXC) and Abbreviations

Figure 20-7 shows IEEE exceptions and flag abbreviations that are used in the result figures, and it explains the symbols “Xi:” and “Xz:” that are used in the figures. Bits 0-4 (i,z,o,u,x) of the eight-bit data-exception code (DXC) in byte 2 of the FPC register are trap flags and correspond to the same bits in bytes 0 and 1 of the register (IEEE masks and IEEE flags). The trap flag for an exception, instead of the IEEE flag, is set to one when an interruption for the exception is enabled by the corresponding IEEE mask bit. Bit 5 (y) of byte 2 is used in conjunction with bit 4, inexact (x), to indicate that the result has been incremented in magnitude.

When the floating-point extension facility is installed, bit 5 of DXC also has a second meaning. When DXC bits 0-4 are zero, DXC bit 5 is the quantum-exception trap flag and corresponds to the quantum-exception mask IMq and its status flag SFq.

Figure 20-8 on page 20-15 shows the various DXCs that can be indicated, the associated instruction endings, and abbreviations that are used for the DXCs in the result figures. (The abbreviation “PID” stands for “program interruption for a data exception.”)

<table>
<thead>
<tr>
<th>Exception</th>
<th>FPC IEEE Mask bit</th>
<th>FPC Bit</th>
<th>Abbr.</th>
</tr>
</thead>
<tbody>
<tr>
<td>IEEE invalid operation</td>
<td>Xi&lt;sup&gt;1&lt;/sup&gt;</td>
<td>0.0</td>
<td>1.0</td>
</tr>
<tr>
<td>IEEE division by zero</td>
<td>Xz&lt;sup&gt;2&lt;/sup&gt;</td>
<td>0.1</td>
<td>1.1</td>
</tr>
<tr>
<td>IEEE overflow</td>
<td>Xo</td>
<td>0.2</td>
<td>1.2</td>
</tr>
<tr>
<td>IEEE underflow</td>
<td>Xu</td>
<td>0.3</td>
<td>1.3</td>
</tr>
<tr>
<td>IEEE inexact</td>
<td>Xx</td>
<td>0.4</td>
<td>1.4</td>
</tr>
<tr>
<td>Quantum-exception</td>
<td>Xq</td>
<td>0.5</td>
<td>1.5</td>
</tr>
</tbody>
</table>

Explanation:

1. The symbol “Xi:” followed by a list of results in a figure indicates that, when FPC 0.0 is zero, then instruction execution is completed by setting SFi (FPC 1.0) to one and producing the indicated results; and when FPC 0.0 is one, then instruction execution is suppressed, the data exception code (DXC) is set to 80 hex, and a program interruption for a data exception occurs.

2. The symbol “Xz:” followed by a list of results in a figure indicates that, when FPC 0.1 is zero, then instruction execution is completed by setting SFz (FPC 1.1) to one and producing the indicated results; and when FPC 0.1 is one, then instruction execution is suppressed, the data exception code (DXC) is set to 40 hex, and a program interruption for a data exception occurs.

Figure 20-7. IEEE Exception and Flag Abbreviations
The Decimal-Floating-Point (DFP) instructions and their mnemonics and operation codes are listed in Figure 20-9 on page 20-16.

The figure indicates, in the column labeled “Characteristics,” the instruction format, when the condition code is set, and the exceptional conditions in operand designations, data, or results that cause a program interruption.

All DFP instructions are subject to the AFP-register-control bit, bit 45 of control register 0. For the DFP instructions to be executed successfully, the AFP-register-control bit must be one; otherwise, a DFP-instruction data exception, DXC 3, is recognized.

Mnemonics for the DFP instructions are distinguished from corresponding HFP or BFP instructions by a T in the mnemonic. Mnemonics for the DFP instructions have an R as the last letter or the letter next to the last letter when the instruction is in the RRE or RRF format. Mnemonics for the DFP instructions have an A as the last letter when the instruction is an alternate instruction, which uses additional modifier fields not available to the original instruction. Certain letters are used for DFP instructions to represent operand format and operand-format length, as follows:

E Short
F Thirty-two-bit fixed point
G Sixty-four-bit fixed point
D Long
P Packed
X Extended
Z Zoned

**Note:** In the detailed descriptions of the individual instructions, the mnemonic and the symbolic operand designation for the assembler language are shown with each instruction. For a register-to-register operation using COMPARE (long), for example, CDTR is the mnemonic and R1,R2 the operand designation.

**Programming Notes:**

1. The floating-point extension facility includes the following:
   - The following new DFP instructions:
     - CONVERT FROM FIXED (CXFTR, CDFTR)
     - CONVERT FROM LOGICAL (CXLGTR, CDLGT, CXLFR, CDLFR)
     - CONVERT TO FIXED (CFXTR, CFDT)
     - CONVERT TO LOGICAL (CLGXTR, CLGDTR, CLFXT, CLFDTR)
   - All reserved values in the effective rounding method field and a quantum-exception control (XqC) are assigned for LOAD FP INTEGER, LOAD ROUNDED, QUANTIZE, and REROUND.
   - All reserved values in the effective rounding method field are assigned for CONVERT TO FIXED.
   - An IEEE-inexact-exception control (XxC) is added to CONVERT TO FIXED and LOAD ROUNDED.
   - An effective rounding method field and a quantum-exception control (XqC) are added to ADD, DIVIDE, MULTIPLY, and SUBTRACT.
   - An effective rounding method field, an IEEE-inexact-exception control (XxX), and a quantum-exception control (XxC) are added to CONVERT FROM FIXED.

<table>
<thead>
<tr>
<th>Abbr.</th>
<th>DXC (hex)</th>
<th>Data-Exception-Code Name</th>
<th>Instruction Ending</th>
</tr>
</thead>
<tbody>
<tr>
<td>PIDq</td>
<td>04</td>
<td>Quantum exception</td>
<td>Complete</td>
</tr>
<tr>
<td>PIDx</td>
<td>08</td>
<td>IEEE inexact and truncated</td>
<td>Complete</td>
</tr>
<tr>
<td>PIDy</td>
<td>0C</td>
<td>IEEE inexact and incremented</td>
<td>Complete</td>
</tr>
<tr>
<td>PIDu</td>
<td>10</td>
<td>IEEE underflow, exact</td>
<td>Complete, wrap exponent</td>
</tr>
<tr>
<td>PIDux</td>
<td>18</td>
<td>IEEE underflow, inexact and truncated</td>
<td>Complete, wrap exponent</td>
</tr>
<tr>
<td>PIDuy</td>
<td>1C</td>
<td>IEEE underflow, inexact and incremented</td>
<td>Complete, wrap exponent</td>
</tr>
<tr>
<td>PIDo</td>
<td>20</td>
<td>IEEE overflow, exact</td>
<td>Complete, wrap exponent</td>
</tr>
<tr>
<td>PIDox</td>
<td>28</td>
<td>IEEE overflow, inexact and truncated</td>
<td>Complete, wrap exponent</td>
</tr>
<tr>
<td>PIDoy</td>
<td>2C</td>
<td>IEEE overflow, inexact and incremented</td>
<td>Complete, wrap exponent</td>
</tr>
<tr>
<td>PIDz</td>
<td>40</td>
<td>IEEE division by zero</td>
<td>Suppress</td>
</tr>
<tr>
<td>PDI</td>
<td>80</td>
<td>IEEE invalid operation</td>
<td>Suppress</td>
</tr>
</tbody>
</table>

*Figure 20-8. IEEE Data-Exception Codes (DXC) and Abbreviations*
2. The following instructions are available when the DFP-zoned-conversion facility is installed:

- CONVERT FROM ZONED (CDZT, CXZT)
- CONVERT TO ZONED (CZDT, CZXT)

3. The following instructions are available when the DFP-packed-conversion facility is installed:

- CONVERT FROM PACKED (CDPT, CXPT)
- CONVERT TO PACKED (CPDT, CPXT)

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD (extended DFP)</td>
<td>AXTR</td>
<td>7F 1F</td>
<td>20-18</td>
</tr>
<tr>
<td>ADD (extended DFP)</td>
<td>AXTRA</td>
<td>7F 1F</td>
<td>20-18</td>
</tr>
<tr>
<td>ADD (long DFP)</td>
<td>ADTR</td>
<td>7F 1F</td>
<td>20-18</td>
</tr>
<tr>
<td>ADD (long DFP)</td>
<td>ADTRA</td>
<td>7F 1F</td>
<td>20-18</td>
</tr>
<tr>
<td>COMPARE (extended DFP)</td>
<td>CXTR</td>
<td>7F 1F</td>
<td>20-20</td>
</tr>
<tr>
<td>COMPARE (long DFP)</td>
<td>CDTR</td>
<td>7F 1F</td>
<td>20-20</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (extended DFP)</td>
<td>KXTR</td>
<td>7F 1F</td>
<td>20-22</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (long DFP)</td>
<td>KDR</td>
<td>7F 1F</td>
<td>20-22</td>
</tr>
<tr>
<td>COMPARE BIASED EXPONENT (extended DFP)</td>
<td>CEXTR</td>
<td>7F 1F</td>
<td>20-22</td>
</tr>
<tr>
<td>COMPARE BIASED EXPONENT (long DFP)</td>
<td>CEDTR</td>
<td>7F 1F</td>
<td>20-22</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to extended DFP)</td>
<td>CXFTR</td>
<td>3A 7F</td>
<td>20-23</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (32 to long DFP)</td>
<td>CDFTR</td>
<td>3A 7F</td>
<td>20-23</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to extended DFP)</td>
<td>CXGTR</td>
<td>3A 7F</td>
<td>20-23</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to extended DFP)</td>
<td>CXGTRA</td>
<td>3A 7F</td>
<td>20-23</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to long DFP)</td>
<td>CDGTR</td>
<td>3A 7F</td>
<td>20-23</td>
</tr>
<tr>
<td>CONVERT FROM FIXED (64 to long DFP)</td>
<td>CDGTRA</td>
<td>3A 7F</td>
<td>20-23</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL (32 to extended DFP)</td>
<td>CXLFR</td>
<td>3A 7F</td>
<td>20-24</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL (32 to long DFP)</td>
<td>CDLFR</td>
<td>3A 7F</td>
<td>20-24</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL (64 to extended DFP)</td>
<td>CXLGTR</td>
<td>3A 7F</td>
<td>20-24</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL (64 to long DFP)</td>
<td>CDLGTR</td>
<td>3A 7F</td>
<td>20-24</td>
</tr>
<tr>
<td>CONVERT FROM PACKED (32 to extended DFP)</td>
<td>CXPT</td>
<td>3A 7F</td>
<td>20-25</td>
</tr>
<tr>
<td>CONVERT FROM PACKED (32 to long DFP)</td>
<td>CDPT</td>
<td>3A 7F</td>
<td>20-25</td>
</tr>
<tr>
<td>CONVERT FROM SIGNED PACKED (128 to extended DFP)</td>
<td>CXUTR</td>
<td>3A 7F</td>
<td>20-27</td>
</tr>
<tr>
<td>CONVERT FROM SIGNED PACKED (64 to long DFP)</td>
<td>CDSTR</td>
<td>3A 7F</td>
<td>20-27</td>
</tr>
<tr>
<td>CONVERT FROM UNSIGNED PACKED (128 to extended DFP)</td>
<td>CDUTR</td>
<td>3A 7F</td>
<td>20-27</td>
</tr>
<tr>
<td>CONVERT FROM UNSIGNED PACKED (64 to long DFP)</td>
<td>CDSTR</td>
<td>3A 7F</td>
<td>20-27</td>
</tr>
</tbody>
</table>

Figure 20-9. Summary of Decimal Instructions (Part 1 of 3)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT TO SIGNED PACKED (extended DFP to 128)</td>
<td>CSXTR</td>
<td>RRF-d TF $\sigma^7$ SP Dt</td>
<td>B3EB</td>
<td>20-34</td>
</tr>
<tr>
<td>CONVERT TO SIGNED PACKED (long DFP to 64)</td>
<td>CSDTR</td>
<td>RRF-d TF $\sigma^7$ Dt</td>
<td>B3E3</td>
<td>20-34</td>
</tr>
<tr>
<td>CONVERT TO UNSIGNED PACKED (extended DFP to 128)</td>
<td>CUXTR</td>
<td>RRE TF $\sigma^7$ SP Dt</td>
<td>B3EA</td>
<td>20-34</td>
</tr>
<tr>
<td>CONVERT TO UNSIGNED PACKED (long DFP to 64)</td>
<td>CUDTR</td>
<td>RRE TF $\sigma^7$ Dt</td>
<td>B3E2</td>
<td>20-34</td>
</tr>
<tr>
<td>CONVERT TO ZONED (from extended DFP)</td>
<td>CXZT</td>
<td>RSL C ZF $\sigma^7$ A SP</td>
<td>ST B3E</td>
<td>20-35</td>
</tr>
<tr>
<td>CONVERT TO ZONED (from long DFP)</td>
<td>CZDT</td>
<td>RSL C ZF $\sigma^7$ A SP</td>
<td>ST B3E</td>
<td>20-35</td>
</tr>
<tr>
<td>DIVIDE (extended DFP)</td>
<td>DXTR</td>
<td>RRF-a TF $\sigma^7$ SP Dt Xi Xz Xo Xu Xx</td>
<td>B3D9</td>
<td>20-36</td>
</tr>
<tr>
<td>DIVIDE (extended DFP)</td>
<td>DXTRA</td>
<td>RRF-a F $\sigma^7$ SP Dt Xi Xz Xo Xu Xx Xq</td>
<td>B3D9</td>
<td>20-36</td>
</tr>
<tr>
<td>DIVIDE (long DFP)</td>
<td>DDTR</td>
<td>RRF-a TF $\sigma^7$ Dt Xi Xz Xo Xu Xx</td>
<td>B3D1</td>
<td>20-36</td>
</tr>
<tr>
<td>DIVIDE (long DFP)</td>
<td>DDTRA</td>
<td>RRF-a F $\sigma^7$ Dt Xi Xz Xo Xu Xx Xq</td>
<td>B3D1</td>
<td>20-36</td>
</tr>
<tr>
<td>EXTRACT BIASED EXPONENT (extended DFP to 64)</td>
<td>EEXTR</td>
<td>RRE TF $\sigma^7$ SP Dt</td>
<td>B3ED</td>
<td>20-38</td>
</tr>
<tr>
<td>EXTRACT BIASED EXPONENT (long DFP to 64)</td>
<td>EEDTR</td>
<td>RRE TF $\sigma^7$ Dt</td>
<td>B3E5</td>
<td>20-38</td>
</tr>
<tr>
<td>EXTRACT SIGNIFICANCE (extended DFP to 64)</td>
<td>ESXTR</td>
<td>RRE TF $\sigma^7$ SP Dt</td>
<td>B3EF</td>
<td>20-38</td>
</tr>
<tr>
<td>EXTRACT SIGNIFICANCE (long DFP to 64)</td>
<td>ESDT</td>
<td>RRE TF $\sigma^7$ Dt</td>
<td>B3E7</td>
<td>20-38</td>
</tr>
<tr>
<td>INSERT BIASED EXPONENT (64 to extended DFP)</td>
<td>IEXTR</td>
<td>RRF-b TF $\sigma^7$ SP Dt</td>
<td>B3FE</td>
<td>20-39</td>
</tr>
<tr>
<td>LOAD AND TEST (extended DFP)</td>
<td>LTXTR</td>
<td>RRE C TF $\sigma^7$ SP Dt Xi</td>
<td>B3DE</td>
<td>20-40</td>
</tr>
<tr>
<td>LOAD AND TEST (long DFP)</td>
<td>LTDT</td>
<td>RRE C TF $\sigma^7$ Dt Xi</td>
<td>B3D6</td>
<td>20-40</td>
</tr>
<tr>
<td>LOAD FP INTEGER (extended DFP)</td>
<td>FIXTR</td>
<td>RRF-e TF $\sigma^7$ SP Dt Xi Xz Xo Xu Xx</td>
<td>B3DF</td>
<td>20-41</td>
</tr>
<tr>
<td>LOAD FP INTEGER (long DFP)</td>
<td>FIDTR</td>
<td>RRF-e TF $\sigma^7$ Dt Xi Xz Xo Xu Xx Xq</td>
<td>B3D7</td>
<td>20-41</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended DFP)</td>
<td>LXDTR</td>
<td>RRF-d TF $\sigma^7$ SP Dt Xi</td>
<td>B3DC</td>
<td>20-44</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to long DFP)</td>
<td>LDTR</td>
<td>RRF-d TF $\sigma^7$ Dt Xi</td>
<td>B3D4</td>
<td>20-44</td>
</tr>
<tr>
<td>LOAD ROUNDED (extended to long DFP)</td>
<td>LDXT</td>
<td>RRF-e TF $\sigma^7$ SP Dt Xi Xo Xu Xx Xq</td>
<td>B3D0</td>
<td>20-45</td>
</tr>
<tr>
<td>LOAD ROUNDED (long to short DFP)</td>
<td>LEDTR</td>
<td>RRF-e TF $\sigma^7$ Dt Xi Xo Xu Xx Xq</td>
<td>B3D5</td>
<td>20-45</td>
</tr>
<tr>
<td>MULTIPLY (extended DFP)</td>
<td>MXTRA</td>
<td>RRF-a F $\sigma^7$ SP Dt Xi Xo Xu Xx Xq</td>
<td>B3D8</td>
<td>20-46</td>
</tr>
<tr>
<td>MULTIPLY (long DFP)</td>
<td>MDTR</td>
<td>RRF-a F $\sigma^7$ SP Dt Xi Xo Xu Xx</td>
<td>B3D0</td>
<td>20-46</td>
</tr>
<tr>
<td>MULTIPLY (long DFP)</td>
<td>MDTA</td>
<td>RRF-a F $\sigma^7$ Dt Xi Xo Xu Xx</td>
<td>B3D0</td>
<td>20-47</td>
</tr>
<tr>
<td>QUANTIZE (extended DFP)</td>
<td>QAXTR</td>
<td>RRF-b TF $\sigma^7$ SP Dt Xi Xx Xq</td>
<td>B3FD</td>
<td>20-48</td>
</tr>
<tr>
<td>QUANTIZE (long DFP)</td>
<td>QADTR</td>
<td>RRF-b TF $\sigma^7$ Dt Xi Xx Xq</td>
<td>B3F5</td>
<td>20-48</td>
</tr>
<tr>
<td>REROUND (extended DFP)</td>
<td>RRXTR</td>
<td>RRF-b TF $\sigma^7$ SP Dt Xi Xx Xq</td>
<td>B3FF</td>
<td>20-51</td>
</tr>
<tr>
<td>REROUND (long DFP)</td>
<td>RRDTR</td>
<td>RRF-b TF $\sigma^7$ Dt Xi Xx Xq</td>
<td>B3F7</td>
<td>20-51</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND LEFT (extended DFP)</td>
<td>SLXT</td>
<td>RXF TF $\sigma^7$ SP Dt</td>
<td>B3F7</td>
<td>20-51</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND LEFT (long DFP)</td>
<td>SLDT</td>
<td>RXF TF $\sigma^7$ Dt</td>
<td>B3F7</td>
<td>20-51</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND RIGHT (extended DFP)</td>
<td>SRXT</td>
<td>RXF TF $\sigma^7$ SP Dt</td>
<td>B3F7</td>
<td>20-51</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND RIGHT (long DFP)</td>
<td>SRDT</td>
<td>RXF TF $\sigma^7$ Dt</td>
<td>B3F7</td>
<td>20-51</td>
</tr>
<tr>
<td>SUBTRACT (extended DFP)</td>
<td>SXTR</td>
<td>RRF-a C TF $\sigma^7$ SP Dt Xi Xo Xu Xx Xq</td>
<td>B3D0</td>
<td>20-54</td>
</tr>
<tr>
<td>SUBTRACT (extended DFP)</td>
<td>SXTRA</td>
<td>RRF-a C F $\sigma^7$ SP Dt Xi Xo Xu Xx Xq</td>
<td>B3D0</td>
<td>20-54</td>
</tr>
<tr>
<td>SUBTRACT (long DFP)</td>
<td>SDTR</td>
<td>RRF-a C TF $\sigma^7$ SP Dt Xi Xo Xu Xx Xq</td>
<td>B3D3</td>
<td>20-54</td>
</tr>
<tr>
<td>SUBTRACT (long DFP)</td>
<td>SDTRA</td>
<td>RRF-a C F $\sigma^7$ SP Dt Xi Xo Xu Xx Xq</td>
<td>B3D3</td>
<td>20-54</td>
</tr>
<tr>
<td>TEST DATA CLASS (extended DFP)</td>
<td>TDCXT</td>
<td>RXE C TF $\sigma^7$ SP Dt</td>
<td>B3E8</td>
<td>20-55</td>
</tr>
<tr>
<td>TEST DATA CLASS (long DFP)</td>
<td>TDCDT</td>
<td>RXE C TF $\sigma^7$ Dt</td>
<td>B3E4</td>
<td>20-55</td>
</tr>
<tr>
<td>TEST DATA CLASS (short DFP)</td>
<td>TDCET</td>
<td>RXE C TF $\sigma^7$ Dt</td>
<td>B3E0</td>
<td>20-55</td>
</tr>
<tr>
<td>TEST DATA GROUP (extended DFP)</td>
<td>TGDXT</td>
<td>RXE C TF $\sigma^7$ SP Dt</td>
<td>B3E9</td>
<td>20-56</td>
</tr>
<tr>
<td>TEST DATA GROUP (long DFP)</td>
<td>TGDGT</td>
<td>RXE C TF $\sigma^7$ Dt</td>
<td>B3E5</td>
<td>20-56</td>
</tr>
<tr>
<td>TEST DATA GROUP (short DFP)</td>
<td>TGDGT</td>
<td>RXE C TF $\sigma^7$ Dt</td>
<td>B3E5</td>
<td>20-56</td>
</tr>
</tbody>
</table>

Explanation:

$\sigma^7$ Restricted from transactional execution when the effective allow-floating-point-operation control is zero.

Figure 20-9. Summary of Decimal Instructions (Part 2 of 3)
The third operand is added to the second operand, and the sum is placed at the first-operand location.

If both operands are finite numbers, they are added algebraically, forming an intermediate sum. The intermediate sum, if nonzero, is rounded to the operand format and the rounded value is then placed at the result location.

When the floating-point extension facility is installed, the intermediate sum is rounded by rounding as specified by the modifier in the $M_4$ field:

- 0: According to the current DFP rounding mode
- 1: Round to nearest with ties away from 0
- 2: According to the current DFP rounding mode
- 3: Round to prepare for shorter precision
- 4: Round to nearest with ties to even
When the modifier field is zero or two, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 1, or 3-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-7, the quantum-exception control is zero and recognition of the exception is not suppressed.

When the floating-point extension facility is not installed, no quantum exception is recognized. If bits 20-23 of the instruction contain a value of zero, the intermediate sum is rounded according to the current DFP rounding mode; if bits 20-23 of the instruction contain a nonzero value, it is unpredictable which rounding method is performed.

The sign of the sum is determined by the rules of algebra. This also applies to a result of zero, as follows:

- If the result of rounding a nonzero intermediate sum is zero, the sign of the zero result is the sign of the intermediate sum.
- If the sum of two operands with opposite signs is exactly zero, the sign of the result is plus in all rounding methods except round toward \(-\infty\), in which method the sign is minus.
- The sign of the sum \(x + x\) is the sign of \(x\), even when \(x\) is zero.

If one operand is an infinity and the other is a finite number, the result is an infinity with the sign of the source infinity. If both operands are infinities of the same sign, the result is an infinity with the same sign. If the two operands are infinities of opposite signs, an IEEE-invalid-operation exception is recognized.

When the delivered value is exact, the preferred quantum is the smaller quantum of the two source operands; when the delivered value is inexact, the preferred quantum is the smallest quantum.

The result placed at the first-operand location is canonical.

See Figure 20-11 on page 20-20 for a detailed description of the results of this instruction. (Figure 20-10 is referred to by Figure 20-11.)

For AXTR and AXTRA, the R fields designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

- 0 Result is zero
- 1 Result is less than zero
- 2 Result is greater than zero
- 3 Result is a NaN

**IEEE Exceptions:**

- Invalid operation
- Overflow
- Underflow
- Inexact
- Quantum (if the floating-point extension facility is installed)

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (AXTR and AXTRA only)
- Transaction constraint

<table>
<thead>
<tr>
<th>Value of Result (r)</th>
<th>Condition code</th>
</tr>
</thead>
<tbody>
<tr>
<td>r = 0</td>
<td>0</td>
</tr>
<tr>
<td>r &lt; 0</td>
<td>1</td>
</tr>
<tr>
<td>r &gt; 0</td>
<td>2</td>
</tr>
</tbody>
</table>

*Figure 20-10. Condition Code for Resultant Sum*

**Programming Notes:**

1. Interchanging the two operands in a DFP addition does not affect the value of the sum when
the result is numeric. This is not true, however, when both operands are QNaNs; or when both operands are SNaNs and the IEEE invalid-operation mask bit in the FPC register is zero, in these cases, the result is the canonical QNaN derived from the second operand.

2. For ADD or SUBTRACT, when the delivered value is inexact, the preferred quantum is the smallest quantum which is the same quantum as that closest to the smaller quantum of the two source operands.

<table>
<thead>
<tr>
<th>Second Operand (b) is</th>
<th>Results for ADD (b+c) when Third Operand (c) is</th>
<th>QNaN</th>
<th>SNaN</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞</td>
<td>T(-∞), cc1</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>-Nn</td>
<td>T(-∞), cc1, R(b+c), cc1</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>-Dn</td>
<td>T(-∞), cc1, R(b+c), cc1</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>-0</td>
<td>T(-∞), cc1, T(c), cc1</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>+0</td>
<td>T(-∞), cc1, T(c), cc1</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>+Dn</td>
<td>T(-∞), cc1, R(b+c), cc1</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>+Nn</td>
<td>T(-∞), cc1, R(b+c), cc1</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>+∞</td>
<td>T(dNaN), cc3</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>QNaN</td>
<td>T(b), cc3</td>
<td>T(c), cc3</td>
<td></td>
</tr>
<tr>
<td>SNaN</td>
<td>T(b), cc3</td>
<td>T(c), cc3</td>
<td></td>
</tr>
</tbody>
</table>

Explanation:
* The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
cccn Condition code is set to n.
ccrs Condition code is set according to the resultant sum. See Figure 20-10 on page 20-19.
dNaN Default NaN.
Nn Normal number.
R(v) Rounding and range action is performed on the value v. See Figure 20-5 on page 20-10. The result is canonical.
Rezd Exact zero-difference result. See Figure 20-5 on page 20-10.
Dn Subnormal number.
T(x) The canonical result x is placed at the target operand location.
Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

Figure 20-11. Results: ADD

COMPARE

| Mnemonic | Op Code |  |  |
|----------|---------|  |  |
| R1, R2   | 1111111 | R1 | R2 |

The first operand is compared with the second operand, and the condition code is set to indicate the result.
If both operands are finite numbers, the comparison is algebraic and follows the procedure for DFP subtraction, except that the difference is discarded after setting the condition code, and both operands remain unchanged. If the difference is exactly zero with either sign, the operands are equal; this includes zero operands (so +0 equals -0). If a nonzero difference is positive or negative, the first operand is high or low, respectively.

$+\infty$ compares greater than any finite number, and all finite numbers compare greater than $-\infty$. Two infinity operands of like sign compare equal.

Numeric comparison is exact, and the condition code is determined for finite operands as if range and precision were unlimited. No overflow or underflow exception can occur.

If either or both operands are QNaNs and neither operand is an SNaN, the comparison result is unordered, and condition code 3 is set.

If either or both operands are SNaNs, an IEEE-invalid-operation exception is recognized. If the IEEE invalid-operation mask bit is one, a program interruption for a data exception with DXC 80 hex (IEEE invalid operation) occurs. If the IEEE-invalid-operation mask bit is zero, the IEEE-invalid-operation flag bit is set to one, and instruction execution is completed by setting condition code 3.

See Figure 20-12 on page 20-21 for a detailed description of the results of this instruction.

For CXTR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

### Resulting Condition Code:

<table>
<thead>
<tr>
<th>First Operand (a) is</th>
<th>Results for COMPARE (a:b) when Second Operand (b) is</th>
</tr>
</thead>
<tbody>
<tr>
<td>≈</td>
<td>-∞</td>
</tr>
<tr>
<td>-∞</td>
<td>cc0</td>
</tr>
<tr>
<td>-Fn</td>
<td>cc2</td>
</tr>
<tr>
<td>-0</td>
<td>cc2</td>
</tr>
<tr>
<td>+0</td>
<td>cc2</td>
</tr>
<tr>
<td>+Fn</td>
<td>cc2</td>
</tr>
<tr>
<td>+∞</td>
<td>cc2</td>
</tr>
<tr>
<td>QNaN</td>
<td>cc3</td>
</tr>
<tr>
<td>SNaN</td>
<td>Xi: cc3</td>
</tr>
</tbody>
</table>

Explanation:

- ccn: Condition code is set to n.
- C(a:b): Basic compare results. See Figure 20-13.
- Fn: Nonzero finite number (includes both subnormal and normal).
- Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

**IEEE Exceptions:**

- Invalid operation

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (CXTR only)
- Transaction constraint
COMPARE AND SIGNAL

Mnemonic R1 R2 [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

Mnemonic Op Code Operands
KDTR 'B3E0' Long DFP
KXTR 'B3E8' Extended DFP

The first operand is compared with the second operand, and the condition code is set to indicate the result. The operation is the same as for COMPARE except that QNaN operands cause an IEEE-invalid-operation exception to be recognized. Thus QNaN operands are treated as if they were SNaNs.

See Figure 20-14 on page 20-22 for a detailed description of the results of this instruction.

For KXTR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

- 0 Operands equal
- 1 First operand low
- 2 First operand high
- 3 Operands unordered

**IEEE Exceptions:**

- Invalid operation

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (KXTR only)
- Transaction constraint

**Figure 20-14. Results: COMPARE AND SIGNAL**

<table>
<thead>
<tr>
<th>First Operand (a) is</th>
<th>Results for COMPARE AND SIGNAL (a:b) when Second Operand (b) is</th>
<th>NaN</th>
</tr>
</thead>
<tbody>
<tr>
<td>-\infty</td>
<td>cc0</td>
<td>cc1</td>
</tr>
<tr>
<td>-\infty</td>
<td>cc2</td>
<td>C(a:b)</td>
</tr>
<tr>
<td>-0</td>
<td>cc2</td>
<td>cc2</td>
</tr>
<tr>
<td>+0</td>
<td>cc2</td>
<td>cc2</td>
</tr>
<tr>
<td>\infty</td>
<td>cc2</td>
<td>cc2</td>
</tr>
<tr>
<td>NaN</td>
<td>Xn: cc3</td>
<td>Xn: cc3</td>
</tr>
</tbody>
</table>

**Explanation:**

- ccn Condition code is set to n.
- C(a:b) Basic compare results. See Figure 20-13.
- Fn Nonzero finite number (includes both subnormal and normal).
- Xn: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

COMPARE BIASED EXPONENT

Mnemonic R1 R2 [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
</tr>
</tbody>
</table>

Mnemonic Op Code Operands
CEDTR 'B3F4' Long DFP
CEXTR 'B3FC' Extended DFP

The biased exponent of the first operand is compared with the biased exponent of the second operand, and the condition code is set to indicate the result.

This operation is performed for any second operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

See Figure 20-15 on page 20-23 for a detailed description of the results of this instruction.

For CEXTR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.
**Resulting Condition Code:**

0  Biased exponents equal
1  First-operan biased exponent low
2  First-operan biased exponent high
3  Unordered

**IEEE Exceptions:**  None.

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (CEXTR only)
- Transaction constraint

---

**Table:**

<table>
<thead>
<tr>
<th>First operand (a) is</th>
<th>Result for COMPARE BIASED EXPONENT when second operand (b) is</th>
<th>F</th>
<th>∞</th>
<th>QNaN</th>
<th>SNaN</th>
</tr>
</thead>
<tbody>
<tr>
<td>F</td>
<td>( C(e_a,e_b) ) cc3 cc3 cc3 cc3</td>
<td>F</td>
<td>∞</td>
<td>QNaN</td>
<td>SNaN</td>
</tr>
<tr>
<td>∞</td>
<td>cc3 cc0 cc3 cc3</td>
<td>F</td>
<td>∞</td>
<td>QNaN</td>
<td>SNaN</td>
</tr>
<tr>
<td>QNaN</td>
<td>cc3 cc3 cc0 cc0</td>
<td>F</td>
<td>∞</td>
<td>QNaN</td>
<td>SNaN</td>
</tr>
<tr>
<td>SNaN</td>
<td>cc3 cc3 cc3 cc0</td>
<td>F</td>
<td>∞</td>
<td>QNaN</td>
<td>SNaN</td>
</tr>
</tbody>
</table>

**Explanation:**

\( C(e_a,e_b) \) Biased-exponent compare results. See Figure 20-16 on page 20-23.

ccn  Condition code is set to n.

F    All finite numbers, including zeros.

---

**Figure 20-15. Results: COMPARE BIASED EXPONENT**

<table>
<thead>
<tr>
<th>Relation of value ( e_a ) to value ( e_b )</th>
<th>Condition Code for ( C(e_a,e_b) )</th>
</tr>
</thead>
<tbody>
<tr>
<td>( e_a = e_b )</td>
<td>cc0</td>
</tr>
<tr>
<td>( e_a &lt; e_b )</td>
<td>cc1</td>
</tr>
<tr>
<td>( e_a &gt; e_b )</td>
<td>cc2</td>
</tr>
</tbody>
</table>

**Explanation:**

ccn  Condition code is set to n.

\( e_a \) Biased exponent of the first operand

\( e_b \) Biased exponent of the second operand

---

**Figure 20-16. Biased-Exponent Compare Results**

---

**CONVERT FROM FIXED**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDGTRA</td>
<td>'B3F1'</td>
<td>64-bit binary integer source, long DFP result</td>
</tr>
<tr>
<td>CXGTRA</td>
<td>'B3F9'</td>
<td>64-bit binary integer source, extended DFP result</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDFTTR</td>
<td>'B951'</td>
<td>32-bit binary integer source, long DFP result</td>
</tr>
<tr>
<td>CXTTR</td>
<td>'B959'</td>
<td>32-bit binary integer source, extended DFP result</td>
</tr>
</tbody>
</table>

The fixed-point second operand is converted to the DFP format, and the result is placed at the first-operand location.

The second operand is a signed binary integer that is located in the general register designated by \( R_2 \). A 32-bit operand is in bit positions 32-63 of the register.

The converted result is rounded and then the rounded value is placed at the first-operand location.

When the floating-point extension facility is installed, the converted result is rounded by rounding as specified by the modifier in the \( M_3 \) field:

**M_3 Effective Rounding Method**

0  According to the current DFP rounding mode
1  Round to nearest with ties away from 0
2  According to the current DFP rounding mode
3  Round to prepare for shorter precision
4  Round to nearest with ties to even
5  Round toward 0
6  Round toward +∞
7  Round toward −∞
8  Round to nearest with ties to even
9  Round toward 0
10 Round toward +∞
11 Round toward −∞
12 Round to nearest with ties away from 0
13 Round to nearest with ties toward 0
14 Round away from 0
15 Round to prepare for shorter precision

When the modifier field is zero or two, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 1, or 3-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.
If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-7, the quantum-exception control is zero and recognition of the exception is not suppressed.

When the floating-point extension facility is not installed, no quantum exception is recognized. If bits 16-19 of the instruction contain a value of zero, the converted result is rounded according to the current DFP rounding mode; if bits 16-19 of the instruction contain a nonzero value, it is unpredictable which rounding method is performed.

When the delivered value is exact, the preferred quantum is one; when the delivered value is inexact, the preferred quantum is the smallest quantum.

The result placed at the first-operand location is canonical.

See Figure 20-24 on page 20-41 for a detailed description of the results of this instruction.

When the floating-point extension facility is installed, bit 1 of the M₄ field is the IEEE-inexact-exception control (XxC), and bits 0, 2, and 3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of the exception is suppressed.

When the floating-point extension facility is not installed, and if bits 20-23 of the instruction are zeros, then recognition of IEEE-inexact exception is not suppressed; if bits 20-23 of the instruction contain a nonzero value, it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

For CXGTR, CXGTRA, and CXFTR, the R₃ field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

An operation exception is recognized if the DFP facility is not installed. For CDFTR and CXFTR, the operation exception is also recognized if the floating-point extension facility is not installed.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Inexact (CDGTR and CDGTRA only)
- Quantum (CDGTR and CDGTRA only, if the floating-point extension facility is installed)

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (CXGTR, CXGTRA, and CXFTR only)
- Transaction constraint

**Programming Note:** Unassigned bits in the M₄ field are reserved for future extensions and should be set to zeros; otherwise, the program may not operate compatibly in the future.

### CONVERT FROM LOGICAL

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDLGTR 'B952'</td>
<td>64-bit binary-integer source, long DFP result</td>
<td></td>
</tr>
<tr>
<td>CXLGTR 'B95A'</td>
<td>64-bit binary-integer source, extended DFP result</td>
<td></td>
</tr>
<tr>
<td>CDLFTR 'B953'</td>
<td>32-bit binary-integer source, long DFP result</td>
<td></td>
</tr>
<tr>
<td>CXLFTR 'B95B'</td>
<td>32-bit binary-integer source, extended DFP result</td>
<td></td>
</tr>
</tbody>
</table>

The fixed-point second operand is converted to the DFP format, and the result is placed at the first-operand location.

The second operand is an unsigned binary integer that is located in the general register designated by R₂. A 32-bit operand is in bit positions 32-63 of the register.

The converted result is rounded to an integer value by rounding as specified by the modifier in the M₃ field:

**M₃ Effective Rounding Method**
- 0: According to the current DFP rounding mode
- 1: Round to nearest with ties away from 0
- 2: According to the current DFP rounding mode
- 3: Round to prepare for shorter precision
- 4: Round to nearest with ties to even
- 5: Round toward 0
- 6: Round toward +∞
- 7: Round toward −∞
- 8: Round to nearest with ties to even
- 9: Round toward 0
When the modifier field is zero or two, rounding is
controlled by the current DFP rounding mode speci-
fied in the FPC register. When the field is 1, or 3-15,
rounding is performed as specified by the modifier,
regardless of the current DFP rounding mode.

If the modifier field is 0 or 8-15, the quantum-excep-
tion control (XqC) is one and recognition of the quan-
tum exception is suppressed; if the modifier field is 1-
7, the quantum-exception control is zero and recogni-
tion of the exception is not suppressed.

Bit 1 of the M4 field is the IEEE-inexact-exception
control (XxC). Bits 0, 2, and 3 are ignored. If XxC is
zero, recognition of IEEE-inexact exception is not
suppressed; if XxC is one, recognition of the exception
is suppressed.

The result always has a plus sign.

When the delivered value is exact, the preferred
quantum is one; when the delivered value is inexact,
the preferred quantum is the smallest quantum.

The result placed at the first-operand location is
canonical.

See Figure 20-24 on page 20-41 for a detailed
description of the results of this instruction.

For CXLGTR and CXLFR, the R1 field must desig-
nate a valid floating-point-register pair; otherwise, a
specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Inexact (CDLGTR only)
- Quantum (CDLGTR only)

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the floating-point extension facility is
  not installed)
- Specification (CXLGTR and CXLFR only)
- Transaction constraint

**Programming Notes:**
1. Unassigned bits in the M4 field are reserved for
   future extensions and should be set to zeros;
   otherwise, the program may not operate compat-
   ibly in the future.

2. Using either the round toward 0 or the round
toward \(-\infty\) rounding method produces the same
result; using either the round away from 0 or the
round toward \(+\infty\) rounding method produces the
same result.

**CONVERT FROM PACKED**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Rd(Dx),L2,B2,M3</th>
<th>[RSL-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDPT</td>
<td>‘EDAE’</td>
<td>Packed source, long DFP result</td>
</tr>
<tr>
<td>CXPT</td>
<td>‘EDAF’</td>
<td>Packed source, extended DFP result</td>
</tr>
</tbody>
</table>

The second operand in the packed-decimal format is
converted to the DFP format, and the result is placed
at the first-operand location.

The preferred quantum is one, and the delivered
value is always represented with the preferred quan-
tum.

The result placed at the first-operand location is
canonical.

For CXPT the length in bytes of the second operand
is 1-18, corresponding to a length code in L2 of 0-17.
For CDPT the length in bytes of the second operand
is 1-9, corresponding to a length code in L2 of 0-8.
See Figure 20-17 for valid L2 values along with the
corresponding number of digits converted.

The M3 field has the following format:
The bits of the $M_3$ field are defined as follows:

- **Sign-Control (S):** Bit 0 of the $M_3$ field is the sign control (S). When the S bit is zero, the second operand does not have a sign field and the sign bit of the DFP first-operand result is set to zero.

When the S bit is one, the second operand contains a sign field in the rightmost four bit positions of the rightmost byte. The sign bit of the DFP first-operand result is set to zero when the sign field of the second operand indicates a positive value, or when the ignore-sign-digit control is one. The sign bit of the DFP first-operand result is set to one when the sign field of the second operand indicates a negative value and the ignore-sign-digit control is zero.

- **Reserved:** Bits 1-2 of the $M_3$ field are reserved.

- **Ignore-Sign-Digit Control (I):** Bit 3 of the $M_3$ field is the ignore-sign-digit control (I). When the I bit is zero, no special action is taken. When the I bit is one, the sign field of the second operand is ignored, it is not checked for invalid digits, and the sign bit of the DFP first-operand result is set to zero. When the S-bit is zero, the I bit is ignored.

**Special Conditions**

When an invalid digit or sign code is detected in the second operand, or an unused digit is not zero, a general-operand data exception is recognized. If the sign control and the ignore-sign-digit control are one, no sign code checking is performed on the sign digit. A specification exception is recognized, and the operation is suppressed, when any of the following is true.

- For CDPT, the $L_2$ field is greater than 8
- For CXPT, the $R_1$ field designates an invalid floating-point-register pair, or the $L_2$ field is greater than 17

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (Fetch operand 2)
- Data with DXC 0, general operand

- Data with DXC 3, DFP instruction
- Operation (if the DFP packed-conversion facility is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. Depending on the model, for CXPT, when the $L_2$ field specifies 16 or 17 (meaning 32-34 digits), performance may be significantly worse than if shorter lengths are specified.

2. When trying to convert 16 packed digits and a sign digit for CDPT, a $L_2$ value of 8 should be used and the S bit in the $M_3$ field should be set to one. When trying to convert 34 packed digits and a sign digit for CXPT an $L_2$ value of 17 should be used and the S bit in the $M_3$ field should be set to one. In both of these cases, bits 0-3 of the first byte of the second operand should be zero; otherwise, a general-operand data exception will occur.

<table>
<thead>
<tr>
<th>$L_2$</th>
<th>S=0</th>
<th>S=1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>2</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>4</td>
<td>3</td>
</tr>
<tr>
<td>2</td>
<td>6</td>
<td>5</td>
</tr>
<tr>
<td>3</td>
<td>8</td>
<td>7</td>
</tr>
<tr>
<td>4</td>
<td>10</td>
<td>9</td>
</tr>
<tr>
<td>5</td>
<td>12</td>
<td>11</td>
</tr>
<tr>
<td>6</td>
<td>14</td>
<td>13</td>
</tr>
<tr>
<td>7</td>
<td>16</td>
<td>15</td>
</tr>
<tr>
<td>For CDPT only:</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>16*</td>
<td>16*</td>
</tr>
<tr>
<td>CXPT only below</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>18</td>
<td>17</td>
</tr>
<tr>
<td>9</td>
<td>20</td>
<td>19</td>
</tr>
<tr>
<td>10</td>
<td>22</td>
<td>21</td>
</tr>
<tr>
<td>11</td>
<td>24</td>
<td>23</td>
</tr>
<tr>
<td>12</td>
<td>26</td>
<td>25</td>
</tr>
<tr>
<td>13</td>
<td>28</td>
<td>27</td>
</tr>
<tr>
<td>14</td>
<td>30</td>
<td>29</td>
</tr>
<tr>
<td>15</td>
<td>32</td>
<td>31</td>
</tr>
<tr>
<td>16</td>
<td>34</td>
<td>33</td>
</tr>
<tr>
<td>17</td>
<td>34*</td>
<td>34*</td>
</tr>
</tbody>
</table>

**Explanation:**

* Unused digits must be zero.

*Figure 20-17. Valid $L_2$ Values for Signed and Unsigned Digit Combinations*
### CONVERT FROM SIGNED PACKED

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDSTR</td>
<td>‘B3F3’</td>
<td>64-bit signed-packed-decimal source in GR, long DFP result</td>
</tr>
<tr>
<td>CXSTR</td>
<td>‘B3FB’</td>
<td>128-bit signed-packed-decimal source in GRs, extended DFP result</td>
</tr>
</tbody>
</table>

The second operand in the signed-packed-decimal format is converted to the DFP format, and the result is placed at the first-operand location.

The second operand is located in the general register or general-register pair designated by $R_2$.

The preferred quantum is one, and the delivered value is always represented with the preferred quantum.

The result placed at the first-operand location is canonical.

When an invalid digit or sign code is detected in the second operand, a general-operand data exception is recognized.

For CXSTR, the $R_1$ field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized. Also, the $R_2$ field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 0, general operand
- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (CXSTR only)
- Transaction constraint

### CONVERT FROM UNSIGNED PACKED

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDUTR</td>
<td>‘B3F2’</td>
<td>64-bit unsigned-packed-decimal source in GR, long DFP result</td>
</tr>
<tr>
<td>CXUTR</td>
<td>‘B3FA’</td>
<td>128-bit unsigned-packed-decimal source in GRs, extended DFP result</td>
</tr>
</tbody>
</table>

The second operand in the unsigned-packed-decimal format is converted to the DFP format with a positive sign, and the result is placed at the first-operand location.

The second operand is located in the general register or general-register pair designated by $R_2$.

The preferred quantum is one, and the delivered value is always represented with the preferred quantum.

The result placed at the first-operand location is canonical.

When an invalid digit code is detected in the second operand, a general-operand data exception is recognized.

For CXUTR, the $R_1$ field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized. Also, the $R_2$ field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 0, general operand
- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (CXUTR only)
- Transaction constraint
CONVERT FROM ZONED

Mnemonic: \( R_1, D_2(L_2, B_2), M_3 \) [RSL-b]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L_2</th>
<th>B_2</th>
<th>D_2</th>
<th>R_1</th>
<th>M_3</th>
<th>Op Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>36</td>
<td>40</td>
<td>47</td>
</tr>
</tbody>
</table>

Mnemonic Op Code Operands
CDZT ‘EDAA’ Zoned source, long DFP result
CXZT ‘EDAB’ Zoned source, extended DFP result

The second operand in the zoned format is converted to the DFP format, and the result is placed at the first-operand location.

The preferred quantum is one, and the delivered value is always represented with the preferred quantum.

The result placed at the first-operand location is canonical.

The length in bytes of the second operand is 1-34 for CXZT, corresponding to a length code in \( L_2 \) of 0-33. The length in bytes of the second operand is 1-16 for CDZT, corresponding to a length code in \( L_2 \) of 0-15.

The \( M_3 \) field has the following format:

\[
\begin{array}{cccc}
S & / & / & \n\end{array}
\]

0 1 2 3

The bits of the \( M_3 \) field are defined as follows:

- **Sign-Control (S):** Bit 0 of the \( M_3 \) field is the sign control (S). When zero, the second operand does not have a sign field and the sign bit of the DFP first-operand result is set to zero. When one, the second operand is signed. That is, the leftmost four bit positions of the rightmost byte are a sign. The sign bit of the DFP first-operand result is set to zero when the sign field indicates a positive value and one when the sign field indicates a negative value.

- **Reserved:** Bits 1-3 of the \( M_3 \) field are ignored.

**Special Conditions:**

When an invalid digit or sign code is detected in the second operand, a general-operand data exception is recognized.

A specification exception is recognized, and the operation is suppressed, when any of the following is true:

- For CDZT, the \( L_2 \) field is greater than or equal to 16.
- For CXZT, the \( R_1 \) field designates an invalid floating-point-register pair, or the \( L_2 \) field is greater than or equal to 34.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (Fetch operand 2)
- Data with DXC 0, general operand
- Data with DXC 3, DFP instruction
- Operation (if the DFP zoned-conversion facility is not installed)
- Specification
- Transaction constraint

**Programming Notes:**

1. When an ASCII second operand is specified, bit 0 of the \( M_3 \) field must be zero, otherwise a general-operand data exception is recognized. That is, a sign value of 0011 binary is not a valid sign.

2. Depending on the model, for CXZT, when the \( L_2 \) field specifies 32 or 33 (meaning 33 or 34 digits), performance may be significantly worse than if shorter lengths are specified.

3. Bits 1-3 of the \( M_3 \) field should be set to zeros, otherwise the program may not operate compatibly in the future.

CONVERT TO FIXED

Mnemonic: \( R_1, M_3, R_2 \) [RRF-e]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>M_3</th>
<th>// //</th>
<th>R_1</th>
<th>R_2</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 16</td>
<td>20</td>
<td>24</td>
<td>28</td>
<td>31</td>
</tr>
</tbody>
</table>

Mnemonic Op Code Operands
CGDTR ‘B3E1’ Long DFP source, 64-bit binary-integer result
CGXTR ‘B3E9’ Extended DFP source, 64-bit binary-integer result
The DFP second operand is rounded to an integer value and then converted to the fixed-point format. The result is placed at the first-operand location.

The result is a signed binary integer that is placed in the general register designated by R1. A 32-bit result replaces bits 32-63 of the register, and bits 0-31 of the register remain unchanged.

If the second operand is numeric and finite, it is rounded to an integer value by rounding as specified by the modifier in the M3 field:

<table>
<thead>
<tr>
<th>M3</th>
<th>Effective Rounding Method</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>1</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>2</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>3</td>
<td>Round to prepare for shorter precision</td>
</tr>
<tr>
<td>4</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>5</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>6</td>
<td>Round toward +∞</td>
</tr>
<tr>
<td>7</td>
<td>Round toward -∞</td>
</tr>
<tr>
<td>8</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>9</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>10</td>
<td>Round toward +∞</td>
</tr>
<tr>
<td>11</td>
<td>Round toward -∞</td>
</tr>
<tr>
<td>12</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>13</td>
<td>Round to nearest with ties toward 0</td>
</tr>
<tr>
<td>14</td>
<td>Round away from 0</td>
</tr>
<tr>
<td>15</td>
<td>Round to prepare for shorter precision</td>
</tr>
</tbody>
</table>

When the modifier field is zero, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 8-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

When the floating-point extension facility is installed and if the M3 modifier field is 1-7, it is unpredictable which rounding method is performed.

The sign of the result is the sign of the second operand, except that a zero result has a plus sign.

This operation performs a functionally-constrained rounding. Neither overflow nor underflow condition can occur.

When the floating-point extension facility is installed, bit 1 of the M4 field is the IEEE-inexact-exception control (XxC), and bits 0, 2, and 3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of the exception is suppressed.

When the floating-point extension facility is not installed, and if bits 20-23 of the instruction are zeros, then recognition of IEEE-inexact exception is not suppressed; if bits 20-23 of the instruction contain a nonzero value, it is unpredictable whether recognition of IEEE-inexact exception is suppressed.

See Figure 20-18 for a detailed description of the results of this instruction.

For CGXTR, CGXTRA, and CFXTR, the R2 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

An operation exception is recognized if the DFP facility is not installed. For CFDTR, CFDTRA, CFXTR, and CFXTRA the operation exception is also recognized if the floating-point extension facility is not installed.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Source was zero</td>
</tr>
<tr>
<td>1</td>
<td>Source was less than zero</td>
</tr>
<tr>
<td>2</td>
<td>Source was greater than zero</td>
</tr>
<tr>
<td>3</td>
<td>Special case</td>
</tr>
</tbody>
</table>

**IEEE Exceptions:**

- Invalid operation
- Inexact
**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation
- Specification (CGXTR, CGXTRA, and CFXTR only)
- Transaction constraint

**Programming Note:** Unassigned bits in the M₄ field are reserved for future extensions and should be set to zeros; otherwise, the program may not operate compatibly in the future.

<table>
<thead>
<tr>
<th>Operand (b)</th>
<th>Is n</th>
<th>Inexact Mask (FPC 0.0)</th>
<th>IEEE Inexact Exception Control (XXC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Is n Incremented (ln b)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞ ≤ b &lt; MN, n &lt; MN</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(MN), SFx←1, cc3 †</td>
</tr>
<tr>
<td>-∞ ≤ b &lt; MN, n &lt; MN</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>PiDx(80)</td>
</tr>
<tr>
<td>-∞ &lt; b &lt; MN, n = MN</td>
<td>—</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>T(MN), cc1</td>
</tr>
<tr>
<td>-∞ &lt; b &lt; MN, n = MN</td>
<td>—</td>
<td>—</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>T(MN), SFx←1, cc1</td>
</tr>
<tr>
<td>-∞ &lt; b &lt; MN, n = MN</td>
<td>—</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>—</td>
<td>T(MN), cc1, PiDx(08)</td>
</tr>
<tr>
<td>MN ≤ b &lt; 0</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(0), cc1</td>
</tr>
<tr>
<td>MN ≤ b &lt; 0</td>
<td>Yes</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>T(0), cc1</td>
</tr>
<tr>
<td>MN ≤ b &lt; 0</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>T(0), SFx←1, cc1</td>
</tr>
<tr>
<td>MN ≤ b &lt; 0</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>No</td>
<td>T(0), cc1, PiDx(08)</td>
</tr>
<tr>
<td>MN ≤ b &lt; 0</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>Yes</td>
<td>T(0), cc1, PiDy(0C)</td>
</tr>
<tr>
<td>-0</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(0), cc0</td>
</tr>
<tr>
<td>+0</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(0), cc0</td>
</tr>
<tr>
<td>0 &lt; b ≤ MP</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(0), cc2</td>
</tr>
<tr>
<td>0 &lt; b ≤ MP</td>
<td>Yes</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>T(0), cc2</td>
</tr>
<tr>
<td>0 &lt; b ≤ MP</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>T(0), SFx←1, cc2</td>
</tr>
<tr>
<td>0 &lt; b ≤ MP</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>No</td>
<td>T(0), cc2, PiDx(08)</td>
</tr>
<tr>
<td>0 &lt; b ≤ MP</td>
<td>Yes</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>Yes</td>
<td>T(0), cc2, PiDy(0C)</td>
</tr>
<tr>
<td>MP &lt; b &lt; +∞, n = MP</td>
<td>—</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>T(MP), cc2</td>
</tr>
<tr>
<td>MP &lt; b &lt; +∞, n = MP</td>
<td>—</td>
<td>—</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>T(MP), SFx←1, cc2</td>
</tr>
<tr>
<td>MP &lt; b &lt; +∞, n = MP</td>
<td>—</td>
<td>—</td>
<td>0</td>
<td>1</td>
<td>—</td>
<td>T(MP), cc2, PiDx(08)</td>
</tr>
<tr>
<td>MP &lt; b &lt; +∞, n &gt; MP</td>
<td>—</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(MP), SFx←1, cc3 †</td>
</tr>
<tr>
<td>MP &lt; b &lt; +∞, n &gt; MP</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>PiDx(80)</td>
</tr>
<tr>
<td>NaN</td>
<td>—</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(MN), SFx←1, cc3 †</td>
</tr>
<tr>
<td>NaN</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>PiDx(80)</td>
</tr>
</tbody>
</table>

**Explanation:**

— The results do not depend on this condition or mask bit.

1 This condition is true by virtue of the state of some condition to the left of this column.

2 XxC is defined only when the floating-point extension facility is installed.

ccn Condition code is set to n.

† Result differs from BFP CONVERT TO FIXED. The BFP instruction recognizes inexact for this case and takes different actions depending on the inexact mask. The DFP implementation is intended to be more in keeping with the spirit of the IEEE standard.

f The value n converted to a fixed-point result.

n The value derived when the source value (b) is rounded to a floating-point integer using the effective rounding method.

MN Maximum negative number representable in the target fixed-point format.

MP Maximum positive number representable in the target fixed-point format.

PiDc(h) Program interruption for data exception, condition c, with DXC of h in hex. Figure 20-8 on page 20-15

SFi IEEE invalid-operation flag, FPC 1.0.

SFx IEEE inexact flag, FPC 1.4.

T(x) The value x is placed at the target operand location.

---

*Figure 20-18. Results: CONVERT TO FIXED*
CONVERT TO LOGICAL

Mnemonic | R1 | M3 | R2 | [RRF-e]  
---|---|---|---|---
Op Code | M3 | M4 | R1 | R2

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLGDTR</td>
<td>'B942'</td>
<td>Long DFP source, 64-bit binary-integer result</td>
</tr>
<tr>
<td>CLGXTR</td>
<td>'B94A'</td>
<td>Extended DFP source, 64-bit binary-integer result</td>
</tr>
<tr>
<td>CLFDTR</td>
<td>'B943'</td>
<td>Long DFP source, 32-bit binary-integer result</td>
</tr>
<tr>
<td>CLFXTR</td>
<td>'B94B'</td>
<td>Extended DFP source, 32-bit binary-integer result</td>
</tr>
</tbody>
</table>

The DFP second operand is rounded to an integer value and then converted to the fixed-point format. The result is placed at the first-operand location.

The result is an unsigned binary integer that is placed in the general register designated by R1. A 32-bit result replaces bits 32-63 of the register, and bits 0-31 of the register remain unchanged.

If the second operand is numeric and finite, it is rounded to an integer value by rounding as specified by the modifier in the M3 field:

<table>
<thead>
<tr>
<th>M3</th>
<th>Effective Rounding Method</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>1</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>2</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>3</td>
<td>Round to prepare for shorter precision</td>
</tr>
<tr>
<td>4</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>5</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>6</td>
<td>Round toward +( \infty )</td>
</tr>
<tr>
<td>7</td>
<td>Round toward —( \infty )</td>
</tr>
<tr>
<td>8</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>9</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>10</td>
<td>Round toward +( \infty )</td>
</tr>
<tr>
<td>11</td>
<td>Round toward —( \infty )</td>
</tr>
<tr>
<td>12</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>13</td>
<td>Round to nearest with ties toward 0</td>
</tr>
<tr>
<td>14</td>
<td>Round away from 0</td>
</tr>
<tr>
<td>15</td>
<td>Round to prepare for shorter precision</td>
</tr>
</tbody>
</table>

When the modifier field is zero or two, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 1, or 3-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

This operation performs a functionally-constrained rounding. Neither overflow nor underflow condition can occur.

Bit 1 of the M4 field is the IEEE-inexact-exception control (XxC). Bits 0, 2, and 3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of the exception is suppressed.

See Figure 20-19 for a detailed description of the results of this instruction.

For CLGXTR and CLFXTR, the R2 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Source was zero</td>
</tr>
<tr>
<td>1</td>
<td>Source was less than zero</td>
</tr>
<tr>
<td>2</td>
<td>Source was greater than zero</td>
</tr>
<tr>
<td>3</td>
<td>Special case</td>
</tr>
</tbody>
</table>

**IEEE Exceptions:**

- Invalid operation
- Inexact

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the floating-point extension facility is not installed.)
- Specification (CLGXTR and CLFXTR only)
- Transaction constraint

**Programming Note:** Unassigned bits in the M4 field are reserved for future extensions and should be set.

---

20-31
to zeros; otherwise, the program may not operate compatibly in the future.

<table>
<thead>
<tr>
<th>Operand (b)</th>
<th>Is n Inexact (n ≠ b)</th>
<th>Inv.-Op. Mnemonic R1,D2(B2),M3</th>
<th>IEEE Inexact Mask (FPC 0.0)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Is n Incremented (ln &gt; lbi)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞ ≤ b &lt; 0, n &lt; 0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(0), SFI=1, cc3 †</td>
<td>T(0), SFI=1, cc3 †</td>
</tr>
<tr>
<td>-∞ ≤ b &lt; 0, n &lt; 0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(0), SFI=1, cc1</td>
<td>T(0), SFI=1, cc1</td>
</tr>
<tr>
<td>-∞ ≤ b &lt; 0, n = 0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(0), SFI=1, cc1</td>
<td>T(0), SFI=1, cc1</td>
</tr>
<tr>
<td>-∞ ≤ b &lt; 0, n = 0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>T(0), SFI=1, PIDI(08)</td>
<td>T(0), SFI=1, PIDI(08)</td>
</tr>
<tr>
<td>-∞ ≤ b &lt; 0, n = 0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(0), SFI=1, cc0</td>
<td>T(0), SFI=1, cc0</td>
</tr>
<tr>
<td>+0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(0), SFI=1, cc0</td>
<td>T(0), SFI=1, cc0</td>
</tr>
<tr>
<td>0 &lt; b ≤ MU</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(f), cc2</td>
<td>T(f), cc2</td>
</tr>
<tr>
<td>0 &lt; b ≤ MU</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(f), SFI=1, cc2</td>
<td>T(f), SFI=1, cc2</td>
</tr>
<tr>
<td>0 &lt; b ≤ MU</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>No T(f), SFI=1, PIDI(08)</td>
<td>T(f), SFI=1, PIDI(08)</td>
</tr>
<tr>
<td>0 &lt; b ≤ MU</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Yes T(f), cc2, PIDI(0C)</td>
<td>T(f), cc2, PIDI(0C)</td>
</tr>
<tr>
<td>MU &lt; b &lt; +∞, n = MU</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>T(MU), SFI=1, cc2</td>
<td>T(MU), SFI=1, cc2</td>
</tr>
<tr>
<td>MU &lt; b &lt; +∞, n = MU</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>T(MU), SFI=1, cc2</td>
<td>T(MU), SFI=1, cc2</td>
</tr>
<tr>
<td>MU &lt; b &lt; +∞, n &gt; MU</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>No T(MU), SFI=1, cc3 †</td>
<td>T(MU), SFI=1, cc3 †</td>
</tr>
<tr>
<td>MU &lt; b &lt; +∞, n &gt; MU</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Yes T(MU), SFI=1, cc3 †</td>
<td>T(MU), SFI=1, cc3 †</td>
</tr>
<tr>
<td>NaN</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>PIDi(80)</td>
<td>PIDi(80)</td>
</tr>
<tr>
<td>NaN</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>PIDi(80)</td>
<td>PIDi(80)</td>
</tr>
</tbody>
</table>

Explanation:

— The results do not depend on this condition or mask bit.
1 This condition is true by virtue of the state of some condition to the left of this column.
2 XxC is defined only when the floating-point extension facility is installed.
ccn Condition code is set to n.
† Result differs from BFP CONVERT TO LOGICAL. The BFP instruction recognizes inexact for this case and takes different actions depending on the inexact mask. The DFP implementation is intended to be more in keeping with the spirit of the IEEE standard.
f The value n converted to a fixed-point result.
n The value derived when the source value (b) is rounded to a floating-point integer using the effective rounding method.
MU Maximum unsigned number representable in the target fixed-point format.
PIDc(h) Program interruption for data exception, condition c, with DXC of h in hex. Figure 20-8 on page 20-15
SFi IEEE invalid-operation flag, FPC 1.0.
SFx IEEE inexact flag, FPC 1.4.
T(x) The value x is placed at the target operand location.

Figure 20-19. Results: CONVERT TO LOGICAL

CONVERT TO PACKED

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CPDT</td>
<td>EDAC</td>
<td>Long DFP source, packed result</td>
</tr>
<tr>
<td>CPXT</td>
<td>‘EDAD’</td>
<td>Extended DFP source, packed result</td>
</tr>
</tbody>
</table>

The significand digits of the DFP first operand and the sign bit of the first operand are converted to the packed format. The exponent in the combination field is ignored. The specified number of rightmost bytes of packed digits are placed at the second-operand location.

If there are not enough significand digits to fill all of the packed bytes, zero digits are appended to the significand as leftmost digits.

The number of bytes containing rightmost significant digits of the converted first operand is specified by L₂. The length in bytes of the second operand is 1-18 for
The M₃ field has the following format:

```
S / P  F
0 1 2 3
```

The bits of the M₃ field are defined as follows:

- **Sign Control (S):** Bit 0 of the M₃ field is the sign control (S). When S is zero, the second operand does not have a sign field. When S is one, the second operand has a sign field. That is, the rightmost four bit positions of the rightmost byte are a sign.

- **Reserved:** Bit 1 of the M₃ field is reserved and should be zero.

- **Plus-Sign-Code Control (P):** Bit 2 of the M₃ field is the plus-sign-code control (P). When P is zero, the plus sign is encoded as 1100 binary. When P is one, the plus sign is encoded as 1111 binary. When the S bit is zero, the P bit is ignored.

- **Force-Plus-Zero Control (F):** Bit 3 of the M₃ field is the force-plus-zero control (F). When F is zero and a signed value of negative zero results, no action is taken. When F is one and the absolute value of the result placed in the second operand location is zero, the result is set to indicate a positive zero with the sign code specified by the P bit. When the S bit is zero, the F bit is ignored.

**Special Conditions**

The operation is performed for any first operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

If the first operand is an infinity or a NaN, a zero digit is appended as the leftmost digit (LMD) of the significand, thereby conceptually forming the effective significand to be converted. The specified number of rightmost effective significand digits and the sign bit are converted to the packed format, the result is placed at the second-operand location, and execution completes with condition code 3.

For any type of first operand, including an infinity and a NAN, when one or more leftmost nonzero digits of the significand are lost because the second operand field is too short, the result is obtained by ignoring the overflow digits, condition code 3 is set, and, if the decimal-overflow mask bit is one, a program interruption for decimal overflow occurs. The operand lengths alone are not an indication of overflow; nonzero digits must have been lost during the operation.

A specification exception is recognized, and the operation is suppressed, when any of the following is true:

- For CPDT, the L₂ field is greater than 8.
- For CPXT, the R₁ field designates an invalid floating-point-register pair, or the L₂ field is greater than 17.

**Resulting Condition Code:**

0  Source is zero  
1  Source is not special and is less than zero  
2  Source is not special and is greater than zero  
3  Source is special which is infinity, QNaN, SNaN, or a partial result

**Program Exceptions:**

- Access (Store operand 2)  
- Data with DXC 3, DFP instruction  
- Decimal overflow  
- Operation (if the DFP packed-conversion facility is not installed)  
- Specification  
- Transaction constraint

**Programming Notes:**

1. If the number of significant digits of a significand exceeds the specified number, one or more leftmost digits of the significand are ignored except for the detection of a decimal overflow exception.

2. A completion with condition code 0 indicates that the absolute value of the first operand is zero.
CONVERT TO SIGNED PACKED

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CSBTR</td>
<td>'B3E3'</td>
<td>Long DFP source, 64-bit signed-packed-decimal result in GR</td>
</tr>
<tr>
<td>CSXTR</td>
<td>'B3EB'</td>
<td>Extended DFP source, 128-bit signed-packed-decimal result in GRs</td>
</tr>
</tbody>
</table>

Rightmost significand digits of the DFP second operand are converted to the signed-packed-decimal format, and the result is placed at the first-operand location.

For CSBTR, the rightmost 15 digits in the trailing significand and the sign bit of the second operand are converted to a 64-bit result (15 4-bit decimal digits and a 4-bit sign); for CSXTR, the rightmost 31 digits in the trailing significand and the sign bit of the second operand are converted to a 128-bit result (31 4-bit decimal digits and a 4-bit sign). The sign of the result is the sign of the second operand.

Bit 3 of the M4 field is the plus sign-code selection bit. When the bit is zero, the plus sign is encoded as 1100; when the bit is one, the plus sign is encoded as 1111. Bits 0-2 are ignored.

The result is placed in the general register or general-register pair designated by R1.

This operation is performed for any second operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

For CSXTR, the R2 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized. Also, the R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (CSXTR only)

CONVERT TO UNSIGNED PACKED

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CUDTR</td>
<td>'B3E2'</td>
<td>Long DFP source, 64-bit unsigned-packed-decimal result in GR</td>
</tr>
<tr>
<td>CUXTR</td>
<td>'B3EA'</td>
<td>Extended DFP source, 128-bit unsigned-packed-decimal result in GRs</td>
</tr>
</tbody>
</table>

Rightmost significand digits of the DFP second operand are converted to the unsigned-packed-decimal format, and the result is placed at the first-operand location.

For CUDTR, 16 significand digits of the second operand are converted to a 64-bit result (16 4-bit decimal digits). If the second operand is an infinity or NaN, the 15 digits in the trailing significand are padded with a zero digit on the left to form a 16 significand digits.

For CUXTR, the rightmost 32 digits in the trailing significand of the second operand are converted to a 128-bit result (32 4-bit decimal digits).

The result is placed in the general register or general-register pair designated by R1.

This operation is performed for any second operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

For CUXTR, the R2 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized. Also, the R1 field designates an even-odd pair of general registers and must designate an even-numbered register; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.
**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (CUXTR only)
- Transaction constraint

## CONVERT TO ZONED

### Mnemonic

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L₂</th>
<th>B₂</th>
<th>D₂</th>
<th>R₁</th>
<th>M₃</th>
<th>Op Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>R₁,D₂(L₂,B₂),M₃</td>
<td>[RSL-b]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Op Code

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>CZDT</td>
<td>‘EDA8’</td>
<td>Long DFP source, zoned result</td>
</tr>
<tr>
<td>CZXT</td>
<td>‘EDA9’</td>
<td>Extended DFP source, zoned result</td>
</tr>
</tbody>
</table>

The specified number of rightmost significand digits of the DFP first operand and the sign bit of the first operand are converted to the zoned format, and the result is placed at the second-operand location. The exponent in the combination field is ignored.

The number of rightmost significand digits of the first operand to be converted is specified by L₂. The length in bytes of the second operand is 1-34 for CZXT, corresponding to a length code in L₂ of 0-33, meaning 1-34 digits. The length in bytes of the second operand is 1-16 for CZDT, corresponding to a length code in L₂ of 0-15, meaning 1-16 digits.

The M₃ field has the following format:

```
SZPF
0 1 2 3
```

The bits of the M₃ field are defined as follows:

- **Sign Control (S):** Bit 0 of the M₃ field is the sign control (S). When S is zero, the second operand does not have a sign field, and the zone field is set as determined by the Z bit. When S is one, the second operand has a sign field. That is, the leftmost four bit positions of the rightmost byte are a sign.

- **Zone Control (Z):** Bit 1 of the M₃ field is the zone control (Z). When Z is zero, each zone field of the second operand is stored as 1111 binary, except that the zone field of the rightmost byte is set to the sign when the S bit is one. When Z is one, each zone field of the second operand is stored as 0011 binary, except that the zone field of the rightmost byte is set to the sign when the S bit is one.

- **Plus-Sign-Code Control (P):** Bit 2 of the M₃ field is the plus-sign-code control (P). When P is zero, the plus sign is encoded as 1100 binary. When P is one, the plus sign is encoded as 1111 binary.

When the S bit is zero, the P bit is ignored and assumed to be zero. The zone of the rightmost digit is set as determined by the Z bit.

- **Force-Plus-Zero Control (F):** Bit 3 of the M₃ field is the force-plus-zero control (F). When F is zero, no action is taken. When F is one and the absolute value of the result placed at the second-operand location is zero, the sign of the result is set to indicate a plus value with the sign code specified by the P bit.

When the S bit is zero, the F bit is ignored and assumed to be zero.

### Special Conditions

The operation is performed for any first operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

If the first operand is an infinity or a NaN, a zero digit is assumed to be the leftmost digit (LMD) of the significand, thereby conceptually forming the effective significand to be converted. The specified number of rightmost effective-significand digits and the sign bit are converted to the zoned format, the result is placed at the second-operand location, and execution completes with condition code 3.

For any type of first operand, including an infinity, and a NaN, when one or more leftmost nonzero digits of the significand are lost because the second-operand field is too short, the result is obtained by ignoring the overflow digits, condition code 3 is set, and, if the decimal-overflow mask bit is one, a program interruption for decimal overflow occurs. The operand lengths alone are not an indication of overflow; non-zero digits must have been lost during the operation.

A specification exception is recognized, and the operation is suppressed, when any of the following is true:

---

20-35
• For CZDT, the L₂ field is greater than or equal to 16, meaning 17 or more digits.
• For CZXT, the R₁ field designates an invalid floating-point-register pair, or the L₂ field is greater than or equal to 34, meaning 35 or more digits.

**Resulting Condition Code:**

0 Source is zero  
1 Source is less than zero  
2 Source is greater than zero  
3 Infinity, QNaN, SNaN, Partial result

**Program Exceptions:**

• Access (Store operand 2)  
• Data with DXC 3, DFP instruction  
• Decimal overflow  
• Operation (if the DFP zoned-conversion facility is not installed)  
• Specification  
• Transaction constraint

**Programming Notes:**

1. An ASCII zoned-decimal operand may be stored as signed when the S bit is one. This is entirely up to the program as ASCII representations are usually unsigned and positive with no concept of a rightmost zone being used as a sign.

2. If the number of significant digits of a significand exceeds the specified number, one or more leftmost digits of the significand are ignored.

3. Depending on the model, for CZXT, when the L₂ field specifies 32 or 33 (meaning 33 or 34 digits), performance may be significantly worse than if shorter lengths are specified.

4. A completion with condition code 0 indicates that the absolute value of the first operand is zero.

**DIVIDE**

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>R₁,R₂,R₃</th>
<th>[RRF-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R₃</td>
<td>/ / /</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic1 Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>DDTR 'B3D1'</td>
<td>Long DFP</td>
</tr>
<tr>
<td>DXTR 'B3D9'</td>
<td>Extended DFP</td>
</tr>
</tbody>
</table>

The second operand (the dividend) is divided by the third operand (the divisor), and the quotient is placed at the first-operand location. No remainder is preserved.

If divisor is nonzero and both the dividend and divisor are finite numbers, the second operand is divided by the third operand to form an intermediate quotient. The intermediate quotient, if nonzero, is rounded to the target format and the rounded value is then placed at the first-operand location.

When the floating-point extension facility is installed, the intermediate quotient is rounded by rounding as specified by the modifier in the M₄ field:

<table>
<thead>
<tr>
<th>M₄</th>
<th>Effective Rounding Method</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>1</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>2</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>3</td>
<td>Round to prepare for shorter precision</td>
</tr>
<tr>
<td>4</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>5</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>6</td>
<td>Round toward +∞</td>
</tr>
<tr>
<td>7</td>
<td>Round toward -∞</td>
</tr>
<tr>
<td>8</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>9</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>10</td>
<td>Round toward +∞</td>
</tr>
<tr>
<td>11</td>
<td>Round toward -∞</td>
</tr>
<tr>
<td>12</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>13</td>
<td>Round to nearest with ties toward 0</td>
</tr>
<tr>
<td>14</td>
<td>Round away from 0</td>
</tr>
<tr>
<td>15</td>
<td>Round to prepare for shorter precision</td>
</tr>
</tbody>
</table>

When the modifier field is zero or two, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 1, or 3-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-
7, the quantum-exception control is zero and recognition of the exception is not suppressed.

When the floating-point extension facility is not installed, no quantum exception is recognized. If bits 20-23 of the instruction contain a value of zero, the intermediate quotient is rounded according to the current DFP rounding mode; if bits 20-23 of the instruction contain a nonzero value, it is unpredictable which rounding method is performed.

When the dividend is a finite number and the divisor is infinity, then a value of zero with zero significant and zero biased exponent is produced.

The sign of the quotient, if the quotient is numeric, is the exclusive or of the operand signs. This includes the sign of a zero or infinite quotient.

When the delivered value is exact, the preferred quantum is the quantum of the dividend divided by the quantum of the divisor; when the delivered value is inexact, the preferred quantum is the smallest quantum.

The result placed at the first-operand location is canonical.

If the divisor is zero but the dividend is nonzero and finite, an IEEE-division-by-zero exception is recognized. If the dividend and divisor are both zero, or if both are infinite, regardless of sign, an IEEE-invalid-operation exception is recognized.

See Figure 20-20 on page 20-37 for a detailed description of the results of this instruction.

For DXTR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid operation
- Division by zero
- Overflow
- Underflow
- Inexact
- Quantum (if the floating-point extension facility is installed)

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (DXTR and DXTRA only)
- Transaction constraint

### Table: Results for \( b \div c \) when divisor (c) is

<table>
<thead>
<tr>
<th>Dividend (b) ( b )</th>
<th>( \infty )</th>
<th>( -\infty )</th>
<th>( -0 )</th>
<th>( +0 )</th>
<th>( +\infty )</th>
<th>QNaN</th>
<th>SNaN</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \infty )</td>
<td>X: T(dNaN)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>X: T(dNaN)</td>
<td>T(\pm)</td>
</tr>
<tr>
<td>( -\infty )</td>
<td>T(\pm)</td>
<td>R(b+c)</td>
<td>X: T(\pm)</td>
<td>X: T(\pm)</td>
<td>R(b+c)</td>
<td>T(\pm)</td>
<td>X: T(c*)</td>
</tr>
<tr>
<td>( -0 )</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>X: T(dNaN)</td>
<td>X: T(dNaN)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>X: T(c*)</td>
</tr>
<tr>
<td>( +0 )</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>X: T(dNaN)</td>
<td>X: T(dNaN)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
</tr>
<tr>
<td>( +\infty )</td>
<td>X: T(dNaN)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>T(\pm)</td>
<td>X: T(dNaN)</td>
<td>T(\pm)</td>
</tr>
<tr>
<td>QNaN</td>
<td>T(b)</td>
<td>T(b)</td>
<td>T(b)</td>
<td>T(b)</td>
<td>T(b)</td>
<td>T(b)</td>
<td>T(b)</td>
</tr>
<tr>
<td>SNaN</td>
<td>X: T(b*)</td>
<td>X: T(b*)</td>
<td>X: T(b*)</td>
<td>X: T(b*)</td>
<td>X: T(b*)</td>
<td>X: T(b*)</td>
<td>X: T(b*)</td>
</tr>
</tbody>
</table>

**Explanation:**
- The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
- dNaN Default NaN.
- Fn Nonzero finite number (includes both subnormal and normal numbers).
- R(x) Rounding and range action is performed on the value x. See Figure 20-5 on page 20-10. The result is canonical.
- T(x) The canonical result x is placed at the target operand location.
- Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.
- Xz: IEEE division-by-zero exception. The results shown are produced only when FPC 0.1 is zero.
- zt A value of zero with zero significant and zero biased exponent.

Figure 20-20. Results: DIVIDE
Programming Note: For DIVIDE, when the delivered value is inexact, the preferred quantum is the smallest quantum which is not always the same quantum as that closest to the quantum of the dividend divided by the quantum of the divisor.

For example, with the short data format, when \( 5000001 \times 10^{-7} \) is divided by \( 400 \times 10^0 \), the smallest quantum for the delivered value is \( 1 \times 10^{-8} \). However, the quantum that is closest to the quantum of the dividend divided by the quantum of the divisor is \( 1 \times 10^{-7} \).

**EXTRACT BIASED EXPONENT**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>EEDTR</td>
<td>'B3E5'</td>
<td>Long DFP source, 64-bit binary-integer result</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EEXTR</td>
<td>'B3ED'</td>
<td>Extended DFP source, 64-bit binary-integer result</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The biased exponent of the DFP second operand is placed at the first-operand location.

When the second operand is a finite number, the biased exponent of the second operand is placed at the first-operand location. When the second operand is an infinity, QNaN, or SNaN, a special value is placed at the first-operand location.

The result is a 64-bit signed binary integer that is placed in the general register designated by R1.

This operation is performed for any second operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

See Figure 20-21 for a detailed description of the results of this instruction.

For EEXTR, the R2 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (EEXTR only)
- Transaction constraint

**EXTRACT SIGNIFICANCE**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>ESDTR</td>
<td>'B3E7'</td>
<td>Long DFP source, 64-bit binary-integer result</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ESXTR</td>
<td>'B3EF'</td>
<td>Extended DFP source, 64-bit binary-integer result</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The number of DFP significant digits of the DFP second operand is placed at the first-operand location.

When the second operand is a finite number, the result is set to the number of DFP significant digits of the second operand. When the second operand is an infinity, QNaN, or SNaN, the result is set to -1, -2, or -3, respectively.

The result is a 64-bit signed binary integer that is placed in the general register designated by R1.

See Figure 20-22 for a detailed description of the results of this instruction.

**Second-operand data**

<table>
<thead>
<tr>
<th>Nonzero finite number</th>
<th>NSD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Zero</td>
<td>0</td>
</tr>
<tr>
<td>Infinity</td>
<td>-1</td>
</tr>
<tr>
<td>QNaN</td>
<td>-2</td>
</tr>
<tr>
<td>SNaN</td>
<td>-3</td>
</tr>
</tbody>
</table>

**Explanation:**
- NSD The number of DFP significant digits of the second operand.

Figure 20-21. Results: EXTRACT BIASED EXPONENT

Figure 20-22. Results: EXTRACT SIGNIFICANCE
This operation is performed for any second operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

For ESXTR, the R₂ field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (ESXTR only)
- Transaction constraint

---

**INSERT BIASED EXPONENT**

```
Mnemonic    R₁,R₂,R₃    [RRF-b]
```

```
Op Code     R₃    ∥∥∥∥    R₁    R₂
0            16  20  24  28  31
```

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>IEDTR</td>
<td>'B3F6'</td>
<td>Long DFP</td>
</tr>
<tr>
<td>IEXTR</td>
<td>'B3FE'</td>
<td>Extended DFP</td>
</tr>
</tbody>
</table>

A DFP operand is produced by combining the requested biased exponent with the sign bit and the significand of the DFP third operand, and the result is placed in the first-operand location.

The value of the requested biased exponent is a 64-bit signed binary integer and is located in the general register designated by R₂.

When the value of the requested biased exponent is in the range between zero and the maximum biased exponent, inclusively, for the target format, the result is a finite number. The biased exponent of the result is set to the value of the requested biased exponent; the significand of the result is set to the significand of the third operand. If the third operand is an infinity or NaN, the significand of the third operand contains the digits in the trailing significand of the third operand padded with a zero digit on the left.

When the value of the requested biased exponent is -1, the result is an infinity. The reserved field of the result is set to zero; the trailing significand of the result is set to the trailing significand of the third operand.

When the value of the requested biased exponent is equal to -2, less than -3, or greater than the maximum biased exponent for the target format, the result is a QNaN; when the value of the requested biased exponent is -3, the result is an SNaN. When a NaN is produced as the result, the reserved field of the result is set to zero, and the trailing significand of the result is set to the trailing significand of the third operand.

The sign of the result is the same as the sign of the third operand.

The preferred quantum is the quantum that corresponds to the requested biased exponent. If the delivered value is a finite number, it is always represented with the preferred quantum.

The result placed at the first-operand location is canonical, except for infinity. When the result is an infinity, if all digits in the trailing significand of the third operand are zeros, then the result is a canonical infinity; otherwise, the result is an infinity that has the reserved field set to zero, canonical declets in the encoded trailing-significand field, and some nonzero digits in the trailing significand.

See Figure 20-23 for a detailed description of the results of this instruction.

This operation is performed for any requested biased exponent and any third operand without causing an IEEE exception.

For IEXTR, the R₁ and R₃ fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (IEXTR only)
- Transaction constraint

**Programming Note:** Infinities produced as DFP results have the reserved field set to zero and have canonical declets in the encoded trailing-significand...
field. An infinity is not considered canonical unless all digits in the trailing significand are zeros.

LOAD AND TEST

Mnemonic R1,R2 [RRE]

<table>
<thead>
<tr>
<th>Op Code</th>
<th>0</th>
<th>16</th>
<th>24</th>
<th>28</th>
<th>31</th>
</tr>
</thead>
<tbody>
<tr>
<td>Mnemonic</td>
<td>LTDTR</td>
<td>'B3D6'</td>
<td>Long DFP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Mnemonic</td>
<td>LTXTR</td>
<td>'B3DE'</td>
<td>Extended DFP</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The second operand is placed at the first-operand location, and its sign and magnitude are tested to determine the setting of the condition code. The condition code is set the same as for a comparison of the second operand with zero.

The second operand is canonicalized before it is placed at the first-operand location. If the second operand is an SNaN, an IEEE-invalid-operation exception is recognized; if there is no interruption, the result is the corresponding QNaN.

The preferred quantum is the quantum of the second operand. If the delivered value is a finite number, it is always represented with the preferred quantum.

The result placed at the first-operand location is canonical.

See Figure 20-24 for a detailed description of the results of this instruction.

For LTXTR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

- 0 Result is zero
- 1 Result is less than zero
- 2 Result is greater than zero
- 3 Result is a NaN

**IEEE Exceptions:**

- Invalid operation

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (LTXTR only)
- Transaction constraint
### LOAD FP INTEGER

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Results for some instructions with a single operand (b) when second operand (b) is</th>
<th>~∞</th>
<th>-∞</th>
<th>0</th>
<th>+∞</th>
<th>QNaN</th>
<th>SNaN</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT FROM FIXED</td>
<td>−</td>
<td>R(b)</td>
<td>−</td>
<td>T(+0)</td>
<td>R(b)</td>
<td>−</td>
<td>−</td>
</tr>
<tr>
<td>CONVERT FROM LOGICAL</td>
<td>−</td>
<td>−</td>
<td>−</td>
<td>T(+0)</td>
<td>R(b)</td>
<td>−</td>
<td>−</td>
</tr>
<tr>
<td>LOAD AND TEST</td>
<td>T(−∞)</td>
<td>T(b)</td>
<td>T(−0)</td>
<td>T(+0)</td>
<td>T(b)</td>
<td>T(+∞)</td>
<td>T(b)</td>
</tr>
<tr>
<td>LOAD LENGTHENED (XIC = 0)</td>
<td>T(−∞)</td>
<td>T(b) 1</td>
<td>T(0)</td>
<td>T(+0)</td>
<td>T(b) 1</td>
<td>T(+∞)</td>
<td>T(b) 1</td>
</tr>
<tr>
<td>LOAD LENGTHENED (XIC = 1)</td>
<td>N(−∞) 2</td>
<td>T(b) 1</td>
<td>T(−0)</td>
<td>T(+0)</td>
<td>T(b) 1</td>
<td>N(+∞) 2</td>
<td>T(b) 1</td>
</tr>
<tr>
<td>LOAD ROUNDED (XIC = 0)</td>
<td>T(−∞)</td>
<td>R(b)</td>
<td>T(0)</td>
<td>T(+0)</td>
<td>R(b)</td>
<td>T(+∞)</td>
<td>T(b) 2</td>
</tr>
<tr>
<td>LOAD ROUNDED (XIC = 1)</td>
<td>N(−∞) 2</td>
<td>R(b)</td>
<td>T(0)</td>
<td>T(+0)</td>
<td>R(b)</td>
<td>N(+∞) 2</td>
<td>T(b) 2</td>
</tr>
</tbody>
</table>

**Explanation:**

- The results do not depend on this condition.
- * The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
- 1 The operand is extended to the longer format by appending zeros on the left before it is placed at the target operand location.
- 2 The operand is shortened to the target format by truncating the leftmost digits.
- Fn Nonzero finite number (includes both subnormal and normal).
- N(±∞) The resultant infinity has the reserved field set to zero and has canonical declets in the encoded trailing-significand field. The result is not considered canonical unless all digits in the trailing significand are zeros.
- R(v) Rounding and range action is performed on the value v. See Figure 20-5 on page 20-10. The result is canonical.
- R(b) The value b is converted to the exact floating-point number v, and then action R(v) is performed. The result is canonical.
- T(x) The canonical result x is placed at the target operand location.
- Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.
- XiC IEEE-invalid-operation-exception control, bit 0 of the M4 field.

Figure 20-24. Results: Some Single-Operand Instructions

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Mnemonic R1, M1, R2, M4</th>
<th>Op Code</th>
<th>M3</th>
<th>M2</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOAD AND TEST</td>
<td>FIDTR ‘B3D7’</td>
<td>‘B3D7’</td>
<td>Long DFP</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FIXTR ‘B3DF’</td>
<td>Extended DFP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The second operand is rounded to an integer value in the same floating-point format, and the result is placed at the first-operand location.

The second operand, if a finite number, is rounded to an integer value as specified by the modifier in the M3 field:

<table>
<thead>
<tr>
<th>M3</th>
<th>Effective Rounding Method</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>1</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>2</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>3</td>
<td>Round to prepare for shorter precision</td>
</tr>
<tr>
<td>4</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>5</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>6</td>
<td>Round toward +∞</td>
</tr>
</tbody>
</table>

When the modifier field is zero, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 8-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

When the floating-point extension facility is installed and if the modifier field is 2, rounding is controlled by the current DFP rounding mode specified in the FPC register; if the field is 1, or 3-7, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode. If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-7, the quantum-exception con-
trol is zero and recognition of the exception is not suppressed.

When the floating-point extension facility is not installed, no quantum exception is recognized. If the \( M_2 \) modifier field is 1-7, it is unpredictable which rounding method is performed.

In the absence of an interruption, if the second operand is an infinity, the result is the canonical infinity; if the second operand is a QNaN, the result is the canonicalized source QNaN that has the same sign and payload as the source; if the second operand is an SNaN, the result is the corresponding QNaN.

The sign of the result is the sign of the second operand, even when the result is zero.

Bit 1 of the \( M_4 \) field is the IEEE-inexact-exception control (XxC). Bits 0, 2, and 3 are ignored.

When the result differs in value from the second operand, if XxC is zero, an IEEE-inexact exception is recognized. If XxC one, then no IEEE-inexact exception is recognized.

This operation performs a functionally-constrained rounding. Neither overflow nor underflow condition can occur.

When the delivered value is exact, the preferred quantum is the larger value of one and the quantum of the second operand; when the delivered value is inexact, the preferred quantum is one. If the delivered value is a finite number, it is always represented with the preferred quantum.

The result placed at the first-operand location is canonical.

See Figure 20-25 on page 20-42 for a detailed description of the results of FIDTR and FIXTR.

When the floating-point extension facility is installed, if the quantum of the delivered finite number is not equal to the quantum of the second operand and if XqC is zero, then a quantum exception is recognized.

For FIXTR, the R fields must designate valid floating-point-register fields; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**

- Invalid operation
- Inexact
- Quantum (if the floating-point extension facility is installed)

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (FIXTR only)
- Transaction constraint

<table>
<thead>
<tr>
<th>Second Operand (b)</th>
<th>Is n Inexact (n ≠ b)</th>
<th>IEEE Inexact Exception Control (XxC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Is n Incremented (ln lbi l)</th>
<th>Is Q &lt; 1</th>
<th>Quantum-Exception Control (XqC)(^2)</th>
<th>Quantum Exception Mask (FPC 0.5)</th>
<th>Inv.-Op. Mask (FPC 0.0)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(-∞)</td>
</tr>
<tr>
<td>-Fn</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(n)</td>
</tr>
<tr>
<td>-Fn</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(n)</td>
</tr>
<tr>
<td>-Fn</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>T(n), SFq&lt;1</td>
</tr>
<tr>
<td>-Fn</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>T(n), PIDq(04)</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>0</td>
<td>0</td>
<td>Yes</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(n), SFx&lt;1</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>0</td>
<td>0</td>
<td>Yes</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>T(n), SFx&lt;1, SFq&lt;1</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>0</td>
<td>0</td>
<td>Yes</td>
<td>0</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>T(n), PIDq(04)</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>0</td>
<td>1</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(n), PIDx(08)</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>0</td>
<td>1</td>
<td>Yes</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(n), PIDy(0C)</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(n)</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>1</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>0</td>
<td>—</td>
<td>—</td>
<td>T(n), SFq&lt;1</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>1</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>1</td>
<td>—</td>
<td>—</td>
<td>T(n), PIDq(04)</td>
</tr>
</tbody>
</table>

*Figure 20-25. Results: LOAD FP INTEGER*
Programming Notes:

1. Unassigned bits in the M₄ field are reserved for future extensions and should be set to zeros; otherwise, the program may not operate compatibly in the future.

2. If the DFP source operand is numeric with a quantum of at least one so that it is already an integer, the result value and quantum remain the same. Other numeric DFP source operands that are integers with a quantum less than one are

<table>
<thead>
<tr>
<th>Second Operand (b)</th>
<th>Is n Inexact Exception Control (XnC)</th>
<th>XnC Mask (FPC 0.4)</th>
<th>Is n Inexact Quantum-Exception Control (XnQ)</th>
<th>Quantum-Exception Mask (FPC 0.5)</th>
<th>Inv.-Op. Mask (FPC 0.0)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>-0</td>
<td>No'</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>—</td>
<td>T(-0)</td>
</tr>
<tr>
<td>-0</td>
<td>No'</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>1</td>
<td>T(-0)</td>
</tr>
<tr>
<td>-0</td>
<td>No'</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>T(-0), SFq−1</td>
</tr>
<tr>
<td>-0</td>
<td>No'</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>T(-0), PiDq(04)</td>
</tr>
<tr>
<td>+0</td>
<td>No'</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>—</td>
<td>T(+0)</td>
</tr>
<tr>
<td>+0</td>
<td>No'</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>1</td>
<td>T(+0)</td>
</tr>
<tr>
<td>+0</td>
<td>No'</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>T(+0), SFq−1</td>
</tr>
<tr>
<td>+0</td>
<td>No'</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>T(+0), PiDq(04)</td>
</tr>
<tr>
<td>+Fn</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>1</td>
<td>T(n)</td>
</tr>
<tr>
<td>+Fn</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>T(n), SFq−1</td>
</tr>
<tr>
<td>+Fn</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>Yes</td>
<td>0</td>
<td>T(n), PiDq(04)</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>Yes</td>
<td>0</td>
<td>Yes</td>
<td>1</td>
<td>T(n), SFx−1</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>Yes</td>
<td>0</td>
<td>Yes</td>
<td>0</td>
<td>T(n), SFx−1, SFq−1</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>Yes</td>
<td>0</td>
<td>Yes</td>
<td>0</td>
<td>T(n), PiDq(04)</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>Yes</td>
<td>0</td>
<td>Yes</td>
<td>1</td>
<td>T(n), PiDq(04)</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>Yes</td>
<td>1</td>
<td>No</td>
<td>—</td>
<td>T(n), PiDx(08)</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>Yes</td>
<td>1</td>
<td>Yes</td>
<td>1</td>
<td>T(n)</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>Yes</td>
<td>1</td>
<td>Yes</td>
<td>0</td>
<td>T(n), SFq−1</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>Yes</td>
<td>1</td>
<td>Yes</td>
<td>0</td>
<td>T(n), PiDq(04)</td>
</tr>
<tr>
<td>+∞</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(+∞)</td>
</tr>
<tr>
<td>QNaN</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>T(b)</td>
</tr>
<tr>
<td>SNaN</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>0</td>
<td>T(b′), SFi−1</td>
</tr>
<tr>
<td>SFNa</td>
<td>No</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>1</td>
</tr>
</tbody>
</table>

Explanations:

The results do not depend on this condition or mask bit.

*The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.

This condition is true by virtue of the state of some condition to the left of this column.

XnC is defined only if the floating-point extension facility is installed.

The value derived when the source value, b, is rounded to an integer using the effective rounding method.

Fn Finite nonzero number (includes both subnormal and normal).

PiDc(h) Program interruption for data exception, condition c, with DXC of h in hex. See Figure 20-8 on page 20-15.

PiDq(04) Program interruption for data exception, quantum-exception condition q, with DXC of 04 in hex. It is defined only if the floating-point extension facility is installed.

Q Quantum of the second operand.

SF i IEEE invalid-operation flag, FPC 1.0.

SFq Quantum exception flag, FPC 1.5. The flag is defined only if the floating-point extension facility is installed.

SFx IEEE inexact flag, FPC 1.4.

T(x) The canonical result x is placed at the target operand location. The result, when it is a finite number, is always represented with the preferred quantum.

Figure 20-25. Results: LOAD FP INTEGER
converted to the same value with a quantum of one.

**LOAD LENGTHENED**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>LDETR</td>
<td>'B3D4'</td>
<td>Short DFP source, long DFP result</td>
</tr>
<tr>
<td>LXDTR</td>
<td>'B3DC'</td>
<td>Long DFP source, extended DFP result</td>
</tr>
</tbody>
</table>

The second operand is converted to a longer format, and the result is placed at the first-operand location.

Bit 0 of the \( M_4 \) field controls the handling of SNaN and infinity, and is called the IEEE-invalid-operation-exception control (XiC). Bits 1-3 are ignored. When XiC is zero, recognition of IEEE-invalid-operation exception is not suppressed; when XiC is one, recognition of the exception is suppressed.

When the second operand is a finite number, the value of the second operand is placed in the target format.

When the second operand is an infinity, if XiC is zero, the result is the canonical infinity for the target format; if XiC is one, the result is the source infinity with the reserved field of the target format being set to zero, the trailing significand being extended by appending zeros on the left, and all decimals in the encoded trailing-significand field being canonicalized.

When the second operand is a QNaN, the result is the canonicalized source QNaN with the payload extended by appending zeros on the left.

When the second operand is an SNaN, if XiC is zero, an invalid-operation exception is recognized and the nontrap result is the corresponding QNaN with the payload extended by appending zeros on the left; if XiC is one, no invalid-operation exception is recognized, and the result is the canonicalized source SNaN with the payload extended by appending zeros on the left.

The sign of the result is the same as the sign of the second operand.

The delivered value is always exact and the preferred quantum is the quantum of the second operand.

When XiC is zero, the result placed at the first-operand location is canonical. When XiC is one, the result is canonical, except for infinity. See the detailed description above for producing an infinity when XiC is one.

See Figure 20-24 on page 20-41 for a detailed description of the results of this instruction.

For LXDTR, the \( R_1 \) field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**

- Invalid operation

**Program Exceptions:**

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (LXDTR only)
- Transaction constraint

**Programming Notes:**

1. Unassigned bits in the \( M_4 \) field are reserved for future extensions and should be set to zeros; otherwise, the program may not operate compatibly in the future.

2. The equivalent operations of LOAD LENGTHENED (short to long) in the Power architecture do not recognize the invalid-operation exception for both BFP and DFP. The equivalent operations of LOAD LENGTHENED in z/Architecture do recognize the exception for BFP. The IEEE-invalid-operation exception control (XiC) is provided for compatibility.

3. Infinities produced as DFP results have the reserved field set to zero and have canonical decimals in the encoded trailing-significand field. An infinity is not considered canonical unless all digits in the trailing significand are zeros.
LOAD ROUNDED

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
<th>R3</th>
<th>R4</th>
</tr>
</thead>
<tbody>
<tr>
<td>LEDTR</td>
<td>'B3D5'</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LDXTR</td>
<td>'B3DD'</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The second operand, in the format of the source, is rounded to the precision of the target, and the result is placed at the first-operand location.

The second operand, if it is a finite number, is rounded as specified by the modifier in the M3 field:

<table>
<thead>
<tr>
<th>M3</th>
<th>Effective Rounding Method</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>1</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>2</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>3</td>
<td>Round to prepare for shorter precision</td>
</tr>
<tr>
<td>4</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>5</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>6</td>
<td>Round toward $+\infty$</td>
</tr>
<tr>
<td>7</td>
<td>Round toward $-\infty$</td>
</tr>
<tr>
<td>8</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>9</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>10</td>
<td>Round toward $+\infty$</td>
</tr>
<tr>
<td>11</td>
<td>Round toward $-\infty$</td>
</tr>
<tr>
<td>12</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>13</td>
<td>Round to nearest with ties toward 0</td>
</tr>
<tr>
<td>14</td>
<td>Round away from 0</td>
</tr>
<tr>
<td>15</td>
<td>Round to prepare for shorter precision</td>
</tr>
</tbody>
</table>

When the modifier field is zero, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 8-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

When the modifier field is 2, rounding is controlled by the current DFP rounding mode specified in the FPC register; if the field is 1, or 3-7, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode. If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-7, the quantum-exception control is zero and recognition of the exception is not suppressed.

When the floating-point extension facility is not installed, no quantum exception is recognized. If the M3 modifier field is 1-7, it is unpredictable which rounding method is performed.

Bit 0 of the M4 field controls the handling of SNaN and infinity, and is called the IEEE-invalid-operation-exception control (XIC). When XIC is zero, recognition of IEEE-invalid-operation exception is not suppressed; when XIC is one, recognition of IEEE-invalid-operation exception is suppressed.

When the floating-point extension facility is installed, bit 1 of the M4 field is the IEEE-inexact-exception control (XxC), and bits 2-3 are ignored. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact-exception is suppressed.

In the absence of a trap overflow or trap underflow, the result is in the format and length of the target. However, when a trap overflow or trap underflow occurs, the operation is completed by producing a scaled result in the same format and length as the source but rounded to the precision of the target. In this case, the result is selected from a subset of the cohort for the delivered value in the source format. This subset consists of members that have the number of DFP significand digits equal to or less than the precision of the target format. For LEDTR, the result has at most seven DFP significant digits; for LDXTR, the result has at most 16 DFP significant digits.

When the floating-point extension facility is not installed, and if the M4 field is 2, rounding is controlled by the current DFP rounding mode specified in the FPC register; if the field is 3-7, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode. If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-7, the quantum-exception control is zero and recognition of the exception is not suppressed.

When the second operand is an infinity, if XIC is zero, the result is the canonical infinity for the target format; if XIC is one, the result is the source infinity with the reserved field of the target format being set to zero, the trailing significand being shortened by removing leftmost digits, and declets corresponding to the shortened trailing significand being canonicalized.
When the second operand is a QNaN, the result is the canonicalized source QNaN with the payload shortened by removing leftmost digits.

When the second operand is an SNaN, if XiC is zero, an invalid-operation exception is recognized and the nontrap result is the corresponding QNaN with the payload shortened by removing leftmost digits; if XiC is one, no invalid-operation exception is recognized, and the result is the canonicalized source SNaN with the payload shortened by removing leftmost digits.

The sign of the result is the same as the sign of the second operand.

When the delivered value is exact, the preferred quantum is the quantum of the second operand; when the delivered value is inexact, the preferred quantum is the smallest quantum.

When XiC is zero, the result placed at the first-operation location is canonical. When XiC is one, the result is canonical, except for infinity. See the detailed description above for producing an infinity when XiC is one.

See Figure 20-24 on page 20-41 for a detailed description of the results of this instruction.

For LDXTR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid operation
- Overflow
- Underflow
- Inexact
- Quantum (if the floating-point extension facility is installed)

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (LDXTR only)
- Transaction constraint

**Programming Notes:**

1. LOAD ROUNDED and the round-to-prepare-for-shorter-precision rounding method can be used to simulate a DFP operation with the precision of a shorter format and with the effect of single rounding. The round-to-prepare-for-shorter-precision rounding method is used by the operation, and the desirable rounding method is used by the subsequent LOAD ROUNDED instruction.

2. Unassigned bits in the M₄ field are reserved for future extensions and should be set to zeros; otherwise, the program may not operate compatibly in the future.

3. The equivalent operation of LOAD ROUNDED (long to short) in the Power architecture does not recognize the invalid-operation exception. IEEE-invalid-operation-exception control (XiC) is provided for compatibility.

4. Infinities produced as DFP results have the reserved field set to zero and have canonical declets in the encoded trailing-significand field. An infinity is not considered canonical unless all digits in the trailing significand are zeros.

5. In case of a trap overflow or a trap underflow, the number of DFP significand digits of the delivered result is limited to the precision of the target format. For example, when the source operand is $75958100 \times 10^{369}$ and is represented with the quantum of $10^{369}$, execution of LEDTR using the round-away-from-0 rounding method produces a value of $7595810 \times 10^{178}$ with the delivered quantum of $10^{178}$ as the trap overflow result.
The product of the second operand (the multiplicand) and the third operand (the multiplier) is placed at the first-operand location.

If both source operands are finite numbers, they are multiplied to form an intermediate product. The intermediate product is rounded to the target format and the rounded value is then placed at the first-operand location.

When the floating-point extension facility is installed, the intermediate product is rounded by rounding as specified by the modifier in the $M_4$ field:

$$
\begin{align*}
M_4 & \quad \text{Effective Rounding Method} \\
0 & \quad \text{According to the current DFP rounding mode} \\
1 & \quad \text{Round to nearest with ties away from 0} \\
2 & \quad \text{According to the current DFP rounding mode} \\
3 & \quad \text{Round to prepare for shorter precision} \\
4 & \quad \text{Round to nearest with ties to even} \\
5 & \quad \text{Round toward 0} \\
6 & \quad \text{Round toward } +\infty \\
7 & \quad \text{Round toward } -\infty \\
8 & \quad \text{Round to nearest with ties to even} \\
9 & \quad \text{Round toward 0} \\
10 & \quad \text{Round toward } +\infty \\
11 & \quad \text{Round toward } -\infty \\
12 & \quad \text{Round to nearest with ties away from 0} \\
13 & \quad \text{Round to nearest with ties toward 0} \\
14 & \quad \text{Round away from 0} \\
15 & \quad \text{Round to prepare for shorter precision}
\end{align*}
$$

When the modifier field is zero or two, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 1, or 3-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-7, the quantum-exception control is zero and recognition of the exception is not suppressed.

When the floating-point extension facility is not installed, no quantum exception is recognized. If bits 20-23 of the instruction contain a value of zero, the intermediate product is rounded according to the current DFP rounding mode; if bits 20-23 of the instruction contain a nonzero value, it is unpredictable which rounding method is performed.

The sign of the product, if the product is numeric, is the exclusive or of the operand signs. This includes the sign of a zero or infinite product.

When the delivered value is exact, the preferred quantum is the product of the quanta of the two source operands; when the delivered value is inexact, the preferred quantum is the smallest quantum.

The result placed at the first-operand location is canonical.

See Figure 20-26 on page 20-48 for a detailed description of the results of this instruction.

If one source operand is a zero and the other an infinity, an IEEE-invalid-operation exception is recognized.

For MXTR and MXTRA, the $R$ fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

IEEE Exceptions:
- Invalid operation
- Overflow
- Underflow
- Inexact
- Quantum (if the floating-point extension facility is installed)

Program Exceptions:
- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (MXTR and MXTRA only)
- Transaction constraint

Programming Notes:
1. Interchanging the two operands in a DFP multiplication does not affect the value of the product when the result is numeric. This is not true, however, when both operands are QNaNs, in which case the result is the canonical QNaN derived from the second operand; or when both operands are SNaNs and the IEEE invalid-operation
When both the second and third operands are finite numbers, if the quantum of the third operand is equal to or larger than the requested quantum, the value of the third operand with the requested quantum is placed at the first-operand location. If the quantum of the third operand is smaller than the requested quantum, the third operand is rounded to the requested quantum by rounding as specified by the modifier in the M₄ field, and the result with the requested quantum is placed at the first-operand location.

When the modifier field is zero, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 8-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

When the floating-point extension facility is installed and if the modifier field is 2, rounding is controlled by the current DFP rounding mode specified in the FPC.
register; if the field is 1, or 3-7, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode. If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-7, the quantum-exception control is zero and recognition of the exception is not suppressed.

When the floating-point extension facility is not installed, no quantum exception is recognized. If the modifier field is 1-7, it is unpredictable which rounding method is performed.

The sign of the result, if numeric, is the same as the sign of the third operand.

This operation performs a functionally-constrained rounding, and does not recognize an underflow exception. No overflow condition can occur.

The preferred quantum is the requested quantum. If the delivered value is a finite number, it is always represented with the preferred quantum.

The result placed at the first-operand location is canonical.

See Figure 20-27 on page 20-50 for a detailed description of the results of this instruction.

An invalid-operation exception is recognized when the resultant value cannot be represented in the target format with the requested quantum. When the invalid-operation exception is recognized, and if the exception is disabled, the result is the default QNaN.

An IEEE inexact exception is recognized when the result differs in value from the third operand.

When the floating-point extension facility is installed, if the quantum of the delivered finite number is not equal to the quantum of the third operand and if XqC is zero, then a quantum exception is recognized.

For QAXTR, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid operation
- Inexact
- Quantum (if the floating-point extension facility is installed)

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (QAXTR only)
- Transaction constraint
Programming Notes:

1. When the third operand is larger than \((10^p - 1) \times 10^{Q_b}\) in magnitude, an invalid-operation exception is recognized, where \(p\) is the format precision and \(10^{Q_b}\) is the requested quantum.

   The expression, \((10^p - 1) \times 10^{Q_b}\), specifies the largest magnitude that can be represented with the requested quantum in the format. A value larger than \((10^p - 1) \times 10^{Q_b}\) in magnitude will have more than \(p\) digits when the value is represented with the requested quantum.

2. When both source operands are finite numbers, an invalid-operation exception can occur only if the requested quantum is smaller than the quantum of the third operand; and an inexact exception can occur only if the requested quantum is larger than the quantum of the third operand.

### Table 20-27: Results: QUANTIZE

| Relation | Is \(|V_c| > (10^p - 1) \times 10^{Q_b}\)? | Result for Q(b:c) |
|----------|----------------------------------------|-------------------|
| \(10^{Q_b} < 10^{Q_c}\) | Yes | Xi: T(dNaN) |
| \(10^{Q_b} = 10^{Q_c}\) | | T(c) |
| \(10^{Q_b} > 10^{Q_c}\) | | Rq(c) |

### Explanation:

1. The quantum of the second operand and the third operand is \(10^{Q_b}\) and \(10^{Q_c}\), respectively.

- **dNaN**: Default NaN.
- **E(0)**: The value zero with the quantum of operand b is placed at the target operand location.
- **Fn**: Finite nonzero number (includes both subnormal and normal).
- **Q(b:c)**: See Figure 20-28.
- **T(x)**: The canonical result x is placed at the target operand location.
- **Xi**: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

### Figure 20-28. Results: Q(b:c)
### REROUND

**Mnemonic** \( R_1, R_2, R_3, M_4 \) \([RRF-b]\)

<table>
<thead>
<tr>
<th>Op Code</th>
<th>( R_3 )</th>
<th>( M_4 )</th>
<th>( R_1 )</th>
<th>( R_2 )</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>16</td>
<td>24</td>
<td>28</td>
<td>31</td>
</tr>
</tbody>
</table>

**Op Code** | **Operands**
--- | ---
RRDTR | "B3F7" Long DFP
RRXTR | "B3FF" Extended DFP

The third operand is rounded to the requested significance, and the result is placed at the first-operand location.

The requested significance, which specifies a number of DFP significant digits, is an unsigned binary integer and is in bit positions 58-63 of general register \( R_2 \). The contents of bit positions 0-57 of general register \( R_2 \) are ignored.

When the third operand is a finite number, if the requested significance is zero, then the value of the third operand with the original quantum is placed at the first-operand location.

When the third operand is a finite number, if the requested significance is nonzero, and if the number of DFP significant digits of the third operand is equal to or less than the requested significance, then the value of the third operand with the original quantum is placed at the first-operand location.

When the third operand is a finite number, if the requested significance is nonzero, and if the number of DFP significant digits of the third operand is greater than the requested significance, then the third operand is rounded to the requested significance, and the result with the requested significance is placed at the first-operand location.

The third operand is rounded to the requested significance by rounding as specified by the modifier in the \( M_4 \) field:

<table>
<thead>
<tr>
<th>( M_4 )</th>
<th>Effective Rounding Method</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>1</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>2</td>
<td>According to the current DFP rounding mode</td>
</tr>
<tr>
<td>3</td>
<td>Round to prepare for shorter precision</td>
</tr>
<tr>
<td>4</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>5</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>6</td>
<td>Round toward (+\infty)</td>
</tr>
</tbody>
</table>

When the modifier field is zero, rounding is controlled by the current DFP rounding mode specified in the FPC register. When the field is 8-15, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode.

When the floating-point extension facility is installed and if the modifier field is 2, rounding is controlled by the current DFP rounding mode specified in the FPC register; if the field is 1, or 3-7, rounding is performed as specified by the modifier, regardless of the current DFP rounding mode. If the modifier field is 0 or 8-15, the quantum-exception control (XqC) is one and recognition of the quantum exception is suppressed; if the modifier field is 1-7, the quantum-exception control is zero and recognition of the exception is not suppressed.

When the floating-point extension facility is not installed, no quantum exception is recognized. If the \( M_4 \) modifier field is 1-7, it is unpredictable which rounding method is performed.

The sign of the result, if numeric, is the same as the sign of the third operand.

This operation performs a functionally-constrained rounding, and does not recognize an underflow exception. No overflow condition can occur.

When the delivered value is exact, if the requested significance is zero, or if the requested significance is nonzero and the number of DFP significant digits of the third operand is equal to or less than the requested significance, then the preferred quantum is the quantum of the third operand. When the delivered value is exact, if the requested significance is nonzero and the number of DFP significant digits of the third operand is greater than the requested significance, then the preferred quantum is the quantum that corresponds to the requested significance.
When the delivered value is inexact, the preferred quantum is the quantum that corresponds to the requested significance.

If the delivered value is a finite number, it is always represented with the preferred quantum.

The result placed at the first-operand location is canonical.

See Figure 20-29 for a detailed description of the results of this instruction.

<table>
<thead>
<tr>
<th>Significance Comparison</th>
<th>Is</th>
<th>Rp(c)</th>
<th>(10^{(k-1)} \times 10^{Q_{\text{max}}} )</th>
<th>Results for REROUND when the Third Operand (c) is</th>
</tr>
</thead>
<tbody>
<tr>
<td>k = 0 ( k \neq 0 ); ( k &gt; m )</td>
<td>--</td>
<td>( T(\pm \infty) )</td>
<td>( T(c) )</td>
<td>( T(c) )</td>
</tr>
<tr>
<td>k ( k = m )</td>
<td>--</td>
<td>( T(\pm \infty) )</td>
<td>( T(c) )</td>
<td>--</td>
</tr>
<tr>
<td>k ( k &lt; m )</td>
<td>No</td>
<td>( T(\pm \infty) )</td>
<td>Rp(c)</td>
<td>--</td>
</tr>
</tbody>
</table>

Explanation:

-- Not applicable.

* The SNaN is converted to the corresponding QNaN and placed at the target operand location.

dNaN Default NaN.

Fn Nonzero finite numbers (includes both subnormal and normal).

k The requested significance.

m Number of DFP significant digits in the third operand (c).

Qmax Maximum right-units-view exponent.

Rp(c) The third operand (c) is rounded to the requested significance. The result is canonical and is represented with the preferred quantum.

Explanation:

\( T(x) \) The canonical result x is placed at the target operand location. The result is canonical and, when it is a finite number, is represented with the preferred quantum.

Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

Figure 20-29. Results: REROUND

An invalid-operation exception is recognized when the resultant value cannot be represented in the target format with the requested significance. When the invalid-operation exception is recognized, and if the exception is disabled, the result is the default QNaN.

When an invalid-operation exception is recognized, the IEEE inexact exception is not recognized.

In the absence of an invalid-operation exception, if the result differs in value from the third operand, an IEEE inexact exception is recognized.

When the floating-point extension facility is installed, if the quantum of the delivered finite number is not equal to the quantum of the third operand and if XqC is zero, then a quantum exception is recognized.

For RRXTR, the \( R_1 \) and \( R_3 \) fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

IEEE Exceptions:

- Invalid operation
- Inexact
- Quantum (if the floating-point extension facility is installed)

Program Exceptions:

- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (RRXTR only)
- Transaction constraint

Programming Notes:

1. REROUND and the round-to-prepare-for-shorter-precision rounding method can be used to simulate a DFP operation with a precision other than any supported format precision and with the effect of single rounding. The round-to-prepare-for-shorter-precision rounding method is used by the operation, and the desirable round-
ing method is used by the subsequent REROUND instruction.

2. When the rounded intermediate value is larger than \((10^k - 1) \times 10^{Q_{\text{max}}}\) in magnitude, an invalid-operation exception is recognized, where \(k\) is the requested significance and \(10^{Q_{\text{max}}}\) is the largest quantum for the format.

The expression, \((10^k - 1) \times 10^{Q_{\text{max}}}\), specifies the largest magnitude that can be represented with the requested significance in the format. A value larger than \((10^p - 1) \times 10^{Q_{\text{b}}}\) in magnitude will have a quantum larger than \(10^{Q_{\text{max}}}\) when the value is represented with the requested significance.

\[\text{SHIFT SIGNIFICAND LEFT}\]

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>R_1,R_3,D_2(X_2,B_2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>OpCode</td>
<td>R_3 X_2 B_2 D_2 R_1</td>
</tr>
<tr>
<td>0 8 12 16 20 32 36 40 47</td>
<td>[RXF]</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>SLDT</td>
<td>'ED40'</td>
<td>Long DFP</td>
</tr>
<tr>
<td>SLXT</td>
<td>'ED48'</td>
<td>Extended DFP</td>
</tr>
</tbody>
</table>

The significand of the third operand is shifted left the number of digits specified by the second-operand address, and the result is placed at the first-operand location.

Digits shifted out of the leftmost digit are lost. Zeros are supplied to the vacated positions on the right. The sign of the result is the same as the sign of the third operand.

For a finite number, all digits in the significand participate in the shift and the result is a finite number with the same biased exponent as the third operand and the shifted significand. For an infinity, all digits in the trailing significand participate in the shift, and the result is an infinity with the shifted trailing significand and a zero in the reserved field of the format. For a QNaN or SNaN, all digits in the payload participate in the shift and the result is a QNaN or SNaN, respectively, with the shifted payload and a zero in the reserved field of the format.

The second-operand address is not used to address data; its rightmost six bits indicate the number of digit positions to be shifted. The remainder of the address is ignored.

\[\text{SHIFT SIGNIFICAND RIGHT}\]

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>R_1,R_3,D_2(X_2,B_2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>OpCode</td>
<td>R_3 X_2 B_2 D_2 R_1</td>
</tr>
<tr>
<td>0 8 12 16 20 32 36 40 47</td>
<td>[RXF]</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRDT</td>
<td>'ED41'</td>
<td>Long DFP</td>
</tr>
<tr>
<td>SRXT</td>
<td>'ED49'</td>
<td>Extended DFP</td>
</tr>
</tbody>
</table>

The significand of the third operand is shifted right the number of digits specified by the second-operand address, and the result is placed at the first-operand location.

The preferred quantum is the quantum of the third operand. If the delivered value is a finite number, it is always represented with the preferred quantum.

The result placed at the first-operand location is canonical, except for infinity. When the result is an infinity, if all digits in the trailing significand of the result are zeros, then the result is canonical; otherwise, the result is an infinity that has the reserved field set to zero, canonical declets in the encoded trailing-significand field, and some nonzero digits in the trailing significand.

This operation is performed for any second operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

For SLXT, the \(R_1\) and \(R_3\) fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (SLXT only)
- Transaction constraint

**Programming Note:** Infinities produced as DFP results have the reserved field set to zero and have canonical declets in the encoded trailing-significand field. An infinity is not considered canonical unless all digits in the trailing significand are zeros.
Digits shifted out of the rightmost digit are lost. Zeros are supplied to the vacated positions on the left. The sign of the result is the same as the sign of the third operand.

For a finite number, all digits in the significand participate in the shift and the result is a finite number with the same biased exponent as the third operand and the shifted significand. For an infinity, all digits in the trailing significand participate in the shift, and the result is an infinity with the shifted trailing significand and a zero in the reserved field of the format. For a QNaN or SNaN, all digits in the payload participate in the shift and the result is a QNaN or SNaN, respectively, with the shifted payload and a zero in the reserved field of the format.

The second-operand address is not used to address data; its rightmost six bits indicate the number of digit positions to be shifted. The remainder of the address is ignored.

The preferred quantum is the quantum of the third operand. If the delivered value is a finite number, it is always represented with the preferred quantum.

The result placed at the first-operand location is canonical. When the result is an infinity, if all digits in the trailing significand are zero, then the result is canonical; otherwise, the result is an infinity that has the reserved field set to zero, canonical declets in the encoded trailing-significand field, and some nonzero digits in the trailing significand.

This operation is performed for any second operand, including an infinity, QNaN, or SNaN, without causing an IEEE exception.

For SRXT, the R₃ and R₅ fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (SRXT only)
- Transaction constraint

**Programming Note:** Infinities produced as DFP results have the reserved field set to zero and have canonical declets in the encoded trailing-significand field. An infinity is not considered canonical unless all digits in the trailing significand are zeros.

### SUBTRACT

<table>
<thead>
<tr>
<th>Mnemonic1</th>
<th>R₁, R₂, R₃</th>
<th>[RRF-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R₃  / / / R₁ R₂</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>16  20  24  28  31</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic1 Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>SDTR 'B3D3'</td>
<td>Long DFP</td>
</tr>
<tr>
<td>SXTR 'B3DB'</td>
<td>Extended DFP</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2</th>
<th>R₁, R₂, R₃, M₄</th>
<th>[RRF-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code</td>
<td>R₃  M₄  R₁ R₂</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>16  24  28  31</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic2 Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>SDTRA 'B3D3'</td>
<td>Long DFP</td>
</tr>
<tr>
<td>SXTRA 'B3DB'</td>
<td>Extended DFP</td>
</tr>
</tbody>
</table>

The third operand is subtracted from the second operand, and the difference is placed at the first-operand location.

The execution of SUBTRACT is identical to that of ADD, except that the third operand, if numeric, participates in the operation with its sign bit inverted. When the third operand is a NaN, it participates in the operation with its sign bit unchanged. See Figure 20-11 on page 20-20 for the detailed results of ADD.

When the delivered value is exact, the preferred quantum is the smaller quantum of the two source operands; when the delivered value is inexact, the preferred quantum is the smallest quantum.

The result placed at the first-operand location is canonical.

For SXTR and SXTRA, the R fields must designate valid floating-point-register pairs; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0 Result is zero
1 Result is less than zero
2 Result is greater than zero
3 Result is a NaN

**IEEE Exceptions:**
- Invalid operation
- Overflow
- Underflow
- Inexact
- Quantum (if the floating-point extension facility is installed)

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Data with DXC for IEEE exception
- Operation (if the DFP facility is not installed)
- Specification (SXTR and SXTRA only)
- Transaction constraint

**Programming Note:** See the programming notes for ADD.

**TEST DATA CLASS**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>R1,D2(X2,B2)</th>
<th>OpCode</th>
</tr>
</thead>
<tbody>
<tr>
<td>TDCET</td>
<td>'ED50' Short DFP</td>
<td></td>
</tr>
<tr>
<td>TDCDT</td>
<td>'ED54' Long DFP</td>
<td></td>
</tr>
<tr>
<td>TDCXT</td>
<td>'ED58' Extended DFP</td>
<td></td>
</tr>
</tbody>
</table>

The class and sign of the first operand are examined to select one bit from the second-operand address. Condition code 0 or 1 is set according to whether the selected bit is zero or one, respectively.

The second-operand address is not used to address data; instead, the rightmost 12 bits of the address, bits 52-63, are used to specify 12 combinations of data class and sign. Bits 0-51 of the second-operand address are ignored.

As shown in Figure 20-30, DFP operands are divided into six classes: zero, subnormal, normal, infinity, quiet NaN, and signaling NaN:

<table>
<thead>
<tr>
<th>DFP data class</th>
<th>Bit used when sign is +</th>
<th>Bit used when sign is -</th>
</tr>
</thead>
<tbody>
<tr>
<td>Zero</td>
<td>52</td>
<td>53</td>
</tr>
<tr>
<td>Subnormal</td>
<td>54</td>
<td>55</td>
</tr>
<tr>
<td>Normal</td>
<td>56</td>
<td>57</td>
</tr>
<tr>
<td>Infinity</td>
<td>58</td>
<td>59</td>
</tr>
<tr>
<td>Quiet NaN</td>
<td>60</td>
<td>61</td>
</tr>
<tr>
<td>Signaling NaN</td>
<td>62</td>
<td>63</td>
</tr>
</tbody>
</table>

**Figure 20-30. Second-Operand-Address Bits for TEST DATA CLASS**

corresponding to the class and sign of the first operand is one, condition code 1 is set; otherwise, condition code 0 is set.

Operands, including SNaNs and QNaNs, are examined without causing an IEEE exception.

For TDCXT, the R1 field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

**Resulting Condition Code:**

0 Selected bit is 0 (no match)
1 Selected bit is 1 (match)
2 --
3 --

**IEEE Exceptions:** None.

**Program Exceptions:**
- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (TDCXT only)
- Transaction constraint

**Programming Notes:**

1. TEST DATA CLASS provides a way to test an operand without risk of an exception or setting the IEEE flags.

2. The bits used to specify the combinations of data class and sign are not all the same for BFP and DFP. Specifically, BFP TEST DATA CLASS uses bits 54 and 55 for normal number, and bits 56 and 57 for subnormal number.
The group and sign of the first operand are examined to select one bit from the second-operand address. Condition code 0 or 1 is set according to whether the selected bit is zero or one, respectively.

The second-operand address is not used to address data; instead, the rightmost 12 bits of the address, bits 52-63, are used to specify 12 combinations of data group and sign. Bits 0-51 of the second-operand address are ignored.

TEST DATA GROUP is used to determine whether a finite number is safe. A finite number is safe if the exponent is neither maximum nor minimum, and the leftmost significand digit is zero.

Figure 20-31 on page 20-57 shows the data groups and the bit assignment. There are six data groups: safe zero, zero with extreme exponent, nonzero with extreme exponent, safe nonzero, nonzero leftmost significand digit with nonextreme exponent, and special. The special group is defined for infinity and NaN. Depending on the model, subnormal with nonextreme exponent may be placed in the nonzero-with-extreme-exponent group or the safe-nonzero group.

One or more of the second-operand-address bits may be set to one. If the second-operand-address bit corresponding to the group and sign of the first operand is one, condition code 1 is set; otherwise, condition code 0 is set.

Operands, including SNaNs and QNaNs, are examined without causing an IEEE exception.

For TDGXT, the $R_1$ field must designate a valid floating-point-register pair; otherwise, a specification exception is recognized.

### Test Data Group

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Op Code</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td>TDGET</td>
<td>'ED51'</td>
<td>Short DFP</td>
</tr>
<tr>
<td>TDGDT</td>
<td>'ED55'</td>
<td>Long DFP</td>
</tr>
<tr>
<td>TDGXT</td>
<td>'ED59'</td>
<td>Extended DFP</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>OpCode</th>
<th>Operands</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R_1, X_2, X_4, B_2</td>
<td></td>
</tr>
</tbody>
</table>

### Resulting Condition Code:

- 0: Selected bit is 0 (no match)
- 1: Selected bit is 1 (match)
- 2: --
- 3: --

### IEEE Exceptions:

None.

### Program Exceptions:

- Data with DXC 3, DFP instruction
- Operation (if the DFP facility is not installed)
- Specification (TDGXT only)
- Transaction constraint

### Programming Notes:

1. TEST DATA GROUP provides a way to test an operand without risk of an exception or setting the IEEE flags.
2. TEST DATA GROUP can be issued after an operation that produces a DFP result to quickly determine if the result is safe. For DFP results that are finite numbers, the result is safe if using a wider data format by the operation would have produced the same value and quantum. A safe result has two important characteristics: (1) the exponent is neither the maximum exponent nor the minimum exponent, and (2) the leftmost significand digit is zero.
3. TEST DATA GROUP may be used to test whether a nonzero finite number is safe by setting bits 58 and 59 of the second-operand address to ones.
4. TEST DATA GROUP may be used to test whether a nonzero finite number has reached the limit of the format precision but not the limit of the format range by setting bits 60 and 61 of the second-operand address to ones.
5. Subnormal with nonextreme exponent may be grouped with either the nonzero-with-extreme exponent group or the safe-nonzero group. The
program shouldn’t depend on which group sub-normal with nonextreme exponent is in.

### Densely Packed Decimal (DPD)

#### Decimal-to-DPD Mapping

The mapping of a 3-digit decimal number (000 - 999) to a 10-bit value, called a declet is shown in Figure 20-32 on page 20-58. The DPD entries are shown in hexadecimal. The first two digits of the decimal number are shown in the leftmost column and the third digit along the top row. The table is split into two halves, with the right half being a continuation of the left half.

#### DPD-to-Decimal Mapping

The mapping of the 10-bit declet to a 3-digit decimal number is shown in Figure 20-33 on page 20-59. The 10-bit declet value is split into a 6-bit index shown in the left column and a 4-bit index shown along the top row, both represented in hexadecimal. The values marked with an asterisk are results mapped from noncanonical declets and are explained further in the following section.

<table>
<thead>
<tr>
<th>DFP Operand</th>
<th>Exponent</th>
<th>LMD</th>
<th>Data Group</th>
<th>Bit used when sign is</th>
</tr>
</thead>
<tbody>
<tr>
<td>Zero</td>
<td>Nonextreme</td>
<td>z(^{+})</td>
<td>Safe zero</td>
<td>+ 52 53</td>
</tr>
<tr>
<td></td>
<td>Extreme</td>
<td>z(^{+})</td>
<td>Zero with extreme exponent</td>
<td>- 54 55</td>
</tr>
<tr>
<td>Nonzero finite</td>
<td>Extreme</td>
<td>--</td>
<td>Nonzero with extreme exponent</td>
<td>+ 56 57</td>
</tr>
<tr>
<td></td>
<td>Nonextreme</td>
<td>z</td>
<td>Safe nonzero</td>
<td>- 58 59</td>
</tr>
<tr>
<td></td>
<td>Nonextreme</td>
<td>nz</td>
<td>Nonzero leftmost significand digit with nonextreme exponent</td>
<td>+ 60 61</td>
</tr>
<tr>
<td>Infinity or NaN</td>
<td>na</td>
<td>na</td>
<td>Special</td>
<td>62 63</td>
</tr>
</tbody>
</table>

**Explanation:**

- --: The result does not depend on this condition.
- \(^{+}\): This condition is true by virtue of the condition to the left of this column.
- Extreme: Maximum right-units-view (RUV) exponent, Qmax, or minimum right-units-view (RUV) exponent, Qmin.
- Nonextreme: Qmax < right-units-view (RUV) exponent < Qmin.
- LMD: Leftmost significand digit.
- na: Not applicable.
- nz: Nonzero.
- z: Zero.

*Figure 20-31. Second-Operand-Address Bits for TEST DATA GROUP*
Figure 20-32. Decimal-to-DPD Mapping
<table>
<thead>
<tr>
<th></th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>090</td>
<td>089</td>
<td>088</td>
<td>087</td>
<td>086</td>
<td>085</td>
<td>084</td>
<td>083</td>
<td>082</td>
<td>081</td>
</tr>
<tr>
<td>B</td>
<td>080</td>
<td>079</td>
<td>078</td>
<td>077</td>
<td>076</td>
<td>075</td>
<td>074</td>
<td>073</td>
<td>072</td>
<td>071</td>
</tr>
<tr>
<td>C</td>
<td>070</td>
<td>069</td>
<td>068</td>
<td>067</td>
<td>066</td>
<td>065</td>
<td>064</td>
<td>063</td>
<td>062</td>
<td>061</td>
</tr>
<tr>
<td>D</td>
<td>060</td>
<td>059</td>
<td>058</td>
<td>057</td>
<td>056</td>
<td>055</td>
<td>054</td>
<td>053</td>
<td>052</td>
<td>051</td>
</tr>
<tr>
<td>E</td>
<td>050</td>
<td>049</td>
<td>048</td>
<td>047</td>
<td>046</td>
<td>045</td>
<td>044</td>
<td>043</td>
<td>042</td>
<td>041</td>
</tr>
<tr>
<td>F</td>
<td>040</td>
<td>039</td>
<td>038</td>
<td>037</td>
<td>036</td>
<td>035</td>
<td>034</td>
<td>033</td>
<td>032</td>
<td>031</td>
</tr>
</tbody>
</table>

* Result mapped from a noncanonical decit.
Overview

The vector facility provided in the z/Architecture architectural mode provides fixed-sized vectors ranging from one to sixteen elements. For most instructions, all of the data contained in a vector is operated on by the instructions defined in this facility. Some instructions only operate on a subset of the elements within a vector. If a vector is made up of multiple elements, each element is processed in parallel with the others. Instruction completion does not occur until processing of all elements is complete.

Vector Registers and Controls

Vector Enablement Control

The vector instructions should only be used if both the vector enablement control (bit 46) and the AFP-register-control (bit 45) in control register zero are set to one. If the vector facility for z/Architecture is installed and a vector instruction is executed without the vector enablement control set, a data exception with DXC FE hex is recognized. If bit 45 of control register zero is not also set to one, it is unpredictable if a data exception is recognized. If the vector facility
for z/Architecture is not installed, an operation exception is recognized.

**Programming Note:** When a control program initially enables the vector facility for z/Architecture for a task, which may occur in response to a data exception with DXC FE, it should ensure that newly enabled full vector registers as well as the rightmost portions of vector registers that overlap with any enabled floating-point registers are zeroed.

**Vector Storage Accesses**

All vector data appears in storage in the same left-to-right sequence as all other data formats. Bits of a data format that are numbered 0-7 constitute the byte in the leftmost (lowest-numbered) byte location in storage, bits 8-15 form the byte in the next sequential location, and so on. (See also “Storage Addressing” on page 3-2.)

**Saturating Arithmetic**

Some vector operations perform saturating operations. Saturation for signed binary integers means that if there is an overflow, the result is set to the largest positive number; if there is an underflow, the result is set to the largest negative number. Saturation for unsigned binary integers means that if there is an overflow, the result is set to the largest representable number; if there is an underflow, the result is set to zero.

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic Characteristics</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VECTOR GATHER ELEMENT (32)</td>
<td>VGEF VRV VF z^A A SP Dv</td>
<td>B_</td>
<td>E713</td>
<td>21-4</td>
</tr>
<tr>
<td>VECTOR GATHER ELEMENT (64)</td>
<td>VEGE VRV VF z^A A SP Dv</td>
<td>B_</td>
<td>E712</td>
<td>21-4</td>
</tr>
<tr>
<td>VECTOR GENERATE BYTE MASK</td>
<td>VGBM VRl-a VF z^A Dv</td>
<td>B_</td>
<td>E744</td>
<td>21-4</td>
</tr>
<tr>
<td>VECTOR GENERATE MASK</td>
<td>VGM VRl-b VF z^A SP Dv</td>
<td>B_</td>
<td>E746</td>
<td>21-4</td>
</tr>
<tr>
<td>VECTOR LOAD</td>
<td>VL VRX VF z^A Dv</td>
<td>B_</td>
<td>E706</td>
<td>21-5</td>
</tr>
<tr>
<td>VECTOR LOAD AND REPLICATE</td>
<td>VLR REP VRX VF z^A Dv</td>
<td>B_</td>
<td>E756</td>
<td>21-5</td>
</tr>
<tr>
<td>VECTOR LOAD ELEMENT (8)</td>
<td>VLEB VRX VF z^A A SP Dv</td>
<td>B_</td>
<td>E705</td>
<td>21-5</td>
</tr>
<tr>
<td>VECTOR LOAD ELEMENT (16)</td>
<td>VLEH VRX VF z^A A SP Dv</td>
<td>B_</td>
<td>E700</td>
<td>21-6</td>
</tr>
<tr>
<td>VECTOR LOAD ELEMENT (32)</td>
<td>VLEF VRX VF z^A A SP Dv</td>
<td>B_</td>
<td>E701</td>
<td>21-6</td>
</tr>
<tr>
<td>VECTOR LOAD ELEMENT (64)</td>
<td>VLEG VRX VF z^A A SP Dv</td>
<td>B_</td>
<td>E702</td>
<td>21-6</td>
</tr>
<tr>
<td>VECTOR LOAD ELEMENT IMMEDIATE (8)</td>
<td>VLEIB VRl-a VF z^A SP Dv</td>
<td>B_</td>
<td>E740</td>
<td>21-6</td>
</tr>
<tr>
<td>VECTOR LOAD ELEMENT IMMEDIATE (16)</td>
<td>VLEIH VRl-a VF z^A SP Dv</td>
<td>B_</td>
<td>E741</td>
<td>21-6</td>
</tr>
<tr>
<td>VECTOR LOAD ELEMENT IMMEDIATE (32)</td>
<td>VLEIF VRl-a VF z^A SP Dv</td>
<td>B_</td>
<td>E743</td>
<td>21-6</td>
</tr>
</tbody>
</table>

Figure 21-2. Summary of Vector Support Instructions

**Instructions**

All vector instructions, defined in chapters 21-24, have a field in bits 36-39 of the instruction labeled as RXB. This field contains the most significant bit for each of the vector register designated operands. Bits for register designations not specified by the instruction are reserved and should be set to zero; otherwise the program may not operate compatibly in the future.

The bits are defined as follows:

<table>
<thead>
<tr>
<th>Bit</th>
<th>MSB of Vector Register in Instruction Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>36</td>
<td>8-11</td>
</tr>
<tr>
<td>37</td>
<td>12-15</td>
</tr>
<tr>
<td>38</td>
<td>16-19</td>
</tr>
<tr>
<td>39</td>
<td>32-35</td>
</tr>
</tbody>
</table>

**Programming Note:** It is assumed that the assembler will set these bits whenever a vector register designation greater than 15 is specified.

Unless otherwise specified, all operands are vector-register operands. A “V” in the assembler syntax designates a vector operand.

Each instruction has an extended-mnemonic section which describes recommended extended mnemonics and their corresponding machine assembler syntax.
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VECTOR LOAD ELEMENT IMMEDIATE (64)</td>
<td>VLEIG</td>
<td>VRI-a VF G^7  A SP Dv</td>
<td>E742</td>
<td>21-6</td>
</tr>
<tr>
<td>VECTOR LOAD GR FROM VR ELEMENT</td>
<td>VLGV</td>
<td>VRS-c VF G^9  A SP Dv</td>
<td>E721</td>
<td>21-7</td>
</tr>
<tr>
<td>VECTOR LOAD LOGICAL ELEMENT AND ZERO</td>
<td>VLLEZ</td>
<td>VRX VF G^9  A SP Dv</td>
<td>B_2</td>
<td>21-7</td>
</tr>
<tr>
<td>VECTOR LOAD MULTIPLE</td>
<td>VLM</td>
<td>VRS-a VF G^9  A SP Dv</td>
<td>B_2</td>
<td>21-8</td>
</tr>
<tr>
<td>VECTOR LOAD TO BLOCK BOUNDARY</td>
<td>VLBB</td>
<td>VRX VF G^9  A SP Dv</td>
<td>B_2</td>
<td>21-8</td>
</tr>
<tr>
<td>VECTOR LOAD VR ELEMENT FROM GR</td>
<td>VLG</td>
<td>VRS-b VF G^9  A SP Dv</td>
<td>E722</td>
<td>21-9</td>
</tr>
<tr>
<td>VECTOR LOAD VR FROM GRS DISJOINT</td>
<td>VLVGP</td>
<td>VRR-l VF G^9  A Dv</td>
<td>E762</td>
<td>21-9</td>
</tr>
<tr>
<td>VECTOR LOAD WITH LENGTH</td>
<td>VLL</td>
<td>VRS-b VF G^9  A Dv</td>
<td>B_2</td>
<td>21-10</td>
</tr>
<tr>
<td>VECTOR MERGE HIGH</td>
<td>VMRH</td>
<td>VRR-c VF G^9  A SP Dv</td>
<td>E761</td>
<td>21-10</td>
</tr>
<tr>
<td>VECTOR MERGE LOW</td>
<td>VMRL</td>
<td>VRR-c VF G^9  A SP Dv</td>
<td>E760</td>
<td>21-10</td>
</tr>
<tr>
<td>VECTOR PACK</td>
<td>VPK</td>
<td>VRR-c VF G^9  A SP Dv</td>
<td>E794</td>
<td>21-11</td>
</tr>
<tr>
<td>VECTOR PACK SATURATE</td>
<td>VPKS</td>
<td>VRR-b C* VF G^9  A SP Dv</td>
<td>E797</td>
<td>21-11</td>
</tr>
<tr>
<td>VECTOR PACK LOGICAL SATURATE</td>
<td>VPKLS</td>
<td>VRR-b C* VF G^9  A SP Dv</td>
<td>E795</td>
<td>21-12</td>
</tr>
<tr>
<td>VECTOR PERMUTE</td>
<td>VPERM</td>
<td>VRR-e VF G^9  A Dv</td>
<td>E78C</td>
<td>21-13</td>
</tr>
<tr>
<td>VECTOR PERMUTE DOUBLEWORD IMMEDIATE</td>
<td>VPDI</td>
<td>VRR-c VF G^9  A Dv</td>
<td>E784</td>
<td>21-13</td>
</tr>
<tr>
<td>VECTOR REPlicate</td>
<td>VREP</td>
<td>VRR-c VF G^9  A SP Dv</td>
<td>E74D</td>
<td>21-14</td>
</tr>
<tr>
<td>VECTOR REPLICATE IMMEDIATE</td>
<td>VREPI</td>
<td>VRI-a VF G^9  A SP Dv</td>
<td>E745</td>
<td>21-14</td>
</tr>
<tr>
<td>VECTOR SCATTER ELEMENT (32)</td>
<td>VSCFE</td>
<td>VRV VF G^9  A SP Dv</td>
<td>ST B_2</td>
<td>21-15</td>
</tr>
<tr>
<td>VECTOR SCATTER ELEMENT (64)</td>
<td>VSCEG</td>
<td>VRV VF G^9  A SP Dv</td>
<td>ST B_2</td>
<td>21-15</td>
</tr>
<tr>
<td>VECTOR SELECT</td>
<td>VSEL</td>
<td>VRR-e VF G^9  A Dv</td>
<td>E78D</td>
<td>21-15</td>
</tr>
<tr>
<td>VECTOR SIGN EXTEND TO DOUBLEWORD</td>
<td>VSEG</td>
<td>VRR-a VF G^9  A SP Dv</td>
<td>E75F</td>
<td>21-15</td>
</tr>
<tr>
<td>VECTOR STORE</td>
<td>VST</td>
<td>VRX VF G^9  A Dv</td>
<td>ST B_2 E70E</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE ELEMENT (8)</td>
<td>VSTEB</td>
<td>VRX VF G^9  A SP Dv</td>
<td>ST B_2</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE ELEMENT (16)</td>
<td>VSTEH</td>
<td>VRX VF G^9  A SP Dv</td>
<td>ST B_2</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE ELEMENT (32)</td>
<td>VSTEF</td>
<td>VRX VF G^9  A SP Dv</td>
<td>ST B_2</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE ELEMENT (64)</td>
<td>VSTEG</td>
<td>VRX VF G^9  A SP Dv</td>
<td>ST B_2</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE MULTIPLE</td>
<td>VSTM</td>
<td>VRS-a VF G^9  A SP Dv</td>
<td>ST B_2</td>
<td>21-17</td>
</tr>
<tr>
<td>VECTOR STORE WITH LENGTH</td>
<td>VSTL</td>
<td>VRS-b VF G^9  A SP Dv</td>
<td>ST B_2</td>
<td>21-17</td>
</tr>
<tr>
<td>VECTOR UNPACK HIGH</td>
<td>VUPH</td>
<td>VRX-a VF G^9  A SP Dv</td>
<td>E7D7</td>
<td>21-17</td>
</tr>
<tr>
<td>VECTOR UNPACK LOGICAL HIGH</td>
<td>VUPLH</td>
<td>VRX-a VF G^9  A SP Dv</td>
<td>E7D5</td>
<td>21-18</td>
</tr>
<tr>
<td>VECTOR UNPACK LOW</td>
<td>VUPL</td>
<td>VRX-a VF G^9  A SP Dv</td>
<td>E7D6</td>
<td>21-18</td>
</tr>
<tr>
<td>VECTOR UNPACK LOGICAL LOW</td>
<td>VUPLL</td>
<td>VRX-a VF G^9  A SP Dv</td>
<td>E7D4</td>
<td>21-19</td>
</tr>
</tbody>
</table>

**Explanation:**

- G^7: Restricted from transactional execution when the effective allow-floating-point-operation control is zero.
- G^9: Restricted in the constrained transactional-execution mode; a transaction-constraint program exception may be recognized.
- A: Access exceptions for logical addresses.
- B_2: B_2 field designates an access register in the access-register mode.
- C*: Condition code optionally set.
- Dv: Vector-instruction data exception
- SP: Specification exception.
- ST: PER storage-alteration event.
- VF: Vector facility for z/Architecture
- VR: VRI instruction format
- VR: VRR instruction format
- VR: VRS instruction format
- VR: VX instruction format
- VR: VR instruction format

*Figure 21-2: Summary of Vector Support Instructions*
VECTOR GATHER ELEMENT

VGEF  \[E7\] \(V_1, D_2(V_2, B_2), M_3\)  [VRV]

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 20 & 32 & 36 & 40 & 47 \\
\end{array}
\]

The element-sized second operand replaces the specified element of the first operand indexed by the \(M_3\) field. The remaining elements are left unchanged. If the \(M_3\) field specifies a value greater than the highest numbered element in the first operand, of the specified element size, a specification exception is recognized.

For VGEF the elements in all operands are 4-bytes in size; for VGEG the elements in all operands are 8-bytes in size.

The second-operand address is generated by adding the unsigned binary integer value from the element in vector-register \(V_2\) indexed by the \(M_3\) field with the address in the \(B_2\) register along with the \(D_2\) value.

The displacement for VECTOR GATHER ELEMENT is treated as a 12-bit unsigned integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Extended Mnemonics:**
- Extended Mnemonic  Base Mnemonic
  - VZERO \(V_1\)  VGBM \(V_1,0\)
  - VONE \(V_1\)  VGBM \(V_1,X'FFFF'\)

**Programming Note:** VECTOR GENERATE BYTE MASK is the preferred method for setting a vector register to all zeroes or ones.

VECTOR GENERATE BYTE MASK

VGGM  \[E7\] \(V_1, I_2\)  [VRI-a]

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 32 & 36 & 40 & 47 \\
\end{array}
\]

For each bit in the second operand, if the bit is one, all bit positions in the corresponding byte element of the first operand are set to ones. If the bit is zero, all bit positions in the corresponding byte element of the first operand are set to zeros.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Extended Mnemonics:**

**Programming Note:** VECTOR GENERATE BYTE MASK is the preferred method for setting a vector register to all zeroes or ones.

VECTOR GENERATE MASK

VGM  \[E7\] \(V_1, I_2, I_3, M_4\)  [VRI-b]

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 24 & 32 & 36 & 40 & 47 \\
\end{array}
\]

For each element in the first operand a bit mask is generated. The mask consists of bits set to one starting at the bit position specified by the unsigned integer value in \(I_2\) and ending with the bit position specified by the unsigned integer value in \(I_3\). All other bit positions are set to zero. Only the number of bits needed to represent all of the bit positions for the
specified element size are used from the I\(_2\) and I\(_3\) fields, other bits are ignored. If the bit position in the I\(_2\) field is greater than the bit position in the I\(_3\) field, the range of bits wraps at the maximum bit position for the specified element size.

The M\(_4\) field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M(_4)</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2 for VL)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Programming Note:** For VL, performance may be reduced if the second operand is not on a quadword boundary.

### VECTOR LOAD AND REPLICATE

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VGMB</td>
<td>V(_1),I(_2),I(_3)</td>
</tr>
<tr>
<td>VGMH</td>
<td>V(_1),I(_2),I(_3)</td>
</tr>
<tr>
<td>VGMF</td>
<td>V(_1),I(_2),I(_3)</td>
</tr>
<tr>
<td>VGMG</td>
<td>V(_1),I(_2),I(_3)</td>
</tr>
</tbody>
</table>

**Extended Mnemonic Base Mnemonic**

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>'E7' V(_1),D(_2)(X(_2),B(_2)) M(_3)</td>
<td>[VRX]</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VLREPB</td>
<td>V(_1),D(_2)(X(_2),B(_2))</td>
</tr>
<tr>
<td>VLREPH</td>
<td>V(_1),D(_2)(X(_2),B(_2))</td>
</tr>
</tbody>
</table>

**Extended Mnemonic Base Mnemonic**

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>'E7' V(_1),V(_2)</td>
<td>[VRR-a]</td>
</tr>
</tbody>
</table>

The 128-bit second operand is placed unchanged in the first-operand location.

The displacement for VL is treated as a 12-bit unsigned integer.
VECTORN LOAD ELEMENT

### Extended Mnemonic
- VLEB \( V_1, D_2(X_2, B_2), M_3 \) [VRX]
- VLEH \( V_1, D_2(X_2, B_2), M_3 \) [VRX]
- VLEF \( V_1, D_2(X_2, B_2), M_3 \) [VRX]
- VLEG \( V_1, D_2(X_2, B_2), M_3 \) [VRX]

### Base Mnemonic
- VLREF \( V_1, D_2(X_2, B_2), M_3 \)
- VLREG \( V_1, D_2(X_2, B_2), M_3 \)

#### Programming Note:
For VLEB a specification is not recognized since the third operand cannot designate an index greater than the number of elements.

### Vector Load Element Immediate

#### VLEIB
- Extended Mnemonic: \( 'E7' V_1 X_2 B_2 D_2 M_3 \)
- Immediate: \( '00' \)

#### VLEIH
- Extended Mnemonic: \( 'E7' V_1 X_2 B_2 D_2 M_3 \)
- Immediate: \( '01' \)

#### VLEIF
- Extended Mnemonic: \( 'E7' V_1 X_2 B_2 D_2 M_3 \)
- Immediate: \( '02' \)

#### VLEG
- Extended Mnemonic: \( 'E7' V_1 X_2 B_2 D_2 M_3 \)
- Immediate: \( '03' \)

The element-sized second operand replaces the specified element of the first operand indexed by the \( M_3 \) field. The remaining elements are left unchanged. If the third operand specifies a value greater than the highest numbered element in the first operand, of the specified element size, a specification exception is recognized.

The displacement for VECTOR LOAD ELEMENT is treated as a 12-bit unsigned integer.

For VLEB the elements are byte sized. For VLEH the elements are halfword sized. For VLEF the elements are word sized. For VLEG the elements are doubleword sized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

### Vector Load Element Immediate

#### VLEIB
- Extended Mnemonic: \( 'E7' V_1 I_2 M_3 \)
- Immediate: \( '00' \)

#### VLEIH
- Extended Mnemonic: \( 'E7' V_1 I_2 M_3 \)
- Immediate: \( '01' \)

#### VLEIF
- Extended Mnemonic: \( 'E7' V_1 I_2 M_3 \)
- Immediate: \( '02' \)

#### VLEG
- Extended Mnemonic: \( 'E7' V_1 I_2 M_3 \)
- Immediate: \( '03' \)

The signed binary integer second operand is sign extended, if necessary, and replaces the specified element of the first operand. The remaining elements are left unchanged. The \( M_3 \) field specifies the element index of the first operand to replace. For VLEIB, only bits 8-15 of the second operand are placed into the byte element; bits 0-7 are ignored. If the third operand specifies a value greater than the highest numbered element in the first operand, of the specified element size, a specification exception is recognized.

For VLEIB the elements are byte sized. For VLEIH the elements are word sized. For VLEIF the elements are halfword sized. For VLEG the elements are doubleword sized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
**Programming Note:** For VLEIB a specification is not recognized since the third operand cannot designate an index greater than the number of elements.

**VECTOR LOAD GR FROM VR ELEMENT**

VLGV $R_1$, $V_3$, $B_2$, $D_2$, $M_4$ [VRS-c]

The element of the third operand indexed by the second-operand address is placed in the first-operand location. The third operand is a vector register. The first operand is a general register. If the index specified by the second-operand address is greater than the highest numbered element in the third operand, of the specified element size, the result in the first operand is unpredictable.

If the vector register element is smaller than a doubleword, the element is right aligned in the 64-bit general register and zeros fill the remaining bits.

The second-operand address is not used to address data; instead the rightmost 12 bits of the address are used to specify the index of an element within the third operand.

The $M_4$ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>$M_4$</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

**Extended Mnemonic** | **Base Mnemonic**
--- | ---
VLGVB $R_1$, $V_3$, $D_2(B_2)$ | VLGV $R_1$, $V_3$, $D_2(B_2)$,0
VLGVH $R_1$, $V_3$, $D_2(B_2)$ | VLGV $R_1$, $V_3$, $D_2(B_2)$,1
VLGVF $R_1$, $V_3$, $D_2(B_2)$ | VLGV $R_1$, $V_3$, $D_2(B_2)$,2
VLGVG $R_1$, $V_3$, $D_2(B_2)$ | VLGV $R_1$, $V_3$, $D_2(B_2)$,3

**VECTOR LOAD LOGICAL ELEMENT AND ZERO**

VLLEZ $V_1$, $X_2$, $B_2$, $D_2$, $M_3$ [VRX]

The unsigned element-sized second operand is placed in the rightmost sub-element or element of the leftmost doubleword element of the vector-register specified first operand. The bit positions of all other elements are set to zero. The element size is determined by the ES value in the $M_3$ field.

The displacement for VLLEZ is treated as a 12-bit unsigned binary integer.

The $M_3$ field specifies the element size control (ES). The ES control specifies the size of the element in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>$M_3$</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
**Vector Load Multiple**

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VLLEZB V_i D_j(X_k B_2)</td>
<td>VLLEZ V_i D_j(X_k B_2),0</td>
</tr>
<tr>
<td>VLLEZH V_i D_j(X_k B_2)</td>
<td>VLLEZ V_i D_j(X_k B_2),1</td>
</tr>
<tr>
<td>VLLEZF V_i D_j(X_k B_2)</td>
<td>VLLEZ V_i D_j(X_k B_2),2</td>
</tr>
<tr>
<td>VLLEZG V_i D_j(X_k B_2)</td>
<td>VLLEZ V_i D_j(X_k B_2),3</td>
</tr>
</tbody>
</table>

**Programming Note:** This instruction can be used for loading scalar values into vector registers.

The set of vector registers starting with the first operand vector register designation and ending with the third operand vector register designation are loaded from storage beginning at the location specified by the second operand address and continuing through as many locations as needed.

The vector registers are loaded in ascending order of their register numbers starting with the first operand vector register designation and continuing up to and including the third operand vector register designation. If the third operand vector register designation is less than the first operand vector register designation, a specification exception is recognized. The number of registers to be loaded is at most sixteen. If a range of more than sixteen registers is specified, a specification exception is recognized.

The displacement for VLM is treated as a 12-bit unsigned binary number.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

---

**Vector Load To Block Boundary**

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VLLEZB V_1 D_2(X_k B_2),M_3</td>
<td>VLLEZ V_1 D_2(X_k B_2),0</td>
</tr>
<tr>
<td>VLLEZH V_1 D_2(X_k B_2),M_3</td>
<td>VLLEZ V_1 D_2(X_k B_2),1</td>
</tr>
<tr>
<td>VLLEZF V_1 D_2(X_k B_2),M_3</td>
<td>VLLEZ V_1 D_2(X_k B_2),2</td>
</tr>
<tr>
<td>VLLEZG V_1 D_2(X_k B_2),M_3</td>
<td>VLLEZ V_1 D_2(X_k B_2),3</td>
</tr>
</tbody>
</table>

**Programming Notes:**

1. On some models, performance may be improved if the second operand is on a doubleword boundary.
2. If the first operand vector register designation and the third operand vector register designation specify the same vector register only 16-bytes are loaded.

The single vector-register first operand is loaded starting at the zero indexed byte element with bytes from the second operand. If a boundary condition is encountered, the rest of the first operand is unpredictable. Access exceptions are not recognized for second-operand locations beyond the specified boundary. If no boundary is encountered, all byte elements of the first operand are loaded with data from storage.

The displacement for VLBB is treated as a 12-bit unsigned integer.

The M_3 field specifies a code indicating the boundary at which the second operand ends. If a reserved value is specified, a specification exception is recognized.

**Code Boundary**

<table>
<thead>
<tr>
<th>Code</th>
<th>Boundary</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>64-Byte</td>
</tr>
<tr>
<td>1</td>
<td>128-Byte</td>
</tr>
<tr>
<td>2</td>
<td>256-Byte</td>
</tr>
<tr>
<td>3</td>
<td>512-Byte</td>
</tr>
<tr>
<td>4</td>
<td>1K-Byte</td>
</tr>
<tr>
<td>5</td>
<td>2K-Byte</td>
</tr>
<tr>
<td>6</td>
<td>4K-Byte</td>
</tr>
<tr>
<td>7-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (fetch, operand 2)
Programming Notes:

1. In certain circumstances, data may be loaded past the block boundary. However, this will only occur if there are no access exceptions on that data. The program should not depend on the unpredictable data being loaded by a particular model.

2. This instruction can be used for loading null-terminated character data without crossing a page, segment, or region boundary unnecessarily.

3. If a block size code equal to the cache line size of the processor is specified, performance may be improved due to the fact that subsequent accesses will be aligned.

4. The LOAD COUNT TO BLOCK BOUNDARY instruction may be used with the same specified boundary to obtain a count of the number of bytes loaded.

**VECTOR LOAD VR ELEMENT FROM GR**

\[ \text{VLVG} \quad V_1, R_3, D_2(B_2), M_4 \]  
\[ \text{[VRS-b]} \]

The third operand of size specified by the ES value in the \( M_4 \) field is placed into the element of the first operand indexed by the second-operand address. The third operand is a general register. The first operand is a vector register. If the index, specified by the second-operand address, is greater than the highest numbered element in the first operand, of the specified element size, it is unpredictable. Which element, if any, is replaced.

For element sizes less than doubleword the rightmost bits of the third operand are used.

The second operand is not used to address data; instead the rightmost 12 bits of the address are used to specify the index of an element within the first operand.

**VECTOR LOAD VR FROM GRS DISJOINT**

\[ \text{VLVGP} \quad V_1, R_2, R_3 \]  
\[ \text{[VRR-f]} \]

The general register specified second operand placed unchanged into bit positions 0-63 of the first operand. The general register specified third operand is placed unchanged into bit positions 64-127 of the first operand.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint
**VECTOR LOAD WITH LENGTH**

\[
\text{VLL} \quad \text{V}_1, \text{R}_3, \text{D}_2(\text{B}_2) \quad [\text{VRS-b}]
\]

```
<table>
<thead>
<tr>
<th></th>
<th>E7</th>
<th>V1</th>
<th>R3</th>
<th>B2</th>
<th>D2</th>
<th></th>
<th>RXB</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>36</td>
<td>40</td>
<td>47</td>
</tr>
</tbody>
</table>
```

Proceeding from left to right, bytes of the first operand are loaded from the second-operand location. The general-register \( R_3 \) contains a 32-bit unsigned integer that represents the highest indexed byte to load. If the third operand contains a value greater than or equal to the highest byte index of the vector, all bytes of the first operand are loaded. Zeros are placed in any bytes that are not loaded.

Access exceptions are only recognized for the bytes of the second operand that are loaded from storage.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (fetch, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Extended Mnemonics:**

\[
\text{VMRHB} \quad \text{V}_1, \text{V}_2, \text{V}_3 \quad \text{VMRH} \quad \text{V}_1, \text{V}_2, \text{V}_3, 0
\]

\[
\text{VMRHH} \quad \text{V}_1, \text{V}_2, \text{V}_3 \quad \text{VMRH} \quad \text{V}_1, \text{V}_2, \text{V}_3, 1
\]

\[
\text{VMRFH} \quad \text{V}_1, \text{V}_2, \text{V}_3 \quad \text{VMRH} \quad \text{V}_1, \text{V}_2, \text{V}_3, 2
\]

\[
\text{VMRFG} \quad \text{V}_1, \text{V}_2, \text{V}_3 \quad \text{VMRH} \quad \text{V}_1, \text{V}_2, \text{V}_3, 3
\]

**VECTOR MERGE HIGH**

\[
\text{VMRH} \quad \text{V}_1, \text{V}_2, \text{V}_3, \text{M}_4 \quad [\text{VRR-c}]
\]

```
<table>
<thead>
<tr>
<th></th>
<th>E7</th>
<th>V1</th>
<th>V2</th>
<th>V3</th>
<th>M4</th>
<th>RXB</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>36</td>
<td>40</td>
<td>47</td>
</tr>
</tbody>
</table>
```

Proceeding from left to right, the elements in the leftmost half of the second operand are placed into the even indexed elements of the first operand. Proceeding from left to right, the elements in the leftmost half of the third operand are placed into the odd indexed elements of the first operand. The elements in the low order half of the second and third operands are ignored.

If the same register is used to designate the first operand as either the second or third operands the source value is used throughout the operation with no intermediate updates.

The \( M_4 \) field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>( M_4 )</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**VECTOR MERGE LOW**

\[
\text{VMRL} \quad \text{V}_1, \text{V}_2, \text{V}_3, \text{M}_4 \quad [\text{VRR-c}]
\]

```
<table>
<thead>
<tr>
<th></th>
<th>E7</th>
<th>V1</th>
<th>V2</th>
<th>V3</th>
<th>M4</th>
<th>RXB</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>36</td>
<td>40</td>
<td>47</td>
</tr>
</tbody>
</table>
```

Proceeding from left to right, the elements in the rightmost half of the second operand are placed into the even indexed elements of the first operand. Proceeding from left to right, the elements in the rightmost half of the third operand are placed into the odd indexed elements of the first operand. The elements in the high order half of the second and third operands are ignored.

If the same register is used to designate the first operand as either the second or third operands the source value is used throughout the operation with no intermediate updates.

The \( M_4 \) field specifies the element size control (ES). The ES control specifies the size of the elements in
the vector register operands. If a reserved value is specified, a specification exception is recognized.

### M4 Element Size

0  Byte  
1  Halfword  
2  Word  
3  Doubleword  
4-15  Reserved

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VMRLB V1,V2,V3</td>
<td>VMRL V1,V2,V3,0</td>
</tr>
<tr>
<td>VMRLH V1,V2,V3</td>
<td>VMRL V1,V2,V3,1</td>
</tr>
<tr>
<td>VMRLF V1,V2,V3</td>
<td>VMRL V1,V2,V3,2</td>
</tr>
<tr>
<td>VMRLG V1,V2,V3</td>
<td>VMRL V1,V2,V3,3</td>
</tr>
</tbody>
</table>

**VECTOR PACK**

<table>
<thead>
<tr>
<th>VPK</th>
<th>V1,V2,V3,M4</th>
<th>[VRR-c]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘E’</td>
<td>V1</td>
<td>V2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

A source vector is created from the concatenation of the vector register-specified second operand followed by the vector-register-specified third operand. In a left to right fashion, each element in the source vector is reduced in size by half. The rightmost half of each element of the source vector is placed into the corresponding element of the vector-register-specified first operand.

If the same register is used to designate the first operand as either the second or third operands the source value is used throughout the operation with no intermediate updates.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in the second and third operands. The first operand contains elements half the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

### M4 Element Size

0  Reserved  
1  Halfword  
2  Word  
3  Doubleword  
4-15  Reserved

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VPKH V1,V2,V3</td>
<td>VPK V1,V2,V3,1</td>
</tr>
<tr>
<td>VPKF V1,V2,V3</td>
<td>VPK V1,V2,V3,2</td>
</tr>
<tr>
<td>VPKG V1,V2,V3</td>
<td>VPK V1,V2,V3,3</td>
</tr>
</tbody>
</table>

**VECTOR PACK SATURATE**

<table>
<thead>
<tr>
<th>VPKS</th>
<th>V1,V2,V3,M4,M5</th>
<th>[VRR-b]</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘E’</td>
<td>V1</td>
<td>V2</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

A source vector is created from the concatenation of the second operand followed by the third operand. In a left to right fashion each signed element in the source vector is reduced in size by half and placed in the corresponding element of the first operand. If the element in the source vector is outside of the allowable range of the target element, the target element is set to the maximum value in the target format in the direction of the overflow.

If the same register is used to designate the first operand as either the second or third operands, the original source value is used throughout the operation with no intermediate updates.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in
the second and third operands. The first operand contains elements half the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

\[ \text{VECTOR PACK LOGICAL SATURATE} \]

The \( M_5 \) field has the following format:

\[
\begin{array}{c|c|c|c}
\hline
\text{Reserved} & \text{Condition Code Set (CS)} & \text{Other Bits} \\
\hline
\text{Reserved} & \text{Reserved} & \text{Reserved} \\
\hline
\end{array}
\]

The bits of the \( M_5 \) field are defined as follows:

- **Reserved**: Bits 0, 1, and 2 are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.
- **Condition Code Set (CS)**: If bit 3 is 0, the code remains unchanged. If the bit is one, the code is set as described below.

**Resulting Condition Code**: When bit 3 of the \( M_5 \) field is one, the condition code is set as follows:

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No saturation</td>
</tr>
<tr>
<td>1</td>
<td>At least one but not all elements saturated</td>
</tr>
<tr>
<td>2</td>
<td>--</td>
</tr>
<tr>
<td>3</td>
<td>Saturation on all elements</td>
</tr>
</tbody>
</table>

When bit 3 of the \( M_5 \) field is zero, the code remains unchanged.

**Program Exceptions**:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics**:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VPKSH ( V_1, V_2, V_3 )</td>
<td>VPKS ( V_1, V_2, V_3, 1,0 )</td>
</tr>
<tr>
<td>VPKSF ( V_1, V_2, V_3 )</td>
<td>VPKS ( V_1, V_2, V_3, 2,0 )</td>
</tr>
</tbody>
</table>

A source vector is created from the concatenation of the second operand followed by the third operand. In a left to right fashion, each unsigned integer element in the source vector is reduced in size by half and placed in the corresponding element in the first operand. If the magnitude of the element in the source vector is greater than the largest magnitude representable in the target element, the target element is set to the largest representable magnitude value.

If the same register is used to designate the first operand as either the second or third operands, the original source value is used throughout the operation with no intermediate updates.

The \( M_4 \) field specifies the element size control (ES). The ES control specifies the size of the elements in the second and third operands. The first operand contains elements half the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>( M_4 ) Element Size</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The \( M_5 \) field has the following format:

\[
\begin{array}{c|c|c|c}
\hline
\text{Reserved} & \text{Reserved} & \text{Reserved} \\
\hline
\text{Reserved} & \text{Reserved} & \text{Reserved} \\
\hline
\end{array}
\]

The bits of the \( M_5 \) field are defined as follows:
Reserved: Bits 0, 1, and 2 are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.

Condition Code Set (CS): If bit 3 is 0, the code remains unchanged. If the bit is one, the code is set as described below.

Resulting Condition Code: When bit 3 of the M₅ field is one, the condition code is set as follows:

0  No saturation
1  At least one but not all elements saturated
2  --
3  Saturation on all elements

When bit 3 of the M₅ field is zero, the code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

Extended Mnemonic | Base Mnemonic
--- | ---
VPKLSH V₁,V₂,V₃ | VPKLS V₁,V₂,V₃,1,0
VPKLSF V₁,V₂,V₃ | VPKLS V₁,V₂,V₃,2,0
VPKLSG V₁,V₂,V₃ | VPKLS V₁,V₂,V₃,3,0
VPKLSHS V₁,V₂,V₃ | VPKLS V₁,V₂,V₃,1,1
VPKLSFS V₁,V₂,V₃ | VPKLS V₁,V₂,V₃,2,1
VPKLSGS V₁,V₂,V₃ | VPKLS V₁,V₂,V₃,3,1

VECTOR PERMUTE

A source vector is created from the concatenation of the second operand followed by the third operand. The byte element of the source vector indexed by the five least significant bits of each byte element of the fourth operand is placed into the byte element of the first operand corresponding to the byte element in the fourth operand.

If the same register is used to designate the first operand as either the second, third, or fourth operands the original source value is used throughout the operation with no intermediate updates.

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

VECTOR PERMUTE DOUBLEWORD IMMEDIATE

<table>
<thead>
<tr>
<th>VPDI</th>
<th>V₁,V₂,V₃,M₄</th>
<th>[VRR-c]</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
</tr>
</tbody>
</table>

The first, second and third operands consist of double word elements. Bit 1 of the M₄ field is the index which selects which doubleword of the second operand is placed into the zero indexed doubleword of the first operand. Bit 3 of the M₄ field is the index which selects which doubleword of the third operand is placed in the doubleword element with index one of the first operand.

The M₄ field has the following format:

<table>
<thead>
<tr>
<th>1</th>
<th>2</th>
<th>3</th>
</tr>
</thead>
</table>

The bits of the M₄ field are defined as follows:

- Reserved: Bits 0 and 2 are reserved and should be zeros; otherwise, the program may not operate compatibly in the future.

- Second Operand Index (I₂): Bit 1 provides the index of the doubleword in the second operand to be placed in the first operand.

- Third operand index (I₃): Bit 3 provides the index of the doubleword in the third operand to be placed in the first operand.

If the same register is used to designate the first operand as either the second or third operands, the
VECTOR REPLICATE

The element of the third operand indexed by the unsigned integer in I2 is replicated across all elements of the first operand. If the value of the unsigned integer in I2 is greater than the highest element number in the third operand, of the specified element size, a specification exception is recognized.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

M4 Element Size
0 Byte
1 Halfword
2 Word
3 Doubleword
4-15 Reserved

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VREPB V1,V3,I2</td>
<td>VREP V1,V3,I2,0</td>
</tr>
<tr>
<td>VREPH V1,V2,I2</td>
<td>VREP V1,V2,I2,1</td>
</tr>
<tr>
<td>VREPF V1,V3,I2</td>
<td>VREP V1,V3,I2,2</td>
</tr>
<tr>
<td>VREPG V1,V2,I2</td>
<td>VREP V1,V2,I2,3</td>
</tr>
</tbody>
</table>

VECTOR REPLICATE IMMEDIATE

The signed integer immediate value in I2 is sign extended, if necessary, and replicated across all elements of the first operand. If the element size is less than a halfword, only bits 8 through 15 of the I2 field are used; bits zero through seven are ignored.

The M3 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

M3 Element Size
0 Byte
1 Halfword
2 Word
3 Doubleword
4-15 Reserved

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VREPIB V1,I2</td>
<td>VREPI V1,I2,0</td>
</tr>
<tr>
<td>VREPHI V1,I2</td>
<td>VREPI V1,I2,1</td>
</tr>
<tr>
<td>VREPF I V1,I2</td>
<td>VREPI V1,I2,2</td>
</tr>
<tr>
<td>VREPIG V1,I2</td>
<td>VREPI V1,I2,3</td>
</tr>
</tbody>
</table>
**VECTOR SCATTER ELEMENT**

VSCEF \( V_x, D_y(V_2, B_2), M_3 \) [VRV]

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 20 & 32 & 36 & 40 & 47 \\
\hline
\text{‘E7’} & V_1 & V_2 & B_2 & D_2 & M_3 & RXB & \text{‘1B’} \\
\end{array}
\]

VSCEG \( V_x, D_y(V_2, B_2), M_3 \) [VRV]

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 20 & 32 & 36 & 40 & 47 \\
\hline
\text{‘E7’} & V_1 & V_2 & B_2 & D_2 & M_3 & RXB & \text{‘1A’} \\
\end{array}
\]

The element of the first operand designated by the \( M_3 \) field is placed unchanged into the second-operand location. If the third operand specifies a value greater than the highest numbered element in the first operand, of the specified element size, a specification exception is recognized.

For VSCEF the elements are 4-bytes in size; for VSCEG the elements are 8-bytes in size.

The second-operand address is generated by adding the unsigned binary integer value from the element in vector-register \( V_2 \) indexed by the \( M_3 \) field with the address in the \( B_2 \) register along with the \( D_2 \) value.

The displacement for VECTOR SCATTER ELEMENT is treated as a 12-bit unsigned integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Programming Notes:**

1. The VECTOR SCATTER ELEMENT instruction can be used to perform a store when doing scalar computation in vector registers and the address resides in a vector register. However, depending on the model, performance may be better if address computations are done in general registers.

2. For VGEF care must be taken to ensure that the values in the second operand elements are unsigned. Otherwise, when running in 64-bit addressing mode program behavior might not be as expected.

**VECTOR SELECT**

VSEL \( V_x, V_y, V_z, V_4 \) [VRR-e]

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 20 & 32 & 40 & 47 \\
\hline
\text{‘E7’} & V_1 & V_2 & V_3 & V_4 & RXB & \text{‘8D’} \\
\end{array}
\]

For each bit in the fourth operand that contains a zero, the corresponding bit from the third operand is placed in the corresponding bit of the first operand. For each bit in the fourth operand that contains a one, the corresponding bit from the second operand is placed in the corresponding bit of the first operand.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**VECTOR SIGN EXTEND TO DOUBLEWORD**

VSEG \( V_x, M_3 \) [VRR-a]

\[
\begin{array}{cccccccc}
0 & 8 & 12 & 16 & 32 & 40 & 47 \\
\hline
\text{‘E7’} & V_1 & V_2 & V_3 & M_3 & RXB & \text{‘5F’} \\
\end{array}
\]

The leftmost bit of the rightmost element-sized sub-element of each doubleword of the second operand is replicated across all bit positions of all other elements in the doubleword. The result is placed in the corresponding doubleword of the first operand.

The \( M_3 \) field specifies the element size control (ES). The ES control specifies the size of the element in each doubleword of the second operand. If a reserved value is specified, a specification exception is recognized.

**M3 Element Size**

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
**VECTOR STORE**

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

**Extended Mnemonic** | **Base Mnemonic**
--- | ---
VSEGB | VSEG | V1,V2,0
VSEGH | VSEG | V1,V2,1
VSEGF | VSEG | V1,V2,2

**Programming Notes:**

1. This instruction allows for a value to be sign extended after being loaded with VECTOR LOAD LOGICAL ELEMENT AND ZERO.
2. To sign extend to smaller element sizes the VECTOR UNPACK instructions can be used.

**VECTOR STORE**

VST | V1,D2(X2,B2) | [VRX]

**Extended Mnemonic Base Mnemonic**

\[ \text{E7} \quad \text{V1} \quad \text{X2} \quad \text{B2} \quad \text{D2} \quad \text{M3} \quad \text{RXB} \quad \text{0E} \]

The 128-bit value in the first operand is stored to the storage location specified by the second operand.

The displacement for VST is treated as a 12-bit unsigned integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Programming Note:** Performance may be reduced if the second operand is not on a quadword boundary.

**VECTOR STORE ELEMENT**

VSTEB | V1,D2(X2,B2),M3 | [VRX]

**Extended Mnemonic Base Mnemonic**

\[ \text{E7} \quad \text{V1} \quad \text{X2} \quad \text{B2} \quad \text{D2} \quad \text{M3} \quad \text{RXB} \quad \text{08} \]

The element of the first operand designated by the third operand is placed unchanged into the second operand location. If the third operand specifies a value greater than the highest numbered element in the first operand, of the specified element size, a specification exception is recognized. For VSTEB a specification is not recognized since the third operand cannot designate an index greater than the number of elements.

The displacement for VECTOR STORE ELEMENT is treated as a 12-bit unsigned integer.

For VSTEB the elements are byte sized. For VSTEH the elements are halfword sized. For VSTEF the elements are word sized. For VSTEG the elements are doubleword sized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Access (store, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
VECTOR STORE MULTIPLE

\[\text{VSTM} \quad V_1, V_2, D_2(B_2) \quad [\text{VRS-a}]\]

The set of vector registers starting with the first operand vector register designation and ending with the third operand vector register designation are placed in the storage area beginning at the location specified by the second-operand address and continuing through as many locations as needed.

The contents of bit positions 0-127 of the vector registers are stored in successive 16-byte fields beginning at the second-operand address.

The vector registers are stored in the ascending order of their register numbers, starting with the first operand vector register designation and continuing up to and including the third operand vector register designation. If the third operand vector register designation is less than the first operand vector register designation, a specification exception is recognized.

The number of registers to be stored is at most sixteen. If a range of more than sixteen registers is specified, a specification exception is recognized.

The displacement for VSTM is treated as a 12-bit unsigned binary number.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Programming Notes:**
1. On some models performance may be improved if the second operand is on a doubleword boundary.
2. If the first operand vector register designation and the third operand vector register designation specify the same vector register only 16-bytes are stored.

VECTOR STORE WITH LENGTH

\[\text{VSTL} \quad V_1, R_3, D_2(B_2) \quad [\text{VRS-b}]\]

Proceeding from left to right, bytes from the first operand are stored at the second-operand location. The general register specified third operand contains a 32-bit unsigned integer containing a value that represents the highest indexed byte to store. If the third operand contains a value greater than or equal to the highest byte index of the vector, all bytes of the first operand are stored.

Access exceptions are only recognized on bytes stored.

The displacement for VECTOR STORE WITH LENGTH is treated as a 12-bit unsigned integer.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Access (store, operand 2)
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

VECTOR UNPACK HIGH

\[\text{VUPH} \quad V_1, V_2, M_3 \quad [\text{VRR-a}]\]

The elements of the left-most half of the vector-register second operand are sign extended and placed into double-sized elements in the first operand. The right-most half of the second operand are ignored.

If the same register is used to designate the first operand as the second operand the original source value is used throughout the operation with no intermediate updates.

The \(M_3\) field specifies the element size control (ES). The ES control specifies the size of the elements in the second operand. The first operand contains elements twice the size of those specified by the ES.
control. If a reserved value is specified, a specification exception is recognized.

### M₃ Element Size

<table>
<thead>
<tr>
<th>0</th>
<th>Byte</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### Condition Code:

The code remains unchanged.

### Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

### Extended Mnemonics:

**VECTOR UNPACK LOGICAL HIGH**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VUPLHB V₁,V₂ M₃</td>
<td>VUPH V₁,V₂,0</td>
</tr>
<tr>
<td>VUPLHH V₁,V₂ M₃</td>
<td>VUPH V₁,V₂,1</td>
</tr>
<tr>
<td>VUPLHF V₁,V₂ M₃</td>
<td>VUPH V₁,V₂,2</td>
</tr>
</tbody>
</table>

The elements of the left-most half of the second operand are zero extended and placed into double-sized elements in the first operand. The right-most half of the second operand is ignored.

If the same register is used to designate the first operand as the second operand the original source value is used throughout the operation with no intermediate updates.

The M₃ field specifies the element size control (ES). The ES control specifies the size of the elements in the second operand. The first operand contains elements double the size of those specified in the ES control. If a reserved value is specified, a specification exception is recognized.

### M₃ Element Size

<table>
<thead>
<tr>
<th>0</th>
<th>Byte</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### Condition Code:

The code remains unchanged.

### Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

### Extended Mnemonics:

**VECTOR UNPACK LOW**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VUPLH V₁,V₂ M₃</td>
<td>VUPLH V₁,V₂,0</td>
</tr>
<tr>
<td>VUPLHH V₁,V₂ M₃</td>
<td>VUPLH V₁,V₂,1</td>
</tr>
<tr>
<td>VUPLHF V₁,V₂ M₃</td>
<td>VUPLH V₁,V₂,2</td>
</tr>
</tbody>
</table>

The elements of the right-most half of the second operand are sign extended and placed into double-sized elements in the first operand. The left-most half of the second operand is ignored.

If the same register is used to designate the first operand as the second operand the original source value is used throughout the operation with no intermediate updates.

The M₃ field specifies the element size control (ES). The ES control specifies the size of the elements in the second operand. The first operand contains elements double the size of those specified by the ES.
control. If a reserved value is specified, a specification exception is recognized.

\[ \text{M}_3 \quad \text{Element Size} \]
0  Byte
1  Halfword
2  Word
3-15  Reserved

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VUPLB ( V_1V_2 )</td>
<td>VUPL ( V_1V_2,0 )</td>
</tr>
<tr>
<td>VUPLHW ( V_1V_2 )</td>
<td>VUPL ( V_1V_2,1 )</td>
</tr>
<tr>
<td>VUPLF ( V_1V_2 )</td>
<td>VUPL ( V_1V_2,2 )</td>
</tr>
</tbody>
</table>

**VECTOR UNPACK LOGICAL LOW**

\[
\text{VUPLL} \quad V_1V_2M_3 \quad [\text{VRR-a}]
\]

The elements of the right-most half of the second operand are zero extended and placed into double-sized elements in the first operand. The left-most half of the second operand is ignored.

If the same register is used to designate the first operand as the second operand the original source value is used throughout the operation with no intermediate updates.

The \( \text{M}_3 \) field specifies the element size control (ES). The ES control specifies the size of the elements in the second operand. The first operand contains elements double the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

\[ \text{M}_3 \quad \text{Element Size} \]
0  Byte
1  Halfword
2  Word
3-15  Reserved

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VUPLLB ( V_1V_2 )</td>
<td>VUPLL ( V_1V_2,0 )</td>
</tr>
<tr>
<td>VUPLLHW ( V_1V_2 )</td>
<td>VUPLL ( V_1V_2,1 )</td>
</tr>
<tr>
<td>VUPLLFF ( V_1V_2 )</td>
<td>VUPLL ( V_1V_2,2 )</td>
</tr>
</tbody>
</table>
# Chapter 22. Vector Integer Instructions

Instructions .......................... 22-1  
VECTOR ADD .......................... 22-3  
VECTOR ADD COMPUTE CARRY ....... 22-4  
VECTOR ADD WITH CARRY ........... 22-4  
VECTOR ADD WITH CARRY COMPUTE CARRY ........... 22-5  
VECTOR AND .......................... 22-5  
VECTOR AND WITH COMPLEMENT .... 22-5  
VECTOR AVERAGE ...................... 22-5  
VECTOR AVERAGE LOGICAL .......... 22-6  
VECTOR CHECKSUM ................... 22-6  
VECTOR ELEMENT COMPARE ......... 22-7  
VECTOR ELEMENT COMPARE LOGICAL .... 22-7  
VECTOR COMPARE EQUAL ............ 22-7  
VECTOR COMPARE HIGH .............. 22-8  
VECTOR COMPARE HIGH LOGICAL .... 22-9  
VECTOR COUNT LEADING ZEROS ..... 22-10  
VECTOR COUNT TRAILING ZEROS ..... 22-10  
VECTOR EXCLUSIVE OR .............. 22-11  
VECTOR GALOIS FIELD MULTIPLY SUM AND ACCUMULATE .... 22-11  
VECTOR HALOIS FIELD MULTIPLY SUM .... 22-11  
VECTOR LOAD COMPLEMENT .......... 22-12  
VECTOR LOAD POSITIVE ............. 22-12  
VECTOR MAXIMUM .................... 22-13  
VECTOR MAXIMUM LOGICAL .......... 22-13  
VECTOR MINIMUM .................... 22-13  
VECTOR MINIMUM LOGICAL .......... 22-13  
VECTOR MULTIPLY AND ADD LOW .... 22-14  
VECTOR MULTIPLY AND ADD HIGH ... 22-14  
VECTOR MULTIPLY AND ADD LOGICAL HIGH ........... 22-15  
VECTOR MULTIPLY AND ADD EVEN .... 22-15  
VECTOR MULTIPLY AND ADD LOGICAL EVEN ........... 22-15  
VECTOR MULTIPLY AND ADD ODD .... 22-16  
VECTOR MULTIPLY AND ADD LOGICAL ODD ........... 22-16  
VECTOR MULTIPLY HIGH ............. 22-16  
VECTOR MULTIPLY LOGICAL HIGH .... 22-16  
VECTOR MULTIPLY LOW ............... 22-17  
VECTOR MULTIPLY EVEN ............. 22-17  
VECTOR MULTIPLY LOGICAL EVEN .... 22-18  
VECTOR MULTIPLY ODD .............. 22-18  
VECTOR MULTIPLY LOGICAL ODD ...... 22-18  
VECTOR NOR .......................... 22-19  
VECTOR OR ........................... 22-19  
VECTOR POPULATION COUNT ......... 22-19  
VECTOR ELEMENT ROTATE LEFT LOGICAL ........... 22-19  
VECTOR ELEMENT ROTATE AND INSERT UNDER MASK .... 22-20  
VECTOR ELEMENT SHIFT LEFT ........ 22-21  
VECTOR ELEMENT SHIFT RIGHT ARITHMETIC ........... 22-22  
VECTOR ELEMENT SHIFT RIGHT LOGICAL ........... 22-22  
VECTOR SHIFT LEFT .................. 22-23  
VECTOR SHIFT LEFT BY BYTE ........ 22-23  
VECTOR SHIFT LEFT DOUBLE BY BYTE .... 22-23  
VECTOR SHIFT RIGHT ARITHMETIC BY BYTE ........... 22-24  
VECTOR SHIFT RIGHT ARITHMETIC LOGICAL ........... 22-24  
VECTOR SUBTRACT ................... 22-25  
VECTOR SUBTRACT COMPUTE BORROW INDICATION .... 22-25  
VECTOR SUBTRACT WITH BORROW INDICATION ........... 22-26  
VECTOR SUBTRACT WITH BORROW COMPUTE BORROW INDICATION ........... 22-26  
VECTOR SUM ACROSS DOUBLEWORD ... 22-27  
VECTOR SUM ACROSS QUADWORD .... 22-27  
VECTOR SUM ACROSS WORD ........... 22-27  
VECTOR TEST UNDER MASK ........... 22-28

---

### Instructions

Many instructions have an extended mnemonic section which describe recommended extended mnemonics and their corresponding machine assembler syntax.
Unless otherwise specified all operands are vector-register operands. A “V” in the assembler syntax designates a vector operand.

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VECTOR ADD</td>
<td>VA</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7F3</td>
</tr>
<tr>
<td>VECTOR ADD COMPUTE CARRY</td>
<td>VACC</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7F1</td>
</tr>
<tr>
<td>VECTOR ADD WITH CARRY</td>
<td>VAC</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7B8</td>
</tr>
<tr>
<td>VECTOR ADD WITH CARRY COMPUTE CARRY</td>
<td>VACCC</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7B9</td>
</tr>
<tr>
<td>VECTOR AND</td>
<td>VN</td>
<td>VRR-c</td>
<td>VF</td>
<td>E768</td>
</tr>
<tr>
<td>VECTOR AND WITH COMPLEMENT</td>
<td>VNC</td>
<td>VRR-c</td>
<td>VF</td>
<td>E769</td>
</tr>
<tr>
<td>VECTOR AVERAGE</td>
<td>VAVG</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7F2</td>
</tr>
<tr>
<td>VECTOR AVERAGE LOGICAL</td>
<td>VAVGL</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7F0</td>
</tr>
<tr>
<td>VECTOR CHECKSUM</td>
<td>VCKSM</td>
<td>VRR-c</td>
<td>VF</td>
<td>E766</td>
</tr>
<tr>
<td>VECTOR ELEMENT COMPARE</td>
<td>VEC</td>
<td>VRR-a</td>
<td>C</td>
<td>E7DB</td>
</tr>
<tr>
<td>VECTOR ELEMENT COMPARE LOGICAL</td>
<td>VECL</td>
<td>VRR-a</td>
<td>C</td>
<td>E7D9</td>
</tr>
<tr>
<td>VECTOR COMPARE EQUAL</td>
<td>VCEQ</td>
<td>VRR-b</td>
<td>C*</td>
<td>E7F8</td>
</tr>
<tr>
<td>VECTOR COMPARE HIGH</td>
<td>VCH</td>
<td>VRR-b</td>
<td>C</td>
<td>E7FB</td>
</tr>
<tr>
<td>VECTOR COMPARE HIGH LOGICAL</td>
<td>VCHL</td>
<td>VRR-b</td>
<td>C*</td>
<td>E7F9</td>
</tr>
<tr>
<td>VECTOR COUNT LEADING ZEROS</td>
<td>VCLZ</td>
<td>VRR-a</td>
<td>VF</td>
<td>E753</td>
</tr>
<tr>
<td>VECTOR COUNT TRAILING ZEROS</td>
<td>VCTZ</td>
<td>VRR-a</td>
<td>VF</td>
<td>E752</td>
</tr>
<tr>
<td>VECTOR EXCLUSIVE OR</td>
<td>VX</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7BD</td>
</tr>
<tr>
<td>VECTOR GALOIS FIELD MULTIPLY SUM</td>
<td>VGF</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7B4</td>
</tr>
<tr>
<td>VECTOR GALOIS FIELD MULTIPLY SUM AND ACCUMULATE</td>
<td>VGFMA</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7BC</td>
</tr>
<tr>
<td>VECTOR LOAD COMPLEMENT</td>
<td>VLC</td>
<td>VRR-a</td>
<td>VF</td>
<td>E7DE</td>
</tr>
<tr>
<td>VECTOR LOAD POSITIVE</td>
<td>VLP</td>
<td>VRR-a</td>
<td>VF</td>
<td>E7DF</td>
</tr>
<tr>
<td>VECTOR MAXIMUM</td>
<td>VMX</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7F7</td>
</tr>
<tr>
<td>VECTOR MAXIMUM LOGICAL</td>
<td>VMXL</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7FD</td>
</tr>
<tr>
<td>VECTOR MINIMUM</td>
<td>VMN</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7FE</td>
</tr>
<tr>
<td>VECTOR MINIMUM LOGICAL</td>
<td>VMNL</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7FC</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD LOW</td>
<td>VMAL</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7AA</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD EVEN</td>
<td>VMAE</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7AE</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD LOGICAL EVEN</td>
<td>VMALE</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7AC</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD HIGH</td>
<td>VMAH</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7AB</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD LOGICAL HIGH</td>
<td>VMAH</td>
<td>VRR-d</td>
<td>VF</td>
<td>E79A</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD LOGICAL ODD</td>
<td>VMAO</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7AF</td>
</tr>
<tr>
<td>VECTOR MULTIPLY ADD LOGICAL ODD</td>
<td>VMALO</td>
<td>VRR-d</td>
<td>VF</td>
<td>E7AD</td>
</tr>
<tr>
<td>VECTOR MULTIPLY HIGH</td>
<td>VMH</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7A3</td>
</tr>
<tr>
<td>VECTOR MULTIPLY LOGICAL HIGH</td>
<td>VMLH</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7A1</td>
</tr>
<tr>
<td>VECTOR MULTIPLY LOW</td>
<td>VML</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7A2</td>
</tr>
<tr>
<td>VECTOR MULTIPLY EVEN</td>
<td>VME</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7A8</td>
</tr>
<tr>
<td>VECTOR MULTIPLY LOGICAL EVEN</td>
<td>VMLE</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7A4</td>
</tr>
<tr>
<td>VECTOR MULTIPLY ODD</td>
<td>VMO</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7A7</td>
</tr>
<tr>
<td>VECTOR MULTIPLY LOGICAL ODD</td>
<td>VMLO</td>
<td>VRR-c</td>
<td>VF</td>
<td>E7A5</td>
</tr>
<tr>
<td>VECTOR NOR</td>
<td>VNO</td>
<td>VRR-c</td>
<td>VF</td>
<td>E76B</td>
</tr>
<tr>
<td>VECTOR OR</td>
<td>VO</td>
<td>VRR-c</td>
<td>VF</td>
<td>E76A</td>
</tr>
<tr>
<td>VECTOR POPULATION COUNT</td>
<td>VPOPCT</td>
<td>VRR-a</td>
<td>VF</td>
<td>E750</td>
</tr>
<tr>
<td>VECTOR ELEMENT ROTATE LEFT LOGICAL</td>
<td>VERLLV</td>
<td>VRR-c</td>
<td>VF</td>
<td>E773</td>
</tr>
<tr>
<td>VECTOR ELEMENT ROTATE LEFT LOGICAL AND MASK</td>
<td>VERIM</td>
<td>VRR-d</td>
<td>VF</td>
<td>E772</td>
</tr>
<tr>
<td>VECTOR ELEMENT SHIFT LEFT</td>
<td>VESLV</td>
<td>VRR-c</td>
<td>VF</td>
<td>E770</td>
</tr>
<tr>
<td>VECTOR ELEMENT SHIFT LEFT</td>
<td>VESL</td>
<td>VRR-a</td>
<td>VF</td>
<td>E790</td>
</tr>
<tr>
<td>VECTOR ELEMENT SHIFT RIGHT ARITHMETIC</td>
<td>VESRAV</td>
<td>VRR-c</td>
<td>VF</td>
<td>E77A</td>
</tr>
<tr>
<td>VECTOR ELEMENT SHIFT RIGHT ARITHMETIC</td>
<td>VESRA</td>
<td>VRR-a</td>
<td>VF</td>
<td>E73A</td>
</tr>
</tbody>
</table>

*Figure 22-1. Summary of Vector Integer Instructions*
VECTORS ADD

VA \ V_1 V_2 V_3 M_4 [VRR-c]

\textquote{0 \ 8 \ 12 \ 16 \ 20 \ 32 \ 36 \ 40 \ 47}

The contents of each element of the second operand are added to the contents of each corresponding element of the third operand and the resulting sum or sums are placed in the first operand. Each element is treated as a signed binary integer of size specified by the element size control in the M_4 field.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position.

No fixed point overflow exceptions are recognized.

The M_4 field specifies the element size control (ES). The ES control specifies the size of the element or elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

\begin{align*}
M_4 & \text{ Element Size} \\
0 & \text{Byte} \\
1 & \text{Halfword} \\
2 & \text{Word} \\
3 & \text{Doubleword} \\
4 & \text{Quadword} \\
5-15 & \text{Reserved}
\end{align*}

\textbf{Condition Code:} The code remains unchanged.

\textbf{Program Exceptions:}

- Data with DXC FE, Vector Instruction
VECTOR ADD COMPUTE CARRY

\[
\text{VACC} \quad V_1, V_2, V_3, M_4 \quad \text{[VRR-c]}
\]

The contents of each element of the second operand are added to the contents of each corresponding element of the third operand. If the addition of two elements results in a carry out of bit zero, a value of one is placed in the corresponding element of the first operand. If there is no carry out of bit zero, a value of zero is placed in the corresponding element of the first operand. Each element is treated as an unsigned binary integer of size specified by the element size in the \(M_4\) field.

The \(M_4\) field specifies the element size control (ES). The ES control specifies the size of the element or elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

\[
\begin{array}{c|c}
\text{M}_4 & \text{Element Size} \\
0 & \text{Byte} \\
1 & \text{Halfword} \\
2 & \text{Word} \\
3 & \text{Doubleword} \\
4 & \text{Quadword} \\
5-15 & \text{Reserved}
\end{array}
\]

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

- **VACCB** \(V_1, V_2, V_3\)
- **VACCH** \(V_1, V_2, V_3, 1\)
- **VACCF** \(V_1, V_2, V_3, 2\)
- **VACCG** \(V_1, V_2, V_3, 3\)
- **VACCQ** \(V_1, V_2, V_3, 4\)

VECTOR ADD WITH CARRY

\[
\text{VAC} \quad V_1, V_2, V_3, V_4, M_5 \quad \text{[VRR-d]}
\]

The contents of the second operand are added to the third operand to form an intermediate quadword sum. Subsequently, the rightmost bit of the fourth operand concatenated with 127 bits of zero on its left are added to the intermediate sum and the resulting sum is placed in the first operand. All bits except for the rightmost bit position of the fourth operand are ignored. Each operand is treated as a 128-bit unsigned binary integer.

When there is an overflow, the result is obtained by allowing any carry into the leftmost-bit position and ignoring any carry out of the leftmost-bit position.

No fixed point overflow exceptions are recognized.

The \(M_5\) field must contain a value of 4; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
**VECTOR AVERAGE**

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VACQ V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;,V&lt;sub&gt;4&lt;/sub&gt;</td>
<td>VAC V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;,V&lt;sub&gt;4&lt;/sub&gt;,4</td>
</tr>
</tbody>
</table>

**VECTOR ADD WITH CARRY COMPUTE CARRY**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VACCC V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;,V&lt;sub&gt;4&lt;/sub&gt;,M&lt;sub&gt;5&lt;/sub&gt;</td>
<td>[VRR-d]</td>
</tr>
</tbody>
</table>

The contents of the second operand are added to the third operand to form an intermediate quadword sum. Subsequently, the rightmost bit of the fourth operand concatenated with 127 bits of zero on its left are added to the intermediate sum. All bits except for the rightmost bit position of the fourth operand are ignored. If the addition results in a carry out of the leftmost bit, a value of one is placed in the first operand. If there is no carry out of the leftmost bit, a value of zero is placed in the first operand. Each operand is treated as a 128-bit unsigned binary integer.

The M<sub>5</sub> field must contain a value of 4; otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**VECTOR AND**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VN V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;</td>
<td>[VRR-c]</td>
</tr>
</tbody>
</table>

The AND of the second and third operands is placed in the first operand.

**VECTOR AND WITH COMPLEMENT**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VNC V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;</td>
<td>[VRR-c]</td>
</tr>
</tbody>
</table>

The AND of the second operand and the bit-wise complement of the third operand is placed in the first operand.

**VECTOR AVERAGE**

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VAVG V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;,M&lt;sub&gt;4&lt;/sub&gt;</td>
<td>[VRR-c]</td>
</tr>
</tbody>
</table>

The connective AND is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the corresponding bit positions in both operands contain ones; otherwise, the result bit is set to zero.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Programming Note:** This instruction is useful for zeroing out bits under a mask.
VECTOR AVERAGE LOGICAL

VAVGL V1, V2, V3, M4 [VRR-c]

<table>
<thead>
<tr>
<th>'E7'</th>
<th>V1</th>
<th>V2</th>
<th>V3</th>
<th>M4</th>
<th>RXB</th>
<th>'F0'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>36</td>
</tr>
</tbody>
</table>

The average of the corresponding elements of the second and third operands is placed in the corresponding element of the first operand.

For VECTOR AVERAGE, each element of the second operand and the corresponding element of the third operand are sign extended by one bit. The elements are then added together along with an additional value of one. The sum is then shifted right by one bit to produce an element sized result in the corresponding element of the first operand.

For VECTOR AVERAGE LOGICAL, each element of the second operand and the corresponding element of the third operand are extended by one bit by appending a zero on the left. The elements are then added together along with an additional value of one. The sum is then shifted right by one bit to produce an element sized result in the corresponding element of the first operand.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

M4 | Element Size
---|----------------
0  | Byte
1  | Halfword
2  | Word
3  | Doubleword
4-15 | Reserved

Condition Code: The code remains unchanged.

Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

VECTOR CHECKSUM

VCKSM V1, V2, V3 [VRR-c]

<table>
<thead>
<tr>
<th>'E7'</th>
<th>V1</th>
<th>V2</th>
<th>V3</th>
<th>RXB</th>
<th>'66'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>36</td>
</tr>
</tbody>
</table>

The word-sized elements from the second operand are added together one-by-one along with the element in word one of the third operand. The sum is placed in word one of the first operand. Zeros are placed in word elements 0, and 2-3 of the first operand. The word-sized elements are all treated as 32-bit unsigned binary integers. After each addition of an element, a carry out of bit position 0 of the sum is added to bit position 31 of the result in word element one of the first operand.

Condition Code: The code remains unchanged.

Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

Programming Notes:

1. The contents of the third operand should contain zero at the start of a checksum computation algorithm.

2. A16-bit checksum is used in, for example, the TCP/IP application. The following program can be executed after a 32-bit checksum has been computed:

VERLLF V2, V1, 16(0)
VAF V2, V1, V2
The halfword in element 2 will contain the 16-bit checksum.

**VECTOR ELEMENT COMPARE**

**VEC** \( V_1, V_2, M_3 \) \[VRR-a\]

<table>
<thead>
<tr>
<th>Element</th>
<th>Index</th>
</tr>
</thead>
<tbody>
<tr>
<td>Byte</td>
<td>0</td>
</tr>
<tr>
<td>Halfword</td>
<td>1</td>
</tr>
<tr>
<td>Word</td>
<td>2</td>
</tr>
<tr>
<td>Doubleword</td>
<td>3</td>
</tr>
</tbody>
</table>

**VECTOR ELEMENT COMPARE LOGICAL**

**VECL** \( V_1, V_2, M_3 \) \[VRR-a\]

The single element of specified size of the first and second operands are compared and the result is indicated in the condition code.

The elements compared are treated as signed binary integers for VEC and unsigned binary integers for VECL.

The index of the element that is being compared is dependent on the size of the element being compared. Figure 22-2 specifies what element is compared for each element size.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

Extended Mnemonic | Base Mnemonic
--- | ---
VECB \( V_1, V_2 \) | VEC \( V_1, V_2, 0 \)
VECH \( V_1, V_2 \) | VEC \( V_1, V_2, 1 \)
VECF \( V_1, V_2 \) | VEC \( V_1, V_2, 2 \)
VECG \( V_1, V_2 \) | VEC \( V_1, V_2, 3 \)
VECLB \( V_1, V_2 \) | VECL \( V_1, V_2, 0 \)
VECLH \( V_1, V_2 \) | VECL \( V_1, V_2, 1 \)
VECLF \( V_1, V_2 \) | VECL \( V_1, V_2, 2 \)
VECLG \( V_1, V_2 \) | VECL \( V_1, V_2, 3 \)

**VECTOR COMPARE EQUAL**

**VCEQ** \( V_1, V_2, V_3, M_4, M_5 \) \[VRR-b\]

The unsigned binary integer elements of the second operand are compared with the corresponding unsigned binary integer elements of the third operand. If the element in the second operand is equal to the element in the third operand, all of the bit positions of the corresponding element in the first operand are set to ones; otherwise they are all set to zeros.

The \( M_4 \) field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

**Resulting Condition Code:**
0 Operand elements equal
1 First operand element low
2 First operand element high
3 --
The M₅ field has the following format:

```
0 1 2 3
```

The bits of the M₅ field are defined as follows:

- **Reserved**: Bits 0, 1, and 2 are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.
- **Condition Code Set (CS)**: If bit 3 is 0, the code remains unchanged. If the bit is one, the code is set as described below.

**Resulting Condition Code:**

When bit 3 of the M₅ field is one, the condition code is set as follows:

- 0: All elements equal
- 1: At least one, but not all elements equal
- 2: None
- 3: No element equal

When bit 3 of the M₅ field is zero, the code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
<th>M₄ Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCEQB V₁,V₂,V₃</td>
<td>VCEQ V₁,V₂,V₃,0,0</td>
<td>0: Byte</td>
</tr>
<tr>
<td>VCEQH V₁,V₂,V₃</td>
<td>VCEQ V₁,V₂,V₃,1,0</td>
<td>1: Halfword</td>
</tr>
<tr>
<td>VCEQW V₁,V₂,V₃</td>
<td>VCEQ V₁,V₂,V₃,2,0</td>
<td>2: Word</td>
</tr>
<tr>
<td>VCEQG V₁,V₂,V₃</td>
<td>VCEQ V₁,V₂,V₃,3,0</td>
<td>3: Doubleword</td>
</tr>
<tr>
<td>VCEQBS V₁,V₂,V₃</td>
<td>VCEQ V₁,V₂,V₃,0,1</td>
<td>4-15: Reserved</td>
</tr>
<tr>
<td>VCEQHS V₁,V₂,V₃</td>
<td>VCEQ V₁,V₂,V₃,1,1</td>
<td></td>
</tr>
<tr>
<td>VCEQFS V₁,V₂,V₃</td>
<td>VCEQ V₁,V₂,V₃,2,1</td>
<td></td>
</tr>
<tr>
<td>VCEQGS V₁,V₂,V₃</td>
<td>VCEQ V₁,V₂,V₃,3,1</td>
<td></td>
</tr>
</tbody>
</table>

**Programming Note**: Depending on the model, setting the condition code may result in reduced performance.

**VECTOR COMPARE HIGH**

```
VCH V₁,V₂,V₃,M₄,M₅ [VRR-b]
```

The signed elements of the second operand are compared to the corresponding signed elements of the third operand. If the element in the second operand is greater than the element in the third operand, all of the bit positions of the corresponding element in the first operand are set to ones; otherwise, they are all set to zeros.

The M₄ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M₄ Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0: Byte</td>
</tr>
<tr>
<td>1: Halfword</td>
</tr>
<tr>
<td>2: Word</td>
</tr>
<tr>
<td>3: Doubleword</td>
</tr>
<tr>
<td>4-15: Reserved</td>
</tr>
</tbody>
</table>

The M₅ field has the following format:

```
0 1 2 3
```

The bits of the M₅ field are defined as follows:

- **Reserved**: Bits 0, 1, and 2 are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.
- **Condition Code Set (CS)**: If bit 3 is 0, the code remains unchanged. If the bit is one, the code is set as described below.

**Resulting Condition Code:**

When bit 3 of the M₅ field is one, the condition code is set as follows:

- 0: All elements high
- 1: Some elements high
- 2: --
- 3: No element high
When bit 3 of the M₅ field is zero, the code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCHB V₁,V₂,V₃</td>
<td>VCH V₁,V₂,V₃,0,0</td>
</tr>
<tr>
<td>VCHH V₁,V₂,V₃</td>
<td>VCH V₁,V₂,V₃,1,0</td>
</tr>
<tr>
<td>VCHF V₁,V₂,V₃</td>
<td>VCH V₁,V₂,V₃,2,0</td>
</tr>
<tr>
<td>VCHG V₁,V₂,V₃</td>
<td>VCH V₁,V₂,V₃,3,0</td>
</tr>
<tr>
<td>VCHBS V₁,V₂,V₃</td>
<td>VCH V₁,V₂,V₃,0,1</td>
</tr>
<tr>
<td>VCHHS V₁,V₂,V₃</td>
<td>VCH V₁,V₂,V₃,1,1</td>
</tr>
<tr>
<td>VCHFS V₁,V₂,V₃</td>
<td>VCH V₁,V₂,V₃,2,1</td>
</tr>
<tr>
<td>VCHGS V₁,V₂,V₃</td>
<td>VCH V₁,V₂,V₃,3,1</td>
</tr>
</tbody>
</table>

**Programming Notes:**

1. Depending on the model, setting the condition code may result in reduced performance.

2. To do a COMPARE NOT HIGH, reverse the second and third operands.

**VECTOR COMPARE HIGH LOGICAL**

VCHL V₁,V₂,V₃,M₄,M₅ [VRR-b]

The unsigned elements of the second operand are compared to the corresponding unsigned elements of the third operand. If the element in the second operand is greater than the element in the third operand, all of the bit positions of the corresponding element in the first operand are set to ones; otherwise, they are all set to zeros.

The M₄ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M₄</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The M₅ field has the following format:

- **Reserved:** Bits 0, 1, and 2 are reserved and should contain zeros; otherwise, the program may not operate compatibly in the future.
- **Condition Code Set (CS):** If bit 3 is 0, the code remains unchanged. If the bit is one, the code is set as described below.

**Resulting Condition Code:**

When bit 3 of the M₅ field is one, the condition code is set as follows:

| 0 | All elements high |
| 1 | Some elements high |
| 2 | --                |
| 3 | No element high   |

When bit 3 of the M₅ field is zero, the code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
VECTOR COUNT LEADING ZEROS

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCHLB V₁,V₂,V₃</td>
<td>VCHL V₁,V₂,V₃,0,0</td>
</tr>
<tr>
<td>VCHLH V₁,V₂,V₃</td>
<td>VCHL V₁,V₂,V₃,1,0</td>
</tr>
<tr>
<td>VCHLF V₁,V₂,V₃</td>
<td>VCHL V₁,V₂,V₃,2,0</td>
</tr>
<tr>
<td>VCHLG V₁,V₂,V₃</td>
<td>VCHL V₁,V₂,V₃,3,0</td>
</tr>
<tr>
<td>VCHLBS V₁,V₂,V₃</td>
<td>VCHL V₁,V₂,V₃,0,1</td>
</tr>
<tr>
<td>VCHLHS V₁,V₂,V₃</td>
<td>VCHL V₁,V₂,V₃,1,1</td>
</tr>
<tr>
<td>VCHLFS V₁,V₂,V₃</td>
<td>VCHL V₁,V₂,V₃,2,1</td>
</tr>
<tr>
<td>VCHLGS V₁,V₂,V₃</td>
<td>VCHL V₁,V₂,V₃,3,1</td>
</tr>
</tbody>
</table>

**Programming Notes:**

1. Depending on the model, setting the condition code may result in reduced performance.
2. To do a COMPARE NOT HIGH LOGICAL, reverse the second and third operands.

**VEVECTOR COUNT LEADING ZEROS**

VCLZ V₁,V₂,M₃

For each element in the second operand, the number of leftmost zeros are counted and placed in the corresponding element of the first operand.

The bits of each element in the second operand are scanned left to right for the leftmost one bit. A binary integer designating the bit position of the leftmost one bit, or the number of bits in the element if there is no one bit, is placed in the corresponding element of the first operand.

The M₃ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M₄</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCLZB V₁,V₂</td>
<td>VCLZ V₁,V₂,0</td>
</tr>
<tr>
<td>VCLZH V₁,V₂</td>
<td>VCLZ V₁,V₂,1</td>
</tr>
<tr>
<td>VCLZF V₁,V₂</td>
<td>VCLZ V₁,V₂,2</td>
</tr>
<tr>
<td>VCLZG V₁,V₂</td>
<td>VCLZ V₁,V₂,3</td>
</tr>
</tbody>
</table>

**VECTOR COUNT TRAILING ZEROS**

VCTZ V₁,V₂,M₃

For each element in the second operand the number of rightmost zeros are counted and placed in the corresponding element of the first operand.

The bits of each element in the second operand are scanned right to left for the rightmost one bit. A binary integer designating the number of bits scanned to reach the rightmost one bit, or the number of bits in the element if there is no one bit, is placed in the corresponding element of the first operand.

The M₃ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M₄</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
VECTOR EXCLUSIVE OR

VX V1,V2,V3 [VRR-c]

The EXCLUSIVE OR of the second and third operands is placed at the first-operand location.

The connective EXCLUSIVE OR is applied to the operands bit by bit. The contents of a bit position in the result are set to one if the bits in the corresponding bit positions in the two operands are unlike; otherwise, the result bit is set to zero.

Condition Code: The code remains unchanged.

Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

VECTOR GALOIS FIELD MULTIPLY SUM

VGFM V1,V2,V3,M4 [VRR-c]

Each element of the second operand is multiplied in a Galois field with the corresponding element of the third operand. The Galois field has an order of two. This multiplication is similar to standard binary multiplication, but instead of adding the shifted multiplicand it is exclusive ORed. The resulting even-odd pairs of double element-sized products are exclusive ORed with each other and placed in the corresponding double-wide element of the first operand.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in vector register operands two and three; the elements in the first operand are twice the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

M4  Element Size
0  Byte
1  Halfword
2  Word
3  Doubleword
4-15  Reserved

Condition Code: The code remains unchanged.

Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

Extended Mnemonic Base Mnemonic
VCTZB V1,V2 VCTZ V1,V2,0
VCTZH V1,V2 VCTZ V1,V2,1
VCTZF V1,V2 VCTZ V1,V2,2
VCTZG V1,V2 VCTZ V1,V2,3

VECTOR GALOIS FIELD MULTIPLY SUM AND ACCUMULATE

VGFM V1,V2,V3,V4,M5 [VRR-d]

Each element of the second operand is multiplied in a Galois field with the corresponding element of the third operand. The Galois field has an order of two. This multiplication is similar to standard binary multiplication, but instead of adding the shifted multiplicand it is exclusive ORed. The resulting even-odd pairs of double element-sized products are exclusive ORed with each other and placed in the corresponding double-wide element of the first operand.

The M5 field specifies the element size control (ES). The ES control specifies the size of the elements in vector register operands two and three; the elements in the first operand are twice the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

M5  Element Size
0  Byte
1  Halfword
2  Word
3  Doubleword
4-15  Reserved

Condition Code: The code remains unchanged.

Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

Extended Mnemonic Base Mnemonic
VGFM V1,V2,V3 VGFM V1,V2,V3,0
VGFMH V1,V2,V3 VGFM V1,V2,V3,1
VGFMF V1,V2,V3 VGFM V1,V2,V3,2
VGFMG V1,V2,V3 VGFM V1,V2,V3,3
corresponding double-wide element of the fourth operand. The results are placed in the double-wide elements of the first operand.

The M3 field specifies the element size control (ES). The ES control specifies the size of the elements in vector register operands two and three; the elements in the first and fourth operand are twice the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

\[ M_3 \quad \text{Element Size} \]

0  Byte
1  Halfword
2  Word
3  Doubleword
4-15 Reserved

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VGFMAB ( V_1,V_2,V_3,V_4 )</td>
<td>VGFMA ( V_1,V_2,V_3,V_4 ),0</td>
</tr>
<tr>
<td>VGFMAH ( V_1,V_2,V_3,V_4 )</td>
<td>VGFMA ( V_1,V_2,V_3,V_4 ),1</td>
</tr>
<tr>
<td>VGFMAF ( V_1,V_2,V_3,V_4 )</td>
<td>VGFMA ( V_1,V_2,V_3,V_4 ),2</td>
</tr>
<tr>
<td>VGFMAG ( V_1,V_2,V_3,V_4 )</td>
<td>VGFMA ( V_1,V_2,V_3,V_4 ),3</td>
</tr>
</tbody>
</table>

**VECTOR LOAD POSITIVE**

\[ \text{VLP} \quad V_1,V_2,M_3 \quad [\text{VRR-a}] \]

The absolute value of each element in the second operand is placed in the corresponding element in the first operand. The operands are treated as signed binary integers.

When there is an overflow, the result is obtained by allowing any carry into the sign bit position and ignoring any carry out of the sign-bit position.

The M3 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.
the vector register operands. If a reserved value is specified, a specification exception is recognized.

### Condition Code:
The code remains unchanged.

### Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

### Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VLPB V1, V2</td>
<td>VLP V1, V2, 0</td>
</tr>
<tr>
<td>VLPH V1, V2</td>
<td>VLP V1, V2, 1</td>
</tr>
<tr>
<td>VLPF V1, V2</td>
<td>VLP V1, V2, 2</td>
</tr>
<tr>
<td>VLPG V1, V2</td>
<td>VLP V1, V2, 3</td>
</tr>
</tbody>
</table>

### VECTOR MAXIMUM

VMX V1, V2, V3, M4 [VRR-c]

```
0 8 12 16 20 32 36 40 47
'E7' V1 V2 V3 / / / / / / / / M4 RXB 'FF'
```

Each element of the second operand is compared to the corresponding element of the third operand. The greater of the two values is placed into the corresponding element of the first operand. If the operands are equal the value of both elements is placed in the corresponding element of the first operand.

For VECTOR MAXIMUM the operands are treated as signed integer elements. For VECTOR MAXIMUM LOGICAL the operands are treated as unsigned integer elements.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

### Condition Code:
The code remains unchanged.

### Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

### Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VMXB V1, V2, V3</td>
<td>VMX V1, V2, 0</td>
</tr>
<tr>
<td>VMXH V1, V2, V3</td>
<td>VMX V1, V2, 1</td>
</tr>
<tr>
<td>VMXF V1, V2, V3</td>
<td>VMX V1, V2, 2</td>
</tr>
<tr>
<td>VMXG V1, V2, V3</td>
<td>VMX V1, V2, 3</td>
</tr>
<tr>
<td>VMXLB V1, V2, V3</td>
<td>VMXL V1, V2, 0</td>
</tr>
<tr>
<td>VMXLH V1, V2, V3</td>
<td>VMXL V1, V2, 1</td>
</tr>
<tr>
<td>VMXLF V1, V2, V3</td>
<td>VMXL V1, V2, 2</td>
</tr>
<tr>
<td>VMXLG V1, V2, V3</td>
<td>VMXL V1, V2, 3</td>
</tr>
</tbody>
</table>

### VECTOR MINIMUM

VMN V1, V2, V3, M4 [VRR-c]

```
0 8 12 16 20 32 36 40 47
'E7' V1 V2 V3 / / / / / / / / M4 RXB 'FE'
```

### VECTOR MINIMUM LOGICAL

VMNL V1, V2, V3, M4 [VRR-c]

```
0 8 12 16 20 32 36 40 47
'E7' V1 V2 V3 / / / / / / / / M4 RXB 'FC'
```
Each element of the second operand is compared to the corresponding element of the third operand. The smaller of the two values is placed into the corresponding element of the first operand. If the operands are equal the value of both elements is placed in the corresponding element of the first operand.

For VECTOR MINIMUM the operands contain signed integer elements, for VECTOR MINIMUM LOGICAL the operands contain unsigned integer elements.

The M₄ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VMNB V₁₁V₂₁V₃₁</td>
<td>VMN V₁₁V₂₁V₃₀</td>
</tr>
<tr>
<td>VMNH V₁₁V₂₁V₃₁</td>
<td>VMN V₁₁V₂₁V₃₀</td>
</tr>
<tr>
<td>VMNF V₁₁V₂₁V₃₁</td>
<td>VMN V₁₁V₂₁V₃₀</td>
</tr>
<tr>
<td>VMNG V₁₁V₂₁V₃₁</td>
<td>VMN V₁₁V₂₁V₃₀</td>
</tr>
<tr>
<td>VMNLB V₁₁V₂₁V₃₁</td>
<td>VMNL V₁₁V₂₁V₃₀</td>
</tr>
<tr>
<td>VMNLH V₁₁V₂₁V₃₁</td>
<td>VMNL V₁₁V₂₁V₃₀</td>
</tr>
<tr>
<td>VMNLF V₁₁V₂₁V₃₁</td>
<td>VMNL V₁₁V₂₁V₃₀</td>
</tr>
<tr>
<td>VMNLG V₁₁V₂₁V₃₁</td>
<td>VMNL V₁₁V₂₁V₃₀</td>
</tr>
</tbody>
</table>

**VEVECTOR MULTIPLY AND ADD LOW**

<table>
<thead>
<tr>
<th>VMAL V₁₁V₂₁V₃₁M₅</th>
<th>[VRR-d]</th>
</tr>
</thead>
<tbody>
<tr>
<td>[E7] V₁ V₂ V₃ M₅</td>
<td>[---------] V₄ RXB ‘AA’</td>
</tr>
</tbody>
</table>

The integer elements of the second operand are multiplied by the corresponding integer elements of the third operand producing a double element-sized intermediate product. This intermediate product is then added to the corresponding element of the fourth operand. The least significant half of the resulting sum is placed into the corresponding element of the first operand.

The M₅ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

M₅ Element Size
- 0 Byte
- 1 Halfword
- 2 Word
- 3 Doubleword
- 4-15 Reserved

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VMALB V₁₁V₂₁V₃₁V₄</td>
<td>VMAL V₁₁V₂₁V₃₁V₄,0</td>
</tr>
<tr>
<td>VMALHW V₁₁V₂₁V₃₁V₄</td>
<td>VMAL V₁₁V₂₁V₃₁V₄,1</td>
</tr>
<tr>
<td>VMALF V₁₁V₂₁V₃₁V₄</td>
<td>VMAL V₁₁V₂₁V₃₁V₄,2</td>
</tr>
</tbody>
</table>

**Programming Note:** The results of VMAL are the same for signed and unsigned binary integers.

**VEVECTOR MULTIPLY AND ADD HIGH**

<table>
<thead>
<tr>
<th>VMAM V₁₁V₂₁V₃₁V₄M₅</th>
<th>[VRR-d]</th>
</tr>
</thead>
<tbody>
<tr>
<td>[E7] V₁ V₂ V₃ M₅</td>
<td>[---------] V₄ RXB ‘AB’</td>
</tr>
</tbody>
</table>

| 0 8 16 24 32 40 47 | 0 8 12 16 20 24 32 36 40 47 |
**VECTOR MULTIPLY AND ADD LOGICAL HIGH**

VMALH \( V_1, V_2, V_3, V_4, M_5 \) \[ VRR-d \]

\[ 'E7' \quad V_1 \quad V_2 \quad V_3 \quad M_5 \quad V_4 \quad RXB \quad 'AE' \]

0 8 12 16 20 24 32 36 40 47

The integer elements of the second operand are multiplied by the corresponding integer elements of the third operand producing a double element-sized intermediate product. This intermediate product is then added to the corresponding element of the fourth operand. The most significant half of the resulting sum is placed into the corresponding element of the first operand.

For VECTOR MULTIPLY AND ADD HIGH the elements are treated as signed binary integers. For VECTOR MULTIPLY AND ADD HIGH LOGICAL the elements are treated as unsigned binary integers.

The \( M_5 \) field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>( M_5 )</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VMAHB</td>
<td>VMAH</td>
</tr>
<tr>
<td>VMAHH</td>
<td>VMAH</td>
</tr>
<tr>
<td>VMAHF</td>
<td>VMAH</td>
</tr>
<tr>
<td>VMALHB</td>
<td>VMALH</td>
</tr>
<tr>
<td>VMALHH</td>
<td>VMALH</td>
</tr>
<tr>
<td>VMALHF</td>
<td>VMALH</td>
</tr>
</tbody>
</table>

**VECTOR MULTIPLY AND ADD EVEN**

VMAAE \( V_1, V_2, V_3, V_4, M_5 \) \[ VRR-d \]

\[ 'E7' \quad V_1 \quad V_2 \quad V_3 \quad M_5 \quad V_4 \quad RXB \quad 'AE' \]

0 8 12 16 20 24 32 36 40 47

The even indexed elements of the second operand are multiplied by the corresponding elements of the third operand. The intermediate product is added to the corresponding double-wide even-odd element pair of the fourth operand. The result is placed into the double-wide even-odd element pair of the first operand. The odd elements of the second and third operands are ignored. Any overflow or carry from the final addition is ignored.

For VECTOR MULTIPLY AND ADD EVEN the elements are treated as signed binary integers. For VECTOR MULTIPLY AND ADD LOGICAL EVEN the elements are treated as unsigned binary integers.

The \( M_5 \) field specifies the element size control (ES). The ES control specifies the size of the elements in vector register operands two and three; the elements in the first and fourth operand are twice the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>( M_5 )</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
VECTOR MULTIPLY AND ADD ODD

\[
\text{VMAO } V_1, V_2, V_3, V_4, M_5 \quad [\text{VRR-d}]
\]

\[
\begin{array}{cccccccc}
E7 & V_1 & V_2 & V_3 & M_5 & / & / & / & V_4 & \text{RXB} & \text{AF}
\end{array}
\]

The odd indexed elements of the second operand are multiplied by the corresponding elements of the third operand. The intermediate product is added to the corresponding double-wide even-odd element pair of the fourth operand. The result is placed into the even-odd double-wide element pair of the first operand. The even elements of the second and third operands are ignored. Any overflow or carry from the final addition is ignored.

For VECTOR MULTIPLY AND ADD ODD the elements are treated as signed binary integers. For VECTOR MULTIPLY AND ADD LOGICAL ODD the elements are treated as unsigned binary integers.

The \( M_5 \) field specifies the element size control (ES). The ES control specifies the size of the elements in vector register operands two and three; the elements in the first and fourth operands are twice the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

\( M_5 \) Element Size
0 Byte
1 Halfword
2 Word
3-15 Reserved

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with D XC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

Extended Mnemonic | Base Mnemonic
--- | ---
VMAEB | VMAE
VMAEH | VMAE
VMAEF | VMAE
VMALOB | VMALE
VMALEH | VMALE
VMALEF | VMALE

For VECTOR MULTIPLY HIGH, the elements are treated as signed binary integers. For VECTOR MULTIPLY LOGICAL HIGH, the elements are treated as unsigned binary integers.
The M<sub>4</sub> field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

### M<sub>4</sub> Element Size

- **0**: Byte
- **1**: Halfword
- **2**: Word
- **3-15**: Reserved

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VMHB</td>
<td>V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;</td>
</tr>
<tr>
<td>VMHH</td>
<td>V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;</td>
</tr>
<tr>
<td>VMHF</td>
<td>V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;</td>
</tr>
<tr>
<td>VMLHB</td>
<td>V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;</td>
</tr>
<tr>
<td>VMLHH</td>
<td>V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;</td>
</tr>
<tr>
<td>VMLHF</td>
<td>V&lt;sub&gt;1&lt;/sub&gt;,V&lt;sub&gt;2&lt;/sub&gt;,V&lt;sub&gt;3&lt;/sub&gt;</td>
</tr>
</tbody>
</table>

**VECTOR MULTIPLY LOW**

VML | V<sub>1</sub>,V<sub>2</sub>,V<sub>3</sub>,M<sub>4</sub> | [VRR-c] |

The integer elements of the second operand are multiplied by the corresponding integer elements of the third operand producing a double element-sized intermediate product. The least-significant half of the resulting product is placed into the corresponding element of the first operand. Any overflow or carry from the final addition is ignored.

**Programming Notes:**

1. The results from VML are the same if the elements are treated as unsigned binary integers or signed binary integers.
2. VECTOR MULTIPLY LOW is analogous to MULTIPLY SINGLE in chapter 7.
3. The extended mnemonic VMLHW is not VMLH because that would conflict with VECTOR MULTIPLY LOW.

**VECTOR MULTIPLY EVEN**

VME | V<sub>1</sub>,V<sub>2</sub>,V<sub>3</sub>,M<sub>4</sub> | [VRR-c] |
VECTOR MULTIPLY LOGICAL EVEN

VMLE V1,V2,V3,M4 [VRR-c]

The even indexed elements of the second operand are multiplied with the corresponding even indexed elements of the third operand and the resulting double element width product is placed into the corresponding even and odd indexed element pair of the first operand. The odd elements of the second and third operands are ignored.

For VECTOR MULTIPLY EVEN the elements are treated as signed binary integers. For VECTOR MULTIPLY LOGICAL EVEN the elements are treated as unsigned binary integers.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in vector register operands two and three; the elements in the first operand are twice the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

M4 Element Size
0 Byte
1 Halfword
2 Word
3-15 Reserved

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

Extended Mnemonic | Base Mnemonic
-----------------|------------------
VMEB V1,V2,V3 | VME V1,V2,V3,0
VMEH V1,V2,V3 | VME V1,V2,V3,1
VMEF V1,V2,V3 | VME V1,V2,V3,2
VMLEB V1,V2,V3 | VMLE V1,V2,V3,0
VMLEH V1,V2,V3 | VMLE V1,V2,V3,1

VECTOR MULTIPLY ODD

VMO V1,V2,V3,M4 [VRR-c]

The odd indexed elements of the second operand are multiplied with the corresponding odd indexed elements of the third operand and the resulting double element width product is placed into the corresponding even and odd indexed element pair of the first operand. The even elements of the second and third operands are ignored.

For VECTOR MULTIPLY ODD the elements are treated as signed binary integers. For VECTOR MULTIPLY LOGICAL ODD the elements are treated as unsigned binary integers.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in vector register operands two and three; the elements in the first operand are twice the size of those specified by the ES control. If a reserved value is specified, a specification exception is recognized.

M4 Element Size
0 Byte
1 Halfword
2 Word
3-15 Reserved

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
**Extended Mnemonics:**

**VECTOR NOR**

VNO V1,V2,V3 [VRR-c]

The NOR of the second and third operands is placed at the first-operand location.

The connective NOR is applied to the operand bit by bit. The contents of a bit position in the result are set to one if the corresponding bit in both operands contains a zero; otherwise, the result bit is set to zero.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Programming Note:** VNO can be used to provide the functionality of a bit-wise NOT operation by specifying the same vector-register for V2 and V3.

**Extended Mnemonics:**

**VECTOR OR**

VO V1,V2,V3 [VRR-c]

The OR of the second and third operands is placed at the first-operand location.

The connective OR is applied to the operand bit by bit. The contents of a bit position in the result are set to one if the corresponding bit in one or both operands contains a one; otherwise, the result bit is set to zero.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

**Programming Note:** VNO can be used to provide the functionality of a bit-wise NOT operation by specifying the same vector-register for V2 and V3.

**VECTOR POPULATION COUNT**

VPOPCT V1,V2,M3 [VRR-a]

For each byte element of the second operand the count of the number of bits that are one is stored in the corresponding byte element of the first operand. Each byte element in the result contains an 8-bit binary integer in the range of 0-8.

The M3 field is reserved and must contain zeros, otherwise a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Programming Note:** To count all of the ones in various element sizes a combination of VECTOR SUM ACROSS instructions may be used.
For VERLLV, each element in the second operand is rotated left by the number of bits specified in the corresponding element of the third operand modulo the element size in bits. For VERLL, each element in the third operand is rotated left by the number of bits specified by the second-operand address, modulo the number of bits in the specified element size. Each bit shifted out of the leftmost bit position of the element reenters in the rightmost bit position of the element. The result is placed in the corresponding element the first operand.

For VERLL, The displacement is treated as a 12-bit unsigned integer.

For VERLL, The second-operand address is not used to address data; its rightmost bits indicate the number of bit positions to be rotated. The remainder of the address is ignored.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M4</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Programming Note:** Although the rotate amount is defined to be an unsigned integer of the number of bits necessary to specify a full rotate left amount for an element, a negative value may be encoded which effectively specifies a rotate-right amount.

For VERLLVB, VERLLVH, VERLLVF, and VERLLVG, the number of bits is specified by the fourth operand. Each bit shifted out of the leftmost bit position of the element reenters in the rightmost bit position of the element. The result is placed in the corresponding element the first operand.

Each element of the second operand is rotated left by the number of bits specified by the fourth operand. Each bit shifted out of the leftmost bit position of the element reenters in the rightmost bit position of the element. The third operand contains a mask in each element. For each bit in the third operand that is one, the corresponding bit of the rotated elements in the second operand replaces the corresponding bit in the first operand. For each bit in the third operand that is zero, the corresponding bit of the first operand remains unchanged. Except for the case when the first operand is the same as either the second or third operand, the second and third operands remain unchanged.

The fourth operand is an unsigned binary integer specifying the number of bits to rotate each element in the second operand by. If the value is larger than the number of bits in the specified element size, the value is reduced modulo the number of bits in the element.

The M5 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M5</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
</tbody>
</table>

**Extended Mnemonics:**

**Extended Mnemonic** | **Base Mnemonic**
---|---
VERLLVB $V_1$, $V_2$, $V_3$ | VERLLV $V_1$, $V_2$, $V_3$, 0
VERLLVH $V_1$, $V_2$, $V_3$ | VERLLV $V_1$, $V_2$, $V_3$, 1
VERLLVF $V_1$, $V_2$, $V_3$ | VERLLV $V_1$, $V_2$, $V_3$, 2
VERLLVG $V_1$, $V_2$, $V_3$ | VERLLV $V_1$, $V_2$, $V_3$, 3
VERLLLB $V_1$, $V_3$, $D_2(B_2)$ | VERLL $V_1$, $V_3$, $D_2(B_2)$, 0
VERLLLB $V_1$, $V_3$, $D_2(B_2)$ | VERLL $V_1$, $V_3$, $D_2(B_2)$, 1
VERLLLB $V_1$, $V_3$, $D_2(B_2)$ | VERLL $V_1$, $V_3$, $D_2(B_2)$, 2
VERLLLB $V_1$, $V_3$, $D_2(B_2)$ | VERLL $V_1$, $V_3$, $D_2(B_2)$, 3
VECTOR ELEMENT SHIFT LEFT

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VERIMB V₁,V₂,V₃,I₄</td>
<td>VERIM V₁,V₂,V₃,I₄,0</td>
</tr>
<tr>
<td>VERIMH V₁,V₂,V₃,I₄</td>
<td>VERIM V₁,V₂,V₃,I₄,1</td>
</tr>
<tr>
<td>VERIMF V₁,V₂,V₃,I₄</td>
<td>VERIM V₁,V₂,V₃,I₄,2</td>
</tr>
<tr>
<td>VERIMG V₁,V₂,V₃,I₄</td>
<td>VERIM V₁,V₂,V₃,I₄,3</td>
</tr>
</tbody>
</table>

**Programming Notes:**
1. A combination of VERIM and VGM may be used to accomplish the full functionality of ROTATE AND INSERT SELECTED BITS in Chapter 7.
2. Although the bits of the I₄ field are defined to contain an unsigned binary integer specifying the number of bits to rotate each element left, a negative value may be coded which effectively specifies a rotate-right amount.

**VECTOR ELEMENT SHIFT LEFT**

VESLV V₁,V₂,V₃,M₄ [VRR-c]

<table>
<thead>
<tr>
<th>‘E7’</th>
<th>V₁</th>
<th>V₂</th>
<th>V₃</th>
<th>I₄</th>
<th>M₄</th>
<th>RXB</th>
<th>‘70’</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>36</td>
<td>40</td>
</tr>
</tbody>
</table>

VESL V₁,V₂,D₂(B₂),M₄ [VRS-a]

<table>
<thead>
<tr>
<th>‘E7’</th>
<th>V₁</th>
<th>V₂</th>
<th>D₂</th>
<th>B₂</th>
<th>M₄</th>
<th>RXB</th>
<th>‘30’</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>32</td>
<td>36</td>
<td>40</td>
</tr>
</tbody>
</table>

For VESLV, each element in the second operand is shifted left by the number of bits specified in the corresponding element in the third operand modulo the number of bits in an element. For VESL, each element in the third operand is shifted left by the number of bits specified by the second-operand address modulo the number of bits in the specified element size. Bits shifted out of bit 0 of each element are lost and zeros are supplied to the vacated bit positions to the right of each element. The result is placed in the first operand.

For VESL, the displacement is treated as a 12-bit unsigned integer.

For VESL, the second-operand address is not used to address data; its rightmost bits indicate the number of bit positions to be shifted. The leftmost bits of the address are ignored.

The M₄ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M₄</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3</td>
<td>Doubleword</td>
</tr>
<tr>
<td>4-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Programming Note:** The same results are obtained if the second operand contains either signed or unsigned binary integers.

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VESLVB V₁,V₂,V₃</td>
<td>VESLV V₁,V₂,V₃,0</td>
</tr>
<tr>
<td>VESLVH V₁,V₂,V₃</td>
<td>VESLV V₁,V₂,V₃,1</td>
</tr>
<tr>
<td>VESLVF V₁,V₂,V₃</td>
<td>VESLV V₁,V₂,V₃,2</td>
</tr>
<tr>
<td>VESLVG V₁,V₂,V₃</td>
<td>VESLV V₁,V₂,V₃,3</td>
</tr>
<tr>
<td>VESLB V₁,V₂,D₂(B₂)</td>
<td>VESL V₁,V₂,D₂(B₂),0</td>
</tr>
<tr>
<td>VESLH V₁,V₂,D₂(B₂)</td>
<td>VESL V₁,V₂,D₂(B₂),1</td>
</tr>
<tr>
<td>VESLF V₁,V₂,D₂(B₂)</td>
<td>VESL V₁,V₂,D₂(B₂),2</td>
</tr>
<tr>
<td>VESLG V₁,V₂,D₂(B₂)</td>
<td>VESL V₁,V₂,D₂(B₂),3</td>
</tr>
</tbody>
</table>
VECTOR ELEMENT SHIFT RIGHT ARITHMETIC

VESRAV V1, V2, V3, M4 [VRR-c]

VESRA V1, V3, D2(B2), M4 [VRS-a]

For VESRAV, each element in the second operand is shifted right by the number of bits specified in the corresponding element of the third operand modulo the number of bits in the specified element size. For VESRA, each element in the third operand is shifted right by the number of bits specified in the second-operand address modulo the number of bits in the specified element size. The result is placed in the corresponding element of the first operand with the vacated bits replaced with the original high order bit of each element.

For VESRA, the displacement is treated as a 12-bit unsigned integer.

For VESRA, the second-operand address is not used to address data; its rightmost bits indicate the number of bit positions to be shifted. The leftmost bits of the address are ignored.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

M4 Element Size
0  Byte
1  Halfword
2  Word
3  Doubleword
4-15  Reserved

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

Extended Mnemonic | Base Mnemonic
--- | ---
VESRAVB V1, V2, V3 | VESRA V1, V2, V3, 0
VESRAVH V1, V2, V3 | VESRA V1, V2, V3, 1
VESRAVF V1, V2, V3 | VESRA V1, V2, V3, 2
VESRAVG V1, V2, V3 | VESRA V1, V2, V3, 3
VESRAB V1, V3, D2(B2) | VESRA V1, V3, D2(B2), 0
VESRAH V1, V3, D2(B2) | VESRA V1, V3, D2(B2), 1
VESRAF V1, V3, D2(B2) | VESRA V1, V3, D2(B2), 2
VESRAG V1, V3, D2(B2) | VESRA V1, V3, D2(B2), 3

VECTOR ELEMENT SHIFT RIGHT LOGICAL

VESRLV V1, V2, V3, M4 [VRR-c]

VESRL V1, V3, D2(B2), M4 [VRS-a]

For VESRLV, each element in the second operand is shifted right by the number of bits specified in the corresponding element of the third operand modulo the number of bits in the specified element size. For VESRL, each element in the third operand is shifted right by the number of bits specified in the second-operand address modulo the specified element size. The result is placed in the corresponding element of the first operand with the vacated bits replaced with zeros.

For VESRL, the displacement is treated as a 12-bit unsigned integer.

For VESRL, the second-operand address is not used to address data; its rightmost bits indicate the number of bit positions to be shifted. The leftmost bits of the address are ignored.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in
the vector register operands. If a reserved value is specified, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

### VECTOR SHIFT LEFT

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VESRLVB V1,V2,V3</td>
<td>VESRL V1,V2,0</td>
</tr>
<tr>
<td>VESRLVH V1,V2,V3</td>
<td>VESRL V1,V2,1</td>
</tr>
<tr>
<td>VESRLVF V1,V2,V3</td>
<td>VESRL V1,V2,2</td>
</tr>
<tr>
<td>VESRLVG V1,V2,V3</td>
<td>VESRL V1,V2,3</td>
</tr>
<tr>
<td>VESRLB V1,V3,D2(B2)</td>
<td>VESRL V1,V3,D2(B2),0</td>
</tr>
<tr>
<td>VESRLH V1,V3,D2(B2)</td>
<td>VESRL V1,V3,D2(B2),1</td>
</tr>
<tr>
<td>VESRLF V1,V3,D2(B2)</td>
<td>VESRL V1,V3,D2(B2),2</td>
</tr>
<tr>
<td>VESRLG V1,V3,D2(B2)</td>
<td>VESRL V1,V3,D2(B2),3</td>
</tr>
</tbody>
</table>

**VECTOR SHIFT LEFT**

<table>
<thead>
<tr>
<th>VSL</th>
<th>V1,V2,V3</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘E7’</td>
<td>V1</td>
</tr>
</tbody>
</table>

The second operand is shifted left by the number of bits specified by an unsigned binary integer in bits 5-7 of each byte of the third operand. The result is placed in the first operand.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

### VECTOR SHIFT LEFT BY BYTE

**Extended Mnemonic Base Mnemonic**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VESRLVB V1,V2,V3</td>
<td>VESRL V1,V2,0</td>
</tr>
<tr>
<td>VESRLVH V1,V2,V3</td>
<td>VESRL V1,V2,1</td>
</tr>
<tr>
<td>VESRLVF V1,V2,V3</td>
<td>VESRL V1,V2,2</td>
</tr>
<tr>
<td>VESRLVG V1,V2,V3</td>
<td>VESRL V1,V2,3</td>
</tr>
<tr>
<td>VESRLB V1,V3,D2(B2)</td>
<td>VESRL V1,V3,D2(B2),0</td>
</tr>
<tr>
<td>VESRLH V1,V3,D2(B2)</td>
<td>VESRL V1,V3,D2(B2),1</td>
</tr>
<tr>
<td>VESRLF V1,V3,D2(B2)</td>
<td>VESRL V1,V3,D2(B2),2</td>
</tr>
<tr>
<td>VESRLG V1,V3,D2(B2)</td>
<td>VESRL V1,V3,D2(B2),3</td>
</tr>
</tbody>
</table>

**VECTOR SHIFT LEFT DOUBLE BY BYTE**

<table>
<thead>
<tr>
<th>VSLDB</th>
<th>V1,V2,V3,I4</th>
</tr>
</thead>
<tbody>
<tr>
<td>‘E7’</td>
<td>V1</td>
</tr>
</tbody>
</table>

A double-wide source vector of byte elements is created by concatenating the second operand followed by the third operand. The result is placed in the first operand.

**Condition Code:** The code remains unchanged.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
VECTOR SHIFT RIGHT ARITHMETIC

VSRA V1, V2, V3 [VRR-c]

The second operand is shifted right by the number of bits specified by an unsigned binary integer in bits 5-7 of each byte of the third operand. Bits 5-7 of the bytes in the third operand should all contain the same value, otherwise the result is unpredictable. Bits shifted out of bit 127 are lost and bits equal to bit zero are supplied to the vacated bit positions to the left. The result is placed in the first operand.

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

VECTOR SHIFT RIGHT ARITHMETIC BY BYTE

VSRAB V1, V2, V3 [VRR-c]

The second operand is shifted right by the number of bytes specified by the unsigned integer in bits 1-4 of byte seven of the third operand. Bits shifted out of bit 127 are lost and zeros are supplied to the vacated bit positions to the left. The result is placed in the first operand.

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

VECTOR SHIFT RIGHT LOGICAL

VSRL V1, V2, V3 [VRR-c]

The second operand is shifted right by the number of bits specified by an unsigned binary integer in bits 5-7 of each byte of the third operand. Bits 5-7 of the bytes in the third operand should all contain the same value, otherwise the result is unpredictable. Bits shifted out of bit 127 are lost and zeros are supplied to the vacated bit positions to the left. The result is placed in the first operand.

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint

VECTOR SHIFT RIGHT LOGICAL BY BYTE

VSRLB V1, V2, V3 [VRR-c]

The second operand is shifted right by the number of bytes specified by the unsigned integer in bits 1-4 of byte element seven of the third operand. Bits shifted out of bit 127 are lost and zeros are supplied to the vacated bit positions to the left. The result is placed in the first operand.

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint
VECTOR SUBTRACT

\[ \text{VS} \quad V_1, V_2, V_3, M_4 \quad [\text{VRR-c}] \]

The contents of each element of the third operand are subtracted from the contents of each corresponding element of the second operand and the resulting difference is placed in the corresponding element of the first operand. Each element is treated as a signed binary integer specified by the element size control in the \( M_4 \) field.

When there is an overflow, the result is obtained by allowing any carry into the sign-bit position and ignoring any carry out of the sign-bit position.

The \( M_4 \) field specifies the element size control (ES). The ES control specifies the size of the element or elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

\[
\begin{array}{cccccccc}
\text{M}_4 & \text{ES} & 0 & 1 & 2 & 3 & 4 & 5-15 \\
\text{Element Size} & & \text{Byte} & \text{Halfword} & \text{Word} & \text{Doubleword} & \text{Quadword} & \text{Reserved} \\
\end{array}
\]

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Programming Note:** The same results are obtained if the contents of each element contain unsigned binary integers.

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VSB ( V_1, V_2, V_3 )</td>
<td>VS ( V_1, V_2, V_3, 0 )</td>
</tr>
<tr>
<td>VSH ( V_1, V_2, V_3 )</td>
<td>VS ( V_1, V_2, V_3, 1 )</td>
</tr>
</tbody>
</table>

VECTOR SUBTRACT COMPUTE BORROW INDICATION

\[ \text{VSCBI} \quad V_1, V_2, V_3, M_4 \quad [\text{VRR-c}] \]

The contents of each element of the third operand are subtracted from the contents of each corresponding element of the second operand. An indication of borrow is placed in the corresponding element of the first operand.

If the resulting subtraction results in a carry out of bit zero, a value of one is placed in the corresponding element of the first operand; otherwise, a value of zero is placed in the corresponding element of the first operand. The operands are treated as unsigned binary integers of size specified by the element size control in the \( M_4 \) field.

The \( M_4 \) field specifies the element size control (ES). The ES control specifies the size of the element or elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

\[
\begin{array}{cccccccc}
\text{M}_4 & \text{ES} & 0 & 1 & 2 & 3 & 4 & 5-15 \\
\text{Element Size} & & \text{Byte} & \text{Halfword} & \text{Word} & \text{Doubleword} & \text{Quadword} & \text{Reserved} \\
\end{array}
\]

**Condition Code:** The code remains unchanged.

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
VECTOR SUBTRACT WITH BORROW INDICATION

Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VSCBIB V1,V2,V3</td>
<td>VSCBI V1,V2,V3,0</td>
</tr>
<tr>
<td>VSCBIH V1,V2,V3</td>
<td>VSCBI V1,V2,V3,1</td>
</tr>
<tr>
<td>VSCBIF V1,V2,V3</td>
<td>VSCBI V1,V2,V3,2</td>
</tr>
<tr>
<td>VSCBIF V1,V2,V3</td>
<td>VSCBI V1,V2,V3,3</td>
</tr>
<tr>
<td>VSCBIQ V1,V2,V3</td>
<td>VSCBI V1,V2,V3,4</td>
</tr>
</tbody>
</table>

A subtraction is performed by adding the contents of the second operand with the bitwise complement of the third operand along with a borrow indication from the rightmost bit position of the fourth operand and the result is placed in the first operand. All bit positions to the left of the rightmost bit position of the fourth operand are ignored. Each operand is treated as an unsigned binary integer.

When there is an overflow, the result is obtained by allowing any carry into the leftmost-bit position and ignoring any carry out of the leftmost-bit position.

No fixed point overflow exceptions are recognized.

The M5 field must contain a value of 4; otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VSBIQ V1,V2,V3,V4</td>
<td>VSBI V1,V2,V3,V4,4</td>
</tr>
</tbody>
</table>

Programming Note: VECTOR SUBTRACT WITH BORROW COMPUTE BORROW INDICATION in conjunction with VECTOR SUBTRACT WITH BORROW INDICATION can be used to perform subtractions on values with a precision greater than a quadword.
VECTOR SUM ACROSS DOUBLEWORD

VSUMG V₁,V₂,V₃, M₄ [VRR-c]

The four halfword or two word sub-elements in each of the doubleword elements of the second operand are summed and then added to the corresponding righthmost sub-element of the corresponding doubleword of the third operand. The full-precision intermediate-sum is extended on the left with zeros to a doubleword and the results are placed in the corresponding doubleword of the first operand.

The M₄ field specifies the element size control (ES). The ES control specifies the size of the sub-elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

M₄ Element Size
0 Reserved
1 Halfword
2 Word
3-15 Reserved

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

Extended Mnemonic | Base Mnemonic
------------------|------------------
VSUMGH V₁,V₂,V₃   | VSUMG V₁,V₂,V₃,1
VSUMGF V₁,V₂,V₃   | VSUMG V₁,V₂,V₃,2

VECTOR SUM ACROSS QUADWORD

VSUMQ V₁,V₂,V₃, M₄ [VRR-c]

The two doubleword elements or four word elements of the second operand are added together along with the corresponding rightmost word or doubleword element of the third operand. The full-precision intermediate-sum is extended on the left with zeros to a quadword and the result is placed in the first operand.

The M₄ field specifies the element size control (ES). The ES control specifies the size of the sub-elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

M₄ Element Size
0-1 Reserved
2 Word
3 Doubleword
4-15 Reserved

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

Extended Mnemonic | Base Mnemonic
------------------|------------------
VSUMQF V₁,V₂,V₃   | VSUMQ V₁,V₂,V₃,2
VSUMQG V₁,V₂,V₃   | VSUMQ V₁,V₂,V₃,3

VECTOR SUM ACROSS WORD

VSUM V₁,V₂,V₃, M₄ [VRR-c]

The two halfword elements or four byte elements of each word element of the second operand are added together along with the corresponding rightmost sub-element of each word in the third operand. The full-precision intermediate-sum is extended on the left with zeros to a word and the result is placed in the corresponding word element of the first operand.

The M₄ field specifies the element size control (ES). The ES control specifies the size of the sub-elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

M₄ Element Size
0-1 Reserved
2 Word
3 Doubleword
4-15 Reserved

Condition Code: The code remains unchanged.

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:
The second operand contains a mask. The bits in the mask correspond one for one with the bits of the first operand. A mask bit of one indicates that the first-operand bit is to be tested. When a mask bit is zero, the first operand bit is ignored. When all first-operand bits thus selected are zero, condition code 0 is set. Condition code 0 is also set when the mask is all zeros. When the selected bits are all ones, condition code 3 is set; otherwise, condition code 1 is set.

**Resulting Condition Code:**

| 0 | Selected bits all zeros; or all mask bits zero |
| 1 | Selected bits a mix of zeros and ones          |
| 2 | --                                             |
| 3 | Selected bits all ones                        |

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Transaction constraint
Chapter 23. Vector String Instructions

Vector String Facility

The vector string facility provides instructions to accelerate the processing of strings of character data.

Instructions

All of the instructions except for VECTOR ISOLATE STRING have the ability to produce an index to a character element within a vector. This index is always placed in the rightmost bits of the leftmost doubleword of the vector. This index will often be used in scalar computation for address generation and will need to be transferred to a general register. If an element index is needed the index will have to be shifted right by the appropriate number of bits.

Unless otherwise specified, all operands are vector-register operands. A “V” in the assembler syntax designates a vector operand.

Each instruction has an Extended Mnemonic section which describe recommended extended mnemonics and their corresponding machine assembler syntax.

Programming Note: For all instructions that optionally set the condition code, performance may be degraded if the condition code is set.

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VECTOR FIND ANY ELEMENT EQUAL VFAE V 1,V2,V3,M4[,M5] [VRR-b]</td>
<td>VRR-b C* VF 0*3 SP Dv</td>
<td>E782 23-1</td>
</tr>
<tr>
<td>VECTOR FIND ELEMENT EQUAL VFEE VRR-b C* VF</td>
<td>VRR-b C* VF 0*3 SP Dv</td>
<td>E780 23-3</td>
</tr>
<tr>
<td>VECTOR FIND ELEMENT NOT EQUAL VFENE VRR-b C* VF</td>
<td>VRR-b C* VF 0*3 SP Dv</td>
<td>E781 23-4</td>
</tr>
<tr>
<td>VECTOR ISOLATE STRING VISTR VRR-a C* VF</td>
<td>VRR-a C* VF 0*3 SP Dv</td>
<td>E75C 23-5</td>
</tr>
<tr>
<td>VECTOR STRING RANGE COMPARE VSTRC VRR-d C* VF</td>
<td>VRR-d C* VF 0*3 SP Dv</td>
<td>E78A 23-6</td>
</tr>
</tbody>
</table>

Explanation:

$\sigma^7$ Restricted from transactional execution when the effective allow-floating-point-operation control is zero.

$\sigma^3$ Restricted in the constrained transactional-execution mode; a transaction-constraint program exception may be recognized.

C* Condition code optionally set.

Dv Vector-instruction data exception

SP Specification exception.

VF Vector facility for z/Architecture

VRR VRR instruction format

**Figure 23-1. Summary of Vector String Instructions**

**VECTOR FIND ANY ELEMENT EQUAL**

**| VFAE V1,V2,V3,M4[M5] [VRR-b] | 'E7' V1 V2 V3 M4 M5 RXB '82' |
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0 8 12 16 20 24 28 32 36 40 47</td>
<td></td>
</tr>
</tbody>
</table>

Proceeding from left to right, each element of the second operand is compared for equality with every
If the invert-result (IN) flag in the M5 field is one, then each indication in the first intermediate result is inverted.

If the zero-search (ZS) flag in the M5 field is one, each element in the second operand is also compared with zeros and a second intermediate result is created with an indication for each element if that element is equal to zero. If the ZS flag is zero, the second intermediate result contains all false indications.

If the result-type (RT) flag is zero, for each of the two intermediate results, the index of the lowest indexed true result is obtained. The index is then converted to a byte index by multiplying by the number of bytes in an element. The minimum of the indices obtained from the two intermediate results is then computed. If no true result is found in either intermediate result, a final index equal to the number of bytes in the vector is produced. The index is placed into byte seven of the first operand; all other bytes of the first operand are set to zero.

If the RT flag in the M5 field is one, for each element in the second operand, if the indication in the first intermediate result is true, the bit positions of the corresponding element in first operand are set to ones. If the first intermediate result element contains a false indication the bit positions of the corresponding element in the first operand are set to zero. No indication of true results in the second intermediate value are indicated in the first operand.

The ES field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M5</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The bits of the M5 field are defined as follows:

- **Invert Result (IN):** If bit 0 is zero, the operation proceeds using the comparison indication values in the first intermediate result. If one, the operation proceeds with the comparison indication values in the first intermediate result inverted.

- **Result Type (RT):** If bit 1 is zero, a byte index is stored into byte seven of the first operand and zeros are stored in all other elements. If bit 1 is one, each resulting element is a bit-vector.

- **Zero Search (ZS):** If bit 2 is one, each element of the second operand is also compared for equality with zero.

- **Condition Code Set (CS):** If bit 3 is zero, the condition code is not set and remains unchanged. If one, the condition code is set as specified in the resulting condition code section below.

**Resulting Condition Code:**

If the CS-bit is zero, the code remains unchanged.

If the CS-bit is one, the code is set as follows:

0 If the ZS-bit is one, there are no true indications in a lower indexed element in the first intermediate result than a true indication in the second intermediate result. That is, there were no matching elements before an element containing zero in the second operand.

1 At least one indication in the first intermediate result is true. All indications in the second intermediate result are false. That is, there was at least one match in the second operand and, if the ZS-bit is one, no zero matches.

2 If the ZS-bit is one and at least one indication in the first intermediate result is true with a lower index than a true indication in the second intermediate result.

3 All indications in the first intermediate and second intermediate results are false.
**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFAEB V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3[0][M5]</td>
</tr>
<tr>
<td>VFAEF V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3[1][M5]</td>
</tr>
<tr>
<td>VFAEB F V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3[0][M5]</td>
</tr>
<tr>
<td>VFAEHS V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3, 0, (M5</td>
</tr>
<tr>
<td>VFAEFS V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3, 1, (M5</td>
</tr>
<tr>
<td>VFAEZB V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3, 0, (M5</td>
</tr>
<tr>
<td>VFAEZF V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3, 1, (M5</td>
</tr>
<tr>
<td>VFAEZBS V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3, 0, (M5</td>
</tr>
<tr>
<td>VFAEZH V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3, 1, (M5</td>
</tr>
<tr>
<td>VFAEFS V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3, 2, (M5</td>
</tr>
<tr>
<td>VFAEZBS V1, V2, V3[M5]</td>
<td>VFAE V1, V2, V3, 0, (M5</td>
</tr>
</tbody>
</table>

**Programming Notes:**

1. If the RT flag is zero, a byte index is always stored into the first operand for any element size. For example, if the specified element size is halfword and the 2nd indexed halfword compared equal, a byte index of 4 would be stored.

2. If the CS bit is one, conditions codes 0 and 2 can only be set if the ZS-bit is one.

**VECTOR FIND ELEMENT EQUAL**

![VECTOR FIND ELEMENT EQUAL](image)

Proceeding from left to right, the elements of the second operand are compared with the corresponding elements of the third operand and optionally with zero.

If two elements are equal, the byte index of the first byte of the left-most equal element is placed in byte seven of the first operand. Zeros are stored in the remaining bytes of the first operand. If no bytes are found to be equal, or are equal to zero if the zero search (ZS) bit is one, an index equal to the number of bytes in the vector is stored in byte seven of the first operand. Zeros are stored in the remaining bytes.

If the ZS bit is one in the M5 field, each element in the second operand is also compared for equality with zero. If a zero element is found in the second operand before any other elements of the second and third operands are found to be equal, the byte index of the first byte of the element found to be zero is stored in byte seven the first operand and zeros are stored in all other byte locations. If the condition code-set (CS) flag is one, the condition code is set to zero.

The M4 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M4</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The M5 field has the following format:

```
0 1 2 3
ZE/CS
```

The bits of the M5 field are defined as follows:

- **Reserved:** Bits 0-1 are reserved and must be zero. Otherwise, a specification exception is recognized.
- **Zero Search (ZS):** If bit 2 is one, each element of the second operand is also compared for equality with zero.
- **Condition Code Set (CS):** If bit 3 is zero, the condition code remains unchanged. If one, the condition code is set as specified in the following section.

**Resulting Condition Code:**

If the CS-bit is zero, the code remains unchanged.

If the CS-bit is one, the code is set as follows:
0 If the ZS-bit is one, in the second operand there were no equal comparisons in an element with an index less than an element whose contents are zero.

1 Comparison detected a match between the second and third operands in some element. If the ZS-bit is one, there were no zero comparisons in the second operand.

2 If the ZS-bit is one, there was a match between the second and third operands with a lower index than a match with zero in the second operand.

3 No elements compared equal. Additionally, if the ZS-bit is one, no elements contain zero.

Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFEEB</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEH</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEF</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEBS</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEHS</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEFS</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEZB</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEZH</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEZF</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEZBS</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEZHS</td>
<td>VFE</td>
</tr>
<tr>
<td>VFEEZFS</td>
<td>VFE</td>
</tr>
</tbody>
</table>

Programming Notes:

1. A byte index is always stored into the first operand for any element size. For example, if the specified element size is halfword and the 2nd indexed halfword compared equal, a byte index of 4 would be stored.

2. Depending on the model, VECTOR FIND ELEMENT EQUAL may have better performance than VECTOR FIND ANY EQUAL when searching for a single character by replicating the character across all elements of the third operand.

Extended Mnemonic Base Mnemonic
VFEEB V$1$,V$2$,V$3$,[M$4$]
VFEEH V$1$,V$2$,V$3$|M$4$
VFEEF V$1$,V$2$,V$3$+2|M$4$
VFEEBS V$1$,V$2$,V$3$
VFEEHS V$1$,V$2$,V$3$+1
VFEEFS V$1$,V$2$,V$3$+2
VFEEZB V$1$,V$2$,V$3$
VFEEZH V$1$,V$2$,V$3$+2
VFEEZF V$1$,V$2$,V$3$
VFEEZBS V$1$,V$2$,V$3$+2
VFEEZHS V$1$,V$2$,V$3$+3
VFEEZFS V$1$,V$2$,V$3$+3

VFENE V$1$,V$2$,V$3$,M$4$,M$5$] [VRR-b]

Proceeding from left to right, the elements of the second operand are compared with the corresponding elements of the third operand and optionally with zeros. The elements of the second and third operands are treated as unsigned binary integers.

If two elements are not equal, the byte index of the leftmost not-equal element is placed in byte seven of the first operand and zeros are stored to all other bytes. If the condition code set (CS) bit in the M$5$ field is one, the condition code is set to indicate which operand was greater. If all elements were equal, a byte index equal to the vector size is placed in byte seven of the first operand and zeros are placed in all other byte locations and if the CS bit is one, condition code 3 is set.

If the zero search (ZS) bit is one in the M$5$ field, each element in the second operand is also compared for equality with zero. If a zero element is found in the second operand with a lower index than any other element of the second operand found to be unequal, the byte index of the first byte of the element found to be zero is stored in byte seven of the first operand. Zeros are stored in all other bytes and condition code 0 is set.

The M$4$ field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M$4$</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The M$5$ field has the following format:
The bits of the M5 field are defined as follows:

- **Reserved:** Bits 0 and 1 are reserved and must be zero, otherwise a specification exception is recognized.

- **Zero Search (ZS):** If bit 2 is one, each element of the second operand is also compared for equality with zero.

- **Condition Code Set (CS):** If bit 3 is zero, the condition code is not set and remains unchanged. If one, the condition code is set as specified in the following section.

**Resulting Condition Code:**

If the CS-bit is zero, the code remains unchanged.

If the CS-bit is one, the code is set as follows:

0  If the ZS-bit is one, comparison detected a zero element in both operands in a lower indexed element than any unequal compares.
1  An element mismatch was detected and the element in the second operand is less than the element in the third operand.
2  An element mismatch was detected and the element in the second operand is greater than the element in the third operand.
3  All elements compared equal, and if the ZS-bit is one, no zero elements were found in the second operand.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFENEF V1,V2,V3</td>
<td>VFENE V1,V2,V3,1</td>
</tr>
<tr>
<td>VFENEFS V1,V2,V3</td>
<td>VFENE V1,V2,V3,2</td>
</tr>
<tr>
<td>VFENEZB V1,V2,V3</td>
<td>VFENE V1,V2,V3,0</td>
</tr>
<tr>
<td>VFENEZH V1,V2,V3</td>
<td>VFENE V1,V2,V3,2</td>
</tr>
</tbody>
</table>

**VECTOR ISOLATE STRING**

<table>
<thead>
<tr>
<th>VISTR</th>
<th>V1,V2,M3,M5</th>
<th>VRR-a</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>'E7'</td>
<td>V1</td>
</tr>
<tr>
<td></td>
<td>V2</td>
<td>'/////////'</td>
</tr>
<tr>
<td></td>
<td>M3</td>
<td>'/////////'</td>
</tr>
<tr>
<td></td>
<td>M5</td>
<td>RXB</td>
</tr>
<tr>
<td></td>
<td>'5C'</td>
<td></td>
</tr>
</tbody>
</table>

Proceeding from left to right, the elements of the second operand are compared with zero. The elements of the second operand are treated as unsigned binary integers. If a zero comparison is not found, the element is copied into the corresponding element of the first operand. If a zero comparison is found, comparison stops and the corresponding element and all elements to the right in the first operand are set to zero.

The M3 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

<table>
<thead>
<tr>
<th>M3</th>
<th>Element Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Byte</td>
</tr>
<tr>
<td>1</td>
<td>Halfword</td>
</tr>
<tr>
<td>2</td>
<td>Word</td>
</tr>
<tr>
<td>3-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The M5 field has the following format:

```
0 1 2 3
```

The bits of the M5 field are defined as follows:

- **Reserved:** Bits 0-2 are reserved and must be zero, otherwise a specification exception is recognized.

- **Condition Code Set (CS):** If bit 3 is zero, the condition code is not set and remains unchanged. If one, the condition code is set as specified in the following section.

**Resulting Condition Code:**
If the CS-bit is zero, the code remains unchanged.

If the CS-bit is one, the code is set as follows:

0 A zero element was found in the second operand
1 --
2 --
3 All elements of the second operand are non-zero

Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VISTRB V,I[V1],V2,M3</td>
<td>VISTR V1,V2,0[M3]</td>
</tr>
<tr>
<td>VISTRH V,I[V1],V2,M3</td>
<td>VISTR V1,V2,1[M3]</td>
</tr>
<tr>
<td>VISTRF V1[V1],V2,M3</td>
<td>VISTR V1,V2,2[M3]</td>
</tr>
<tr>
<td>VISTRBS V1,V2</td>
<td>VISTR V1,V2,0,1</td>
</tr>
<tr>
<td>VISTRHS V1,V2</td>
<td>VISTR V1,V2,1,1</td>
</tr>
<tr>
<td>VISTRFS V1,V2</td>
<td>VISTR V1,V2,2,1</td>
</tr>
</tbody>
</table>

VECTOR STRING RANGE COMPARE

<table>
<thead>
<tr>
<th>VSTRC V1,V2,V3,M4[M5]</th>
<th>[VRR-d]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E7' V1 V2 V3 M4 M5 V4</td>
<td>RXB '8A'</td>
</tr>
</tbody>
</table>

Proceeding from left to right, the elements of the second operand are compared to ranges specified by values in even-odd element pairs of the third and fourth operands and, optionally, against an element containing zero. The element in the second and third operand are treated as unsigned binary integers.

The elements of the third and fourth operands form range comparisons to which are applied to elements of the second operand. The even-odd pairs of elements in the third operand define values for the limits of the ranges. The corresponding even-odd pair of elements in the fourth operand contain control information to specify the comparison to be done with each value in the third operand. A range comparison is said to be true if the comparisons on both elements in the even-odd pair are true.

Each element in the second operand is compared against every range specified by the even-odd element pairs in the third and fourth operands. A first intermediate result is created from this comparison with an indication for each element in the second operand if the element was contained in any of the specified ranges.

If the invert-result (IN) flag in the M6 field is one, then each indication in the first intermediate result is inverted.

If the zero-search (ZS) flag in the M6 field is one, each element in the second operand is also compared with zeros and a second intermediate result is created with an indication for each element if that element is equal to zero. If the ZS flag is zero the second intermediate result contains all false indications.

If the result-type (RT) flag is zero, for each of the two intermediate results, the index of the lowest indexed true result is obtained. The index is then converted to a byte index by multiplying by the number of bytes in an element. The minimum of the indices obtained from the two intermediate results is then computed. If no true result is found in either intermediate result, a final index equal to the number of bytes in the vector is produced. The index is placed into byte seven of the first operand; all other bytes of the first operand are set to zero.

If the RT flag in the M6 field is one, for each element in the second operand, if the indication in the first intermediate result is true, the bit positions of the corresponding element in first operand are set to ones. If the first intermediate result element contains a false indication the bit positions of the corresponding element in the first operand are set to zero. No indication of true results in the second intermediate value are indicated in the first operand.

The fourth operand elements have the following format:

If ES equals 0:

<table>
<thead>
<tr>
<th>ELH</th>
<th>1</th>
<th>1</th>
<th>1</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>2</td>
<td>7</td>
<td></td>
</tr>
</tbody>
</table>

If ES equals 1:

<table>
<thead>
<tr>
<th>ELH</th>
<th>1</th>
<th>1</th>
<th>1</th>
<th>1</th>
<th>1</th>
<th>1</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>2</td>
<td>15</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
If ES equals 2:

- **Equal (E):** When one, a comparison for equality is made.
- **Low (L):** When one, a less than comparison is performed.
- **High (H):** When one, a greater than comparison is performed.
- All other bits are reserved and should be zero to ensure future compatibility.

The control bits may be used in any combination. If none of the bits are set, the comparison will always produce a false result. If all of the bits are set, the comparison will always produce a true result.

The M5 field specifies the element size control (ES). The ES control specifies the size of the elements in the vector register operands. If a reserved value is specified, a specification exception is recognized.

The M6 field has the following format:

- **Element Size**
  - 0: Byte
  - 1: Halfword
  - 2: Word
  - 3-15: Reserved

The M6 field has the following format:

- **Invert Result (IN):** If bit 0 is zero, the operation proceeds using the comparison indication values in the first intermediate result. If one, the operation proceeds with the comparison indication values in the first intermediate result inverted.
- **Result Type (RT):** If bit 1 is zero, a byte index is stored into byte seven of the first operand and zeros are stored in all other elements. If bit 1 is one, each resulting element is a bit-vector.
- **Zero Search (ZS):** If bit 2 is one, each element of the second operand is also compared for equality with zero.
- **Condition Code Set (CS):** If bit 3 is zero, the condition code is not set and remains unchanged. If one, the condition code is set as specified in the following section.

**Resulting Condition Code:**

If the CS-bit is zero, the code remains unchanged.

If the CS-bit is one, the code is set as follows:

1. **0** If the ZS-bit is one, there are no true indications in a lower indexed element in the first intermediate result than a true indication in the second intermediate result. That is, there were no matching elements before an element containing zero in the second operand.
2. **1** At least one indication in the first intermediate result is true. All indications in the second intermediate result are false. That is, there was at least one match in the second operand and, if the ZS-bit is one, no zero matches.
3. **2** If the ZS-bit is one and at least one indication in the first intermediate result is true with a lower index than a true indication in the second intermediate result.
4. **3** All indications in the first intermediate and second intermediate results are false.

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VSTRCB</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCH</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCF</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCBS</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCHS</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCHS</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCBS</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCBZ</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCHZ</td>
<td>VSTR</td>
</tr>
<tr>
<td>VSTRCFS</td>
<td>VSTR</td>
</tr>
<tr>
<td>Extended Mnemonic</td>
<td>Base Mnemonic</td>
</tr>
<tr>
<td>------------------</td>
<td>--------------</td>
</tr>
<tr>
<td>VSTRCZBS V₁,V₂,V₃,V₄[,M₆]</td>
<td>VSTRC V₁,V₂,V₃,V₄,0,((M₆</td>
</tr>
<tr>
<td>VSTRCZHS V₁,V₂,V₃,V₄[,M₆]</td>
<td>VSTRC V₁,V₂,V₃,V₄,1,((M₆</td>
</tr>
<tr>
<td>VSTRCZFS V₁,V₂,V₃,V₄[,M₆]</td>
<td>VSTRC V₁,V₂,V₃,V₄,2,((M₆</td>
</tr>
</tbody>
</table>

**Programming Notes:**

1. To create a comparison that is a range with only one bound, either place that comparison in both the even and odd elements of the pair in the third and fourth operands or place the operand in a single element of the pair with the comparison needed in the corresponding element of the fourth operand, and set the other element in the fourth operand to have all three control bits set.

2. To create a comparison for equality place the same value in the even-odd pair in the third operand. The corresponding even-odd element pair in the fourth operand should contain elements with only a one in the EQ bit.

3. If all available ranges are not needed, the control bits in the fourth operand should all be zero for the elements in the unneeded range. The corresponding elements in the third operand are ignored.
### IEEE Exception Handling

When a vector instruction is executed and a trapping IEEE exception condition is encountered, instruction execution is suppressed for all elements, except that the floating-point-control register is updated with the VXC.

If trapping vector-processing exception conditions exist for multiple elements, the exception of the lowest-indexed element is recognized.

When either a trapping IEEE overflow or IEEE underflow exception occur concurrently on the same element with a trapping IEEE inexact exception, only the IEEE overflow or IEEE underflow exception is recognized.

### Result Figures

Concise descriptions of the results produced by many of the vector floating point instructions are made by means of figures which contain columns and rows representing all possible combinations of data class for the source operand elements of an instruction. The information shown at the intersection of a row and a column is one or more symbols representing the result or results produced for that particular combination of source-operand element data classes. Explanations of the symbols used are contained in each figure. In many cases, the explanation of a particular result is in the form of a cross reference to another figure. In many cases, the information shown at the intersection consists of several symbols separated by commas. All such results are produced unless one of the results for an element is

---

**Table:**

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>IEEE Exception Handling</td>
<td>24-1</td>
</tr>
<tr>
<td>Result Figures</td>
<td>24-1</td>
</tr>
<tr>
<td>Instructions</td>
<td>24-2</td>
</tr>
<tr>
<td>VECTOR FP ADD</td>
<td>24-3</td>
</tr>
<tr>
<td>VECTOR FP COMPARE SCALAR</td>
<td>24-7</td>
</tr>
<tr>
<td>VECTOR FP COMPARE AND SIGNAL SCALAR</td>
<td>24-8</td>
</tr>
<tr>
<td>VECTOR FP COMPARE EQUAL</td>
<td>24-9</td>
</tr>
<tr>
<td>VECTOR FP COMPARE HIGH</td>
<td>24-10</td>
</tr>
<tr>
<td>VECTOR FP COMPARE HIGH OR EQUAL</td>
<td>24-12</td>
</tr>
<tr>
<td>VECTOR FP CONVERT FROM FIXED</td>
<td>24-13</td>
</tr>
<tr>
<td>VECTOR FP CONVERT FROM LOGICAL</td>
<td>24-15</td>
</tr>
<tr>
<td>VECTOR FP CONVERT TO FIXED 64-BIT</td>
<td>24-16</td>
</tr>
<tr>
<td>VECTOR FP CONVERT TO LOGICAL 64-BIT</td>
<td>24-18</td>
</tr>
<tr>
<td>VECTOR FP DIVIDE</td>
<td>24-20</td>
</tr>
<tr>
<td>VECTOR LOAD FP INTEGER</td>
<td>24-22</td>
</tr>
<tr>
<td>VECTOR LOAD FP LENGTHENED</td>
<td>24-24</td>
</tr>
<tr>
<td>VECTOR LOAD ROUNDED</td>
<td>24-25</td>
</tr>
<tr>
<td>VECTOR FP MULTIPLY</td>
<td>24-26</td>
</tr>
<tr>
<td>VECTOR FP MULTIPLY AND ADD</td>
<td>24-27</td>
</tr>
<tr>
<td>VECTOR FP MULTIPLY AND SUBTRACT</td>
<td>24-27</td>
</tr>
<tr>
<td>VECTOR FP PERFORM SIGN OPERATION</td>
<td>24-29</td>
</tr>
<tr>
<td>VECTOR FP SQUARE ROOT</td>
<td>24-30</td>
</tr>
<tr>
<td>VECTOR FP SUBTRACT</td>
<td>24-31</td>
</tr>
<tr>
<td>VECTOR FP TEST DATA CLASS IMMEDIATE</td>
<td>24-31</td>
</tr>
</tbody>
</table>

---

**Notes:**

The vector facility for z/Architecture provides support for long-format binary-floating-point (BFP) operations, with the exception of VECTOR LOAD LENGTHENED which operates on short-format BFP numbers and VECTOR LOAD ROUNDED which produces a short-format BFP result. Numerically, the results in each element are the same as would occur as if an instruction in Chapter 19 was used to compute the result. Some instructions have different result figures noting changes due to different exception handling described below.

When a vector instruction is executed, no trapping IEEE exceptions are encountered on any elements, and a non-trapping IEEE exception condition is encountered on an element, the flag bit for that exception is set in the floating-point-control (FPC) register and the IEEE defined default value is placed in the corresponding element of the target operand. If multiple elements have non-trapping IEEE exception conditions then each element sets the flag bit in the FPC register and the defined default values are placed in the corresponding elements of the target operand.
a program interruption. In the case of a program interruption on any element, the operation is suppressed.

Figure 24-1, “IEEE Exception and Flag Abbreviations” on page 24-2 shows IEEE exceptions and flag abbreviations that are used in the result figures.

<table>
<thead>
<tr>
<th>Exception</th>
<th>FPC IEEE Mask Bit</th>
<th>IEEE Flag</th>
</tr>
</thead>
<tbody>
<tr>
<td>IEEE invalid operation</td>
<td>0.0</td>
<td>1.0</td>
</tr>
<tr>
<td>IEEE division by zero</td>
<td>0.1</td>
<td>1.1</td>
</tr>
<tr>
<td>IEEE overflow</td>
<td>0.2</td>
<td>1.2</td>
</tr>
<tr>
<td>IEEE underflow</td>
<td>0.3</td>
<td>1.3</td>
</tr>
<tr>
<td>IEEE inexact</td>
<td>0.4</td>
<td>1.4</td>
</tr>
</tbody>
</table>

Explanations:

1 The symbol “Xi” followed by a list of results in a figure indicates that, when FPC 0.0 is zero, then instruction execution is completed by setting SFi (FPC 1.0) to one and producing the indicated results; and when FPC 0.0 is one, then instruction execution is suppressed, if the element is the leftmost element upon which an exception is recognized the vector interrupt code (VIC) in the vector exception code (VXC) is set to 1 hex, the VIX is set to the index of the element recognizing the exception, and a program interruption for a vector-processing exception occurs.

2 The symbol “Xz” followed by a list of results in a figure indicates that, when FPC 0.1 is zero, then instruction execution is completed by setting SFz (FPC 1.1) to one and producing the indicated results; and when FPC 0.1 is one, then instruction execution is suppressed if the element is the leftmost element upon which an exception is recognized the vector interrupt code (VIC) in the vector exception code (VXC) is set to 2 hex, the VIX is set to the index of the element recognizing the exception, and a program interruption for a data exception occurs.

Instructions

Each instruction has an Extended Mnemonic section which describes recommended extended mnemonics and their corresponding machine assembler syntax. Not all assemblers may provide these mnemonics.

Most vector floating-point instructions have a single element control bit. If this bit is set to one, indicating only one element is to be executed, performance may be improved on some models. When the single element control bit is set the bit positions of all other elements besides the zero indexed element are unpredictable. A mnemonic with the initial V replaced with a W indicates the instruction will only operate on a single element.

<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VECTOR FP ADD</td>
<td>VFA</td>
<td>VRR-c VF</td>
<td>Dv Xi Xo Xu Xx</td>
<td>E7E3 24-3</td>
</tr>
<tr>
<td>VECTOR FP COMPARE SCALAR</td>
<td>WFC</td>
<td>VRR-a C VF</td>
<td>Dv Xi</td>
<td>E7CB 24-7</td>
</tr>
<tr>
<td>VECTOR FP COMPARE AND SIGNAL SCALAR</td>
<td>WFK</td>
<td>VRR-a C VF</td>
<td>Dv Xi</td>
<td>E7CA 24-8</td>
</tr>
<tr>
<td>VECTOR FP COMPARE EQUAL</td>
<td>VFCE</td>
<td>VRR-c C* VF</td>
<td>Dv Xi</td>
<td>E7EB 24-9</td>
</tr>
<tr>
<td>VECTOR FP COMPARE HIGH</td>
<td>VFCH</td>
<td>VRR-c C* VF</td>
<td>Dv Xi</td>
<td>E7EB 24-10</td>
</tr>
<tr>
<td>VECTOR FP COMPARE HIGH OR EQUAL</td>
<td>VFCHE</td>
<td>VRR-c C* VF</td>
<td>Dv Xi</td>
<td>E7EA 24-12</td>
</tr>
</tbody>
</table>
VECTOR FP ADD

VFA \( V_1, V_2, V_3, M_4, M_5 \) [VRR-c]

\[
\begin{array}{cccccccccc}
\text{E7} & V_1 & V_2 & V_3 & / / / / / / & M_6 & M_4 & R_{XB} & \text{E3}'
\end{array}
\]

0 8 12 16 20 28 32 36 40 47

The floating-point element or elements of the third operand are added to the corresponding floating-point element or elements of the second operand. The results are placed in the corresponding elements of the first operand. All operand elements contain long-format BFP numbers.

If the corresponding elements of both operands are finite numbers, they are added algebraically, forming an intermediate sum. The intermediate sum, if nonzero, is rounded to the operand format according to the current BFP rounding mode. The sum is then placed at the result location.

The sign of the sum is determined by the rules of algebra. This also applies to a result of zero:

- If the result of rounding a nonzero intermediate sum is zero, the sign of the zero result is the sign of the intermediate sum.
- If the sum of two operand elements with opposite signs is exactly zero, the sign of the result is plus in all rounding methods except round toward \(-\infty\), in which method the sign is minus.
- The sign of the sum \( x + x \) is the sign of \( x \), even when \( x \) is zero.

**Explanation:**

- \( \sigma^7 \) Restricted from transactional execution when the effective allow-floating-point-operation control is zero.
- \( \sigma^9 \) Restricted in the constrained transactional-execution mode; a transaction-constraint program exception may be recognized.
- \( C \) Condition code set.
- \( C^* \) Condition code optionally set.
- \( Dv \) Vector-instruction data exception.
- \( SP \) Specification exception.
- \( VF \) Vector facility for z/Architecture.
- \( VRI \) VRI instruction format.
- \( VRR \) VRR instruction format.
- \( Xi \) IEEE invalid-operation exception.
- \( Xo \) IEEE overflow exception.
- \( Xu \) IEEE underflow exception.
- \( Xx \) IEEE inexact exception.
- \( Xz \) IEEE division-by-zero exception.
If one operand element is an infinity and the other is a finite number, the result is that infinity. If both operand elements are infinities of the same sign, the result is the same infinity. If the two operand elements are infinities of opposite signs, an IEEE-invalid-operation exception is recognized.

See Figure 24-3 on page 24-5 for detailed information on the results for each element.

The M₄ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M₅ field has the following format:

```
0 1 3
```

The bits of the M₅ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **Reserved:** Bits 1 to 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid Operation
- Overflow
- Underflow
- Inexact

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFADB</td>
<td>V₁,V₂,V₃</td>
</tr>
<tr>
<td>WFADB</td>
<td>V₁,V₂,V₃</td>
</tr>
<tr>
<td>Second Operand Element (a) Is</td>
<td>$-\infty$</td>
</tr>
<tr>
<td>-----------------------------</td>
<td>-----------</td>
</tr>
<tr>
<td>$-\infty$</td>
<td>T($-\infty$)</td>
</tr>
<tr>
<td>-Nn</td>
<td>T($-\infty$)</td>
</tr>
<tr>
<td>-Dn</td>
<td>T($-\infty$)</td>
</tr>
<tr>
<td>-0</td>
<td>T($-\infty$)</td>
</tr>
<tr>
<td>+0</td>
<td>T($-\infty$)</td>
</tr>
<tr>
<td>+Dn</td>
<td>T($-\infty$)</td>
</tr>
<tr>
<td>+Nn</td>
<td>T($-\infty$)</td>
</tr>
<tr>
<td>$+\infty$</td>
<td>Xi: T(dNaN)</td>
</tr>
<tr>
<td>QNaN</td>
<td>T(a)</td>
</tr>
<tr>
<td>SNaN</td>
<td>Xi: T(a*)</td>
</tr>
</tbody>
</table>

**Explanation:**

* The SNaN is converted to the corresponding QNaN before it is placed at the target operand element location.

dNaN Default NaN.

Dn Subnormal number.

Nn Normal number.

R(v) Rounding and range action is performed on the value v. See Figure 24-4 on page 24-6.

Rezd Exact zero-difference result. See Figure 24-4 on page 24-6.

T(x) The value x is placed at the target operand element location if no trapping exceptions on other elements.

Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

Figure 24-3. Results: VECTOR FP ADD
### Nontrap Result (r) when Effective Rounding Method Is To Nearest with ties to even Toward 0 Toward +∞ Toward -∞ Prepare for shorter precision

<table>
<thead>
<tr>
<th>Range of v</th>
<th>Case</th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>v &lt; -Nmax, g &lt; -Nmax</td>
<td>Overflow</td>
<td>-∞1</td>
<td>-Nmax</td>
<td>-Nmax</td>
<td>-∞1</td>
</tr>
<tr>
<td>v &lt; -Nmax, g = -Nmax</td>
<td>Normal</td>
<td>-Nmax</td>
<td>-Nmax</td>
<td>-Nmax</td>
<td>-</td>
</tr>
<tr>
<td>-Nmax ≤ v ≤ -Nmin</td>
<td>Normal</td>
<td>g</td>
<td>g</td>
<td>g</td>
<td>g</td>
</tr>
<tr>
<td>-Nmin &lt; v ≤ -Dmin</td>
<td>Tiny</td>
<td>d*</td>
<td>d</td>
<td>d</td>
<td>d*</td>
</tr>
<tr>
<td>-Dmin &lt; v &lt; -Dmin/2</td>
<td>Tiny</td>
<td>-Dmin</td>
<td>-0</td>
<td>-0</td>
<td>-Dmin</td>
</tr>
<tr>
<td>-Dmin/2 ≤ v &lt; 0</td>
<td>Tiny</td>
<td>-0</td>
<td>-0</td>
<td>-0</td>
<td>-Dmin</td>
</tr>
<tr>
<td>v = 0</td>
<td>Exact zero difference2</td>
<td>+0</td>
<td>+0</td>
<td>+0</td>
<td>-0</td>
</tr>
<tr>
<td>0 ≤ v ≤ +Dmin/2</td>
<td>Tiny</td>
<td>+0</td>
<td>+0</td>
<td>+Dmin</td>
<td>+0</td>
</tr>
<tr>
<td>+Dmin/2 ≤ v &lt; +Dmin</td>
<td>Tiny</td>
<td>+Dmin</td>
<td>+0</td>
<td>+Dmin</td>
<td>+0</td>
</tr>
<tr>
<td>+Dmin ≤ v &lt; +Nmin</td>
<td>Tiny</td>
<td>d*</td>
<td>d</td>
<td>d*</td>
<td>d</td>
</tr>
<tr>
<td>+Nmin ≤ v ≤ +Nmax</td>
<td>Normal</td>
<td>g</td>
<td>g</td>
<td>g</td>
<td>g</td>
</tr>
<tr>
<td>+Nmax &lt; v, g = +Nmax</td>
<td>Normal</td>
<td>+Nmax</td>
<td>+Nmax</td>
<td>-</td>
<td>+Nmax</td>
</tr>
<tr>
<td>+Nmax &lt; v, +Nmax &lt; g</td>
<td>Overflow</td>
<td>+∞1</td>
<td>+Nmax</td>
<td>+∞1</td>
<td>+Nmax</td>
</tr>
</tbody>
</table>

**Explanation:**

– This situation cannot occur.
* The rounded value, in the extreme case, may be Nmin. In this case, the exceptions are underflow, inexact and incremented.
1 The nontrap result r is considered to have been incremented.
2 The exact-zero-difference case applies only to VECTOR FP ADD, VECTOR FP SUBTRACT, VECTOR FP MULTIP Y AND ADD, and VECTOR FP MULTIPLY AND SUBTRACT. For all other vector BFP operations, a zero result is detected by inspection of the source operand elements without use of the R(v) function.

**Legend:**

- **d**: The denormalized value. The value derived when the precise intermediate value (v) is rounded to the format of the target, including both precision and bounded exponent range. Except as explained in note *, this is a subnormal number.
- **g**: The precision-rounded value. The value derived when the precise intermediate value (v) is rounded to the precision of the target, but assuming an unbounded exponent range.
- **v**: Precise intermediate value. This is the value, before rounding, assuming unbounded precision and an unbounded exponent range. For VECTOR LOAD ROUNDED, v is the source value (a).
- **Dmin**: Smallest (in magnitude) representable subnormal number in the target format.
- **Nmax**: Largest (in magnitude) representable finite number in the target format.
- **Nmin**: Smallest (in magnitude) representable normal number in the target format.

---

Figure 24-4. Action for R(v): Rounding and Range Function (Part 1 of 2)
The zero-indexed element of the first operand is compared with the zero-indexed element of the second operand, and the condition code is set to indicate the result.

If both operand elements are finite numbers, the comparison is algebraic and follows the procedure for BFP subtraction, except that the difference is discarded after setting the condition code, and both operand elements remain unchanged. If the difference is exactly zero with either sign, the operand elements are equal; this includes zero operand elements (so +0 equals -0). If a nonzero difference is positive or negative, the first operand element is high or low, respectively.

+∞ compares greater than any finite number, and all finite numbers compare greater than -∞. Two infinity operand elements of like sign compare equal.

Numeric comparison is exact, and the condition code is determined for finite operand elements as if range and precision were unlimited. No overflow or underflow exception can occur.

If either or both operand elements are QNaNs and neither operand element is an SNaN, the comparison result is unordered, and condition code 3 is set.

If either or both operand elements are SNaNs, an IEEE-invalid-operation exception is recognized. If the IEEE invalid-operation mask bit is one, a program interruption for a vector-processing exception with a VXC indicating an IEEE invalid-operation occurs. If
the IEEE-invalid-operation mask bit is zero, the IEEE-invalid-operation flag bit is set to one, and instruction execution is completed by setting condition code 3.

See Figure 19-14, “Results: COMPARE” on page 19-18 for a detailed description of the results of this instruction substituting the first operand element for (a) and the second operand element for (b).

The M₃ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M₄ field must be zero otherwise a specification exception is recognized.

**Resulting Condition Code:**

0  Operand elements equal
1  First operand element low
2  First operand element high
3  Operand elements unordered

**IEEE Exceptions:**

- Invalid operation

**Program Exceptions:**

- Data with DXC FE, Vector instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>WFCDB V₁,V₂</td>
<td>WFC V₁,V₂,3,0</td>
</tr>
</tbody>
</table>

**Programming Notes:**

1. VECTOR FP COMPARE SCALAR may be used to set a condition code to be used by a subsequent branch for program control flow.
2. VECTOR FP COMPARE SCALAR may be used to implement those comparisons which are required by ANSI/IEEE Standard 754-2008 to not recognize an exception when the result is unordered due to a QNaN.

**IEEE Exceptions:**

- Invalid operation

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index
**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>WFKDB V1,V2</td>
<td>WFK V1,V2,3,0</td>
</tr>
</tbody>
</table>

**Programming Notes:**

1. **VECTOR FP COMPARE AND SIGNAL SCALAR** may be used to set a condition code to be used by a subsequent branch for program control flow.

2. **VECTOR FP COMPARE AND SIGNAL SCALAR** may be used to implement those comparisons which are required by ANSI/IEEE Standard 754-2008 to recognize an exception when the result is unordered due to a QNaN.

**VECTOR FP COMPARE EQUAL**

\[ VFCE V_1, V_2, M_4, M_5, M_6 \] [VRR-c]

The floating-point element or elements of the second operand are compared for equality with the corresponding element or elements of the third operand. If equal, the bits of the corresponding element in the first operand are set to all ones, otherwise the bits are set to all zeros. The second and third operand elements contain long-format BFP numbers.

If any of the elements in the second or third operands are SNaNs, an IEEE invalid-operation exception is recognized. If the IEEE invalid-operation mask bit is one, a program interruption with VXC set for IEEE invalid-operation and the corresponding element index occurs and the operation is suppressed. If the IEEE invalid-operation mask bit is zero, the bits of the corresponding element in the first operand are set to zeros and the IEEE invalid-operation flag bit is set in the FPC register.

See Figure 24-5 on page 24-10 for a detailed description of the results for each element.

The \( M_4 \) field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The bits of the \( M_5 \) field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. The values of all other elements in the second and third operands are ignored. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **Reserved:** Bits 1, 2, and 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

The bits of the \( M_6 \) field are defined as follows:

- **Reserved:** Bits 0, 1, and 2 are reserved and must be zero. Otherwise, a specification exception is recognized.

- **Condition Code Set (CS):** If bit 3 is 0, the code remains unchanged. If the bit is one, the code is set as described below.

**Resulting Condition Code:** When Bit 3 of the \( M_6 \) field is one, the code is set as follows:

0 All elements equal (All T results in Figure 24-5)
1 Mix of equal, and unequal or unordered elements (A mix of T and F results in Figure 24-5)
2 --
3 All elements not equal or unordered (All F results in Figure 24-5)

Otherwise, the code remains unchanged.

**IEEE Exceptions:**

- Invalid Operation
**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFCEDB V₁, V₂, V₃</td>
<td>VFCE V₁, V₂, V₃, 3, 0, 0</td>
</tr>
<tr>
<td>VFCEDBS V₁, V₂, V₃</td>
<td>VFCE V₁, V₂, V₃, 3, 0, 1</td>
</tr>
<tr>
<td>WFCEDB V₁, V₂, V₃</td>
<td>VFCE V₁, V₂, V₃, 3, 8, 0</td>
</tr>
<tr>
<td>WFCEDBS V₁, V₂, V₃</td>
<td>VFCE V₁, V₂, V₃, 3, 8, 1</td>
</tr>
</tbody>
</table>

**Programming Note:** Condition code 1 will never be presented if the S-bit is set to one.

### VECTOR FP COMPARE EQUAL (a:b) when Third Operand Element (b) Is

<table>
<thead>
<tr>
<th>Second Operand Element (a)</th>
<th>Results for VECTOR FP COMPARE EQUAL (a:b)</th>
<th>QNaN</th>
<th>SNaN</th>
</tr>
</thead>
<tbody>
<tr>
<td>ls</td>
<td>-∞</td>
<td>-Fn</td>
<td>-0</td>
</tr>
<tr>
<td>-∞</td>
<td>T</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>-Fn</td>
<td>F</td>
<td>C(a=b)</td>
<td>F</td>
</tr>
<tr>
<td>-0</td>
<td>F</td>
<td>F</td>
<td>T</td>
</tr>
<tr>
<td>+0</td>
<td>F</td>
<td>F</td>
<td>T</td>
</tr>
<tr>
<td>+Fn</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>+∞</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>QNaN</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>SNaN</td>
<td>X: F</td>
<td>F</td>
<td>X: F</td>
</tr>
</tbody>
</table>

**Explanation:**
- T: Corresponding element in operand one is set to all ones
- F: Corresponding element in operand one is set to all zeros
- C(a=b): Basic compare result. T if a=b and F if a≠b.
- Fn: Finite nonzero number (includes both subnormal and normal).
- Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

*Figure 24-5. Results: VECTOR FP COMPARE EQUAL*

**VECTOR FP COMPARE HIGH**

VFCH V₁, V₂, V₃, M₄, M₅, M₆ [VRR-c]

The floating-point element or elements of the second operand are compared with each corresponding floating-point element or elements of the third operand. If the element in the second operand is greater than the element in the third operand, the bit positions of the corresponding element in the first operand are set to one. Otherwise, the bit positions in the corresponding element of the first operand are set to zeros. The second and third operand elements contain long-format BFP numbers.

If any of the elements in the second and third operands are SNaNs, an IEEE invalid-operation exception is recognized. If the IEEE invalid-operation mask bit is one, a program interruption with a VXC indicating and IEEE invalid-operation and the corresponding element index occurs and the operation is suppressed. If the IEEE invalid-operation mask bit is zero, the bits of the corresponding element in the first operand are set to zeros and the IEEE invalid-operation flag bit is set in the FPC register.

See Figure 24-6 on page 24-12 for a detailed description of the results for each element.

The M₄ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.
The M₅ field has the following format:

```
0 1 2 3
```

The bits of the M₅ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. The values of all other elements in the second and third operands are ignored. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **Reserved:** Bits 1, 2, and 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

The M₆ field has the following format:

```
0 2 3
```

The bits of the M₆ field are defined as follows:

- **Reserved:** Bits 0, 1, and 2 are reserved and must be zero. Otherwise, a specification exception is recognized.

- **Condition Code Set (CS):** If bit 3 is 0, the code remains unchanged. If the bit is one, the code is set as described below.

**Resulting Condition Code:** When Bit 3 of the M₆ field is one, the code is set as follows:

0. All elements greater than (All T results in Figure 24-6)
1. Mix of greater than, and non-greater than or unordered elements (A mix of T and F results in Figure 24-6)
2. All elements not greater than, or unordered (All F results in Figure 24-6)

Otherwise, the code remains unchanged.

**IEEE Exceptions:**

- Invalid operation

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFCHDB V₁,V₂,V₃</td>
<td>VFCH V₁,V₂,V₃,3,0,0</td>
</tr>
<tr>
<td>VFCHDBS V₁,V₂,V₃</td>
<td>VFCH V₁,V₂,V₃,3,0,1</td>
</tr>
<tr>
<td>WFCHDB V₁,V₂,V₃</td>
<td>VFCH V₁,V₂,V₃,8,0</td>
</tr>
<tr>
<td>WFCHDBS V₁,V₂,V₃</td>
<td>VFCH V₁,V₂,V₃,8,1</td>
</tr>
</tbody>
</table>

**Programming Note:** Condition Code 1 will never be presented if the S-bit is set to one.
VECTOR FP COMPARE HIGH OR EQUAL

The floating-point element or elements of the second operand are compared with each corresponding floating-point element or elements of the third operand. If the element in the second operand is greater than or equal to the element in the third operand, the bit positions of the corresponding element in the first operand are set to one. Otherwise the bit positions in the corresponding element of the first operand are set to zeros. The second and third operand elements contain long-format BFP numbers.

If any of the floating-point elements in the second or third operand are SNaNs, an IEEE invalid-operation exception is recognized. If the IEEE invalid-operation mask bit is one, a program interruption with VXC set for IEEE invalid-operation and the corresponding element index occurs and the operation is suppressed. If the IEEE invalid-operation mask bit is zero, the bits of the corresponding element in the first operand are set to zeros and the IEEE invalid-operation flag bit is set in the FPC register.

See Figure 24-7 on page 24-13 for a detailed description of the results for each element.

The M₄ field must contain a value of three, all other values are reserved. If a reserved value is specified a specification exception is recognized.

The M₅ field has the following format:

<table>
<thead>
<tr>
<th>S</th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>2</td>
<td>3</td>
</tr>
</tbody>
</table>

The bits of the M₅ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. The values of all other elements in the second and third operands are ignored. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **Reserved:** Bits 1, 2, and 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

---

<table>
<thead>
<tr>
<th>Second Operand (a)</th>
<th>Results for COMPARE HIGH (a:b) when Third Operand (b) Is</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞</td>
<td>F</td>
</tr>
<tr>
<td>-Fn</td>
<td>T</td>
</tr>
<tr>
<td>-0</td>
<td>T</td>
</tr>
<tr>
<td>+0</td>
<td>T</td>
</tr>
<tr>
<td>+Fn</td>
<td>T</td>
</tr>
<tr>
<td>+∞</td>
<td>T</td>
</tr>
<tr>
<td>QNaN</td>
<td>F</td>
</tr>
<tr>
<td>SNaN</td>
<td>Xi: F</td>
</tr>
</tbody>
</table>

**Explanation:**

- T: Corresponding element in operand one is set to all ones
- F: Corresponding element in operand one is set to all zeros
- C(a>b): Basic compare results. T if a>b, F if a<b
- Fn: Finite nonzero number (includes both subnormal and normal).
- Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

**Figure 24-6. Results: VECTOR FP COMPARE HIGH**

---

VECTOR FP COMPARE HIGH OR EQUAL

VFCHE V₁,V₂,V₃,M₄,M₅,M₆ [VRR-c]

<table>
<thead>
<tr>
<th>'E7'</th>
<th>V₁</th>
<th>V₂</th>
<th>V₃</th>
<th>//</th>
<th>M₄</th>
<th>M₅</th>
<th>M₆</th>
<th>RXB 'EA'</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>24</td>
<td>28</td>
<td>32</td>
<td>36</td>
</tr>
</tbody>
</table>

The floating-point element or elements of the second operand are compared with each corresponding floating-point element or elements of the third operand. If the element in the second operand is greater than or equal to the element in the third operand, the bit positions of the corresponding element in the first operand are set to one. Otherwise the bit positions in the corresponding element of the first operand are set to zeros. The second and third operand elements contain long-format BFP numbers.
The M₆ field has the following format:

```
0 1 2 3
```

The bits of the M₆ field are defined as follows:

- **Reserved**: Bits 0, 1, and 2 are reserved and must be zero. Otherwise, a specification exception is recognized.
- **Condition Code Set (CS)**: If bit 3 is 0, the code remains unchanged. If the bit is one, the code is set as described below.

**Resulting Condition Code**: When Bit 3 of the M₆ field is one, the code is set as follows:

- **0**: All elements greater than or equal (All T results in Figure 24-7)
- **1**: Mix of greater than or equal and less than elements (A mix of T and F results in Figure 24-7)
- **2-3**: All elements less than or unordered (All F results in Figure 24-7)

**IEEE Exceptions**:
- Invalid operation

**Program Exceptions**:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics**:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFCHEDB V₁,V₂,V₃</td>
<td>VFCE V₁,V₂,V₃,3,0,0</td>
</tr>
<tr>
<td>VFCHEDBS V₁,V₂,V₃</td>
<td>VFCE V₁,V₂,V₃,3,0,1</td>
</tr>
<tr>
<td>WFCHEDB V₁,V₂,V₃</td>
<td>VFCE V₁,V₂,V₃,3,8,0</td>
</tr>
<tr>
<td>WFCHEDBS V₁,V₂,V₃</td>
<td>VFCE V₁,V₂,V₃,3,8,1</td>
</tr>
</tbody>
</table>

**Programming Note**: Condition Code 1 will never be presented if the S-bit is set to one.

---

### Second Operand (a) Is

<table>
<thead>
<tr>
<th>Second Operand (a) Is</th>
<th>Results for COMPARE HIGH OR EQUAL (a:b) when Third Operand (b) Is</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞</td>
<td>-Fn</td>
</tr>
<tr>
<td>-∞</td>
<td>T</td>
</tr>
<tr>
<td>-Fn</td>
<td>T</td>
</tr>
<tr>
<td>-0</td>
<td>T</td>
</tr>
<tr>
<td>+0</td>
<td>T</td>
</tr>
<tr>
<td>+Fn</td>
<td>T</td>
</tr>
<tr>
<td>+∞</td>
<td>T</td>
</tr>
<tr>
<td>QNaN</td>
<td>F</td>
</tr>
<tr>
<td>SNaN</td>
<td>Xi: F</td>
</tr>
</tbody>
</table>

**Explanation**:
- **T**: Corresponding element in operand one is set to all ones
- **F**: Corresponding element in operand one is set to all zeros
- **C(a≥b)**: Basic compare results. See Figure 19-15 on page 19-18
- **Fn**: Finite nonzero number (includes both subnormal and normal).
- **Xi**: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

**Figure 24-7. Results: VECTOR FP COMPARE HIGH OR EQUAL**

**VECTOR FP CONVERT FROM FIXED 64-BIT**

<table>
<thead>
<tr>
<th>VCDG</th>
<th>V₁,V₂,M₅,M₄,M₃</th>
<th>[VRR-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>E7</td>
<td>V₁,V₂,M₅,M₄,M₃</td>
<td>RXB: &quot;C3&quot;</td>
</tr>
</tbody>
</table>
VECTOR FP CONVERT FROM FIXED 64-BIT

The signed binary integer doubleword element or elements of the second operand are converted to a long-format binary floating-point number. The results are placed in the corresponding element or elements of the first-operand location.

The M₃ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M₄ field has the following format:

```
S X C
0 1 2 3
```

The bits of the M₄ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **IEEE-inexact-exception control (XxC):** Bit 1 of the M₄ field is the XxC bit. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

- **Reserved:** Bits 2 and 3 are reserved and must contain zeros otherwise a specification is recognized.

The converted result is rounded by the rounding method as specified by the modifier in the M₅ field:

<table>
<thead>
<tr>
<th>M₅</th>
<th>Effective Rounding Method</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>According to current BFP rounding mode</td>
</tr>
<tr>
<td>1</td>
<td>Round to nearest with ties away from 0</td>
</tr>
<tr>
<td>3</td>
<td>Round to prepare for shorter precision</td>
</tr>
<tr>
<td>4</td>
<td>Round to nearest with ties to even</td>
</tr>
<tr>
<td>5</td>
<td>Round toward 0</td>
</tr>
<tr>
<td>6</td>
<td>Round toward +∞</td>
</tr>
<tr>
<td>7</td>
<td>Round toward −∞</td>
</tr>
</tbody>
</table>

An M₅ modifier other than 0, 1, or 3-7 is invalid. The M₅ field must designate a valid modifier; otherwise, a specification exception is recognized.

When the M₅ modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

See Figure 24-8 on page 24-15 for a detailed description of the results for each element.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**

- Inexact

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCDGB V₁,V₂,M₄,M₅</td>
<td>VCDG V₁,V₂,3,M₄,M₅</td>
</tr>
<tr>
<td>WCDGB V₁,V₂,M₃,M₅</td>
<td>VCDG V₁,V₂,3,(8</td>
</tr>
</tbody>
</table>
The unsigned binary integer doubleword element or elements in the second operand are converted to long-format binary floating-point number. The results are placed in the corresponding element or elements of the first-operand location.

The M₃ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M₄ field has the following format:

The bits of the M₄ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **IEEE-inexact-exception control (XxC):** Bit 1 of the M₄ field is the XxC bit. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.
**Reserved:** Bits 2 and 3 are reserved and must contain zeros otherwise a specification is recognized.

The converted result is rounded by the rounding method as specified by the modifier in the M₅ field:

M₅ Effective Rounding Method
0  According to current BFP rounding mode
1  Round to nearest with ties away from 0
3  Round to prepare for shorter precision
4  Round to nearest with ties to even
5  Round toward 0
6  Round toward +∞
7  Round toward -∞

An M₅ modifier other than 0, 1, or 3-7 is invalid. The M₅ field must designate a valid modifier; otherwise, a specification exception is recognized.

When the M₅ modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

See Figure 24-8 on page 24-15 for a detailed description of the results for each element.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Inexact

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCDLGB</td>
<td>V₁, V₂, M₄, M₅</td>
</tr>
<tr>
<td>WCDLGB</td>
<td>V₁, V₂, M₄, M₅</td>
</tr>
</tbody>
</table>

**VECToR FP CONVERT TO FIXED 64-BIT**

<table>
<thead>
<tr>
<th>VCGD</th>
<th>V₁, V₂, M₃, M₄, M₅</th>
<th>[VRR-a]</th>
</tr>
</thead>
<tbody>
<tr>
<td>'E7'</td>
<td>V₁, V₂</td>
<td></td>
</tr>
<tr>
<td></td>
<td>M₃, M₄</td>
<td>'C2'</td>
</tr>
</tbody>
</table>

The BFP long-format floating-point element or elements of the second operand are rounded to an integer value and then converted to the fixed-point format. The doubleword signed binary integer result is placed in the corresponding element of the first-operand location.

If the second operand element is a finite number, it is rounded to an integer value by the rounding method as specified by the modifier in the M₅ field:

M₅ Effective Rounding Method
0  According to current BFP rounding mode
1  Round to nearest with ties away from 0
3  Round to prepare for shorter precision
4  Round to nearest with ties to even
5  Round toward 0
6  Round toward +∞
7  Round toward -∞

An M₅ modifier other than 0, 1, or 3-7 is invalid. The M₅ field must designate a valid modifier; otherwise, a specification exception is recognized.

When the M₅ modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

The sign of the result is the sign of the second operand element, except that a zero result has a plus sign.

See Figure 24-9 on page 24-17 for a detailed description of the results for each element.

The M₃ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.
The $M_4$ field has the following format:

$$
\begin{array}{c|c|c|c}
X & S & x & C \\
0 & 1 & 2 & 3 \\
\end{array}
$$

The bits of the $M_4$ field are defined as follows:

- **Single-Element-Control ($S$):** If bit 0 of the $M_4$ field is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **IEEE-inexact-exception control ($XxC$):** Bit 1 of the $M_4$ field is the $XxC$ bit. If $XxC$ is zero, recognition of IEEE-inexact exception is not suppressed; if $XxC$ is one, recognition of IEEE-inexact exception is suppressed.

- **Reserved:** Bits 2 and 3 are reserved and must contain zeros otherwise a specification is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Inexact
- Invalid operation

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCGDB</td>
<td>V1,V2,M4,M5</td>
</tr>
<tr>
<td>WCGDB</td>
<td>V1,V2,M4,M5</td>
</tr>
<tr>
<td></td>
<td>V1,V2,3(M4),M5</td>
</tr>
</tbody>
</table>

**Operand Element (a)**

<table>
<thead>
<tr>
<th>Operand Element (a)</th>
<th>Is n Inexact (n≠0)</th>
<th>Inv.-Op. Mask (FPC 0.0)</th>
<th>IEEE Inexact Exception Control (XxC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>$-\infty &lt; a &lt; MN, n &lt; MN$</td>
<td>−</td>
<td>0</td>
<td>1</td>
<td>−</td>
<td>T(MN), SFi−1</td>
</tr>
<tr>
<td>$-\infty &lt; a &lt; MN, n &lt; MN$</td>
<td>−</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(MN), SFi−1, SFx−1</td>
</tr>
<tr>
<td>$-\infty &lt; a &lt; MN, n &lt; MN$</td>
<td>−</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>PIV(5)</td>
</tr>
<tr>
<td>$-\infty &lt; a &lt; MN, n &lt; MN$</td>
<td>−</td>
<td>1</td>
<td>−</td>
<td>−</td>
<td>PIV(1)</td>
</tr>
<tr>
<td>$MN \leq a &lt; 0$</td>
<td>No</td>
<td>−</td>
<td>−</td>
<td>−</td>
<td>T(f)</td>
</tr>
<tr>
<td>$MN \leq a &lt; 0$</td>
<td>Yes</td>
<td>−</td>
<td>1</td>
<td>−</td>
<td>T(f)</td>
</tr>
<tr>
<td>$MN \leq a &lt; 0$</td>
<td>Yes</td>
<td>−</td>
<td>0</td>
<td>0</td>
<td>T(f), SFx−1</td>
</tr>
<tr>
<td>$MN \leq a &lt; 0$</td>
<td>Yes</td>
<td>−</td>
<td>0</td>
<td>1</td>
<td>PIV(5)</td>
</tr>
<tr>
<td>$-0$</td>
<td>No</td>
<td>−</td>
<td>−</td>
<td>−</td>
<td>T(0)</td>
</tr>
<tr>
<td>$+0$</td>
<td>No</td>
<td>−</td>
<td>−</td>
<td>−</td>
<td>T(0)</td>
</tr>
<tr>
<td>$0 &lt; a \leq MP$</td>
<td>No</td>
<td>−</td>
<td>−</td>
<td>−</td>
<td>T(f)</td>
</tr>
<tr>
<td>$0 &lt; a \leq MP$</td>
<td>Yes</td>
<td>−</td>
<td>1</td>
<td>−</td>
<td>T(f)</td>
</tr>
<tr>
<td>$0 &lt; a \leq MP$</td>
<td>Yes</td>
<td>−</td>
<td>0</td>
<td>0</td>
<td>T(f), SFx−1</td>
</tr>
<tr>
<td>$0 &lt; a \leq MP$</td>
<td>Yes</td>
<td>−</td>
<td>0</td>
<td>1</td>
<td>T(f), PIV(5)</td>
</tr>
<tr>
<td>$MP &lt; a \leq +\infty, n &gt; MP$</td>
<td>−</td>
<td>0</td>
<td>1</td>
<td>−</td>
<td>T(MP), SFi−1</td>
</tr>
<tr>
<td>$MP &lt; a \leq +\infty, n &gt; MP$</td>
<td>−</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(MP), SFi−1, SFx−1</td>
</tr>
<tr>
<td>$MP &lt; a \leq +\infty, n &gt; MP$</td>
<td>−</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>PIV(5)</td>
</tr>
</tbody>
</table>

**Figure 24-9. Results: VECTOR FP CONVERT TO FIXED 64**
VECTOR FP CONVERT TO LOGICAL 64-BIT

VCLGD V1,V2,M3,M4,M5 [VRR-a]

<table>
<thead>
<tr>
<th>Operand Element (a)</th>
<th>Is n Inexact (n=a)</th>
<th>Inv.-Op. Mask (FPC 0.0)</th>
<th>IEEE Inexact Exception Control (XxC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>MP &lt; a ≤ +∞, n &gt; MP</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>PIV(1)</td>
</tr>
<tr>
<td>NaN</td>
<td>–</td>
<td>0</td>
<td>1</td>
<td>–</td>
<td>T(MN), SFi←1</td>
</tr>
<tr>
<td>NaN</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>T(MN), SFi←1, SFx+1</td>
</tr>
<tr>
<td>NaN</td>
<td>–</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>PIV(5)</td>
</tr>
</tbody>
</table>

Explanation:

– The results do not depend on this condition or mask bit.
1 This condition is true by virtue of the state of some condition to the left of this column.
f The value n converted to a fixed-point result.
n The value derived when the source value (a) is rounded to a floating-point integer using the effective rounding method.
MN Maximum negative number representable in the target fixed-point format.
MP Maximum positive number representable in the target fixed-point format.
PIV(h) Program interruption for vector-processing exception with VXC containing the element index and a VIC of h in hex.
SFi IEEE invalid-operation flag, FPC 1.0.
SFx IEEE inexact flag, FPC 1.4.
T(x) The value x is placed at the target operand element location if no trapping exceptions on other elements.

Figure 24-9. Results: VECTOR FP CONVERT TO FIXED 64 (Continued)

VECTOR FP CONVERT TO LOGICAL 64-BIT

The BFP long-format floating-point element or elements of the second operand are rounded to an integer value and then converted to the fixed-point format. The doubleword unsigned binary integer result is placed in the corresponding element of the first-operand location.

If the second operand element is a finite number, it is rounded to an integer value by the rounding method as specified by the modifier in the M5 field:

M5 Effective Rounding Method

0 According to current BFP rounding mode
1 Round to nearest with ties away from 0
3 Round to prepare for shorter precision
4 Round to nearest with ties to even
5 Round toward 0
6 Round toward +∞
7 Round toward -∞

An M5 modifier other than 0, 1, or 3-7 is invalid. The M5 field must designate a valid modifier; otherwise, a specification exception is recognized.

When the M5 modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

The sign of the result is the sign of the second operand element, except that a zero result has a plus sign.

See Figure 24-10 on page 24-20 for a detailed description of the results for each element.

The M5 field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.
The M₄ field has the following format:

```
X
S x x C
0 1 2 3
```

The bits of the M₄ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **IEEE-inexact-exception control (XxC):** Bit 1 of the M₄ field is the XxC bit. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

- **Reserved:** Bits 2 and 3 are reserved and must contain zeros otherwise a specification is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Inexact
- Invalid operation

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VCLGDB V₁, V₂, M₄, M₅</td>
<td>VCLGD V₁, V₂, 3, M₄, M₅</td>
</tr>
<tr>
<td>WCLGDB V₁, V₂, M₄, M₅</td>
<td>VCLGD V₁, V₂, 3, (8 + M₄), M₅</td>
</tr>
</tbody>
</table>
### VECTOR FP DIVIDE

**Operand Element (a)**

<table>
<thead>
<tr>
<th>Is n Inexact</th>
<th>Inv.-Op. Mask (FPC 0.0)</th>
<th>IEEE Inexact Exception Control (XxC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>&lt;\infty &lt; a &lt; 0, n &gt; 0</td>
<td>–</td>
<td>0</td>
<td>1</td>
<td>–</td>
</tr>
<tr>
<td>&lt;\infty &lt; a &lt; 0, n &gt; 0</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>&lt;\infty &lt; a &lt; 0, n &gt; 0</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>&lt;\infty &lt; a &lt; 0, n = 0</td>
<td>–</td>
<td>1</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>&lt;\infty &lt; a &lt; 0, n = 0</td>
<td>–</td>
<td>–</td>
<td>1</td>
<td>–</td>
</tr>
<tr>
<td>&lt;\infty &lt; a &lt; 0, n = 0</td>
<td>–</td>
<td>–</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>&lt;\infty &lt; a &lt; 0, n = 0</td>
<td>–</td>
<td>–</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>-0</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>+0</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>0 &lt; a ≤ MU</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>0 &lt; a &lt; MU</td>
<td>Yes</td>
<td>–</td>
<td>1</td>
<td>–</td>
</tr>
<tr>
<td>0 &lt; a ≤ MU</td>
<td>Yes</td>
<td>–</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>MU &lt; a ≤ +\infty, n &gt; MU</td>
<td>–</td>
<td>0</td>
<td>1</td>
<td>–</td>
</tr>
<tr>
<td>MU &lt; a ≤ +\infty, n &gt; MU</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>MU &lt; a ≤ +\infty, n &gt; MU</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>MU &lt; a ≤ +\infty, n &gt; MU</td>
<td>–</td>
<td>1</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>NaN</td>
<td>–</td>
<td>0</td>
<td>1</td>
<td>–</td>
</tr>
<tr>
<td>NaN</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>NaN</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>NaN</td>
<td>–</td>
<td>1</td>
<td>–</td>
<td>–</td>
</tr>
</tbody>
</table>

**Explanations:**

- The results do not depend on this condition or mask bit.
- This condition is true by virtue of the state of some condition to the left of this column.
- The value n converted to a fixed-point result.
- The value derived when the source value (a) is rounded to a floating-point integer using the effective rounding method.
- Maximum unsigned number representable in the target fixed-point format.
- Program interruption for vector-processing exception with VXC containing the element index and a VIC of h in hex.
- IEEE invalid-operation flag, FPC 1.0.
- IEEE inexact flag, FPC 1.4.
- The value x is placed at the target operand element location if no trapping exceptions on other elements.

**Figure 24-10. Results: VECTOR FP CONVERT TO LOGICAL 64-BIT**

**VECTOR FP DIVIDE**

<table>
<thead>
<tr>
<th>VFD</th>
<th>V1</th>
<th>V2</th>
<th>V3</th>
<th>M5</th>
<th>M4</th>
<th>RXB</th>
<th>‘E5’</th>
</tr>
</thead>
<tbody>
<tr>
<td>E7</td>
<td>0</td>
<td>8</td>
<td>12</td>
<td>16</td>
<td>20</td>
<td>28</td>
<td>32</td>
</tr>
</tbody>
</table>

The element or elements of the second operand (the dividend) are divided by the corresponding element or elements in the third operand (the divisor), and the quotient or quotients are placed at the corresponding elements in first-operand location. No remainder is preserved.
If the divisor is nonzero and both the dividend and divisor are finite numbers, the second operand element is divided by the third operand element to form an intermediate quotient. The intermediate quotient, if nonzero, is rounded to the target format according to the current BFP rounding mode.

When the dividend is a finite number and the divisor is infinity, the result is zero.

The sign of the quotient, if the quotient is numeric, is the exclusive or of the corresponding operand element signs. This includes the sign of a zero or infinite quotient.

If the divisor is zero but the dividend is a finite number, an IEEE-division-by-zero exception is recognized. If the dividend and divisor are both zero, or if both are infinity, regardless of sign, an IEEE-invalid-operation exception is recognized.

See Figure 24-11 on page 24-22 for a detailed description of the results of each element.

The M₄ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M₅ field has the following format:

```
S / / / 0 1 3
```

The bits of the M₅ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **Reserved:** Bits 1 to 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**

- Invalid operation
- Division by zero
- Overflow
- Underflow
- Inexact

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFDB</td>
<td>V₁,V₂,V₃</td>
</tr>
<tr>
<td>WFDB</td>
<td>V₁,V₂,V₃</td>
</tr>
</tbody>
</table>

24-21
**VECTOR LOAD FP INTEGER**

<table>
<thead>
<tr>
<th>Dividend Element (a)</th>
<th>Results for DIVIDE (a+b) when Divisor Element (b) Is</th>
</tr>
</thead>
<tbody>
<tr>
<td>~( \infty )</td>
<td>X: T(dNaN)</td>
</tr>
<tr>
<td>-( \infty )</td>
<td>T(+0)</td>
</tr>
<tr>
<td>-0</td>
<td>T(+0)</td>
</tr>
<tr>
<td>+0</td>
<td>T(-0)</td>
</tr>
<tr>
<td>+( \infty )</td>
<td>X: T(dNaN)</td>
</tr>
<tr>
<td>QNaN</td>
<td>T(a)</td>
</tr>
<tr>
<td>SNaN</td>
<td>X: T(a')</td>
</tr>
</tbody>
</table>

**Explanation:**

* The SNaN is converted to the corresponding QNaN before it is placed at the target operand location.
* F\( n \) Finite nonzero number (includes both subnormal and normal).
* R(v) Rounding and range action is performed on the value \( v \). See Figure 24-4 on page 24-6.
* T(x) The value \( x \) is placed at the target operand element location if no trapping exceptions on other elements.
* Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.
* Xz: IEEE division-by-zero exception. The results shown are produced only when FPC 0.1 is zero.

**Figure 24-11. Results: DIVIDE**

When the M5 modifier field is zero, rounding is controlled by the current BFP rounding mode in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

In the absence of an interruption, if the second operand element is an infinity or a QNaN, the result is that operand element; if the second operand element is an SNaN, the result is the corresponding QNaN.

The sign of the result is the sign of the second operand element, even when the result is zero.

The M3 field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M4 field has the following format:

```
0 1 2 3
```

The bits of the M4 field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-
indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **IEEE-inexact-exception control (XxC):** Bit 1 of the M₄ field is the XxC bit. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

- **Reserved:** Bits 2 and 3 are reserved and must contain zeros otherwise a specification is recognized.

See Figure 24-12 on page 24-24 for a detailed description of the results for each element.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid operation
- Inexact

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Programming Notes:**

1. VECTOR LOAD FP INTEGER rounds BFP numbers to an integer values. These integers, which remain in the BFP format, should not be confused with binary integers, which have a fixed-point format.

2. If the BFP operand element is a finite number with a large enough exponent so that it is already an integer, the result value remains the same.

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFIDB V₁, V₂, M₄, M₅</td>
<td>VFI V₁, V₂, 3, M₄, M₅</td>
</tr>
<tr>
<td>WFIDB V₁, V₂, M₄, M₅</td>
<td>VFI V₁, V₂, 3, 8(M₄), M₅</td>
</tr>
</tbody>
</table>
## VECTOR FP LOAD LENGTHENED

<table>
<thead>
<tr>
<th>Operand Element (a)</th>
<th>Is n Inexact (nna)</th>
<th>Inv.-Op. Mask (FPC 0.0)</th>
<th>IEEE Inexact Exception Control (XxC)</th>
<th>Inexact Mask (FPC 0.4)</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>T(−∞)</td>
</tr>
<tr>
<td>-Fn</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>T(n)</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>–</td>
<td>1</td>
<td>–</td>
<td>T(n)</td>
</tr>
<tr>
<td>-Fn</td>
<td>Yes</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>T(n), SFx←1</td>
</tr>
<tr>
<td>-0</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>T(0)</td>
</tr>
<tr>
<td>+0</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>T(+0)</td>
</tr>
<tr>
<td>+Fn</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>T(n)</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>–</td>
<td>1</td>
<td>–</td>
<td>T(n)</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>–</td>
<td>0</td>
<td>0</td>
<td>T(n), SFx←1</td>
</tr>
<tr>
<td>+Fn</td>
<td>Yes</td>
<td>–</td>
<td>0</td>
<td>1</td>
<td>PIV(5)</td>
</tr>
<tr>
<td>+∞</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>T(∞)</td>
</tr>
<tr>
<td>QNaN</td>
<td>No</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>T(a)</td>
</tr>
<tr>
<td>SNaN</td>
<td>No</td>
<td>0</td>
<td>–</td>
<td>–</td>
<td>T(a*), SFx←1</td>
</tr>
<tr>
<td>SNaN</td>
<td>No</td>
<td>1</td>
<td>–</td>
<td>–</td>
<td>PIV(1)</td>
</tr>
</tbody>
</table>

**Explanation:**
- The results do not depend on this condition or mask bit.
- * The SNaN is converted to the corresponding QNaN before it is placed at the target operand element location.
- 1 This condition is true by virtue of the state of some condition to the left of this column.
- n The value derived when the source value, a, is rounded to a floating-point integer using the effective rounding mode.
- Fn Finite nonzero number (includes both subnormal and normal).
- PIV(h) Program interruption for vector-processing exception, with a VXC containing the element index and a VIC of h in hex.
- SFi IEEE invalid-operation flag, FPC 1.0.
- SFx IEEE inexact flag, FPC 1.4.
- T(x) The value x is placed at the target operand element location if no trapping exceptions on other elements.

---

**VECTOR FP LOAD LENGTHENED**

When the second operand element is a finite number, the value of the second operand element is placed in the target format. The exponent of the second operand element is converted to the corresponding exponent in the result format, and the fraction is extended by appending zeros on the right.

If the second operand element is an infinity, the result is an infinity of the same sign. If the second operand element is an SNaN, an IEEE-invalid-operation exception is recognized; if there is no interruption, the result is the corresponding QNaN with the fraction extended.

---

The leftmost word-sized sub-element of each doubleword element or elements of the second operand containing short-format BFP numbers are converted to long-format BFP numbers, and the results are placed at the corresponding doubleword elements in the first-operand.
The sign of the result is the same as the sign of the source.

See Figure 24-8 on page 24-15 for a detailed description of the results for each element.

The M₃ field must contain a value of two, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M₄ field has the following format:

```
  S  | 0 | 1 | 2 | 3
```

The bits of the M₄ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **Reserved:** Bits 1 to 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**

- **Invalid operation**

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VLDEB V₁,V₂</td>
<td>VLDE V₁,V₂,2,0</td>
</tr>
<tr>
<td>WLDEB V₁,V₂</td>
<td>VLDE V₁,V₂,2,8</td>
</tr>
</tbody>
</table>

**VECTOR FP LOAD ROUNDED**

The elements of the second operand, are rounded to the precision of the next smallest element size, and the result is placed at the corresponding even elements in the first-operand location. The data in the odd elements of the first operand is unpredictable. Elements of the second operand are long-format BFP numbers.

The sign of the resulting element or elements is the same as the corresponding element of the second operand.

The second operand element, if a finite number, is rounded by the rounding method as specified by the modifier in the M₅ field:

- **M₅ Effective Rounding Method**
  - 0 According to current BFP rounding mode
  - 1 Round to nearest with ties away from 0
  - 3 Round to prepare for shorter precision
  - 4 Round to nearest with ties to even
  - 5 Round toward 0
  - 6 Round toward +∞
  - 7 Round toward −∞

An M₅ modifier other than 0, 1, or 3-7 is invalid. The M₅ field must designate a valid modifier; otherwise, a specification exception is recognized.

When the M₅ modifier field is zero, rounding is controlled by the current BFP rounding mode specified in the FPC register. When the field is not zero, rounding is performed as specified by the modifier, regardless of the current BFP rounding mode.

See Figure 24-8 on page 24-15 for a detailed description of the results for each element.

The M₃ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.
VECTOR FP MULTIPLY

The M4 field has the following format:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **IEEE-inexact-exception control (XxC):** Bit 1 of the M4 field is the XxC bit. If XxC is zero, recognition of IEEE-inexact exception is not suppressed; if XxC is one, recognition of IEEE-inexact exception is suppressed.

- **Reserved:** Bits 2 and 3 are reserved and must contain zeros otherwise a specification is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**
- Invalid operation
- Overflow
- Underflow
- Inexact

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

**Programming Note:** The sign of the rounded result is the same as the sign of the operand element, even when the result is zero.

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>WLEDB V1,V2,M4,M5</td>
<td>VLED V1,V2,3,(8</td>
</tr>
</tbody>
</table>

The product of the element or elements of the second operand (the multiplier) and the corresponding element or elements of the third operand (the multiplicand) are placed in the corresponding element or elements of the first operand. The second and third operand elements contain long-format BFP numbers.

The two corresponding operand elements, if finite numbers, are multiplied, forming an intermediate product. The result is rounded to the operand format according to the current BFP rounding mode.

The sign of the product, if the product is numeric, is the exclusive OR of the operand element signs. This includes the sign of a zero or infinite product.

If one operand element is a zero and the other an infinity, an IEEE-invalid-operation exception is recognized.

See Figure 24-13 on page 24-27 for a detailed description of the results for each element.

The M5 field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M5 field has the following format:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.
Reserved: Bits 1 to 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

IEEE Exceptions:
- Invalid operation
- Overflow
- Underflow
- Inexact

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification

Extended Mnemonics:

Extended Mnemonic Base Mnemonic
VFMB V1,V2,V3 VFM V1,V2,V3,3,0
WFMB V1,V2,V3 VFM V1,V2,V3,3,8

Programming Note: Interchanging the two operand elements in a BFP multiplication does not affect the value of the product when the result is numeric. This is not true, however, when both operand elements are QNaNs, in which case the result is the second operand element; or when both operand elements are SNaNs and the IEEE-invalid-operation mask bit in the FPC register is zero, in which case the result is the QNaN derived from the second operand element.

Extended Mnemonics:

VFMA V1,V2,V3,V4,M5,M6 [VRR-e]
VFMS V1,V2,V3,V4,M5,M6 [VRR-e]

Results for VECTOR FP MULTIPLY (a•b) when Third Operand Element (b) Is

<table>
<thead>
<tr>
<th>Second Operand Element (a) Is</th>
<th>-∞</th>
<th>-Fn</th>
<th>-0</th>
<th>+0</th>
<th>+Fn</th>
<th>+∞</th>
<th>QNaN</th>
<th>SNaN</th>
</tr>
</thead>
<tbody>
<tr>
<td>-∞</td>
<td>T(+∞)</td>
<td>T(+∞)</td>
<td>Xi: T(dNaN)</td>
<td>Xi: T(dNaN)</td>
<td>T(−∞)</td>
<td>T(−∞)</td>
<td>T(b)</td>
<td>Xi: T(b*)</td>
</tr>
<tr>
<td>-Fn</td>
<td>T(+∞)</td>
<td>R(a•b)</td>
<td>T(+0)</td>
<td>T(−0)</td>
<td>R(a•b)</td>
<td>T(−∞)</td>
<td>T(b)</td>
<td>Xi: T(b*)</td>
</tr>
<tr>
<td>-0</td>
<td>Xi: T(dNaN)</td>
<td>T(+0)</td>
<td>T(−0)</td>
<td>T(−0)</td>
<td>Xi: T(dNaN)</td>
<td>T(b)</td>
<td>Xi: T(b*)</td>
<td></td>
</tr>
<tr>
<td>+0</td>
<td>Xi: T(dNaN)</td>
<td>T(−0)</td>
<td>T(−0)</td>
<td>T(+0)</td>
<td>Xi: T(dNaN)</td>
<td>T(b)</td>
<td>Xi: T(b*)</td>
<td></td>
</tr>
<tr>
<td>+Fn</td>
<td>T(−∞)</td>
<td>R(a•b)</td>
<td>T(−0)</td>
<td>T(+0)</td>
<td>R(a•b)</td>
<td>T(+∞)</td>
<td>T(b)</td>
<td>Xi: T(b*)</td>
</tr>
<tr>
<td>+∞</td>
<td>T(+∞)</td>
<td>T(−∞)</td>
<td>Xi: T(dNaN)</td>
<td>Xi: T(dNaN)</td>
<td>T(+∞)</td>
<td>T(+∞)</td>
<td>T(b)</td>
<td>Xi: T(b*)</td>
</tr>
<tr>
<td>QNaN</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>T(a)</td>
<td>Xi: T(b*)</td>
</tr>
<tr>
<td>SNaN</td>
<td>Xi: T(a*)</td>
<td>Xi: T(a*)</td>
<td>Xi: T(a*)</td>
<td>Xi: T(a*)</td>
<td>Xi: T(a*)</td>
<td>Xi: T(a*)</td>
<td>Xi: T(a*)</td>
<td>Xi: T(a*)</td>
</tr>
</tbody>
</table>

Explanation:
* The SNaN is converted to the corresponding QNaN before it is placed at the target operand element location.

dNaN Default NaN.
Fn Finite nonzero number (includes both subnormal and normal).
R(v) Rounding and range action is performed on the value v. See Figure 24-4 on page 24-6.
T(x) The value x is placed at the target operand element location if no trapping exceptions on other elements.
Xi: IEEE invalid-operation exception. The results shown are produced only when FPC 0.0 is zero.

Figure 24-13. Results: VECTOR FP MULTIPLY

VECTOR FP MULTIPLY AND ADD

VFMA V1,V2,V3,V4,M5,M6 [VRR-e]

VECTOR FP MULTIPLY AND SUBTRACT

VFMS V1,V2,V3,V4,M5,M6 [VRR-e]

The element or elements of the third operand are multiplied by the corresponding element or elements.
of the second operand, and then the corresponding
element or elements of the fourth operand are added
to or subtracted from the products. The sum or differ-
ences are placed at the corresponding first-operand
element locations. All operand elements contain
long-format BFP numbers. The VECTOR FP MULTI-
PLY AND ADD and VECTOR FP MULTIPLY AND
SUBTRACT operations may be summarized as fol-

gows, where “(i)” represents the “i”th indexed element
of the operand:

\[
\text{op}_1(i) = \text{op}_2(i) \cdot \text{op}_3(i) \pm \text{op}_4(i)
\]

When all of the corresponding operand elements are
finite numbers, the third and second BFP operand
elements are multiplied, forming an intermediate
product, and the corresponding first operand element
is then added (or subtracted) algebraically to (or
from) the intermediate product, forming an interme-
diate sum. The intermediate sum, if nonzero, is
rounded to the operand format according to the cur-
cent BFP rounding mode and then placed at the cor-
responding element of the first-operand location. The
exponent and fraction of the intermediate product are
maintained exactly; rounding and range checking
occur only on the intermediate sum.

See Figure 24-14 for a detailed description of the
results for each element of VECTOR FP MULTIPLY
AND ADD. The results for each element of VECTOR
FP MULTIPLY AND SUBTRACT are the same,
except that the fourth operand element, if numeric,
participates in the operation with its sign bit inverted.
When the fourth operand element is a NaN, it partici-
pates in the operation with its sign bit unchanged.

The \( M_6 \) field must contain a value of three, all other
values are reserved. If a reserved value is specified,
a specification exception is recognized.

The \( M_5 \) field has the following format:

\[
\begin{array}{c}
\text{S} \\
0 \ 1 \ 3
\end{array}
\]

The bits of the \( M_5 \) field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to
  one, the operation takes place only on the zero-
  indexed element in the vector. In the absence of
  a trapping exception condition, the bit positions
  of all other elements in the first operand vector are
  unpredictable. If bit 0 is set to zero, the
  operation occurs on all elements in the vector.

- **Reserved:** Bits 1 to 3 are reserved and must be
  zero. Otherwise, a specification exception is rec-
  ognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:**

- Invalid operation
- Overflow
- Underflow
- Inexact

**Program Exceptions:**

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture
  is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception
  and element index

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>( VFMADB ) ( V_1, V_2, V_3, V_4 )</td>
<td>( VFMA ) ( V_1, V_2, V_3, 0, 3 )</td>
</tr>
<tr>
<td>( WFMADB ) ( V_1, V_2, V_3, V_4 )</td>
<td>( VFMA ) ( V_1, V_2, V_3, V_4, 8, 3 )</td>
</tr>
<tr>
<td>( VFMSDB ) ( V_1, V_2, V_3, V_4 )</td>
<td>( VFMS ) ( V_1, V_2, V_3, 0, 3 )</td>
</tr>
<tr>
<td>( WFMSDB ) ( V_1, V_2, V_3, V_4 )</td>
<td>( VFMS ) ( V_1, V_2, V_3, V_4, 8, 3 )</td>
</tr>
</tbody>
</table>

**Programming Note:** VECTOR FP MULTIPLY AND
ADD and VECTOR FP MULTIPLY AND SUBTRACT
produce a precise intermediate value, and a single
rounding operation is performed after the addition or
subtraction. This definition is consistent with the
Power architecture, and, in certain applications, can
be used to great advantage, especially in algorithms
used in math libraries.
The sign of the element or elements of the second operand are modified in a manner specified by the value of the M5 field. The modified sign bit and the rest of the unchanged second operand element are placed into the corresponding element in the first operand. All operand elements contain long-format BFP numbers.

The sign operation is performed even if the element contains zero. If the element contains a QNaN or SNaN, the sign is still set without causing an IEEE exception.

The M5 field indicates the operation to perform on the sign bit.

<table>
<thead>
<tr>
<th>M5</th>
<th>Sign Operation Performed</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The sign bit is inverted (complement)</td>
</tr>
<tr>
<td>1</td>
<td>The sign bit is set to one (negative)</td>
</tr>
<tr>
<td>2</td>
<td>The sign bit is set to zero (positive)</td>
</tr>
</tbody>
</table>
If any other $M_3$ values are specified, a specification exception is recognized.

The $M_3$ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The $M_4$ field has the following format:

```
S 1 3
```

The bits of the $M_4$ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. The bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.
- **Reserved:** Bits 1 to 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.

**IEEE Exceptions:** None

**Program Exceptions:**
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

**Extended Mnemonics:**

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFPSODB $V_1,V_2,M_5$</td>
<td>VFPSO $V_1,V_2,3,0,M_5$</td>
</tr>
<tr>
<td>WFPSODB $V_1,V_2,M_5$</td>
<td>VFPSO $V_1,V_2,3,8,M_5$</td>
</tr>
<tr>
<td>VFLCDB $V_1,V_2$</td>
<td>VFPSO $V_1,V_2,3,0,0$</td>
</tr>
<tr>
<td>WFLCDB $V_1,V_2$</td>
<td>VFPSO $V_1,V_2,3,8,0$</td>
</tr>
<tr>
<td>VFLNDB $V_1,V_2$</td>
<td>VFPSO $V_1,V_2,3,0,1$</td>
</tr>
<tr>
<td>WFLNDB $V_1,V_2$</td>
<td>VFPSO $V_1,V_2,3,8,1$</td>
</tr>
<tr>
<td>VFLPDB $V_1,V_2$</td>
<td>VFPSO $V_1,V_2,3,0,2$</td>
</tr>
<tr>
<td>WFLPDB $V_1,V_2$</td>
<td>VFPSO $V_1,V_2,3,8,2$</td>
</tr>
</tbody>
</table>

**VECTOR FP SQUARE ROOT**

```
<table>
<thead>
<tr>
<th>VFSQ</th>
<th>$V_1,V_2,M_3,M_4$</th>
</tr>
</thead>
<tbody>
<tr>
<td>VRR-a</td>
<td></td>
</tr>
</tbody>
</table>
```

The square roots of each element of the second operand are placed at the corresponding elements of the first-operand location. All operand elements contain long-format BFP numbers.

The result rounded according to the current BFP rounding mode is placed at the first operand element location.

If the second operand element is a positive finite number, the result is the square root of that number with a plus sign. If the operand element is a zero of either sign, the result is a zero of the same sign. If the operand element is $+\infty$, the result is $+\infty$.

If the second operand element is less than zero, an IEEE-invalid-operation exception is recognized.

See Figure 24-8 on page 24-15 for a detailed description of the results for each element.

The $M_3$ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The $M_4$ field has the following format:

```
S 1 3
```

The bits of the $M_4$ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.
- **Reserved:** Bits 1 to 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

**Condition Code:** The code remains unchanged.
IEEE Exceptions:
- Invalid operation
- Inexact

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFSQDB V1,V2</td>
<td>VFSQ V1,V2,3,0</td>
</tr>
<tr>
<td>WFSQDB V1,V2</td>
<td>VFSQ V1,V2,3,8</td>
</tr>
</tbody>
</table>

VECTOR FP SUBTRACT

VFS V1,V2,V3,M4,M5 [VRR-c]

The floating-point element or elements in the third operand are subtracted from the floating-point element or elements of the second operand, and the difference is placed in the floating-point element or elements at the first-operand location. All operand elements contain long-format BFP numbers.

The execution of VECTOR FP SUBTRACT is identical to that of VECTOR FP ADD, except that the third operand element, if numeric, participates in the operation with its sign bit inverted. When the third operand contains an element that is a NaN, it participates in the operation with its sign bit unchanged. See Figure 24-3 on page 24-5 for the detailed results for each element of VECTOR FP ADD.

The M4 field must contain a value of three, all other values are reserved. If a reserved value is specified a specification exception is recognized.

The M5 field has the following format:

<table>
<thead>
<tr>
<th>S</th>
<th>S</th>
<th>S</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>3</td>
</tr>
</tbody>
</table>

The bits of the M5 field are defined as follows:

- Single-Element-Control (S): If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. In the absence of a trapping exception condition, the bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.
- Reserved: Bits 1 to 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

Condition Code: The code remains unchanged.

IEEE Exceptions:
- Invalid operation
- Overflow
- Underflow
- Inexact

Program Exceptions:
- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint
- Vector processing with VXC for IEEE exception and element index

Extended Mnemonics:

<table>
<thead>
<tr>
<th>Extended Mnemonic</th>
<th>Base Mnemonic</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFSQDB V1,V2,V3</td>
<td>VFS V1,V2,V3,3,0</td>
</tr>
<tr>
<td>WFSQDB V1,V2,V3</td>
<td>VFS V1,V2,V3,3,8</td>
</tr>
</tbody>
</table>

VECTOR FP TEST DATA CLASS IMMEDIATE

VFTCI V1,V2,I3,M5 [VRRI-e]

The class and sign of the floating-point element or elements of the second operand are examined to select one bit from the third-operand. If the selected bit is set, all bit positions of the corresponding element in the first operand are set to ones, otherwise...
they are set to zero. All operand elements contain long-format BFP numbers.

The 12 bits of the third operand, bits 16-27 of the instruction text, are used to specify 12 combinations of BFP data class and sign.

As shown in Figure 24-15, BFP operand elements are divided into six classes: zero, normal number, subnormal number, infinity, quiet NaN, and signaling NaN.

One or more of the third-operand bits may be set to one.

Operand elements, including SNaNs and QNaNs, are examined without causing an IEEE exception.

The M₄ field must contain a value of three, all other values are reserved. If a reserved value is specified, a specification exception is recognized.

The M₅ field has the following format:

![Table of BFP Element Class and Bit Used](image)

The bits of the M₅ field are defined as follows:

- **Single-Element-Control (S):** If bit 0 is set to one, the operation takes place only on the zero-indexed element in the vector. The bit positions of all other elements in the first operand vector are unpredictable. If bit 0 is set to zero, the operation occurs on all elements in the vector.

- **Reserved:** Bits 1 to 3 are reserved and must be zero. Otherwise, a specification exception is recognized.

### Resulting Condition Code:

- 0: Selected bit is 1 for all elements (match)
- 1: Selected bit is 1 for at least one but not all elements (when S-bit is zero)
- 2-3: Selected bit is 0 for all elements (no match)

### IEEE Exceptions:

- None.

### Program Exceptions:

- Data with DXC FE, Vector Instruction
- Operation (if the vector facility for z/Architecture is not installed)
- Specification
- Transaction constraint

### Extended Mnemonics:

- **Extended Mnemonic** | **Base Mnemonic**
  - VFTCIDB $V_1,V_2,I_3$
  - WFTCIDB $V_1,V_2,I_3$

### Programming Notes:

1. VECTOR TEST DATA CLASS provides a way to test operand elements without risk of an exception or setting the IEEE flags.
2. When the S bit is set it is impossible to get a Condition Code of 1.
3. Use VECTOR FP COMPARE EQUAL if you want behavior similar to LOAD AND TEST in Chapter 19.
## Appendix A. Number Representation and Instruction-Use Examples

<table>
<thead>
<tr>
<th>Number Representation</th>
<th>A-2</th>
</tr>
</thead>
<tbody>
<tr>
<td>Binary Integers</td>
<td>A-2</td>
</tr>
<tr>
<td>Signed Binary Integers</td>
<td>A-2</td>
</tr>
<tr>
<td>Unsigned Binary Integers</td>
<td>A-3</td>
</tr>
<tr>
<td>Decimal Integers</td>
<td>A-4</td>
</tr>
<tr>
<td>Hexadecimal-Floating-Point Numbers</td>
<td>A-5</td>
</tr>
<tr>
<td>Conversion Example</td>
<td>A-6</td>
</tr>
<tr>
<td>Instruction-Use Examples</td>
<td>A-7</td>
</tr>
<tr>
<td>Machine Format</td>
<td>A-7</td>
</tr>
<tr>
<td>Assembler-Language Format</td>
<td>A-7</td>
</tr>
<tr>
<td>Addressing Mode in Examples</td>
<td>A-7</td>
</tr>
<tr>
<td>General Instructions</td>
<td>A-7</td>
</tr>
<tr>
<td>ADD HALFWORD (AH)</td>
<td>A-8</td>
</tr>
<tr>
<td>AND (N, NC, NI, NR)</td>
<td>A-8</td>
</tr>
<tr>
<td>NI Example</td>
<td>A-8</td>
</tr>
<tr>
<td>Linkage Instructions (BAL, BALR, BAS, BASR, BASSM, BSM)</td>
<td>A-8</td>
</tr>
<tr>
<td>Other BALR and BASR Examples</td>
<td>A-10</td>
</tr>
<tr>
<td>BRANCH AND STACK (BAKR)</td>
<td>A-10</td>
</tr>
<tr>
<td>BAKR Example 1</td>
<td>A-10</td>
</tr>
<tr>
<td>BAKR Example 2</td>
<td>A-11</td>
</tr>
<tr>
<td>BAKR Example 3</td>
<td>A-11</td>
</tr>
<tr>
<td>BRANCH ON CONDITION (BC, BCR)</td>
<td>A-12</td>
</tr>
<tr>
<td>BRANCH ON COUNT (BCT, BCTR)</td>
<td>A-12</td>
</tr>
<tr>
<td>BRANCH ON INDEX HIGH (BXH)</td>
<td>A-12</td>
</tr>
<tr>
<td>BXH Example 1</td>
<td>A-12</td>
</tr>
<tr>
<td>BXH Example 2</td>
<td>A-13</td>
</tr>
<tr>
<td>BRANCH ON INDEX LOW OR EQUAL (BXLE)</td>
<td>A-13</td>
</tr>
<tr>
<td>BXLE Example 1</td>
<td>A-14</td>
</tr>
<tr>
<td>BXLE Example 2</td>
<td>A-14</td>
</tr>
<tr>
<td>COMPARE AND FORM CODEWORD (CFC)</td>
<td>A-14</td>
</tr>
<tr>
<td>COMPARE HALFWORD (CH)</td>
<td>A-14</td>
</tr>
<tr>
<td>COMPARE LOGICAL (CL, CLC, CLI, CLR)</td>
<td>A-15</td>
</tr>
<tr>
<td>CLC Example</td>
<td>A-15</td>
</tr>
<tr>
<td>CLI Example</td>
<td>A-15</td>
</tr>
<tr>
<td>CLR Example</td>
<td>A-15</td>
</tr>
<tr>
<td>COMPARE LOGICAL CHARACTERS UNDER MASK (CLM)</td>
<td>A-16</td>
</tr>
<tr>
<td>COMPARE LOGICAL LONG (CLCL)</td>
<td>A-16</td>
</tr>
<tr>
<td>COMPARE LOGICAL STRING (CLST)</td>
<td>A-18</td>
</tr>
<tr>
<td>CONVERT TO BINARY (CVB)</td>
<td>A-18</td>
</tr>
<tr>
<td>CONVERT TO DECIMAL (CVD)</td>
<td>A-19</td>
</tr>
<tr>
<td>DIVIDE (D, DR)</td>
<td>A-19</td>
</tr>
<tr>
<td>EXCLUSIVE OR (X, XC, XI, XR)</td>
<td>A-20</td>
</tr>
<tr>
<td>XC Example</td>
<td>A-20</td>
</tr>
<tr>
<td>XI Example</td>
<td>A-21</td>
</tr>
<tr>
<td>EXECUTE (EX)</td>
<td>A-21</td>
</tr>
<tr>
<td>FIND LEFTMOST ONE (FLOGR)</td>
<td>A-22</td>
</tr>
<tr>
<td>INSERT CHARACTERS UNDER MASK (ICM)</td>
<td>A-23</td>
</tr>
<tr>
<td>LOAD (L, LR)</td>
<td>A-23</td>
</tr>
<tr>
<td>LOAD ADDRESS (LA)</td>
<td>A-23</td>
</tr>
<tr>
<td>LOAD HALFWORD (LH)</td>
<td>A-24</td>
</tr>
<tr>
<td>MOVE (MVC, MVI)</td>
<td>A-24</td>
</tr>
<tr>
<td>MVC Example</td>
<td>A-24</td>
</tr>
<tr>
<td>MVI Example</td>
<td>A-25</td>
</tr>
<tr>
<td>MOVE INVERSE (MVCIN)</td>
<td>A-25</td>
</tr>
<tr>
<td>MOVE LONG (MVCL)</td>
<td>A-26</td>
</tr>
<tr>
<td>MOVE NUMERICS (MVN)</td>
<td>A-26</td>
</tr>
<tr>
<td>MOVE STRING (MVST)</td>
<td>A-27</td>
</tr>
<tr>
<td>MOVE WITH OFFSET (MVO)</td>
<td>A-27</td>
</tr>
<tr>
<td>MOVE ZONES (MVZ)</td>
<td>A-28</td>
</tr>
<tr>
<td>MULTIPLY (M, MR)</td>
<td>A-28</td>
</tr>
<tr>
<td>MULTIPLY HALFWORD (MH)</td>
<td>A-29</td>
</tr>
<tr>
<td>OR (O, OC, OI, OR)</td>
<td>A-29</td>
</tr>
<tr>
<td>OI Example</td>
<td>A-29</td>
</tr>
<tr>
<td>PACK (PACK)</td>
<td>A-29</td>
</tr>
<tr>
<td>ROTATE THEN EXCLUSIVE OR SELECTED BITS</td>
<td>A-30</td>
</tr>
<tr>
<td>ROTATE THEN INSERT SELECTED BITS</td>
<td>A-30</td>
</tr>
<tr>
<td>SEARCH STRING (SRST)</td>
<td>A-31</td>
</tr>
<tr>
<td>SRST Example 1</td>
<td>A-31</td>
</tr>
<tr>
<td>SRST Example 2</td>
<td>A-31</td>
</tr>
<tr>
<td>SHIFT LEFT DOUBLE (SLDA)</td>
<td>A-31</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE (SLA)</td>
<td>A-32</td>
</tr>
<tr>
<td>STORE CHARACTERS UNDER MASK (STCM)</td>
<td>A-32</td>
</tr>
<tr>
<td>STORE MULTIPLE (STM)</td>
<td>A-32</td>
</tr>
<tr>
<td>TEST UNDER MASK (TM)</td>
<td>A-33</td>
</tr>
<tr>
<td>TRANSLATE (TR)</td>
<td>A-33</td>
</tr>
<tr>
<td>TRANSLATE AND TEST (TRT)</td>
<td>A-34</td>
</tr>
<tr>
<td>UNPACK (UNPK)</td>
<td>A-35</td>
</tr>
<tr>
<td>UPDATE TREE (UPT)</td>
<td>A-36</td>
</tr>
<tr>
<td>Decimal Instructions</td>
<td>A-36</td>
</tr>
<tr>
<td>ADD DECIMAL (AP)</td>
<td>A-36</td>
</tr>
<tr>
<td>COMPARE DECIMAL (CP)</td>
<td>A-36</td>
</tr>
<tr>
<td>DIVIDE DECIMAL (DP)</td>
<td>A-37</td>
</tr>
<tr>
<td>EDIT (ED)</td>
<td>A-37</td>
</tr>
<tr>
<td>EDIT AND MARK (EDMK)</td>
<td>A-38</td>
</tr>
<tr>
<td>MULTIPLY DECIMAL (MP)</td>
<td>A-39</td>
</tr>
<tr>
<td>SHIFT AND ROUND DECIMAL (SRP)</td>
<td>A-39</td>
</tr>
<tr>
<td>Decimal Left Shift</td>
<td>A-39</td>
</tr>
<tr>
<td>Decimal Right Shift</td>
<td>A-39</td>
</tr>
<tr>
<td>Decimal Right Shift and Round</td>
<td>A-40</td>
</tr>
</tbody>
</table>
Number Representation

Binary Integers

Signed Binary Integers
Signed binary integers are most commonly represented as halfwords (16 bits) or words (32 bits). In both lengths, the leftmost bit (bit 0) is the sign of the number. The remaining bits (bits 1-15 for halfwords and 1-31 for words) are used to specify the magnitude of the number. Binary integers are also referred to as fixed-point numbers, because the radix point (binary point) is considered to be fixed at the right, and any scaling is done by the programmer.

Positive binary integers are in true binary notation with a zero sign bit. Negative binary integers are in two's-complement notation with a one bit in the sign position. In all cases, the bits between the sign bit and the leftmost significant bit of the integer are the same as the sign bit (that is, all zeros for positive numbers, all ones for negative numbers).

Negative binary integers are formed in two's-complement notation by inverting each bit of the positive binary integer and adding one. As an example using the halfword format, the binary number with the decimal value +26 is made negative (-26) in the following manner:

\[
\begin{align*}
+26 & \quad 00000000\ 00011010 \\
\text{Invert} & \quad 11111111\ 11100101 \\
\text{Add} & \quad 00000000\ 00000001 \\
\hline
-26 & \quad 11111111\ 11100110 \quad \text{(Two's complement form)}
\end{align*}
\]

(S is the sign bit.)

This is equivalent to subtracting the number:

\[
\begin{align*}
00000000\ 00011010 \\
\text{from} & \quad 10000000\ 00000000
\end{align*}
\]

Negative binary integers are changed to positive in the same manner.

The following addition examples illustrate two's-complement arithmetic and overflow conditions. Only eight bit positions are used.
The presence or absence of an overflow condition may be recognized from the carries:

- There is no overflow:
  1. If there is no carry into the leftmost bit position and no carry out (examples 1 and 3).
  2. If there is a carry into the leftmost position and also a carry out (examples 2 and 4).

- There is an overflow:
  1. If there is a carry into the leftmost position but no carry out (example 5).
  2. If there is no carry into the leftmost position but there is a carry out (example 6).

The following are 16-bit signed binary integers. The first is the maximum positive 16-bit binary integer. The last is the maximum negative 16-bit binary integer (the negative 16-bit binary integer with the greatest absolute value).

\[
\begin{align*}
2^{15} - 1 &= 32,767 = 0111 \ 1111 \ 1111 \ 1111 \\
2^{16} &= 65,536 = 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \\
2^8 &= 1 \ 000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \\
0 &= 0 \ 000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \\
-2^0 &= -1 = 1 \ 111 \ 1111 \ 1111 \ 1111 \ 1111 \ 1111 \ 1111 \\
-2^1 &= -2 = 1 \ 111 \ 1111 \ 1111 \ 1111 \ 1111 \ 1111 \ 1110 \\
-2^{16} &= -65,536 = 1 \ 111 \ 1111 \ 1111 \ 1111 \ 0000 \ 0000 \ 0000 \\
-2^{31} + 1 &= -2 \ 147 \ 483 \ 647 = 0 \ 000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0001 \\
-2^{31} &= -2 \ 147 \ 483 \ 648 = 1 \ 000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \\
\end{align*}
\]

Figure A-1 illustrates several 32-bit signed binary integers arranged in descending order. The first is the maximum positive binary integer that can be represented by 32 bits, and the last is the maximum negative binary integer that can be represented by 32 bits.

\[Figure \ A-1. \ 32-\text{Bit Signed Binary Integers}\]
signed binary integers, except that the leftmost bit is interpreted as another numeric bit rather than a sign bit. There is no complement notation because all unsigned binary integers are considered positive.

The following examples illustrate the addition of unsigned binary integers. Only eight bit positions are used. The examples are numbered the same as the corresponding examples for signed binary integers.

1. \[ \begin{align*} 57 &= 0011\ 1001 \\ 35 &= 0010\ 0011 \end{align*} \]

\[ 92 = 0101\ 1100 \]

2. \[ \begin{align*} 57 &= 0011\ 1001 \\ 221 &= 1101\ 1101 \end{align*} \]

\[ 278 = \star 0001\ 0110 \quad \text{*Carry out of leftmost position} \]

3. \[ \begin{align*} 35 &= 0010\ 0011 \\ 199 &= 1100\ 0111 \end{align*} \]

\[ 234 = 1110\ 1010 \]

4. \[ \begin{align*} 199 &= 1100\ 0111 \\ 221 &= 1101\ 1101 \end{align*} \]

\[ 420 = \star 1010\ 0100 \quad \text{*Carry out of leftmost position} \]

5. \[ \begin{align*} 57 &= 0011\ 1001 \\ 92 &= 0101\ 1100 \end{align*} \]

\[ 149 = 1001\ 0101 \]

6. \[ \begin{align*} 199 &= 1100\ 0111 \\ 164 &= 1010\ 0100 \end{align*} \]

\[ 363 = \star 0110\ 1011 \quad \text{*Carry out of leftmost position} \]

A carry out of the leftmost bit position may or may not imply an overflow, depending on the application.

Figure A-2 illustrates several 32-bit unsigned binary integers arranged in descending order.

### Decimal Integers

Decimal integers consist of one or more decimal digits and a sign. Each digit and the sign are represented by a 4-bit code. The decimal digits are in binary-coded decimal (BCD) form, with the values 0-9 encoded as 0000-1001. The sign is usually represented as 1100 (C hex) for plus and 1101 (D hex) for minus. These are the preferred sign codes, which are generated by the machine for the results of decimal-arithmetic operations. There are also several alternate sign codes (1010, 1110, and 1111 for plus; 1011 for minus). The alternate sign codes are accepted by the machine as valid in source operands but are not generated for results.

Decimal integers may have different lengths, from one to 16 bytes. Of the many decimal formats, only two will be considered here: signed-packed-decimal and zoned. In the signed-packed-decimal format, each byte contains two decimal digits, except for the rightmost byte, which contains the sign code in the right half. For decimal arithmetic, the number of decimal digits in the signed-packed-decimal format can vary from one to 31. Because decimal integers must consist of whole bytes and there must be a sign code on the right, the number of decimal digits in this format is always odd. If an even number of significant digits is desired, a leading zero must be inserted on the left.

In the zoned format, each byte consists of a decimal digit on the right and the zone code 1111 (F hex) on the left, except for the rightmost byte where the sign code replaces the zone code. Thus, a decimal integer in the zoned format can have from one to 16 digits. The zoned format may be used directly for input
and output in the extended binary-coded-decimal interchange code (EBCDIC), except that the sign must be separated from the rightmost digit and handled as a separate character. For positive (unsigned) numbers, however, the sign can simply be represented by the zone code of the rightmost digit because the zone code is one of the acceptable alternate codes for plus.

In either format, negative decimal integers are represented in true notation with a separate sign. As for binary integers, the radix point (decimal point) of decimal integers is considered to be fixed at the right, and any scaling is done by the programmer.

The following are some examples of decimal integers shown in hexadecimal notation:

<table>
<thead>
<tr>
<th>Decimal Value</th>
<th>Signed Packed Format</th>
<th>Zoned Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>+123</td>
<td>12 3C or 12 3F</td>
<td>F1 F2 C3</td>
</tr>
<tr>
<td>-4321</td>
<td>04 32 1D</td>
<td>F4 F3 F2 D1</td>
</tr>
<tr>
<td>+000050</td>
<td>00 00 05 0C or 00 00 05 0F</td>
<td>F0 F0 F0 F0 F5 C0 or F0 F0 F0 F0 F5 F0</td>
</tr>
<tr>
<td>-7</td>
<td>00 00 0C or 00 00 0F</td>
<td>D7</td>
</tr>
<tr>
<td>00000</td>
<td>00 00 0C or 00 00 0F</td>
<td>00 00 0C or 00 00 0F</td>
</tr>
</tbody>
</table>

Under some circumstances, a zero with a minus sign (negative zero) is produced. For example, the multiplicand:

00 12 3D (-123)

times the multiplier:

0C (+0)

generates the product:

00 00 0D (-0)

because the product sign follows the algebraic rule of signs even when the value is zero. A negative zero, however, is equivalent to a positive zero in that they compare equal in a decimal comparison.

**Hexadecimal-Floating-Point Numbers**

A hexadecimal-floating-point (HFP) number is expressed as a hexadecimal fraction multiplied by a separate power of 16. The term floating point indicates that the placement, of the radix (hexadecimal) point, or scaling, is automatically maintained by the machine.

The part of an HFP number which represents the significant digits of the number is called the fraction. A second part specifies the power (exponent) to which 16 is raised and indicates the location of the radix point of the number. The fraction and exponent may be represented by 32 bits (short format), 64 bits (long format), or 128 bits (extended format).

**Short HFP Number**

```
S Characteristic | 6-Digit Fraction
0 1 8 31
```

**Long HFP Number**

```
Word
S Characteristic | 14-Digit Fraction
0 1 8 31
1 14-Digit Fraction (continued)
32 63
```

**Extended HFP Number**

```
Word
S Characteristic | Leftmost 14 Digits of 28-Digit Fraction
0 1 8 31
1 Leftmost 14 Digits of 28-Digit Fraction (continued)
32 63
2 Low-Order S Characteristic | Rightmost 14 Digits of 28-Digit Fraction
64 72 95
3 Rightmost 14 Digits of 28-Digit Fraction (continued)
96 127
```
An HFP number has two signs: one for the fraction and one for the exponent. The fraction sign, which is also the sign of the entire number, is the leftmost bit of each format (0 for plus, 1 for minus). The numeric part of the fraction is in true notation regardless of the sign. The numeric part is contained in bits 8-31 for the short format, in bits 8-63 for the long format, and in bits 8-63 followed by bits 72-127 for the extended format.

The exponent sign is obtained by expressing the exponent in excess-64 notation; that is, the exponent is added as a signed number to 64. The resulting number is called the characteristic. It is located in bits 1-7 for all formats. The characteristic can vary from 0 to 127, permitting the exponent to vary from -64 through 0 to +63. This provides a scale multiplier in the range of $16^{-64}$ to $16^{63}$. A nonzero fraction, if normalized, has a value less than one and greater than or equal to 1/16, so that the range covered by the magnitude $M$ of a normalized floating-point number is:

\[
16^{-65} \leq M < 16^{63}
\]

In decimal terms:

- $16^{-65}$ is approximately $5.4 \times 10^{-79}$
- $16^{63}$ is approximately $7.2 \times 10^{75}$

More precisely,

In the short format:

\[
16^{-65} \leq M \leq (1 - 16^{-6}) \times 16^{63}
\]

In the long format:

\[
16^{-65} \leq M \leq (1 - 16^{-14}) \times 16^{63}
\]

In the extended format:

\[
16^{-65} \leq M \leq (1 - 16^{-28}) \times 16^{63}
\]

Within a given fraction length (6, 14, or 28 digits), an HFP operation will provide the greatest precision if the fraction is normalized. A fraction is normalized when the leftmost digit (bit positions 8, 9, 10, and 11) is nonzero. It is unnormalized if the leftmost digit contains all zeros.

If normalization of the operand is desired, the HFP instructions that provide automatic normalization are used. This automatic normalization is accomplished by left-shifting the fraction (four bits per shift) until a nonzero digit occupies the leftmost digit position. The characteristic is reduced by one for each digit shifted.

Figure A-3 illustrates sample normalized short HFP numbers. The last two numbers represent the smallest and the largest positive normalized numbers.

### Conversion Example

Convert the decimal number 59.25 to a short HFP number. (In another appendix are tables for the conversion of hexadecimal and decimal integers and fractions.)

1. The number is separated into a decimal integer and a decimal fraction.

\[
59.25 = 59 + 0.25
\]

2. The decimal integer is converted to its hexadecimal representation.

\[
59_{10} = 3B_{16}
\]

3. The decimal fraction is converted to its hexadecimal representation.

\[
0.25_{10} = 0.4_{16}
\]

4. The integral and fractional parts are combined and expressed as a fraction times a power of 16 (exponent).
3B.4_{16} = 0.3B4_{16} \times 16^2

5. The characteristic is developed from the exponent and converted to binary.

\[
\text{base + exponent} = \text{characteristic} \\
64 + 2 = 66 = 1000010
\]

6. The fraction is converted to binary and grouped hexadecimally.

\[.3B4_{16} = .0011\ 1011\ 0100\]

7. The characteristic and the fraction are stored in the short format. The sign position contains the sign of the fraction.

\[
\begin{array}{cc}
\text{S Char} & \text{Fraction} \\
0 & 1000010 \ 0011\ 1011\ 0100\ 0000\ 0000\ 0000
\end{array}
\]

Examples of instruction sequences that may be used to convert between signed binary integers and HFP numbers are shown in “Hexadecimal-Floating-Point-Number Conversion” on page A-44.

**Instruction-Use Examples**

The following examples illustrate the use of many of the unprivileged instructions. Before studying one of these examples, the reader should consult the instruction description.

The instruction-use examples are written principally for assembler-language programmers, to be used in conjunction with the appropriate assembler-language publications.

Most examples present one particular instruction, both as it is written in an assembler-language statement and as it appears when assembled in storage (machine format).

**Machine Format**

All machine-format values are given in hexadecimal notation unless otherwise specified. Storage addresses are also given in hexadecimal. Hexadecimal operands are shown converted into binary, decimal, or both if such conversion helps to clarify the example for the reader.

**Assembler-Language Format**

In assembler-language statements, registers and lengths are presented in decimal. Displacements, immediate operands, and masks may be shown in decimal, hexadecimal, or binary notation; for example, 12, X'C', and B'1100' represent the same value. Whenever the value in a register or storage location is referred to as “not significant,” this value is replaced during the execution of the instruction.

When SS-format instructions are written in the assembler language, lengths are given as the total number of bytes in the field. This differs from the machine definition, in which the length field specifies the number of bytes to be added to the field address to obtain the address of the last byte of the field. Thus, the machine length is one less than the assembler-language length. The assembler program automatically subtracts one from the length specified when the instruction is assembled.

In some of the examples, symbolic addresses are used in order to simplify the examples. In assembler-language statements, a symbolic address is represented as a mnemonic term written in all capitals, such as FLAGS, which may denote the address of a storage location containing data or program-control information. When symbolic addresses are used, the assembler supplies actual base and displacement values according to the programmer’s specifications. Therefore, the actual values for base and displacement are not shown in the assembler-language format or in the machine-language format. For assembler-language formats, in the labels that designate instruction fields, the letter “S” is used to indicate the combination of base and displacement fields for an operand address. (For example, S2 represents the combination of B2 and D2.) In the machine-language format, the base and displacement address components are shown as asterisks (****).

**Addressing Mode in Examples**

Except where otherwise specified, the examples assume the 24-bit addressing mode.

**General Instructions**

(See Chapter 7, “General Instructions” for a complete description of the general instructions.)
ADD HALFWORD (AH)

The ADD HALFWORD instruction algebraically adds the contents of a two-byte field in storage to the contents of a register. The storage operand is expanded to 32 bits after it is fetched and before it is used in the add operation. The expansion consists in propagating the leftmost (sign) bit 16 positions to the left. For example, assume that the contents of storage locations 2000-2001 are to be added to register 5. Initially:

- Register 5 contains 00 00 00 19 = 2510.
- Storage locations 2000-2001 contain FF FE = \(-2^{10}\).
- Register 12 contains 00 00 18 00.
- Register 13 contains 00 00 01 50.

The format of the required instruction is:

<table>
<thead>
<tr>
<th>Machine Format</th>
<th>Assembler Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code  R1,D2(X2,B2)</td>
<td>AH 5,X'6B0'(13,12)</td>
</tr>
</tbody>
</table>

After the instruction is executed, register 5 contains 00 00 00 17 = 2310. Condition code 2 is set to indicate a result greater than zero.

AND (N, NC, NI, NR)

When the Boolean operator AND is applied to two bits, the result is one when both bits are one; otherwise, the result is zero. When two bytes are ANDed, each pair of bits is handled separately; there is no connection from one bit position to another. The following is an example of ANDing two bytes:

- First-operand byte: 0011 01012
- Second-operand byte: 0101 11002
- Result byte: 0001 01002

NI Example

A frequent use of the AND instruction is to set a particular bit to zero. For example, assume that storage location 4891 contains 0100 00112. To set the rightmost bit of this byte to zero without affecting the other bits, the following instruction can be used (assume that register 8 contains 00 00 48 90):

<table>
<thead>
<tr>
<th>Machine Format</th>
<th>Assembler Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code  D1(B1),I2</td>
<td>NI 1(8),X'FE'</td>
</tr>
</tbody>
</table>

When this instruction is executed, the byte in storage is ANDed with the immediate byte (the I2 field of the instruction):

- Location 4891: 0100 00112
- Immediate byte: 1111 11102
- Result: 0100 00102

The resulting byte, with bit 7 set to zero, is stored back in location 4891. Condition code 1 is set.

Linkage Instructions (BAL, BALR, BAS, BASR, BASSM, BSM)

Four unprivileged instructions (BRANCH AND LINK, BRANCH AND SAVE, BRANCH AND SAVE AND SET MODE, and BRANCH AND SET MODE) are available, together with the unconditional branch (BRANCH ON CONDITION with a mask of 15), to provide linkage between subroutines. BRANCH AND LINK (BAL or BALR) is provided primarily for compatibility with programs written for System/370; BRANCH AND SAVE (BAS or BASR) is recommended instead for programs which are to be executed using ESA/370. The instructions BRANCH AND SAVE AND SET MODE (BASSM) and BRANCH AND SET MODE (BSM) provide subroutine linkage together with switching between the 24-bit and the 31-bit addressing modes. The use of these instructions is discussed in a programming note at the end of “Subroutine Linkage without the Linkage Stack.” (See also the semiprivileged instruction BRANCH AND STACK.)
The following example compares the operation of these instructions and of the unconditional-branch instruction BRANCH ON CONDITION (BC or BCR with a mask of 15). Assume that each instruction in turn is located at the current instruction address, ready to be executed next. For the first set of examples, the addressing-mode bit, PSW bit 32, is initially zero (24-bit addressing in effect). For the second set, PSW bit 32 is initially one (31-bit addressing). Assume also that general register 5 is to receive the linkage information, and that general register 6 contains the branch address.

The format of the BALR instruction is:

<table>
<thead>
<tr>
<th>Machine Format</th>
<th>Assembler Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code R1 R2</td>
<td>Op Code R1 R2</td>
</tr>
<tr>
<td>05 5 6</td>
<td>BALR 5,6</td>
</tr>
</tbody>
</table>

The other linkage instructions in the RR format have the same format but different op codes:

- BASR 0D
- BASSM 0C
- BSM 0B

For comparison with the RR-format instructions, the results of two RX-format instructions are also shown.

The format of the BAL instruction is:

<table>
<thead>
<tr>
<th>Machine Format</th>
<th>Assembler Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code R1 X2 B2 D2</td>
<td>Op Code R1 D2(X2,B2)</td>
</tr>
<tr>
<td>45 5 0 6 000</td>
<td>BAL 5,0(0,6)</td>
</tr>
</tbody>
</table>

The BAS instruction has the same format, but the op code is 4D.

The BCR instruction specifies only one register:

<table>
<thead>
<tr>
<th>Machine Format</th>
<th>Assembler Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code M1 R2</td>
<td>Op Code M1 R2</td>
</tr>
<tr>
<td>07 5 6</td>
<td>BCR 15,6</td>
</tr>
</tbody>
</table>

Assume that:

- Register 5 contains BB BB BB BB.
- Register 6 contains 82 46 8A CE.
- PSW bits 32-63 contain
  - 00 00 10 D6 (for 24-bit addressing).
  - 80 00 10 D6 (for 31-bit addressing).
- Condition code is 012.
- Program mask is 11002.

The effect of executing each instruction in turn is as follows:

**24-Bit Mode Initially**

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Register 5</th>
<th>PSW (32-63)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Before</td>
<td>BB BB BB BB 00 00 10 D6</td>
<td></td>
</tr>
<tr>
<td>BCR 15,6</td>
<td>BB BB BB BB 00 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BAL 5,0(0,6)</td>
<td>9C 00 10 DA 00 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BAS 5,0(0,6)</td>
<td>00 00 10 DA 00 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BALR 5,6</td>
<td>9C 00 10 DA 00 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BASR 5,6</td>
<td>00 00 10 DB 00 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BASSM 5,6</td>
<td>00 00 10 DB 82 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BSM 5,6</td>
<td>3B BB BB BB 82 46 8A CE</td>
<td></td>
</tr>
</tbody>
</table>

**31-Bit Mode Initially**

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Register 5</th>
<th>PSW (32-63)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Before</td>
<td>BB BB BB BB 80 00 10 D6</td>
<td></td>
</tr>
<tr>
<td>BCR 15,6</td>
<td>BB BB BB BB 82 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BAL 5,0(0,6)</td>
<td>80 00 10 DA 82 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BAS 5,0(0,6)</td>
<td>80 00 10 DA 82 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BALR 5,6</td>
<td>80 00 10 DA 82 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BASR 5,6</td>
<td>80 00 10 DB 82 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BASSM 5,6</td>
<td>80 00 10 DB 82 46 8A CE</td>
<td></td>
</tr>
<tr>
<td>BSM 5,6</td>
<td>82 BB BB BB 82 46 8A CE</td>
<td></td>
</tr>
</tbody>
</table>

Note that a value of zero in the R2 field of any of the RR-format instructions indicates that the branching function is not to be performed; it does not refer to register 0. Likewise, a value of zero in the R1 field of the BSM instruction indicates that the old value of
PSW bit 32 is not to be saved and that register 0 is to be left unchanged. Register 0 can be designated by the R1 field of instructions BAL, BALR, BAS, BASR, and BASSM, however. In the RX-format branch instructions, branching occurs independent of whether there is a value of zero in the B2 field or X2 field of the instruction. However, when the field is zero, instead of using the contents of general register 0, a value of zero is used for that component of address generation.

**Programming Note:** It should be noted that execution of BAL in the 24-bit addressing mode results in bit 0 of register 5 being set to one. This is because the ILC for an RX-format instruction is 10. This is the only case in which bit zero of the return register does not correctly reflect the addressing mode of the caller. Thus, BSM may be used to return for BALR, BAS, BASR, and BASSM in both the 24-bit and the 31-bit addressing modes, but it cannot be used to return if the program was called by using BAL in the 24-bit addressing mode.

**Other BALR and BASR Examples**
The BALR or BASR instruction with the R2 field set to zero may be used to load a register for use as a base register. For example, in the assembler language, the two statements:

```
BALR    15,0
USING   *,15
```

or

```
BASR    15,0
USING   *,15
```

indicate that the address of the next sequential instruction following the BALR or BASR instruction will be placed in register 15, and that the assembler may use register 15 as a base register until otherwise instructed. (The USING statement is an "assembler instruction" and is thus not a part of the object program.)

**BRANCH AND STACK (BAKR)**
The semiprivileged BRANCH AND STACK instruction facilitates linkage between subroutines by saving status in a linkage-stack state entry (sometimes called a branch state entry to distinguish it from a program-call state entry). When BRANCH AND STACK has been used, the return from the called program is made by means of the PROGRAM RETURN instruction. PROGRAM RETURN restores access registers 2-14, general registers 2-14, and the PSW with values saved in the state entry, except that it leaves the PER mask unchanged and sets the condition code to an unpredictable value. The use of BRANCH AND STACK is discussed in “Branching Using the Linkage Stack” on page 5-74.

**BRANCH AND STACK**

BRANCH AND STACK can be used to perform a calling linkage, or it can be used at or near the entry point of the called program, depending on whether the R1 field of the instruction is zero or nonzero, respectively. If the R1 field is zero, bits 32-63 of the PSW saved in the state entry indicate the current addressing mode (24-bit or 31-bit) and the address of the next sequential instruction after the BRANCH AND STACK instruction or an EXECUTE instruction. If the R1 field is nonzero, bits 32-63 of the PSW saved in the state entry are set with a value generated from the contents of general register R1; bit 32 of the PSW is set equal to bit 0 of the register, and bits 1-31 of the PSW are set with an address generated from bits 1-31 of the register under the control of bit 0 of the register. Bits 32-63 of the PSW saved in the state entry are referred to in the following examples as the return value.

The branch address for the instruction is generated from the contents of general register R2 under the control of the current addressing mode. Bit 0 of general register R2 does not affect the operation. If the R2 field of the instruction is zero, the operation is performed without branching.

In addition to saving a complete PSW (except with an unpredictable PER mask) in the state entry, BRANCH AND STACK saves the new value of bits 32-63 of the current PSW in the state entry. Bits 32-63 are referred to in the following examples as the branch value.

The following examples contain cases in which bit 32 of the current PSW is either zero or one (24-bit or 31-bit addressing) before BRANCH AND STACK is executed and in which bit 0 of the general register designated by a nonzero R1 or R2 field is either zero or one.

**BAKR Example 1**
This example shows BAKR used in a calling program. BAKR performs a branch, and the return is to be the next sequential instruction.
The format of the BAKR instruction is:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁</th>
<th>R₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>B240</td>
<td>0</td>
<td>6</td>
</tr>
</tbody>
</table>

**Assembler Format**

Op Code R₁,R₂

BAKR 0,6

Assume four cases of initial values, as follows:

<table>
<thead>
<tr>
<th>PSW (32-63)</th>
<th>Register 6</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. 00 00 10 D6</td>
<td>02 46 8A CE</td>
</tr>
<tr>
<td>2. 00 00 10 D6</td>
<td>82 46 8A CE</td>
</tr>
<tr>
<td>3. 80 00 10 D6</td>
<td>02 46 8A CE</td>
</tr>
<tr>
<td>4. 80 00 10 D6</td>
<td>82 46 8A CE</td>
</tr>
</tbody>
</table>

The results in the four cases are as follows:

<table>
<thead>
<tr>
<th>Return Value</th>
<th>Branch Value and PSW (32-63)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. 00 00 10 DA</td>
<td>00 46 8A CE</td>
</tr>
<tr>
<td>2. 00 00 10 DA</td>
<td>82 46 8A CE</td>
</tr>
<tr>
<td>3. 80 00 10 DA</td>
<td>02 46 8A CE</td>
</tr>
<tr>
<td>4. 80 00 10 DA</td>
<td>82 46 8A CE</td>
</tr>
</tbody>
</table>

**BAKR Example 2**

This example shows BAKR used in a called program. BAKR does not perform a branch, and the return is to be as specified in general register R₁.

The format of the BAKR instruction is:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁</th>
<th>R₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>B240</td>
<td>5</td>
<td>6</td>
</tr>
</tbody>
</table>

**Assembler Format**

Op Code R₁,R₂

BAKR 5,6

Assume eight cases of initial values, as follows:

<table>
<thead>
<tr>
<th>Register 5</th>
<th>Register 6</th>
<th>PSW (32-63)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. 04 00 10 D6</td>
<td>06 99 99 00</td>
<td>00 46 8A CE</td>
</tr>
<tr>
<td>2. 04 00 10 D6</td>
<td>86 99 99 00</td>
<td>82 46 8A CE</td>
</tr>
<tr>
<td>3. 04 00 10 D6</td>
<td>06 99 99 00</td>
<td>00 46 8A CE</td>
</tr>
<tr>
<td>4. 04 00 10 D6</td>
<td>86 99 99 00</td>
<td>82 46 8A CE</td>
</tr>
<tr>
<td>5. 84 00 10 D6</td>
<td>06 99 99 00</td>
<td>00 46 8A CE</td>
</tr>
<tr>
<td>6. 84 00 10 D6</td>
<td>86 99 99 00</td>
<td>82 46 8A CE</td>
</tr>
<tr>
<td>7. 84 00 10 D6</td>
<td>06 99 99 00</td>
<td>00 46 8A CE</td>
</tr>
<tr>
<td>8. 84 00 10 D6</td>
<td>86 99 99 00</td>
<td>82 46 8A CE</td>
</tr>
</tbody>
</table>

The results in the eight cases are as follows:

<table>
<thead>
<tr>
<th>Return Value</th>
<th>Branch Value and PSW (32-63)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. 00 00 10 D6</td>
<td>00 99 99 00</td>
</tr>
<tr>
<td>2. 00 00 10 D6</td>
<td>86 99 99 00</td>
</tr>
<tr>
<td>3. 00 00 10 D6</td>
<td>00 99 99 00</td>
</tr>
<tr>
<td>4. 00 00 10 D6</td>
<td>86 99 99 00</td>
</tr>
<tr>
<td>5. 84 00 10 D6</td>
<td>00 99 99 00</td>
</tr>
<tr>
<td>6. 84 00 10 D6</td>
<td>86 99 99 00</td>
</tr>
<tr>
<td>7. 84 00 10 D6</td>
<td>00 99 99 00</td>
</tr>
<tr>
<td>8. 84 00 10 D6</td>
<td>86 99 99 00</td>
</tr>
</tbody>
</table>
BRANCH ON CONDITION (BC, BCR)

The BRANCH ON CONDITION instruction tests the condition code to see whether a branch should or should not occur. The branch occurs only if the current condition code corresponds to a one bit in a mask specified by the instruction.

For example, assume that an ADD (A or AR) operation has been performed and that a branch to address 6050 is desired if the sum is zero or less (condition code is 0 or 1). Also assume:

Register 10 contains 00 00 50 00.
Register 11 contains 00 00 10 00.

The RX form of the instruction performs the required test (and branch if necessary) when written as:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>M1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>4 7 CBA 0 5 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Assembler Format

Op Code M1, D2(X2, B2)

BRANCH ON INDEX HIGH (BXH)

BXH Example 1

The BRANCH ON INDEX HIGH instruction is an index-incrementing and loop-controlling instruction that causes a branch whenever the sum of an index value and an increment value is greater than some compare value. For example, assume that:

Register 4 contains 00 00 00 8A = 13810 = the index.
Register 6 contains 00 00 00 02 = 210 = the increment.
Register 7 contains 00 00 00 AA = 17010 = the compare value.

<table>
<thead>
<tr>
<th>Condition Code</th>
<th>Instruction (Mask) Bit</th>
<th>Mask Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>1</td>
<td>9</td>
<td>4</td>
</tr>
<tr>
<td>2</td>
<td>10</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>11</td>
<td>1</td>
</tr>
</tbody>
</table>

(See also “Linkage Instructions (BAL, BALR, BAS, BASR, BASSM, BSM)” on page A-8 for an example of the BCR instruction.)

BRANCH ON COUNT (BCT, BCTR)

The BRANCH ON COUNT instruction is often used to execute a program loop for a specified number of times. For example, assume that the following represents some lines of coding in an assembler-language program:

```
LUPE AR 8,1
BACK BCT 6,LUPE
```

where register 6 contains 00 00 00 03 and the address of LUPE is 6826. Assume that, in order to address this location, register 10 is used as a base register and contains 00 00 68 00.

The format of the BCT instruction is:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>46 6 0 A 026</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Assembler Format

Op Code R1, D2(X2, B2)

BRANCH ON INDEX HIGH (BXH)

BXH Example 1

The BRANCH ON INDEX HIGH instruction is an index-incrementing and loop-controlling instruction that causes a branch whenever the sum of an index value and an increment value is greater than some compare value. For example, assume that:

Register 4 contains 00 00 00 8A = 13810 = the index.
Register 6 contains 00 00 00 02 = 210 = the increment.
Register 7 contains 00 00 00 AA = 17010 = the compare value.
Register 10 contains 00 00 71 30 = the branch address.

The format of the BXH instruction is:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R3</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>86</td>
<td>4</td>
<td>6</td>
<td>A</td>
<td>00</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, R3, D2(B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>BXH</td>
<td>4, 6, 0(10)</td>
</tr>
</tbody>
</table>

When the instruction is executed, first the contents of register 6 are added to register 4, second the sum is compared with the contents of register 7, and third the decision whether to branch is made. After execution:

Register 4 contains 00 00 00 8C = 14010.

Registers 6 and 7 are unchanged.

Since the new value in register 4 is not yet greater than the value in register 7, the branch to address 7130 is not taken. Repeated use of the instruction will eventually cause the branch to be taken when the value in register 4 reaches 17210.

**BXH Example 2**

When the register used to contain the increment is odd, that register also becomes the compare-value register. The following assembler-language subroutine illustrates how this may be used to search a table.

<table>
<thead>
<tr>
<th>Table</th>
</tr>
</thead>
<tbody>
<tr>
<td>2 Bytes</td>
</tr>
<tr>
<td>ARG1</td>
</tr>
<tr>
<td>ARG2</td>
</tr>
<tr>
<td>ARG3</td>
</tr>
<tr>
<td>ARG4</td>
</tr>
<tr>
<td>ARG5</td>
</tr>
<tr>
<td>ARG6</td>
</tr>
</tbody>
</table>

Assume that:

Register 8 contains the search argument.

Register 9 contains the width of the table in bytes (00 00 00 04).

Register 10 contains the length of the table in bytes (00 00 00 18).

Register 11 contains the starting address of the table.

Register 14 contains the return address to the main program.

As the following subroutine is executed, the argument in register 8 is successively compared with the arguments in the table, starting with argument 6 and working backward to argument 1. If an equality is found, the corresponding function replaces the argument in register 8. If an equality is not found, zero replaces the argument in register 8.

```
SEARCH LNR 9,9
NOTEQUAL BXH 10, 9, LOOP
NOTFOUND SR 8, 8
BCR 15, 14
LOOP CH 8, 0(10, 11)
BC 7, NOTEQUAL
LH 8, 8(10, 11)
BCR 15, 14
```

The first instruction (LNR) causes the value in register 9 to be made negative. After execution of this instruction, register 9 contains FF FF FF FC = -410. Considering the case when no equality is found, the BXH instruction will be executed seven times. Each time BXH is executed, a value of -4 is added to register 10, thus reducing the value in register 10 by 4. The new value in register 10 is compared with the -4 value in register 9. The branch is taken each time until the value in register 10 is -4. Then the branch is not taken, and the SR instruction sets register 8 to zero.

**BRANCH ON INDEX LOW OR EQUAL (BXLE)**

The BRANCH ON INDEX LOW OR EQUAL instruction performs the same operation as BRANCH ON INDEX HIGH, except that branching occurs when the sum is lower than or equal to (instead of higher than) the compare value. As the instruction which increments and tests an index value in a program loop, BXLE is useful at the end of the loop and BXH at the beginning. The following assembler-language routines illustrate loops with BXLE.
BXLE Example 1
Assume that a group of ten 32-bit signed binary integers are stored at consecutive locations, starting at location GROUP. The integers are to be added together, and the sum is to be stored at location SUM.

```
SR  5,5   Set sum to zero
LA  6,GROUP Load first address
SR  7,7   Set index to zero
LA  8,4   Load increment 4
LA  9,39  Load compare value
LOOP A  5,0(7,6) Add integer to sum
BXLE 7,8,LOOP Test end of loop
ST 5,SUM Store sum
```

The two-instruction loop contains an ADD (A) instruction which adds each integer to the contents of general register 5. The ADD instruction uses the contents of general register 7 as an index value to modify the starting address obtained from register 6. Next, BXLE increments the index value by 4, the increment previously loaded into register 8, and compares it with the compare value in register 9, the odd register of this even-odd pair. The compare value was previously set to 39, which is one less than the number of bytes in the data area; this is also the address, relative to the starting address, of the rightmost byte of the last integer to be added. When the last integer has been added, BXLE increments the index value to the next relative address (40), which is found to be greater than the compare value (39) so that no branching takes place.

BXLE Example 2
The technique illustrated in Example 1 is restricted to loops containing instructions in the RX instruction format. That format allows both a base register and an index register to be specified (double indexing).

For instructions in other formats, where an index register cannot be specified, the previous technique may be modified by having the address itself serve as the index value in a BXLE instruction and by using as the compare value the address of the last byte to be added. When the last integer has been added, BXLE increments the index value to the next relative address (40), which is found to be greater than the compare value (39) so that no branching takes place.

The technique shown in Example 2 does not work, however, on an ESA/370 system when it is in the 31-bit addressing mode and the data is located at the rightmost end of a 31-bit address space. In this case, the compare value would be set to $2^{31}-1$, which is the largest possible 32-bit signed binary value. The reason the technique does not work is that the BXLE and BXH instructions treat their operands as 32-bit signed binary integers. When the address in general register 6 reaches the value $2^{31}-4$, BXLE increments it to a value that is interpreted as $-2^{31}$, rather than $2^{31}$, and the comparison remains low, which causes looping to continue indefinitely.

This situation can be avoided by not allowing data areas to extend to the rightmost location in a 31-bit address space or by using other techniques; these may include double indexing when possible, as in Example 1, or starting at the end and stepping downward through the data area with a negative increment.

COMPARE AND FORM CODEWORD (CFC)
See “Sorting Instructions” on page A-53.

COMPARE HALFWORD (CH)
The COMPARE HALFWORD instruction compares a 16-bit signed binary integer in storage with the contents of a register. For example, assume that:

- Register 4 contains FF FF 00 00 = -32,768_{10}.
- Register 13 contains 00 01 60 50.
- Storage locations 16080-16081 contain 8000 = -32,768_{10}.

When the instruction:
is executed, the contents of locations 16080-16081 are fetched, expanded to 32 bits (the sign bit is propagated to the left), and compared with the contents of register 4. Because the two numbers are equal, condition code 0 is set.

**COMPARE LOGICAL (CL, CLC, CLI, CLR)**

The COMPARE LOGICAL instruction differs from the signed-binary comparison instructions (C, CH, CR) in that all quantities are handled as unsigned binary integers or as unstructured data.

**CLC Example**
The COMPARE LOGICAL (CLC) instruction can be used to perform the byte-by-byte comparison of storage fields up to 256 bytes in length. For example, assume that the following two fields of data are in storage:

Field 1

1886 1891
D1 D6 C8 D5 E2 D6 D5 6B C1 4B C2 4B

Field 2

1900 1908
D1 D6 C8 D5 E2 D6 D5 6B C1 4B C3 4B

Also assume:

Register 9 contains 00 00 18 80.

Register 7 contains 00 00 19 00.

Execution of the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>I2</th>
<th>B1</th>
<th>D1</th>
</tr>
</thead>
<tbody>
<tr>
<td>95</td>
<td>AF</td>
<td>A</td>
<td>003</td>
</tr>
</tbody>
</table>

Assembler Format

Op Code  D1(B1), I2

| CLI     | 3(10), X'AF' |

sets condition code 1, indicating that the contents of field 1 are lower in value than the contents of field 2.

Because the collating sequence of the EBCDIC code is determined simply by a logical comparison of the bits in the code, the CLC instruction can be used to collate EBCDIC-coded fields. For example, in EBCDIC, the above two data fields are:

Field 1: JOHNSON,A.B.
Field 2: JOHNSON,A.C.

Condition code 1 indicates that JOHNSON,A.B. should precede JOHNSON,A.C. for the fields to be in alphabetic sequence.

**CLI Example**
The COMPARE LOGICAL (CLI) instruction compares a byte from the instruction stream with a byte from storage. For example, assume that:

Register 10 contains 00 00 17 00.

Storage location 1703 contains 7E.

Execution of the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>I2</th>
<th>B1</th>
<th>D1</th>
</tr>
</thead>
<tbody>
<tr>
<td>95</td>
<td>AF</td>
<td>A</td>
<td>003</td>
</tr>
</tbody>
</table>

Assembler Format

Op Code  D1(B1),I2

| CLI     | 3(10), X'AF' |

sets condition code 1, indicating that the first operand (the quantity in main storage) is lower than the second (immediate) operand.

**CLR Example**
Assume that:
Register 4 contains 00 00 00 01 = 1.

Register 7 contains FF FF FF FF = 2^32 - 1.

Execution of the instruction:

Machine Format
Op Code  R1, R2
15 4 7

Assembler Format
Op Code  R1, R2
CLR 4, 7

sets condition code 1. Condition code 1 indicates that the first operand is lower than the second.

If, instead, the signed-binary comparison instruction COMPARE (CR) had been executed, the contents of register 4 would have been interpreted as +1 and the contents of register 7 as -1. Thus, the first operand would have been higher, so that condition code 2 would have been set.

**COMPARE LOGICAL CHARACTERS UNDER MASK (CLM)**

The COMPARE LOGICAL CHARACTERS UNDER MASK (CLM) instruction provides a means of comparing bytes selected from a general register to a contiguous field of bytes in storage. The M3 field of the CLM instruction is a four-bit mask that selects zero to four bytes from a general register, each mask bit corresponding, left to right, to a register byte. In the comparison, the register bytes corresponding to ones in the mask are treated as a contiguous field. The operation proceeds left to right. For example, assume that:

Storage locations 10200-10202 contain F0 BC 7B.

Register 12 contains 00 01 00 00.

Register 6 contains F0 BC 5C 7B.

Execution of the instruction:

Machine Format
Op Code  R1, M3, B2, D2

Assembler Format
Op Code  R1, M3, D2(B2)

causes the following comparison:

Register 6:  F0 BC 5C 7B
Mask M3:   1 1 0 1
-- --        --

Because the selected bytes are equal, condition code 0 is set.

**COMPARE LOGICAL LONG (CLCL)**

The COMPARE LOGICAL LONG instruction is used to compare two operands in storage, byte by byte. Each operand can be of any length. Two even-odd pairs of general registers (four registers in all) are used to locate the operands and to control the execution of the CLCL instruction, as illustrated in the following diagram. The first register of each pair must be an even register, and it contains the storage address of an operand. The odd register of each pair contains the length of the operand it covers, and the leftmost byte of the second-operand odd register contains a padding byte which is used to extend the shorter operand, if any, to the same length as the longer operand.

The following illustrates the assignment of registers in the 24-bit addressing mode:

R1 (even) // First-Operand Address

R1+1 (odd) // First-Operand Length
In the 31-bit addressing mode, the operand addresses would be in bit positions 1-31 of the even registers shown above.

Since the CLCL instruction may be interrupted during execution, the interrupting program must preserve the contents of the four registers for use when the instruction is resumed.

The following instructions set up two register pairs to control a text-string comparison. For example, assume:

<table>
<thead>
<tr>
<th>Operand 1</th>
<th>Address: 20800_{16}</th>
<th>Length: 100_{10}</th>
</tr>
</thead>
<tbody>
<tr>
<td>Operand 2</td>
<td>Address: 20A00_{16}</td>
<td>Length: 132_{10}</td>
</tr>
</tbody>
</table>

Padding Byte
| Address: 20003_{16} | Length: 1 | Value: 40_{16} |

Register 12 contains 00 02 00 00.

The setup instructions are:

<table>
<thead>
<tr>
<th>OP</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>LA</td>
<td>4, X’800’(12)</td>
<td>Set register 4 to start of first operand</td>
</tr>
<tr>
<td>LA</td>
<td>5, 100</td>
<td>Set register 5 to length of first operand</td>
</tr>
<tr>
<td>LA</td>
<td>8, X’A00’(12)</td>
<td>Set register 8 to start of second operand</td>
</tr>
<tr>
<td>LA</td>
<td>9, 132</td>
<td>Set register 9 to length of second operand</td>
</tr>
<tr>
<td>ICM</td>
<td>9, B’1000’(3)</td>
<td>Insert padding byte in leftmost byte position of register 9</td>
</tr>
</tbody>
</table>

Register pair 4,5 defines the first operand. Bits 8-31 of register 4 contain the storage address of the start of an EBCDIC text string, and bits 8-31 of register 5 contain the length of the string, in this case 100 bytes.

Register pair 8,9 defines the second operand, with bits 8-31 of register 8 containing the starting location of the second operand and bits 8-31 of register 9 containing the length of the second operand, in this case 132 bytes. Bits 0-7 of register 9 contain an EBCDIC blank character (X’40’) to pad the shorter operand. In this example, the padding byte is used in the first operand, after the 100th byte, to compare with the remaining bytes in the second operand.

With the register pairs thus set up, the format of the CLCL instruction is:

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLCL</td>
<td>4, 8</td>
<td></td>
</tr>
</tbody>
</table>

When this instruction is executed, the comparison starts at the left end of each operand and proceeds to the right. The operation ends as soon as an inequality is detected or the end of the longer operand is reached.

If this CLCL instruction is interrupted after 60 bytes have compared equal, the operand lengths in registers 5 and 9 will have been decremented to 40 and 72, respectively. The operand addresses in registers 4 and 8 will have been incremented to X’2083C’ and X’20A3C’; the leftmost byte of registers 4 and 8 will have been set to zero. The padding byte X’40’ remains in register 9. When the CLCL instruction is reexecuted with these register contents, the comparison resumes at the point of interruption.

Now, assume that the instruction is interrupted after 110 bytes. That is, the first 100 bytes of the second operand have compared equal to the first operand, and the next 10 bytes of the second operand have compared equal to the padding byte (blank). The residual operand lengths in registers 5 and 9 are 0 and 22, respectively, and the operand addresses in registers 4 and 8 are X’20864’ (the value when the first operand was exhausted) and X’20A6E’ (the current value for the second operand).

When the comparison ends, the condition code is set to 0, 1, or 2, depending on whether the first operand...
is equal to, less than, or greater than the second operand, respectively.

When the operands are unequal, the addresses in registers 4 and 8 indicate the bytes that caused the mismatch.

**COMPARE LOGICAL STRING (CLST)**

The COMPARE LOGICAL STRING instruction is used to compare a first operand designated by general register $R_1$ and a second operand designated by general register $R_2$. The comparison is made left to right, byte by byte, until unequal bytes are compared, an ending character specified in general register 0 is encountered in either operand, or a CPU-determined number of bytes have been compared. The condition code is set to 0 if the two operands are equal, to 1 if the first operand is low, to 2 if the second operand is low, or to 3 if a CPU-determined number of bytes have been compared. If the ending character is found in both operands simultaneously, the operands are equal. If it is found in only one operand, that operand is low.

When condition code 1 or 2 is set, the addresses of the last bytes processed in the first and second operands are placed in general registers $R_1$ and $R_2$, respectively. These are the addresses of unequal bytes in the two operands, or they are the address of an ending character in one operand and of the byte in the corresponding byte position in the other operand. When condition code 3 is set, the addresses of the next bytes to be processed are placed in the registers. When condition code 0 is set, the contents of the registers remain unchanged.

Following are examples of first and second operands beginning at decimal locations 1000 and 2000, respectively. The addresses in general registers $R_1$ and $R_2$ are 1000 and 2000, respectively. The ending character in general register 0 is 00 hex (as in the C programming language). The values of the operand bytes are shown in hex, and the resulting condition code and final contents of general registers $R_1$ and $R_2$ are shown.

**Example 1**

1000 2000
C1 C2 C3 00  C1 C2 C3 00
CC: 0; (R1): 1000; (R2): 2000

**Example 2**

1000 2000
40 40 40 C1  40 40 40 C2
CC: 1; (R1): 1003; (R2): 2003

**Example 3**

1000 2000
40 40 40 C2  40 40 40 C1
CC: 2; (R1): 1003; (R2): 2003

**Example 4**

1000 2000
C1 C2 C3 00  C1 C2 C3 C4
CC: 1; (R1): 1003; (R2): 2003

**Example 5**

1000 2000
C1 C2 C3 C4  C1 C2 C3 00
CC: 2; (R1): 1003; (R2): 2003

**Example 6**

Assuming that the CPU-determined number of bytes compared is 256:

1000 1256 2000 2256
40 .. 40 00  40 .. 40 00
CC: 3; (R1): 1256; (R2): 2256

**Example 7**

1000 2000
00 40 40 40  40 40 40 40
CC: 1; (R1): 1000; (R2): 2000

**Example 8**

1000 2000
40 40 40 40  00 40 40 40
CC: 2; (R1): 1000; (R2): 2000

**Example 9**

1000 2000
00 40 40 40  00 40 40 40
CC: 0; (R1): 1000; (R2): 2000

**CONVERT TO BINARY (CVB)**

The CONVERT TO BINARY instruction converts an eight-byte, signed-packed-decimal number into a signed binary integer and loads the result into a gen-
eral register. After the conversion operation is completed, the number is in the proper form for use as an operand in signed binary arithmetic. For example, assume:

Storage locations 7608-760F contain a decimal number in the signed-packed-decimal format: 00 00 00 00 25 59 4C (+25,594).

The contents of register 7 are not significant.

Register 13 contains 00 00 76 00.

The format of the conversion instruction is:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁</th>
<th>X₂</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>4F</td>
<td>7</td>
<td>0</td>
<td>0</td>
<td>008</td>
</tr>
</tbody>
</table>

**Assembler Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁, D₂(X₂, B₂)</th>
</tr>
</thead>
<tbody>
<tr>
<td>CVB</td>
<td>7,8(0,13)</td>
</tr>
</tbody>
</table>

After the instruction is executed, register 7 contains 00 00 63 FA.

**CONVERT TO DECIMAL (CVD)**

The CONVERT TO DECIMAL instruction is the opposite of the CONVERT TO BINARY instruction. CVD converts a signed binary integer in a register to signed-packed-decimal number and stores the eight-byte result. For example, assume:

Register 1 contains the signed binary integer: 00 00 0F 0F.

Register 13 contains 00 00 76 00.

The format of the instruction is:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁</th>
<th>X₂</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>4E</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>008</td>
</tr>
</tbody>
</table>

**Assembler Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁, D₂(X₂, B₂)</th>
</tr>
</thead>
<tbody>
<tr>
<td>CVD</td>
<td>1,8(0,13)</td>
</tr>
</tbody>
</table>

After the instruction is executed, storage locations 7608-760F contain 00 00 00 00 03 85 5C (+3855).

The plus sign generated is the preferred plus sign, 1100₂.

**DIVIDE (D, DR)**

The DIVIDE instruction divides the dividend in an even-odd register pair by the divisor in a register or in storage. Since the instruction assumes the dividend to be 64 bits long, it is important first to extend a 32-bit dividend on the left with bits equal to the sign bit. For example, assume that:

Storage locations 3550-3553 contain 00 00 08 DE = 2270₁₀ (the dividend).

Storage locations 3554-3557 contain 00 00 00 32 = 50₁₀ (the divisor).

The initial contents of registers 6 and 7 are not significant.

Register 8 contains 00 00 35 50.

The following assembler-language statements load the registers properly and perform the divide operation:

<table>
<thead>
<tr>
<th>Statement</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>L 6,0(0,8)</td>
<td>Places 00 00 08 DE into register 6.</td>
</tr>
<tr>
<td>SRDA 6,32(0)</td>
<td>Shifts 00 00 08 DE into register 7.</td>
</tr>
<tr>
<td>D 6,4(0,8)</td>
<td>Register 6 is filled with zeros (sign bits).</td>
</tr>
</tbody>
</table>

The plus sign generated is the preferred plus sign, 1100₂.

The machine format of the above DIVIDE instruction is:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁</th>
<th>X₂</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>5D</td>
<td>6</td>
<td>0</td>
<td>8</td>
<td>004</td>
</tr>
</tbody>
</table>

After the instructions listed above are executed:

Register 6 contains 00 00 00 14 = 20₁₀ = the remainder.

Register 7 contains 00 00 00 2D = 45₁₀ = the quotient.
Note that if the dividend had not been first placed in register 6 and shifted into register 7, register 6 might not have been filled with the proper dividend-sign bits (zeros in this example), and the DIVIDE instruction might not have given the expected results.

**EXCLUSIVE OR (X, XC, XI, XR)**

When the Boolean operator EXCLUSIVE OR is applied to two bits, the result is one when either, but not both, of the two bits is one; otherwise, the result is zero. When two bytes are EXCLUSIVE ORed, each pair of bits is handled separately; there is no connection from one bit position to another. The following is an example of the EXCLUSIVE OR of two bytes:

First-operand byte: 0011 0101
Second-operand byte: 0101 1100
Result byte: 0110 1001

**XC Example**

The EXCLUSIVE OR (XC) instruction can be used to exchange the contents of two areas in storage without the use of an intermediate storage area. For example, assume two three-byte fields in storage:

Field 1: 00000000 00010111 10010000
Field 2: 00000000 00010100 00000001

Execution of the instruction (assume that register 7 contains 00 00 03 58):

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L</th>
<th>B₁</th>
<th>D₁</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>D7 02</td>
<td>7</td>
<td>008</td>
<td>7</td>
<td>001</td>
<td></td>
</tr>
</tbody>
</table>

Assembler Format

Op Code D₁(L, B₁), D₂(B₂)

| XC 1(3,7), 8(7) |

produces the following result:

Field 1: 00000000 00000001 10010001 = 00 03 91₁₆
Field 2: 00000000 00010100 00000001 = 00 14 0₁₆
Result: 00000000 00010111 10010000 = 00 17 90₁₆

The result of this operation replaces the former contents of field 2. Field 2 now contains the original value of field 1. Condition code 1 is set to indicate a nonzero result.

Lastly, execution of the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L</th>
<th>B₁</th>
<th>D₁</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>D7 02</td>
<td>7</td>
<td>001</td>
<td>7</td>
<td>008</td>
<td></td>
</tr>
</tbody>
</table>

Assembler Format

Op Code D₁(L, B₁), D₂(B₂)

| XC 1(3,7), 8(7) |

produces the following result:

Field 1: 00000000 00000001 10010001 = 00 03 91₁₆
Field 2: 00000000 00010100 00000001 = 00 14 0₁₆
Result: 00000000 00010111 10010000 = 00 17 90₁₆

The result of this operation replaces the former contents of field 1. Field 1 now contains the original value of field 2. Condition code 1 is set to indicate a nonzero result.
XI Example
A frequent use of the EXCLUSIVE OR (XI) instruction is to invert a bit (change a zero bit to a one or a one bit to a zero). For example, assume that storage location 8082 contains 0110 1001₂. To invert the leftmost and rightmost bits without affecting any of the other bits, the following instruction can be used (assume that register 9 contains 00 00 80 80):

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>I₂</th>
<th>B₁</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>97</td>
<td>81</td>
<td>9</td>
<td>002</td>
</tr>
</tbody>
</table>

Assembler Format

Op Code D₁(B₁),I₂

XI 2(9),X'81'

When the instruction is executed, the byte in storage is EXCLUSIVE ORed with the immediate byte (the I₂ field of the instruction):

Location 8082: 0110 1001₂
Immediate byte: 1000 0001₂

Result: 1110 1000₂

The resulting byte is stored back in location 8082. Condition code 1 is set to indicate a nonzero result.

Notes:

1. With the XC instruction, fields up to 256 bytes in length can be exchanged.
2. With the XR instruction, the contents of two registers can be exchanged.
3. Because the X instruction operates storage to register only, an exchange cannot be made solely by the use of X.
4. A field EXCLUSIVE ORed with itself is cleared to zeros.
5. For additional examples of the use of EXCLUSIVE OR, see “Hexadecimal-Floating-Point-Number Conversion” on page A-44.

EXECUTE (EX)

The EXECUTE instruction causes one target instruction in main storage to be executed out of sequence without actually branching to the target instruction. Unless the R₁ field of the EXECUTE instruction is zero, bits 8-15 of the target instruction are ORed with bits 56-63 of the R₁ register before the target instruction is executed. Thus, EXECUTE may be used to supply the length field for an SS instruction without modifying the SS instruction in storage. For example, assume that a MOVE (MVC) instruction is the target that is located at address 3820, with a format as follows:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L</th>
<th>B₁</th>
<th>D₁</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Assembler Format

Op Code D₁(L,B₁),D₂(B₂)

MVC 3(1,12),0(13)

where register 12 contains 00 00 89 13 and register 13 contains 00 00 90 A0.

Further assume that at storage address 5000, the following EXECUTE instruction is located:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁</th>
<th>X₂</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>44</td>
<td>1</td>
<td>0</td>
<td>A</td>
<td>000</td>
</tr>
</tbody>
</table>

Assembler Format

Op Code R₁,X₂(B₂,B₂)

EX 1,0(0,10)

where register 10 contains 00 00 38 20 and register 1 contains 00 0F F0 03.

When the instruction at 5000 is executed, the rightmost byte of register 1 is ORed with the second byte of the target instruction:

Instruction byte: 0000 0000₂ = 00
Register byte: 0000 0011₂ = 03

Result: 0000 0011₂ = 03

causing the instruction at 3820 to be executed as if it originally were:
Machine Format

Op Code  L   B₁   D₁   B₂   D₂
        02   03   C    003  D    000

Assembler Format

Op Code  D₁(L₁,B₁),D₂(B₂)
        MVC  3(4,12),0(13)

However, after execution:

Register 1 is unchanged.
The instruction at 3820 is unchanged.
The contents of the four bytes starting at location 90A0 have been moved to the four bytes starting at location 8916.
The CPU next executes the instruction at address 5004 (PSW bits 104-127 contain 00 50 04).

FIND LEFTMOST ONE (FLOGR)

FIND LEFTMOST ONE may be used to locate free objects, the availability of which is tracked in a hierarchical bit map.

In the following example, the hierarchical bit map consists of multiple levels of bits, each level having 64 times the number of bits as the next lower-numbered level. This example shows four levels, mapping a total of 16M objects, however additional levels may be added to manage larger numbers of objects.

The highest-numbered bit map level (L3 in this illustration) represents the availability of individual objects, for example, records or pages. A one bit indicates that the object is available, and a zero bit means that the object is not available.

In lower-numbered bit map levels (L0, L1, and L2 in this illustration), a bit position corresponds to a doubleword in the next higher-numbered level. When a bit in a lower-numbered bit map level is one, at least one bit of the corresponding doubleword in the higher-level is one. When a bit in a lower-numbered bit map level is zero, no bits in the corresponding higher-level doubleword are one.

An example of using FIND LEFTMOST ONES to quickly locate the next available lowest-numbered object, as mapped by such a hierarchical bit map, is shown below. Upon completion, at the label "FOUND", general register 15 contains the number of the located object. If no objects are available, the code branches to the label "NOTFND".

```
LA 15,0 Zero accumulator
LA 9,OFFSET Point to table
LA 10,4 Load increment
LA 11,ENOFF-1 Load compare value
FIND LGR 7,15 Copy accum. to R7
ALGF 7,0(,9) Add # DWs to bits
SLLG 7,7,3 Get byte offset
LG 1,BITS(7) Get DW to test
FLOGR 0,1 Find leftmost one
BZ NOTFND No one bits found
SLLG 15,15,6 Times # bits in DW
AGR 15,0 Add bit just found
BXLEG 9,10,FIND Do for each level
FOUND STG 1,BITS(7) Update changed bit
...
NOTFND [Any instruction]
```

OFFSET DC A((L0-BITS)/8) Offset to level 0
DC A((L1-BITS)/8) Offset to level 1
DC A((L2-BITS)/8) Offset to level 2
DC A((L3-BITS)/8) Offset to level 3
ENDOFF EQU * End of table

BITS DS 0D Start of bit map
L0 DS FD -L0 (64 objects)
L1 DS 64FD -L1 (4K objects)
L2 DS (64+64)FD -L2 (256K objects)
L3 DS (64+64+64)FD -L3 (16M objects)

This code sequence shows the zeroing of the found bit with the STORE (STG) instruction at the label "FOUND". Proper maintenance of such a hierarchical bit map requires that when all bits of a doubleword become zeros, the corresponding bit in the next lower-numbered level is set to zeros. Similarly, when adding a free object to the highest level, the corresponding bits in lower-numbered levels must be set to one. These maintenance functions are not shown.

Note, in a multiprocessing environment, access to the bit map is assumed to be serialized for the duration of the update process.
INSERT CHARACTERS UNDER MASK (ICM)

The INSERT CHARACTERS UNDER MASK (ICM) instruction may be used to replace all or selected bytes in a general register with bytes from storage and to set the condition code to indicate the value of the inserted field.

For example, if it is desired to insert a three-byte address from FIELD A into register 5 and leave the leftmost byte of the register unchanged, assume:

Machine Format

\[
\begin{array}{c}
\text{Op Code} \quad R_1, M_3, S_2 \\
\text{BF} \quad 5, 7, * * * *
\end{array}
\]

Assembler Format

\[
\begin{array}{c}
\text{Op Code} \quad R_1, M_3, S_2 \\
\text{ICM} \quad 5, B'0111', \text{FIELD A}
\end{array}
\]

FIELD A: FE DC BA
Register 5 (before): 12 34 56 78
Register 5 (after): 12 FE DC BA
Condition code (after): 1 (leftmost bit of inserted field is one)

As another example:

Machine Format

\[
\begin{array}{c}
\text{Op Code} \quad R_1, M_3, S_2 \\
\text{BF} \quad 6, 9, * * * *
\end{array}
\]

Assembler Format

\[
\begin{array}{c}
\text{Op Code} \quad R_1, M_3, S_2 \\
\text{ICM} \quad 6, B'1001', \text{FIELD B}
\end{array}
\]

FIELD B: 12 34
Register 6 (before): 00 00 00 00
Register 6 (after): 12 00 00 34
Condition code (after): 2 (inserted field is nonzero with leftmost zero bit)

When the mask field contains 1111, the ICM instruction produces the same result as LOAD (L) (provided that the indexing capability of the RX format is not needed), except that ICM also sets the condition code. The condition-code setting is useful when an all-zero field (condition code 0) or a leftmost one bit (condition code 1) is used as a flag.

LOAD (L, LR)

The LOAD instruction takes four bytes from storage or from a general register and place them unchanged into a general register. For example, assume that the four bytes starting with location 21003 are to be loaded into register 10. Initially:

Register 5 contains 00 02 00 00.
Register 6 contains 00 00 10 03.
The contents of register 10 are not significant.
Storage locations 21003-21006 contain 00 00 AB CD.

To load register 10, the RX form of the instruction can be used:

Machine Format

\[
\begin{array}{c}
\text{Op Code} \quad R_1, D_2(X_2, B_2) \\
L \quad 10, 0(5, 6)
\end{array}
\]

Assembler Format

\[
\begin{array}{c}
\text{Op Code} \quad R_1, D_2(X_2, B_2) \\
L \quad 10, 0(5, 6)
\end{array}
\]

After the instruction is executed, register 10 contains 00 00 AB CD.

LOAD ADDRESS (LA)

The LOAD ADDRESS instruction provides a convenient way to place a nonnegative binary integer up to $4095_{10}$ in a register without first defining a constant and then using it as an operand. For example, the following instruction places the number $2048_{10}$ in register 1:

Machine Format

\[
\begin{array}{c}
\text{Op Code} \quad R_1, X_2, B_2, D_2 \\
41 \quad 1 \quad 0 \quad 0 \quad 800
\end{array}
\]
The LOAD ADDRESS instruction can also be used to increment a register by an amount up to 409510 specified in the \(D_2\) field. Depending on the addressing mode, only the rightmost 24 or 31 bits of the sum are retained, however. The leftmost bits of the 32-bit result are set to zeros. For example, assume that register 5 contains 00 12 34 56.

The instruction:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>(R_1)</th>
<th>(X_2)</th>
<th>(B_2)</th>
<th>(D_2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>41</td>
<td>5</td>
<td>0</td>
<td>5</td>
<td>00A</td>
</tr>
</tbody>
</table>

**Assembler Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>(R_1),(D_2)((X_2),(B_2))</th>
</tr>
</thead>
<tbody>
<tr>
<td>LA</td>
<td>5,10(0,5)</td>
</tr>
</tbody>
</table>

adds 10 (decimal) to the contents of register 5 as follows:

Register 5 (old): 00 12 34 56  
\(D_2\) field: 00 00 00 0A  
Register 5 (new): 00 12 34 60

The register may be specified as either \(B_2\) or \(X_2\). Thus, the instruction LA 5,10(5,0) produces the same result.

As the most general example, the instruction LA 6,10(5,4) forms the sum of three values: the contents of register 4, the contents of register 5, and a displacement of 10 and places the 24-bit or 31-bit sum with zeros appended on the left in register 6.

**LOAD HALFWORD (LH)**

The LOAD HALFWORD instruction places unchanged a halfword from storage into the right half of a register. The left half of the register is loaded with zeros or ones according to the sign (leftmost bit) of the halfword.

For example, assume that the two bytes in storage locations 1803-1804 are to be loaded into register 6. Also assume:

- The contents of register 6 are not significant.
- Register 14 contains 00 00 18 03.
- Locations 1803-1804 contain 00 20.

The instruction required to load the register is:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>(R_1)</th>
<th>(X_2)</th>
<th>(B_2)</th>
<th>(D_2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>48</td>
<td>6</td>
<td>0</td>
<td>E</td>
<td>000</td>
</tr>
</tbody>
</table>

**Assembler Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>(R_1),(D_2)((X_2),(B_2))</th>
</tr>
</thead>
<tbody>
<tr>
<td>LH</td>
<td>6,0(0,14)</td>
</tr>
</tbody>
</table>

After the instruction is executed, register 6 contains 00 00 00 20. If locations 1803-1804 had contained a negative number, for example, A7 B6, a minus sign would have been propagated to the left, giving FF FF A7 B6 as the final result in register 6.

**MOVE (MVC, MVI)**

**MVC Example**

The MOVE (MVC) instruction can be used to move data from one storage location to another. For example, assume that the following two fields are in storage:

Field 2048:

<table>
<thead>
<tr>
<th>2052</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
</tr>
<tr>
<td>C1 C2 C3 C4 C5 C6 C7 C8 CA CB</td>
</tr>
</tbody>
</table>

Field 3840:

<table>
<thead>
<tr>
<th>3848</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
</tr>
<tr>
<td>F1 F2 F3 F4 F5 F6 F7 F8 F9</td>
</tr>
</tbody>
</table>

Also assume:

- Register 1 contains 00 00 20 48.
- Register 2 contains 00 00 38 40.

With the following instruction, the first eight bytes of field 2 replace the first eight bytes of field 1:
Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L</th>
<th>B₁</th>
<th>D₁</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>D2</td>
<td>07</td>
<td>1</td>
<td>000</td>
<td>2</td>
<td>000</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>D₁(L,B₁),D₂(B₂)</th>
</tr>
</thead>
<tbody>
<tr>
<td>MVC</td>
<td>0(8,1),0(2)</td>
</tr>
</tbody>
</table>

After the instruction is executed, field 1 becomes:

Field 2 is unchanged.

MVC can also be used to propagate a byte through a field by starting the first-operand field one byte location to the right of the second-operand field. For example, suppose that an area in storage starting with address 358 contains the following data:

<table>
<thead>
<tr>
<th>Location</th>
<th>Data</th>
</tr>
</thead>
<tbody>
<tr>
<td>358</td>
<td>00</td>
</tr>
<tr>
<td>359</td>
<td>F1</td>
</tr>
<tr>
<td>360</td>
<td>F2</td>
</tr>
</tbody>
</table>

With the following MVC instruction, the zeros in location 358 can be propagated throughout the entire field (assume that register 11 contains 00 00 03 58):

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L</th>
<th>B₁</th>
<th>D₁</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>D2</td>
<td>07</td>
<td>1</td>
<td>000</td>
<td>2</td>
<td>000</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>D₁(L,B₁),D₂(B₂)</th>
</tr>
</thead>
<tbody>
<tr>
<td>MVC</td>
<td>1(8,11),0(11)</td>
</tr>
</tbody>
</table>

Because MVC is executed as if one byte were processed at a time, the above instruction, in effect, takes the byte at address 358 and stores it at 359 (359 now contains 00), takes the byte at 359 and stores it at 35A, and so on, until the entire field is filled with zeros. Note that an MVI instruction could have been used originally to place the byte of zeros in location 358.

Notes:

1. Although the field occupying locations 358-360 contains nine bytes, the length coded in the assembler format is equal to the number of moves (one less than the field length).

2. The order of operands is important even though only one field is involved.

**MVI Example**

The MOVE (MVI) instruction places one byte of information from the instruction stream into storage. For example, the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>I₂</th>
<th>B₁</th>
<th>D₁</th>
</tr>
</thead>
<tbody>
<tr>
<td>92</td>
<td>5B</td>
<td>1</td>
<td>000</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>D₁(B₁),I₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>MVC</td>
<td>0(1),C'$'$</td>
</tr>
</tbody>
</table>

may be used, in conjunction with the instruction EDIT AND MARK, to insert the EBCDIC code for a dollar symbol at the storage address contained in general register 1 (see also the example for EDIT AND MARK).

**MOVE INVERSE (MVCIN)**

The MOVE INVERSE (MVCIN) instruction can be used to move data from one storage location to another while reversing the order of the bytes within the field. For example, assume that the following two fields are in storage:

<table>
<thead>
<tr>
<th>Field 1</th>
<th>2048</th>
<th>2052</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>C1</td>
<td>C2</td>
</tr>
<tr>
<td></td>
<td>C3</td>
<td>C4</td>
</tr>
<tr>
<td></td>
<td>C5</td>
<td>C6</td>
</tr>
<tr>
<td></td>
<td>C7</td>
<td>C8</td>
</tr>
<tr>
<td></td>
<td>C9</td>
<td>CA</td>
</tr>
<tr>
<td></td>
<td>CB</td>
<td></td>
</tr>
</tbody>
</table>

Also assume:

- Register 1 contains 00 00 20 48.
- Register 2 contains 00 00 38 40.

With the following instruction, the first eight bytes of field 2 replace the first eight bytes of field 1:
After the instruction is executed, field 1 becomes:

<table>
<thead>
<tr>
<th>Field</th>
<th>2048</th>
<th>2052</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>F8 F7 F6 F5 F4 F3 F2 F1 C9 CA CB</td>
<td></td>
</tr>
</tbody>
</table>

Field 2 is unchanged.

**Note:** This example uses the same general registers, storage locations, and original values as the first example for MVC. For MVCIN, the second-operand address must designate the rightmost byte of the field to be moved, in this case location 3847. This is accomplished by means of the 7 in the D2 field of the instruction.

### MOVE LONG (MVCL)

The MOVE LONG (MVCL) instruction can be used for moving data in storage as in the first example of the MVC instruction, provided that the two operands do not overlap. MVCL differs from MVC in that the address and length of each operand are specified in an even-odd pair of general registers. Consequently, MVCL can be used to move more than 256 bytes of data with one instruction. As an example, assume:

Register 2 contains 00 0A 00 00.
Register 3 contains 00 00 08 00.
Register 8 contains 00 06 00 00.
Register 9 contains 00 00 08 00.

Execution of the instruction:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>E8</td>
<td>07</td>
<td>1</td>
</tr>
</tbody>
</table>

**Assembler Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>D1(L,B1),D2(B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>MVCIN</td>
<td>0(8,1),7(2)</td>
</tr>
</tbody>
</table>

If register 3 had contained F0 00 04 00, only the 1,024 bytes from locations A0000-A03FF would have been moved to locations 60000-603FF. The remaining locations 60400-607FF of the first operand would have been filled with 1,024 copies of the padding byte X’F0’, as specified by the leftmost byte of register 3. Bits 8-31 of register 2 would have been incremented by 40016, bits 8-31 of register 8 would have been incremented by 80016, and bits 0-7 of registers 2 and 8 would have been set to zeros. Bits 8-31 of registers 3 and 9 would still have been decremented to zero. Condition code 2 would have been set to indicate that the first operand is longer than the second.

Instead, MVCL may be used to clear a storage area to zeros as follows. Assume register 8 and 9 are set up as before. Register 3 contains only zeros, specifying zero length for the second operand and a zero padding byte. Register 2 is not used to access storage, and its contents are not significant. Executing the instruction MVCL 8,2 causes locations 60000-607FF to be filled with zeros. Bits 8-31 of register 8 are incremented by 80016, and bits 0-7 of registers 2 and 8 are set to zeros. Bits 8-31 of register 9 are decremented to zero, and condition code 2 is set to indicate that the first operand is longer than the second.

### MOVE NUMERICS (MVN)

Two related instructions, MOVE NUMERICS and MOVE ZONES, may be used with decimal data in the zoned format to operate separately on the rightmost
four bits (the numeric bits) and the leftmost four bits (the zone bits) of each byte. Both are similar to MOVE (MVC), except that MOVE NUMERIC moves only the numeric bits and MOVE ZONES moves only the zone bits.

To illustrate the operation of the MOVE NUMERIC instruction, assume that the following two fields are in storage:

Field A

<table>
<thead>
<tr>
<th>7090</th>
<th>7093</th>
</tr>
</thead>
<tbody>
<tr>
<td>C6</td>
<td>C7</td>
</tr>
<tr>
<td>C8</td>
<td>C9</td>
</tr>
</tbody>
</table>

Field B

<table>
<thead>
<tr>
<th>7041</th>
<th>7046</th>
</tr>
</thead>
<tbody>
<tr>
<td>F0</td>
<td>F1</td>
</tr>
<tr>
<td>F2</td>
<td>F3</td>
</tr>
<tr>
<td>F4</td>
<td>F5</td>
</tr>
</tbody>
</table>

Also assume:

Register 14 contains 00 00 70 90.
Register 15 contains 00 00 70 40.

After the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L</th>
<th>B1</th>
<th>D1</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>D1</td>
<td>03</td>
<td>F</td>
<td>001</td>
<td>E</td>
<td>000</td>
</tr>
</tbody>
</table>

Assembler Format

Op Code: D1(B1),D2(B2)

MVN 1(4,15),0(14)

is executed, field B becomes:

<table>
<thead>
<tr>
<th>7041</th>
<th>7046</th>
</tr>
</thead>
<tbody>
<tr>
<td>F6</td>
<td>F7</td>
</tr>
<tr>
<td>F8</td>
<td>F9</td>
</tr>
<tr>
<td>F4</td>
<td>F5</td>
</tr>
</tbody>
</table>

The numeric bits of the bytes at locations 7090-7093 have been stored in the numeric bits of the bytes at locations 7041-7044. The contents of locations 7090-7093 and 7045-7046 are unchanged.

### MOVE STRING (MVST)

The MOVE STRING instruction is used to move a second operand designated by general register R2 to a first-operand location designated by general register R1. The movement is made left to right until an ending character specified in general register 0 has been moved or a CPU-determined number of bytes have been moved. The condition code is set to 1 if the ending character was moved or to 3 if a CPU-determined number of bytes were moved.

When condition code 1 is set, the address of the ending character in the first operand is placed in general register R1, and the contents of general register R2 remain unchanged. When condition code 3 is set, the address of the next byte to be processed in the first and second operands is placed in general registers R1 and R2, respectively.

Following is an example program that sets string A equal to the concatenation of string B followed by string C, where the length of each of strings B and C is unknown, and the end of each of strings B and C is indicated by an ending character of 00 hex (as in the C programming language). The program is not written for execution in the access-register mode.

MOVE WITH OFFSET (MVO)

MOVE WITH OFFSET may be used to shift a signed-packed-decimal number an odd number of digit positions or to concatenate a sign to an unsigned-packed-decimal number.

Assume that the three-byte unsigned-packed-decimal number in storage locations 4500-4502 is to be moved to locations 5600-5603 and given the sign of the signed-packed-decimal number ending at location 5603. Also assume:

Register 12 contains 00 00 56 00.
Register 15 contains 00 00 45 00.

Storage locations 5600-5603 contain 77 88 99 0C.
Storage locations 4500-4502 contain 12 34 56.

After the instruction:
MVO is executed, the storage locations 5600-5603 contain 01 23 45 6C. Note that the second operand is extended on the left with one zero to fill out the first-operand field.

MOVE ZONES (MVZ)

The MOVE ZONES instruction can operate on overlapping or nonoverlapping fields, as can the instructions MOVE (MVC) and MOVE NUMERICS. When operating on nonoverlapping fields, MOVE ZONES works like the MOVE NUMERICS instruction (see its example), except that MOVE ZONES moves only the zone bits of each byte. To illustrate the use of MOVE ZONES with overlapping fields, assume that the following data field is in storage:

Also assume that register 15 contains 00 00 08 00. The instruction:

After the instruction is executed, the product is in the register pair 4 and 5:

Register 4 contains 00 00 00 00.
Register 5 contains 00 00 4E CE = 20,17410.
Storage locations 3750-3753 are unchanged.

The RR format of the instruction can be used to square the number in a register. Assume that register 7 contains 00 01 00 05. The contents of register 6 are not significant. The instruction:

After the instruction is executed, the product is in the register pair 4 and 5:

Also assume that register 15 contains 00 00 08 00. The instruction:

The instruction required for performing the multiplication is:

The contents of register 4 are not significant.
Register 5 contains 00 00 00 9A = 15410 = the multiplicand.
Register 11 contains 00 00 06 00.
Register 12 contains 00 00 30 00.
Storage locations 3750-3753 contain 00 00 00 83 = 13110 = the multiplier.

The instruction required for performing the multiplication is:
multiplies the number in register 7 by itself and places the result in the pair of registers 6 and 7:

Register 6 contains 00 00 00 01.
Register 7 contains 00 0A 00 19.

MULTIPLY HALFWORD (MH)

The MULTIPLY HALFWORD instruction is used to multiply the contents of a register by a two-byte field in storage. For example, assume that:

Register 11 contains 00 00 00 15 =21_{10} = the multiplicand.
Register 14 contains 00 00 01 00.
Register 15 contains 00 00 20 00.
Storage locations 2102-2103 contain FF D9 = -39_{10} = the multiplier.

The instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, D2(X2, B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>MH</td>
<td>11,2(14,15)</td>
</tr>
</tbody>
</table>

multiplies the two numbers. The product, FF FF FC CD = -819_{10}, replaces the original contents of register 11.

Only the rightmost 32 bits of a product are stored in a register; any significant bits on the left are lost. No program interruption occurs on overflow.

OR (O, OC, OI, OR)

When the Boolean operator OR is applied to two bits, the result is one when either bit is one; otherwise, the result is zero. When two bytes are ORed, each pair of bits is handled separately; there is no connection from one bit position to another. The following is an example of ORing two bytes:

First-operand byte: 0011 0101_2
Second-operand byte: 0101 1100_2
Result byte: 0111 1101_2

OI Example

A frequent use of the OR instruction is to set a particular bit to one. For example, assume that storage location 4891 contains 0100 0010_2. To set the rightmost bit of this byte to one without affecting the other bits, the following instruction can be used (assume that register 8 contains 00 00 48 90):

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>I2, B1, D1</th>
</tr>
</thead>
<tbody>
<tr>
<td>OI</td>
<td>1(8), X'01'</td>
</tr>
</tbody>
</table>

When this instruction is executed, the byte in storage is ORed with the immediate byte (the I2 field of the instruction):

Location 4891: 0100 0010_2
Immediate byte: 0000 0001_2
Result: 0100 0011_2

The resulting byte with bit 7 set to one is stored back in location 4891. Condition code 1 is set.

PACK (PACK)

Assume that storage locations 1000-1003 contain the following zoned-decimal number that is to be converted to a signed-packed-decimal number and left in the same location:

```
Zoned number: F1 F2 F3 CA
```

Also assume that register 12 contains 00 00 10 00. After the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L1, L2, B1, D1, B2, D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>F2</td>
<td>3 3 C 000 C 000</td>
</tr>
</tbody>
</table>

A-29
Assembler Format
Op Code   \(D_1(L_1,B_1),D_2(L_2,B_2)\)

PACK   \(0(4,12),0(4,12)\)

is executed, the result in locations 1000-1003 is in
the signed-packed-decimal format:

Signed-packed number  \[0001234C\]

Notes:
1. This example illustrates the operation of PACK
   when the first- and second-operand fields overlap
   completely.
2. During the operation, the second operand was
   extended on the left with zeros.

ROTATE THEN EXCLUSIVE OR
SELECTED BITS

The following example illustrates the use of ROTATE
THEN EXCLUSIVE OR SELECTED BITS to deter-
mine if the access-control bits of a page’s storage-
protection key match the key in the PSW. In this
example, only the condition code is set; the result
is not placed in the first-operand register.

LAY 9,BLOCK Point to storage block.
IVSK 14,9 Insert key into bits 56-63.
EPSW 4,0 Extract PSW key (bits 40-43).
RXSBG 4,14,128+40,43,16 Compare keys.

On completion, the condition code will be set to zero
if the PSW key matches the access-control bits in the
storage key of page addressed by general register 9.
Condition code 1 will be set if the keys do not match.

ROTATE THEN INSERT SELECTED
BITS

1. The following example illustrates the use of ROTATE
   THEN INSERT SELECTED BITS to extract the various DAT-table indices of a virtual
   address contained in general register 8. This
   example shows the use of the zero-remaining-
   bits control to set the remaining bits of the result
   registers to zero.

The virtual address in general register 8 is
assumed to be 123456789ABCDEF0 hex.

RISBG 1,8,53,128+63,11 Get reg. 1st index.
RISBG 2,8,53,128+63,22 Get reg. 2nd index.
RISBG 3,8,53,128+63,33 Get reg. 3rd index.
RISBG 4,8,53,128+63,44 Get segment index.
RISBG 5,8,56,128+63,52 Get page index.
RISBG 6,8,52,128+63,0 Get byte index.

The condition code following each RISBG is 2.
On completion, general registers 1-6 contain the
region-first index, region-second index, region-
third index, segment index, page index, and byte
index, respectively, as follows:

GR1: 0000000000000091 (RFX)
GR2: 00000000000000515 (RSX)
GR3: 0000000000000004F1 (RTX)
GR4: 000000000000001AB (SX)
GR5: 0000000000000000CD (PX)
GR6: 0000000000000000EF0 (BX)

2. The following example illustrates shifting a 64-bit
   value to the left by \(L\) bits:

RISBG R,0,0,X’80’+63,-\(L\)

3. The following example illustrates shifting a 32-bit
   value to the right by \(R\) bits and setting the left-
   most 32 bits to zero:

RISBG R,32+R,0,X’80’+63,-\(R\)

4. The following example illustrates zeroing bits \(S\)
   through \(E\) of general register 3.

RISBG 3,mod64(E+1),128+mod64(S-1),0

\(Mod64\) represents a modulo function which
effectively ANDs the value in parentheses with
3F hex.

ROTATE THEN OR SELECTED BITS

The following example illustrates the use of ROTATE
THEN OR SELECTED BITS to rotate and combine
selected bits of general registers 6 and 8.

LG 6,=X’004C487040CF4600’
LG 8,=X’C07FAF37FC968280’
ROSBG 6,8,54,32
On completion, condition code 1 is set, and general register 6 is as follows:

GR6: 00DECAF0C0FFEE00

Note that only bits 8-54 of the registers are ORed; bits 0-7 and 55-63 of general register 6 are not modified.

**SEARCH STRING (SRST)**

The SEARCH STRING instruction is used to search a second operand designated by general register R₂ for a character specified in general register 0. The length of the second operand is known — the address of the first byte after the second operand is in general register R₁.

When the specified character is found, condition code 1 is set, the address of the character is placed in general register R₁, and the contents of general register R₂ remain unchanged. When the address of the next second-operand byte to be examined equals the address in general register R₁, condition code 2 is set, and the contents of general register R₁ and R₂ remain unchanged. When a CPU-determined number of second-operand bytes have been examined, condition code 3 is set, the address of the next byte to be processed in the second operand is placed in general register R₂, and the contents of general register R₁ remain unchanged.

**SRST Example 1**

Following is an example program that determines the end of string A, as indicated by an ending character equal to 00 hex (as in the C programming language), and then determines the address of the first character equal to C1 hex in the string. The program is not written for execution in the access-register mode.

```assembly
L 5,STRAADR
SR 0,0
LOOPO SRST 0,5
BC 1,LOOPO
L 5,STRAADR
LR 4,0
LA 0,X'C1'
```

**SRST Example 2**

Following is an example program that determines the address of the first character equal to C1 hex in the string A whose length is known. The program is not written for execution in the access-register mode.

```assembly
L 5,STRAADR
L 4,STRALEN
AR 4,5
LA 0,X'C1'
LOOPO SRST 4,5
BC 1,LOOPO
BC 2,NOTFND
FOUND [Any instruction]
...
NOTFND [Any instruction]
```

In this example, the value in STRALEN may be a length that either does or does not include an ending character at the end of the string, provided that the ending character is not the character for which the search is made.

**SHIFT LEFT DOUBLE (SLDA)**

The SHIFT LEFT DOUBLE instruction shifts the 63 numeric bits of an even-odd register pair to the left, leaving the sign bit unchanged. Thus, the instruction performs an algebraic left shift of a 64-bit signed binary integer.

For example, if the contents of registers 2 and 3 are:

```
00 7F 0A 72   FE DC BA 98 =
00000000 01111111 00001010 01110010
11111110 11011100 10111010 100110002
```

The instruction:

```
```

<table>
<thead>
<tr>
<th>Machine Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>Op Code R₂ B₂ D₂</td>
</tr>
<tr>
<td>8F 2 ///// 0 01F</td>
</tr>
</tbody>
</table>

A-31
results in registers 2 and 3 both being left-shifted 31 bit positions, so that their new contents are:

```
7F 6E 5D 4C 00 00 00 00 = 01111111 01101110 01011101 01001100
00000000 00000000 00000000 00000000
```

Because significant bits are shifted out of bit position 1 of register 2, overflow is indicated by setting condition code 3, and, if the fixed-point-overflow mask bit in the PSW is one, a fixed-point-overflow program interruption occurs.

**SHIFT LEFT SINGLE (SLA)**

The SHIFT LEFT SINGLE instruction is similar to SHIFT LEFT DOUBLE, except that it shifts only the 31 numeric bits of a single register. Therefore, this instruction performs an algebraic left shift of a 32-bit signed binary integer.

For example, if the contents of register 2 are:

```
00 7F 0A 72 = 00000000 01111111 00001010 01110010
```

The instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, B2, D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>BE</td>
<td>8, 7</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, D2(B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>SLA</td>
<td>2, 8(0)</td>
</tr>
</tbody>
</table>

results in register 2 being shifted left eight bit positions so that its new contents are:

```
7F 0A 72 00 = 01111111 00001010 01110010 00000000
```

Condition code 2 is set to indicate that the result is greater than zero.

If a left shift of nine places had been specified, a significant bit would have been shifted out of bit position 1. Condition code 3 would have been set to indicate this overflow and, if the fixed-point-overflow mask bit in the PSW were one, a fixed-point overflow interruption would have occurred.

**STORE CHARACTERS UNDER MASK (STCM)**

STORE CHARACTERS UNDER MASK (STCM) may be used to place selected bytes from a register into storage. For example, if it is desired to store a three-byte address from general register 8 into location FIELD3, assume:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, M3, S2</th>
</tr>
</thead>
<tbody>
<tr>
<td>STCM</td>
<td>8, B'0111', FIELD3</td>
</tr>
</tbody>
</table>

Register Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, M3, S2</th>
</tr>
</thead>
<tbody>
<tr>
<td>STCM</td>
<td>8, B'0111', FIELD3</td>
</tr>
</tbody>
</table>

Register 8: 12 34 56 78
FIELD3 (before): not significant
FIELD3 (after): 34 56 78

As another example:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, M3, S2</th>
</tr>
</thead>
<tbody>
<tr>
<td>STCM</td>
<td>9, B'0101', FIELD2</td>
</tr>
</tbody>
</table>

Register Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, M3, S2</th>
</tr>
</thead>
<tbody>
<tr>
<td>STCM</td>
<td>9, B'0101', FIELD2</td>
</tr>
</tbody>
</table>

Register 9: 01 23 45 67
FIELD2 (before): not significant
FIELD2 (after): 23 67

**STORE MULTIPLE (STM)**

Assume that the contents of general registers 14, 15, 0, and 1 are to be stored in consecutive four-byte fields starting with location 4050 and that:

```
Register 14 contains 00 00 25 63.
```
Register 15 contains 00 01 27 36.
Register 0 contains 12 43 00 62.
Register 1 contains 73 26 12 57.
Register 6 contains 00 00 40 00.
The initial contents of locations 4050-405F are not significant.

The STORE MULTIPLE instruction allows the use of just one instruction to store the contents of the four registers:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R3</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>90</td>
<td>E</td>
<td>1</td>
<td>6</td>
<td>050</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, R3, D2(B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>STM</td>
<td>14, 1, X'50'(6)</td>
</tr>
</tbody>
</table>

After the instruction is executed:

- Locations 4050-4053 contain 00 00 25 63.
- Locations 4054-4057 contain 00 01 27 36.
- Locations 4058-405B contain 12 43 00 62.
- Locations 405C-405F contain 73 26 12 57.

TEST UNDER MASK (TM)

The TEST UNDER MASK instruction examines selected bits of a byte and sets the condition code accordingly. For example, assume that:

- Storage location 9999 contains FB.
- Register 7 contains 00 00 99 90.

Assume the instruction to be:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>I2</th>
<th>B1</th>
<th>D1</th>
</tr>
</thead>
<tbody>
<tr>
<td>91</td>
<td>C3</td>
<td>7</td>
<td>009</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>D1(B1), I2</th>
</tr>
</thead>
<tbody>
<tr>
<td>TM</td>
<td>9(7), B'11000011'</td>
</tr>
</tbody>
</table>

The instruction tests only those bits of the byte in storage for which the mask bits are ones:

- FB = 1111 10112
- Mask = 1100 00112
- Test = 11xx xx112

Condition code 3 is set: all selected bits in the test result are ones. (The bits marked “x” are ignored.)

If location 9999 had contained B9, the test would have been:

- B9 = 1011 10012
- Mask = 1100 00112
- Test = 10xx xx012

Condition code 1 is set: the selected bits are both zeros and ones.

If location 9999 had contained 3C, the test would have been:

- 3C = 0011 11002
- Mask = 1100 00112
- Test = 00xx xx002

Condition code 0 is set: all selected bits are zeros.

Note: Storage location 9999 remains unchanged.

TRANSLATE (TR)

The TRANSLATE instruction can be used to translate data from any character code to any other desired code, provided that each character code consists of eight bits or fewer. An appropriate translation table is required in storage.

In the following example, EBCDIC code is translated to ASCII code. The first step is to create a 256-byte table in storage locations 1000-10FF. This table contains the characters of the ASCII code in the sequence of the binary representation of the EBCDIC code; that is, the ASCII representation of a
character is placed in storage at the starting address of the table plus the binary value of the EBCDIC representation of the same character.

For simplicity, the example shows only the part of the table containing the decimal digits:

```
<table>
<thead>
<tr>
<th>DC</th>
<th>L</th>
<th>B1</th>
<th>D1</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>03</td>
<td>C</td>
<td>000</td>
<td>F</td>
<td>000</td>
<td></td>
</tr>
</tbody>
</table>
```

Assume that the four-byte field at storage location 2100 contains the EBCDIC code for the digits 1984:

Locations 2100-2103 contain F1 F9 F8 F4.

Register 12 contains 00 00 21 00.

Register 15 contains 00 00 10 00.

As the instruction:

```
Machine Format
Op Code  D1(L,B1),D2(B2)
```

```
Assembler Format
Op Code  D1(L,B1),D2(B2)
```

is executed, the binary value of each EBCDIC byte is added to the starting address of the table, and the resulting address is used to fetch an ASCII byte:

Table starting address: 1000
First EBCDIC byte: F1
Address of ASCII byte: 10F1

After execution of the instruction:

Locations 2100-2103 contain 31 39 38 34.

Thus, the ASCII code for the digits 1984 has replaced the EBCDIC code in the four-byte field at storage location 2100.

**TRANSLATE AND TEST (TRT)**

The TRANSLATE AND TEST instruction can be used to scan a data field for characters with a special meaning. To indicate which characters have a special meaning, a table similar to the one used for the TRANSLATE instruction is set up, except that zeros in the table indicate characters without any special meaning and nonzero values indicate characters with a special meaning.

Figure A-4 on page A-34 has been set up to distinguish alphabetic characters (A to Z and 0 to 9) from blanks, certain special symbols, and all other characters which are considered invalid. EBCDIC coding is assumed. The 256-byte table is assumed stored at locations 2000-20FF.

Note: If the character codes in the statement being translated occupy a range smaller than 00 through FF₁₆, a table of fewer than 256 bytes can be used.

**Figure A-4. Translate and Test Table**

The table entries for the alphabetic characters in EBCDIC are 00; thus, the letter A (code C1) corresponds to byte location 20C1, which contains 00.

The 15 special symbols have nonzero entries from 0₄₁₆ to 3C₁₆ in increments of 4. Thus, the blank (code 40) has the entry 0₄₁₆, the period (code 4B) has the entry 0₈₁₆, and so on.

All other table positions have the entry 40₁₆ to indicate an invalid character.

The table entries are chosen so that they may be used to select one of a list of 16 words containing

```
<table>
<thead>
<tr>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>A</th>
<th>B</th>
<th>C</th>
<th>D</th>
<th>E</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>200</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>201</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>202</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>203</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>204</td>
<td>04</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>08</td>
<td>40</td>
<td>0C</td>
<td>10</td>
<td>40</td>
</tr>
<tr>
<td>205</td>
<td>14</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>18</td>
<td>1C</td>
<td>20</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>206</td>
<td>24</td>
<td>28</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>2C</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>207</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>30</td>
<td>34</td>
<td>38</td>
<td>3C</td>
<td>40</td>
</tr>
<tr>
<td>208</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>209</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>20A</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>20B</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>20C</td>
<td>40</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
</tr>
<tr>
<td>20D</td>
<td>40</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
</tr>
<tr>
<td>20E</td>
<td>40</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
</tr>
<tr>
<td>20F</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
</tr>
</tbody>
</table>
addresses of different routines to be entered for each special symbol or invalid character encountered during the scan.

Assume that this list of 16 branch addresses is stored at locations 3004-3043.

Starting at storage location CA80, there is the following sequence of 21,10 EBCDIC characters, where “b” stands for a blank.

Locations CA80-CA94:
UNPKbPROUT(9),WORD(5)

Also assume:
Register 1 contains 00 00 CA 7F.
Register 2 contains 00 00 30 00.
Register 15 contains 00 00 20 00.

As the instruction:
Machine Format
Op Code  D1(L,B1),D2(B2)
Assembler Format
Op Code  D1(L,B1),D2(B2)

is executed, the value of the first source byte, the EBCDIC code for the letter U, is added to the starting address of the table to produce the address of the table entry to be examined:

Table starting address      2000
Source byte (U)         E4
—————————————————–
Address of table entry      20E4

Because zeros were placed in storage location 20E4, no special action occurs. The operation continues with the second and subsequent source bytes until it reaches the blank in location CA84. When this symbol is reached, its value is added to the starting address of the table, as usual:

UNPACK (UNPK)

Assume that storage locations 2501-2502 contain a signed-packed-decimal number that is to be unpacked and placed in storage locations 1000-1004. Also assume:
Register 12 contains 00 00 10 00.
Register 13 contains 00 00 25 00.
Storage locations 2501-2502 contain 12 3D.
The initial contents of storage locations 1000-1004 are not significant.

After the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L1</th>
<th>L2</th>
<th>B1</th>
<th>D1</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>F3</td>
<td>4</td>
<td>1</td>
<td>C</td>
<td>000</td>
<td>D</td>
<td>001</td>
</tr>
</tbody>
</table>

Assembler Format

Op Code \( D_1(L_1,B_1),D_2(L_2,B_2) \)

UNPK \( 0(5,12),1(2,13) \)

is executed, the storage locations 1000-1004 contain F0 F0 F1 F2 D3.

**UPDATE TREE (UPT)**

See “Sorting Instructions” on page A-53.

---

**Decimal Instructions**

(See Chapter 8, “Decimal Instructions” for a complete description of the decimal instructions.)

**ADD DECIMAL (AP)**

Assume that the signed-packed-decimal number at storage locations 500-503 is to be added to the signed-packed-decimal number at locations 2000-2002. Also assume:

Register 12 contains 00 00 06 00.
Register 13 contains 00 00 03 00.
Storage locations 700-703 contain 17 25 35 6D.
Storage locations 500-502 contain 72 14 2D.

After the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L1</th>
<th>L2</th>
<th>B1</th>
<th>D1</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>FA</td>
<td>2</td>
<td>3</td>
<td>C</td>
<td>000</td>
<td>0</td>
<td>000</td>
</tr>
</tbody>
</table>

Assembler Format

Op Code \( D_1(L_1,B_1),D_2(L_2,B_2) \)

\( AP \ 0(3,12),0(4,13) \)

is executed, the storage locations 2000-2002 contain 73 88 5C; condition code 2 is set to indicate that the result is greater than zero. Note that:

1. Because the two numbers had different signs, they were in effect subtracted.
2. Although the second operand is longer than the first operand, no overflow interruption occurs because the result can be entirely contained within the first operand.

**COMPARE DECIMAL (CP)**

Assume that the signed-packed-decimal contents of storage locations 700-703 are to be algebraically compared with the signed-packed-decimal contents of locations 500-502. Also assume:

Register 12 contains 00 00 06 00.
Register 13 contains 00 00 03 00.
Storage locations 700-703 contain 17 25 35 6D.
Storage locations 500-502 contain 72 14 2D.

After the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L1</th>
<th>L2</th>
<th>B1</th>
<th>D1</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>F9</td>
<td>3</td>
<td>2</td>
<td>C</td>
<td>100</td>
<td>D</td>
<td>200</td>
</tr>
</tbody>
</table>

Assembler Format

Op Code \( D_1(L_1,B_1),D_2(L_2,B_2) \)

\( CP \ X'100' (4,12),X'200' (3,13) \)

is executed, condition code 1 is set, indicating that the first operand (the contents of locations 700-703) is less than the second.
DIVIDE DECIMAL (DP)

Assume that the signed-packed-decimal number at storage locations 2000-2004 (the dividend) is to be divided by the signed-packed-decimal number at locations 3000-3001 (the divisor). Also assume:

Register 12 contains 00 00 20 00.
Register 13 contains 00 00 30 00.
Storage locations 2000-2004 contain 01 23 45 67 8C.
Storage locations 3000-3001 contain 32 1D.

After the instruction:

Machine Format

Assembler Format

Op Code  D1(L1,B1),D2(L2,B2)

DP    0(5,12),0(2,13)

is executed, the dividend is entirely replaced by the signed quotient and remainder, as follows:

Notes:

1. Because the dividend and divisor have different signs, the quotient receives a negative sign.
2. The remainder receives the sign of the dividend and the length of the divisor.
3. If an attempt were made to divide the dividend by the one-byte field at location 3001, the quotient would be too long to fit within the four bytes allotted to it. A decimal-divide exception would exist, causing a program interruption.

EDIT (ED)

Before data in the signed-packed-decimal or unsigned-packed-decimal format can be used in a printed report, digits and signs must be converted to printable characters. Moreover, punctuation marks, such as commas and decimal points, may have to be inserted in appropriate places. The highly flexible EDIT instruction performs these functions in a single instruction execution.

This example shows step-by-step one way that the EDIT instruction can be used. The field to be edited (the source) is four bytes long; it is edited against a pattern 13 bytes long. The following symbols are used:

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>b</td>
<td>Blank character</td>
</tr>
<tr>
<td>d(21)</td>
<td>Significance starter</td>
</tr>
<tr>
<td>d(20)</td>
<td>Digit selector</td>
</tr>
</tbody>
</table>

Assume that register 12 contains:

00 00 10 00

and that the source and pattern fields are:

Source

1200 1203

Pattern

1000 100C

Execution of the instruction:

Machine Format

Assembler Format

Op Code  D1(L1,B1),D2(L2,B2)

ED    0(13,12),X’200'(12)

alters the pattern field as follows:
Thus, after the instruction is executed, the pattern field contains the result as follows:

<table>
<thead>
<tr>
<th>Pattern</th>
<th>Digit</th>
<th>Significance Indicator (Before/After)</th>
<th>Rule</th>
<th>Location 1000-100C</th>
</tr>
</thead>
<tbody>
<tr>
<td>b</td>
<td>0</td>
<td>off/off</td>
<td>leave(1)</td>
<td>bdd,d(d.ddbCR</td>
</tr>
<tr>
<td>d</td>
<td>0</td>
<td>off/off</td>
<td>fill</td>
<td>bbd,d(d.ddbCR</td>
</tr>
<tr>
<td>d</td>
<td>2</td>
<td>off/on(2)</td>
<td>digit</td>
<td>bb2,d(d.ddbCR</td>
</tr>
<tr>
<td>,</td>
<td>5</td>
<td>on/on</td>
<td>same</td>
<td>bb2,5(d.ddbCR</td>
</tr>
<tr>
<td>(</td>
<td>7</td>
<td>on/on</td>
<td>digit</td>
<td>bb2,57d.ddbCR</td>
</tr>
<tr>
<td>)</td>
<td>4</td>
<td>on/on</td>
<td>digit</td>
<td>bb2,574.ddbCR</td>
</tr>
<tr>
<td>.</td>
<td>2</td>
<td>on/on</td>
<td>digit</td>
<td>bb2,574.2dbCR</td>
</tr>
<tr>
<td>d</td>
<td>6+</td>
<td>on/off(3)</td>
<td>digit</td>
<td>bb2,574.26dbCR</td>
</tr>
<tr>
<td>b</td>
<td>0</td>
<td>off/off</td>
<td>fill</td>
<td>bb2,574.26bbR</td>
</tr>
<tr>
<td>C</td>
<td>0</td>
<td>off/off</td>
<td>fill</td>
<td>bb2,574.26bbR</td>
</tr>
<tr>
<td>R</td>
<td>0</td>
<td>off/off</td>
<td>fill</td>
<td>bb2,574.26bbR</td>
</tr>
</tbody>
</table>

Notes:
1. This character is the fill byte.
2. First nonzero decimal source digit turns on significance indicator.
3. Plus sign in the four rightmost bits of the byte turns off significance indicator.

Thus, after the instruction is executed, the pattern field contains the result as follows:

**Pattern**

<table>
<thead>
<tr>
<th>1000</th>
<th>100C</th>
</tr>
</thead>
<tbody>
<tr>
<td>40 40</td>
<td>F2 6B F5 F7 F4 4F F2 F6 40 40</td>
</tr>
<tr>
<td>b b 2</td>
<td>5 7 4</td>
</tr>
</tbody>
</table>

This pattern field prints as:

2,574.26

The source field remains unchanged. Condition code 2 is set because the number was greater than zero.

If the number in the source field is changed to the negative number 00 00 02 6D and the original pattern is used, the edited result this time is:

**Pattern**

<table>
<thead>
<tr>
<th>1000</th>
<th>100C</th>
</tr>
</thead>
<tbody>
<tr>
<td>40 40</td>
<td>40 40 40 40 40 40 40 40</td>
</tr>
<tr>
<td>b b b b</td>
<td>b b 0</td>
</tr>
</tbody>
</table>

This pattern field prints as:

$2,574.26

Condition code 2 is set to indicate that the number edited was greater than zero.

The significance starter forces the significance indicator to the on state and hence causes a leading zero and the decimal point to be preserved. Because the minus-sign code has no effect on the significance indicator, the characters CR are printed to show a negative (credit) amount.

Condition code 1 is set (number less than zero).

**EDIT AND MARK (EDMK)**

The EDIT AND MARK instruction may be used, in addition to the functions of EDIT, to insert a currency symbol, such as a dollar sign, at the appropriate position in the edited result. Assume the same source in storage locations 1200-1203, the same pattern in locations 1000-100C, and the same contents of general register 12 as for the EDIT instruction above. The previous contents of general register 1 (GR1) are not significant; a LOAD ADDRESS instruction is used to set up the first digit position that is forced to print if no significant digits occur to the left.

The instructions:

- **LA 1,6(0,12)** Load address of forced significant digit into GR1
- **EDMK 0(13,12),X’200'(12)** Leave address of first significant digit in GR1
- **BCTR 1,0** Subtract 1 from address in GR1
- **MVI 0(1),C ‘$’** Store dollar sign at address in GR1

produce the following results for the two examples under EDIT:

**Pattern**

<table>
<thead>
<tr>
<th>1000</th>
<th>100C</th>
</tr>
</thead>
<tbody>
<tr>
<td>40 5B</td>
<td>F2 6B F5 F7 F4 4F F2 F6 40 40 40</td>
</tr>
<tr>
<td>b b b</td>
<td>b b 0</td>
</tr>
</tbody>
</table>

This pattern field prints as:

$2,574.26

Condition code 2 is set to indicate that the number edited was greater than zero.
Pattern

This pattern field prints as:

$0.26 \text{ CR}$

Condition code 1 is set because the number is less than zero.

MULTIPLY DECIMAL (MP)

Assume that the signed-packed-decimal number in storage locations 1202-1204 (the multiplicand) is to be multiplied by the signed-packed-decimal number in locations 500-501 (the multiplier).

The multiplicand must first be extended to have at least two bytes of leftmost zeros, corresponding to the multiplier length, so as to avoid a data exception during the multiplication. ZERO AND ADD can be used to move the multiplicand into a longer field.

Assume:

Register 4 contains 00 00 12 00.
Register 6 contains 00 00 05 00.

Then execution of the instruction:

ZAP X'100'(5,4),2(3,4)

sets up a new multiplicand in storage locations 1300-1304:

Now, after the instruction:

<table>
<thead>
<tr>
<th></th>
<th></th>
<th>1202</th>
<th>1204</th>
</tr>
</thead>
<tbody>
<tr>
<td>38</td>
<td>46</td>
<td>00</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>500</th>
<th>501</th>
</tr>
</thead>
<tbody>
<tr>
<td>32</td>
<td>10</td>
</tr>
</tbody>
</table>

The multiplicand must first be extended to have at least two bytes of leftmost zeros, corresponding to the multiplier length, so as to avoid a data exception during the multiplication. ZERO AND ADD can be used to move the multiplicand into a longer field.


decimal right shift

In this example, the contents of storage location FIELD1 are shifted three places to the left, effectively multiplying the contents of FIELD1 by 1000. FIELD1 is six bytes long. The following instruction performs the operation:

Machine Format

| Op Code L1 L2 B1 D1 B2 D2 |
|--------------------------|---|---|---|---|---|---|
| FC 4 1 4 100 6 000 |

Assembler Format

| Op Code D1(L1,B1),D2(L2,B2) |
|-----------------------------|---|---|
| MP X'100'(5,4),0(2,6) |

is executed, storage locations 1300-1304 contain the product: 01 23 45 66 0C.

SHIFT AND ROUND DECIMAL (SRP)

The SHIFT AND ROUND DECIMAL (SRP) instruction can be used for shifting decimal numbers in storage to the left or right. When a number is shifted right, rounding can also be done.

Decimal Left Shift

In this example, the contents of storage location FIELD2 are shifted one place to the right, effectively multiplying the contents of FIELD1 by 1000. FIELD1 is six bytes long. The following instruction performs the operation:

Machine Format

| Op Code L1 I3 S1 B2 D2 |
|------------------------|---|---|---|---|---|
| F0 5 0 * * * 0 003 |

Assembler Format

| Op Code S1(L1),S2,I3 |
|---------------------|---|---|
| SRP FIELD1(6),3,0 |

FIELD1 (before): 00 01 23 45 67 8C
FIELD1 (after): 12 34 56 78 00 0C

The second-operand address in this instruction specifies the shift amount (three places). The rounding digit, I3, is not used in a left shift, but it must be a valid decimal digit. After execution, condition code 2 is set to show that the result is greater than zero.

Decimal Right Shift

In this example, the contents of storage location FIELD2 are shifted one place to the right, effectively
dividing the contents of FIELD2 by 10 and discarding the remainder. FIELD2 is five bytes in length. The following instruction performs this operation:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L₁</th>
<th>I₃</th>
<th>S₁</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>F0</td>
<td>4</td>
<td>0</td>
<td>***</td>
<td>0</td>
<td>03F</td>
</tr>
</tbody>
</table>

Assembler Format

SRP FIELD2(5),64-1,0

FIELD 2 (before): 01 23 45 67 8C
FIELD 2 (after): 00 12 34 56 7C

In the SRP instruction, shifts to the right are specified in the second-operand address by negative shift values, which are represented as a six-bit value in two’s complement form.

The six-bit two’s complement of a number, n, can be specified as 64 - n. In this example, a right shift of one is represented as 64 - 1.

Condition code 2 is set.

Decimal Right Shift and Round

In this example, the contents of storage location FIELD3 are shifted three places to the right and rounded, in effect dividing by 1000 and rounding up. FIELD3 is four bytes in length.

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L₁</th>
<th>I₃</th>
<th>S₁</th>
<th>B₂</th>
<th>D₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>F0</td>
<td>3</td>
<td>5</td>
<td>***</td>
<td>0</td>
<td>03D</td>
</tr>
</tbody>
</table>

Assembler Format

SRP FIELD3(4),64-3,5

FIELD 3 (before): 12 39 60 0D
FIELD 3 (after): 00 01 24 0D

The shift amount (three places) is specified in the D₂ field. The I₃ field specifies a rounding digit of 5. The rounding digit is added to the last digit shifted out (which is a 6), and the carry is propagated to the left. The sign is ignored during the addition.

Condition code 1 is set because the result is less than zero.

Multiplying by a Variable Power of 10

Since the shift value specified by the SRP instruction specifies both the direction and amount of the shift, the operation is equivalent to multiplying the decimal first operand by 10 raised to the power specified by the shift value.

If the shift value is to be variable, it may be specified by the B₂ field instead of the displacement D₂ of the SRP instruction. The general register designated by B₂ should contain the shift value (power of 10) as a signed binary integer.

A fixed scale factor modifying the variable power of 10 may be specified by using both the B₂ field (variable part in a general register) and the D₂ field (fixed part in the displacement).

The SRP instruction uses only the rightmost six bits of the effective address D₂(B₂) and interprets them as a six-bit signed binary integer to control the left or right shift as in the preceding shift examples.
**ZERO AND ADD (ZAP)**

Assume that the signed-packed-decimal number at storage locations 4500-4502 is to be moved to locations 4000-4004 with four leading zeros in the result field. Also assume:

- Register 9 contains 00 00 40 00.
- Storage locations 4000-4004 contain 12 34 56 78 90.
- Storage locations 4500-4502 contain 38 46 0D.

After the instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>L1</th>
<th>L2</th>
<th>B1</th>
<th>D1</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>F8</td>
<td>4</td>
<td>2</td>
<td>9</td>
<td>000</td>
<td>9</td>
<td>500</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>D1(L1,B1),D2(L2,B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>ZAP</td>
<td>0(5,9),X'500'(3,9)</td>
</tr>
</tbody>
</table>

is executed, the storage locations 4000-4004 contain 00 00 38 46 0D; condition code 1 is set to indicate a negative result without overflow.

Note that, because the first operand is not checked for valid sign and digit codes, it may contain any combination of hexadecimal digits before the operation.

**Hexadecimal-Floating-Point Instructions**

(See Chapter 9, “Floating-Point Overview and Support Instructions” for a complete description of the hexadecimal-floating-point instructions.)

In this section, the abbreviations FPR0, FPR2, FPR4, and FPR6 stand for floating-point registers 0, 2, 4, and 6 respectively.

**ADD NORMALIZED (AD, ADR, AE, AER, AXR)**

The ADD NORMALIZED instruction performs the addition of two HFP numbers and places the normalized result in a floating-point register. Neither of the two numbers to be added must necessarily be in normalized form before addition occurs. For example, assume that:

- FPR6 contains the unnormalized number C3 08 21 00 00 00 00 00 = -82.116 = -130.0610 approximately.
- Storage locations 2000-2007 contain the normalized number 41 12 34 56 00 00 00 00 = +1.23456 16 = +1.1410 approximately.
- Register 13 contains 00 00 20 00.

The instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>7A</td>
<td>6</td>
<td>0</td>
<td>0</td>
<td>000</td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1,X2(B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>AE</td>
<td>6,0(0,13)</td>
</tr>
</tbody>
</table>

performs the short-precision addition of the two operands, as follows.

The characteristics of the two numbers (43 and 41) are compared. Since the number in storage has a characteristic that is smaller by 2, it is right-shifted two hexadecimal digit positions. One guard digit is retained on the right. The fractions of the two numbers are then added algebraically:

<table>
<thead>
<tr>
<th>Fraction GD1</th>
</tr>
</thead>
<tbody>
<tr>
<td>FPR6</td>
</tr>
<tr>
<td>Shifting from storage</td>
</tr>
<tr>
<td>Intermediate sum</td>
</tr>
<tr>
<td>Left-shifted sum</td>
</tr>
<tr>
<td>Guard digit</td>
</tr>
</tbody>
</table>

Because the intermediate sum is unnormalized, it is left-shifted to form the normalized HFP number -80.ECBB16 = -128.9210 approximately. Combining the sign with the characteristic, the result is C2 80 EC BB, which replaces the left half of FPR6. The right half of FPR6 and the contents of storage locations 2000-2007 are unchanged. Condition code 1 is set to indicate a result less than zero.
If the long-precision instruction AD were used, the result in FPR6 would be C2 80 EC BA 00 00 00. Note that use of the long-precision instruction would avoid a loss of precision in this example.

**ADD UNNORMALIZED (AU, AUR, AW, AWR)**

The ADD UNNORMALIZED instruction operates the same as the ADD NORMALIZED instruction, except that the final result is not normalized. For example, using the same operands as in the example for ADD NORMALIZED, when the short-precision instruction:

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>X2</th>
<th>B2</th>
<th>D2</th>
</tr>
</thead>
<tbody>
<tr>
<td>7E 6 0 D 000</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, D2(X2, B2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>AU 6,0(0,13)</td>
<td></td>
</tr>
</tbody>
</table>

is executed, the two numbers are added as follows:

\[
\begin{align*}
\text{FPR6} & \quad \text{Fraction GD}^1 \\
& \quad -43 08 21 00 \\
\text{Shifted number from storage} & \quad +43 00 12 34 5 \\
\text{Intermediate sum} & \quad -43 08 0E CB B
\end{align*}
\]

\(^1\) Guard digit

The guard digit participates in the addition but is discarded. The unnormalized sum replaces the left half of FPR6. Condition code 1 is set because the result is less than zero.

The truncated result in FPR6 (C3 08 0E CB 00 00 00 00) shows a loss of a significant digit when compared to the result of short-precision normalized addition.

**COMPARE (CD, CDR, CE, CER)**

Assume that FPR4 contains 43 00 00 00 00 00 00 00 (zero), and FPR6 contains 35 12 34 56 78 9A BC DE (a positive number). The contents of the two registers are to be compared using a long-precision COMPARE instruction.

Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>29 4 6</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1, R2</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDR 4,6</td>
<td></td>
</tr>
</tbody>
</table>

The number with the smaller characteristic, which is in register FPR6, is right-shifted 43 - 35 hex (67 - 53 decimal) or 14 digit positions, so that the two characteristics agree. The shifted number is 43 00 00 00 00 00 00 00, with a guard digit of one. Therefore, when the two numbers are compared, condition code 1 is set, indicating that operand 1 in FPR4 is less than operand 2 in FPR6.

If the example is changed to a second operand with a characteristic of 34 instead of 35, so that FPR6 contains 34 12 34 56 78 9A BC DE, the operand is right-shifted 15 positions, leaving all fraction digits and the guard digit as zeros. Condition code 0 is set, indicating equality. This example shows that two HFP numbers with different characteristics or fractions may compare equal if the numbers are unnormalized or zero.

As another example of comparing unnormalized HFP numbers, 41 00 12 34 56 78 9A BC compares equal to all numbers of the form 3F 12 34 56 78 9A BC 0X (X represents any hexadecimal digit). When the COMPARE instruction is executed, the two rightmost digits are shifted right two places, the 0 becomes the guard digit, and the X does not participate in the comparison.

However, when two normalized HFP numbers are compared, the relationship between numbers that compare equal is unique: each digit in one number must be the same as the corresponding digit in the other number.

**DIVIDE (DD, DDR, DE, DER)**

Assume that the first operand (the dividend) is in FPR2 and the second operand (the divisor) in FPR0. If the operands are in the short-precision divisor format, the resulting quotient is returned to FPR2 by the instruction:
Several examples of short-precision HFP division, with the dividend in FPR2 and the divisor in FPR0, are shown below. For case A, the result, which replaces the dividend, is obtained in the following steps.

**HALVE (HDR, HER)**

HALVE produces the same result as HFP DIVIDE with a divisor of 2.0. Assume FPR2 contains the long-precision number +48 30 00 00 00 00 00 0F. The following HALVE instruction produces the result +48 18 00 00 00 00 00 07 in FPR2:

**MULTIPLY (MD, MDR, MDE, MDER, MXD, MXDR, MXR)**

For this example, the following long-precision operands are in FPR0 and FPR2:

- FPR0: -33 606060 60606060
- FPR2: -5A 200000 20000020

A long-precision product is generated by the instruction:

If the operands were not already normalized, the instruction would first normalize them. It then generates an intermediate result consisting of the full 28-digit hexadecimal product fraction obtained by multiplying the 14-digit hexadecimal operand fractions, together with the appropriate sign and a characteristic that is the sum of the operand characteristics less 64 (40 hex):

---

# Machine Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁</th>
<th>R₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>3D 2 0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

# Assembler Format

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R₁, R₂</th>
</tr>
</thead>
<tbody>
<tr>
<td>DER 2,0</td>
<td></td>
</tr>
</tbody>
</table>

Case C shows a number being divided by 4.0. Case D divides the same number by 2.0, and case E divides the result of case D again by 2.0. The results of cases C and E differ in the rightmost hexadecimal digit position, which illustrates an effect of result truncation.
The fraction multiplication is performed as follows:

\[
\begin{align*}
\frac{.606060606060}{.2000020000020} & = \frac{C0C0C0C0C0C0C0}{C0C0C0C0C0C0} \\
& = .0C0C0C181818241818180C0C0C00
\end{align*}
\]

Attaching the sign and characteristic to the fraction gives:

\[+4D0C0C0C181818241818180C0C0C00\]

Because this intermediate product has a leading zero, it is then normalized. The truncated final result placed in FPR0 is:

\[+4C C0C0C181818241\]

**Hexadecimal-Floating-Point-Number Conversion**

The following examples illustrate one method of converting between binary fixed-point numbers (32-bit signed binary integers) and normalized HFP numbers. Conversion must provide for the different representations used with negative numbers: the two's-complement form for signed binary integers, and the signed-absolute-value form for the fractions of HFP numbers.

**Fixed Point to Hexadecimal Floating Point**

The method used here inverts the leftmost bit of the 32-bit signed binary integer, which is equivalent to adding \(2^{31}\) to the number and considering the result to be positive. This changes the number from a signed integer in the range \(2^{31} - 1\) through \(-2^{31}\) to an unsigned integer in the range \(2^{32} - 1\) through 0. After conversion to the long HFP format, the value \(2^{31}\) is subtracted again.

Assume that general register 9 (GR9) contains the integer -59 in two's-complement form:

\[GR9: \quad FF \quad FF \quad FF \quad C5\]

Further, assume two eight-byte fields in storage: TEMP, for use as temporary storage, and TWO31, which contains the floating-point constant \(2^{31}\) in the following format:

\[\text{TWO31:} \quad 4E \quad 00 \quad 00 \quad 00 \quad 80 \quad 00 \quad 00 \quad 00\]

This is an unnormalized long HFP number with the characteristic 4E, which corresponds to a radix point (hexadecimal point) to the right of the number.

The following instruction sequence performs the conversion:

\[
X \quad 9, \text{TWO31} + 4 \\
\text{ST} \quad 9, \text{TEMP} + 4 \\
\text{MVC} \quad \text{TEMP}(4), \text{TWO31} \\
\text{LD} \quad 2, \text{TEMP} \\
\text{SD} \quad 2, \text{TWO31}
\]

The EXCLUSIVE OR (X) instruction inverts the leftmost bit in general register 9, using the right half of the constant as the source for a leftmost one bit. The next two instructions assemble the modified number in an unnormalized long HFP format, using the left half of the constant as the plus sign, the characteristic, and the leading zeros of the fraction. LOAD (LD) places the number unchanged in floating-point register 2. The SUBTRACT NORMALIZED (SD) instruction performs the final two steps by subtracting \(2^{31}\) in HFP form and normalizing the result.

**Hexadecimal Floating Point to Fixed Point**

The procedure described here consists basically in reversing the steps of the previous procedure. Two additional considerations must be taken into account. First: the HFP number may not be an exact integer. Truncating the excess hexadecimal digits on the right requires shifting the number one digit position farther to the right than desired for the final result, so that the units digit occupies the position of the guard digit. Second: the HFP number may have to be tested as to whether it is outside the range of numbers representable as a 32-bit signed binary integer.

Assume that floating-point register 6 contains the number 59.2510 = 3B.416 in normalized form:

\[\text{FPR6:} \quad 42 \quad 3B \quad 40 \quad 00 \quad 00 \quad 00 \quad 00 \quad 00\]
Further, assume three eight-byte fields in storage: TEMP, for use as temporary storage, and the constants $2^{32}$ (TWO32) and $2^{31}$ (TWO31R) in the following formats:

\[
\begin{align*}
\text{TWO32:} & \quad 4E 00 00 01 00 00 00 00 \\
\text{TWO31R:} & \quad 4F 00 00 00 08 00 00 00
\end{align*}
\]

The constant TWO31R is shifted right one more position than the constant TWO31 of the previous example, so as to force the units digit into the guard-digit position.

The following instruction sequence performs the integer truncation, range tests, and conversion to a signed binary integer in general register 8 (GR8):

\[
\begin{align*}
\text{SD} & \quad 6, \text{TWO31R} & \text{Result} & \text{FPR6:} \\
& \quad & C87F \text{ FFFF C500 0000} \\
\text{BC} & \quad 11, \text{OVERFLOW} & \text{Branch to overflow routine if result is greater than or equal to zero} \\
\text{AW} & \quad 6, \text{TWO32} & \text{FPR6:} & 4E00 0000 8000 003B \\
\text{BC} & \quad 4, \text{OVERFLOW} & \text{Branch to overflow routine if result is less than zero} \\
\text{STD} & \quad 6, \text{TEMP} & \text{TEMP:} & 4E00 0000 8000 003B \\
\text{XI} & \quad \text{TEMP+4,X’80’} & \text{TEMP:} & 4E00 0000 0000 003B \\
\text{L} & \quad 8, \text{TEMP+4} & \text{GR8:} & 0000 003B
\end{align*}
\]

The SUBTRACT NORMALIZED (SD) instruction shifts the fraction of the number to the right until it lines up with TWO31R, which causes the fraction digit 4 to fall to the right of the guard digit and be lost; the result of subtracting $2^{31}$ from the remaining digits is renormalized. The result should be less than zero; if not, the original number was too large in the positive direction. The first BRANCH ON CONDITION (BC) performs this test.

The ADD UNNORMALIZED (AW) instruction adds $2^{32}$, $2^{31}$ to correct for the previous subtraction and another $2^{31}$ to change to an all-positive range. The second BC tests for a result less than zero, showing that the original number was too large in the negative direction. The unnormalized result is placed in temporary storage by the STORE (STD) instruction. There the leftmost bit of the binary integer is inverted by the EXCLUSIVE OR (XI) instruction to subtract $2^{31}$ and thus convert the unsigned number to the signed format. The final result is loaded into GR8.

### Multiprogramming and Multiprocessing Examples

When two or more programs sharing common storage locations are being executed concurrently in a multiprogramming or multiprocessing environment, one program may, for example, set a flag bit in the common-storage area for testing by another program. It should be noted that the instructions AND (NI, NIY, or NC), EXCLUSIVE OR (XI, XIY, or XC), and OR (OI, OIY, or OC) could be used to set flag bits in a multiprogramming environment; but when the interlocked-access facility 2 is not installed, the same instructions may cause program logic errors in a multiprocessing configuration where two or more CPUs can fetch, modify, and store data in the same storage locations simultaneously.

### Example of a Program Failure Using OR Immediate

The following example assumes that the interlocked-access facility 2 is not installed.

Assume that two independent programs try to set different bits to one in a common byte in storage. The following example shows how the use of the instruction OR immediate (OI) can fail to accomplish this, if the programs are executed simultaneously on two different CPUs. One of the possible error situations is depicted.

<table>
<thead>
<tr>
<th>Execution of instruction</th>
<th>Flags</th>
<th>Execution of instruction</th>
<th>Flags</th>
</tr>
</thead>
<tbody>
<tr>
<td>OI FLAGS,X’01’ on CPU A</td>
<td></td>
<td>OI FLAGS,X’80’ on CPU B</td>
<td></td>
</tr>
<tr>
<td>Fetch FLAGS X’00’</td>
<td>X’00’</td>
<td>Fetch FLAGS X’00’</td>
<td></td>
</tr>
<tr>
<td>OR X’01’ into X’00’</td>
<td>X’00’</td>
<td>OR X’80’ into X’00’</td>
<td></td>
</tr>
<tr>
<td>Store X’01’ into FLAGS</td>
<td></td>
<td>Store X’80’ into FLAGS</td>
<td></td>
</tr>
<tr>
<td>X’80’ into FLAGS</td>
<td></td>
<td>Flags should have value of X’81’ following both updates.</td>
<td></td>
</tr>
</tbody>
</table>

The problem shown here is that the value stored by the OI instruction executed on CPU A overlays the value that was stored by CPU B. The X’80’ flag bit
was erroneously turned off, and the data is now invalid.

The COMPARE AND SWAP instruction has been provided to overcome this and similar problems.

When the interlocked-access facility 2 is installed, the update performed by OR (OI) instruction is an interlocked-update reference, and the problem illustrated here does not occur.

**Conditional Swapping Instructions (CS, CDS)**

The COMPARE AND SWAP (CS) and COMPARE DOUBLE AND SWAP (CDS) instructions can be used in multiprogramming or multiprocessing environments to serialize access to counters, flags, control words, and other common storage areas.

The following examples of the use of the COMPARE AND SWAP and COMPARE DOUBLE AND SWAP instructions illustrate the applications for which the instructions are intended. It is important to note that these are examples of functions that can be performed by programs while the CPU is enabled for interruption (multiprogramming) or by programs that are being executed in a multiprocessor configuration. That is, the routine allows a program to modify the contents of a storage location while the CPU is enabled, even though the routine may be interrupted by another program on the same CPU that will update the location, and even though the possibility exists that another CPU may simultaneously update the same location.

The COMPARE AND SWAP instruction first checks the value of a storage location and then modifies it only if the value is what the program expects; normally this would be a previously fetched value. If the value in storage is not what the program expects, then the location is not modified; instead, the current value of the location is loaded into a general register, in preparation for the program to loop back and try again. During the execution of COMPARE AND SWAP, no other CPU can perform a store access or interlocked-update access at the specified location.

To ensure successful updating of a common storage field by two or more CPUs, all updates must be done by means of an interlocked-update reference. See the programming notes of COMPARE AND SWAP for an example of how COMPARE AND SWAP can be unsuccessful due to an OR IMMEDIATE instruction executed by another CPU.

**Setting a Single Bit**

The following instruction sequence shows how the COMPARE AND SWAP instruction can be used to set a single bit in storage to one. Assume that the first byte of a word in storage called “WORD” contains eight flag bits.

```
LA 6,X’80’  Put bit to be ORed into GR6
SLL 6,24    Shift left 24 places to align the byte to be ORed with the location of the flag bits within WORD
L 7,WORD    Fetch current flag values
RETRY LR 8,7 Load flags into GR8
OR 8,6      Set bit to one
CS 7,8,WORD Store new flags if current flags unchanged, or re-fetch current flag values if changed
BC 4,RETRY  If new flags are not stored, try again
```

The format of the COMPARE AND SWAP instruction is:

**Machine Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1</th>
<th>R2</th>
<th>S2</th>
</tr>
</thead>
<tbody>
<tr>
<td>BA</td>
<td>7</td>
<td>8</td>
<td></td>
</tr>
</tbody>
</table>

**Assembler Format**

<table>
<thead>
<tr>
<th>Op Code</th>
<th>R1,R2,S2</th>
</tr>
</thead>
<tbody>
<tr>
<td>CS</td>
<td>7,8,WORD</td>
</tr>
</tbody>
</table>

The COMPARE AND SWAP instruction compares the first operand (general register 7 containing the current flag values) to the second operand in storage (WORD) while no CPU other than the one executing the COMPARE AND SWAP instruction is permitted to perform a store access or interlocked-update access at the specified storage location.

If the comparison is successful, indicating that the flag bits have not been changed since they were fetched, the modified copy in general register 8 is stored into WORD. If the flags have been changed, the compare will not be successful, and their new values are loaded into general register 7.
The conditional branch (BC) instruction tests the condition code and reexecutes the flag-modifying instructions if the COMPARE AND SWAP instruction indicated an unsuccessful comparison (condition code 1). When the COMPARE AND SWAP instruction is successful (condition code 0), the flags contain valid data, and the program exits from the loop.

The branch to RETRY will be taken only if some other program modifies the contents of WORD. This type of a loop differs from the typical “bit-spin” loop. In a bit-spin loop, the program continues to loop until the bit changes. In this example, the program continues to loop only if the value does change during each iteration. If a number of CPUs simultaneously attempt to modify a single location by using the sample instruction sequence, one CPU will fall through on the first try, another will loop once, and so on until all CPUs have succeeded.

**Updating Counters**

In this example, a 32-bit counter is updated by a program using the COMPARE AND SWAP instruction to ensure that the counter will be correctly updated. The original value of the counter is obtained by loading the word containing the counter into general register 7. This value is moved into general register 8 to provide a modifiable copy, and general register 6 (containing an increment to the counter) is added to the modifiable copy to provide the updated counter value. The COMPARE AND SWAP instruction is used to ensure valid storing of the counter.

The program updating the counter checks the result by examining the condition code. The condition code 0 indicates a successful update, and the program can proceed. If the counter had been changed between the time that the program loaded its original value and the time that it executed the COMPARE AND SWAP instruction, the execution would have loaded the new counter value into general register 7 and set the condition code to 1, indicating an unsuccessful update. The program must then repeat the update sequence until the execution of the COMPARE AND SWAP instruction results in a successful update.

The following instruction sequence performs the above procedure:

```asm
LA  6,1 Put increment (1) into GR6
L  7,CNTR Put original counter value into GR7
```

The following shows two CPUs, A and B, executing this instruction sequence simultaneously: both CPUs attempt to add one to CNTR.

<table>
<thead>
<tr>
<th>CPU A</th>
<th>CPU B</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>GR7</td>
<td>GR8</td>
<td>CNTR</td>
</tr>
<tr>
<td>16</td>
<td>16</td>
<td>CPU A loads GR7 and GR8 from CNTR</td>
</tr>
<tr>
<td>16</td>
<td>16</td>
<td>CPU B loads GR7 and GR8 from CNTR</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td>CPU B adds one to GR8</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td>CPU A adds one to GR8</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td>CPU B executes CS; successful match, store</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td>CPU B executes CS; no match, GR7 changed to CNTR value</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td>CPU B loads GR8 from GR7, adds one to GR8</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td>CPU B executes CS; successful match, store</td>
</tr>
</tbody>
</table>

**Bypassing Post and Wait**

See the MVS Programming: Authorized Assembler Services Guide (SA22-7608) for details on bypassing the z/OS WAIT and POST routines.

**Lock/Unlock**

When a common storage area larger than a double-word is to be updated, it is usually necessary to provide special interlocks to ensure that a single program at a time updates the common area. Such an area is called a serially reusable resource (SRR).

In general, updating a list, or even scanning a list, cannot be safely accomplished without first “freezing” the list. However, the COMPARE AND SWAP and COMPARE DOUBLE AND SWAP instructions can be used in certain restricted situations to perform queuing and list manipulation. Of prime importance is the capability to perform the lock/unlock functions and to provide sufficient queuing to resolve contentions, either in a LIFO or FIFO manner. The lock/unlock
functions can then be used as the interlock mechanism for updating an SRR of any complexity.

The lock/unlock functions are based on the use of a "header" associated with the SRR. The header is the common starting point for determining the states of the SRR, either free or in use, and also is used for queuing requests when contentions occur. Contentions are resolved using WAIT and POST. The general programming technique requires that the program that encounters a "locked" SRR must "leave a mark on the wall" indicating the address of an ECB on which it will WAIT. The "unlocking" program sees the mark and posts the ECB, thus permitting the waiting program to continue. In the two examples given, all programs using a particular SRR must use either the LIFO queuing scheme or the FIFO scheme; the two cannot be mixed. When more complex queuing is required, it is suggested that the queue for the SRR be locked using one of the two methods shown.

**Lock/Unlock with LIFO Queuing for Contentions**

The header consists of a word, that is, a four-byte field aligned on a word boundary. The word can contain zero, a positive value, or a negative value.

- A zero value indicates that the serially reusable resource (SRR) is free.
- A negative value indicates that the SRR is in use but no additional programs are waiting for the SRR.
- A positive value indicates that the SRR is in use and that one or more additional programs are waiting for the SRR. Each waiting program is identified by an element in a chained list. The positive value in the header is the address of the element most recently added to the list.

Each element consists of two words. The first word is used as an ECB; the second word is used as a pointer to the next element in the list. A negative value in a pointer indicates that the element is the last element in the list. The element is required only if the program finds the SRR locked and desires to be placed in the list.

The following chart describes the action taken for LIFO LOCK and LIFO UNLOCK routines. The routines following the chart allow enabled code to perform the actions described in the chart.

<table>
<thead>
<tr>
<th>Function</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>LIFO LOCK</strong></td>
<td><strong>Header Contains Zero</strong></td>
</tr>
<tr>
<td>(the incoming element is at location A)</td>
<td>SRR is free. Set the header to a negative value. Use the SRR.</td>
</tr>
<tr>
<td><strong>LIFO UNLOCK</strong></td>
<td>Error</td>
</tr>
</tbody>
</table>

**LIFO LOCK Routine:**

**Initial Conditions:**

- GR1 contains the address of the incoming element.
- GR2 contains the address of the header.

```assembly
LLOCK SR 3,3 GR3 = 0
ST 3,0(1) Initialize the ECB
LNR 0,1 GR0 = a negative value
TRYAGN CS 3,0,0(2) Set the header to a negative value if the header contains zeros
BC 8,USE Did the header contain zeros?
ST 3,4(1) No, store the value of the header into the pointer in the incoming element
CS 3,1,0(2) Store the address of the incoming element into the header
LA 3,0(0) GR3 = 0
BC 7,TRYAGN Did the header get updated?
WAIT ECB=(1) Yes, wait for the resource; the ECB is in the incoming element
USE [Any instruction]
```
**LIFO UNLOCK Routine:**

Initial Conditions:

- GR2 contains the address of the header.

LUNLK L 1,0(2) GR1 = the contents of the header

A LTR 1,1 Does the header contain a negative value?

BC 4,B No, load the pointer

L 0,4(1) CS 1,0,0(2) from the 'last in' element and store it in the header

BC 7,A Did the header get updated?

POST (1) Yes, post the 'last in' element

BC 15,EXIT Continue

B SR 0,0 The header contains a negative value; free

CS 1,0,0(2) BC 7,A the header and continue

EXIT [Any instruction]

Note that the LOAD instruction L 1,0(2) at location LUNLK would have to be CS 1,1,0(2) if it were not for the rule concerning storage-operand consistency. This rule requires the LOAD instruction to fetch a four-byte operand aligned on a word boundary such that, if another CPU changes the word being fetched by an operation which is also at least word-consistent, either the entire new or the entire old value of the word is obtained, and not a combination of the two. (See “Storage-Operand Consistency” on page 5-123.)

**Lock/Unlock with FIFO Queuing for Contentions**

The header always contains the address of the most recently entered element. The header is originally initialized to contain the address of a posted ECB. Each program using the serially reusable resource (SRR) must provide an element regardless of whether contention occurs. Each program then enters the address of the element which it has provided into the header, while simultaneously it removes the address previously contained in the header. Thus, associated with any particular program attempting to use the SRR are two elements, called the “entered element” and the “removed element.” The “entered element” of one program becomes the “removed element” for the immediately following program. Each program then waits on the removed element, uses the SRR, and then posts the entered element.

When no contention occurs, that is, when the second program does not attempt to use the SRR until after the first program is finished, then the POST of the first program occurs before the WAIT of the second program. In this case, the bypass-post and bypass-wait routines described in the preceding section are applicable. For simplicity, these two routines are shown only by name rather than as individual instructions.

In the example, the element need be only a single word, that is, an ECB. However, in actual practice, the element could be made larger to include a pointer to the previous element, along with a program identification. Such information would be useful in an error situation to permit starting with the header and chaining through the list of elements to find the program currently holding the SRR.

It should be noted that the element provided by the program remains pointed to by the header until the next program attempts to lock. Thus, in general, the entered element cannot be reused by the program. However, the removed element is available, so each program gives up one element and gains a new one. It is expected that the element removed by a particular program during one use of the SRR would then be used by that program as the entry element for the next request to the SRR.

It should be noted that, since the elements are exchanged from one program to the next, the elements cannot be allocated from storage that would be freed and reused when the program ends. It is expected that a program would obtain its first element and release its last element by means of the routines described in “Free-Pool Manipulation.”

The following chart describes the action taken for FIFO LOCK and FIFO UNLOCK.

<table>
<thead>
<tr>
<th>Function</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>FIFO LOCK</td>
<td>Store address A into the header.</td>
</tr>
<tr>
<td>(the incoming element is at location A)</td>
<td>WAIT; the ECB is at the location addressed by the old contents of the header.</td>
</tr>
<tr>
<td>FIFO UNLOCK</td>
<td>POST; the ECB is at location A.</td>
</tr>
</tbody>
</table>

The following routines allow enabled code to perform the actions described in the previous chart.

**FIFO Lock Routine:**

Initial conditions:
- GR3 contains the address of the header.
- GR4 contains the address, A, of the element currently owned by this program. This element becomes the entered element.

FLOCK LR 2,4 GR2 now contains address of element to be entered
SR 1,1 GR1 = 0
ST 1,0(2) Initialize the ECB
L 1,0(3) GR1 = contents of the header
TRYAGN CS 1,2,0(3) Enter address A into header while remembering old contents of header into GR1; GR1 now contains address of removed element
LR 4,1 Removed element becomes new currently owned element
HSWAIT Perform bypass-wait routine; if ECB already posted, continue; if not, wait; GR1 contains the address of the ECB

USE [Any instruction]

**FIFO Unlock Routine:**

Initial conditions:
- GR2 contains the address of the removed element, obtained during the FLOCK routine.
- GR5 contains 40 00 00 00₁₆

FUNLK LR 1,2 Place address of entered element in GR1; GR1 = address of ECB to be posted
SR 0,0 GR0 = 0; GR0 has a post code of zero
OR 0,5 Set bit 1 of GR0 to one
HSPOST Perform bypass-post routine; if ECB has not been waited on, then mark posted and continue; if it has been waited on, then post
CONTINUE [Any instruction]

**Free-Pool Manipulation**

It is anticipated that a program will need to add and delete items from a free list without using the lock/unlock routines. This is especially likely since the lock/unlock routines require storage elements for queuing and may require working storage. The lock/unlock routines discussed previously allow simultaneous lock routines but permit only one unlock routine at a time. In such a situation, multiple additions and a single deletion to the list may all occur simultaneously, but multiple deletions cannot occur at the same time. In the case of a chain of pointers containing free storage buffers, multiple deletions along with additions can occur simultaneously. In this case, the removal cannot be done using the COMPARE AND SWAP instruction without a certain degree of exposure.

Consider a chained list of the type used in the example in section “Lock/Unlock with LIFO Queuing for Contentions” on page A-48. Assume that the first two elements are at locations A and B, respectively. If one program attempted to remove the first element and was interrupted between the fourth and fifth instructions of the LUNLK routine, the list could be changed so that elements A and C are the first two elements when the interrupted program resumes execution. The COMPARE AND SWAP instruction would then succeed in storing the value B into the header, thereby destroying the list.

The probability of the occurrence of such list destruction can be reduced to near zero by appending to the header a counter that indicates the number of times elements have been added to the list. The use of a 32-bit counter guarantees that the list will not be destroyed unless the following events occur, in the exact sequence:

1. An unlock routine is interrupted between the fetch of the pointer from the first element and the update of the header.
2. The list is manipulated, including the deletion of the element referenced in 1, and exactly $2^{32}$ (or an integer multiple of $2^{32}$) additions to the list are performed. Note that this takes on the order of days to perform in any practical situation.
3. The element referenced in 1 is added to the list.
4. The unlock routine interrupted in 1 resumes execution.
The following routines use such a counter in order to allow multiple, simultaneous additions and removals at the head of a chain of pointers.

The list consists of a doubleword header and a chain of elements. The first word of the header contains a pointer to the first element in the list. The second word of the header contains a 32-bit counter indicating the number of additions that have been made to the list. Each element contains a pointer to the next element in the list. A zero value indicates the end of the list.

The following chart describes the free-pool-list manipulation.

<table>
<thead>
<tr>
<th>Function</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD TO LIST (the incoming element is at location A)</td>
<td>Store the first word of the header into location A. Store the address A into the first word of the header. Decrement the second word of the header by one.</td>
</tr>
<tr>
<td>DELETE FROM LIST</td>
<td>The list is empty. Set the first word of the header to the value of the contents of location A. Use element A.</td>
</tr>
</tbody>
</table>

The following routines allow enabled code to perform the free-pool-list manipulation described in the above chart.

**ADD TO FREE LIST Routine:**

Initial Conditions:

- GR2 contains the address of the element to be added.
- GR4 contains the address of the header.

ADDQ LM 0,1,0(4) GR0,GR1 = contents of the header
TRYAGN ST 0,4(2) Point the new element to the top of the list
LR 3,1 Move the count to GR3
AHI 3,1 Increment the count
CDS 0,2,0(4) Update the header
BC 7,TRYAGN

**DELETE FROM FREE LIST Routine:**

Initial conditions:

- GR4 contains the address of the header.

DELETQ LM 2,3,0(4) GR2,GR3 = contents of the header
TRYAGN LTR 2,2 Is the list empty?
BC 8,EMPTY Yes, get help
L 0,4(2) No, GR0 = the pointer from the first element
LR 1,3 Move the count to GR1
CDS 2,0,0(4) Update the header
BC 7,TRYAGN
USE [Any instruction] The address of the removed element is in GR2

**Notes:**

1. The LM (LOAD MULTIPLE) instructions at locations ADDQ and DELETQ would have to be CDS (COMPARE DOUBLE AND SWAP) instructions if it were not for the rule concerning storage-oper- and consistency. This rule requires the LOAD MULTIPLE instructions to fetch an eight-byte operand aligned on a doubleword boundary such that, if another CPU changes the doubleword being fetched by an operation which is also at least doubleword-consistent, either the entire new or the entire old value of the doubleword is obtained, and not a combination of the two. (See “Storage-Operand Consistency” on page 5-123.)

2. The add-to-free-list and delete-from-free-list examples shown above assume that the pointer to the next element in the list is in the second word of the element, as described “Lock/Unlock with LIFO Queuing for Contentions” on page A-48.

**PERFORM LOCKED OPERATION (PLO)**

The PERFORM LOCKED OPERATION instruction can be used in a multiprogramming or multiprocess- ing environment to perform compare, load, compare-and-swap, and store operations on two or more dis- contiguous locations that can be words or double- words. The operations are performed as an atomic set of operations under the control of a lock that is held only for the duration of the execution of a single PERFORM LOCKED OPERATION instruction, as opposed to across the execution of multiple instruc- tions. Since lock contention is resolved by the CPU and is very brief, the program need not include a method for dealing with the case when the lock to be
used is held by a program being executed by another CPU. Also, there need be no concern that the program may be interrupted while it holds a lock, since PERFORM LOCKED OPERATION will complete its operation and release its lock before an interruption can occur.

PERFORM LOCKED OPERATION can be thought of as performing concurrent interlocked updates of multiple operands. However, the instruction does not actually perform any interlocked update, and a serially reusable resource cannot be updated predictably through the use of both PERFORM LOCKED OPERATION and conditional-swapping instructions (CS and CDS).

Following is an example of how PERFORM LOCKED OPERATION can be used to add an element at the beginning of a queue.

Assume the following variables associated with the queue: S, which is a sequence number that is incremented anytime the queue is changed; H (for head), which is the address of the first element on the queue; and C, which is a count of the number of elements on the queue. Assume a queue element contains a variable, F (for forward), which is the address of the next element on the queue. If a new element, N, is to be enqueued at the head of the queue, that can be done by setting F in N to H and then performing the following atomic set of operations:

\[
\begin{align*}
S+1 & \rightarrow S \\
A(N) & \rightarrow H \\
C+1 & \rightarrow C
\end{align*}
\]

where A(N) is the address of N.

The enqueueing of N can be done by means of the following steps:

1. Obtain consistent values of S, H, and C, meaning obtain S and obtain the H and C that are consistent with that value of S.
2. Store H in N.F.
3. By means of PLO.csdst (PERFORM LOCKED OPERATION performing compare and swap and double store), with S as the swap variable and H and C as the store variables, add one to S, set H to A(N), and add one to C, provided that S still has the value obtained in step 1. If S has already been changed, go back to step 1.

Consistent values of S, H, and C cannot necessarily be obtained simply by using three LOAD instructions because a PERFORM LOCKED OPERATION instruction being executed by another CPU may have completed an update of S but not yet of H or C. In this case, the three LOAD instructions will obtain the new S but the old H or C. However, as will be described, it may be possible to use three LOAD instructions.

If S is obtained while holding the lock, meaning by means of PERFORM LOCKED OPERATION, then H and C can be obtained by LOAD instructions since no other CPU can subsequently change H or C without changing S, as observed when the lock is held.

The parameter list used by the PLO.csdst is as follows, assuming the access-register mode is not used:

<table>
<thead>
<tr>
<th>Address</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td></td>
</tr>
<tr>
<td>40</td>
<td></td>
</tr>
<tr>
<td>48</td>
<td>A(N)</td>
</tr>
<tr>
<td>56</td>
<td></td>
</tr>
<tr>
<td>64</td>
<td>A(H)</td>
</tr>
<tr>
<td>72</td>
<td></td>
</tr>
<tr>
<td>80</td>
<td>C+1</td>
</tr>
<tr>
<td>88</td>
<td></td>
</tr>
<tr>
<td>96</td>
<td></td>
</tr>
<tr>
<td>104</td>
<td>A(C)</td>
</tr>
</tbody>
</table>

The program is as follows:

```
LA RT,H Initialize addresses in PL (T = temp)  
ST RT,PL+76 Op4 address (address of H)  
LA RT,C  
ST RT,PL+108 Op6 address (address of C)  
LA RN,N Address of N  
ST RN,PL+60 Initialize op3 in PL (address of N)  
LA R1,S PLT address = address of S  
SR RS,RS Dummy S. CC1 will probably be set  
SR R0,R0 Function code 0 (compare and load)
```
PLO   RS,S,RS,S Obtain S while holding lock
------------------------------------------
LA   R0,16     Function code 16 (csdst)
LOOP L  RT,H    Consistent H
ST  RT,OFSTF(RN) OFSTF = offset of F in N
   RT,C    Consistent C
LA  RT,1(RT) C+1
ST  RT,PL+92 Initialize op5 in PL
       (C+1)
LA  RSP,1(RS) RS/RSP = even-odd pair.
       S+1 in RSP
PLO   RS,S,0,PL
BNZ LOOP   Br if S changed (if CC not 0)

Note the following about the first PERFORM LOCKED OPERATION instruction (PLO.cl). If S is not zero (which is probably true), S (the second operand, op2) is loaded into RS (the first-operand comparison value, op1c). If S is zero, S (the fourth operand, op4) is loaded into RS (the third operand, op3). Either of these loads occurs while the lock is held. It is unnecessary to test the condition code to determine which load occurred.

The above program may be a simplification. If the queue has associated with it a variable, T (for tail), that is the address of the last element on the queue, and the queue is currently empty. T also must be set when N is added to the queue. This would require a different program using a compare-and-swap-and-triple-store operation.

If the queue is added to, deleted from, and rearranged by means of PERFORM LOCKED OPERATION instructions in which the sequence number, S, is always the second operand, then, since the definition of PERFORM LOCKED OPERATION specifies that the second operand is always stored last, the first PERFORM LOCKED OPERATION instruction in the above program can be replaced by a LOAD instruction. The three instructions within the dashed lines would be replaced by L RS,S.

---

**Sorting Instructions**

**Tree Format**

Two instructions, COMPARE AND FORM CODE-WORD and UPDATE TREE, refer to a tree — a data structure with a specific format. A tree consists of some number (always odd) of consecutively numbered nodes. Node 1 is the root of the tree. Every node except the root has one parent node in the same tree. Every parent node has two son nodes. Every even-numbered node is the leftson of its parent node, and every odd-numbered node (except node 1) is the rightson of its parent node. Division by two (ignoring remainder) of the node number gives the parent node number. Nodes with sons are also called internal nodes, and nodes without sons are called terminal nodes. Figure A-5 on page A-54 illustrates schematically a 21-node tree with arrows drawn from each parent node to each son node.

A tree is used for merging several sorted sequences of records into a single merged sequence of records. At each step in the merging process, there exists the initial part of the merged sequence and the remaining parts of each of the sorted sequences that are being merged. Each step consists in selecting the lowest record (the record with the lowest key when sorting in ascending sequence) from all of the as yet unmerged parts of the sorted sequences and adding it to the merged sequence. Each terminal node in the tree represents one of the sorted sequences. The number of internal nodes in the tree is one less than the number of sorted sequences. Each internal node conceptually contains one record from each of the sorted sequences but one; these are the lowest records, from all but one of the sorted sequences, that have not yet been added to the merged sequence. In addition, there is the lowest record from the one remaining sorted sequence. This additional record is compared and interchanged with nodes of the tree to select the record to be added next to the merged sequence. This processing begins with the parent of the terminal node that represents the one remaining sorted sequence, and it continues from that node along the path to the root of the tree. The selected record emerges from the root of the tree.

The tree may perhaps be most easily explained by considering each node to represent a comparison operation in an “elimination tournament” to find the lowest record. After the tournament has been com-
pleted, each node has an associated "loser" record which had a higher key in the comparison represented by that node. Besides a loser record at each node, there is one record (the "winner") which is not associated with any node since it never compared high. The next step would be to introduce a new record from the same sorted sequence from which the winner record originated and replay the tournament with the new record in place of the former winner. It can be seen that it is unnecessary to do all the comparisons represented by all the nodes in the tree — most of them are unaffected by the new record replacing the former winner. In fact, it is sufficient to redo only those node comparisons in which the former winner record participated. Each new record is inserted into the tree at the terminal node that represents the sorted sequence containing the record. The use of the tree assumes that programming provides a method of remembering at which terminal node each winning record originated. The instruction UPDATE TREE allows for a new record to be inserted at a terminal node and the tree to be updated so that a new winner record is left in the general registers.

Rather than comparing the actual keys of records, much of the merge logic can be performed using "codewords" to represent a record key rather than referring to actual keys. The value of a codeword at a node in the tree depends not only on the record's key but also on the key of the winning record in the last comparison at that node. The codeword consists of two parts:

1. Bits 16-31 contain the one’s complement of the first halfword in which the record key differs from that of the node’s winning record.

2. Bits 0-15 specify the byte offset of the halfword in this record’s key just beyond the halfword value (complemented) in bit positions 16-31.

When comparing records in the path of the last winner record, if the new record is also represented by a codeword resulting from a comparison with the last winner, all codewords in the update path are with respect to the same winner. When comparing such codewords, a high codeword represents a low key and vice versa. Thus, when codewords are unequal, a node entry with a high codeword (representing a low actual key) should move up the tree.

In the case of a tie value of codewords, it is necessary to refer to the actual keys. This is done by the instruction COMPARE AND FORM CODEWORD, which resolves the ambiguity and computes a new codeword for the high-key (loser) record.

The eight bytes at each node of a tree consist of (1) a codeword for this record, computed with respect to the last record which compared low against this record and (2) a parameter usable to locate this record, for example, a direct or indirect address.

The instruction UPDATE TREE is so defined that tree updating stops after equal codewords are detected and the tie-breaking instruction COMPARE AND FORM CODEWORD can be used, after which UPDATE TREE can resume tree updating at the point where equal codewords were previously found.

COMPARE AND FORM CODEWORD may alternatively be used for merging in descending sequence. In that case, bits 16-31 of the codeword at a node contain the true value of the first halfword in which the record key differs from that of the node’s winning record. When the descending option of COMPARE AND FORM CODEWORD is used, the higher of two codewords represents the higher key.

![Schematic Diagram of Merge Control Tree with 21 Nodes](image-url)
Example of Use of Sort Instructions

An example illustrates how the instructions UPDATE TREE and COMPARE AND FORM CODEWORD may be used in the merge operation within a sort program. A five-way merge requires a tree data structure with four internal nodes and five terminal-node positions. The schematic diagram shown later in this section illustrates such a tree, containing four internal nodes (not counting the dummy node) and five input sequences for a merge, one sequence at each terminal-node position. Each record in an input sequence in the diagram is indicated by its address. The actual record contents are shown in Figure A-7 on page A-58. Each record contains 16 bytes, consisting of the following fields:

<table>
<thead>
<tr>
<th>Byte Offset (hexadecimal)</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-5</td>
<td>Six-byte record key.</td>
</tr>
<tr>
<td>6-7</td>
<td>Halfword node index specifying the input sequence of the next record of this input sequence.</td>
</tr>
<tr>
<td>8-B</td>
<td>Address of the next record in the same input sequence.</td>
</tr>
<tr>
<td>C-F</td>
<td>This chaining field is initially zero. At the completion of the merge, this field is to contain the address of the next record in the merged sequence.</td>
</tr>
</tbody>
</table>

The merge process forms a single sorted sequence from five input sequences, each of which is in sorted order. This process can be subdivided into three steps:

1. A priming step takes the first record from each of the five input sequences and places them in the tree data structure. For each record to be introduced into the tree, first its codeword value is computed with respect to the lowest possible key value of all zeros. This codeword, with a second word which contains the address of the record represented by that node value, forms a doubleword node value that can be placed at the appropriate node. After priming, the node values, one each from each of the five input sequences, will have been placed in the tree so that each of the four internal nodes contains one node value and the node value for a winner record has emerged from the root of the tree.

2. After each winner emerges from the tree, the main merge process is performed repeatedly. Each iteration introduces the node value for one new record into the tree and produces a node value for a new winner record. The tree plus the winner must at all times contain precisely one node value from each input sequence being merged. Therefore, the new node value that is introduced into the tree on each iteration must come from the same input sequence from which the winner node value in the preceding iteration originated.

3. When the node value for the last record of an input sequence emerges as a winner, there is no successor record from that input sequence to be introduced into the tree on the next iteration. Hence, the order of the merge must be reduced by one for each such occurrence. This runout process will consist of one or more iterations for each of a four-way, three-way, two-way, and one-way merge. The onset of runout occurs in the example when it is found that the next input record from a sequence is lower than its predecessor (a sequence break).

The priming process is discussed next, and the state of the tree is shown after priming is complete. Then, a short program that uses the instructions UPDATE TREE and COMPARE AND FORM CODEWORD to perform the main merge is described. An abbreviated trace is then presented to show the status of the tree and certain general registers for 16 iterations of the main merge. The runout process is not discussed in this example.

Priming begins by forming the node value for the first record of each input sequence. The first word of the node value is the codeword formed by executing COMPARE AND FORM CODEWORD on a record key containing all binary zeros. The second word of the node value is the address of the record represented by that node value. The node values for the first record of each input sequence are:

<table>
<thead>
<tr>
<th>Sequence Index</th>
<th>Node Values</th>
</tr>
</thead>
<tbody>
<tr>
<td>28</td>
<td>0006 FFFC 0000 1030</td>
</tr>
<tr>
<td>30</td>
<td>0006 FFFB 0000 1040</td>
</tr>
<tr>
<td>38</td>
<td>0006 FFFA 0000 1050</td>
</tr>
<tr>
<td>40</td>
<td>0004 FFTE 0000 1080</td>
</tr>
<tr>
<td>48</td>
<td>0006 FFF9 0000 1069</td>
</tr>
</tbody>
</table>

In the example, the tree data structure is assumed to have base address X’1000’, which is kept in general register 4 (to match the expected use in UPDATE TREE). Similarly, internal-node index values and

A-55
input-sequence index values are always used from general register 5.

Although the tree-priming program is not part of this example, the UPDATE TREE instruction is used in creating it as follows. First, the codeword position for each internal node of the tree is initialized to all ones (X’FFFFFFF’). This artifice fills the tree with dummy low records. Then, for each record in the table, (1) the sequence index is loaded into general register 5, (2) the node value is loaded into general registers 0 and 1, and (3) UPDATE TREE is executed. At the completion of this priming process, the tree-node contents in the example are as shown on line 0 of Figure A-9 on page A-60. The contents of the general registers are as shown on the first line of Figure A-8 on page A-59.

The figure illustrating the program for the main merge is divided into three groups of columns, containing the absolute program, the general-register trace, and the symbolic program. The first part of the program extends from symbolic locations L1 through L2; it introduces a new record into the tree and executes an UPDATE TREE instruction. If no tied codewords are encountered in UPDATE TREE, then the BRANCH ON CONDITION instruction following UPDATE TREE loops back to L1 to introduce the next record into the tree. This BRANCH ON CONDITION instruction is suitable for use when UPDATE TREE operates in accordance with either its method 1 (setting condition code 1) or its method 2 (setting condition code 3). (The preceding sentence applies to 370-XA. In ESA/370 and ESA/390, UPDATE TREE operates in accordance with only method 2, which is not to say that it cannot set condition code 1. Method 2, but not method 1, tests for the condition that sets condition code 3.)

If UPDATE TREE encounters tied codewords, then the UPDATE TREE instruction is completed, the subsequent BRANCH ON CONDITION instruction does not branch, and control falls through to the second part of the program, which handles entries with tied codewords. This part then branches back to UPDATE TREE at L2, which resumes the tree updating. It is possible for tied codewords to be encountered at any level in the tree (or indeed at all levels), so that the tied-codeword part of the program may be entered up to three times for each record introduced.

The general-register trace for the first part of the main merge shows the contents of the first seven general registers after each instruction is executed during the first iteration. Note that the merged-chain field (at 1140) serves as the anchor for the merged-chain address chain through the records. The trace shows only the lower half of certain general registers, whose upper half is always zero.

Figure A-9 on page A-60 gives an abbreviated trace of the entire main merge of 16 records. For each record introduced into the tree, there are one or more lines (always an odd number) given in the figure to show the tree updating, which results finally in a winner in GR0 and GR1. The first line for each record shows the values of GR5, GR2, and GR3 before the first or only execution of UPDATE TREE. For the even-numbered lines, the storage updating by UPDATE TREE of tree nodes is shown (read left to right to follow the order of swapping). For example, consider line 10 and the corresponding UPDATE TREE: since GR5 contains 28, the first storage node examined is 1010 (refer to the schematic diagram). Since the codeword in GR0 is 0004 FFFE (same as for GR2), which is less than that of the word at 1010 (0006 FFF0), the doubleword at 1010 is swapped with that in GR0 and GR1. A second comparison at 1008 in the same execution of UPDATE TREE causes another register-storage doubleword swap, which leaves the winner (record 1040) in GR1 at the completion of UPDATE TREE (see the column at the far right of Figure A-9 on page A-60).

When a codeword comparison is made which does not result in a tie or a swap (that is, when the storage-codeword value is low), an asterisk appears in the trace for that storage entry.

When equal codewords are found, the execution of UPDATE TREE is completed. The following line in each such case shows the result of the tied-codeword routine, which always stores a new codeword and may also store a new record address before branching back to L2 to execute UPDATE TREE again. In this line, the notation “loses” or “wins” means that the node loses or wins, respectively.

The tie-break trace part of Figure A-8 on page A-59 shows the treatment of the third record (that is, the first record for which UPDATE TREE encounters a tied codeword). This corresponds to line 31 in Figure A-9 on page A-60.

The following is a summary of the steps that are needed to use this example for verification purposes:

1. Initialize storage as follows:
a. 1008 through 102F from line 0 of Figure A-9 on page A-60

b. 1030 through 114F from Figure A-7 on page A-58

c. 1150 through 1189 from Figure A-8 on page A-59

2. Initialize GRs per first line in Figure A-8 and trace first record per Figure A-8.

3. Trace to completion of each UPT or BC 15,L2 (once for each line of Figure A-9). A detailed trace of the GRs for the tied-codeword part of line 31 of Figure A-9 is given in the lower part of Figure A-8.

4. Verify that addresses in the chain beginning at 103C and continuing through 114C are as shown in the right-hand column of Figure A-7.

Note: Each node and input sequence is identified by a number which is the hexadecimal node index. Each input sequence is given as a list of record addresses (also in hexadecimal).

Figure A-6. Schematic Diagram for Example of Merge to Be Performed
<table>
<thead>
<tr>
<th>Location</th>
<th>Record Key at Hex Byte Offset</th>
<th>Successor Record</th>
<th>Merged-Chain Address</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Index</td>
<td>Location</td>
<td>Address</td>
</tr>
<tr>
<td>1030</td>
<td>0 0 0 0 0 0 0 0 0 0 3</td>
<td>0 0 2 8 0 0 0 1 0 7 0</td>
<td>0 0 0 1 0 4 0</td>
</tr>
<tr>
<td>1040</td>
<td>0 0 0 0 0 0 0 0 0 0 4</td>
<td>0 0 3 0 0 0 1 0 B 0</td>
<td>0 0 0 1 0 5 0</td>
</tr>
<tr>
<td>1050</td>
<td>0 0 0 0 0 0 0 0 0 0 5</td>
<td>0 0 3 8 0 0 1 0 9 0</td>
<td>0 0 0 1 0 6 0</td>
</tr>
<tr>
<td>1060</td>
<td>0 0 0 0 0 0 0 0 0 0 F</td>
<td>0 0 4 8 0 0 1 0 A 0</td>
<td>0 0 0 1 0 8 0</td>
</tr>
<tr>
<td>1070</td>
<td>0 0 0 0 0 0 0 1 F F F F</td>
<td>0 0 2 8 0 0 1 0 D 0</td>
<td>0 0 0 1 0 9 0</td>
</tr>
<tr>
<td>1080</td>
<td>0 0 0 0 0 0 0 1 F F F F</td>
<td>0 0 4 0 0 0 1 0 F 0</td>
<td>0 0 0 1 0 7 0</td>
</tr>
<tr>
<td>1090</td>
<td>0 0 0 0 F F F F 0 0 0 0</td>
<td>0 0 3 8 0 0 1 0 E 0</td>
<td>0 0 0 1 0 A 0</td>
</tr>
<tr>
<td>10A0</td>
<td>0 0 0 0 F F F F 0 0 0 1</td>
<td>0 0 4 8 0 0 1 1 0 0</td>
<td>0 0 0 1 0 B 0</td>
</tr>
<tr>
<td>10B0</td>
<td>0 0 0 0 F F F F 0 0 0 2</td>
<td>0 0 3 0 0 0 1 0 C 0</td>
<td>0 0 0 1 0 C 0</td>
</tr>
<tr>
<td>10C0</td>
<td>0 0 0 0 F F F F 0 0 0 2</td>
<td>0 0 3 0 0 0 1 1 4 0</td>
<td>0 0 0 1 0 D 0</td>
</tr>
<tr>
<td>10D0</td>
<td>0 0 0 1 0 0 0 0 0 0 0</td>
<td>0 0 2 8 0 0 1 1 1 0</td>
<td>0 0 0 1 0 E 0</td>
</tr>
<tr>
<td>10E0</td>
<td>0 0 8 0 0 0 0 0 0 0 0</td>
<td>0 0 3 8 0 0 1 1 3 0</td>
<td>0 0 0 1 0 F 0</td>
</tr>
<tr>
<td>10F0</td>
<td>0 0 8 0 0 0 2 0 0 4 0</td>
<td>0 0 4 0 0 0 1 1 2 0</td>
<td>0 0 0 1 1 0 0</td>
</tr>
<tr>
<td>1100</td>
<td>0 0 8 0 0 0 2 0 0 5 0</td>
<td>0 0 4 8 0 0 1 1 4 0</td>
<td>0 0 0 1 1 1 0</td>
</tr>
<tr>
<td>1110</td>
<td>0 0 8 0 0 0 3 0 0 0 0</td>
<td>0 0 2 8 0 0 1 1 4 0</td>
<td>0 0 0 1 1 2 0</td>
</tr>
<tr>
<td>1120</td>
<td>0 0 9 0 0 0 0 0 0 0 0</td>
<td>0 0 4 0 0 0 1 1 4 0</td>
<td>0 0 0 1 1 3 0</td>
</tr>
<tr>
<td>1130</td>
<td>F F F F F F F F F F E</td>
<td>0 0 3 8 0 0 1 0 5 0</td>
<td>0 0 0 0 0 0 0</td>
</tr>
<tr>
<td>1140</td>
<td>F F F F F F F F F F F F</td>
<td>0 0 0 0 0 0 0 0 0 0</td>
<td>0 0 0 1 0 3 0</td>
</tr>
</tbody>
</table>

*Figure A-7. Contents of Records to Be Merged*
<table>
<thead>
<tr>
<th>Loc</th>
<th>INSTR</th>
<th>GR0</th>
<th>GR1</th>
<th>GR2</th>
<th>GR3</th>
<th>GR4</th>
<th>GR5</th>
<th>GR6</th>
<th>Loc</th>
<th>Instruction</th>
</tr>
</thead>
<tbody>
<tr>
<td>0006FFFC</td>
<td>1030</td>
<td>0000</td>
<td>1000</td>
<td>0000</td>
<td>1140</td>
<td>Using X'1000',4</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1150</td>
<td>5010600C</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>↓</td>
<td>′</td>
<td>1</td>
<td>L1 ST 1,12(,6) Store merged-chain address</td>
</tr>
<tr>
<td>1154</td>
<td>48501006</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>0028</td>
<td>′</td>
<td>′</td>
<td>5</td>
<td>LH 5,6(,1) Load node index of input sequence of winner</td>
</tr>
<tr>
<td>1158</td>
<td>58301008</td>
<td>′</td>
<td>′</td>
<td>1070</td>
<td>′</td>
<td>′</td>
<td>↓</td>
<td>′</td>
<td>1150</td>
<td>L 3,8(,1) Load successor-record address</td>
</tr>
<tr>
<td>115C</td>
<td>1861</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1030</td>
<td>LR 6,1 Save old winner address for next merged-chain store</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>115E</td>
<td>1B22</td>
<td>′</td>
<td>00000000</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>SR 2,2 Zero GR2 as initial offset</td>
<td></td>
</tr>
<tr>
<td>1160</td>
<td>821A0004</td>
<td>′</td>
<td>0004FFFE</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>CFC 4 Compute codeword of new record based on new winner</td>
<td></td>
</tr>
<tr>
<td>1164</td>
<td>4720418A</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>BC 2,L3 Exit on CC=2 (sequence break)</td>
</tr>
<tr>
<td>1168</td>
<td>1813</td>
<td>′</td>
<td>1070</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>LR 1,3 Move new record entry to GRs 0-1</td>
</tr>
<tr>
<td>116A</td>
<td>1802</td>
<td>0004FFFE</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>L2 UPT Update tree data structure</td>
<td></td>
</tr>
<tr>
<td>116C</td>
<td>0102</td>
<td>0006FFFB</td>
<td>1040</td>
<td>′</td>
<td>′</td>
<td>0000</td>
<td>′</td>
<td>1150</td>
<td>BC 5,L1 If no codeword tie found, branch to next iteration</td>
<td></td>
</tr>
<tr>
<td>116E</td>
<td>47504150</td>
<td>↓</td>
<td>↓</td>
<td>↓</td>
<td>↓</td>
<td>↓</td>
<td>↓</td>
<td>↓</td>
<td>1150</td>
<td>* Fall through on tied codewords</td>
</tr>
<tr>
<td>1172</td>
<td>88200010</td>
<td>′</td>
<td>00000004</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>SRL 2,16 Shift codeword offset to initial offset position for CFC</td>
</tr>
<tr>
<td>1176</td>
<td>821A0004</td>
<td>′</td>
<td>0006FFFD</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>CFC 4 Compute loser codeword</td>
</tr>
<tr>
<td>117A</td>
<td>50254000</td>
<td>′</td>
<td>[CC=1]</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>ST 2,0(5,4) Store loser codeword in current storage node</td>
</tr>
<tr>
<td>117E</td>
<td>47C0416C</td>
<td>↓</td>
<td>↓</td>
<td>branch</td>
<td>′</td>
<td>′</td>
<td>↓</td>
<td>′</td>
<td>1150</td>
<td>BC 12,L2 Resume tree update if old storage-node entry is loser</td>
</tr>
<tr>
<td>1182</td>
<td>50354004</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>ST 3,4(5,4) Store loser record address</td>
</tr>
<tr>
<td>1186</td>
<td>47F0416C</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>BC 15,L2 Resume tree update</td>
</tr>
<tr>
<td>118A</td>
<td>...</td>
<td>↓</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>′</td>
<td>1150</td>
<td>L3 ... Control reaches here at end</td>
</tr>
</tbody>
</table>

Figure A-8. Program for Main Merge
<table>
<thead>
<tr>
<th>L#</th>
<th>GR5</th>
<th>GR2</th>
<th>GR3</th>
<th>Comment</th>
<th>1020</th>
<th>1018</th>
<th>1010</th>
<th>1008</th>
<th>GR0</th>
<th>GR1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>28</td>
<td>0004FFE</td>
<td>1070</td>
<td>No tie</td>
<td>00040000</td>
<td>1080</td>
<td></td>
<td></td>
<td>00060000</td>
<td>1030</td>
</tr>
<tr>
<td>20</td>
<td>30</td>
<td>00040000</td>
<td>1080</td>
<td>No tie</td>
<td>00040000</td>
<td>1080</td>
<td></td>
<td></td>
<td>00060000</td>
<td>1030</td>
</tr>
<tr>
<td>30</td>
<td>38</td>
<td>00040000</td>
<td>1090</td>
<td>CC = 0</td>
<td>Tie 00060000</td>
<td>1080</td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>31</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>32</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>40</td>
<td>48</td>
<td>00040000</td>
<td>10A0</td>
<td>CC = 0</td>
<td>Tie 00060000</td>
<td>1080</td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>41</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>42</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>50</td>
<td>40</td>
<td>0002FF7F</td>
<td>10F0</td>
<td>No tie</td>
<td>0002FF7F</td>
<td>10F0</td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>60</td>
<td>28</td>
<td>0002FF7F</td>
<td>1000</td>
<td>CC = 0</td>
<td>Tie 00060000</td>
<td>1080</td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>61</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>62</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00040000</td>
<td>1030</td>
</tr>
<tr>
<td>70</td>
<td>38</td>
<td>0002FF7F</td>
<td>10E0</td>
<td>No tie</td>
<td>0002FF7F</td>
<td>10E0</td>
<td></td>
<td></td>
<td>00060000</td>
<td>1030</td>
</tr>
<tr>
<td>80</td>
<td>48</td>
<td>0002FF7F</td>
<td>1100</td>
<td>CC = 0</td>
<td>Tie 00060000</td>
<td>1100</td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1100</td>
</tr>
<tr>
<td>81</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1100</td>
</tr>
<tr>
<td>82</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1100</td>
</tr>
<tr>
<td>90</td>
<td>30</td>
<td>00060000</td>
<td>10C0</td>
<td>No tie</td>
<td>*</td>
<td></td>
<td></td>
<td></td>
<td>00060000</td>
<td>1030</td>
</tr>
<tr>
<td>100</td>
<td>30</td>
<td>00200000</td>
<td>1140</td>
<td>No tie</td>
<td>00020000</td>
<td>1140</td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1100</td>
</tr>
<tr>
<td>110</td>
<td>28</td>
<td>0002FF7F</td>
<td>1110</td>
<td>CC = 0</td>
<td>Tie 0004FFFC</td>
<td>1110</td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1110</td>
</tr>
<tr>
<td>111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1110</td>
</tr>
<tr>
<td>112</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1110</td>
</tr>
<tr>
<td>113</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1110</td>
</tr>
<tr>
<td>114</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0002FF7F</td>
<td>1110</td>
</tr>
<tr>
<td>120</td>
<td>38</td>
<td>00020000</td>
<td>1130</td>
<td>CC = 0</td>
<td>Tie 00060000</td>
<td>1130</td>
<td></td>
<td></td>
<td>00020000</td>
<td>1130</td>
</tr>
<tr>
<td>121</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1130</td>
</tr>
<tr>
<td>122</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1130</td>
</tr>
<tr>
<td>130</td>
<td>40</td>
<td>0002FF6F</td>
<td>1120</td>
<td>No tie</td>
<td>0002FF6F</td>
<td>1120</td>
<td></td>
<td></td>
<td>00060000</td>
<td>1100</td>
</tr>
<tr>
<td>140</td>
<td>48</td>
<td>00020000</td>
<td>1140</td>
<td>No tie</td>
<td>00020000</td>
<td>1140</td>
<td></td>
<td></td>
<td>0004FFFC</td>
<td>1110</td>
</tr>
<tr>
<td>150</td>
<td>28</td>
<td>00020000</td>
<td>1140</td>
<td>No tie</td>
<td>00020000</td>
<td>1140</td>
<td></td>
<td></td>
<td>0002FF6F</td>
<td>1120</td>
</tr>
<tr>
<td>160</td>
<td>40</td>
<td>00020000</td>
<td>1140</td>
<td>CC = 0</td>
<td>Tie 800001140</td>
<td>1140</td>
<td></td>
<td></td>
<td>00020000</td>
<td>1140</td>
</tr>
<tr>
<td>161</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1140</td>
</tr>
<tr>
<td>162</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1140</td>
</tr>
<tr>
<td>163</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1140</td>
</tr>
<tr>
<td>164</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1140</td>
</tr>
<tr>
<td>165</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1140</td>
</tr>
<tr>
<td>166</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1140</td>
</tr>
<tr>
<td>170</td>
<td>38</td>
<td>00020000</td>
<td>1050</td>
<td>Branch</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00020000</td>
<td>1130</td>
</tr>
</tbody>
</table>

**Explanation:**

1 Line 0 shows the values in the tree after it is primed.
2 Means no swap.
3 ** Means no swap if UPDATE TREE method 1 is used or no examination if UPDATE TREE method 2 is used. Only method 2 is included in ESA/370 and ESA/390.
4 CC = 0 UPDATE TREE finds a tie and sets condition code 0.
5 Loses The tied-codeword routine finds that the node loses.
6 Wins The tied-codeword routine finds that the node wins.
7 Equal The tied-codeword routine finds that the keys are equal.
8 Branch Branches to terminate at 118A on sequence break.
9 No comp No compare.

*Figure A-9. Abbreviated Trace of Main Merge Processing*
Appendix B. Lists of Instructions

The following figures list instructions by name, mnemonic, and operation code. Some models may offer instructions that do not appear in the figures, such as those provided for assists or as part of special or custom features.

The operation code for the interpretive execution facility is not included in this appendix. See the publication IBM System/370 Extended Architecture Interpretive Execution, SA22-7095, for the operation code associated with that facility.

The operation code 00 hex with a two-byte instruction format is allocated for use by the program when an indication of an invalid operation is required. Operation code 00 hex will never be assigned to an instruction implemented in the CPU.

Explanation of Symbols in “Characteristics” and “Page” Columns:

$ Causes serialization.
¢ Causes serialization and checkpoint synchronization.
¢1 Causes serialization and checkpoint synchronization when the M1 and R2 fields contain 1111 binary and 0000 binary, respectively. Causes only serialization when the fast-BCR-serialization facility is installed, and the M1 and R2 fields contain 1110 binary and 0000 binary, respectively.
¢2 Causes serialization and checkpoint synchronization when the state entry to be unstacked is a program-call state entry.
¢3 Causes serialization and checkpoint synchronization when the set-key control is one.
£ Causes specific-operand serialization.
£1 Causes specific-operand serialization when the interlocked-access facility 1 is installed and the storage operand is aligned on an integral boundary corresponding to its size.
£2 Causes specific-operand serialization when the interlocked-access facility 2 is installed.
σ1 Restricted from transactional execution.
σ2 Restricted from transactional execution when R2 nonzero and branch tracing is enabled.
σ3 Restricted from transactional execution when mode tracing is enabled.
σ4Restricted from transactional execution when a monitor-event condition occurs.
σ5 Model dependent whether the instruction is restricted from transactional execution.
σ6 Restricted from transactional execution when the effective allow-AR-modification control is zero.
σ7 Restricted from transactional execution when the effective allow-floating-point-operation control is zero.
σ8 May be restricted from transactional execution depending on machine conditions.
σ9 Restricted in the constrained transactional-execution mode; a transaction-constraint program exception may be recognized. For PFD and PFDRL, the instruction is restricted only when the code in the M1 field is 6 or 7; for STCMH, the instruction is restricted only when the M3 field is zero and the code in the R1 field is 6 or 7.
σ10 Restricted to forward branches in the constrained transactional-execution mode.
σ11 PFD and PFDRL restricted from transactional execution when the code in the M1 field is 6 or 7; STCMH restricted when the M3 field is zero, and the code in the R1 field is 6 or 7.
A* Access exceptions for logical addresses. The optional asterisk indicates that a PER ZAD event is not recognized.
A1* Access exceptions; not all access exceptions may occur; see instruction description for details. The optional asterisk indicates that a PER ZAD event is not recognized.
A1 Access exceptions for instruction address.
B PER branch event.
B1 B1 field designates an access register in the access-register mode.
B2 B2 field designates an access register in the access-register mode.
B4 B4 field designates an access register in the access-register mode.
B† B1 field designates an access register when bit 47 of GR0 is zero, and bits 16-17 of the current PSW are 01 binary; or when bit 47 of GR0 is one, and bits 40-41 of GR0 are 01 binary.
| B‡ | B§ field designates an access register when bit 63 of GR0 is zero, and bits 16-17 of the current PSW are 01 binary; or when bit 63 of GR0 is one, and bits 56-57 of GR0 are 01 binary. |
| BP | B§ field designates an access register when PSW bits 16 and 17 have the value 01. |
| C  | Condition code is set. |
| C* | Condition code is optionally set. |
| C¹ | Condition code is set when the conditional-SSKE facility is installed, and either or both of the MR and MC bits are one. |
| CT | Configuration-topology facility. |
| CX | Constrained transactional-execution facility. |
| C2 | DAT-enhancement facility 2. |
| Da | AFP-register data exception. |
| Db | BFP-instruction data exception. |
| Dc | Compare-and-trap data exception. |
| DE | DAT-enhancement facility. |
| DF | Decimal-overflow exception. |
| Dg | General-operand data exception. |
| DK | Decimal-divide exception. |
| DM | Depending on the model, DIAGNOSE may generate various program exceptions and may change the condition code. |
| DO | Distinct-operands facility. |
| Dt | DFP-instruction data exception. |
| Dv | Vector-instruction data exception. |
| E  | E instruction format. |
| E2 | Extended-translation facility 2. |
| E3 | Extended-translation facility 3. |
| ED1 | Enhanced-DAT facility 1. |
| ED2 | Enhanced-DAT facility 2. |
| EH | Execution-hint facility. |
| EI | Extended-immediate facility. |
| EO | HFP-exponent-overflow exception. |
| ES | Expanded-storage facility. |
| ET | Extract-CPU-time facility. |
| EU | HFP-exponent-underflow exception. |
| EX | Execute exception. |
| F  | Floating-point-extension facility. |
| FC | Designation of access registers depends on the function code of the instruction. |
| FG | FPR-GR-transfer facility. |
| FK | HFP-floating-point-divide exception. |
| FL | Store-facility-list-extended facility. |
| FS | Floating-point-support-sign-handling facility. |
| G0 | Instruction execution includes the implied use of general register 0. |
| G1 | Instruction execution includes the implied use of general register 1. |
| G2 | Instruction execution includes the implied use of general register 2. |
| G4 | Instruction execution includes the implied use of general register 4. |
| GE | General-instructions-extension facility. |
| GM | Instruction execution includes the implied use of multiple general registers. |
| GS | Instruction execution includes the implied use of general register 1 as the subsystem-identification word. |
| HM | HFP-multiply-add/subtract facility. |
| HW | High-word facility. |
| I  | I instruction format. |
| IE | IE instruction format. |
| I1 | Access register 1 is implicitly designated in the access-register mode. |
| I4 | Access register 4 is implicitly designated in the access-register mode. |
| IC | Condition code alternative to interruptible instruction. |
| IF | Fixed-point-overflow exception. |
| IA | Interlocked-access facility. |
| I1 | Interruptible instruction. |
| IK | Fixed-point-divide exception. |
| LS | HFP-significance exception. |
| L  | New condition code is loaded. |
| LD | Long-displacement facility. |
| LT | Load-and-trap facility. |
| LZ | Load-and-zero-rightmost-byte facility. |
| L1 | Load/store-on-condition facility 1. |
| L2 | Load/store-on-condition facility 2. |
| MD | Designation of access registers in the access-register mode is model-dependent. |
| ME | Monitor event. |
| MI | Miscellaneous-instruction-extensions facility. |
| MII | MII instruction format. |
| MO | Move-with-optional-specifications facility. |
| MS | Message-security assist. |
| M3 | Message-security assist extension 3. |
| M4 | Message-security assist extension 4. |
| M5 | Message-security assist extension 5. |
| N  | Instruction is new in z/Architecture as compared to ESA/390. |
N3  Instruction is new in z/Architecture and has been added to ESA/390.
OP  Operand exception.
P   Privileged-operation exception; also, restricted from transactional execution.
PA  Processor-assist facility.
PC  DFP packed-conversion facility.
PK  Population-count facility.
PE  Parsing-enhancement facility.
PF  PFPO facility.
Q   Privileged-operation exception for semiprileged instructions; also, restricted from transactional execution.
R1  R1 field designates an access register in the access-register mode.
R2  R2 field designates an access register in the access-register mode.
R3  R3 field designates an access register in the access-register mode.
RA  Reusable-ASN-and-LX facility.
RB  Reset-reference-bits-multiple facility.
RI  RI instruction format.
RIE RIE instruction format.
RIL RIL instruction format.
RIS RIS instruction format.
RM  R1 field designates an access register in the access-register mode.
RR  RR instruction format.
RRD RRD instruction format.
RRE RRE instruction format.
RRF RRF instruction format.
RRS RRS instruction format.
RS  RS instruction format.
RSI RSI instruction format.
RSL RSL instruction format.
RSY RSY instruction format.
RX  RX instruction format.
RXE RXE instruction format.
RXF RXF instruction format.
RXY RXY instruction format.
S   S instruction format.
SC  Store-clock-fast facility.
SE  Special operation, stack-empty, stack-specification, and stack-type exceptions.
SF  Special-operation, stack-full, and stack-specification exceptions.
SI  SI instruction format.
SIL SIL instruction format.
SIY SIY instruction format.
SMI SMI instruction format.
SO  Special-operation exception.
SP  Specification exception.
SQ  HFP-square-root exception.
SS  SS instruction format.
SSE SSE instruction format.
SSF SSSF instruction format.
ST  PER storage-alteration event.
SU  PER store-using-real-address event.
SW  Special-operation exception and space-switch event.
T   Trace exceptions (which include trace table, addressing, and low-address protection).
TF  Decimal-floating-point facility.
TR  Decimal-floating-point-rounding facility.
TS  TOD-clock-steering facility.
TX  Transactional-execution facility.
U   Condition code is unpredictable.
U1  R1 field designates an access register unconditionally.
U2  R2 field designates an access register unconditionally.
UB  R1 and R3 fields designate access registers unconditionally, and B2 field designates an access register in the access-register mode.
UE  HFP unnormalized-extensions facility.
VF  Vector facility for z/Architecture.
VRI VRI instruction format.
VRR VRR instruction format.
VRS VRS instruction format.
VRX VRX instruction format.
VRF VRF instruction format.
WE  Space-switch event.
XF  IEEE-exception-simulation facility.
Xg  Simulated IEEE exception.
Xi  IEEE invalid-operation exception.
Xo  IEEE overflow exception.
Xq  Quantum exception (if the floating-point extension facility is installed).
Xu  IEEE underflow exception.
XX  Execute-extension facility.
Xx  IEEE inexact exception.
Xz  IEEE division-by-zero exception.
ZF  Decimal-floating-point-zoned-conversion facility.
Z\(^1\)  Additional exceptions and events for PROGRAM CALL (which include ASX-translation, EX-translation, LX-translation, PC-translation-specification, special-operation, stack-full, and stack-specification exceptions and space-switch event).
Z\(^2\)  Additional exceptions and events for PROGRAM TRANSFER (which include AFX-translation, ASX-translation, primary-authority, and special-operation exceptions and space-switch event).
Z\(^3\)  Additional exceptions for SET SECONDARY ASN (which include AFX translation, ASX translation, secondary authority, and special operation).
Z\(^4\)  Additional exceptions and events for PROGRAM RETURN (which include AFX-translation, ASX-translation, secondary-authority, special-operation, stack-empty, stack-operation, stack-specification, and stack-type exceptions and space-switch event).
Z\(^5\)  Additional exceptions for BRANCH AND STACK (which include special operation, stack full, and stack specification).
Z\(^6\)  Additional exceptions and events for PROGRAM TRANSFER WITH INSTANCE (which include AFX-translation, ASTE-instance, ASX-translation, primary-authority, special-operation, and subspace-replacement exceptions and space-switch event).
Z\(^7\)  Additional exceptions for SET SECONDARY ASN WITH INSTANCE (which include AFX translation, ASTE instance, ASX translation, secondary authority, special operation, and subspace replacement).
## Instructions Arranged by Name

<table>
<thead>
<tr>
<th>Name (32)</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD (32)</td>
<td>A</td>
<td>RX-a C</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD (32)</td>
<td>AR</td>
<td>RR C</td>
<td>IF</td>
<td>1A</td>
</tr>
<tr>
<td>ADD (32)</td>
<td>ARK</td>
<td>RRF-a C DO</td>
<td>IF</td>
<td>B9F8</td>
</tr>
<tr>
<td>ADD (32)</td>
<td>AY</td>
<td>RX-y-a C LD A</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AG</td>
<td>RX-y-a C N A</td>
<td>IF</td>
<td>B3</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AGR</td>
<td>RRE C N</td>
<td>IF</td>
<td>B908</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AGRK</td>
<td>RRF-a C DO</td>
<td>IF</td>
<td>B9E8</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AGF</td>
<td>RX-y-a C N A</td>
<td>IF</td>
<td>B3</td>
</tr>
<tr>
<td>ADD (64)</td>
<td>AGFR</td>
<td>RRE C N</td>
<td>IF</td>
<td>B918</td>
</tr>
<tr>
<td>ADD (extended BFP)</td>
<td>AXBR</td>
<td>RRE C p^3 SP Db Xi Xo Xu Xx</td>
<td>B34A</td>
<td></td>
</tr>
<tr>
<td>ADD (extended DFP)</td>
<td>AXTR</td>
<td>RRF-a C TF p^3 g^3 SP Dt Xi Xo Xu Xx Sp Xq</td>
<td>B3DA</td>
<td></td>
</tr>
<tr>
<td>ADD (long BFP)</td>
<td>ADBR</td>
<td>RRE C p^3 A Db Xi Xo Xu Xx</td>
<td>B3DA</td>
<td></td>
</tr>
<tr>
<td>ADD (long DFP)</td>
<td>ADTR</td>
<td>RRF-a C TF p^3 g^3 A Db Xi Xo Xu Xx Sp Xq</td>
<td>B3DA</td>
<td></td>
</tr>
<tr>
<td>ADD DECIMAL</td>
<td>AP</td>
<td>SS-b C p^3 A Dg DF</td>
<td>ST</td>
<td>B7</td>
</tr>
<tr>
<td>ADD HALFWORD (32)</td>
<td>AH</td>
<td>RX-a C A</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD HALFWORD (32)</td>
<td>AHI</td>
<td>RY-a C LD A</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AHI</td>
<td>RY-a C LD A</td>
<td>IF</td>
<td>A7</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AGHI</td>
<td>RY-a C LD A</td>
<td>IF</td>
<td>A7</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AIH</td>
<td>RY-a C LD A</td>
<td>IF</td>
<td>B9C8</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AHHLR</td>
<td>RX-a C</td>
<td>IF</td>
<td>B9D8</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AFI</td>
<td>RIL-a C EI</td>
<td>IF</td>
<td>C29</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AHIK</td>
<td>RIE-d C DO</td>
<td>IF</td>
<td>ECDA</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ASI</td>
<td>SIY C GE A</td>
<td>IF £</td>
<td>ST</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AGHI</td>
<td>RIE-d C DO</td>
<td>IF</td>
<td>EBD6</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AGFI</td>
<td>RIL-a C EI</td>
<td>IF</td>
<td>ECD9</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AGSI</td>
<td>SIY C GE A</td>
<td>IF £</td>
<td>ST</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AH</td>
<td>RIL-a C HW</td>
<td>IF</td>
<td>C2B</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>AL</td>
<td>RX-a C A</td>
<td>IF</td>
<td>C2B</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALR</td>
<td>RR C</td>
<td>IF</td>
<td>B9FA</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALK</td>
<td>RRF-a C DO</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALY</td>
<td>RX-ya C LD A</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALG</td>
<td>RX-ya C N</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALGR</td>
<td>RRE C N</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALGRK</td>
<td>RRF-a C DO</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALGF</td>
<td>RX-ya C N</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALGFR</td>
<td>RRE C N</td>
<td>IF</td>
<td>B91A</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALC</td>
<td>RX-ya C N</td>
<td>IF</td>
<td>B9C</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALCR</td>
<td>RRE C N</td>
<td>IF</td>
<td>B9C</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALGC</td>
<td>RX-ya C N</td>
<td>IF</td>
<td>B9C</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALCG</td>
<td>RRE C N</td>
<td>IF</td>
<td>B9C</td>
</tr>
<tr>
<td>ADD IMMEDIATE (32)</td>
<td>ALGFI</td>
<td>RIL-a C EI</td>
<td>IF</td>
<td>C2B</td>
</tr>
<tr>
<td>ADD IMMEDIATE WITH CARRY (32)</td>
<td>ALC</td>
<td>RX-ya C N</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE WITH CARRY (32)</td>
<td>ALCR</td>
<td>RRE C N</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE WITH CARRY (32)</td>
<td>ALGC</td>
<td>RX-ya C N</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE WITH CARRY (32)</td>
<td>ALCG</td>
<td>RRE C N</td>
<td>IF</td>
<td>B2</td>
</tr>
<tr>
<td>ADD IMMEDIATE WITH CARRY (32)</td>
<td>ALGFI</td>
<td>RIL-a C EI</td>
<td>IF</td>
<td>C2B</td>
</tr>
<tr>
<td>ADD IMMEDIATE WITH SIGNED IMMEDIATE (32)</td>
<td>ALSI</td>
<td>SIY C GE A</td>
<td>IF £</td>
<td>ST</td>
</tr>
<tr>
<td>ADD IMMEDIATE WITH SIGNED IMMEDIATE (32)</td>
<td>ALSI</td>
<td>SIY C GE A</td>
<td>IF £</td>
<td>ST</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 1 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-Code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (64-16)</td>
<td>ALGRSIIK</td>
<td>R-E= d C D=</td>
<td>A</td>
<td>36</td>
</tr>
<tr>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (64-8)</td>
<td>ALGSI</td>
<td>S-Y= C G=E</td>
<td>A</td>
<td>6A</td>
</tr>
<tr>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE HIGH (32)</td>
<td>ALSIH</td>
<td>R-I= a C H=W</td>
<td>A</td>
<td>2A</td>
</tr>
<tr>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE HIGH (32)</td>
<td>ALSIHN</td>
<td>R-I= a H=W</td>
<td>A</td>
<td>2A</td>
</tr>
<tr>
<td>ADD NORMALIZED (extended HFP)</td>
<td>AXR</td>
<td>R-R= C d=10</td>
<td>Da</td>
<td>3E</td>
</tr>
<tr>
<td>ADD NORMALIZED (long HFP)</td>
<td>AD</td>
<td>R-X=a C d=9</td>
<td>Da</td>
<td>3E</td>
</tr>
<tr>
<td>ADD NORMALIZED (short HFP)</td>
<td>AE</td>
<td>R-X=a C d=9</td>
<td>Da</td>
<td>3E</td>
</tr>
<tr>
<td>ADD NORMALIZED (short HFP)</td>
<td>AER</td>
<td>R-R= C d=9</td>
<td>Da</td>
<td>3E</td>
</tr>
<tr>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>AW</td>
<td>R-X=a C d=9</td>
<td>Da</td>
<td>3E</td>
</tr>
<tr>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>AWR</td>
<td>R-R= C d=9</td>
<td>Da</td>
<td>3E</td>
</tr>
<tr>
<td>ADD UNNORMALIZED (short HFP)</td>
<td>AUR</td>
<td>R-R= C d=9</td>
<td>Da</td>
<td>3E</td>
</tr>
<tr>
<td>AND (32)</td>
<td>N</td>
<td>R-X=a C A</td>
<td></td>
<td>54</td>
</tr>
<tr>
<td>AND (32)</td>
<td>NR</td>
<td>R-R= C A</td>
<td></td>
<td>B9F4</td>
</tr>
<tr>
<td>AND (32)</td>
<td>NRK</td>
<td>R-RF=a C D=</td>
<td>A</td>
<td>E354</td>
</tr>
<tr>
<td>AND (64)</td>
<td>NG</td>
<td>R-RY=a C N A</td>
<td></td>
<td>E380</td>
</tr>
<tr>
<td>AND (64)</td>
<td>NGR</td>
<td>R-RRE C N</td>
<td></td>
<td>B980</td>
</tr>
<tr>
<td>AND (character)</td>
<td>NGRK</td>
<td>R-RF=a C d=10</td>
<td>A</td>
<td>49E4</td>
</tr>
<tr>
<td>AND (immediate)</td>
<td>NC</td>
<td>S-S=a C A</td>
<td></td>
<td>94</td>
</tr>
<tr>
<td>AND (immediate)</td>
<td>NI</td>
<td>S-I= C A</td>
<td></td>
<td>94</td>
</tr>
<tr>
<td>AND IMMEDIATE (high high)</td>
<td>NIY</td>
<td>S-IY=C LD A</td>
<td></td>
<td>EB64</td>
</tr>
<tr>
<td>AND IMMEDIATE (high low)</td>
<td>NIH</td>
<td>R-I= a C N</td>
<td></td>
<td>A55</td>
</tr>
<tr>
<td>AND IMMEDIATE (high)</td>
<td>NIHF</td>
<td>R-I= a C E I</td>
<td></td>
<td>C0A</td>
</tr>
<tr>
<td>AND IMMEDIATE (low high)</td>
<td>NILH</td>
<td>R-I= a C N</td>
<td></td>
<td>A56</td>
</tr>
<tr>
<td>AND IMMEDIATE (low low)</td>
<td>NIL</td>
<td>R-I= a C N</td>
<td></td>
<td>A57</td>
</tr>
<tr>
<td>AND IMMEDIATE (low)</td>
<td>NILF</td>
<td>R-I= a C E I</td>
<td></td>
<td>C0B</td>
</tr>
<tr>
<td>BRANCH AND LINK</td>
<td>BAL</td>
<td>R-X=a C d=10</td>
<td></td>
<td>45</td>
</tr>
<tr>
<td>BRANCH AND LINK</td>
<td>BALR</td>
<td>R-R= C d=9</td>
<td></td>
<td>45</td>
</tr>
<tr>
<td>BRANCH AND SAVE</td>
<td>BAS</td>
<td>R-X=a C d=9</td>
<td></td>
<td>4D</td>
</tr>
<tr>
<td>BRANCH AND SAVE</td>
<td>BASR</td>
<td>R-R= C d=9</td>
<td></td>
<td>4D</td>
</tr>
<tr>
<td>BRANCH AND SAVE AND SET MODE</td>
<td>BASSM</td>
<td>R-R= C d=9</td>
<td></td>
<td>4D</td>
</tr>
<tr>
<td>BRANCH AND SET AUTHORITY</td>
<td>BSA</td>
<td>R-R= Q A= T</td>
<td></td>
<td>B25A</td>
</tr>
<tr>
<td>BRANCH AND SET MODE</td>
<td>BSM</td>
<td>R-R= C d=9</td>
<td></td>
<td>B25A</td>
</tr>
<tr>
<td>BRANCH AND STACK</td>
<td>BAKR</td>
<td>R-R= C A= T</td>
<td></td>
<td>B240</td>
</tr>
<tr>
<td>BRANCH IN SUBSPACE GROUP</td>
<td>BSG</td>
<td>R-R= C A= T</td>
<td></td>
<td>B258</td>
</tr>
<tr>
<td>BRANCH ON CONDITION</td>
<td>BC</td>
<td>R-X=b C d=10</td>
<td></td>
<td>47</td>
</tr>
<tr>
<td>BRANCH ON CONDITION</td>
<td>BCR</td>
<td>R-R= C d=10</td>
<td></td>
<td>B06</td>
</tr>
<tr>
<td>BRANCH ON COUNT (32)</td>
<td>BCT</td>
<td>R-X=a C d=9</td>
<td></td>
<td>46</td>
</tr>
<tr>
<td>BRANCH ON COUNT (32)</td>
<td>BCTR</td>
<td>R-R= C d=9</td>
<td></td>
<td>46</td>
</tr>
<tr>
<td>BRANCH ON COUNT (64)</td>
<td>BCTG</td>
<td>R-R= C N d=9</td>
<td></td>
<td>E346</td>
</tr>
<tr>
<td>BRANCH ON INDEX HIGH (32)</td>
<td>BXC</td>
<td>R-R= C d=10</td>
<td></td>
<td>B346</td>
</tr>
<tr>
<td>BRANCH ON INDEX HIGH (64)</td>
<td>BXH</td>
<td>R-R= C N d=9</td>
<td></td>
<td>B346</td>
</tr>
<tr>
<td>BRANCH ON INDEX LOW OR EQUAL (32)</td>
<td>BXLE</td>
<td>R-R= C d=10</td>
<td></td>
<td>87</td>
</tr>
<tr>
<td>BRANCH ON INDEX LOW OR EQUAL (64)</td>
<td>BXLEG</td>
<td>R-R= C N d=9</td>
<td></td>
<td>87</td>
</tr>
<tr>
<td>BRANCH PREDICTION PRELOAD</td>
<td>BPP</td>
<td>S-MI= E= C d=10</td>
<td></td>
<td>C5</td>
</tr>
<tr>
<td>BRANCH PREDICTION RELATIVE PRELOAD</td>
<td>BPRP</td>
<td>M-I= E= C d=10</td>
<td></td>
<td>C5</td>
</tr>
<tr>
<td>BRANCH RELATIVE AND SAVE</td>
<td>BRAS</td>
<td>R-I= b C d=10</td>
<td></td>
<td>A75</td>
</tr>
<tr>
<td>BRANCH RELATIVE AND SAVE LONG</td>
<td>BRASL</td>
<td>R-I= b N d=10</td>
<td></td>
<td>47</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON CONDITION</td>
<td>BRC</td>
<td>R-I= c C d=10</td>
<td></td>
<td>A74</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON CONDITION LONG</td>
<td>BRCL</td>
<td>R-I= c N d=10</td>
<td></td>
<td>C44</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON COUNT (32)</td>
<td>BRCT</td>
<td>R-I= b C d=10</td>
<td></td>
<td>A76</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 2 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>BRANCH RELATIVE ON COUNT (64)</td>
<td>BRCTG</td>
<td>Rl-b N</td>
<td>B</td>
<td>A77</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON COUNT HIGH (32)</td>
<td>BRCTH</td>
<td>Rl-b HW</td>
<td>B</td>
<td>C6</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON INDEX HIGH (32)</td>
<td>BRXH</td>
<td>Rl-e N</td>
<td>B</td>
<td>B4</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON INDEX HIGH (64)</td>
<td>BRXHG</td>
<td>Rl-e N</td>
<td>B</td>
<td>E44</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON INDEX LOW OR EQ. (32)</td>
<td>BRXLE</td>
<td>Rl-e N</td>
<td>B</td>
<td>85</td>
</tr>
<tr>
<td>BRANCH RELATIVE ON INDEX LOW OR EQ. (64)</td>
<td>BRXLG</td>
<td>Rl-e N</td>
<td>B</td>
<td>EC45</td>
</tr>
<tr>
<td>CANCEL SUBCHANNEL</td>
<td>XSC</td>
<td>P</td>
<td>G</td>
<td>B276</td>
</tr>
<tr>
<td>CHECKSUM</td>
<td>CKSM</td>
<td>Rr E</td>
<td>C</td>
<td>B241</td>
</tr>
<tr>
<td>CIPHER MESSAGE</td>
<td>KM</td>
<td>Rr E</td>
<td>C</td>
<td>B92E</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH CHAINING</td>
<td>KMC</td>
<td>Rr E</td>
<td>C</td>
<td>B92F</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH CIPHER FEEDBACK</td>
<td>KMF</td>
<td>Rr E</td>
<td>C</td>
<td>B92A</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH COUNTER</td>
<td>KMR</td>
<td>Rr E</td>
<td>C</td>
<td>B92D</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH OUTPUT FEEDBACK</td>
<td>KMO</td>
<td>Rr E</td>
<td>C</td>
<td>B92B</td>
</tr>
<tr>
<td>CLEAR SUBCHANNEL</td>
<td>CSCH</td>
<td>P</td>
<td>G</td>
<td>B230</td>
</tr>
<tr>
<td>COMPARE (32)</td>
<td>C</td>
<td>Rx-a C</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE (32)</td>
<td>CR</td>
<td>Rr C</td>
<td>A</td>
<td>59</td>
</tr>
<tr>
<td>COMPARE (32)</td>
<td>CY</td>
<td>Rx-a C</td>
<td>A</td>
<td>E359</td>
</tr>
<tr>
<td>COMPARE (64)</td>
<td>CG</td>
<td>Rx-a C</td>
<td>N</td>
<td>E320</td>
</tr>
<tr>
<td>COMPARE (64)</td>
<td>CGR</td>
<td>Rr C</td>
<td>N</td>
<td>B920</td>
</tr>
<tr>
<td>COMPARE (64--32)</td>
<td>CFG</td>
<td>Rr Rx-a C N</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE (64--32)</td>
<td>CGRF</td>
<td>Rr C</td>
<td>N</td>
<td>E330</td>
</tr>
<tr>
<td>COMPARE (extended BFP)</td>
<td>CXBR</td>
<td>Rr C</td>
<td>N</td>
<td>B349</td>
</tr>
<tr>
<td>COMPARE (extended DFP)</td>
<td>CXTR</td>
<td>Rr C</td>
<td>N</td>
<td>E341</td>
</tr>
<tr>
<td>COMPARE (extended HFP)</td>
<td>CXR</td>
<td>Rr C</td>
<td>N</td>
<td>B369</td>
</tr>
<tr>
<td>COMPARE (long BFP)</td>
<td>CDB</td>
<td>Rr Rx-e C</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE (long BFP)</td>
<td>CDBR</td>
<td>Rr C</td>
<td>A</td>
<td>E19</td>
</tr>
<tr>
<td>COMPARE (long BFP)</td>
<td>CDTR</td>
<td>Rr C</td>
<td>A</td>
<td>B319</td>
</tr>
<tr>
<td>COMPARE (long HFP)</td>
<td>CD</td>
<td>Rx-e C</td>
<td>A</td>
<td>E341</td>
</tr>
<tr>
<td>COMPARE (long HFP)</td>
<td>CDR</td>
<td>Rr C</td>
<td>A</td>
<td>B341</td>
</tr>
<tr>
<td>COMPARE (short BFP)</td>
<td>CEB</td>
<td>Rx-e C</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE (short BFP)</td>
<td>CEBR</td>
<td>Rr C</td>
<td>A</td>
<td>E19</td>
</tr>
<tr>
<td>COMPARE (short HFP)</td>
<td>CE</td>
<td>Rx-e C</td>
<td>A</td>
<td>B309</td>
</tr>
<tr>
<td>COMPARE (short HFP)</td>
<td>CER</td>
<td>Rr C</td>
<td>A</td>
<td>E19</td>
</tr>
<tr>
<td>COMPARE AND BRANCH (32)</td>
<td>CRB</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND BRANCH RELATIVE (32)</td>
<td>CRJ</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND BRANCH RELATIVE (64)</td>
<td>CGRJ</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND FORM CODEWORD</td>
<td>CFC</td>
<td>S C</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND REPLACE DAT TABLE ENTRY</td>
<td>CRDTE</td>
<td>Rr-f Ed2 P A</td>
<td>S</td>
<td>B96F</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (extended BFP)</td>
<td>KXBR</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (extended DFP)</td>
<td>KXTR</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (long BFP)</td>
<td>KDB</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (long BFP)</td>
<td>KDBR</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (long BFP)</td>
<td>KDDR</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (short BFP)</td>
<td>KEB</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL (short BFP)</td>
<td>KEBR</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SWAP (32)</td>
<td>CS</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SWAP (64)</td>
<td>CSG</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SWAP AND PURGE (32)</td>
<td>CSP</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SWAP AND PURGE (64)</td>
<td>CSPG</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND SWAP AND STORE</td>
<td>CSS</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND TRAP (32)</td>
<td>CRT</td>
<td>Rr-f T</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE AND TRAP (64)</td>
<td>CRT</td>
<td>Rr-f T</td>
<td>A</td>
<td>B2</td>
</tr>
<tr>
<td>COMPARE BIASED EXPONENT (extended DFP)</td>
<td>CEXTR</td>
<td>Rr S</td>
<td>A</td>
<td>B2</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 3 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARE BIASED EXPONENT (long DFP)</td>
<td>CEDTR</td>
<td>Df</td>
<td>B3F4</td>
<td>20-22</td>
</tr>
<tr>
<td>COMPARE DECIMAL</td>
<td>CP</td>
<td>Dg</td>
<td>B1, B2</td>
<td>8-7</td>
</tr>
<tr>
<td>COMPARE DOUBLE AND SWAP (32)</td>
<td>CDS</td>
<td>ST</td>
<td>B3</td>
<td>7-127</td>
</tr>
<tr>
<td>COMPARE DOUBLE AND SWAP (32)</td>
<td>CDSY</td>
<td>ST</td>
<td>B3</td>
<td>7-127</td>
</tr>
<tr>
<td>COMPARE DOUBLE AND SWAP (64)</td>
<td>CDG</td>
<td>ST</td>
<td>B3</td>
<td>7-127</td>
</tr>
<tr>
<td>COMPARE HALFWORD (32 ⋅ 16)</td>
<td>CH</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD (32 ⋅ 16)</td>
<td>CHY</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD (64 ⋅ 16)</td>
<td>CGH</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (16 ⋅ 16)</td>
<td>CHHISI</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (32 ⋅ 16)</td>
<td>CHI</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (32 ⋅ 16)</td>
<td>CHISI</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (64 ⋅ 16)</td>
<td>CGHI</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (64 ⋅ 16)</td>
<td>CGHISI</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (32 ⋅ 16)</td>
<td>CHRL</td>
<td></td>
<td>B3</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE (64 ⋅ 16)</td>
<td>CGHRIL</td>
<td>A*</td>
<td>C64</td>
<td>7-133</td>
</tr>
<tr>
<td>COMPARE HIGH (32)</td>
<td>CHF</td>
<td></td>
<td>B3</td>
<td>7-134</td>
</tr>
<tr>
<td>COMPARE HIGH (32)</td>
<td>CHHR</td>
<td></td>
<td>B3</td>
<td>7-134</td>
</tr>
<tr>
<td>COMPARE HIGH (32)</td>
<td>CHLR</td>
<td></td>
<td>B3</td>
<td>7-134</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE (32)</td>
<td>CFI</td>
<td></td>
<td>C2D</td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE (64 ⋅ 32)</td>
<td>CGFI</td>
<td></td>
<td>C2C</td>
<td>7-117</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND BRANCH (32 ⋅ 8)</td>
<td>CIB</td>
<td></td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND BRANCH (64 ⋅ 32)</td>
<td>CGIB</td>
<td></td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (32 ⋅ 8)</td>
<td>CU</td>
<td></td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (64 ⋅ 8)</td>
<td>CGU</td>
<td></td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND TRAP (32 ⋅ 16)</td>
<td>CIT</td>
<td></td>
<td>E72</td>
<td>7-132</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE AND TRAP (64 ⋅ 16)</td>
<td>CGIT</td>
<td></td>
<td>E70</td>
<td>7-132</td>
</tr>
<tr>
<td>COMPARE IMMEDIATE HIGH (32)</td>
<td>CIH</td>
<td></td>
<td>C70</td>
<td>7-132</td>
</tr>
<tr>
<td>COMPARE LOGICAL (32)</td>
<td>CL</td>
<td></td>
<td>55</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (32)</td>
<td>CLR</td>
<td></td>
<td>15</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64)</td>
<td>CLG</td>
<td></td>
<td>B3</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64)</td>
<td>CLGR</td>
<td></td>
<td>B3</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (64 ⋅ 32)</td>
<td>CLGFR</td>
<td></td>
<td>B3</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (character)</td>
<td>CLC</td>
<td></td>
<td>B1, B2</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (immediate)</td>
<td>CLI</td>
<td></td>
<td>B3</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL (immediate)</td>
<td>CLY</td>
<td></td>
<td>B3</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND BRANCH (32)</td>
<td>CLRIB</td>
<td>GE</td>
<td>E555</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND BRANCH (64)</td>
<td>CLGB</td>
<td>GE</td>
<td>E21</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND BRANCH RELATIVE (32)</td>
<td>CLRJ</td>
<td>GE</td>
<td>E72</td>
<td>7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND BRANCH RELATIVE (64)</td>
<td>CLGRJ</td>
<td>GE</td>
<td>E65</td>
<td>7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND TRAP (32)</td>
<td>CLRT</td>
<td>GE</td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE LOGICAL AND TRAP (64)</td>
<td>CLGT</td>
<td>GE</td>
<td>B</td>
<td>7-138</td>
</tr>
<tr>
<td>COMPARE LOGICAL CHAR. UNDER MASK (high)</td>
<td>CLMH</td>
<td></td>
<td>B3</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL CHAR. UNDER MASK (low)</td>
<td>CLM</td>
<td></td>
<td>B3</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL CHAR. UNDER MASK (low)</td>
<td>CLMY</td>
<td></td>
<td>B3</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL HIGH (32)</td>
<td>CLH</td>
<td></td>
<td>B3</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL HIGH (32)</td>
<td>CLHHR</td>
<td></td>
<td>B3</td>
<td>7-140</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (16 ⋅ 16)</td>
<td>CLHISI</td>
<td></td>
<td>B3</td>
<td>7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (32)</td>
<td>CLFI</td>
<td></td>
<td>C2F</td>
<td>7-135</td>
</tr>
</tbody>
</table>

*Figure B-1. Instructions Arranged by Name* (Part 4 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic Characteristics</th>
<th>Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (32-16)</td>
<td>CLPHSI SIL C GE A</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>E55D 7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64-16)</td>
<td>CLGHSI SIL C GE A</td>
<td>B&lt;sub&gt;1&lt;/sub&gt;</td>
<td>E559 7-135</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64-32)</td>
<td>CLGFI RIL-a C EI</td>
<td>C2E 7-135</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH (32-8)</td>
<td>CLIB RIS GE o&lt;sup&gt;3&lt;/sup&gt;</td>
<td>B</td>
<td>ECFF 7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH (64-8)</td>
<td>CLGIB RIS GE o&lt;sup&gt;3&lt;/sup&gt;</td>
<td>B</td>
<td>ECFD 7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (32-8)</td>
<td>CLJU RIE-c GE o&lt;sup&gt;3&lt;/sup&gt;</td>
<td>B</td>
<td>EC7F 7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (64-8)</td>
<td>CLJU RIE-c GE o&lt;sup&gt;3&lt;/sup&gt;</td>
<td>B</td>
<td>EC7D 7-137</td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-139</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-139</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE HIGH (32)</td>
<td>CLIH RIL-a C HW</td>
<td>CCF 7-141</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (32)</td>
<td>CLCL RR C GE A* SP C6F 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64)</td>
<td>CLGRL RIL-b C GE A* SP C6A 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (32)</td>
<td>CLIJ RIE-c GE A* SP C67 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (64)</td>
<td>CLGIJ RIE-c GE A* SP C65 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE HIGH (32)</td>
<td>CLIH RIL-a C HW</td>
<td>CCF 7-141</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (32)</td>
<td>CLCL RR C GE A* SP C6F 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64)</td>
<td>CLGRL RIL-b C GE A* SP C6A 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (32)</td>
<td>CLIJ RIE-c GE A* SP C67 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (64)</td>
<td>CLGIJ RIE-c GE A* SP C65 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE HIGH (32)</td>
<td>CLIH RIL-a C HW</td>
<td>CCF 7-141</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (32)</td>
<td>CLCL RR C GE A* SP C6F 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64)</td>
<td>CLGRL RIL-b C GE A* SP C6A 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (32)</td>
<td>CLIJ RIE-c GE A* SP C67 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (64)</td>
<td>CLGIJ RIE-c GE A* SP C65 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE HIGH (32)</td>
<td>CLIH RIL-a C HW</td>
<td>CCF 7-141</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (32)</td>
<td>CLCL RR C GE A* SP C6F 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64)</td>
<td>CLGRL RIL-b C GE A* SP C6A 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (32)</td>
<td>CLIJ RIE-c GE A* SP C67 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (64)</td>
<td>CLGIJ RIE-c GE A* SP C65 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-8)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-8)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (32-16)</td>
<td>CLFIT RIE-a GE Dc</td>
<td>EC73 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP RELATIVE (64-16)</td>
<td>CLGIT RIE-a GE Dc</td>
<td>EC71 7-137</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE HIGH (32)</td>
<td>CLIH RIL-a C HW</td>
<td>CCF 7-141</td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (32)</td>
<td>CLCL RR C GE A* SP C6F 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE (64)</td>
<td>CLGRL RIL-b C GE A* SP C6A 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (32)</td>
<td>CLIJ RIE-c GE A* SP C67 7-136</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE RELATIVE (64)</td>
<td>CLGIJ RIE-c GE A* SP C65 7-136</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 5 of 22)
Name
CONVERT FROM FIXED (64 to short BFP)
CONVERT FROM FIXED (64 to short BFP)
CONVERT FROM FIXED (64 to short HFP)
CONVERT FROM LOGICAL (32 to extended BFP)
CONVERT FROM LOGICAL (32 to extended DFP)
CONVERT FROM LOGICAL (32 to long BFP)
CONVERT FROM LOGICAL (32 to long DFP)
CONVERT FROM LOGICAL (32 to short BFP)
CONVERT FROM LOGICAL (64 to extended BFP)
CONVERT FROM LOGICAL (64 to extended DFP)
CONVERT FROM LOGICAL (64 to long BFP)
CONVERT FROM LOGICAL (64 to long DFP)
CONVERT FROM LOGICAL (64 to short BFP)
CONVERT FROM PACKED (to extended DFP)
CONVERT FROM PACKED (to long DFP)
CONVERT FROM SIGNED PACKED (128 to extended
DFP)
CONVERT FROM SIGNED PACKED (64 to long DFP)
CONVERT FROM UNSIGNED PACKED (128 to ext.
DFP)
CONVERT FROM UNSIGNED PACKED (64 to long
DFP)
CONVERT FROM ZONED (to extended DFP)
CONVERT FROM ZONED (to long DFP)
CONVERT HFP TO BFP (long to short)
CONVERT HFP TO BFP (long)
CONVERT TO BINARY (32)
CONVERT TO BINARY (32)
CONVERT TO BINARY (64)
CONVERT TO DECIMAL (32)
CONVERT TO DECIMAL (32)
CONVERT TO DECIMAL (64)
CONVERT TO FIXED (extended BFP to 32)
CONVERT TO FIXED (extended BFP to 32)
CONVERT TO FIXED (extended BFP to 64)
CONVERT TO FIXED (extended BFP to 64)
CONVERT TO FIXED (extended DFP to 32)
CONVERT TO FIXED (extended DFP to 64)
CONVERT TO FIXED (extended DFP to 64)
CONVERT TO FIXED (extended HFP to 32)
CONVERT TO FIXED (extended HFP to 64)
CONVERT TO FIXED (long BFP to 32)
CONVERT TO FIXED (long BFP to 32)
CONVERT TO FIXED (long BFP to 64)
CONVERT TO FIXED (long BFP to 64)
CONVERT TO FIXED (long DFP to 32)
CONVERT TO FIXED (long DFP to 64)
CONVERT TO FIXED (long DFP to 64)
CONVERT TO FIXED (long HFP to 32)
CONVERT TO FIXED (long HFP to 64)
CONVERT TO FIXED (short BFP to 32)
CONVERT TO FIXED (short BFP to 32)
CONVERT TO FIXED (short BFP to 64)
CONVERT TO FIXED (short BFP to 64)
CONVERT TO FIXED (short HFP to 32)

Mnemonic
CEGBR
CEGBRA
CEGR
CXLFBR
CXLFTR
CDLFBR
CDLFTR
CELFBR
CXLGBR
CXLGTR
CDLGBR
CDLGTR
CELGBR
CXPT
CDPT
CXSTR

RRE
RRF-e
RRE
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RSL-b
RSL-b
RRE

N
F
N
F
F
F
F
F
F
F
F
F
F
PC
PC
TF

¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9 A
7,9
¤
A
7,9
¤

CDSTR
CXUTR

RRE
RRE

TF
TF

¤
¤7,9

7,9

Dt
SP Dt

Dg
Dg

B3F3 20-27
B3FA 20-27

CDUTR

RRE

TF

¤7,9

Dt

Dg

B3F2 20-27

CXZT
CDZT
TBEDR
TBDR
CVB
CVBY
CVBG
CVD
CVDY
CVDG
CFXBR
CFXBRA
CGXBR
CGXBRA
CFXTR
CGXTR
CGXTRA
CFXR
CGXR
CFDBR
CFDBRA
CGDBR
CGDBRA
CFDTR
CGDTR
CGDTRA
CFDR
CGDR
CFEBR
CFEBRA
CGEBR
CGEBRA
CFER

RSL
RSL
RRF-e
RRF-e
RX-a
RXY-a
RXY-a
RX-a
RXY-a
RXY-a
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e
RRF-e

ZF
ZF

¤
7,9
¤
¤7,9
7,9
¤
9
¤
¤9
9
¤
9
¤
¤9
9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9
7,9
¤
7,9
¤
¤7,9

C
C
LD
N
LD
N
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C
C

Figure B-1. Instructions Arranged by Name (Part 6 of 22)

B-10

IBM z/Architecture Principles of Operation

F
N
F
F
TF
F
N
F
N
F
F
TF
F
N
F
N
F

7,9

7,9

A
A

SP
SP
SP
SP
SP
SP
SP
SP
SP
SP
SP
SP

SP
SP
SP
SP

A
A
A
A
A
A

Characteristics
Db
Db
Da
Db
Dt
Db
Dt
Db
Db
Dt
Db
Dt
Db
Dt Dg
Dt Dg
Dt Dg

Xx
Xx

Xx

Xx
Xx Xq
Xx
B2
B2

Dt Dg
Dt Dg
Da
Da
Dg IK
Dg IK
Dg IK

B2
B2

ST
ST
ST
SP
SP
SP
SP
SP
SP
SP
SP
SP
SP
SP
SP
SP

SP
SP
SP
SP
SP
SP
SP

Db
Db
Db
Db
Dt
Dt
Dt
Da
Da
Db
Db
Db
Db
Dt
Dt
Dt
Da
Da
Db
Db
Db
Db
Da

Xi
Xi
Xi
Xi
Xi
Xi
Xi

Xx
Xx
Xx
Xx
Xx
Xx
Xx

Xi
Xi
Xi
Xi
Xi
Xi
Xi

Xx
Xx
Xx
Xx
Xx
Xx
Xx

Xi
Xi
Xi
Xi

Xx
Xx
Xx
Xx

B2
B2
B2
B2
B2
B2

Opcode
B3A4
B3A4
B3C4
B392
B95B
B391
B953
B390
B3A2
B95A
B3A1
B952
B3A0
EDAF
EDAE
B3FB

EDAB
EDAA
B350
B351
4F
E306
E30E
4E
E326
E32E
B39A
B39A
B3AA
B3AA
B949
B3E9
B3E9
B3BA
B3CA
B399
B399
B3A9
B3A9
B941
B3E1
B3E1
B3B9
B3C9
B398
B398
B3A8
B3A8
B3B8

Page
19-19
19-19
18-11
19-21
20-24
19-21
20-24
19-21
19-21
20-24
19-21
20-24
19-21
20-25
20-25
20-27

20-28
20-28
9-28
9-28
7-188
7-188
7-188
7-189
7-189
7-189
19-22
19-22
19-22
19-22
20-29
20-28
20-29
18-11
18-11
19-22
19-22
19-22
19-22
20-29
20-28
20-29
18-11
18-11
19-22
19-22
19-22
19-22
18-11


<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic Characteristics</th>
<th>Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT TO FIXED (short HFP to 64)</td>
<td>CGER</td>
<td>RRF-e C N g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (extended BFP to 32)</td>
<td>CLFXBR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (extended BFP to 64)</td>
<td>CLGXBR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (extended DFP to 32)</td>
<td>CLFXTR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (extended DFP to 64)</td>
<td>CLGXTR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (long BFP to 32)</td>
<td>CLFDBR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (long BFP to 64)</td>
<td>CLGDBR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (long DFP to 32)</td>
<td>CLFDTR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (long DFP to 64)</td>
<td>CLGDTR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (short BFP to 32)</td>
<td>CLFEBR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL (short BFP to 64)</td>
<td>CLGEBR</td>
<td>RRF-e C F g</td>
<td>Db Xi Xx</td>
</tr>
<tr>
<td>CONVERT TO PACKED (from extended DFP)</td>
<td>CPXT</td>
<td>RSL-b C PC g</td>
<td>Dt DF</td>
</tr>
<tr>
<td>CONVERT TO PACKED (from long DFP)</td>
<td>CPDT</td>
<td>RSL-b C PC g</td>
<td>Dt DF</td>
</tr>
<tr>
<td>CONVERT TO SIGNED PACKED (extended DFP to 128)</td>
<td>CSXTR</td>
<td>RRF-d TF g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO SIGNED PACKED (long DFP to 64)</td>
<td>CSDTR</td>
<td>RRF-d TF g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO SIGNED PACKED (long DFP to 128)</td>
<td>CUXTR</td>
<td>RRF-d TF g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO SIGNED PACKED (long DFP to 64)</td>
<td>CUDTR</td>
<td>RRF-d TF g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO ZONED (from extended DFP)</td>
<td>CZXT</td>
<td>RRL C ZF g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO ZONED (from long DFP)</td>
<td>CXTZ</td>
<td>RRL C ZF g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO ZONED (from extended DFP)</td>
<td>CSDT</td>
<td>RRL C ZF g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO ZONED (from long DFP)</td>
<td>CXTZ</td>
<td>RRL C ZF g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT TO UNICODE TO UTF-8</td>
<td>CUUTF</td>
<td>RRF-c C g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT UTF-16 TO UTF-32</td>
<td>CU24</td>
<td>RRF-c C E3 g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT UTF-16 TO UTF-8</td>
<td>CU21</td>
<td>RRF-c C g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT UTF-8 TO UNCODE</td>
<td>CUTF</td>
<td>RRF-c C g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT UTF-8 TO UTF-16</td>
<td>CU12</td>
<td>RRF-c C g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT UTF-8 TO UTF-32</td>
<td>CU14</td>
<td>RRF-c C E3 g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT UTF-32 TO UTF-16</td>
<td>CU42</td>
<td>RRF-c C E3 g</td>
<td>Da</td>
</tr>
<tr>
<td>CONVERT UTF-32 TO UTF-8</td>
<td>CU41</td>
<td>RRF-c C E3 g</td>
<td>Da</td>
</tr>
<tr>
<td>COPY ACCESS</td>
<td>CPYA</td>
<td>RRF-c C g</td>
<td>Da</td>
</tr>
<tr>
<td>COPY SIGN (long)</td>
<td>CPSDR</td>
<td>RRF-c C g</td>
<td>Da</td>
</tr>
<tr>
<td>DIVIDE (32–64)</td>
<td>D</td>
<td>RX-a</td>
<td>g6 A SP</td>
</tr>
<tr>
<td>DIVIDE (32–64)</td>
<td>DR</td>
<td>RR</td>
<td>g6 A SP</td>
</tr>
<tr>
<td>DIVIDE (extended BFP)</td>
<td>DXBR</td>
<td>RRE g6 A SP</td>
<td>Db Xi Xz Xo Xu Xx</td>
</tr>
<tr>
<td>DIVIDE (extended DFP)</td>
<td>DXTR</td>
<td>RRF-a TF g6 A SP</td>
<td>Db Xi Xz Xo Xu Xx</td>
</tr>
<tr>
<td>DIVIDE (extended DFP)</td>
<td>DXTRA</td>
<td>RRF-a TF g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (extended DFP)</td>
<td>DXR</td>
<td>RRE g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (long BFP)</td>
<td>DDB</td>
<td>RXE g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (long BFP)</td>
<td>DDBR</td>
<td>RRE g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (long BFP)</td>
<td>DDT</td>
<td>RRF-a TF g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (long BFP)</td>
<td>DDTR</td>
<td>RRF-a TF g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (long BFP)</td>
<td>DDB</td>
<td>RXE g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (short BFP)</td>
<td>DEB</td>
<td>RXE g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (short BFP)</td>
<td>DEBR</td>
<td>RRE g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE (short BFP)</td>
<td>DD</td>
<td>RX-a</td>
<td>g6 A SP</td>
</tr>
<tr>
<td>DIVIDE (short BFP)</td>
<td>DER</td>
<td>RR</td>
<td>g6 A SP</td>
</tr>
<tr>
<td>DIVIDE DECIMAL</td>
<td>DP</td>
<td>SS-b g6 A SP</td>
<td>Da EU EO FK</td>
</tr>
<tr>
<td>DIVIDE LOGICAL (32–64)</td>
<td>DL</td>
<td>RXY-a N g6 A SP</td>
<td>IK</td>
</tr>
<tr>
<td>DIVIDE LOGICAL (32–64)</td>
<td>DLR</td>
<td>RRE N g6 A SP</td>
<td>IK</td>
</tr>
<tr>
<td>DIVIDE LOGICAL (64–128)</td>
<td>DLG</td>
<td>RXY-a N g6 A SP</td>
<td>IK</td>
</tr>
<tr>
<td>DIVIDE LOGICAL (64–128)</td>
<td>DLGR</td>
<td>RRRE N g6 A SP</td>
<td>IK</td>
</tr>
<tr>
<td>DIVIDE SINGLE (64)</td>
<td>DSG</td>
<td>RXY-a N g6 A SP</td>
<td>IK</td>
</tr>
<tr>
<td>DIVIDE SINGLE (64)</td>
<td>DSGR</td>
<td>RRRE N g6 A SP</td>
<td>IK</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 7 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIVIDE SINGLE (64→32)</td>
<td>DSGF</td>
<td>RXY-a N d A SP</td>
<td>Ik</td>
<td>B2</td>
</tr>
<tr>
<td>DIVIDE SINGLE (64→32)</td>
<td>DSGFR</td>
<td>RRE N d SP</td>
<td>Ik</td>
<td>B910</td>
</tr>
<tr>
<td>DIVIDE TO INTEGER (long BFP)</td>
<td>DIDBR</td>
<td>RRF-b C d(^3) SP</td>
<td>Db Xs Xu Xx</td>
<td>B33B</td>
</tr>
<tr>
<td>DIVIDE TO INTEGER (short BFP)</td>
<td>DIEBR</td>
<td>RRF-b C d(^3) SP</td>
<td>Db Xs Xu Xx</td>
<td>B333</td>
</tr>
<tr>
<td>EDIT</td>
<td>ED</td>
<td>SS-a C d A</td>
<td>Dg Gt</td>
<td>ST B1 B2</td>
</tr>
<tr>
<td>EDIT AND MARK</td>
<td>EDMK</td>
<td>SS-a C d A</td>
<td>Dg Gt</td>
<td>ST B1 B2</td>
</tr>
<tr>
<td>EXCLUSIVE OR (32)</td>
<td>X</td>
<td>RX-a C A</td>
<td>B5</td>
<td>7-212</td>
</tr>
<tr>
<td>EXCLUSIVE OR (32)</td>
<td>XR</td>
<td>RR C A</td>
<td>17</td>
<td>7-212</td>
</tr>
<tr>
<td>EXCLUSIVE OR (32)</td>
<td>XRFK</td>
<td>RRF-a C DO</td>
<td>ST B1 B2</td>
<td>D7</td>
</tr>
<tr>
<td>EXCLUSIVE OR (32)</td>
<td>XY</td>
<td>RX-a C LD A</td>
<td>B2</td>
<td>E357</td>
</tr>
<tr>
<td>EXCLUSIVE OR (64)</td>
<td>XG</td>
<td>RX-a C N A</td>
<td>B2</td>
<td>E382</td>
</tr>
<tr>
<td>EXCLUSIVE OR (64)</td>
<td>XGR</td>
<td>RRE N C N</td>
<td>B982</td>
<td>7-212</td>
</tr>
<tr>
<td>EXCLUSIVE OR (character)</td>
<td>XC</td>
<td>SS-a C d A</td>
<td>ST B1 B2</td>
<td>D7</td>
</tr>
<tr>
<td>EXCLUSIVE OR (character)</td>
<td>XI</td>
<td>SI C A</td>
<td>B1</td>
<td>7-213</td>
</tr>
<tr>
<td>EXCLUSIVE OR (character)</td>
<td>XRY</td>
<td>RX-a C N A</td>
<td>ST B1 B2</td>
<td>E582</td>
</tr>
<tr>
<td>EXCLUSIVE OR IMMEDIATE (high)</td>
<td>XIHF</td>
<td>RIL-a C EI</td>
<td>C06</td>
<td>7-214</td>
</tr>
<tr>
<td>EXCLUSIVE OR IMMEDIATE (low)</td>
<td>XILF</td>
<td>RIL-a C EI</td>
<td>C07</td>
<td>7-214</td>
</tr>
<tr>
<td>EXECUTE</td>
<td>EX</td>
<td>RX-a C d A</td>
<td>EX</td>
<td>44</td>
</tr>
<tr>
<td>EXECUTE RELATIVE LONG</td>
<td>EXRL</td>
<td>RIL-b XX C d A</td>
<td>EX</td>
<td>C60</td>
</tr>
<tr>
<td>EXTRACT ACCESS</td>
<td>EAR</td>
<td>RRE U1</td>
<td>U2</td>
<td>B24F</td>
</tr>
<tr>
<td>EXTRACT AND SET EXTENDED AUTHORITY</td>
<td>ESEA</td>
<td>RRE N P</td>
<td>B99D</td>
<td>10-23</td>
</tr>
<tr>
<td>EXTRACT BIASED EXPONENT (extended DFP to 64)</td>
<td>EXEEX</td>
<td>RRE TF d(^3) SO</td>
<td>Dt</td>
<td>B3ED</td>
</tr>
<tr>
<td>EXTRACT BIASED EXPONENT (long DFP to 64)</td>
<td>EEDTR</td>
<td>RRE TF d(^3) SO</td>
<td>Dt</td>
<td>B3E5</td>
</tr>
<tr>
<td>EXTRACT CPU ATTRIBUTE</td>
<td>ECAG</td>
<td>RS-a C Ge d A</td>
<td>R1</td>
<td>B1</td>
</tr>
<tr>
<td>EXTRACT CPU TIME</td>
<td>ECTG</td>
<td>SSF ET d A</td>
<td>GM</td>
<td>Rj</td>
</tr>
<tr>
<td>EXTRACT FPC</td>
<td>EFPC</td>
<td>RRE d(^2) Db</td>
<td>B38C</td>
<td>9-30</td>
</tr>
<tr>
<td>EXTRACT PRIMARY ASN</td>
<td>EPAR</td>
<td>RRE Q SO</td>
<td>B226</td>
<td>10-23</td>
</tr>
<tr>
<td>EXTRACT PRIMARY ASN AND INSTANCE</td>
<td>EPAR</td>
<td>RRE RA Q SO</td>
<td>B99A</td>
<td>10-23</td>
</tr>
<tr>
<td>EXTRACT PSW</td>
<td>EPSW</td>
<td>RRE N3 d(^2)</td>
<td>B98D</td>
<td>7-218</td>
</tr>
<tr>
<td>EXTRACT SECONDARY ASN</td>
<td>ESAR</td>
<td>RRE Q SO</td>
<td>B227</td>
<td>10-24</td>
</tr>
<tr>
<td>EXTRACT SECONDARY ASN AND INSTANCE</td>
<td>ESAIR</td>
<td>RRE RA Q SO</td>
<td>B99B</td>
<td>10-24</td>
</tr>
<tr>
<td>EXTRACT SIGNIFICANCE (extended DFP to 64)</td>
<td>ESXTR</td>
<td>RRE TF d(^3) SO</td>
<td>Dt</td>
<td>B3E7</td>
</tr>
<tr>
<td>EXTRACT SIGNIFICANCE (long DFP to 64)</td>
<td>ESDTR</td>
<td>RRE TF d(^3) SO</td>
<td>Dt</td>
<td>B3E5</td>
</tr>
<tr>
<td>EXTRACT STACKED REGISTERS (32)</td>
<td>EREG</td>
<td>RRE d(^{1}) A(^{1}) SE</td>
<td>U1</td>
<td>U2</td>
</tr>
<tr>
<td>EXTRACT STACKED REGISTERS (32)</td>
<td>EREGG</td>
<td>RRE d(^{1}) A(^{1}) SE</td>
<td>U1</td>
<td>U2</td>
</tr>
<tr>
<td>EXTRACT STACKED STATE</td>
<td>ESTA</td>
<td>RRE C d(^{1}) A(^{1}) SP SE</td>
<td>B24A</td>
<td>10-26</td>
</tr>
<tr>
<td>EXTRACT TRANSACTION NESTING DEPTH</td>
<td>ETND</td>
<td>RRE TX d(^1) SO</td>
<td>B2EC</td>
<td>7-218</td>
</tr>
<tr>
<td>FIND LEFTMOST ONE</td>
<td>FLOGR</td>
<td>RRE C EI SP</td>
<td>SP</td>
<td>B983</td>
</tr>
<tr>
<td>HALT SUBCHANNEL</td>
<td>HSCH</td>
<td>S C P OP c GS</td>
<td>B231</td>
<td>14-6</td>
</tr>
<tr>
<td>HALVE (short HFP)</td>
<td>HDR</td>
<td>RR d(^3) Da EU</td>
<td>24</td>
<td>18-13</td>
</tr>
<tr>
<td>HALVE (long HFP)</td>
<td>HER</td>
<td>RR d(^{1}) Da EU</td>
<td>34</td>
<td>18-13</td>
</tr>
<tr>
<td>INSERT ADDRESS SPACE CONTROL</td>
<td>IAC</td>
<td>RRE C Q SO</td>
<td>B224</td>
<td>10-28</td>
</tr>
<tr>
<td>INSERT BIASED EXPONENT (46 to extended DFP)</td>
<td>IEXTR</td>
<td>RRF-b TF d(^3) SP</td>
<td>Dt</td>
<td>B3FE</td>
</tr>
<tr>
<td>INSERT BIASED EXPONENT (46 to long DFP)</td>
<td>EEDTR</td>
<td>RRF-b TF d(^3) SP</td>
<td>Dt</td>
<td>B3F6</td>
</tr>
<tr>
<td>INSERT CHARACTER</td>
<td>IC</td>
<td>RX-a d A</td>
<td>B3</td>
<td>7-219</td>
</tr>
<tr>
<td>INSERT CHARACTER</td>
<td>ICGY</td>
<td>RX-a LD A</td>
<td>B3</td>
<td>E373</td>
</tr>
<tr>
<td>INSERT CHARACTERS UNDER MASK (high)</td>
<td>ICMH</td>
<td>RS-yb C N A</td>
<td>B2</td>
<td>E8B0</td>
</tr>
<tr>
<td>INSERT CHARACTERS UNDER MASK (low)</td>
<td>ICM</td>
<td>RS-b C A</td>
<td>B2</td>
<td>7-220</td>
</tr>
<tr>
<td>INSERT CHARACTERS UNDER MASK (low)</td>
<td>ICMY</td>
<td>RS-yb C LD A</td>
<td>B2</td>
<td>E8B1</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (high)</td>
<td>IHH</td>
<td>Ri-a N</td>
<td>A50</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (high)</td>
<td>IHL</td>
<td>Ri-a N</td>
<td>A51</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (low)</td>
<td>IमH</td>
<td>Ri-a E</td>
<td>C08</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT IMMEDIATE (low)</td>
<td>ILL</td>
<td>Ri-a N</td>
<td>A53</td>
<td>7-221</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 8 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>INSERT IMMEDIATE (low)</td>
<td>IILF</td>
<td>RIL-a E1</td>
<td>C09</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT PROGRAM MASK</td>
<td>IPM</td>
<td>RRE</td>
<td>B222</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT STORAGE KEY EXTENDED</td>
<td>ISKE</td>
<td>RRE P A&quot;</td>
<td>B223</td>
<td>7-221</td>
</tr>
<tr>
<td>INSERT VIRTUAL STORAGE KEY</td>
<td>IVSK</td>
<td>RRE Q A&quot;</td>
<td>R2</td>
<td>7-221</td>
</tr>
<tr>
<td>INVALIDATE DAT TABLE ENTRY</td>
<td>IDTE</td>
<td>RRF-b U DE P A' SP</td>
<td>B98E</td>
<td>10-31</td>
</tr>
<tr>
<td>INVALIDATE PAGE TABLE ENTRY</td>
<td>IPTE</td>
<td>RRF-a P A' SP</td>
<td>B221</td>
<td>10-36</td>
</tr>
<tr>
<td>LOAD (32)</td>
<td>L</td>
<td>RX-a A</td>
<td>B2</td>
<td>7-221</td>
</tr>
<tr>
<td>LOAD (32)</td>
<td>L</td>
<td>RR</td>
<td>18</td>
<td>7-221</td>
</tr>
<tr>
<td>LOAD (32)</td>
<td>LY</td>
<td>RXy-a LD A</td>
<td>B2</td>
<td>7-221</td>
</tr>
<tr>
<td>LOAD (64)</td>
<td>LG</td>
<td>RXy-a N A</td>
<td>B2</td>
<td>7-221</td>
</tr>
<tr>
<td>LOAD (64)</td>
<td>LG</td>
<td>RXy-a N A</td>
<td>B2</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD (64)</td>
<td>LGR</td>
<td>RRE N</td>
<td>B904</td>
<td>7-221</td>
</tr>
<tr>
<td>LOAD (64)</td>
<td>LGFR</td>
<td>RRE N</td>
<td>B914</td>
<td>7-221</td>
</tr>
<tr>
<td>LOAD (extended)</td>
<td>LXR</td>
<td>RRE p3 A SP Da</td>
<td>B2</td>
<td>9-31</td>
</tr>
<tr>
<td>LOAD (long)</td>
<td>LD</td>
<td>RX-a p3 A Da</td>
<td>B6</td>
<td>9-31</td>
</tr>
<tr>
<td>LOAD ACCESS MULTIPLE</td>
<td>LAM</td>
<td>RS-a p3 A SP</td>
<td>UB</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD ACCESS MULTIPLE</td>
<td>LAMY</td>
<td>RSY-a LD p3 A SP</td>
<td>UB</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD ADDRESS</td>
<td>LA</td>
<td>RX-a</td>
<td>B2</td>
<td>7-223</td>
</tr>
<tr>
<td>LOAD ADDRESS</td>
<td>LAY</td>
<td>RXy-a LD</td>
<td>B2</td>
<td>7-223</td>
</tr>
<tr>
<td>LOAD ADDRESS EXTENDED</td>
<td>LAE</td>
<td>RX-a p3</td>
<td>B1</td>
<td>7-223</td>
</tr>
<tr>
<td>LOAD ADDRESS EXTENDED RELATIVE LONG</td>
<td>LAREL</td>
<td>RIL-b N5</td>
<td>B1</td>
<td>7-224</td>
</tr>
<tr>
<td>LOAD ADDRESS SPACE PARAMETERS</td>
<td>LASP</td>
<td>SSE C P A' SP SO</td>
<td>B1</td>
<td>10-39</td>
</tr>
<tr>
<td>LOAD AND ADD (32)</td>
<td>LAA</td>
<td>RSY-a C IA p3 A SP IF £ ST</td>
<td>B2</td>
<td>7-225</td>
</tr>
<tr>
<td>LOAD AND ADD (64)</td>
<td>LAAG</td>
<td>RSY-a C IA p3 A SP IF £ ST</td>
<td>B2</td>
<td>7-225</td>
</tr>
<tr>
<td>LOAD AND ADD LOGICAL (32)</td>
<td>LAAL</td>
<td>RSY-a C IA p3 A SP £ ST</td>
<td>B2</td>
<td>7-225</td>
</tr>
<tr>
<td>LOAD AND ADD LOGICAL (64)</td>
<td>LAALG</td>
<td>RSY-a C IA p3 A SP £ ST</td>
<td>B2</td>
<td>7-225</td>
</tr>
<tr>
<td>LOAD AND ADD (32)</td>
<td>LAN</td>
<td>RSY-a C IA p3 A SP £ ST</td>
<td>B2</td>
<td>7-226</td>
</tr>
<tr>
<td>LOAD AND ADD (64)</td>
<td>LANG</td>
<td>RSY-a C IA p3 A SP £ ST</td>
<td>B2</td>
<td>7-226</td>
</tr>
<tr>
<td>LOAD AND EXCLUSIVE OR (32)</td>
<td>LAX</td>
<td>RSY-a C IA p3 A SP £ ST</td>
<td>B2</td>
<td>7-226</td>
</tr>
<tr>
<td>LOAD AND EXCLUSIVE OR (64)</td>
<td>LAXG</td>
<td>RSY-a C IA p3 A SP £ ST</td>
<td>B2</td>
<td>7-227</td>
</tr>
<tr>
<td>LOAD AND OR (32)</td>
<td>LAO</td>
<td>RSY-a C IA p3 A SP £ ST</td>
<td>B2</td>
<td>7-227</td>
</tr>
<tr>
<td>LOAD AND OR (64)</td>
<td>LAOG</td>
<td>RSY-a C IA p3 A SP £ ST</td>
<td>B2</td>
<td>7-227</td>
</tr>
<tr>
<td>LOAD AND TEST (32)</td>
<td>LT</td>
<td>RXy-a C EI A</td>
<td>B2</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND TEST (32)</td>
<td>LTR</td>
<td>RR C</td>
<td>12</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND TEST (64)</td>
<td>LG</td>
<td>RXy-a C EI A</td>
<td>B2</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND TEST (64)</td>
<td>LG</td>
<td>RXy-a C N</td>
<td>B2</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND TEST (64)</td>
<td>LGF</td>
<td>RXy-a C GE A</td>
<td>B2</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND TEST (extended BFP)</td>
<td>LTXBR</td>
<td>RRE p3 A SP Db Xi</td>
<td>B342</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD AND TEST (extended BFP)</td>
<td>LTXBR</td>
<td>RRE C TF p3 A SP Da Xi</td>
<td>B302</td>
<td>20-40</td>
</tr>
<tr>
<td>LOAD AND TEST (extended HFP)</td>
<td>LTXBR</td>
<td>RRE C p3 A SP Da Xi</td>
<td>B302</td>
<td>18-14</td>
</tr>
<tr>
<td>LOAD AND TEST (long BFP)</td>
<td>LTDQ</td>
<td>RRE C p3 A Da Xi</td>
<td>B312</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD AND TEST (long DFP)</td>
<td>LTDTR</td>
<td>RRE C p3 A Da Xi</td>
<td>B302</td>
<td>20-40</td>
</tr>
<tr>
<td>LOAD AND TEST (long HFP)</td>
<td>LTDTR</td>
<td>RRE C p3 A Da Xi</td>
<td>B2</td>
<td>18-13</td>
</tr>
<tr>
<td>LOAD AND TEST (short BFP)</td>
<td>LTEBR</td>
<td>RCE C p3 A Da Xi</td>
<td>B302</td>
<td>19-31</td>
</tr>
<tr>
<td>LOAD AND TEST (short HFP)</td>
<td>LTEBR</td>
<td>RCE C p3 A Da Xi</td>
<td>B2</td>
<td>18-13</td>
</tr>
<tr>
<td>LOAD AND TRAP (32L−32)</td>
<td>LAT</td>
<td>RXy-a LT A Da</td>
<td>B2</td>
<td>7-228</td>
</tr>
<tr>
<td>LOAD AND TRAP (64)</td>
<td>LGAT</td>
<td>RXy-a LT A Da</td>
<td>B2</td>
<td>7-228</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 9 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOAD AND ZERO RIGHTMOST BYTE (32)</td>
<td>LZRF</td>
<td>RXY-a LZ A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD AND ZERO RIGHTMOST BYTE (64)</td>
<td>LZRG</td>
<td>RXY-a LZ A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD BYTE (32&lt;–8)</td>
<td>LB</td>
<td>RXY-a LD A</td>
<td></td>
</tr>
<tr>
<td>LOAD BYTE (32&lt;–8)</td>
<td>LBR</td>
<td>RRE EI</td>
<td></td>
</tr>
<tr>
<td>LOAD BYTE (64&lt;–8)</td>
<td>LGB</td>
<td>RXY-a LD A</td>
<td></td>
</tr>
<tr>
<td>LOAD BYTE (64&lt;–8)</td>
<td>LGBR</td>
<td>RRE EI</td>
<td></td>
</tr>
<tr>
<td>LOAD BYTE HIGH (32&lt;–8)</td>
<td>LBH</td>
<td>RXY-a HW A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (32)</td>
<td>LCR</td>
<td>RR C IF</td>
<td>13</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (64)</td>
<td>LCGR</td>
<td>RRE C N IF</td>
<td></td>
</tr>
<tr>
<td>LOAD COMPLEMENT (64&lt;–32)</td>
<td>LCGR</td>
<td>RRE C N</td>
<td></td>
</tr>
<tr>
<td>LOAD COMPLEMENT (extended BFP)</td>
<td>LCXBR</td>
<td>RRE C 8 SP Db</td>
<td></td>
</tr>
<tr>
<td>LOAD COMPLEMENT (extended HFP)</td>
<td>LCXR</td>
<td>RRE C 8 SP Da</td>
<td></td>
</tr>
<tr>
<td>LOAD COMPLEMENT (long BFP)</td>
<td>LCBR</td>
<td>RRE C N Da</td>
<td>23</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (long HFP)</td>
<td>LCFR</td>
<td>RRE FS Da</td>
<td></td>
</tr>
<tr>
<td>LOAD COMPLEMENT (short BFP)</td>
<td>LCEBR</td>
<td>RRE C 8 Da</td>
<td></td>
</tr>
<tr>
<td>LOAD CONTROL (32)</td>
<td>LCTL</td>
<td>RS-a P A SP</td>
<td></td>
</tr>
<tr>
<td>LOAD CONTROL (64)</td>
<td>LCTLG</td>
<td>RSY-a N P A SP</td>
<td></td>
</tr>
<tr>
<td>LOAD COUNT TO BLOCK BOUNDARY</td>
<td>LCBB</td>
<td>RXE C VF SP</td>
<td></td>
</tr>
<tr>
<td>LOAD FP INTEGER (extended BFP)</td>
<td>FIXBR</td>
<td>RRF-e 8 SP Db Xi Xx</td>
<td></td>
</tr>
<tr>
<td>LOAD FP INTEGER (extended HFP)</td>
<td>FIXR</td>
<td>RRE 8 SP Da</td>
<td></td>
</tr>
<tr>
<td>LOAD FP INTEGER (long BFP)</td>
<td>FIDBR</td>
<td>RRF-e 8 SP Db Xi Xx</td>
<td></td>
</tr>
<tr>
<td>LOAD FP INTEGER (long HFP)</td>
<td>FIDR</td>
<td>RRE 8 SP Da</td>
<td></td>
</tr>
<tr>
<td>LOAD FP INTEGER (short BFP)</td>
<td>FIEBR</td>
<td>RRF-e 8 SP Db Xi Xx</td>
<td></td>
</tr>
<tr>
<td>LOAD FP INTEGER (short HFP)</td>
<td>FIER</td>
<td>RRE 8 Da</td>
<td></td>
</tr>
<tr>
<td>LOAD FPC</td>
<td>LFPC</td>
<td>S 8 A SP Db</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD FPC AND SIGNAL</td>
<td>LFAS</td>
<td>S XF 8 A SP D Xg</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD FRR FROM GR (64 to long)</td>
<td>LGDR</td>
<td>RRE FG 8 Da</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD GR FROM FRR (long to 64)</td>
<td>LGDR</td>
<td>RRE FG 8 Da</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD HALFWORD (32)&lt;–16</td>
<td>LHY</td>
<td>RXY-a LD A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD HALFWORD (32&lt;–16)</td>
<td>LH</td>
<td>RXY-a A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD HALFWORD (32&lt;–16)</td>
<td>LHR</td>
<td>RRE EI</td>
<td></td>
</tr>
<tr>
<td>LOAD HALFWORD (64&lt;–16)</td>
<td>LGH</td>
<td>RXY-a N A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD HALFWORD (64&lt;–16)</td>
<td>LGHR</td>
<td>RRE EI</td>
<td></td>
</tr>
<tr>
<td>LOAD HALFWORD HIGH (32&lt;–16)</td>
<td>LHH</td>
<td>RXY-a HW A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD HALFWORD HIGH IMMEDIATE ON CONDITION (32&lt;–16)</td>
<td>LOCHHI</td>
<td>RIE-g L2</td>
<td></td>
</tr>
<tr>
<td>LOAD HALFWORD IMMEDIATE (32&lt;–16)</td>
<td>LHI</td>
<td>RY-a</td>
<td></td>
</tr>
<tr>
<td>LOAD HALFWORD IMMEDIATE (64&lt;–16)</td>
<td>LGHI</td>
<td>RY-a N</td>
<td></td>
</tr>
<tr>
<td>LOAD HALFWORD IMMEDIATE ON CONDITION (32&lt;–16)</td>
<td>LOCHI</td>
<td>RIE-g L2</td>
<td></td>
</tr>
<tr>
<td>LOAD HALFWORD IMMEDIATE ON CONDITION (64&lt;–16)</td>
<td>LOCHGI</td>
<td>RIE-g L2</td>
<td></td>
</tr>
<tr>
<td>LOAD HALFWORD RELATIVE LONG (32&lt;–16)</td>
<td>LRHL</td>
<td>RIL-b GE A</td>
<td></td>
</tr>
<tr>
<td>LOAD HALFWORD RELATIVE LONG (64&lt;–16)</td>
<td>LGHRH</td>
<td>RIL-b GE A</td>
<td></td>
</tr>
<tr>
<td>LOAD HIGH (32)</td>
<td>LFH</td>
<td>RXY-a HW A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD HIGH AND TRAP (32H&lt;–32)</td>
<td>LFHAT</td>
<td>RXY-a LT A Dc</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD HIGH ON CONDITION (32)</td>
<td>LOCFH</td>
<td>RSY-b L2 A</td>
<td>B3</td>
</tr>
<tr>
<td>LOAD HIGH ON CONDITION (32)</td>
<td>LOCFHR</td>
<td>RRF-c L2</td>
<td></td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 10 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOAD IMMEDIATE (64→32)</td>
<td>LGFI</td>
<td>RI-Za Ei</td>
<td>C07</td>
<td>7-222</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>LXDB</td>
<td>RXE g32 A SP Db Xi</td>
<td>B2</td>
<td>19-94</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>LDBR</td>
<td>RRE g32 SP Db Xi</td>
<td>B305</td>
<td>19-33</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended DFP)</td>
<td>LDXTR</td>
<td>RRF-d TF g32 SP Ot Xi</td>
<td>B30C</td>
<td>20-44</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended HFP)</td>
<td>LDX</td>
<td>RXE g32 A SP Da</td>
<td>B3</td>
<td>18-15</td>
</tr>
<tr>
<td>LOAD LENGTHENED (long to extended HFP)</td>
<td>LDXR</td>
<td>RRE g32 SP Da</td>
<td>B3D5</td>
<td>18-15</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to extended BFP)</td>
<td>LXE</td>
<td>RXE g32 A SP Db Xi</td>
<td>B306</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to extended HFP)</td>
<td>LXE</td>
<td>RXE g32 SP Db Xi</td>
<td>B306</td>
<td>19-33</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to extended HFP)</td>
<td>LXE</td>
<td>RRE g32 A SP Da</td>
<td>B2ED6</td>
<td>18-15</td>
</tr>
<tr>
<td>LOAD LENGTHENED (short to extended HFP)</td>
<td>LXE</td>
<td>RRE g32 SP Da</td>
<td>B2ED4</td>
<td>18-15</td>
</tr>
<tr>
<td>LOAD LOGICAL (64→32)</td>
<td>LLGF</td>
<td>RXY-a N A</td>
<td>B3</td>
<td>7-233</td>
</tr>
<tr>
<td>LOAD LOGICAL (64→32)</td>
<td>LLGFR</td>
<td>RRE N B916</td>
<td>7-233</td>
<td></td>
</tr>
<tr>
<td>LOAD LOGICAL AND TRAP (64→32)</td>
<td>LLGFA</td>
<td>RXY-a LT A Dc</td>
<td>B3ED3</td>
<td>7-234</td>
</tr>
<tr>
<td>LOAD LOGICAL AND ZERO RIGHTMOST BYTE (64→32)</td>
<td>LLZRGF</td>
<td>RX-Ya LZ A</td>
<td>B3</td>
<td>E33D</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (32→8)</td>
<td>LLC</td>
<td>RX-Ya Ei</td>
<td>B3</td>
<td>E394</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (32→8)</td>
<td>LLCR</td>
<td>RRE Ei</td>
<td>B994</td>
<td>7-234</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (64→64)</td>
<td>LLGC</td>
<td>RX-Ya N A</td>
<td>B3</td>
<td>E390</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER (64→64)</td>
<td>LLGCR</td>
<td>RRE Ei</td>
<td>B984</td>
<td>7-234</td>
</tr>
<tr>
<td>LOAD LOGICAL CHARACTER HIGH (32→8)</td>
<td>LLCH</td>
<td>RX-Ya HW A</td>
<td>B3</td>
<td>E3C2</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (32→16)</td>
<td>LLH</td>
<td>RX-Ya Ei A</td>
<td>B3</td>
<td>E395</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (32→16)</td>
<td>LLHR</td>
<td>RRE Ei</td>
<td>B995</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (64→16)</td>
<td>LLGH</td>
<td>RX-Ya N A</td>
<td>B3</td>
<td>E391</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD (64→16)</td>
<td>LLGHR</td>
<td>RRE Ei</td>
<td>B985</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD HIGH (32→16)</td>
<td>LLHH</td>
<td>RX-Ya HW A</td>
<td>B3</td>
<td>E3C6</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (32→16)</td>
<td>LLHLR</td>
<td>RI-b GE A*</td>
<td>C42</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (64→16)</td>
<td>LLHRL</td>
<td>RI-b GE A*</td>
<td>C4</td>
<td>7-235</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (high high)</td>
<td>LLIH</td>
<td>RI-a N</td>
<td>ASC</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (high low)</td>
<td>LLIH</td>
<td>RI-a N</td>
<td>ASC</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (high)</td>
<td>LLIH</td>
<td>RI-a Ei</td>
<td>COE</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (low high)</td>
<td>LLIH</td>
<td>RI-a N</td>
<td>ASC</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (low low)</td>
<td>LLIH</td>
<td>RI-a N</td>
<td>ASC</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE (low)</td>
<td>LLIH</td>
<td>RI-a EI</td>
<td>COE</td>
<td>7-236</td>
</tr>
<tr>
<td>LOAD LOGICAL IMMEDIATE LONG (64→32)</td>
<td>LLGFR</td>
<td>RI-b GE A SP</td>
<td>C4E</td>
<td>7-233</td>
</tr>
<tr>
<td>LOAD LOGICAL THIRTY ONE BITS (64→31)</td>
<td>LLGTR</td>
<td>RX-Ya N A</td>
<td>B3</td>
<td>E317</td>
</tr>
<tr>
<td>LOAD LOGICAL THIRTY ONE BITS (64→31)</td>
<td>LLGTRAT</td>
<td>RX-Ya LT A Dc</td>
<td>B3</td>
<td>E390</td>
</tr>
<tr>
<td>LOAD MULTIPLE (32)</td>
<td>LM</td>
<td>RS-a A</td>
<td>B2</td>
<td>98</td>
</tr>
<tr>
<td>LOAD MULTIPLE (32)</td>
<td>LMY</td>
<td>RSY-a LD A</td>
<td>B2</td>
<td>EB98</td>
</tr>
<tr>
<td>LOAD MULTIPLE (64)</td>
<td>LGM</td>
<td>RSY-a N A</td>
<td>B2</td>
<td>EB04</td>
</tr>
<tr>
<td>LOAD MULTIPLE DISJOINT (64→32&amp;32)</td>
<td>LMD</td>
<td>SS-a N g32 A</td>
<td>B2</td>
<td>EF</td>
</tr>
<tr>
<td>LOAD MULTIPLE HIGH (32)</td>
<td>LH</td>
<td>RSY-a N A</td>
<td>B2</td>
<td>EB98</td>
</tr>
<tr>
<td>LOAD NEGATIVE (32)</td>
<td>LNR</td>
<td>RR C</td>
<td>B2</td>
<td>11</td>
</tr>
<tr>
<td>LOAD NEGATIVE (64)</td>
<td>LNR</td>
<td>RR C N</td>
<td>B2</td>
<td>B901</td>
</tr>
<tr>
<td>LOAD NEGATIVE (64→32)</td>
<td>LNR</td>
<td>RR C N</td>
<td>B2</td>
<td>B911</td>
</tr>
<tr>
<td>LOAD NEGATIVE (extended BFP)</td>
<td>LNXBR</td>
<td>RX-C g32 SP Db</td>
<td>B341</td>
<td>19-34</td>
</tr>
<tr>
<td>LOAD NEGATIVE (extended HFP)</td>
<td>LNXB</td>
<td>RX-C g32 SP Da</td>
<td>B341</td>
<td>18-34</td>
</tr>
<tr>
<td>LOAD NEGATIVE (long BFP)</td>
<td>LNXB</td>
<td>RX-C g32 Db</td>
<td>B311</td>
<td>19-34</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 11 of 22)
Figure B-1. Instructions Arranged by Name  (Part 12 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>MONITOR CALL</td>
<td>MC</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE (16→16)</td>
<td>MVHHI</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE (32→16)</td>
<td>MVHI</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE (64→16)</td>
<td>MVGHI</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE (character)</td>
<td>MVC</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE (immediate)</td>
<td>MVI</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE (immediate)</td>
<td>MVIII</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE INVERSE</td>
<td>MVCIN</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE LONG</td>
<td>MVCL</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE LONG EXTENDED</td>
<td>MVCLE</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE LONG UNICODE</td>
<td>MVCLE</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE NUMERICS</td>
<td>MVI</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE PAGE</td>
<td>MVPG</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE WITH KEY</td>
<td>MVCK</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE WITH OFFSET</td>
<td>MVO</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE WITH OPTIONAL SPECIFICATIONS</td>
<td>MVCK</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE WITH SOURCE KEY</td>
<td>MVCS</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MOVE ZONES</td>
<td>MVZ</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (64→32)</td>
<td>M</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (64→32)</td>
<td>MFY</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (64→32)</td>
<td>MR</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (extended BFP)</td>
<td>MXBR</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (extended DFP)</td>
<td>MXTRA</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (long BFP)</td>
<td>MDB</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (long BFP)</td>
<td>MDPR</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (long BFP)</td>
<td>MXDB</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (long BFP)</td>
<td>MXD</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (long BFP)</td>
<td>MXDR</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (long HFP)</td>
<td>MEEB</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (short BFP)</td>
<td>MEEBR</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (short HFP)</td>
<td>MEE</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (short HFP)</td>
<td>MEEER</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (short HFP)</td>
<td>MDEB</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (short HFP)</td>
<td>MDER</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (short HFP)</td>
<td>ME</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY (short HFP)</td>
<td>MERE</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORMALIZED (long to ext. HFP)</td>
<td>MAYR</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNORMALIZED (long to ext. HFP)</td>
<td>MADB</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY AND ADD (long BFP)</td>
<td>MADBR</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>MULTIPLY AND ADD (long HFP)</td>
<td>MADRF</td>
<td>AF</td>
<td>ST</td>
<td>B1</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 13 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>MULTIPLY AND ADD (short BFP)</td>
<td>MAEB</td>
<td>$o^+\ A$ Db Xi Xo Xu Xx</td>
<td>B5</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPLY AND ADD (short BFP)</td>
<td>MAEBR</td>
<td>$o^+\ A$ Db Xi Xo Xu Xx</td>
<td>B5</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPLY AND ADD (short HFP)</td>
<td>MAE</td>
<td>$o^+\ A$ Da EU EO</td>
<td>B5</td>
<td>18-19</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNRM. (long to ext. high HFP)</td>
<td>MAYHR</td>
<td>$o^+\ A$ Da</td>
<td>B5</td>
<td>18-20</td>
</tr>
<tr>
<td>MULTIPLY AND ADD UNNRM. (long to ext. low HFP)</td>
<td>MAYLR</td>
<td>$o^+\ A$ Da</td>
<td>B338</td>
<td>18-20</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT (long BFP)</td>
<td>MSDB</td>
<td>$o^+\ A$ Db Xi Xo Xu Xx</td>
<td>B5</td>
<td>19-38</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT (long HFP)</td>
<td>MSDR</td>
<td>$o^+\ A$ Da EU EO</td>
<td>B5</td>
<td>18-19</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT UNNRM. (long to ext. high HFP)</td>
<td>MSEBR</td>
<td>$o^+\ A$ Da EU EO</td>
<td>B5</td>
<td>18-20</td>
</tr>
<tr>
<td>MULTIPLY AND SUBTRACT UNNRM. (long to ext. low HFP)</td>
<td>MSLR</td>
<td>$o^+\ A$ Da EU EO</td>
<td>B5</td>
<td>18-20</td>
</tr>
<tr>
<td>MULTIPLY Decimal</td>
<td>MP</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY HALFWORD (32-bit)</td>
<td>MH</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY HALFWORD IMMEDIATE (32-bit)</td>
<td>MHI</td>
<td>$o^+\ A$ Da EU EO</td>
<td>B5</td>
<td>18-20</td>
</tr>
<tr>
<td>MULTIPLY HALFWORD IMMEDIATE (64-bit)</td>
<td>MGHI</td>
<td>$o^+\ A$ Da EU EO</td>
<td>B5</td>
<td>18-20</td>
</tr>
<tr>
<td>MULTIPLY LOGICAL (128-bit)</td>
<td>MLG</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY LOGICAL (128-bit)</td>
<td>MLG</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY LOGICAL (64-bit)</td>
<td>MLR</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY LOGICAL IMMEDIATE (32-bit)</td>
<td>MS</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY LOGICAL IMMEDIATE (64-bit)</td>
<td>MSG</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY SINGLE IMMEDIATE (32-bit)</td>
<td>MSGF</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY SINGLE IMMEDIATE (64-bit)</td>
<td>MSGFR</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY SINGLE IMMEDIATE IMMEDIATE (64-bit)</td>
<td>MSPI</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY UNNORM. (long to ext. high HFP)</td>
<td>MYHR</td>
<td>$o^+\ A$ Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY UNNORM. (long to ext. low HFP)</td>
<td>MLR</td>
<td>$o^+\ A$ Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY UNNORM. (long to ext. HFP)</td>
<td>MY</td>
<td>$o^+\ A$ Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY UNNORM. (long to ext. low HFP)</td>
<td>MLR</td>
<td>$o^+\ A$ Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>MULTIPLY UNNORM. IMMEDIATE (long to ext. high HFP)</td>
<td>MYR</td>
<td>$o^+\ A$ Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>NEXT INSTRUCTION ACCESS INTENT</td>
<td>NIAI</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>NONTRANSACTIONAL STORE (64-bit)</td>
<td>NTSTG</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (32-bit)</td>
<td>O</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (32-bit)</td>
<td>OR</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (32-bit)</td>
<td>ORK</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (32-bit)</td>
<td>ORY</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (64-bit)</td>
<td>OG</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (64-bit)</td>
<td>OGR</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (character)</td>
<td>OC</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (immediate)</td>
<td>OI</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR (immediate)</td>
<td>OIY</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR IMMEDIATE (high high)</td>
<td>OIHR</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR IMMEDIATE (high low)</td>
<td>OIHL</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
<tr>
<td>OR IMMEDIATE (high)</td>
<td>OIHF</td>
<td>$o^+\ A$ ST Da</td>
<td>B5</td>
<td>18-22</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name  (Part 14 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>OR IMMEDIATE (low high)</td>
<td>OILH</td>
<td>Rl-a C N</td>
<td>A5A</td>
<td>7-266</td>
</tr>
<tr>
<td>OR IMMEDIATE (low low)</td>
<td>OILL</td>
<td>Ra-a C N</td>
<td>A5B</td>
<td>7-266</td>
</tr>
<tr>
<td>OR IMMEDIATE (low)</td>
<td>OILF</td>
<td>Rl-a C E1</td>
<td>C0D</td>
<td>7-265</td>
</tr>
<tr>
<td>PACK</td>
<td>PACK</td>
<td>SS-b</td>
<td>B1, B2</td>
<td>F2</td>
</tr>
<tr>
<td>PACK ASCII</td>
<td>PKA</td>
<td>SS-l E2</td>
<td>B1, B2</td>
<td>E9</td>
</tr>
<tr>
<td>PACK UNICODE</td>
<td>PKU</td>
<td>SS-l E2</td>
<td>B1, B2</td>
<td>E1</td>
</tr>
<tr>
<td>PAGE IN</td>
<td>PGIN</td>
<td>CRE E5</td>
<td>A1, c</td>
<td>B22E</td>
</tr>
<tr>
<td>PAGE OUT</td>
<td>PGOUT</td>
<td>CRE E5</td>
<td>A1, c</td>
<td>B22F</td>
</tr>
<tr>
<td>PERFORM CRYPTOGRAPHIC COMPUTATION</td>
<td>PCC</td>
<td>CRE M4</td>
<td>B3</td>
<td>7-269</td>
</tr>
<tr>
<td>PERFORM CRYPTOGRAPHIC KEY MGMT. OPERATIONS</td>
<td>PCKMO</td>
<td>REE M3</td>
<td>B928</td>
<td>10-72</td>
</tr>
<tr>
<td>PERFORM FLOATING-POINT OPERATION</td>
<td>PFPO</td>
<td>E PF</td>
<td>010A</td>
<td>9-35</td>
</tr>
<tr>
<td>PERFORM FRAME MANAGEMENT FUNCTION</td>
<td>PFMM</td>
<td>RE E1</td>
<td>0101</td>
<td>10-79</td>
</tr>
<tr>
<td>PERFORM LOCKED OPERATION</td>
<td>PLO</td>
<td>SS-e C</td>
<td>B9E1</td>
<td>7-310</td>
</tr>
<tr>
<td>PERFORM PROCESSOR ASSIST</td>
<td>PPA</td>
<td>RRF-c PA</td>
<td>B2E9</td>
<td>7-284</td>
</tr>
<tr>
<td>PERFORM PSEUDORANDOM NUMBER OPERATION</td>
<td>PPNO</td>
<td>RRE C M5</td>
<td>B93C</td>
<td>7-299</td>
</tr>
<tr>
<td>PERFORM TIMING FACILITY FUNCTION</td>
<td>PTFF</td>
<td>E C TS</td>
<td>B2B8</td>
<td>10-86</td>
</tr>
<tr>
<td>PERFORM TOPOLOGY FUNCTION</td>
<td>PTF</td>
<td>CRE CT</td>
<td>B9A2</td>
<td>10-85</td>
</tr>
<tr>
<td>POPULATION COUNT</td>
<td>POPCNT</td>
<td>RRE PK</td>
<td>B9E1</td>
<td>7-310</td>
</tr>
<tr>
<td>PREFETCH DATA</td>
<td>PDF</td>
<td>RXy b GE</td>
<td>E330</td>
<td>7-310</td>
</tr>
<tr>
<td>PREFETCH DATA RELATIVE LONG</td>
<td>PDFRL</td>
<td>RIL-c GE</td>
<td>C62</td>
<td>7-310</td>
</tr>
<tr>
<td>PROGRAM CALL</td>
<td>PC</td>
<td>S Q A</td>
<td>B218</td>
<td>10-86</td>
</tr>
<tr>
<td>PROGRAM RETURN</td>
<td>PR</td>
<td>E L</td>
<td>B01</td>
<td>10-99</td>
</tr>
<tr>
<td>PROGRAM TRANSFER WITH INSTANCE</td>
<td>PTI</td>
<td>RRE RA</td>
<td>B22B</td>
<td>10-103</td>
</tr>
<tr>
<td>PURGE ALB</td>
<td>PALB</td>
<td>RRE</td>
<td>B2A8</td>
<td>10-112</td>
</tr>
<tr>
<td>PURGE TLB</td>
<td>PTLB</td>
<td>S P</td>
<td>B2OD</td>
<td>10-112</td>
</tr>
<tr>
<td>QUANTIZE (extended DFP)</td>
<td>QAXTR</td>
<td>RRF-b TF</td>
<td>B3F9</td>
<td>20-48</td>
</tr>
<tr>
<td>QUANTIZE (long DFP)</td>
<td>QADTR</td>
<td>RRF-b TF</td>
<td>B3F5</td>
<td>20-48</td>
</tr>
<tr>
<td>REROUND (extended DFP)</td>
<td>RRXTR</td>
<td>RRF-b TF</td>
<td>B3FF</td>
<td>20-51</td>
</tr>
<tr>
<td>REROUND (long DFP)</td>
<td>RR XTR</td>
<td>RRF-b TF</td>
<td>B3F7</td>
<td>20-51</td>
</tr>
<tr>
<td>RESET CHANNEL PATH</td>
<td>RCHP</td>
<td>S C</td>
<td>B2B9</td>
<td>14-9</td>
</tr>
<tr>
<td>RESET REFERENCE BIT EXTENDED</td>
<td>RRBE</td>
<td>RRE C</td>
<td>B2A2</td>
<td>10-112</td>
</tr>
<tr>
<td>RESET REFERENCE BITS MULTIPLE</td>
<td>RRBM</td>
<td>RRE RB</td>
<td>B9AE</td>
<td>10-113</td>
</tr>
<tr>
<td>RESUME PROGRAM</td>
<td>RP</td>
<td>S L</td>
<td>B277</td>
<td>10-113</td>
</tr>
<tr>
<td>RESUME SUBCHANNEL</td>
<td>RSCH</td>
<td>S C</td>
<td>EB1D</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE LEFT SINGLE LOGICAL (32)</td>
<td>RLL</td>
<td>RSY-a N3</td>
<td>EB1C</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE LEFT SINGLE LOGICAL (64)</td>
<td>RLLG</td>
<td>RSY-a N</td>
<td>EB1C</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE THEN AND SELECTED BITS (64)</td>
<td>RN SBRG</td>
<td>Rl-e C GE</td>
<td>EC54</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE THEN EXCLUSIVE OR SELECT. BITS (64)</td>
<td>RN SBBG</td>
<td>Rl-e C GE</td>
<td>EC57</td>
<td>7-312</td>
</tr>
<tr>
<td>ROTATE THEN INSERT SELECTED BITS (64)</td>
<td>RISBG</td>
<td>Rl-e C GE</td>
<td>EC55</td>
<td>7-314</td>
</tr>
<tr>
<td>ROTATE THEN INSERT SELECTED BITS HIGH (64)</td>
<td>RISBH</td>
<td>Rl-e HW</td>
<td>EC59</td>
<td>7-314</td>
</tr>
<tr>
<td>SET ADDRESS LIMIT</td>
<td>SAL</td>
<td>S P</td>
<td>B237</td>
<td>14-12</td>
</tr>
<tr>
<td>SET ADDRESS SPACE CONTROL</td>
<td>SAC</td>
<td>S Q</td>
<td>B219</td>
<td>10-115</td>
</tr>
<tr>
<td>SET ADDRESS SPACE CONTROL FAST</td>
<td>SACF</td>
<td>S Q</td>
<td>B279</td>
<td>10-116</td>
</tr>
<tr>
<td>SET ADDRES SING MODE (24)</td>
<td>SAM24</td>
<td>E N3</td>
<td>010C</td>
<td>7-321</td>
</tr>
<tr>
<td>SET ADDRES SING MODE (31)</td>
<td>SAM31</td>
<td>E N3</td>
<td>010D</td>
<td>7-321</td>
</tr>
<tr>
<td>SET ADDRES SING MODE (64)</td>
<td>SAM64</td>
<td>E N</td>
<td>010E</td>
<td>7-321</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 15 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>SET BFP Rounding Mode (2 bit)</td>
<td>SRMM</td>
<td>Db</td>
<td>B299</td>
<td>9-47</td>
</tr>
<tr>
<td>SET BFP Rounding Mode (3 bit)</td>
<td>SRNMB</td>
<td>Db</td>
<td>B288</td>
<td>9-47</td>
</tr>
<tr>
<td>SET CHANNEL MONITOR</td>
<td>SCHM</td>
<td>OP c GM</td>
<td>B23C</td>
<td>14-13</td>
</tr>
<tr>
<td>SET CLOCK</td>
<td>SCK</td>
<td>SP</td>
<td>B204</td>
<td>10-117</td>
</tr>
<tr>
<td>SET CLOCK COMPARETOR</td>
<td>SCKC</td>
<td>Db</td>
<td>B206</td>
<td>10-118</td>
</tr>
<tr>
<td>SET CLOCK PROGRAMMABLE FIELD</td>
<td>SCKPF</td>
<td>G0</td>
<td>0107</td>
<td>10-118</td>
</tr>
<tr>
<td>SET CPU TIMER</td>
<td>SPT</td>
<td>SP</td>
<td>B208</td>
<td>10-119</td>
</tr>
<tr>
<td>SET DFP Rounding Mode</td>
<td>SRNMT</td>
<td>Dt</td>
<td>B289</td>
<td>9-47</td>
</tr>
<tr>
<td>SET FPC</td>
<td>SFPC</td>
<td>Db</td>
<td>B384</td>
<td>9-47</td>
</tr>
<tr>
<td>SET FPC AND SIGNAL</td>
<td>SFASR</td>
<td>Xg</td>
<td>B385</td>
<td>9-48</td>
</tr>
<tr>
<td>SET PREFIX</td>
<td>SPX</td>
<td>S</td>
<td>B210</td>
<td>10-119</td>
</tr>
<tr>
<td>SET PROGRAM MASK</td>
<td>SPM</td>
<td>L</td>
<td>04</td>
<td>7-321</td>
</tr>
<tr>
<td>SET PSW KEY FROM ADDRESS</td>
<td>SPKA</td>
<td>Q</td>
<td>B20A</td>
<td>10-120</td>
</tr>
<tr>
<td>SET SECONDARY ASN</td>
<td>SSAR</td>
<td>SP</td>
<td>B226</td>
<td>10-126</td>
</tr>
<tr>
<td>SET SECONDARY ASN WITH INSTANCE</td>
<td>SSAIR</td>
<td>Db</td>
<td>B386</td>
<td>10-120</td>
</tr>
<tr>
<td>SET STORAGE KEY EXTENDED</td>
<td>SSSKE</td>
<td>II</td>
<td>B22B</td>
<td>10-126</td>
</tr>
<tr>
<td>SET SYSTEM MASK</td>
<td>SSMM</td>
<td>SP</td>
<td>80</td>
<td>10-129</td>
</tr>
<tr>
<td>SHIFT AND ROUND DECIMAL</td>
<td>SRP</td>
<td>Dg</td>
<td>ST</td>
<td>8-12</td>
</tr>
<tr>
<td>SHIFT LEFT DOUBLE (64)</td>
<td>SLDA</td>
<td>8F</td>
<td>7-322</td>
<td></td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE (32)</td>
<td>SLA</td>
<td>IF</td>
<td>8B</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE (32)</td>
<td>SLAK</td>
<td>IF</td>
<td>EBDD</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE (64)</td>
<td>SLAG</td>
<td>IF</td>
<td>EB0B</td>
<td>7-323</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE LOGICAL (32)</td>
<td>SLL</td>
<td>89</td>
<td>7-324</td>
<td></td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE LOGICAL (64)</td>
<td>SLK</td>
<td>RSY-a</td>
<td>EBF7</td>
<td>7-324</td>
</tr>
<tr>
<td>SHIFT LEFT SINGLE LOGICAL (32)</td>
<td>SLLG</td>
<td>RSY-a</td>
<td>EBD0</td>
<td>7-324</td>
</tr>
<tr>
<td>SHIFT RIGHT DOUBLE (64)</td>
<td>SRDA</td>
<td>SP</td>
<td>8E</td>
<td>7-325</td>
</tr>
<tr>
<td>SHIFT RIGHT DOUBLE LOGICAL (64)</td>
<td>SRDL</td>
<td>SP</td>
<td>8C</td>
<td>7-325</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>SRA</td>
<td>8A</td>
<td>7-326</td>
<td></td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>SRAK</td>
<td>RSY-a</td>
<td>EBD0</td>
<td>7-326</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>SRLAG</td>
<td>RSY-a</td>
<td>EBOA</td>
<td>7-326</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE LOGICAL (32)</td>
<td>SRLK</td>
<td>RSY-a</td>
<td>EBD0</td>
<td>7-326</td>
</tr>
<tr>
<td>SHIFT RIGHT SINGLE LOGICAL (32)</td>
<td>SRLG</td>
<td>RSY-a</td>
<td>EBD0</td>
<td>7-326</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND LEFT (extended DFP)</td>
<td>SLXT</td>
<td>Da</td>
<td>ED48</td>
<td>20-53</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND LEFT (long DFP)</td>
<td>SLDT</td>
<td>Da</td>
<td>ED40</td>
<td>20-53</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND RIGHT (extended DFP)</td>
<td>SXRT</td>
<td>Da</td>
<td>ED49</td>
<td>20-53</td>
</tr>
<tr>
<td>SHIFT SIGNIFICAND RIGHT (long DFP)</td>
<td>SRDT</td>
<td>Da</td>
<td>ED41</td>
<td>20-53</td>
</tr>
<tr>
<td>SIGNAL PROCESSOR</td>
<td>SIGP</td>
<td>P</td>
<td>AE</td>
<td>10-129</td>
</tr>
<tr>
<td>SQUARE ROOT (extended BFP)</td>
<td>SQXBR</td>
<td>Db</td>
<td>B316</td>
<td>19-40</td>
</tr>
<tr>
<td>SQUARE ROOT (extended HFP)</td>
<td>SQXR</td>
<td>Db</td>
<td>B336</td>
<td>18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (long BFP)</td>
<td>SQDB</td>
<td>Db</td>
<td>ED15</td>
<td>19-40</td>
</tr>
<tr>
<td>SQUARE ROOT (long BFP)</td>
<td>SQDBR</td>
<td>Db</td>
<td>B315</td>
<td>19-40</td>
</tr>
<tr>
<td>SQUARE ROOT (long HFP)</td>
<td>SQDR</td>
<td>Da</td>
<td>ED33</td>
<td>18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (long HFP)</td>
<td>SQDR</td>
<td>Da</td>
<td>B244</td>
<td>18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (short BFP)</td>
<td>SQEB</td>
<td>Da</td>
<td>B244</td>
<td>18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (short HFP)</td>
<td>SQEBR</td>
<td>Da</td>
<td>B244</td>
<td>18-23</td>
</tr>
<tr>
<td>SQUARE ROOT (short HFP)</td>
<td>SQER</td>
<td>Da</td>
<td>B245</td>
<td>18-23</td>
</tr>
<tr>
<td>START SUBCHANNEL</td>
<td>SSCH</td>
<td>OP c GS</td>
<td>B233</td>
<td>14-15</td>
</tr>
<tr>
<td>STORE (32)</td>
<td>ST</td>
<td>ST</td>
<td>B3</td>
<td>7-327</td>
</tr>
<tr>
<td>STORE (32)</td>
<td>ST</td>
<td>ST</td>
<td>50</td>
<td>7-327</td>
</tr>
<tr>
<td>STORE (64)</td>
<td>ST</td>
<td>ST</td>
<td>B3</td>
<td>7-327</td>
</tr>
<tr>
<td>STORE (long)</td>
<td>ST</td>
<td>ST</td>
<td>B3</td>
<td>7-327</td>
</tr>
<tr>
<td>STORE (long)</td>
<td>ST</td>
<td>ST</td>
<td>50</td>
<td>7-327</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 16 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>STORE (short)</td>
<td>STE</td>
<td>RX-a</td>
<td>Da</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE (short)</td>
<td>STEY</td>
<td>RXYa LD</td>
<td>D7-9</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE ACCESS MULTIPLE</td>
<td>STAM</td>
<td>RS-a</td>
<td>A</td>
<td>ST UB</td>
</tr>
<tr>
<td>STORE ACCESS MULTIPLE</td>
<td>STAMY</td>
<td>RXYa LD</td>
<td>A</td>
<td>ST UB</td>
</tr>
<tr>
<td>STORE CHANNEL PATH STATUS</td>
<td>STCPs</td>
<td>S</td>
<td>P</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CHANNEL REPORT WORD</td>
<td>STCRW</td>
<td>S C</td>
<td>P</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CHARACTER</td>
<td>STC</td>
<td>RX-a</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CHARACTER</td>
<td>STCY</td>
<td>RXYa LD</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CHARACTER HIGH (8)</td>
<td>STCH</td>
<td>RXYa</td>
<td>HW</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CHARACTERS UNDER MASK (high)</td>
<td>STCMH</td>
<td>RSYb N</td>
<td>C</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CHARACTERS UNDER MASK (low)</td>
<td>STCM</td>
<td>RS-b</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CHARACTERS UNDER MASK (low)</td>
<td>STCMY</td>
<td>RSYb LD</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CLOCK</td>
<td>STCK</td>
<td>S C</td>
<td>a^3</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CLOCK COMPARATOR</td>
<td>STCKC</td>
<td>S P</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CLOCK EXTENDED</td>
<td>STCKE</td>
<td>S C</td>
<td>a^3</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CONTROL (32)</td>
<td>STCTL</td>
<td>RS-a</td>
<td>P</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CONTROL (64)</td>
<td>STCTG</td>
<td>RSYa N</td>
<td>P A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CPU ADDRESS</td>
<td>STAP</td>
<td>S P</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CPU ID</td>
<td>STIDP</td>
<td>S P</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE CPU TIMER</td>
<td>STPT</td>
<td>S P</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE FACILITY LIST EXTENDED</td>
<td>STFLE</td>
<td>S C FL</td>
<td>a</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE FPC</td>
<td>STFPC</td>
<td>S F</td>
<td>a^3</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE HALFWORD (16)</td>
<td>STH</td>
<td>RX-a</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE HALFWORD (16)</td>
<td>STHY</td>
<td>RXYa LD</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE HALFWORD HIGH (16)</td>
<td>STHH</td>
<td>RXYa</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE HALFWORD RELATIVE LONG (16)</td>
<td>STHRL</td>
<td>RIL-b GE</td>
<td>A</td>
<td>ST C4</td>
</tr>
<tr>
<td>STORE HIGH (32)</td>
<td>STFH</td>
<td>RXYa</td>
<td>HW</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE HIGH ON CONDITION</td>
<td>STOCFH</td>
<td>RSYb L2</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE MULTIPLE (32)</td>
<td>STM</td>
<td>RS-a</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE MULTIPLE (32)</td>
<td>STMY</td>
<td>RSYa LD</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE MULTIPLE (64)</td>
<td>STMG</td>
<td>RSYa N</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE MULTIPLE HIGH (32)</td>
<td>STMH</td>
<td>RSYa N</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE ON CONDITION (32)</td>
<td>STOC</td>
<td>RSYb L1</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE ON CONDITION (64)</td>
<td>STOCG</td>
<td>RSYb L1</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE PAIR TO QUADWORD</td>
<td>STPQ</td>
<td>RXYa N</td>
<td>d^3</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE PREFIX</td>
<td>STPX</td>
<td>S P</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE REAL ADDRESS</td>
<td>STRAG</td>
<td>SSE N</td>
<td>P A</td>
<td>ST B1</td>
</tr>
<tr>
<td>STORE RELATIVE LONG (32)</td>
<td>STRL</td>
<td>RIL-b GE</td>
<td>A</td>
<td>ST C4</td>
</tr>
<tr>
<td>STORE RELATIVE LONG (64)</td>
<td>STGRL</td>
<td>RIL-b GE</td>
<td>A</td>
<td>ST C4</td>
</tr>
<tr>
<td>STORE REVERSED (16)</td>
<td>STRVH</td>
<td>RXYa N3</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE REVERSED (32)</td>
<td>STRV</td>
<td>RXYa N3</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE REVERSED (64)</td>
<td>STRVG</td>
<td>RXYa N</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE SUBCHANNEL</td>
<td>STSCH</td>
<td>S C</td>
<td>P A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE SYSTEM INFORMATION</td>
<td>STSI</td>
<td>S C</td>
<td>P A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE THEN AND SYSTEM MASK</td>
<td>STNSM</td>
<td>S P</td>
<td>A</td>
<td>ST B1</td>
</tr>
<tr>
<td>STORE THEN OR SYSTEM MASK</td>
<td>STOMS</td>
<td>S P</td>
<td>A</td>
<td>ST B1</td>
</tr>
<tr>
<td>STORE USING REAL ADDRESS (32)</td>
<td>STURA</td>
<td>RRE P</td>
<td>A</td>
<td>ST B2</td>
</tr>
<tr>
<td>STORE USING REAL ADDRESS (64)</td>
<td>STURG</td>
<td>RRE N</td>
<td>P A</td>
<td>SU B2</td>
</tr>
<tr>
<td>SUBTRACT (32)</td>
<td>ST RX-a C A</td>
<td>IF</td>
<td>B2 B5</td>
<td>7-338</td>
</tr>
<tr>
<td>SUBTRACT (32)</td>
<td>SR R C</td>
<td>A</td>
<td>IF</td>
<td>B2 1B</td>
</tr>
<tr>
<td>SUBTRACT (32)</td>
<td>SRK RRF-a C DO</td>
<td>IF</td>
<td>B2 B9F9</td>
<td>7-338</td>
</tr>
<tr>
<td>SUBTRACT (32)</td>
<td>SY RXYa C LD A</td>
<td>IF</td>
<td>B2 E35B</td>
<td>7-338</td>
</tr>
<tr>
<td>SUBTRACT (64)</td>
<td>SG RXYa C N A</td>
<td>IF</td>
<td>B2 E309</td>
<td>7-338</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 17 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>SUBTRACT (64)</td>
<td>SGR</td>
<td>RRE C N</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (64)</td>
<td>SGRK</td>
<td>RRA C DO</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (64→32)</td>
<td>SGF</td>
<td>RXYa C N A</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (64→32)</td>
<td>SGFR</td>
<td>RRE C N</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (extended BFP)</td>
<td>SXBR</td>
<td>RRE C</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (extended DFP)</td>
<td>SXTR</td>
<td>RRF-a C TF</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (extended DFP)</td>
<td>SXTRA</td>
<td>RRF-a C F</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (long BFP)</td>
<td>SDB</td>
<td>RXE C</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (long BFP)</td>
<td>SDBR</td>
<td>RRE C</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (long DFP)</td>
<td>SDTR</td>
<td>RRF-a C TF</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (long DFP)</td>
<td>SDTRA</td>
<td>RRF-a C F</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (short BFP)</td>
<td>SEB</td>
<td>RXE C</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (short BFP)</td>
<td>SEBR</td>
<td>RRE C</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT DECIMAL</td>
<td>SP</td>
<td>SS-b C A</td>
<td>ST</td>
</tr>
<tr>
<td>SUBTRACT (halfword (32→16))</td>
<td>SH</td>
<td>RX-a C A</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (halfword (32→16))</td>
<td>SHY</td>
<td>RXya C LD A</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (high)</td>
<td>SHHHR</td>
<td>RRF-a C HW</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (high)</td>
<td>SHHLR</td>
<td>RRF-a C HW</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (32))</td>
<td>SLR</td>
<td>RR C</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (32))</td>
<td>SLRK</td>
<td>RRF-a C DO</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (32))</td>
<td>SLY</td>
<td>RXya C LD A</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (64))</td>
<td>SLG</td>
<td>RXya C N A</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (64))</td>
<td>SLGR</td>
<td>RRE C N</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (64))</td>
<td>SLGRK</td>
<td>RRF-a C DO</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (64→32))</td>
<td>SLG</td>
<td>RXya C N A</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (high (32)</td>
<td>SLHHR</td>
<td>RRF-a C HW</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical (high (32)</td>
<td>SLHLR</td>
<td>RRF-a C HW</td>
<td>IF</td>
</tr>
<tr>
<td>SUBTRACT (logical immediate (32)</td>
<td>SLFI</td>
<td>RIL-a C EI</td>
<td>C25 7-340</td>
</tr>
<tr>
<td>SUBTRACT (logical immediate (64→32)</td>
<td>SLGFI</td>
<td>RIL-a C EI</td>
<td>C24 7-340</td>
</tr>
<tr>
<td>SUBTRACT (logical with borrow (32))</td>
<td>SLB</td>
<td>RXya C N3 A</td>
<td>B3 4B 7-341</td>
</tr>
<tr>
<td>SUBTRACT (logical with borrow (32))</td>
<td>SLBR</td>
<td>RRE C N3</td>
<td>B3 4B 7-341</td>
</tr>
<tr>
<td>SUBTRACT (logical with borrow (64))</td>
<td>SLBGR</td>
<td>RRE C N</td>
<td>B3 4B 7-341</td>
</tr>
<tr>
<td>SUBTRACT (logical with borrow (64))</td>
<td>SLXBR</td>
<td>RR C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUBTRACT (normalized)</td>
<td>SLX</td>
<td>RR C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUBTRACT (normalized)</td>
<td>SDR</td>
<td>RX-a C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUBTRACT (normalized)</td>
<td>SE</td>
<td>RX-a C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUBTRACT (normalized)</td>
<td>SER</td>
<td>RR C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUBTRACT (normalized)</td>
<td>SW</td>
<td>RX-a C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUBTRACT (normalized)</td>
<td>SWR</td>
<td>RR C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUBTRACT (normalized)</td>
<td>SU</td>
<td>RX-a C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUBTRACT (normalized)</td>
<td>SUR</td>
<td>RR C A^3 SP Da EU EO LS</td>
<td>37 18-24</td>
</tr>
<tr>
<td>SUPERVISOR CALL</td>
<td>SVC</td>
<td>I A^x c</td>
<td>U1</td>
</tr>
<tr>
<td>TEST ACCESS</td>
<td>TAR</td>
<td>RRE C A^x</td>
<td>U1</td>
</tr>
<tr>
<td>TEST ADDRESSING MODE</td>
<td>TAM</td>
<td>E C N3 A^x</td>
<td>ST</td>
</tr>
<tr>
<td>TEST AND SET</td>
<td>TS</td>
<td>S C A^x S</td>
<td>ST</td>
</tr>
<tr>
<td>TEST BLOCK</td>
<td>TB</td>
<td>RRE C P A^x II $ G0</td>
<td>B22C 10-161</td>
</tr>
<tr>
<td>TEST DATA CLASS (extended BFP)</td>
<td>TCBX</td>
<td>RXE C A^3 SP Db</td>
<td>ED12 19-41</td>
</tr>
<tr>
<td>TEST DATA CLASS (extended DFP)</td>
<td>TDCX</td>
<td>RXE C TF A^3 SP Dt</td>
<td>ED58 20-55</td>
</tr>
<tr>
<td>TEST DATA CLASS (long BFP)</td>
<td>TCD</td>
<td>RXE C A^3 Db</td>
<td>ED11 19-41</td>
</tr>
<tr>
<td>TEST DATA CLASS (long DFP)</td>
<td>TDCDT</td>
<td>RXE C TF A^3 Db</td>
<td>ED54 20-55</td>
</tr>
<tr>
<td>TEST DATA CLASS (short BFP)</td>
<td>TCEB</td>
<td>RXE C A^3 Db</td>
<td>ED10 19-41</td>
</tr>
<tr>
<td>TEST DATA CLASS (short DFP)</td>
<td>TDCET</td>
<td>RXE C TF A^3 Db</td>
<td>ED50 20-55</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 18 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>TEST DATA GROUP (extended DFP)</td>
<td>TDGXT</td>
<td>RXE C TF</td>
<td>Dt</td>
<td>ED59</td>
</tr>
<tr>
<td>TEST DATA GROUP (long DFP)</td>
<td>TDGDT</td>
<td>RXE C TF</td>
<td>Dt</td>
<td>ED55</td>
</tr>
<tr>
<td>TEST DATA GROUP (short DFP)</td>
<td>TDGET</td>
<td>RXE C TF</td>
<td>Dt</td>
<td>ED51</td>
</tr>
<tr>
<td>TEST DECIMAL</td>
<td>TP</td>
<td>RSL-a C E2</td>
<td>B1, B2</td>
<td>EBC0</td>
</tr>
<tr>
<td>TEST PENDING INTERRUPTION</td>
<td>TPI</td>
<td>S C P A+ SP</td>
<td>c</td>
<td>B236</td>
</tr>
<tr>
<td>TEST PROTECTION</td>
<td>TPROT</td>
<td>SSE C P A+</td>
<td>B1</td>
<td>E501</td>
</tr>
<tr>
<td>TEST SUBCHANNEL</td>
<td>TSCH</td>
<td>S C P A SP</td>
<td>ST</td>
<td>B235</td>
</tr>
<tr>
<td>TEST UNDER MASK</td>
<td>TM</td>
<td>SI C</td>
<td>A</td>
<td>B1</td>
</tr>
<tr>
<td>TEST UNDER MASK</td>
<td>TMY</td>
<td>SIY C LD</td>
<td>A</td>
<td>B1</td>
</tr>
<tr>
<td>TEST UNDER MASK (high)</td>
<td>TMH</td>
<td>Ria-c N</td>
<td>A72</td>
<td>7-343</td>
</tr>
<tr>
<td>TEST UNDER MASK (high low)</td>
<td>TMHL</td>
<td>Ria-c N</td>
<td>A73</td>
<td>7-343</td>
</tr>
<tr>
<td>TEST UNDER MASK (low high)</td>
<td>TTLH</td>
<td>Ria-c N</td>
<td>A70</td>
<td>7-343</td>
</tr>
<tr>
<td>TEST UNDER MASK (low)</td>
<td>TMLL</td>
<td>Ria-c N</td>
<td>A71</td>
<td>7-343</td>
</tr>
<tr>
<td>TEST UNDER MASK (high C)</td>
<td>TMH</td>
<td>Ria-c</td>
<td>A70</td>
<td>7-343</td>
</tr>
<tr>
<td>TEST UNDER MASK LOW</td>
<td>TML</td>
<td>Ria-c</td>
<td>A71</td>
<td>7-343</td>
</tr>
<tr>
<td>TRACE (32)</td>
<td>TRACE</td>
<td>RS-a P A SP T</td>
<td>B1</td>
<td>99</td>
</tr>
<tr>
<td>TRANSACTION ABORT</td>
<td>TABORT</td>
<td>S TX p3 p3 SP SO</td>
<td>EX</td>
<td>B2FC</td>
</tr>
<tr>
<td>TRANSACTION BEGIN (constrained)</td>
<td>TBEGIN</td>
<td>SIL C TX</td>
<td>SO</td>
<td>EX</td>
</tr>
<tr>
<td>TRANSACTION BEGIN (nonconstrained)</td>
<td>TBEGIN</td>
<td>SIL C TX</td>
<td>SO</td>
<td>EX</td>
</tr>
<tr>
<td>TRANSLATE</td>
<td>TR</td>
<td>SS-a p3 A</td>
<td>ST</td>
<td>B1, B2</td>
</tr>
<tr>
<td>TRANSLATE AND TEST</td>
<td>TRT</td>
<td>SS-a p3 A</td>
<td>GM</td>
<td>B1, B2</td>
</tr>
<tr>
<td>TRANSLATE AND TEST EXTENDED</td>
<td>TRTE</td>
<td>RRF-c C PE</td>
<td>IC</td>
<td>ST</td>
</tr>
<tr>
<td>TRANSLATE AND TEST REVERSE</td>
<td>TRTR</td>
<td>SS-a E3 p3 A</td>
<td>GM</td>
<td>B1, B2</td>
</tr>
<tr>
<td>TRANSLATE AND TEST REVERSE EXTENDED</td>
<td>TRTRE</td>
<td>RRF-c C PE</td>
<td>IC</td>
<td>ST</td>
</tr>
<tr>
<td>TRANSLATE EXTENDED</td>
<td>TRE</td>
<td>RRF-c p3 A</td>
<td>IC</td>
<td>ST</td>
</tr>
<tr>
<td>TRANSLATE ONE TO ONE</td>
<td>TROO</td>
<td>RRF-c E2 p3 A</td>
<td>IC</td>
<td>GM</td>
</tr>
<tr>
<td>TRANSLATE ONE TO TWO</td>
<td>TROT</td>
<td>RRF-c E2 p3 A</td>
<td>IC</td>
<td>GM</td>
</tr>
<tr>
<td>TRANSLATE TWO TO ONE</td>
<td>TRTO</td>
<td>RRF-c E2 p3 A</td>
<td>IC</td>
<td>GM</td>
</tr>
<tr>
<td>TRAP</td>
<td>TRAP2</td>
<td>E p3 A SO T</td>
<td>B ST</td>
<td>01FF</td>
</tr>
<tr>
<td>TRAP</td>
<td>TRAP4</td>
<td>S p3 A SO T</td>
<td>B ST</td>
<td>01FF</td>
</tr>
<tr>
<td>UNPACK</td>
<td>UNPK</td>
<td>SS-b p3 A</td>
<td>ST</td>
<td>B1, B2</td>
</tr>
<tr>
<td>UNPACK ASCII</td>
<td>UNPKA</td>
<td>SS-a E2 p3 A</td>
<td>ST</td>
<td>B1, B2</td>
</tr>
<tr>
<td>UNPACK UNICODE</td>
<td>UNPKU</td>
<td>SS-a E2 p3 A</td>
<td>ST</td>
<td>B1, B2</td>
</tr>
<tr>
<td>UPDATE TREE</td>
<td>UPT</td>
<td>E C p3 A II GM I4</td>
<td>ST</td>
<td>0102</td>
</tr>
<tr>
<td>VECTOR ADD</td>
<td>VA</td>
<td>VRR-c VF</td>
<td>Dv</td>
<td>E7F3</td>
</tr>
<tr>
<td>VECTOR ADD COMPUTE CARRY</td>
<td>VACC</td>
<td>VRR-c VF</td>
<td>Dv</td>
<td>E7F1</td>
</tr>
<tr>
<td>VECTOR ADD WITH CARRY</td>
<td>VAC</td>
<td>VRR-d VF</td>
<td>Dv</td>
<td>E7B9</td>
</tr>
<tr>
<td>VECTOR ADD WITH CARRY COMPUTE CARRY</td>
<td>VACCRC</td>
<td>VRR-d VF</td>
<td>Dv</td>
<td>E7B9</td>
</tr>
<tr>
<td>VECTOR AND</td>
<td>VN</td>
<td>VRR-c VF</td>
<td>Dv</td>
<td>E768</td>
</tr>
<tr>
<td>VECTOR AND WITH COMPLEMENT</td>
<td>VNC</td>
<td>VRR-c VF</td>
<td>Dv</td>
<td>E769</td>
</tr>
<tr>
<td>VECTOR AVERAGE</td>
<td>VAVG</td>
<td>VRR-c VF</td>
<td>Dv</td>
<td>E7F2</td>
</tr>
<tr>
<td>VECTOR AVERAGE LOGICAL</td>
<td>VAVGL</td>
<td>VRR-c VF</td>
<td>Dv</td>
<td>E7F0</td>
</tr>
<tr>
<td>VECTOR CHECKSUM</td>
<td>VCKSM</td>
<td>VRR-c VF</td>
<td>Dv</td>
<td>E766</td>
</tr>
<tr>
<td>VECTOR COMPARE EQUAL</td>
<td>VECQ</td>
<td>VRR-b C* VF</td>
<td>Dv</td>
<td>E7F8</td>
</tr>
<tr>
<td>VECTOR COMPARE HIGH</td>
<td>VCH</td>
<td>VRR-b C* VF</td>
<td>Dv</td>
<td>E7FB</td>
</tr>
<tr>
<td>VECTOR COMPARE HIGH LOGICAL</td>
<td>VCHL</td>
<td>VRR-b C* VF</td>
<td>Dv</td>
<td>E7F9</td>
</tr>
<tr>
<td>VECTOR COUNT LEADING ZEROS</td>
<td>VCLZ</td>
<td>VRR-a VF</td>
<td>Dv</td>
<td>E753</td>
</tr>
<tr>
<td>VECTOR COUNT TRAILING ZEROS</td>
<td>VCTZ</td>
<td>VRR-a VF</td>
<td>Dv</td>
<td>E752</td>
</tr>
<tr>
<td>VECTOR ELEMENT COMPARE</td>
<td>VEC</td>
<td>VRR-a C VF</td>
<td>Dv</td>
<td>E7DB</td>
</tr>
<tr>
<td>VECTOR ELEMENT COMPARE LOGICAL</td>
<td>VECL</td>
<td>VRR-a C VF</td>
<td>Dv</td>
<td>E7D8</td>
</tr>
<tr>
<td>VECTOR ELEMENT ROTATE AND INSERT UNDER MASK</td>
<td>VERIM</td>
<td>VRI-d VF</td>
<td>Dv</td>
<td>E772</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 19 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vector Element Rotate Left Logical</td>
<td>VERLVLV</td>
<td>VRR-c VF $d^{+}$ SP Dv</td>
<td>E773</td>
<td>22-19</td>
</tr>
<tr>
<td>Vector Element Rotate Left Logical</td>
<td>VERLL</td>
<td>VRS-a VF $d^{+}$ SP Dv</td>
<td>E733</td>
<td>22-20</td>
</tr>
<tr>
<td>Vector Element Shift Left</td>
<td>VESLV</td>
<td>VRR-c VF $d^{+}$ SP Dv</td>
<td>E770</td>
<td>22-21</td>
</tr>
<tr>
<td>Vector Element Shift Left</td>
<td>VESL</td>
<td>VRS-a VF $d^{+}$ SP Dv</td>
<td>E730</td>
<td>22-21</td>
</tr>
<tr>
<td>Vector Element Shift Right Arithmetic</td>
<td>VESRAV</td>
<td>VRR-c VF $d^{+}$ SP Dv</td>
<td>E77A</td>
<td>22-22</td>
</tr>
<tr>
<td>Vector Element Shift Right Arithmetic</td>
<td>VESRLV</td>
<td>VRS-a VF $d^{+}$ SP Dv</td>
<td>E778</td>
<td>22-22</td>
</tr>
<tr>
<td>Vector Element Shift Right Logical</td>
<td>VESRL</td>
<td>VRS-a VF $d^{+}$ SP Dv</td>
<td>E738</td>
<td>22-22</td>
</tr>
<tr>
<td>Vector Exclusive Or</td>
<td>VX</td>
<td>VRR-c VF $d^{+}$ Dv</td>
<td>E76D</td>
<td>22-11</td>
</tr>
<tr>
<td>Vector Find Any Element Equal</td>
<td>VFAE</td>
<td>VRR-b C* VF $d^{+}$</td>
<td>E780</td>
<td>23-3</td>
</tr>
<tr>
<td>Vector Find Element Not Equal</td>
<td>VFENE</td>
<td>VRR-b C* VF $d^{+}$ SP Dv</td>
<td>E781</td>
<td>23-4</td>
</tr>
<tr>
<td>Vector FP Add</td>
<td>VFA</td>
<td>VRR-a CVF $d^{+}$ SP Dv Xi</td>
<td>E7E3</td>
<td>24-3</td>
</tr>
<tr>
<td>Vector FP Compare and Signal Scalar</td>
<td>WFK</td>
<td>VRR-a C VF $d^{+}$ SP Dv Xi</td>
<td>E7CA</td>
<td>24-8</td>
</tr>
<tr>
<td>Vector FP Compare Equal</td>
<td>VFCE</td>
<td>VRR-c C* VF $d^{+}$ SP Dv Xi</td>
<td>E7E8</td>
<td>24-9</td>
</tr>
<tr>
<td>Vector FP Compare High</td>
<td>VFCH</td>
<td>VRR-c C* VF $d^{+}$ SP Dv Xi</td>
<td>E7EB</td>
<td>24-10</td>
</tr>
<tr>
<td>Vector FP Compare High or Equal</td>
<td>VFCH</td>
<td>VRR-c C* VF $d^{+}$ SP Dv Xi</td>
<td>E7EA</td>
<td>24-12</td>
</tr>
<tr>
<td>Vector FP Compare Scalar</td>
<td>WFC</td>
<td>VRR-a C VF $d^{+}$ SP Dv Xi</td>
<td>E7CB</td>
<td>24-7</td>
</tr>
<tr>
<td>Vector FP Convert from Fixed 64-Bit</td>
<td>VCDG</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi</td>
<td>E7C3</td>
<td>24-13</td>
</tr>
<tr>
<td>Vector FP Convert from Logical 64-Bit</td>
<td>VCDLG</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi</td>
<td>E7C1</td>
<td>24-15</td>
</tr>
<tr>
<td>Vector FP Convert to Fixed 64-Bit</td>
<td>VCDG</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi</td>
<td>E7C2</td>
<td>24-16</td>
</tr>
<tr>
<td>Vector FP Convert to Logical 64-Bit</td>
<td>VCLGD</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi</td>
<td>E7C0</td>
<td>24-18</td>
</tr>
<tr>
<td>Vector FP Divide</td>
<td>VFD</td>
<td>VRR-c VF $d^{+}$ SP Dv Xi Xz Xo Xu Xx</td>
<td>E7E5</td>
<td>24-20</td>
</tr>
<tr>
<td>Vector FP Load Lengthened</td>
<td>VLDE</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi</td>
<td>E7C4</td>
<td>24-24</td>
</tr>
<tr>
<td>Vector FP Load Rounded</td>
<td>VLED</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi Xo Xu Xx</td>
<td>E7C5</td>
<td>24-25</td>
</tr>
<tr>
<td>Vector FP Multiply</td>
<td>VFM</td>
<td>VRR-c VF $d^{+}$ SP Dv Xi Xo Xu Xx</td>
<td>E7E7</td>
<td>24-26</td>
</tr>
<tr>
<td>Vector FP Multiply and Add</td>
<td>VFMA</td>
<td>VRR-a C VF $d^{+}$ SP Dv Xi Xo Xu Xx</td>
<td>E78F</td>
<td>24-27</td>
</tr>
<tr>
<td>Vector FP Multiply and Subtract</td>
<td>VFMS</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi Xo Xu Xx</td>
<td>E78E</td>
<td>24-27</td>
</tr>
<tr>
<td>Vector FP Perform Sign Operation</td>
<td>VFPSO</td>
<td>VRR-a VF $d^{+}$ SP Dv</td>
<td>E7CC</td>
<td>24-29</td>
</tr>
<tr>
<td>Vector FP Rotate Square Root</td>
<td>VFSQ</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi</td>
<td>E7CE</td>
<td>24-30</td>
</tr>
<tr>
<td>Vector FP Subtract</td>
<td>VFS</td>
<td>VRR-c VF $d^{+}$ SP Dv Xi Xo Xu Xx</td>
<td>E7E2</td>
<td>24-31</td>
</tr>
<tr>
<td>Vector FP Test Data Class Immediate</td>
<td>VFTCI</td>
<td>VRR-a C VF $d^{+}$ SP Dv</td>
<td>E7A4</td>
<td>24-31</td>
</tr>
<tr>
<td>Vector Galois Field Multiply Sum</td>
<td>VGFM</td>
<td>VRR-c VF $d^{+}$ SP Dv</td>
<td>E7B4</td>
<td>22-11</td>
</tr>
<tr>
<td>Vector Galois Field Multiply Sum and Accumulate</td>
<td>VGFM</td>
<td>VRR-a VF $d^{+}$ SP Dv</td>
<td>E7BC</td>
<td>22-11</td>
</tr>
<tr>
<td>Vector Gather Element (32)</td>
<td>VGEF</td>
<td>VRV VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E713</td>
</tr>
<tr>
<td>Vector Gather Element (64)</td>
<td>VGEG</td>
<td>VRV VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E712</td>
</tr>
<tr>
<td>Vector Generate Byte Mask</td>
<td>VGBM</td>
<td>VRR-a VF $d^{+}$ Dv</td>
<td>E744</td>
<td>21-4</td>
</tr>
<tr>
<td>Vector Generate Mask</td>
<td>VGM</td>
<td>VRR-b VF $d^{+}$ SP Dv</td>
<td>E746</td>
<td>21-4</td>
</tr>
<tr>
<td>Vector Isolate String</td>
<td>VISTR</td>
<td>VRR-a C* VF $d^{+}$ SP Dv</td>
<td>E75C</td>
<td>23-5</td>
</tr>
<tr>
<td>Vector Load</td>
<td>VL</td>
<td>VRX VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E706</td>
</tr>
<tr>
<td>Vector Load and Replicate</td>
<td>VLREP</td>
<td>VRX VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E705</td>
</tr>
<tr>
<td>Vector Load Complement</td>
<td>VLC</td>
<td>VRR-a VF $d^{+}$ SP Dv</td>
<td>E7DE</td>
<td>22-12</td>
</tr>
<tr>
<td>Vector Load Element (16)</td>
<td>VLEG</td>
<td>VRX VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E701</td>
</tr>
<tr>
<td>Vector Load Element (32)</td>
<td>VLEF</td>
<td>VRX VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E703</td>
</tr>
<tr>
<td>Vector Load Element (64)</td>
<td>VLEG</td>
<td>VRX VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E702</td>
</tr>
<tr>
<td>Vector Load Element (8)</td>
<td>VLEB</td>
<td>VRX VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E700</td>
</tr>
<tr>
<td>Vector Load Element Immediate (16)</td>
<td>VLEIH</td>
<td>VRI-a VF $d^{+}$ SP Dv</td>
<td>E741</td>
<td>21-6</td>
</tr>
<tr>
<td>Vector Load Element Immediate (32)</td>
<td>VLEIF</td>
<td>VRI-a VF $d^{+}$ SP Dv</td>
<td>E743</td>
<td>21-6</td>
</tr>
<tr>
<td>Vector Load Element Immediate (64)</td>
<td>VLEIG</td>
<td>VRI-a VF $d^{+}$ SP Dv</td>
<td>E742</td>
<td>21-6</td>
</tr>
<tr>
<td>Vector Load Element Immediate (8)</td>
<td>VLEG</td>
<td>VRI-a VF $d^{+}$ SP Dv</td>
<td>E740</td>
<td>21-6</td>
</tr>
<tr>
<td>Vector Load FP Integer</td>
<td>VFI</td>
<td>VRR-a VF $d^{+}$ SP Dv Xi Xx</td>
<td>E7C7</td>
<td>24-22</td>
</tr>
<tr>
<td>Vector Load GR from VR Element</td>
<td>VLG</td>
<td>VRS-c VF $d^{+}$ SP Dv</td>
<td>E721</td>
<td>21-7</td>
</tr>
<tr>
<td>Vector Load Logical Element and Zero</td>
<td>VLLZ</td>
<td>VRX VF $d^{+}$ A SP Dv</td>
<td>B,</td>
<td>E704</td>
</tr>
</tbody>
</table>

*Figure B-1. Instructions Arranged by Name (Part 20 of 22)*
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VECTOR LOAD MULTIPLE</td>
<td>VLM</td>
<td>VF $\varphi$ A SP Dv</td>
<td>B$_3$</td>
<td>21-8</td>
</tr>
<tr>
<td>VECTOR LOAD POSITIVE</td>
<td>VLP</td>
<td>VF $\varphi$ A SP Dv</td>
<td>B$_3$</td>
<td>22-12</td>
</tr>
<tr>
<td>VECTOR LOAD TO BLOCK BOUNDARY</td>
<td>VLBB</td>
<td>VF $\varphi$ A SP Dv</td>
<td>B$_2$</td>
<td>21-9</td>
</tr>
<tr>
<td>VECTOR LOAD VR ELEMENT FROM GR</td>
<td>VLVG</td>
<td>VF $\varphi$ A SP Dv</td>
<td>B$_3$</td>
<td>21-9</td>
</tr>
<tr>
<td>VECTOR LOAD VR FROM GRS DISJOINT</td>
<td>VLVGP</td>
<td>VF $\varphi$ A SP Dv</td>
<td>B$_3$</td>
<td>21-10</td>
</tr>
<tr>
<td>VECTOR LOAD WITH LENGTH</td>
<td>VLL</td>
<td>VF $\varphi$ A SP Dv</td>
<td>B$_3$</td>
<td>21-10</td>
</tr>
<tr>
<td>VECTOR MAXIMUM</td>
<td>VMX</td>
<td>VF $\varphi$ SP Dv</td>
<td>E77F</td>
<td>22-13</td>
</tr>
<tr>
<td>VECTOR MAXIMUM LOGICAL</td>
<td>VMXL</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7FD</td>
<td>22-13</td>
</tr>
<tr>
<td>VECTOR MERGE HIGH</td>
<td>VMRH</td>
<td>VF $\varphi$ SP Dv</td>
<td>E761</td>
<td>21-10</td>
</tr>
<tr>
<td>VECTOR MERGE LOW</td>
<td>VMRL</td>
<td>VF $\varphi$ SP Dv</td>
<td>E760</td>
<td>21-10</td>
</tr>
<tr>
<td>VECTOR MINIMUM</td>
<td>VMN</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7FE</td>
<td>22-13</td>
</tr>
<tr>
<td>VECTOR MINIMUM LOGICAL</td>
<td>VMNL</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7FC</td>
<td>22-13</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD EVEN</td>
<td>VMALO</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7AD</td>
<td>22-16</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD LOW</td>
<td>VMAL</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7AA</td>
<td>22-14</td>
</tr>
<tr>
<td>VECTOR MULTIPLY AND ADD ODD</td>
<td>VMAO</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7AF</td>
<td>22-16</td>
</tr>
<tr>
<td>VECTOR MULTIPLY EVEN</td>
<td>VME</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7AE</td>
<td>22-15</td>
</tr>
<tr>
<td>VECTOR MULTIPLY HIGH</td>
<td>VMH</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7AG</td>
<td>22-15</td>
</tr>
<tr>
<td>VECTOR MULTIPLY LOW</td>
<td>VML</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7AJ</td>
<td>22-15</td>
</tr>
<tr>
<td>VECTOR MULTIPLY ODD</td>
<td>VMO</td>
<td>VF $\varphi$ SP Dv</td>
<td>E7AK</td>
<td>22-15</td>
</tr>
<tr>
<td>VECTOR MULTIPACK</td>
<td>VNO</td>
<td>VF $\varphi$ Dv</td>
<td>E7EB</td>
<td>22-19</td>
</tr>
<tr>
<td>VECTOR OR</td>
<td>VO</td>
<td>VF $\varphi$ Dv</td>
<td>E7EA</td>
<td>22-19</td>
</tr>
<tr>
<td>VECTOR PARI</td>
<td>VPK</td>
<td>VF $\varphi$ SP Dv</td>
<td>E794</td>
<td>22-11</td>
</tr>
<tr>
<td>VECTOR PACK LOGICAL SATURATE</td>
<td>VPKLS</td>
<td>VRR-b C* VF $\varphi$ SP Dv</td>
<td>E795</td>
<td>22-12</td>
</tr>
<tr>
<td>VECTOR PACK SATURATE</td>
<td>VPKS</td>
<td>VRR-b C* VF $\varphi$ SP Dv</td>
<td>E797</td>
<td>22-11</td>
</tr>
<tr>
<td>VECTOR PERMUTE</td>
<td>VPERM</td>
<td>VF $\varphi$ Dv</td>
<td>E7CB</td>
<td>21-13</td>
</tr>
<tr>
<td>VECTOR PERMUTE DOUBLEWORD IMMEDIATE</td>
<td>VPDI</td>
<td>VF $\varphi$ SP Dv</td>
<td>E784</td>
<td>22-13</td>
</tr>
<tr>
<td>VECTOR POPULATION COUNT</td>
<td>VPOPCT</td>
<td>VF $\varphi$ SP Dv</td>
<td>E750</td>
<td>22-19</td>
</tr>
<tr>
<td>VECTOR REPLICATE</td>
<td>VREP</td>
<td>VF $\varphi$ SP Dv</td>
<td>E74D</td>
<td>21-14</td>
</tr>
<tr>
<td>VECTOR REPLICATE IMMEDIATE</td>
<td>VREPI</td>
<td>VF $\varphi$ SP Dv</td>
<td>E745</td>
<td>21-14</td>
</tr>
<tr>
<td>VECTOR SCATTER ELEMENT (32)</td>
<td>VSCEF</td>
<td>VF $\varphi$ A SP Dv</td>
<td>ST B$_2$</td>
<td>21-15</td>
</tr>
<tr>
<td>VECTOR SCATTER ELEMENT (64)</td>
<td>VSEGF</td>
<td>VF $\varphi$ A SP Dv</td>
<td>ST B$_2$</td>
<td>21-15</td>
</tr>
<tr>
<td>VECTOR SELET</td>
<td>VSEL</td>
<td>VF $\varphi$ Dv</td>
<td>E7BD</td>
<td>22-23</td>
</tr>
<tr>
<td>VECTOR SHIFT LEFT</td>
<td>VSL</td>
<td>VF $\varphi$ Dv</td>
<td>E777</td>
<td>22-23</td>
</tr>
<tr>
<td>VECTOR SHIFT LEFT BY BYTE</td>
<td>VSLB</td>
<td>VF $\varphi$ Dv</td>
<td>E778</td>
<td>22-23</td>
</tr>
<tr>
<td>VECTOR SHIFT LEFT DOUBLE BY BYTE</td>
<td>VSLDB</td>
<td>VF $\varphi$ Dv</td>
<td>E777</td>
<td>22-23</td>
</tr>
<tr>
<td>VECTOR SHIFT RIGHT ARITHMETIC</td>
<td>VSRA</td>
<td>VF $\varphi$ Dv</td>
<td>E77E</td>
<td>22-24</td>
</tr>
<tr>
<td>VECTOR SHIFT RIGHT ARITHMETIC BY BYTE</td>
<td>VSRAB</td>
<td>VF $\varphi$ Dv</td>
<td>E77F</td>
<td>22-24</td>
</tr>
<tr>
<td>VECTOR SHIFT RIGHT LOGICAL</td>
<td>VSRAL</td>
<td>VF $\varphi$ Dv</td>
<td>E77C</td>
<td>22-24</td>
</tr>
<tr>
<td>VECTOR SHIFT RIGHT LOGICAL BY BYTE</td>
<td>VSRALB</td>
<td>VF $\varphi$ Dv</td>
<td>E77D</td>
<td>22-24</td>
</tr>
<tr>
<td>VECTOR SIGN EXTEND TO DOUBLEWORD</td>
<td>VSEG</td>
<td>VF $\varphi$ A SP Dv</td>
<td>E75F</td>
<td>21-15</td>
</tr>
<tr>
<td>VECTOR STORE</td>
<td>VST</td>
<td>VF $\varphi$ A Dv</td>
<td>ST B$_3$</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE ELEMENT (16)</td>
<td>VSTEH</td>
<td>VF $\varphi$ A SP Dv</td>
<td>ST B$_3$</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE ELEMENT (32)</td>
<td>VSTEF</td>
<td>VF $\varphi$ A SP Dv</td>
<td>ST B$_3$</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE ELEMENT (64)</td>
<td>VSTEG</td>
<td>VF $\varphi$ A SP Dv</td>
<td>ST B$_3$</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE ELEMENT (8)</td>
<td>VSTEB</td>
<td>VF $\varphi$ A SP Dv</td>
<td>ST B$_3$</td>
<td>21-16</td>
</tr>
<tr>
<td>VECTOR STORE MULTIPLE</td>
<td>VSTM</td>
<td>VF $\varphi$ A SP Dv</td>
<td>E73E</td>
<td>21-17</td>
</tr>
<tr>
<td>VECTOR STORE WITH LENGTH</td>
<td>VSTL</td>
<td>VF $\varphi$ A SP Dv</td>
<td>E73F</td>
<td>21-17</td>
</tr>
<tr>
<td>VECTOR STRING RANGE COMPARE</td>
<td>VSTRC</td>
<td>VRR-d C* VF $\varphi$ SP Dv</td>
<td>E78A</td>
<td>23-6</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 21 of 22)
<table>
<thead>
<tr>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VECTOR SUBTRACT</td>
<td>VS</td>
<td>VRR-c VF d⁷-⁴ SP Dv</td>
<td>E7F7</td>
<td>22-25</td>
</tr>
<tr>
<td>VECTOR SUBTRACT COMPUTE BORROW INDICATION</td>
<td>VSCBI</td>
<td>VRR-c VF d⁷-⁴ SP Dv</td>
<td>E7F5</td>
<td>22-25</td>
</tr>
<tr>
<td>VECTOR SUBTRACT WITH BORROW COMPUTE BORROW INDICATION</td>
<td>VSBCBI</td>
<td>VRR-d VF d⁷-⁴ SP Dv</td>
<td>E7BD</td>
<td>22-26</td>
</tr>
<tr>
<td>VECTOR SUBTRACT WITH BORROW INDICATION</td>
<td>VSBI</td>
<td>VRR-d VF d⁷-⁴ SP Dv</td>
<td>E7BF</td>
<td>22-26</td>
</tr>
<tr>
<td>VECTOR SUM ACROSS DOUBLEWORD</td>
<td>VSUMG</td>
<td>VRR-c VF d⁷-⁴ SP Dv</td>
<td>E7E5</td>
<td>22-27</td>
</tr>
<tr>
<td>VECTOR SUM ACROSS QUADWORD</td>
<td>VSUMQ</td>
<td>VRR-c VF d⁷-⁴ SP Dv</td>
<td>E7E7</td>
<td>22-27</td>
</tr>
<tr>
<td>VECTOR SUM ACROSS WORD</td>
<td>VSUM</td>
<td>VRR-c VF d⁷-⁴ SP Dv</td>
<td>E7E4</td>
<td>22-27</td>
</tr>
<tr>
<td>VECTOR TEST UNDER MASK</td>
<td>VTM</td>
<td>VRR-a C VF d⁷-⁴ Dv</td>
<td>E7D8</td>
<td>22-28</td>
</tr>
<tr>
<td>VECTOR UNPACK HIGH</td>
<td>VUPH</td>
<td>VRR-a VF d⁷-⁴ SP Dv</td>
<td>E7D7</td>
<td>21-17</td>
</tr>
<tr>
<td>VECTOR UNPACK LOGICAL HIGH</td>
<td>VUPLH</td>
<td>VRR-a VF d⁷-⁴ SP Dv</td>
<td>E7D5</td>
<td>21-18</td>
</tr>
<tr>
<td>VECTOR UNPACK LOGICAL LOW</td>
<td>VUPLL</td>
<td>VRR-a VF d⁷-⁴ SP Dv</td>
<td>E7D4</td>
<td>21-18</td>
</tr>
<tr>
<td>VECTOR UNPACK LOW</td>
<td>VUPL</td>
<td>VRR-a VF d⁷-⁴ SP Dv</td>
<td>E7D6</td>
<td>21-19</td>
</tr>
<tr>
<td>ZERO AND ADD</td>
<td>ZAP</td>
<td>SS-b C d⁶ A Dg DF</td>
<td>ST B₁ B₂ F₈</td>
<td>8-14</td>
</tr>
</tbody>
</table>

Figure B-1. Instructions Arranged by Name (Part 22 of 22)
## Instructions Arranged by Mnemonic

<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>ADD (32)</td>
<td>RX-a C A IF</td>
<td>B₃ 5A 7-25</td>
</tr>
<tr>
<td>AD</td>
<td>ADD (long HFP)</td>
<td>RX-a C g₃ A Da EU EO LS</td>
<td>B₃ 6A 18-8</td>
</tr>
<tr>
<td>ADB</td>
<td>ADD (long BFP)</td>
<td>RXE C g₃ A Db Xi Xo Xu Xx</td>
<td>B₂ ED1A 19-15</td>
</tr>
<tr>
<td>ADBR</td>
<td>ADD (long BFP)</td>
<td>RRE C g₃ A Db Xi Xo Xu Xx</td>
<td>B₁ B31A 19-15</td>
</tr>
<tr>
<td>ADR</td>
<td>ADD (short HFP)</td>
<td>RR C g₃ A Da EU EO LS</td>
<td>2A 18-8</td>
</tr>
<tr>
<td>ADTR</td>
<td>ADD (long DFP)</td>
<td>RRF-a C TF g₃ A Da EU EO LS</td>
<td>B3D2 20-18</td>
</tr>
<tr>
<td>ADTRA</td>
<td>ADD (long DFP)</td>
<td>RRF-a C F g₃ A Da EU EO LS Xq</td>
<td>B3D2 20-18</td>
</tr>
<tr>
<td>AE</td>
<td>ADD (short HFP)</td>
<td>RX-a C g₃ A Da EU EO LS</td>
<td>B₃ 7A 18-8</td>
</tr>
<tr>
<td>AEB</td>
<td>ADD (short BFP)</td>
<td>RXE C g₃ A Db Xi Xo Xu Xx</td>
<td>B₂ EDOA 19-15</td>
</tr>
<tr>
<td>AEBR</td>
<td>ADD (short BFP)</td>
<td>RRE C g₃ A Db Xi Xo Xu Xx</td>
<td>B₃ 30A 19-15</td>
</tr>
<tr>
<td>AER</td>
<td>ADD (short HFP)</td>
<td>RR C g₃ A Da EU EO LS</td>
<td>3A 18-8</td>
</tr>
<tr>
<td>AFI</td>
<td>ADD IMMEDIATE (32)</td>
<td>RIL-a C EI IF</td>
<td>C29 7-26</td>
</tr>
<tr>
<td>AG</td>
<td>ADD (64)</td>
<td>RXY-a C N A IF</td>
<td>B₃ E308 7-26</td>
</tr>
<tr>
<td>AGF</td>
<td>ADD (64)</td>
<td>RXY-a C N A IF</td>
<td>E318 7-26</td>
</tr>
<tr>
<td>AGFI</td>
<td>ADD IMMEDIATE (64)</td>
<td>RIL-a C EI IF</td>
<td>C29 7-26</td>
</tr>
<tr>
<td>AGFR</td>
<td>ADD (64)</td>
<td>RRE C N IF</td>
<td>B918 7-25</td>
</tr>
<tr>
<td>AGHI</td>
<td>ADD HALFWORD IMMEDIATE (64)</td>
<td>Ri-a C N IF</td>
<td>A7B 7-27</td>
</tr>
<tr>
<td>AGHIK</td>
<td>ADD IMMEDIATE (64)</td>
<td>RIE-d C DO IF</td>
<td>ECD9 7-26</td>
</tr>
<tr>
<td>AGR</td>
<td>ADD (64)</td>
<td>RRE C N IF</td>
<td>B908 7-25</td>
</tr>
<tr>
<td>AGRK</td>
<td>ADD (64)</td>
<td>RRF-a C DO IF</td>
<td>B9E8 7-25</td>
</tr>
<tr>
<td>AGSI</td>
<td>ADD IMMEDIATE (64)</td>
<td>SIY C GE A IF £¹ ST</td>
<td>B₁ EB7A 7-26</td>
</tr>
<tr>
<td>AH</td>
<td>ADD HALFWORD IMMEDIATE (32)</td>
<td>RX-a C A IF</td>
<td>4A 7-27</td>
</tr>
<tr>
<td>AHHLRR</td>
<td>ADD HIGH (32)</td>
<td>RRF-a C HW IF</td>
<td>B₃ B9C8 7-28</td>
</tr>
<tr>
<td>AL</td>
<td>ADD IMMEDIATE (64)</td>
<td>RIL-a C C IF</td>
<td>B₃ B9D8 7-28</td>
</tr>
<tr>
<td>AH</td>
<td>ADD HALFWORD IMMEDIATE (32)</td>
<td>Ri-a C DO</td>
<td>A7A 7-27</td>
</tr>
<tr>
<td>AHHK</td>
<td>ADD IMMEDIATE (32)</td>
<td>RIE-d C DO IF</td>
<td>ECD9 7-26</td>
</tr>
<tr>
<td>AIH</td>
<td>ADD HALFWORD IMMEDIATE (32)</td>
<td>RXY-a C LD A IF</td>
<td>B₂ 7-27</td>
</tr>
<tr>
<td>AHI</td>
<td>ADD HALFWORD IMMEDIATE (32)</td>
<td>RXY-a C HW IF</td>
<td>C3 7-28</td>
</tr>
<tr>
<td>AHIK</td>
<td>ADD IMMEDIATE (32)</td>
<td>RIL-a C HW IF</td>
<td>B₃ 7-29</td>
</tr>
<tr>
<td>ALC</td>
<td>ADD LOGICAL CARRY (32)</td>
<td>RXY-a C N3 A</td>
<td>B₂ E388 7-30</td>
</tr>
<tr>
<td>ALCG</td>
<td>ADD LOGICAL CARRY (64)</td>
<td>RXY-a C N A</td>
<td>B₂ E388 7-30</td>
</tr>
<tr>
<td>ALG</td>
<td>ADD LOGICAL WITH CARRY (32)</td>
<td>RRE C N IF</td>
<td>B₃ B988 7-30</td>
</tr>
<tr>
<td>ALGR</td>
<td>ADD LOGICAL WITH CARRY (64)</td>
<td>RRF-a C DO</td>
<td>B₂ B988 7-30</td>
</tr>
<tr>
<td>ALHSIK</td>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (64)</td>
<td>SYY C GE A £¹ ST</td>
<td>C7 7-31</td>
</tr>
<tr>
<td>ALGF</td>
<td>ADD LOGICAL (64)</td>
<td>RXY-a C N A</td>
<td>B₂ E30A 7-29</td>
</tr>
<tr>
<td>ALGFI</td>
<td>ADD LOGICAL IMMEDIATE (32)</td>
<td>RIL-a C N A</td>
<td>E31A 7-29</td>
</tr>
<tr>
<td>ALGFR</td>
<td>ADD LOGICAL IMMEDIATE (32)</td>
<td>RRE C N IF</td>
<td>C29 7-29</td>
</tr>
<tr>
<td>ALSI</td>
<td>ADD LOGICAL IMMEDIATE (32)</td>
<td>RRF-a C DO</td>
<td>B₁ B91A 7-29</td>
</tr>
<tr>
<td>ALSIH</td>
<td>ADD LOGICAL IMMEDIATE (32)</td>
<td>RIE-d C DO</td>
<td>ECD9 7-31</td>
</tr>
<tr>
<td>ALSIHN</td>
<td>ADD LOGICAL IMMEDIATE IMMEDIATE (32)</td>
<td>RIL-a C A £¹ ST</td>
<td>B₁ EB8E 7-31</td>
</tr>
<tr>
<td>ALSIHK</td>
<td>ADD LOGICAL IMMEDIATE IMMEDIATE (32)</td>
<td>RIE-d C DO</td>
<td>EB7E 7-31</td>
</tr>
<tr>
<td>ALSIH</td>
<td>ADD LOGICAL IMMEDIATE IMMEDIATE (32)</td>
<td>RIL-a C HW</td>
<td>B₃ B9CA 7-30</td>
</tr>
<tr>
<td>ALSIHN</td>
<td>ADD LOGICAL IMMEDIATE IMMEDIATE (32)</td>
<td>RIL-a C HW</td>
<td>B₃ B9D7 7-30</td>
</tr>
</tbody>
</table>

*Figure B-22. Instructions Arranged by Mnemonic (Part 1 of 22)*
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALY</td>
<td>ADD LOGICAL (32)</td>
<td>RXY-a C LD A A</td>
<td>B3 E35E 7-29</td>
</tr>
<tr>
<td>AP</td>
<td>ADD DECIMAL</td>
<td>SS-b C g A A</td>
<td>BFA 8-6</td>
</tr>
<tr>
<td>AR</td>
<td>ADD (32)</td>
<td>RR C I</td>
<td>B1 1A 7-25</td>
</tr>
<tr>
<td>ARK</td>
<td>ADD (32)</td>
<td>RRF-a C DO I</td>
<td>B9F8 7-25</td>
</tr>
<tr>
<td>ASI</td>
<td>ADD IMMEDIATE (32–8)</td>
<td>SIT C GE A I</td>
<td>S9 E6B8 7-26</td>
</tr>
<tr>
<td>AU</td>
<td>ADD UNNORMALIZED (short HFP)</td>
<td>RX-a C g A Da E S LS B</td>
<td>B9 7E 18-9</td>
</tr>
<tr>
<td>AUR</td>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>RR C g A Da E S LS B</td>
<td>B1 6E 18-9</td>
</tr>
<tr>
<td>AW</td>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>RX-a C g A Da E S LS B</td>
<td>B1 2E 18-9</td>
</tr>
<tr>
<td>AWR</td>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>RR C g A Da E S LS B</td>
<td>B1 1E 18-9</td>
</tr>
<tr>
<td>AXBR</td>
<td>ADD (extended BFP)</td>
<td>RRE C g A SP Db Xi Xu Xx</td>
<td>B3A A319-15</td>
</tr>
<tr>
<td>AXR</td>
<td>ADD NORMALIZED (extended HFP)</td>
<td>RR C g A Da E EU LS</td>
<td>36 18-8</td>
</tr>
<tr>
<td>AXTR</td>
<td>ADD (extended DFP)</td>
<td>RRF-a C TF g A SP Dt Xi Xu Xy Xz</td>
<td>B3A B20-18</td>
</tr>
<tr>
<td>AXTRA</td>
<td>ADD (extended DFP)</td>
<td>RRF-a C F g A SP Dt Xi Xu Xy Xz</td>
<td>B3A B20-18</td>
</tr>
<tr>
<td>AY</td>
<td>ADD (32)</td>
<td>RXY-a C LD A I</td>
<td>B3 E35A 7-25</td>
</tr>
<tr>
<td>BAKR</td>
<td>BRANCH AND STACK</td>
<td>RRE g A T B ST</td>
<td>B240 10-10</td>
</tr>
<tr>
<td>BAL</td>
<td>BRANCH AND LINK</td>
<td>RX-a g A</td>
<td>B 45 7-34</td>
</tr>
<tr>
<td>BALR</td>
<td>BRANCH AND LINK</td>
<td>RR g A T B</td>
<td>B 05 7-34</td>
</tr>
<tr>
<td>BAS</td>
<td>BRANCH AND SAVE</td>
<td>RX-a g A</td>
<td>B 4D 7-35</td>
</tr>
<tr>
<td>BASR</td>
<td>BRANCH AND SAVE</td>
<td>RR g A T B</td>
<td>B 0D 7-35</td>
</tr>
<tr>
<td>BASSM</td>
<td>BRANCH AND SAVE AND SET MODE</td>
<td>RR g A T B</td>
<td>B 0D 7-36</td>
</tr>
<tr>
<td>BC</td>
<td>BRANCH ON CONDITION</td>
<td>RX-b g A</td>
<td>B 47 7-37</td>
</tr>
<tr>
<td>BCR</td>
<td>BRANCH ON CONDITION</td>
<td>RR g A</td>
<td>B 07 7-37</td>
</tr>
<tr>
<td>BCT</td>
<td>BRANCH ON COUNT (32)</td>
<td>RX-a g A</td>
<td>B 46 7-38</td>
</tr>
<tr>
<td>BCTG</td>
<td>BRANCH ON COUNT (64)</td>
<td>RXY-a N g A</td>
<td>B E346 7-38</td>
</tr>
<tr>
<td>BCTGR</td>
<td>BRANCH ON COUNT (64)</td>
<td>RRE N g A</td>
<td>B946 7-38</td>
</tr>
<tr>
<td>BCTR</td>
<td>BRANCH ON COUNT (32)</td>
<td>RX-a g A</td>
<td>B 06 7-38</td>
</tr>
<tr>
<td>BPP</td>
<td>BRANCH PREDICTION PRELOAD</td>
<td>SMI E g A</td>
<td>C7 7-40</td>
</tr>
<tr>
<td>BPRP</td>
<td>BRANCH PREDICTION RELATIVE PRELOAD</td>
<td>MI E g A</td>
<td>C5 7-40</td>
</tr>
<tr>
<td>BRAS</td>
<td>BRANCH RELATIVE AND SAVE</td>
<td>RI-b g A</td>
<td>B A75 7-43</td>
</tr>
<tr>
<td>BRASL</td>
<td>BRANCH RELATIVE AND SAVE LONG</td>
<td>RIL-b N3 g A</td>
<td>B C05 7-43</td>
</tr>
<tr>
<td>BRC</td>
<td>BRANCH RELATIVE ON CONDITION</td>
<td>RIL-c N3 g A</td>
<td>B A74 7-44</td>
</tr>
<tr>
<td>BRCL</td>
<td>BRANCH RELATIVE ON CONDITION LONG</td>
<td>RIL-c N3 g A</td>
<td>B C04 7-44</td>
</tr>
<tr>
<td>BRCT</td>
<td>BRANCH RELATIVE ON COUNT (32)</td>
<td>RI-b g A</td>
<td>B A76 7-45</td>
</tr>
<tr>
<td>BRCTG</td>
<td>BRANCH RELATIVE ON COUNT (64)</td>
<td>RI-b N g A</td>
<td>B A77 7-45</td>
</tr>
<tr>
<td>BRCTH</td>
<td>BRANCH RELATIVE ON COUNT HIGH (32)</td>
<td>RIL-b HW g A</td>
<td>B CC6 7-45</td>
</tr>
<tr>
<td>BRXH</td>
<td>BRANCH RELATIVE ON INDEX HIGH (32)</td>
<td>RSI g A</td>
<td>B 84 7-45</td>
</tr>
<tr>
<td>BRXHG</td>
<td>BRANCH RELATIVE ON INDEX HIGH (64)</td>
<td>RIE-e N g A</td>
<td>B E44 7-45</td>
</tr>
<tr>
<td>BRXLE</td>
<td>BRANCH RELATIVE ON INDEX LOW OR EQ. (32)</td>
<td>RSI g A</td>
<td>B 85 7-46</td>
</tr>
<tr>
<td>BRXLG</td>
<td>BRANCH RELATIVE ON INDEX LOW OR EQ. (64)</td>
<td>RIE-e N g A</td>
<td>B E45 7-46</td>
</tr>
<tr>
<td>BSA</td>
<td>BRANCH AND SET AUTHORITY</td>
<td>RRE Q A* SO T B</td>
<td>B25A 10-6</td>
</tr>
<tr>
<td>BSG</td>
<td>BRANCH IN SUBSPACE GROUP</td>
<td>RRE g A* SO T B</td>
<td>B2B8 10-12</td>
</tr>
<tr>
<td>BSM</td>
<td>BRANCH AND SET MODE</td>
<td>RR g A T B</td>
<td>B0 7-37</td>
</tr>
<tr>
<td>BXH</td>
<td>BRANCH ON INDEX HIGH (32)</td>
<td>RS-a g A</td>
<td>B 86 7-39</td>
</tr>
<tr>
<td>BXHG</td>
<td>BRANCH ON INDEX HIGH</td>
<td>RSY-a N g A</td>
<td>B E44 7-39</td>
</tr>
<tr>
<td>BXLE</td>
<td>BRANCH ON INDEX LOW OR EQUAL (32)</td>
<td>RS-a g A</td>
<td>B 87 7-39</td>
</tr>
<tr>
<td>BXLG</td>
<td>BRANCH ON INDEX LOW OR EQUAL (64)</td>
<td>RSY-a N g A</td>
<td>B E45 7-39</td>
</tr>
<tr>
<td>C</td>
<td>COMPARE (32)</td>
<td>RX-a C g A A Da B</td>
<td>B6 69 18-10</td>
</tr>
<tr>
<td>CD</td>
<td>COMPARE (long HFP)</td>
<td>RX-a C g A Da B</td>
<td>B6 69 18-10</td>
</tr>
<tr>
<td>CDB</td>
<td>COMPARE (long BFP)</td>
<td>RXE C g A Db Xi B</td>
<td>B6 ED19 19-17</td>
</tr>
<tr>
<td>CDBR</td>
<td>COMPARE (long BFP)</td>
<td>RRE C g A Db Xi</td>
<td>B3B 19-17</td>
</tr>
<tr>
<td>CDFBR</td>
<td>CONVERT FROM FIXED (32 to long BFP)</td>
<td>RRE g A Db</td>
<td>B3B 19-17</td>
</tr>
<tr>
<td>CDFBRA</td>
<td>CONVERT FROM FIXED (32 to long BFP)</td>
<td>RRF-e F g A SP Db</td>
<td>B3B 19-17</td>
</tr>
<tr>
<td>CDFR</td>
<td>CONVERT FROM FIXED (32 to long HFP)</td>
<td>RRE g A Da B</td>
<td>B3B 18-11</td>
</tr>
<tr>
<td>CDFTR</td>
<td>CONVERT FROM FIXED (32 to long DFP)</td>
<td>RRE F g A Dt B</td>
<td>B95 20-23</td>
</tr>
<tr>
<td>CDBG</td>
<td>CONVERT FROM FIXED (64 to long BFP)</td>
<td>RRE g A Sp Db Xx B</td>
<td>B3A5 19-19</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 2 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDGBRA</td>
<td>CONVERT FROM FIXED (64 to long BFP)</td>
<td>RRF-e F g^7 SP Db Xx</td>
<td>B3A5</td>
<td>19-19</td>
</tr>
<tr>
<td>CDGR</td>
<td>CONVERT FROM FIXED (64 to long HFP)</td>
<td>RRE N g^7 Da</td>
<td>B3C5</td>
<td>18-11</td>
</tr>
<tr>
<td>CDGTR</td>
<td>CONVERT FROM FIXED (64 to long DFP)</td>
<td>RRE TF g^7 Dt Xx</td>
<td>B3F1</td>
<td>20-23</td>
</tr>
<tr>
<td>CDGTRA</td>
<td>CONVERT FROM FIXED (64 to long DFP)</td>
<td>RRF-e F g^7 Ot Xx Xq</td>
<td>B3F1</td>
<td>20-23</td>
</tr>
<tr>
<td>CDFBR</td>
<td>CONVERT FROM LOGICAL (32 to long BFP)</td>
<td>RRF-e F g^7 SP Db Xx</td>
<td>B391</td>
<td>20-23</td>
</tr>
<tr>
<td>CDFTR</td>
<td>CONVERT FROM LOGICAL (32 to long HFP)</td>
<td>RRE F g^7 Da</td>
<td>B953</td>
<td>20-24</td>
</tr>
<tr>
<td>CDGBR</td>
<td>CONVERT FROM LOGICAL (64 to long BFP)</td>
<td>RRF-e F g^7 SP Db Xx</td>
<td>B3A1</td>
<td>20-24</td>
</tr>
<tr>
<td>CDGLTR</td>
<td>CONVERT FROM LOGICAL (64 to long DFP)</td>
<td>RRF-e F g^7 Da Xx Xq</td>
<td>B952</td>
<td>20-24</td>
</tr>
<tr>
<td>CDPT</td>
<td>CONVERT FROM PACKED (to long DFP)</td>
<td>RSL-b PC g^5 A SP Ot Dg</td>
<td>EDAE</td>
<td>20-25</td>
</tr>
<tr>
<td>CDR</td>
<td>COMPARE (long HFP)</td>
<td>RR C g^7 Da</td>
<td>29</td>
<td>18-10</td>
</tr>
<tr>
<td>CDS</td>
<td>COMPARE DOUBLE AND SWAP (32)</td>
<td>RS-a C g^5 A SP $ ST B2</td>
<td>BB</td>
<td>7-127</td>
</tr>
<tr>
<td>CDG</td>
<td>COMPARE DOUBLE AND SWAP (64)</td>
<td>RSY-a C N g^5 A SP $ ST B2</td>
<td>EB3E</td>
<td>7-127</td>
</tr>
<tr>
<td>CDXTR</td>
<td>CONVERT FROM SIGNED PACKED (64 to long DFP)</td>
<td>RRE TF g^5 Da Dt Dg</td>
<td>B3F3</td>
<td>20-27</td>
</tr>
<tr>
<td>CDSY</td>
<td>COMPARE DOUBLE AND SWAP (32)</td>
<td>RSY-a C LD g^5 A SP $ ST B2</td>
<td>EB31</td>
<td>7-127</td>
</tr>
<tr>
<td>CDTR</td>
<td>COMPARE (long DFP)</td>
<td>RRE C g^7 Da Xx</td>
<td>20-29</td>
<td></td>
</tr>
<tr>
<td>CDRT</td>
<td>CONVERT FROM UNSIGNED PACKED (64 to long DFP)</td>
<td>RRE TF g^7 Da Xi</td>
<td>B3E4</td>
<td>20-29</td>
</tr>
<tr>
<td>CDZT</td>
<td>CONVERT FROM ZONED (to long DFP)</td>
<td>RSL ZF g^5 A SP Ot Dg</td>
<td>B3F2</td>
<td>20-29</td>
</tr>
<tr>
<td>CE</td>
<td>COMPARE (short HFP)</td>
<td>RX-a C g^5 A Da</td>
<td>B3F</td>
<td>19-17</td>
</tr>
<tr>
<td>CEB</td>
<td>COMPARE (short BFP)</td>
<td>RXE C g^5 A Db Xi</td>
<td>EDO9</td>
<td>19-17</td>
</tr>
<tr>
<td>CEBR</td>
<td>COMPARE (short BFP)</td>
<td>RRE C g^7 Db Xi</td>
<td>B309</td>
<td>19-17</td>
</tr>
<tr>
<td>CEDTR</td>
<td>COMPARE BIASED EXPONENT (long DFP)</td>
<td>RRE C TF g^7 Ot Xi</td>
<td>B3F4</td>
<td>20-22</td>
</tr>
<tr>
<td>CEFBR</td>
<td>CONVERT FROM FIXED (32 to short BFP)</td>
<td>RRE g^7 Db Xx</td>
<td>B394</td>
<td>19-19</td>
</tr>
<tr>
<td>CEFBRA</td>
<td>CONVERT FROM FIXED (32 to short BFP)</td>
<td>RRF-e F g^7 Db Xx</td>
<td>B394</td>
<td>19-19</td>
</tr>
<tr>
<td>CEFR</td>
<td>CONVERT FROM FIXED (32 to short HFP)</td>
<td>RRE g^7 Da</td>
<td>B384</td>
<td>18-11</td>
</tr>
<tr>
<td>CEGBR</td>
<td>CONVERT FROM FIXED (64 to short BFP)</td>
<td>RRE g^7 Db Xx</td>
<td>B3A4</td>
<td>19-19</td>
</tr>
<tr>
<td>CEGBRA</td>
<td>CONVERT FROM FIXED (64 to short BFP)</td>
<td>RRF-e F g^7 Db Xx</td>
<td>B3A4</td>
<td>19-19</td>
</tr>
<tr>
<td>CEGR</td>
<td>CONVERT FROM FIXED (64 to short HFP)</td>
<td>RRE g^7 Da</td>
<td>B3A4</td>
<td>19-19</td>
</tr>
<tr>
<td>CELFBR</td>
<td>CONVERT FROM LOGICAL (32 to short BFP)</td>
<td>RRF-e F g^7 Db Xx</td>
<td>B390</td>
<td>20-21</td>
</tr>
<tr>
<td>CELGBR</td>
<td>CONVERT FROM LOGICAL (64 to short BFP)</td>
<td>RRF-e F g^7 Db Xx</td>
<td>B3A0</td>
<td>20-21</td>
</tr>
<tr>
<td>CER</td>
<td>COMPARE (short HFP)</td>
<td>RR C g^7 Da</td>
<td>39</td>
<td>18-10</td>
</tr>
<tr>
<td>CEXTR</td>
<td>COMPARE BIASED EXPONENT (extended DFP)</td>
<td>RRE C TF g^5 Da</td>
<td>B3FC</td>
<td>20-22</td>
</tr>
<tr>
<td>CFC</td>
<td>COMPARE AND FORM CODEWORD</td>
<td>S C g^5 A SP II GM I1</td>
<td>B21A</td>
<td>7-120</td>
</tr>
<tr>
<td>CFD</td>
<td>CONVERT TO FIXED (long BFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B399</td>
<td>20-22</td>
</tr>
<tr>
<td>CFDRA</td>
<td>CONVERT TO FIXED (long BFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B399</td>
<td>20-22</td>
</tr>
<tr>
<td>CFD</td>
<td>CONVERT TO FIXED (long HFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B399</td>
<td>20-22</td>
</tr>
<tr>
<td>CDFR</td>
<td>CONVERT TO FIXED (long DFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B399</td>
<td>20-22</td>
</tr>
<tr>
<td>CFDRA</td>
<td>CONVERT TO FIXED (long DFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B399</td>
<td>20-22</td>
</tr>
<tr>
<td>CFI</td>
<td>COMPARE IMMEDIATE (32)</td>
<td>RIL-a C EI g^7 Da</td>
<td>C2D</td>
<td>7-117</td>
</tr>
<tr>
<td>CFXBR</td>
<td>CONVERT TO FIXED (extended BFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B39A</td>
<td>20-22</td>
</tr>
<tr>
<td>CFXBR</td>
<td>CONVERT TO FIXED (extended BFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B39A</td>
<td>20-22</td>
</tr>
<tr>
<td>CFXR</td>
<td>CONVERT TO FIXED (extended DFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B39A</td>
<td>20-22</td>
</tr>
<tr>
<td>CFXR</td>
<td>CONVERT TO FIXED (extended DFP to 32)</td>
<td>RRF-e C g^7 Da Xi Xx</td>
<td>B39A</td>
<td>20-22</td>
</tr>
<tr>
<td>CG</td>
<td>COMPARE (64)</td>
<td>RXY-a C N A g^5 Db Xi Xx</td>
<td>B320</td>
<td>20-11</td>
</tr>
<tr>
<td>CGDBR</td>
<td>CONVERT TO FIXED (long BFP to 64)</td>
<td>RRF-e C N g^7 Da Xi Xx</td>
<td>B3A9</td>
<td>20-22</td>
</tr>
<tr>
<td>CGDBRA</td>
<td>CONVERT TO FIXED (long BFP to 64)</td>
<td>RRF-e C F g^7 Da Xi Xx</td>
<td>B3A9</td>
<td>20-22</td>
</tr>
<tr>
<td>CGDR</td>
<td>CONVERT TO FIXED (long HFP to 64)</td>
<td>RRF-e C N g^7 Da</td>
<td>B3C9</td>
<td>18-11</td>
</tr>
<tr>
<td>CGDTR</td>
<td>CONVERT TO FIXED (long DFP to 64)</td>
<td>RRF-e C TF g^7 Ot Xi Xx</td>
<td>B3E1</td>
<td>20-28</td>
</tr>
<tr>
<td>CGDTRA</td>
<td>CONVERT TO FIXED (long DFP to 64)</td>
<td>RRF-e C F g^7 Ot Xi Xx</td>
<td>B3E1</td>
<td>20-28</td>
</tr>
<tr>
<td>CGEBR</td>
<td>CONVERT TO FIXED (short BFP to 64)</td>
<td>RRF-e C N g^7 Da Xi Xx</td>
<td>B3A8</td>
<td>18-22</td>
</tr>
<tr>
<td>CGEBR</td>
<td>CONVERT TO FIXED (short BFP to 64)</td>
<td>RRF-e C N g^7 Da Xi Xx</td>
<td>B3A8</td>
<td>18-22</td>
</tr>
<tr>
<td>CGER</td>
<td>CONVERT TO FIXED (short HFP to 64)</td>
<td>RRF-e C N g^7 Da</td>
<td>B3C8</td>
<td>18-22</td>
</tr>
<tr>
<td>CFG</td>
<td>COMPARE (64+32)</td>
<td>RXY-a C N A g^5 Da Xx</td>
<td>E330</td>
<td>7-117</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 3 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CGF</td>
<td>COMPARE IMMEDIATE (64-32)</td>
<td>RIL-a C Ei</td>
<td>C2C</td>
<td>7-717</td>
</tr>
<tr>
<td>CGFR</td>
<td>COMPARE (64-32)</td>
<td>RRE C N</td>
<td>B930</td>
<td>7-717</td>
</tr>
<tr>
<td>CGFRL</td>
<td>COMPARE RELATIVE LONG (64-32)</td>
<td>RIL-b C GE A* SP</td>
<td>B1</td>
<td>7-673</td>
</tr>
<tr>
<td>CGH</td>
<td>COMPARE HALFWORD (64-16)</td>
<td>RXY-a C GE A</td>
<td>E334</td>
<td>7-733</td>
</tr>
<tr>
<td>CGHI</td>
<td>COMPARE HALFWORD IMMEDIATE (64-16)</td>
<td>Ri-a C N</td>
<td>A7F</td>
<td>7-733</td>
</tr>
<tr>
<td>CGHRL</td>
<td>COMPARE HALFWORD RELATIVE LONG (64-32)</td>
<td>RIL-b C GE A* SP</td>
<td>B1</td>
<td>7-673</td>
</tr>
<tr>
<td>CGHSI</td>
<td>COMPARE IMMEDIATE (64-16)</td>
<td>SIL C GE A</td>
<td>E583</td>
<td>7-733</td>
</tr>
<tr>
<td>CGIB</td>
<td>COMPARE IMMEDIATE AND BRANCH (64-8)</td>
<td>RIS GE o*</td>
<td>BF</td>
<td>7-393</td>
</tr>
<tr>
<td>CGJU</td>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (64-8)</td>
<td>RIE-c GE o*</td>
<td>E7C7</td>
<td>7-733</td>
</tr>
<tr>
<td>CGIT</td>
<td>COMPARE IMMEDIATE AND TRAP (64-16)</td>
<td>RIE-a GE Dc</td>
<td>EC70</td>
<td>7-732</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Memonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CGR</td>
<td>COMPARE (64)</td>
<td>RRE C N</td>
<td>B920</td>
<td>7-717</td>
</tr>
<tr>
<td>CGRB</td>
<td>COMPARE AND BRANCH (64)</td>
<td>RRS GE o*</td>
<td>ECE4</td>
<td>7-718</td>
</tr>
<tr>
<td>CGRL</td>
<td>COMPARE RELATIVE LONG (64)</td>
<td>RIL-b C GE A* SP</td>
<td>C68</td>
<td>7-718</td>
</tr>
<tr>
<td>CGRT</td>
<td>COMPARE AND TRAP (64)</td>
<td>RRE C N Dc</td>
<td>E960</td>
<td>7-732</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Memonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CGXBR</td>
<td>CONVERT TO FIXED (extended BFP to 64)</td>
<td>RRF-e C N o* SP Db Xi Xx</td>
<td>B3AA</td>
<td>19-22</td>
</tr>
<tr>
<td>CGXBRa</td>
<td>CONVERT TO FIXED (extended BFP to 64)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B3AA</td>
<td>19-22</td>
</tr>
<tr>
<td>CGXR</td>
<td>CONVERT TO FIXED (extended HFP to 64)</td>
<td>RRF-e C N o* SP Da</td>
<td>B3CA</td>
<td>18-11</td>
</tr>
<tr>
<td>CGXTR</td>
<td>CONVERT TO FIXED (extended DFP to 64)</td>
<td>RRF-e C TF o* SP Dt Xi Xx</td>
<td>B3E9</td>
<td>20-28</td>
</tr>
<tr>
<td>CGXTRA</td>
<td>CONVERT TO FIXED (extended DFP to 64)</td>
<td>RRF-e C F o* SP Dt Xi Xx</td>
<td>B3E9</td>
<td>20-29</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Memonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CH</td>
<td>COMPARE HALFWORD (32-16)</td>
<td>RX-a C A</td>
<td>B1</td>
<td>7-733</td>
</tr>
<tr>
<td>CHF</td>
<td>COMPARE HIGH (32)</td>
<td>RXY-a C HW A</td>
<td>E3CD</td>
<td>7-734</td>
</tr>
<tr>
<td>CHHR</td>
<td>COMPARE HALFWORD IMMEDIATE (32-16)</td>
<td>SIL C GE A</td>
<td>E554</td>
<td>7-733</td>
</tr>
<tr>
<td>CHISI</td>
<td>COMPARE HIGH (32)</td>
<td>Ri-a C C</td>
<td>A7E</td>
<td>7-733</td>
</tr>
<tr>
<td>CHL</td>
<td>COMPARE HALFWORD RELATIVE LONG (32-16)</td>
<td>RIL-b C GE A* SP</td>
<td>B1</td>
<td>7-693</td>
</tr>
<tr>
<td>CHSI</td>
<td>COMPARE HIGH (32)</td>
<td>SIL C GE A</td>
<td>E55C</td>
<td>7-733</td>
</tr>
<tr>
<td>CHY</td>
<td>COMPARE HALFWORD IMMEDIATE (32-16)</td>
<td>RX-Y-a C LD A</td>
<td>E379</td>
<td>7-733</td>
</tr>
<tr>
<td>CIB</td>
<td>COMPARE IMMEDIATE AND BRANCH (32-8)</td>
<td>RIS GE o*</td>
<td>ECFE</td>
<td>7-719</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Memonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CH</td>
<td>COMPARE HALFWORD HIGH (32)</td>
<td>RXY-a C HW A</td>
<td>B3</td>
<td>7-733</td>
</tr>
<tr>
<td>CIJ</td>
<td>COMPARE IMMEDIATE HIGH (32)</td>
<td>RIE-c GE o* SP IC</td>
<td>E7C4</td>
<td>7-732</td>
</tr>
<tr>
<td>CIT</td>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (32-8)</td>
<td>RIE-a GE Dc</td>
<td>EC72</td>
<td>7-732</td>
</tr>
<tr>
<td>CJKSM</td>
<td>CHECKSUM</td>
<td>RRE C o* A SP IC</td>
<td>B241</td>
<td>7-74</td>
</tr>
<tr>
<td>CL</td>
<td>COMPARE LOGICAL (32)</td>
<td>RX-a C A</td>
<td>B3</td>
<td>7-735</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Memonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLC</td>
<td>COMPARE LOGICAL (character)</td>
<td>SS-a C A</td>
<td>B1</td>
<td>7-735</td>
</tr>
<tr>
<td>CLCL</td>
<td>COMPARE LOGICAL LONG</td>
<td>RR C o* A SP II</td>
<td>B1</td>
<td>7-735</td>
</tr>
<tr>
<td>CLCLE</td>
<td>COMPARE LOGICAL LONG EXTENDED</td>
<td>RS-a C o* A SP IC</td>
<td>A9</td>
<td>7-734</td>
</tr>
<tr>
<td>CLCLU</td>
<td>COMPARE LOGICAL LONG UNICODE</td>
<td>RSY-a C E2 o* A SP IC</td>
<td>E8BF</td>
<td>7-746</td>
</tr>
<tr>
<td>CLFDBR</td>
<td>CONVERT TO LOGICAL (long BFP to 32)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B9D9</td>
<td>19-25</td>
</tr>
<tr>
<td>CLFDTR</td>
<td>CONVERT TO LOGICAL (long DFP to 32)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B943</td>
<td>20-31</td>
</tr>
<tr>
<td>CLFEBR</td>
<td>CONVERT TO LOGICAL (short BFP to 32)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B939</td>
<td>19-25</td>
</tr>
<tr>
<td>CLFHISI</td>
<td>COMPARE LOGICAL IMMEDIATE (32-16)</td>
<td>SIL C GE A</td>
<td>E55D</td>
<td>7-735</td>
</tr>
<tr>
<td>CLF</td>
<td>COMPARE LOGICAL IMMEDIATE (32)</td>
<td>RIL-a C Ei</td>
<td>C2F</td>
<td>7-735</td>
</tr>
<tr>
<td>CLFIT</td>
<td>COMPARE LOGICAL IMMEDIATE AND TRAP (32-16)</td>
<td>RIE-a GE Dc</td>
<td>EC73</td>
<td>7-739</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Memonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLFXBR</td>
<td>CONVERT TO LOGICAL (extended BFP to 32)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B39E</td>
<td>19-25</td>
</tr>
<tr>
<td>CLFXTA</td>
<td>CONVERT TO LOGICAL (extended DFP to 32)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B94B</td>
<td>20-31</td>
</tr>
<tr>
<td>CLG</td>
<td>COMPARE LOGICAL (64)</td>
<td>RXY-a C N A</td>
<td>B3</td>
<td>7-735</td>
</tr>
<tr>
<td>CLGDBR</td>
<td>CONVERT TO LOGICAL (long BFP to 64)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B3AD</td>
<td>19-25</td>
</tr>
<tr>
<td>CLGDT</td>
<td>CONVERT TO LOGICAL (long DFP to 64)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B942</td>
<td>20-31</td>
</tr>
<tr>
<td>CLGBR</td>
<td>CONVERT TO LOGICAL (short BFP to 64)</td>
<td>RRF-e C F o* SP Db Xi Xx</td>
<td>B3AC</td>
<td>19-25</td>
</tr>
<tr>
<td>CLGF</td>
<td>COMPARE LOGICAL (64-32)</td>
<td>RRF-e C N A</td>
<td>E331</td>
<td>7-735</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 4 of 22)
Figure B-2. Instructions Arranged by Mnemonic (Part 5 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>CSODTR</td>
<td>CONVTO</td>
<td>(long DFP to 64)</td>
<td>RRF-d TF 0^2 SP Dt</td>
<td>B3E3</td>
</tr>
<tr>
<td>CSG</td>
<td>COMPARE AND SWAP (64)</td>
<td>RSY-a C N 0^2 A SP $ ST</td>
<td>BE30</td>
<td>7-127</td>
</tr>
<tr>
<td>CSP</td>
<td>COMPARE AND SWAP AND PURGE (32)</td>
<td>RRE C P A SP $ ST</td>
<td>R6</td>
<td>B520</td>
</tr>
<tr>
<td>CSPG</td>
<td>COMPARE AND SWAP AND PURGE (64)</td>
<td>RRE C DE P A SP $ ST</td>
<td>R6</td>
<td>B98A</td>
</tr>
<tr>
<td>CSST</td>
<td>COMPARE AND SWAP AND STORE</td>
<td>SSF C CS 0^2 A SP $ GM ST</td>
<td>B2</td>
<td>C2</td>
</tr>
<tr>
<td>CSXTR</td>
<td>CONVERT TO SIGNED PACKED (extended DFP to 128)</td>
<td>RRF-d TF 0^15 SP Dt</td>
<td>B3EB</td>
<td>20-34</td>
</tr>
<tr>
<td>CSY</td>
<td>COMPARE AND SWAP (32)</td>
<td>RSY-a C LD 0^2 A SP $ ST</td>
<td>BE14</td>
<td>7-127</td>
</tr>
<tr>
<td>CU12</td>
<td>CONVERT UTF-8 TO UTF-16</td>
<td>RRF-c C 0^3 A SP IC ST</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CU14</td>
<td>CONVERT UTF-8 TO UTF-32</td>
<td>RRF-c C E3 0^3 A SP IC ST</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CU21</td>
<td>CONVERT UTF-16 TO UTF-8</td>
<td>RRF-c C 0^3 A SP IC ST</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CU24</td>
<td>CONVERT UTF-16 TO UTF-32</td>
<td>RRF-c C E3 0^3 A SP IC ST</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CU41</td>
<td>CONVERT UTF-32 TO UTF-8</td>
<td>RRF-c C 0^3 A SP IC ST</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CU42</td>
<td>CONVERT UTF-32 TO UTF-16</td>
<td>RRF-c C 0^3 A SP IC ST</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CUDTR</td>
<td>CONVERT TO UNSIGNED PACKED (long DFP to 64)</td>
<td>RRE TF 0^2 SP Dt</td>
<td>B3E2</td>
<td>20-34</td>
</tr>
<tr>
<td>CUSE</td>
<td>COMPARE UNTIL SUBSTRING EQUAL</td>
<td>RRE C 0^2 A SP II GM</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CUTFU</td>
<td>CONVERT UTF-8 TO UNICODE</td>
<td>RRF-c C 0^3 A SP IC ST</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CUUTF</td>
<td>CONVERT UNICODE TO UTF-8</td>
<td>RRF-c C 0^3 A SP IC ST</td>
<td>R1</td>
<td>R6</td>
</tr>
<tr>
<td>CUXTR</td>
<td>CONVERT TO UNSIGNED PACKED (extended DFP to 128)</td>
<td>RRF TF 0^2 SP Dt</td>
<td>B3EA</td>
<td>20-34</td>
</tr>
<tr>
<td>CVB</td>
<td>CONVERT TO BINARY (32)</td>
<td>RX-a 0^2 A Dg IK</td>
<td>B6</td>
<td>4F</td>
</tr>
<tr>
<td>CVBG</td>
<td>CONVERT TO BINARY (64)</td>
<td>RXY-a N 0^2 A Dg IK</td>
<td>B6</td>
<td>E30E</td>
</tr>
<tr>
<td>CVBY</td>
<td>CONVERT TO BINARY (32)</td>
<td>RXY-a LD 0^2 A Dg IK</td>
<td>B6</td>
<td>E306</td>
</tr>
<tr>
<td>CVD</td>
<td>CONVERT TO DECIMAL (32)</td>
<td>RX-a 0^2 A</td>
<td>B5</td>
<td>4E</td>
</tr>
<tr>
<td>CVDG</td>
<td>CONVERT TO DECIMAL (64)</td>
<td>RXY-a N 0^2 A</td>
<td>ST</td>
<td>B5</td>
</tr>
<tr>
<td>CVDY</td>
<td>CONVERT TO DECIMAL (32)</td>
<td>RXY-a LD 0^2 A</td>
<td>ST</td>
<td>B5</td>
</tr>
<tr>
<td>CXBR</td>
<td>COMPARE (extended BFP)</td>
<td>RRE C 0^2 SP Db Xi</td>
<td>B349</td>
<td>19-17</td>
</tr>
<tr>
<td>CXFBFR</td>
<td>CONVERT FROM FIXED (32 to extended BFP)</td>
<td>RRE 0^2 SP Db</td>
<td>B396</td>
<td>19-19</td>
</tr>
<tr>
<td>CXFBRA</td>
<td>CONVERT FROM FIXED (32 to extended BFP)</td>
<td>RRF-e F 0^2 SP Db</td>
<td>B396</td>
<td>19-19</td>
</tr>
<tr>
<td>CXFR</td>
<td>CONVERT FROM FIXED (32 to extended HFP)</td>
<td>RRE 0^2 SP Da</td>
<td>B396</td>
<td>18-11</td>
</tr>
<tr>
<td>CXXFR</td>
<td>CONVERT FROM FIXED (32 to extended DFP)</td>
<td>RRF-e F 0^2 SP Da</td>
<td>B399</td>
<td>20-23</td>
</tr>
<tr>
<td>CXXXBR</td>
<td>CONVERT FROM FIXED (64 to extended BFP)</td>
<td>RRE 0^2 SP Db</td>
<td>B392</td>
<td>19-21</td>
</tr>
<tr>
<td>CXXGBR</td>
<td>CONVERT FROM FIXED (64 to extended BFP)</td>
<td>RRF-e F 0^2 SP Db</td>
<td>B392</td>
<td>19-21</td>
</tr>
<tr>
<td>CXXGR</td>
<td>CONVERT FROM FIXED (64 to extended DFP)</td>
<td>RRE N 0^2 SP Da</td>
<td>B3C6</td>
<td>18-11</td>
</tr>
<tr>
<td>CXXGTR</td>
<td>CONVERT FROM FIXED (64 to extended DFP)</td>
<td>RRE TF 0^2 SP Da</td>
<td>B3F9</td>
<td>20-23</td>
</tr>
<tr>
<td>CXXGTRA</td>
<td>CONVERT FROM FIXED (64 to extended DFP)</td>
<td>RRF-e F 0^2 SP Da</td>
<td>B3F9</td>
<td>20-23</td>
</tr>
<tr>
<td>CXLFBFR</td>
<td>CONVERT FROM LOGICAL (32 to extended BFP)</td>
<td>RRF-e F 0^2 SP Db</td>
<td>B392</td>
<td>19-21</td>
</tr>
<tr>
<td>CXLFLTR</td>
<td>CONVERT FROM LOGICAL (32 to extended DFP)</td>
<td>RRF-e F 0^2 SP Db</td>
<td>B395B</td>
<td>20-24</td>
</tr>
<tr>
<td>CXLGBR</td>
<td>CONVERT FROM LOGICAL (64 to extended BFP)</td>
<td>RRF-e F 0^2 SP Db</td>
<td>B3A2</td>
<td>19-21</td>
</tr>
<tr>
<td>CXLGTR</td>
<td>CONVERT FROM LOGICAL (64 to extended DFP)</td>
<td>RRF-e F 0^2 SP Db</td>
<td>B3A2</td>
<td>19-21</td>
</tr>
<tr>
<td>CXLT</td>
<td>CONVERT FROM LOGICAL (64 to extended DFP)</td>
<td>RRF-e F 0^2 SP Db</td>
<td>B3A2</td>
<td>20-24</td>
</tr>
<tr>
<td>CXPT</td>
<td>CONVERT FROM PACKED (to extended DFP)</td>
<td>RSL-b PC 0^2 SA SP Da</td>
<td>B6</td>
<td>EDAF</td>
</tr>
<tr>
<td>CXR</td>
<td>COMPARE (extended HFP)</td>
<td>RX-a 0^2 SP Da</td>
<td>B369</td>
<td>18-10</td>
</tr>
<tr>
<td>CXSTR</td>
<td>CONVERT FROM SIGNED PACKED (128 to extended DFP)</td>
<td>RRE TF 0^2 SP Da</td>
<td>B3FB</td>
<td>20-27</td>
</tr>
<tr>
<td>CXTR</td>
<td>COMPARE (extended DFP)</td>
<td>RRE C TF 0^2 SP Da</td>
<td>B3EC</td>
<td>20-20</td>
</tr>
<tr>
<td>CXDTR</td>
<td>CONVERT FROM UNSIGNED PACKED (128 to extended DFP)</td>
<td>RRE TF 0^2 SP Dg</td>
<td>B3FA</td>
<td>20-27</td>
</tr>
<tr>
<td>CXZT</td>
<td>CONVERT FROM SIGNED PACKED (extended DFP)</td>
<td>RSL ZF 0^2 A SP Dg</td>
<td>B5</td>
<td>EDAB</td>
</tr>
<tr>
<td>CY</td>
<td>COMPARE (32)</td>
<td>RXY-a C LD 0^2 A</td>
<td>B6</td>
<td>E359</td>
</tr>
<tr>
<td>CZDT</td>
<td>CONVERT TO ZONED (from long DFP)</td>
<td>RSL C ZF 0^2 A SP ST</td>
<td>B6</td>
<td>EDAF</td>
</tr>
<tr>
<td>CZXT</td>
<td>CONVERT TO ZONED (from extended DFP)</td>
<td>RSL C ZF 0^2 A SP ST</td>
<td>B6</td>
<td>EDAF</td>
</tr>
<tr>
<td>D</td>
<td>DIVIDE (32÷64)</td>
<td>RX-a 0^2 A SP IK</td>
<td>B6</td>
<td>5D</td>
</tr>
<tr>
<td>DD</td>
<td>DIVIDE (long HFP)</td>
<td>RX-a 0^2 A Da EU EO FK</td>
<td>B6</td>
<td>E1D</td>
</tr>
<tr>
<td>DDB</td>
<td>DIVIDE (long BFP)</td>
<td>RXE 0^2 A Db Xz Xz Xo Xx</td>
<td>B6</td>
<td>E1D</td>
</tr>
<tr>
<td>DDBR</td>
<td>DIVIDE (long BFP)</td>
<td>RRE 0^2 A Db Xz Xz Xo Xx</td>
<td>B31D</td>
<td>19-27</td>
</tr>
<tr>
<td>DDR</td>
<td>DIVIDE (long HFP)</td>
<td>RR 0^2 A Da EU EO FK</td>
<td>B6</td>
<td>E1D</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 6 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>DDTR</td>
<td>DIVIDE (long DFP)</td>
<td>RRF-a TF $d^*$ DX XZ Xo Xx</td>
<td>B3D1</td>
<td>20-36</td>
</tr>
<tr>
<td>DDTRA</td>
<td>DIVIDE (long DFP)</td>
<td>RRF-a F $d^*$ Da EU EO FK</td>
<td>B3D1</td>
<td>20-36</td>
</tr>
<tr>
<td>DE</td>
<td>DIVIDE (short HFP)</td>
<td>RX-a $d^*$ A Db Xi Xz Xo Xx Xx</td>
<td>B2</td>
<td>7-12</td>
</tr>
<tr>
<td>DEB</td>
<td>DIVIDE (short BFP)</td>
<td>RXE $d^*$ Db Xi Xz Xo Xx Xx</td>
<td>B2</td>
<td>19-27</td>
</tr>
<tr>
<td>DEBR</td>
<td>DIVIDE (short BFP)</td>
<td>RRE $d^*$ Db Xi Xz Xo Xx Xx</td>
<td>B30D</td>
<td>19-27</td>
</tr>
<tr>
<td>DER</td>
<td>DIVIDE (short HFP)</td>
<td>RR $d^*$ Da EU EO FK</td>
<td>B</td>
<td>3D</td>
</tr>
<tr>
<td>DIDBR</td>
<td>DIVIDE TO INTEGER (long BFP)</td>
<td>RRF-b C $d^*$ Da EU EO FK</td>
<td>B3D5</td>
<td>19-28</td>
</tr>
<tr>
<td>DIEBR</td>
<td>DIVIDE TO INTEGER (short BFP)</td>
<td>RRF-b C $d^*$ Da EU EO FK</td>
<td>B3D5</td>
<td>19-28</td>
</tr>
<tr>
<td>DL</td>
<td>DIVIDE LOGICAL (32→64)</td>
<td>RXY-a N $a^*$ A Db Xi Xz Xo Xx Xx</td>
<td>B2</td>
<td>7-121</td>
</tr>
<tr>
<td>DLAB</td>
<td>DIVIDE LOGICAL (short HFP)</td>
<td>RX-a $a^*$ A Db Xi Xz Xo Xx Xx</td>
<td>B2</td>
<td>7-121</td>
</tr>
<tr>
<td>DER</td>
<td>DIVIDE (short HFP)</td>
<td>RR $d^*$ Da EU EO FK</td>
<td>B3D1</td>
<td>19-27</td>
</tr>
<tr>
<td>DXBR</td>
<td>DIVIDE (extended BFP)</td>
<td>RRE N $d^*$ A Db Xi Xz Xo Xx Xx</td>
<td>B34D</td>
<td>19-27</td>
</tr>
<tr>
<td>DXR</td>
<td>DIVIDE (extended HFP)</td>
<td>RRE $d^*$ A Da EU EO FK</td>
<td>B2D</td>
<td>18-12</td>
</tr>
<tr>
<td>EX</td>
<td>EXECUTE</td>
<td>RX-a $d^*$ Da EU EO FK</td>
<td>B2E</td>
<td>19-27</td>
</tr>
<tr>
<td>EXR</td>
<td>EXECUTE</td>
<td>RX-a $d^*$ Da EU EO FK</td>
<td>B2E</td>
<td>19-27</td>
</tr>
<tr>
<td>FIDB</td>
<td>LOAD FP INTEGER (long BFP)</td>
<td>RRF-e $d^*$ Db Xi Xx</td>
<td>B3D5</td>
<td>19-32</td>
</tr>
<tr>
<td>FIDR</td>
<td>LOAD FP INTEGER (long HFP)</td>
<td>RRE $d^*$ Da EU EO FK</td>
<td>B3D7</td>
<td>18-15</td>
</tr>
<tr>
<td>FIDTR</td>
<td>LOAD FP INTEGER (long DFP)</td>
<td>RRF-e TF $d^*$ Da EU EO FK</td>
<td>B3D7</td>
<td>20-41</td>
</tr>
<tr>
<td>FIEBR</td>
<td>LOAD FP INTEGER (short BFP)</td>
<td>RRF-e $d^*$ Db Xi Xx</td>
<td>B357</td>
<td>19-32</td>
</tr>
<tr>
<td>FIEBRA</td>
<td>LOAD FP INTEGER (short BFP)</td>
<td>RRF-e $d^*$ Db Xi Xx</td>
<td>B357</td>
<td>19-32</td>
</tr>
<tr>
<td>FIER</td>
<td>LOAD FP INTEGER (short HFP)</td>
<td>RRE $d^*$ Da EU EO FK</td>
<td>B3D7</td>
<td>18-15</td>
</tr>
<tr>
<td>FIXB</td>
<td>LOAD FP INTEGER (long BFP)</td>
<td>RRF-e $d^*$ Db Xi Xx</td>
<td>B3D7</td>
<td>19-32</td>
</tr>
<tr>
<td>FIXR</td>
<td>LOAD FP INTEGER (long HFP)</td>
<td>RRE $d^*$ Db Xi Xx</td>
<td>B3D7</td>
<td>19-32</td>
</tr>
<tr>
<td>FIXBRA</td>
<td>LOAD FP INTEGER (long BFP)</td>
<td>RRF-e $d^*$ Db Xi Xx</td>
<td>B3D7</td>
<td>19-32</td>
</tr>
<tr>
<td>FIXX</td>
<td>LOAD FP INTEGER (long HFP)</td>
<td>RRE $d^*$ Db Xi Xx</td>
<td>B3D7</td>
<td>19-32</td>
</tr>
<tr>
<td>FIXTR</td>
<td>LOAD FP INTEGER (long BFP)</td>
<td>RRF-e TF $d^*$ Db Xi Xx</td>
<td>B3D7</td>
<td>19-32</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 7 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLOGR</td>
<td>FIND LEFTMOST ONE</td>
<td>RRE C Ei SP</td>
<td>B983</td>
<td>7-219</td>
</tr>
<tr>
<td>HDR</td>
<td>HALVE (long HFP)</td>
<td>RR a79 Da EU</td>
<td>24</td>
<td>18-13</td>
</tr>
<tr>
<td>HER</td>
<td>HALVE (short HFP)</td>
<td>RR a79 Da EU</td>
<td>34</td>
<td>18-13</td>
</tr>
<tr>
<td>HSCH</td>
<td>HALT SUBCHANNEL</td>
<td>S C P OP c GS</td>
<td>B231</td>
<td>14-6</td>
</tr>
<tr>
<td>IAC</td>
<td>INSERT ADDRESS SPACE CONTROL</td>
<td>RRE C Q SO</td>
<td>B224</td>
<td>10-28</td>
</tr>
<tr>
<td>IC</td>
<td>INSERT CHARACTER</td>
<td>RX-a A</td>
<td>B3</td>
<td>7-219</td>
</tr>
<tr>
<td>ICM</td>
<td>INSERT CHARACTERS UNDER MASK (low)</td>
<td>RS-b C A</td>
<td>B2</td>
<td>7-220</td>
</tr>
<tr>
<td>ICMI</td>
<td>INSERT CHARACTERS UNDER MASK (high)</td>
<td>RSY-b C N A</td>
<td>B2</td>
<td>7-220</td>
</tr>
<tr>
<td>ICMY</td>
<td>INSERT CHARACTERS UNDER MASK (low)</td>
<td>RSY-b C LD A</td>
<td>B2</td>
<td>7-220</td>
</tr>
<tr>
<td>ICY</td>
<td>INSERT CHARACTER</td>
<td>RXY-a LD A</td>
<td>B3</td>
<td>7-219</td>
</tr>
<tr>
<td>IDTE</td>
<td>INVALIDATE DAT TABLE ENTRY</td>
<td>RRF-b U DE P A' SP S</td>
<td>B93E</td>
<td>10-31</td>
</tr>
<tr>
<td>IEDTR</td>
<td>INSERT BIASED EXPONENT (64 to long DFP)</td>
<td>RRF-b TF a79 Dt</td>
<td>B3F6</td>
<td>20-39</td>
</tr>
<tr>
<td>IEXTR</td>
<td>INSERT BIASED EXPONENT (64 to extended DFP)</td>
<td>RRF-b TF a79 SP Dt</td>
<td>B3FE</td>
<td>20-39</td>
</tr>
<tr>
<td>IIHF</td>
<td>INSERT IMMEDIATE (high)</td>
<td>RIL-a EI</td>
<td>C08</td>
<td>7-221</td>
</tr>
<tr>
<td>IIHH</td>
<td>INSERT IMMEDIATE (high high)</td>
<td>RIL-a N</td>
<td>A50</td>
<td>7-221</td>
</tr>
<tr>
<td>IIHL</td>
<td>INSERT IMMEDIATE (high low)</td>
<td>RIL-a N</td>
<td>A51</td>
<td>7-221</td>
</tr>
<tr>
<td>IIIF</td>
<td>INSERT IMMEDIATE (low)</td>
<td>RIL-a EI</td>
<td>C09</td>
<td>7-221</td>
</tr>
<tr>
<td>IIIH</td>
<td>INSERT IMMEDIATE (high low)</td>
<td>RIL-a N</td>
<td>A52</td>
<td>7-221</td>
</tr>
<tr>
<td>IILL</td>
<td>INSERT IMMEDIATE (low low)</td>
<td>RIL-a N</td>
<td>A53</td>
<td>7-221</td>
</tr>
<tr>
<td>IPK</td>
<td>INSERT PSW KEY</td>
<td>R Rp A SO G2</td>
<td>B20B</td>
<td>10-29</td>
</tr>
<tr>
<td>IPM</td>
<td>INSERT PROGRAM MASK</td>
<td>RRE</td>
<td>B222</td>
<td>7-221</td>
</tr>
<tr>
<td>IPTE</td>
<td>INVALIDATE PAGE TABLE ENTRY</td>
<td>RRF-a P A' SP S</td>
<td>B221</td>
<td>10-36</td>
</tr>
<tr>
<td>ISKE</td>
<td>INSERT STORAGE KEY EXTENDED</td>
<td>RRE P A'x</td>
<td>B229</td>
<td>10-29</td>
</tr>
<tr>
<td>IVSK</td>
<td>INSERT VIRTUAL STORAGE KEY</td>
<td>RRE Q A'x SO</td>
<td>R2</td>
<td>B233</td>
</tr>
<tr>
<td>KDB</td>
<td>COMPARE AND SIGNAL (long BFP)</td>
<td>RXE C a79 A Db Xi</td>
<td>B3</td>
<td>19-18</td>
</tr>
<tr>
<td>KDBR</td>
<td>COMPARE AND SIGNAL (long DFP)</td>
<td>RRE C TF a79 Dt Xi</td>
<td>B3E0</td>
<td>20-22</td>
</tr>
<tr>
<td>KDT</td>
<td>COMPARE AND SIGNAL (short BFP)</td>
<td>RXE C a79 A Db Xi</td>
<td>B3</td>
<td>19-18</td>
</tr>
<tr>
<td>KEB</td>
<td>COMPARE AND SIGNAL (short DFP)</td>
<td>RRE C a79 A Db Xi</td>
<td>B3E0</td>
<td>19-18</td>
</tr>
<tr>
<td>KIMD</td>
<td>COMPUTE INTERMEDIATE MESSAGE DIGEST</td>
<td>RRE C MS a79 A SP IC GM 11 ST R3</td>
<td>B3E8</td>
<td>7-165</td>
</tr>
<tr>
<td>KLMN</td>
<td>COMPUTE LAST MESSAGE DIGEST</td>
<td>RRE C MS a79 A SP IC GM 11 ST R3</td>
<td>R3</td>
<td>B93F</td>
</tr>
<tr>
<td>KM</td>
<td>CIPHER MESSAGE</td>
<td>RRE C MS a79 A SP IC GM 11 ST R3</td>
<td>R3</td>
<td>B92E</td>
</tr>
<tr>
<td>KMAC</td>
<td>COMPUTE MESSAGE AUTHENTICATION CODE</td>
<td>RRE C MS a79 A SP IC GM 11 ST R3</td>
<td>R3</td>
<td>B91E</td>
</tr>
<tr>
<td>KMC</td>
<td>CIPHER MESSAGE WITH CHAINING</td>
<td>RRE C MS a79 A SP IC GM 11 ST R3</td>
<td>R3</td>
<td>R3</td>
</tr>
<tr>
<td>KMCRI</td>
<td>CIPHER MESSAGE WITH COUNTER</td>
<td>RRF-b C M4 a79 A SP IC GM 11 ST R3, R3, R3</td>
<td>B92D</td>
<td>7-90</td>
</tr>
<tr>
<td>KMF</td>
<td>CIPHER MESSAGE WITH CIPHER FEEDBACK</td>
<td>RRE C M4 a79 A SP IC GM 11 ST R3, R3</td>
<td>R3</td>
<td>R3</td>
</tr>
<tr>
<td>KMO</td>
<td>CIPHER MESSAGE WITH OUTPUT FEEDBACK</td>
<td>RRE C M4 a79 A SP IC GM 11 ST R3</td>
<td>R3</td>
<td>B92B</td>
</tr>
<tr>
<td>KBXR</td>
<td>COMPARE AND SIGNAL (extended BFP)</td>
<td>RRE C a79 SP Db Xi</td>
<td>B348</td>
<td>19-18</td>
</tr>
<tr>
<td>KXTR</td>
<td>COMPARE AND SIGNAL (extended DFP)</td>
<td>RRE C TF a79 SP Dt Xi</td>
<td>B3E8</td>
<td>20-22</td>
</tr>
<tr>
<td>L</td>
<td>LOAD (32)</td>
<td>RX-a A</td>
<td>B3</td>
<td>7-221</td>
</tr>
<tr>
<td>LA</td>
<td>LOAD ADDRESS</td>
<td>RX-a</td>
<td>41</td>
<td>7-223</td>
</tr>
<tr>
<td>LAA</td>
<td>LOAD AND ADD (32)</td>
<td>RSY-a C IA a79 A SP IF E</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LAAG</td>
<td>LOAD AND ADD (64)</td>
<td>RSY-a C IA a79 A SP IF E</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LAAL</td>
<td>LOAD AND ADD LOGICAL (32)</td>
<td>RSY-a C IA a79 A SP E</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LAALG</td>
<td>LOAD AND ADD LOGICAL (64)</td>
<td>RSY-a C IA a79 A SP E</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LAE</td>
<td>LOAD ADDRESS EXTENDED</td>
<td>RX-a a79</td>
<td>U, BP</td>
<td>51</td>
</tr>
<tr>
<td>LAEY</td>
<td>LOAD ADDRESS EXTENDED</td>
<td>RXY-a GE a79</td>
<td>U, BP</td>
<td>E375</td>
</tr>
<tr>
<td>LAM</td>
<td>LOAD ACCESS MULTIPLE</td>
<td>RS-a a79 A SP</td>
<td>UB</td>
<td>9A</td>
</tr>
<tr>
<td>LAMY</td>
<td>LOAD ACCESS MULTIPLE</td>
<td>RSY-a LD a79 A SP</td>
<td>UB</td>
<td>E9BA</td>
</tr>
<tr>
<td>LAN</td>
<td>LOAD AND ADD (32)</td>
<td>RSY-a C IA a79 A SP E</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LARG</td>
<td>LOAD AND ADD (64)</td>
<td>RSY-a C IA a79 A SP E</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LAO</td>
<td>LOAD AND OR (32)</td>
<td>RSY-a C IA a79 A SP E</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LAOG</td>
<td>LOAD AND OR (64)</td>
<td>RSY-a C IA a79 A SP E</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>LARL</td>
<td>LOAD ADDRESS RELATIVE LONG</td>
<td>RIL-b N3</td>
<td>C00</td>
<td>7-224</td>
</tr>
<tr>
<td>LASP</td>
<td>LOAD ADDRESS SPACE PARAMETERS</td>
<td>SSE C P A' SP SO</td>
<td>B3</td>
<td>E500</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 8 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LAT</td>
<td>LOAD AND TRAP (32L→32)</td>
<td>RXY-a LT A Dc</td>
<td>B2</td>
<td>E39F 7-228</td>
</tr>
<tr>
<td>LAX</td>
<td>LOAD AND EXCLUSIVE OR (32)</td>
<td>RSY-a C IA A SP £ ST B2</td>
<td>EBF 7-226</td>
<td></td>
</tr>
<tr>
<td>LAXG</td>
<td>LOAD AND EXCLUSIVE OR (64)</td>
<td>RSY-a C IA A SP £ ST B2</td>
<td>EBE 7-227</td>
<td></td>
</tr>
<tr>
<td>LAY</td>
<td>LOAD ADDRESS</td>
<td>RXY-a LD</td>
<td>B2</td>
<td>E371 7-223</td>
</tr>
<tr>
<td>LB</td>
<td>LOAD BYTE (32→8)</td>
<td>RXY-a LD A</td>
<td>B2</td>
<td>E376 7-229</td>
</tr>
<tr>
<td>LBH</td>
<td>LOAD BYTE HIGH (32→8)</td>
<td>RXY-a HW A</td>
<td>B2</td>
<td>E3CO 7-229</td>
</tr>
<tr>
<td>LBR</td>
<td>LOAD BYTE (32→8)</td>
<td>RRE EI</td>
<td>B2</td>
<td>B926 7-229</td>
</tr>
<tr>
<td>LCB</td>
<td>LOAD COUNT TO BLOCK BOUNDARY</td>
<td>RXE CV SP</td>
<td>B2</td>
<td>E727 7-230</td>
</tr>
<tr>
<td>LCBBR</td>
<td>LOAD COUNT TO BLOCK BOUNDARY (long)</td>
<td>RRE CV SP</td>
<td>B2</td>
<td>E728 7-230</td>
</tr>
<tr>
<td>LCBFR</td>
<td>LOAD COMPLEMENT (long)</td>
<td>RRE FS</td>
<td>B2</td>
<td>EBE7 7-227</td>
</tr>
<tr>
<td>LCF</td>
<td>LOAD CONTROL</td>
<td>RR CE IF</td>
<td>B2</td>
<td>B913 7-230</td>
</tr>
<tr>
<td>LCE</td>
<td>LOAD CONTROL (32)</td>
<td>RS-a P A SP IF</td>
<td>B2</td>
<td>B7 10-49</td>
</tr>
<tr>
<td>LCLG</td>
<td>LOAD CONTROL (64)</td>
<td>RSY-a N P A SP IF</td>
<td>B2</td>
<td>EB2F 10-49</td>
</tr>
<tr>
<td>LCEB</td>
<td>LOAD COMPLEMENT (short BFP)</td>
<td>RRE CE IF</td>
<td>B2</td>
<td>B304 19-33</td>
</tr>
<tr>
<td>LCEBRA</td>
<td>LOAD COMPLEMENT (short BFP)</td>
<td>RRF-e CE IF</td>
<td>B2</td>
<td>B345 19-35</td>
</tr>
<tr>
<td>LCEBR</td>
<td>LOAD COMPLEMENT (short FP)</td>
<td>RRE CE IF</td>
<td>B2</td>
<td>B303 19-31</td>
</tr>
<tr>
<td>LCFR</td>
<td>LOAD COMPLEMENT (64→32)</td>
<td>RRE CE IF</td>
<td>B2</td>
<td>B313 19-31</td>
</tr>
<tr>
<td>LCFR</td>
<td>LOAD COMPLEMENT (64)</td>
<td>RRE CE IF</td>
<td>B2</td>
<td>B903 7-230</td>
</tr>
<tr>
<td>LCG</td>
<td>LOAD ADDRESS</td>
<td>RXY-a LD</td>
<td>B2</td>
<td>E376 7-229</td>
</tr>
<tr>
<td>LG</td>
<td>LOAD ADDRESS</td>
<td>RXY-a LD</td>
<td>B2</td>
<td>E376 7-229</td>
</tr>
<tr>
<td>LGAT</td>
<td>LOAD AND TRAP (64)</td>
<td>RXY-a LT A Dc</td>
<td>B2</td>
<td>E385 7-228</td>
</tr>
<tr>
<td>LGAX</td>
<td>LOAD AND EXCLUSIVE OR (64)</td>
<td>RXY-a LT A Dc</td>
<td>B2</td>
<td>E385 7-228</td>
</tr>
<tr>
<td>LGB</td>
<td>LOAD BYTE (64→8)</td>
<td>RXY-a LD A</td>
<td>B2</td>
<td>E377 7-229</td>
</tr>
<tr>
<td>LGBR</td>
<td>LOAD BYTE (64→8)</td>
<td>RRE EI</td>
<td>B2</td>
<td>B906 7-229</td>
</tr>
<tr>
<td>LGDR</td>
<td>LOAD BYTE (64→8)</td>
<td>RRE EI</td>
<td>B2</td>
<td>B914 7-221</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 9 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LGFRL</td>
<td>LOAD RELATIVE LONG (64→32)</td>
<td>RIL-b GE A* SP</td>
<td>C4C</td>
<td>7-222</td>
</tr>
<tr>
<td>LGH</td>
<td>LOAD HALFWORD (64→16)</td>
<td>RXY-a N A</td>
<td>B1</td>
<td>7-231</td>
</tr>
<tr>
<td>LGHI</td>
<td>LOAD HALFWORD IMMEDIATE (64→16)</td>
<td>RI-a N</td>
<td>A79</td>
<td>7-231</td>
</tr>
<tr>
<td>LGHR</td>
<td>LOAD HALFWORD (64→16)</td>
<td>RRE EI</td>
<td>B907</td>
<td>7-231</td>
</tr>
<tr>
<td>LGHRL</td>
<td>LOAD HALFWORD RELATIVE LONG (64→16)</td>
<td>RIL-b GE A*</td>
<td>C44</td>
<td>7-231</td>
</tr>
<tr>
<td>LGR</td>
<td>LOAD (64)</td>
<td>RRE N A</td>
<td>B904</td>
<td>7-221</td>
</tr>
<tr>
<td>LGRL</td>
<td>LOAD LONG RELATIVE LONG (64→32)</td>
<td>RIL-b GE A* SP</td>
<td>C48</td>
<td>7-222</td>
</tr>
<tr>
<td>LH</td>
<td>LOAD HALFWORD (32→16)</td>
<td>RXY-a A</td>
<td>B1</td>
<td>7-231</td>
</tr>
<tr>
<td>LHH</td>
<td>LOAD HALFWORD HIGH (32→16)</td>
<td>RXY-a HW A</td>
<td>A87</td>
<td>7-231</td>
</tr>
<tr>
<td>LHI</td>
<td>LOAD HALFWORD IMMEDIATE (32→16)</td>
<td>RI-a</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LHR</td>
<td>LOAD HALFWORD (32→16)</td>
<td>RRE EI</td>
<td>B927</td>
<td>7-231</td>
</tr>
<tr>
<td>LHRRL</td>
<td>LOAD RELATIVE HALFWORD IMMEDIATE (32→16)</td>
<td>RIL-b GE A*</td>
<td>C45</td>
<td>7-231</td>
</tr>
<tr>
<td>LHY</td>
<td>LOAD HALFWORD IMMEDIATE (64→32)</td>
<td>RXY-a LD A</td>
<td>B2</td>
<td>7-231</td>
</tr>
<tr>
<td>LLC</td>
<td>LOAD LOGICAL CHARACTER (32→8)</td>
<td>RXY-a EI A</td>
<td>B3E</td>
<td>7-234</td>
</tr>
<tr>
<td>LLCH</td>
<td>LOAD LOGICAL CHARACTER HIGH (32→8)</td>
<td>RXY-a HW A</td>
<td>B94</td>
<td>7-234</td>
</tr>
<tr>
<td>LLCR</td>
<td>LOAD LOGICAL CHARACTER (32→8)</td>
<td>RRE EI</td>
<td>B994</td>
<td>7-234</td>
</tr>
<tr>
<td>LLGC</td>
<td>LOAD LOGICAL CHARACTER (64→32)</td>
<td>RXY-a N A</td>
<td>B3E</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGCR</td>
<td>LOAD LOGICAL CHARACTER (64→32)</td>
<td>RXY-a EI A</td>
<td>B93E</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGF</td>
<td>LOAD LOGICAL (64→32)</td>
<td>RXY-a N A</td>
<td>B985</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGFAT</td>
<td>LOAD LOGICAL AND TRAP (64→32)</td>
<td>RXY-a LT A Dc</td>
<td>B3D</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGFR</td>
<td>LOAD LOGICAL (64→32)</td>
<td>RRE N A</td>
<td>B916</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGFRRL</td>
<td>LOAD RELATIVE LOGICAL (64→32)</td>
<td>RIL-b GE A* SP</td>
<td>C4E</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGH</td>
<td>LOAD LOGICAL HALFWORD (64→16)</td>
<td>RXY-a N A</td>
<td>B3E</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGHRL</td>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (64→16)</td>
<td>RIL-b GE A*</td>
<td>C46</td>
<td>7-235</td>
</tr>
<tr>
<td>LLGHR</td>
<td>LOAD LOGICAL HALFWORD (64→16)</td>
<td>RRE EI</td>
<td>B985</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGGHR</td>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (64→16)</td>
<td>RIL-b GE A*</td>
<td>B3D</td>
<td>7-233</td>
</tr>
<tr>
<td>LLGT</td>
<td>LOAD LOGICAL THIRTY ONE BITS (64→31)</td>
<td>RXY-a N A</td>
<td>B995</td>
<td>7-235</td>
</tr>
<tr>
<td>LLGTAT</td>
<td>LOAD LOGICAL THIRTY ONE BITS AND TRAP (64→31)</td>
<td>RXY-a LT A Dc</td>
<td>B3C</td>
<td>7-237</td>
</tr>
<tr>
<td>LLGTR</td>
<td>LOAD LOGICAL THIRTY ONE BITS (64→31)</td>
<td>RRE N A</td>
<td>B917</td>
<td>7-237</td>
</tr>
<tr>
<td>LLH</td>
<td>LOAD LOGICAL HALFWORD (64→16)</td>
<td>RXY-a N A</td>
<td>B3E</td>
<td>7-235</td>
</tr>
<tr>
<td>LLHH</td>
<td>LOAD LOGICAL HALFWORD HIGH (64→16)</td>
<td>RXY-a HW A</td>
<td>B3E</td>
<td>7-236</td>
</tr>
<tr>
<td>LLLHR</td>
<td>LOAD LOGICAL HALFWORD (32→16)</td>
<td>RRE EI</td>
<td>B995</td>
<td>7-235</td>
</tr>
<tr>
<td>LLHRL</td>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (32→16)</td>
<td>RIL-b GE A*</td>
<td>C42</td>
<td>7-235</td>
</tr>
<tr>
<td>LLHF</td>
<td>LOAD LOGICAL IMMEDIATE (high)</td>
<td>RXY-a EI A</td>
<td>B39C</td>
<td>7-237</td>
</tr>
<tr>
<td>LLIHH</td>
<td>LOAD LOGICAL IMMEDIATE (high high)</td>
<td>RXY-a EI A</td>
<td>B39C</td>
<td>7-237</td>
</tr>
<tr>
<td>LLILH</td>
<td>LOAD LOGICAL IMMEDIATE (high low)</td>
<td>RXY-a EI A</td>
<td>B39C</td>
<td>7-237</td>
</tr>
<tr>
<td>LLLF</td>
<td>LOAD LOGICAL IMMEDIATE (low)</td>
<td>RXY-a EI A</td>
<td>B39C</td>
<td>7-237</td>
</tr>
<tr>
<td>LLLH</td>
<td>LOAD LOGICAL IMMEDIATE (low high)</td>
<td>RXY-a EI A</td>
<td>B39C</td>
<td>7-237</td>
</tr>
<tr>
<td>LLLIL</td>
<td>LOAD LOGICAL IMMEDIATE (low low)</td>
<td>RXY-a EI A</td>
<td>B39C</td>
<td>7-237</td>
</tr>
<tr>
<td>LLZRGF</td>
<td>LOAD LOGICAL AND ZERO RIGHTMOST BYTE (64→32)</td>
<td>RXY-a LZ A</td>
<td>B33A</td>
<td>7-234</td>
</tr>
<tr>
<td>LM</td>
<td>LOAD MULTIPLE (32)</td>
<td>RS-a A</td>
<td>98</td>
<td>7-237</td>
</tr>
<tr>
<td>LMD</td>
<td>LOAD MULTIPLE DISJOINT (64→32&amp;32)</td>
<td>SS-e N A</td>
<td>B3E</td>
<td>7-238</td>
</tr>
<tr>
<td>LMG</td>
<td>LOAD MULTIPLE (64)</td>
<td>RSY-a A</td>
<td>B36F</td>
<td>7-237</td>
</tr>
<tr>
<td>LMM</td>
<td>LOAD MULTIPLE HIGH (32)</td>
<td>RSY-a A</td>
<td>B36F</td>
<td>7-237</td>
</tr>
<tr>
<td>LMY</td>
<td>LOAD MULTIPLE (32)</td>
<td>RSY-a LD A</td>
<td>B36F</td>
<td>7-237</td>
</tr>
<tr>
<td>LND BR</td>
<td>LOAD NEGATIVE (long BFP)</td>
<td>RRE C A</td>
<td>B311</td>
<td>19-34</td>
</tr>
<tr>
<td>LND FR</td>
<td>LOAD NEGATIVE (long)</td>
<td>RRE FS A</td>
<td>B311</td>
<td>19-34</td>
</tr>
<tr>
<td>LNDNR</td>
<td>LOAD NEGATIVE (long)</td>
<td>RRE C A</td>
<td>B311</td>
<td>19-34</td>
</tr>
<tr>
<td>LNEBR</td>
<td>LOAD NEGATIVE (short BFP)</td>
<td>RRE C A</td>
<td>B311</td>
<td>19-34</td>
</tr>
<tr>
<td>LNER</td>
<td>LOAD NEGATIVE (short BFP)</td>
<td>RRE C A</td>
<td>B311</td>
<td>19-34</td>
</tr>
<tr>
<td>LNZF</td>
<td>LOAD NEGATIVE (long)</td>
<td>RRE C A</td>
<td>B311</td>
<td>19-34</td>
</tr>
<tr>
<td>LNZF</td>
<td>LOAD NEGATIVE (long)</td>
<td>RRE C A</td>
<td>B311</td>
<td>19-34</td>
</tr>
<tr>
<td>LNZFR</td>
<td>LOAD NEGATIVE (64→32)</td>
<td>RRE C N</td>
<td>B901</td>
<td>7-239</td>
</tr>
<tr>
<td>LNZR</td>
<td>LOAD NEGATIVE (64)</td>
<td>RRE C N</td>
<td>B901</td>
<td>7-239</td>
</tr>
</tbody>
</table>

*Figure B-2. Instructions Arranged by Mnemonic (Part 10 of 22)*
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Opcode</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LNXBR</td>
<td>LOAD NEGATIVE (extended BFP)</td>
<td>RRE C q^7 SP</td>
<td>Db</td>
<td>B341</td>
</tr>
<tr>
<td>LNXR</td>
<td>LOAD NEGATIVE (extended HFP)</td>
<td>RRE C q^7 SP</td>
<td>Da</td>
<td>B361</td>
</tr>
<tr>
<td>LOC</td>
<td>LOAD ON CONDITION (32)</td>
<td>RSYb L1 A</td>
<td></td>
<td>B2</td>
</tr>
<tr>
<td>LOCFH</td>
<td>LOAD HIGH ON CONDITION (32)</td>
<td>RSYb L2 A</td>
<td></td>
<td>B2</td>
</tr>
<tr>
<td>LOCFSR</td>
<td>LOAD HIGH ON CONDITION (32)</td>
<td>RRF-c L2 A</td>
<td></td>
<td>B2</td>
</tr>
<tr>
<td>LOCGRH</td>
<td>LOAD HALFWORD IMMEDIATE ON CONDITION (64--)</td>
<td>RIE-g L2 A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LOCGRH</td>
<td>LOAD HALFWORD IMMEDIATE ON CONDITION (32--16)</td>
<td>RIE-g L2 A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LOC1R</td>
<td>LOAD ON CONDITION (32)</td>
<td>RRF-c L1 A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPD</td>
<td>LOAD PAIR DISJOINT (32)</td>
<td>SSF C IA A SP</td>
<td>Db</td>
<td>B1</td>
</tr>
<tr>
<td>LRD</td>
<td>LOAD PAIR DISJOINT (64)</td>
<td>RRE C q^7 SP</td>
<td>Da</td>
<td>B310</td>
</tr>
<tr>
<td>LPDFR</td>
<td>LOAD POSITIVE (long)</td>
<td>RRE FS q^7 Da</td>
<td></td>
<td>B370</td>
</tr>
<tr>
<td>LPD</td>
<td>LOAD PAIR DISJOINT (64)</td>
<td>RRE C q^7 A SP</td>
<td>Da</td>
<td>B61</td>
</tr>
<tr>
<td>LPDR</td>
<td>LOAD POSITIVE (long HFP)</td>
<td>RR C q^7 Da</td>
<td></td>
<td>B300</td>
</tr>
<tr>
<td>LPER</td>
<td>LOAD POSITIVE (short HFP)</td>
<td>RR C q^7 Da</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPGR</td>
<td>LOAD POSITIVE (64--32)</td>
<td>RRE C q^7 Da</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LGR</td>
<td>LOAD POSITIVE (64)</td>
<td>RRE C q^7 IF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPG</td>
<td>LOAD PAIR FROM QUADWORD (64&amp;64--128)</td>
<td>RXY-a q^7 A SP</td>
<td></td>
<td>B340</td>
</tr>
<tr>
<td>LPSW</td>
<td>LOAD PSW</td>
<td>S L q^3 Da</td>
<td></td>
<td>B82</td>
</tr>
<tr>
<td>LPSW</td>
<td>LOAD PSW EXTENDED</td>
<td>S L q^3 Da</td>
<td></td>
<td>B2B2</td>
</tr>
<tr>
<td>LPTA</td>
<td>LOAD PAGE TABLE ENTRY ADDRESS</td>
<td>RRFb C D2 P A SP</td>
<td>c</td>
<td>B9A</td>
</tr>
<tr>
<td>LPXBR</td>
<td>LOAD POSITIVE (extended BFP)</td>
<td>RRE C q^7 SP</td>
<td>Da</td>
<td>B340</td>
</tr>
<tr>
<td>LPXR</td>
<td>LOAD POSITIVE (extended HFP)</td>
<td>RRE C q^7 SP</td>
<td>Da</td>
<td>B360</td>
</tr>
<tr>
<td>LR</td>
<td>LOAD (32)</td>
<td>RR q^3 Da</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LRA</td>
<td>LOAD REAL ADDRESS (32)</td>
<td>RXya C P A SO</td>
<td></td>
<td>B1</td>
</tr>
<tr>
<td>LRA</td>
<td>LOAD REAL ADDRESS (32)</td>
<td>RXya C P A SO</td>
<td></td>
<td>B3</td>
</tr>
<tr>
<td>LRY</td>
<td>LOAD REAL ADDRESS (32)</td>
<td>RXya C LD P A SO</td>
<td></td>
<td>BP</td>
</tr>
<tr>
<td>LRD</td>
<td>LOAD ROUNDED (extended to long HFP)</td>
<td>RR q^7 SP Da EO</td>
<td></td>
<td>25</td>
</tr>
<tr>
<td>LRE</td>
<td>LOAD ROUNDED (long to short HFP)</td>
<td>RR q^7 Da</td>
<td></td>
<td>35</td>
</tr>
<tr>
<td>LRL</td>
<td>LOAD RELATIVE LONG (32)</td>
<td>RIL-b GE A SP</td>
<td></td>
<td>C4D</td>
</tr>
<tr>
<td>LRV</td>
<td>LOAD REVERSED (32)</td>
<td>RXya N A</td>
<td></td>
<td>B3</td>
</tr>
<tr>
<td>LRG</td>
<td>LOAD REVERSED (64)</td>
<td>RXya N A</td>
<td></td>
<td>B2</td>
</tr>
<tr>
<td>LVGR</td>
<td>LOAD REVERSED (64)</td>
<td>RXya N A</td>
<td></td>
<td>B2</td>
</tr>
<tr>
<td>LVGH</td>
<td>LOAD REVERSED (16)</td>
<td>RXya N A</td>
<td></td>
<td>B3</td>
</tr>
<tr>
<td>LVR</td>
<td>LOAD REVERSE (32)</td>
<td>RXya N A</td>
<td></td>
<td>B31F</td>
</tr>
<tr>
<td>LR</td>
<td>LOAD REVERSE (32)</td>
<td>RXya C EI A SP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LT</td>
<td>LOAD AND TEST (32)</td>
<td>RXya C EI A Db</td>
<td></td>
<td>B312</td>
</tr>
<tr>
<td>LTDBR</td>
<td>LOAD AND TEST (long BFP)</td>
<td>RRE C q^7 Db Xi</td>
<td></td>
<td>B312</td>
</tr>
<tr>
<td>LTDR</td>
<td>LOAD AND TEST (long HFP)</td>
<td>RR C q^7 Da</td>
<td></td>
<td>22</td>
</tr>
<tr>
<td>LTRD</td>
<td>LOAD AND TEST (long HFP)</td>
<td>RRE C q^7 Da</td>
<td></td>
<td>B3D</td>
</tr>
<tr>
<td>LTEBR</td>
<td>LOAD AND TEST (short BFP)</td>
<td>RRE C q^7 Db Xi</td>
<td></td>
<td>B302</td>
</tr>
<tr>
<td>LTER</td>
<td>LOAD AND TEST (short HFP)</td>
<td>RR C q^7 Da</td>
<td></td>
<td>32</td>
</tr>
<tr>
<td>LT</td>
<td>LOAD AND TEST (short HFP)</td>
<td>RR C q^7 Da</td>
<td></td>
<td>B312</td>
</tr>
<tr>
<td>LTG</td>
<td>LOAD AND TEST (64)</td>
<td>RXva C EI A</td>
<td></td>
<td>B312</td>
</tr>
<tr>
<td>LTGF</td>
<td>LOAD AND TEST (64--32)</td>
<td>RXva C GE A</td>
<td></td>
<td>B312</td>
</tr>
<tr>
<td>LTGF</td>
<td>LOAD AND TEST (64--32)</td>
<td>RXva C N</td>
<td></td>
<td>B312</td>
</tr>
<tr>
<td>LTR</td>
<td>LOAD AND TEST (64)</td>
<td>RXC N</td>
<td></td>
<td>B902</td>
</tr>
<tr>
<td>LTR</td>
<td>LOAD AND TEST (32)</td>
<td>RXC N</td>
<td></td>
<td>12</td>
</tr>
<tr>
<td>LTXB</td>
<td>LOAD AND TEST (extended BFP)</td>
<td>RRE C q^7 SP Da</td>
<td></td>
<td>B342</td>
</tr>
<tr>
<td>LTXR</td>
<td>LOAD AND TEST (extended HFP)</td>
<td>RRE C q^7 SP Da</td>
<td></td>
<td>B362</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic  (Part 11 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-Code Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LTXTR</td>
<td>LOAD AND TEST (extended DFP)</td>
<td>RRE C TF $d^7$</td>
<td>83DE</td>
</tr>
<tr>
<td>LURA</td>
<td>LOAD USING REAL ADDRESS (32)</td>
<td>RRE P A$^1$ SP</td>
<td>B24B</td>
</tr>
<tr>
<td>LURAG</td>
<td>LOAD USING REAL ADDRESS (64)</td>
<td>RRE N P A$^1$ SP</td>
<td>B905</td>
</tr>
<tr>
<td>LXD</td>
<td>LOAD LENGTHENED (long to extended HFP)</td>
<td>RXE $d^7$ SP Da</td>
<td>B2E</td>
</tr>
<tr>
<td>LXDB</td>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>RXE $d^7$ SP Db Xi</td>
<td>B2E</td>
</tr>
<tr>
<td>LXDBR</td>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>RRE $d^7$ SP Db Xi</td>
<td>B2E</td>
</tr>
<tr>
<td>LXDR</td>
<td>LOAD LENGTHENED (long to extended HFP)</td>
<td>RRE $d^7$ SP Da</td>
<td>B2E</td>
</tr>
<tr>
<td>LXDDR</td>
<td>LOAD LENGTHENED (long to extended DFP)</td>
<td>RRF-d TF $d^7$ SP Dt Xi</td>
<td>B3DC</td>
</tr>
<tr>
<td>LXE</td>
<td>LOAD LENGTHENED (short to extended HFP)</td>
<td>RXE $d^7$ SP Da</td>
<td>B2E</td>
</tr>
<tr>
<td>LXE</td>
<td>LOAD LENGTHENED (short to extended BFP)</td>
<td>RXE $d^7$ SP Db Xi</td>
<td>B2E</td>
</tr>
<tr>
<td>LXEBr</td>
<td>LOAD LENGTHENED (short to extended BFP)</td>
<td>RRE $d^7$ SP Db Xi</td>
<td>B2E</td>
</tr>
<tr>
<td>LXR</td>
<td>LOAD LENGTHENED (short to extended HFP)</td>
<td>RRE $d^7$ SP Da</td>
<td>B2E</td>
</tr>
<tr>
<td>LXR</td>
<td>LOAD (extended)</td>
<td>RRE $d^7$ SP Da</td>
<td>B2E</td>
</tr>
<tr>
<td>LY</td>
<td>LOAD (32)</td>
<td>RXY-a LD A</td>
<td>B378</td>
</tr>
<tr>
<td>LZDR</td>
<td>LOAD ZERO (long)</td>
<td>RRE $d^7$ SP Da</td>
<td>B2E</td>
</tr>
<tr>
<td>LZR</td>
<td>LOAD ZERO (short)</td>
<td>RRE $d^7$ SP Da</td>
<td>B2E</td>
</tr>
<tr>
<td>LZRF</td>
<td>LOAD AND ZERO RIGHTMOST BYTE (32)</td>
<td>RXY-a LZ A</td>
<td>B378</td>
</tr>
<tr>
<td>LZRG</td>
<td>LOAD AND ZERO RIGHTMOST BYTE (64)</td>
<td>RXY-a LZ A</td>
<td>B378</td>
</tr>
<tr>
<td>LXZr</td>
<td>LOAD ZERO (extended)</td>
<td>RRE $d^7$ SP Da</td>
<td>B2E</td>
</tr>
<tr>
<td>M</td>
<td>MULTIPLY (64−32)</td>
<td>RX-a A SP</td>
<td>B3E</td>
</tr>
<tr>
<td>MAD</td>
<td>MULTIPLY AND ADD (long HFP)</td>
<td>RXF HM $d^7$ A</td>
<td>B3E</td>
</tr>
<tr>
<td>MADBr</td>
<td>MULTIPLY AND ADD (long BFP)</td>
<td>RXF $d^7$ A Db Xi Xo Xu Xx Da</td>
<td>B3E</td>
</tr>
<tr>
<td>MADER</td>
<td>MULTIPLY AND ADD (long HFP)</td>
<td>RRD $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MAYER</td>
<td>MULTIPLY AND ADD (short HFP)</td>
<td>RXF $d^7$ A Da</td>
<td>B3E</td>
</tr>
<tr>
<td>MAYER</td>
<td>MULTIPLY AND ADD (short BFP)</td>
<td>RXF $d^7$ A Da</td>
<td>B3E</td>
</tr>
<tr>
<td>MAER</td>
<td>MULTIPLY AND ADD (short HFP)</td>
<td>RXF $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MADER</td>
<td>MULTIPLY AND ADD (short BFP)</td>
<td>RXF $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MCF</td>
<td>MONITOR CALL</td>
<td>RX-a $d^7$ A Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MD</td>
<td>MULTIPLY (long HFP)</td>
<td>RXE $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MDE</td>
<td>MULTIPLY (long HFP)</td>
<td>RRE $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MDER</td>
<td>MULTIPLY (short to long HFP)</td>
<td>RX-a $d^7$ Da Xi Xo Xu Xx</td>
<td>B3E</td>
</tr>
<tr>
<td>MDER</td>
<td>MULTIPLY (short to long HFP)</td>
<td>RX-a $d^7$ Da Xi Xo Xu Xx</td>
<td>B3E</td>
</tr>
<tr>
<td>ME</td>
<td>MULTIPLY (short to long HFP)</td>
<td>RX-a $d^7$ Da Xi</td>
<td>B3E</td>
</tr>
<tr>
<td>MEE</td>
<td>MULTIPLY (short BFP)</td>
<td>RXE $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MEE</td>
<td>MULTIPLY (short BFP)</td>
<td>RXE $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MEEBr</td>
<td>MULTIPLY (short BFP)</td>
<td>RRE $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MEER</td>
<td>MULTIPLY (short HFP)</td>
<td>RRE $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MER</td>
<td>MULTIPLY (short BFP)</td>
<td>RRE $d^7$ Da EU EO</td>
<td>B3E</td>
</tr>
<tr>
<td>MFY</td>
<td>MULTIPLY (64−32)</td>
<td>RXY-a GE A SP</td>
<td>B3E</td>
</tr>
<tr>
<td>MGH</td>
<td>MULTIPLY HALFWORD IMMEDIATE (64−16)</td>
<td>Ri-a N A</td>
<td>B3E</td>
</tr>
<tr>
<td>MH</td>
<td>MULTIPLY HALFWORD (32−16)</td>
<td>Rx-a A</td>
<td>B3E</td>
</tr>
<tr>
<td>MHI</td>
<td>MULTIPLY HALFWORD IMMEDIATE (32−16)</td>
<td>Rx-a A</td>
<td>B3E</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 12 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>MHY</td>
<td>MULTIPLY HALFWORD (32→16)</td>
<td>RXY-a GE A</td>
<td>B₂</td>
<td>E37C</td>
</tr>
<tr>
<td>ML</td>
<td>MULTIPLY LOGICAL (64→32)</td>
<td>RXY-a N S A SP</td>
<td>B₂</td>
<td>E396</td>
</tr>
<tr>
<td>MLG</td>
<td>MULTIPLY LOGICAL (128→64)</td>
<td>RXY-a N A SP</td>
<td>B₂</td>
<td>E386</td>
</tr>
<tr>
<td>MLGR</td>
<td>MULTIPLY LOGICAL (128→64)</td>
<td>RRE N SP</td>
<td>B₂</td>
<td>986</td>
</tr>
<tr>
<td>MLR</td>
<td>MULTIPLY LOGICAL (64→32)</td>
<td>RRE N3 SP</td>
<td>B₂</td>
<td>996</td>
</tr>
<tr>
<td>MP</td>
<td>MULTIPLY DECIMAL</td>
<td>SS-b d³ A SP Dg</td>
<td>ST B₁ B₂</td>
<td>FC</td>
</tr>
<tr>
<td>MR</td>
<td>MULTIPLY (64→32)</td>
<td>RR SP</td>
<td></td>
<td>1C</td>
</tr>
<tr>
<td>MS</td>
<td>MULTIPLY SINGLE (32)</td>
<td>RX-a A</td>
<td>B₁</td>
<td>71</td>
</tr>
<tr>
<td>MSCH</td>
<td>MODIFY SUBCHANNEL</td>
<td>S C A SP OP c GS</td>
<td>B₂</td>
<td>232</td>
</tr>
<tr>
<td>MSD</td>
<td>MULTIPLY AND SUBTRACT (long HFP)</td>
<td>RXF HM d³³ A Da EU EO</td>
<td>B₂</td>
<td>396</td>
</tr>
<tr>
<td>MSDB</td>
<td>MULTIPLY AND SUBTRACT (long BFP)</td>
<td>RXF d³³ A Db Xi Xo Xu Xx</td>
<td>B₂</td>
<td>386</td>
</tr>
<tr>
<td>MSDBR</td>
<td>MULTIPLY AND SUBTRACT (long BFP)</td>
<td>RRD d³³ Db Xi Xo Xu Xx</td>
<td>B₂</td>
<td>376</td>
</tr>
<tr>
<td>MSDR</td>
<td>MULTIPLY AND SUBTRACT (long HFP)</td>
<td>RRD HM d³³ Da EU EO</td>
<td>B₂</td>
<td>E3DF</td>
</tr>
<tr>
<td>MSL</td>
<td>MULTIPLY AND SUBTRACT (short BFP)</td>
<td>RXF HM d³³ A Da EU EO</td>
<td>B₂</td>
<td>E3F</td>
</tr>
<tr>
<td>MSEL</td>
<td>MULTIPLY AND SUBTRACT (short HFP)</td>
<td>RXF d³³ A Db Xi Xo Xu Xx</td>
<td>B₂</td>
<td>ED0F</td>
</tr>
<tr>
<td>MSELB</td>
<td>MULTIPLY AND SUBTRACT (short BFP)</td>
<td>RRD d³³ Db Xi Xo Xu Xx</td>
<td>B₂</td>
<td>E39F</td>
</tr>
<tr>
<td>MSE</td>
<td>MULTIPLY (64→32)</td>
<td>RRE N SP</td>
<td>B₂</td>
<td>996</td>
</tr>
<tr>
<td>MSF</td>
<td>MULTIPLY SINGLE IMMEDIATE (32)</td>
<td>RIL-a GE A</td>
<td>B₂</td>
<td>312</td>
</tr>
<tr>
<td>MSG</td>
<td>MULTIPLY SINGLE (64)</td>
<td>RXY-a N A B₂</td>
<td>B₂</td>
<td>E30C</td>
</tr>
<tr>
<td>MSGF</td>
<td>MULTIPLY SINGLE (64→32)</td>
<td>RXY-a N A</td>
<td>B₂</td>
<td>E31C</td>
</tr>
<tr>
<td>MSFGB</td>
<td>MULTIPLY SINGLE IMMEDIATE (64→32)</td>
<td>RIL-a GE</td>
<td>B₂</td>
<td>320</td>
</tr>
<tr>
<td>MSER</td>
<td>MULTIPLY AND SUBTRACT (short HFP)</td>
<td>RRD HM d³³ Da EU EO</td>
<td>B₂</td>
<td>E32F</td>
</tr>
<tr>
<td>MSFI</td>
<td>MULTIPLY SINGLE IMMEDIATE (32)</td>
<td>RIL-a GE</td>
<td>B₂</td>
<td>E31C</td>
</tr>
<tr>
<td>MSG</td>
<td>MULTIPLY SINGLE (64)</td>
<td>RXY-a N A B₂</td>
<td>B₂</td>
<td>E30C</td>
</tr>
<tr>
<td>MSGB</td>
<td>MULTIPLY SINGLE IMMEDIATE (64→32)</td>
<td>RIL-a GE</td>
<td>B₂</td>
<td>E32F</td>
</tr>
<tr>
<td>MSFR</td>
<td>MULTIPLY SINGLE (64→32)</td>
<td>RRE N</td>
<td>B₂</td>
<td>B11C</td>
</tr>
<tr>
<td>MSR</td>
<td>MULTIPLY SINGLE (32)</td>
<td>RRE N</td>
<td>B₂</td>
<td>B90C</td>
</tr>
<tr>
<td>MSTA</td>
<td>MODIFY STACKED STATE</td>
<td>RRE A³ A³ SP SE ST</td>
<td>B₂</td>
<td>B247</td>
</tr>
<tr>
<td>MSY</td>
<td>MULTIPLY SINGLE (32)</td>
<td>RXY-a LD A</td>
<td>B₂</td>
<td>E351</td>
</tr>
<tr>
<td>MVC</td>
<td>MOVE (character)</td>
<td>SS-a d³ A</td>
<td>ST B₁ B₂</td>
<td>D2</td>
</tr>
<tr>
<td>MVD</td>
<td>MOVE WITH DESTINATION KEY</td>
<td>SSE Q A GM</td>
<td>ST B₁ B₂</td>
<td>E50F</td>
</tr>
<tr>
<td>MVCIN</td>
<td>MOVE INVERSE</td>
<td>SS-a d³ A</td>
<td>ST B₁ B₂</td>
<td>E8</td>
</tr>
<tr>
<td>MVK</td>
<td>MOVE WITH KEY</td>
<td>SS-d C Q A</td>
<td>ST B₁ B₂</td>
<td>D9</td>
</tr>
<tr>
<td>MVCVL</td>
<td>MOVE LONG</td>
<td>RR C d³ A SP I</td>
<td>ST R₁ R₂</td>
<td>0E</td>
</tr>
<tr>
<td>MVCLE</td>
<td>MOVE LONG EXTENDED</td>
<td>HS-a C d³ A SP IC</td>
<td>ST R₁ R₂</td>
<td>A8</td>
</tr>
<tr>
<td>MVCLEU</td>
<td>MOVE LONG UNICODE</td>
<td>RSY-a C E2 d³ A SP IC</td>
<td>ST R₁ R₂</td>
<td>EB8E</td>
</tr>
<tr>
<td>MVCOS</td>
<td>MOVE WITH OPTIONAL SPECIFICATIONS</td>
<td>SSF C MO A SO G₀</td>
<td>ST B₁ B₂</td>
<td>C80</td>
</tr>
<tr>
<td>MVCOS</td>
<td>MOVE TO PRIMARY</td>
<td>SS-d C Q A SO ε</td>
<td>ST</td>
<td>DA</td>
</tr>
<tr>
<td>MVCS</td>
<td>MOVE TO SECONDARY</td>
<td>SS-d C Q A SO ε</td>
<td>ST</td>
<td>DB</td>
</tr>
<tr>
<td>MVLCS</td>
<td>MOVE WITH SOURCE KEY</td>
<td>SSE Q A GM</td>
<td>ST B₁ B₂</td>
<td>E50E</td>
</tr>
<tr>
<td>MVGS</td>
<td>MOVE (64→16)</td>
<td>SIL GE A</td>
<td>ST B₁ B₂</td>
<td>E548</td>
</tr>
<tr>
<td>MVH</td>
<td>MOVE (64→16)</td>
<td>SIL GE A</td>
<td>ST B₁ B₂</td>
<td>E544</td>
</tr>
<tr>
<td>MVHI</td>
<td>MOVE (32→16)</td>
<td>SIL GE A</td>
<td>ST B₁ B₂</td>
<td>E54C</td>
</tr>
<tr>
<td>MVI</td>
<td>MOVE (immediate)</td>
<td>SI A</td>
<td>ST B₁ B₂</td>
<td>92</td>
</tr>
<tr>
<td>MVY</td>
<td>MOVE (immediate)</td>
<td>SIY LD A</td>
<td>ST B₁ B₂</td>
<td>EB52</td>
</tr>
<tr>
<td>MVN</td>
<td>MOVE NUMERICs</td>
<td>SS-a d³ A</td>
<td>ST B₁ B₂</td>
<td>D1</td>
</tr>
<tr>
<td>MOO</td>
<td>MOVE WITH OFFSET</td>
<td>SS-b d³ A</td>
<td>ST B₁ B₂</td>
<td>F1</td>
</tr>
<tr>
<td>MVPG</td>
<td>MOVE PAGE</td>
<td>RRE C Q A SP G₀</td>
<td>ST R₁ R₂</td>
<td>B254</td>
</tr>
<tr>
<td>MVST</td>
<td>MOVE STRING</td>
<td>RRE C d³ A SP IC G₀</td>
<td>ST R₁ R₂</td>
<td>B255</td>
</tr>
<tr>
<td>MZZ</td>
<td>MOVE ZONES</td>
<td>SS-a d³ A</td>
<td>ST B₁ B₂</td>
<td>D3</td>
</tr>
<tr>
<td>MXBR</td>
<td>MULTIPLY (extended BFP)</td>
<td>RRE d³³ SP Da Xi Xo Xu Xx</td>
<td>ST B₁ B₂</td>
<td>234C</td>
</tr>
<tr>
<td>MXD</td>
<td>MULTIPLY (long to extended HFP)</td>
<td>RX-a d³³ A SP Da EU EO</td>
<td>B₂</td>
<td>67</td>
</tr>
<tr>
<td>MXDB</td>
<td>MULTIPLY (long to extended BFP)</td>
<td>RXE d³³ A SP Db Xi</td>
<td>B₂</td>
<td>ED07</td>
</tr>
<tr>
<td>MXDBR</td>
<td>MULTIPLY (long to extended BFP)</td>
<td>RRE d³³ SP Db Xi</td>
<td>B₂</td>
<td>ED07</td>
</tr>
<tr>
<td>MXDR</td>
<td>MULTIPLY (long to extended HFP)</td>
<td>RR d³³ SP Da EU EO</td>
<td></td>
<td>27</td>
</tr>
<tr>
<td>MXR</td>
<td>MULTIPLY (extended HFP)</td>
<td>RR d³³ SP Da EU EO</td>
<td></td>
<td>26</td>
</tr>
<tr>
<td>MXTR</td>
<td>MULTIPLY (extended DFP)</td>
<td>RRF-a TF d³³ SP Dt Xi Xo Xu Xx</td>
<td></td>
<td>B3DB</td>
</tr>
<tr>
<td>MXTRA</td>
<td>MULTIPLY (extended DFP)</td>
<td>RRF-a F d³³ SP Dt Xi Xo Xu Xq</td>
<td></td>
<td>B3DB</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 13 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>NY</td>
<td>OR (32)</td>
<td>RXY-a C A</td>
<td>B-3</td>
<td>B9F4</td>
</tr>
<tr>
<td>OY</td>
<td>OR (32)</td>
<td>RXY-a C LD A</td>
<td>B-3</td>
<td>E381</td>
</tr>
<tr>
<td>OY</td>
<td>OR (32)</td>
<td>RXY-a C N A</td>
<td>B-3</td>
<td>B981</td>
</tr>
<tr>
<td>OY</td>
<td>OR (32)</td>
<td>RXY-a C N A</td>
<td>B-3</td>
<td>B9E6</td>
</tr>
<tr>
<td>OY</td>
<td>OR (32)</td>
<td>RXY-a C N A</td>
<td>B-3</td>
<td>E366</td>
</tr>
<tr>
<td>OY</td>
<td>OR (32)</td>
<td>RXY-a C N A</td>
<td>B-3</td>
<td>E366</td>
</tr>
<tr>
<td>OY</td>
<td>OR (32)</td>
<td>RXY-a C N A</td>
<td>B-3</td>
<td>F2</td>
</tr>
<tr>
<td>PALB</td>
<td>PURGE ALB</td>
<td>RRE P S</td>
<td>B-3</td>
<td>B248</td>
</tr>
<tr>
<td>PC</td>
<td>PROGRAM CALL</td>
<td>S Q A</td>
<td>B-3</td>
<td>B218</td>
</tr>
<tr>
<td>PCC</td>
<td>PERFORM CRYPTOGRAPHIC COMPUTATION</td>
<td>RRE C M4 A SP</td>
<td>B-3</td>
<td>B92C</td>
</tr>
<tr>
<td>PCKMO</td>
<td>PERFORM CRYPTOGRAPHIC KEY MGMT. OPERATIONS</td>
<td>RRE M3 P A SP</td>
<td>B-3</td>
<td>B928</td>
</tr>
<tr>
<td>PFD</td>
<td>PREFETCH DATA</td>
<td>RXY-g GE</td>
<td>B-3</td>
<td>E356</td>
</tr>
<tr>
<td>PFDR</td>
<td>PREFETCH DATA RELATIVE LONG</td>
<td>RIL-c GE</td>
<td>B-3</td>
<td>C62</td>
</tr>
<tr>
<td>PFMF</td>
<td>PERFORM FRAME MANAGEMENT FUNCTION</td>
<td>RRE ED1 A SP</td>
<td>B-3</td>
<td>B9AF</td>
</tr>
<tr>
<td>PFSO</td>
<td>PERFORM FLOATING-POINT OPERATION</td>
<td>E PF A</td>
<td>B-3</td>
<td>01A</td>
</tr>
<tr>
<td>PGIN</td>
<td>PAGE IN</td>
<td>RRE C ES P</td>
<td>B-3</td>
<td>B22E</td>
</tr>
<tr>
<td>PGOUT</td>
<td>PAGE OUT</td>
<td>RRE C ES P</td>
<td>B-3</td>
<td>B22F</td>
</tr>
<tr>
<td>PKA</td>
<td>PACK ASCII</td>
<td>SS-f E2 A</td>
<td>B-3</td>
<td>B9</td>
</tr>
<tr>
<td>PKU</td>
<td>PACK UNICODE</td>
<td>SS-f E2 A</td>
<td>B-3</td>
<td>B9</td>
</tr>
<tr>
<td>PLO</td>
<td>PERFORM LOCKED OPERATION</td>
<td>SS-e C A</td>
<td>B-3</td>
<td>F2</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 14 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>POPCNT</td>
<td>POPULATION COUNT</td>
<td>RRE C PK</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PPA</td>
<td>PERFORM PROCESSOR ASSIST</td>
<td>RRF-c PA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PPNO</td>
<td>PERFORM PSEUDORANDOM NUMBER OPERATION</td>
<td>RRE C M5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PR</td>
<td>PROGRAM RETURN</td>
<td>E L</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PT</td>
<td>PROGRAM TRANSFER</td>
<td>RRE Q A*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PTF</td>
<td>PERFORM TOPOLOGY FUNCTION</td>
<td>RRE C CT</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PTFF</td>
<td>PERFORM TIMING FACILITY FUNCTION</td>
<td>E C TS</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PTI</td>
<td>PROGRAM TRANSFER WITH INSTANCE</td>
<td>RRE RA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PTLB</td>
<td>PURGE TLB</td>
<td>S P</td>
<td></td>
<td></td>
</tr>
<tr>
<td>QADTR</td>
<td>QUANTIZE (long DFP)</td>
<td>RRF-b TF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>QAXTR</td>
<td>QUANTIZE (extended DFP)</td>
<td>RRF-b TF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RCHP</td>
<td>RESET CHANNEL PATH</td>
<td>S C</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RISBG</td>
<td>ROTATE THEN INSERT SELECTED BITS (64)</td>
<td>RIE-f C GE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RISBGN</td>
<td>ROTATE THEN INSERT SELECTED BITS (64)</td>
<td>RIE-f MI</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RISBGH</td>
<td>ROTATE THEN INSERT SELECTED BITS HIGH (64)</td>
<td>RIE-f HW</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RISBGL</td>
<td>ROTATE THEN INSERT SELECTED BITS LOW (64)</td>
<td>RIE-f HW</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RLL</td>
<td>ROTATE LEFT SINGLE LOGICAL (32)</td>
<td>RSY-a N</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RLLG</td>
<td>ROTATE LEFT SINGLE LOGICAL (64)</td>
<td>RSY-a N</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RNSBG</td>
<td>ROTATE THEN AND SELECTED BITS (64)</td>
<td>RIE-f C GE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ROSBG</td>
<td>ROTATE OR SELECTED BITS (64)</td>
<td>RIE-f C GE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RP</td>
<td>RESUME PROGRAM</td>
<td>S L P A*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RRBE</td>
<td>RESUME REFERENCE BIT EXTENDED</td>
<td>RRE C</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RRBM</td>
<td>RESUME REFERENCE BITS MULTIPLE</td>
<td>RRE RB P A*</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RRDTI</td>
<td>REROUND (long DFP)</td>
<td>RRF-b TF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RRXT</td>
<td>REROUND (extended DFP)</td>
<td>RRF-b TF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RSCH</td>
<td>RESUME SUBCHANNEL</td>
<td>S C</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RXSBG</td>
<td>ROTATE THEN EXCLUSIVE OR SELECT. BITS (64)</td>
<td>RIE-f C GE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>SUBTRACT (32)</td>
<td>RX-a C A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SAC</td>
<td>SET ADDRESS SPACE CONTROL</td>
<td>S Q SP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SACF</td>
<td>SET ADDRESS SPACE CONTROL FAST</td>
<td>S Q SP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SAL</td>
<td>SET ADDRESS LIMIT</td>
<td>S P OP ¢ G1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SAM24</td>
<td>SET ADDRESSING MODE (24)</td>
<td>E N3 g^3 SP T</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SAM31</td>
<td>SET ADDRESSING MODE (31)</td>
<td>E N5 g^3+ SP T</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SAM64</td>
<td>SET ADDRESSING MODE (64)</td>
<td>E N g^3+ SP T</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SAR</td>
<td>SET ACCESS</td>
<td>RRE g^6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SCHM</td>
<td>SET CHANNEL MONITOR</td>
<td>S P OP ¢ GM</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SCK</td>
<td>SET CLOCK</td>
<td>S C P A SP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SCCK</td>
<td>SET CLOCK COMPARATOR</td>
<td>S P A SP</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SCKPF</td>
<td>SET CLOCK PROGRAMMABLE FIELD</td>
<td>E P SP G0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SD</td>
<td>SUBTRACT NORMALIZED (long HFP)</td>
<td>RX-a C g^3 A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SDB</td>
<td>SUBTRACT (long BFP)</td>
<td>RXE C g^3 A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SDBR</td>
<td>SUBTRACT (long BFP)</td>
<td>RRE C g^3 A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SDR</td>
<td>SUBTRACT NORMALIZED (long HFP)</td>
<td>RR C g^3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SDTR</td>
<td>SUBTRACT (long DFP)</td>
<td>RRF-a C TF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SDFBT</td>
<td>SUBTRACT (long DFP)</td>
<td>RRF-a C F</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SE</td>
<td>SUBTRACT NORMALIZED (short HFP)</td>
<td>RX-a C g^3 A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEB</td>
<td>SUBTRACT (short BFP)</td>
<td>RXE C g^3 A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEBR</td>
<td>SUBTRACT (short BFP)</td>
<td>RRE C g^7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SER</td>
<td>SUBTRACT (short BFP)</td>
<td>RR C</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SFBFSR</td>
<td>SET FPC AND SIGNAL</td>
<td>RRE XF</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SFFC</td>
<td>SET FPC</td>
<td>RRE       SP Db</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SG</td>
<td>SUBTRACT (64)</td>
<td>RXY-a C N A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SGR</td>
<td>SUBTRACT (64)</td>
<td>RRE C N</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 15 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>SGR</td>
<td>SUBTRACT (64)</td>
<td>RRE C N</td>
<td>B909</td>
<td>7-338</td>
</tr>
<tr>
<td>SGRR</td>
<td>SUBTRACT (64)</td>
<td>RRF-a C DO</td>
<td>B9E9</td>
<td>7-338</td>
</tr>
<tr>
<td>SH</td>
<td>SUBTRACT Halfword (32&lt;-&gt;16)</td>
<td>RX-a C A</td>
<td>B7</td>
<td>7-339</td>
</tr>
<tr>
<td>SHHRR</td>
<td>SUBTRACT HIGH (32)</td>
<td>RRF-a C HW</td>
<td>B9C9</td>
<td>7-339</td>
</tr>
<tr>
<td>SHHLR</td>
<td>SUBTRACT HIGH (32)</td>
<td>RRF-a C HW</td>
<td>B9D9</td>
<td>7-339</td>
</tr>
<tr>
<td>SHY</td>
<td>SUBTRACT Halfword (32&lt;-&gt;16)</td>
<td>RXY-a C LD A</td>
<td>BE7B</td>
<td>7-339</td>
</tr>
<tr>
<td>SIGP</td>
<td>SIGNAL PROCESSOR</td>
<td>RS-a C P $</td>
<td>AE</td>
<td>10-129</td>
</tr>
<tr>
<td>SL</td>
<td>SUBTRACT LOGICAL (32)</td>
<td>RX-a C A</td>
<td>B5</td>
<td>7-340</td>
</tr>
<tr>
<td>SLA</td>
<td>SHIFT LEFT SINGLE (32)</td>
<td>RS-a C</td>
<td>8B</td>
<td>7-323</td>
</tr>
<tr>
<td>SLAG</td>
<td>SHIFT LEFT SINGLE (64)</td>
<td>RSY-a C N</td>
<td>EB0B</td>
<td>7-323</td>
</tr>
<tr>
<td>SLAK</td>
<td>SHIFT LEFT SINGLE (32)</td>
<td>RSY-a C DO</td>
<td>EB0D</td>
<td>7-323</td>
</tr>
<tr>
<td>SLB</td>
<td>SUBTRACT LOGICAL WITH BORROW (32)</td>
<td>RXY-a C N3 A</td>
<td>BE</td>
<td>7-341</td>
</tr>
<tr>
<td>SLBLG</td>
<td>SUBTRACT LOGICAL WITH BORROW (64)</td>
<td>RXY-a C N A</td>
<td>BE89</td>
<td>7-341</td>
</tr>
<tr>
<td>SLBGR</td>
<td>SUBTRACT LOGICAL WITH BORROW (64)</td>
<td>RRE C N</td>
<td>B989</td>
<td>7-341</td>
</tr>
<tr>
<td>SLDG</td>
<td>SUBTRACT LOGICAL WITH BORROW (32)</td>
<td>RRE C N3</td>
<td>B999</td>
<td>7-341</td>
</tr>
<tr>
<td>SLDA</td>
<td>SHIFT LEFT DOUBLE (64)</td>
<td>RS-a C SP</td>
<td>8F</td>
<td>7-322</td>
</tr>
<tr>
<td>SLDL</td>
<td>SHIFT LEFT DOUBLE LOGICAL (64)</td>
<td>RS-a SP</td>
<td>8D</td>
<td>7-323</td>
</tr>
<tr>
<td>SLDT</td>
<td>SHIFT SIGNIFICAND LEFT (long DFP)</td>
<td>RXF TF $ d&lt;9 Dd</td>
<td>ED40</td>
<td>20-53</td>
</tr>
<tr>
<td>SLPF</td>
<td>SUBTRACT LOGICAL IMMEDIATE (32)</td>
<td>RIL-a C EI</td>
<td>C25</td>
<td>7-340</td>
</tr>
<tr>
<td>SLG</td>
<td>SUBTRACT LOGICAL (64)</td>
<td>RXY-a C N A</td>
<td>BE</td>
<td>7-340</td>
</tr>
<tr>
<td>SLGF</td>
<td>SUBTRACT LOGICAL (64&lt;-&gt;32)</td>
<td>RXY-a C N A</td>
<td>BE1B</td>
<td>7-340</td>
</tr>
<tr>
<td>SLGFI</td>
<td>SUBTRACT LOGICAL IMMEDIATE (64&lt;-&gt;32)</td>
<td>RIL-a C EI</td>
<td>C4</td>
<td>7-340</td>
</tr>
<tr>
<td>SLGFR</td>
<td>SUBTRACT LOGICAL (64&lt;-&gt;32)</td>
<td>RRE C N</td>
<td>B91B</td>
<td>7-340</td>
</tr>
<tr>
<td>SLGR</td>
<td>SUBTRACT LOGICAL (64)</td>
<td>RRE C N</td>
<td>B90B</td>
<td>7-340</td>
</tr>
<tr>
<td>SLGK</td>
<td>SUBTRACT LOGICAL (64)</td>
<td>RRF-a C DO</td>
<td>B9EB</td>
<td>7-340</td>
</tr>
<tr>
<td>SLHHR</td>
<td>SUBTRACT LOGICAL HIGH (32)</td>
<td>RRF-a C HW</td>
<td>B9CB</td>
<td>7-341</td>
</tr>
<tr>
<td>SLHHLR</td>
<td>SUBTRACT LOGICAL HIGH (32)</td>
<td>RRF-a C HW</td>
<td>B9DB</td>
<td>7-341</td>
</tr>
<tr>
<td>SLI</td>
<td>SHIFT LEFT SINGLE LOGICAL (32)</td>
<td>RS-a</td>
<td>89</td>
<td>7-324</td>
</tr>
<tr>
<td>SLLG</td>
<td>SHIFT LEFT SINGLE LOGICAL (64)</td>
<td>RSY-a C N</td>
<td>EB0D</td>
<td>7-324</td>
</tr>
<tr>
<td>SLLE</td>
<td>SHIFT LEFT SINGLE LOGICAL (32)</td>
<td>RSY-a DO</td>
<td>EB0F</td>
<td>7-324</td>
</tr>
<tr>
<td>SLR</td>
<td>SUBTRACT LOGICAL (32)</td>
<td>RR C</td>
<td>1F</td>
<td>7-339</td>
</tr>
<tr>
<td>SLRK</td>
<td>SUBTRACT LOGICAL (32)</td>
<td>RRF-a C DO</td>
<td>BEFB</td>
<td>7-340</td>
</tr>
<tr>
<td>SLXT</td>
<td>SHIFT SIGNIFICAND LEFT (extended DFP)</td>
<td>RXF TF $ d&lt;9 Dd</td>
<td>ED48</td>
<td>20-53</td>
</tr>
<tr>
<td>SLY</td>
<td>SUBTRACT LOGICAL (32)</td>
<td>RXY-a C LD A Dg DF ST</td>
<td>B1B1</td>
<td>B1B1</td>
</tr>
<tr>
<td>SLP</td>
<td>SUBTRACT DECIMAL</td>
<td>SS-b C $ A Dg DF ST</td>
<td>B2A0</td>
<td>10-120</td>
</tr>
<tr>
<td>SPKA</td>
<td>SET PSW KEY FROM ADDRESS</td>
<td>S Q</td>
<td>04</td>
<td>7-321</td>
</tr>
<tr>
<td>SPM</td>
<td>SET PROGRAM MASK</td>
<td>RR L</td>
<td>B208</td>
<td>10-119</td>
</tr>
<tr>
<td>SPT</td>
<td>SET CPU TIMER</td>
<td>S P A SP</td>
<td>B210</td>
<td>10-119</td>
</tr>
<tr>
<td>SPX</td>
<td>SET PREFIX</td>
<td>S P A SP</td>
<td>B210</td>
<td>10-119</td>
</tr>
<tr>
<td>SQD</td>
<td>SQUARE ROOT (long HFP)</td>
<td>RXE $ d&lt;9 A Da SQ</td>
<td>B35</td>
<td>18-23</td>
</tr>
<tr>
<td>SQDB</td>
<td>SQUARE ROOT (long BFP)</td>
<td>RXE $ d&lt;9 A Db Xi Xx</td>
<td>B315</td>
<td>19-40</td>
</tr>
<tr>
<td>SQDBR</td>
<td>SQUARE ROOT (long BFP)</td>
<td>RRE $ d&lt;9 Da SQ</td>
<td>B244</td>
<td>18-23</td>
</tr>
<tr>
<td>SQDR</td>
<td>SQUARE ROOT (long HFP)</td>
<td>RRE $ d&lt;9 Da SQ</td>
<td>B336</td>
<td>18-23</td>
</tr>
<tr>
<td>SQE</td>
<td>SQUARE ROOT (short HFP)</td>
<td>RXE $ d&lt;9 A Da SQ</td>
<td>B336</td>
<td>18-23</td>
</tr>
<tr>
<td>SQEB</td>
<td>SQUARE ROOT (short BFP)</td>
<td>RXE $ d&lt;9 A Db Xi Xx</td>
<td>B245</td>
<td>18-23</td>
</tr>
<tr>
<td>SQEBR</td>
<td>SQUARE ROOT (short BFP)</td>
<td>RRE $ d&lt;9 Da SQ</td>
<td>B316</td>
<td>19-40</td>
</tr>
<tr>
<td>SQER</td>
<td>SQUARE ROOT (short HFP)</td>
<td>RRE $ d&lt;9 Da SQ</td>
<td>B245</td>
<td>18-23</td>
</tr>
<tr>
<td>SQXBR</td>
<td>SQUARE ROOT (extended BFP)</td>
<td>RRE $ d&lt;9 Da SQ</td>
<td>B316</td>
<td>19-40</td>
</tr>
<tr>
<td>SQXR</td>
<td>SQUARE ROOT (extended HFP)</td>
<td>RRE $ d&lt;9 Da SQ</td>
<td>B336</td>
<td>18-23</td>
</tr>
<tr>
<td>SR</td>
<td>SUBTRACT (32)</td>
<td>RR C</td>
<td>1B</td>
<td>7-338</td>
</tr>
<tr>
<td>SRA</td>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>RS-a C</td>
<td>8A</td>
<td>7-326</td>
</tr>
<tr>
<td>SRAG</td>
<td>SHIFT RIGHT SINGLE (64)</td>
<td>RSY-a C N</td>
<td>EB0A</td>
<td>7-326</td>
</tr>
<tr>
<td>SRAK</td>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>RSY-a C DO</td>
<td>EBDC</td>
<td>7-326</td>
</tr>
<tr>
<td>SRDA</td>
<td>SHIFT RIGHT DOUBLE (64)</td>
<td>RS-a C SP</td>
<td>8E</td>
<td>7-325</td>
</tr>
<tr>
<td>SRLD</td>
<td>SHIFT RIGHT DOUBLE LOGICAL (64)</td>
<td>RS-a SP</td>
<td>8C</td>
<td>7-325</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 16 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRDT</td>
<td>SHIFT SIGNIFICAND RIGHT (long DFP)</td>
<td>RXF TF $d^3d$ Da IF</td>
<td>ED41</td>
<td>20-53</td>
</tr>
<tr>
<td>SRK</td>
<td>SUBTRACT (32)</td>
<td>RRF-a C DO</td>
<td>B9F9</td>
<td>7-338</td>
</tr>
<tr>
<td>SRL</td>
<td>SHIFT RIGHT SINGLE LOGICAL (32)</td>
<td>RS-a</td>
<td>88</td>
<td>7-327</td>
</tr>
<tr>
<td>SRLG</td>
<td>SHIFT RIGHT SINGLE LOGICAL (64)</td>
<td>RSY-a N</td>
<td>EB0C</td>
<td>7-327</td>
</tr>
<tr>
<td>SRNM</td>
<td>SET BFP Rounding Mode (2 bit)</td>
<td>S $d^3d$ Db</td>
<td>B299</td>
<td>9-47</td>
</tr>
<tr>
<td>SRNMB</td>
<td>SET BFP Rounding Mode (3 bit)</td>
<td>S F $d^3d$ Sp Db</td>
<td>B28B</td>
<td>9-47</td>
</tr>
<tr>
<td>SRNMT</td>
<td>SET DFP Rounding Mode</td>
<td>S TR $d3d$ Dt</td>
<td>B2B9</td>
<td>9-47</td>
</tr>
<tr>
<td>SRP</td>
<td>SHIFT AND ROUND DECIMAL</td>
<td>SS-c C $d3d$ Ax Da Dg DF</td>
<td>ST</td>
<td>B8 B8 F0</td>
</tr>
<tr>
<td>SRST</td>
<td>SEARCH STRING</td>
<td>RRE C $s3s$ A Sp IC G0</td>
<td>R8 R8 B25E</td>
<td>7-317</td>
</tr>
<tr>
<td>SRSTU</td>
<td>SEARCH STRING UNICODE</td>
<td>RRE C E3 $s3s$ A Sp IC G0</td>
<td>R8 R8 B233</td>
<td>14-15</td>
</tr>
<tr>
<td>SRXT</td>
<td>SHIFT SIGNIFICAND RIGHT (extended DFP)</td>
<td>RXF TF $d3d$ Sp Dt</td>
<td>ED49</td>
<td>20-53</td>
</tr>
<tr>
<td>SSAIR</td>
<td>SET SECONDARY ASN WITH INSTANCE</td>
<td>RRE RA $d3d$ Ax $z7d$ T $c$</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SSAR</td>
<td>SET SECONDARY ASN</td>
<td>S C $s3s$ A Sp Op $c$ GS</td>
<td>B233</td>
<td>14-15</td>
</tr>
<tr>
<td>SSCH</td>
<td>START SUBCHANNEL</td>
<td>S C P A Sp Op $c$ GS</td>
<td>B233</td>
<td>14-15</td>
</tr>
<tr>
<td>SSKE</td>
<td>SET STORAGE KEY EXTENDED</td>
<td>RRF-c C $d3d$ Ax Da II $c$</td>
<td>B22B</td>
<td>10-126</td>
</tr>
<tr>
<td>SSM</td>
<td>SET SYSTEM MASK</td>
<td>S P A Sp SO</td>
<td>B9F9</td>
<td>10-120</td>
</tr>
<tr>
<td>ST</td>
<td>STORE (32)</td>
<td>RX-a A</td>
<td>ST</td>
<td>B5</td>
</tr>
<tr>
<td>STAM</td>
<td>STORE ACCESS MULTIPLE</td>
<td>RSY-a LD A Sp</td>
<td>ST</td>
<td>UB</td>
</tr>
<tr>
<td>STAMY</td>
<td>STORE ACCESS MULTIPLE</td>
<td>RSY-a LD A Sp</td>
<td>ST</td>
<td>UB</td>
</tr>
<tr>
<td>STAP</td>
<td>STORE CPU ADDRESS</td>
<td>S P A Sp</td>
<td>ST</td>
<td>B212</td>
</tr>
<tr>
<td>STC</td>
<td>STORE CHARACTER</td>
<td>RX-a A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STCH</td>
<td>STORE CHARACTER (high)</td>
<td>RX-y A HW A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STCK</td>
<td>STORE CLOCK</td>
<td>S C $s3s$ A $s$</td>
<td>ST</td>
<td>B205</td>
</tr>
<tr>
<td>STCKC</td>
<td>STORE CLOCK COMPRESSOR</td>
<td>S P A Sp</td>
<td>ST</td>
<td>B207</td>
</tr>
<tr>
<td>STCKE</td>
<td>STORE CLOCK EXTENDED</td>
<td>S C $s3s$ A $s$</td>
<td>ST</td>
<td>B278</td>
</tr>
<tr>
<td>STCKF</td>
<td>STORE CLOCK FAST</td>
<td>S C SC $s3s$ A</td>
<td>ST</td>
<td>B27C</td>
</tr>
<tr>
<td>STM</td>
<td>STORE CHARACTERS UNDER MASK (low)</td>
<td>Rs-b</td>
<td>A</td>
<td>ST</td>
</tr>
<tr>
<td>STCMY</td>
<td>STORE CHARACTERS UNDER MASK (low)</td>
<td>RSY-b LD A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STOPS</td>
<td>STORE CHANNEL PATH STATUS</td>
<td>S P A Sp</td>
<td>ST</td>
<td>B23A</td>
</tr>
<tr>
<td>STCW</td>
<td>STORE CHANNEL REPORT WORD</td>
<td>S C P A Sp</td>
<td>ST</td>
<td>B239</td>
</tr>
<tr>
<td>STCTG</td>
<td>STORE CONTROL (64)</td>
<td>RSY-a N P A Sp</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STCTL</td>
<td>STORE CONTROL (32)</td>
<td>RS-a P A Sp</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STCY</td>
<td>STORE CHARACTER</td>
<td>RX-y A LD A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STD</td>
<td>STORE (long)</td>
<td>RX-a $d3d$ A Da</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STDY</td>
<td>STORE (long)</td>
<td>RX-y A LD $d3d$ A Da</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STE</td>
<td>STORE (short)</td>
<td>RX-a $d3d$ Da</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STEY</td>
<td>STORE (short)</td>
<td>RX-y A LD $d3d$ A Da</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STFH</td>
<td>STORE HIGH (32)</td>
<td>RX-y A HW A</td>
<td>ST</td>
<td>E3CB</td>
</tr>
<tr>
<td>STFLE</td>
<td>STORE FACILITY LIST EXTENDED</td>
<td>S C FL $d3d$ A Sp</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STFPC</td>
<td>STORE FPC</td>
<td>S $d3d$ A Db</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STG</td>
<td>STORE (64)</td>
<td>RX-y a N A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STGLR</td>
<td>STORE RELATIVE LONG (64)</td>
<td>RIL-b GE A&quot; Sp</td>
<td>ST</td>
<td>C4B</td>
</tr>
<tr>
<td>STH</td>
<td>STORE HALFWORD (16)</td>
<td>RX-a A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STHL</td>
<td>STORE HALFWORD HIGH (16)</td>
<td>RX-y a HW A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STHR</td>
<td>STORE HALFWORD RELATIVE LONG (16)</td>
<td>RIL-b GE A&quot;</td>
<td>ST</td>
<td>C4C7</td>
</tr>
<tr>
<td>STHY</td>
<td>STORE HALFWORD (16)</td>
<td>RX-y a LD A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STM</td>
<td>STORE MULTIPLE (32)</td>
<td>RS-a A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STMG</td>
<td>STORE MULTIPLE (64)</td>
<td>RSY-a N A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STMH</td>
<td>STORE MULTIPLE HIGH (32)</td>
<td>RSY-a N A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STMY</td>
<td>STORE MULTIPLE</td>
<td>RSY-a LD A</td>
<td>ST</td>
<td>B2</td>
</tr>
<tr>
<td>STNSM</td>
<td>STORE THEN AND SYSTEM MASK</td>
<td>SI P A</td>
<td>ST</td>
<td>B2</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 17 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>STOC</td>
<td>STORE ON CONDITION (32)</td>
<td>RSY-b L1 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STOCFH</td>
<td>STORE HIGH ON CONDITION</td>
<td>RSY-b L2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STOCG</td>
<td>STORE ON CONDITION (64)</td>
<td>RSY-b L1 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STOSM</td>
<td>STORE THEN OR SYSTEM MASK</td>
<td>SI P A SP</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STPO</td>
<td>STORE PAIR TO QUADWORD</td>
<td>RXY-a N ^2 A SP</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STPT</td>
<td>STORE CPU TIMER</td>
<td>S P A SP</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STPX</td>
<td>STORE PREFIX</td>
<td>S P A SP</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STRAG</td>
<td>STORE REAL ADDRESS</td>
<td>SSE N P A1 SP</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STRL</td>
<td>STORE RELATIVE LONG (32)</td>
<td>RIL-b GE A* SP</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STRV</td>
<td>STORE REVERSED (32)</td>
<td>RXY-a N3 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STRVG</td>
<td>STORE REVERSED (64)</td>
<td>RXY-a N A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STRVH</td>
<td>STORE REVERSED (16)</td>
<td>RXY-a N3 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STSCH</td>
<td>STORE SUBCHANNEL</td>
<td>S C P A SP OP c GS</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STSI</td>
<td>STORE SYSTEM INFORMATION</td>
<td>RXY-a N P A1 SP</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STURA</td>
<td>STORE USING REAL ADDRESS (32)</td>
<td>RRE P A1 SP</td>
<td>SU</td>
<td>B246 10-159</td>
</tr>
<tr>
<td>STURG</td>
<td>STORE USING REAL ADDRESS (64)</td>
<td>RRE N P A1 SP</td>
<td>SU</td>
<td>B295 10-159</td>
</tr>
<tr>
<td>STY</td>
<td>STORE (32)</td>
<td>RXY-a N A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STY</td>
<td>STORE (64)</td>
<td>RXY-a N A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>STY</td>
<td>STORE (32)</td>
<td>RXY-a N A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SU</td>
<td>SUBTRACT UNNORMALIZED (short HFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SVC</td>
<td>SUBTRACT UNNORMALIZED (short HFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SW</td>
<td>SUBTRACT UNNORMALIZED (long HFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SWR</td>
<td>SUBTRACT UNNORMALIZED (long HFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SXBR</td>
<td>SUBTRACT (extended BFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SXR</td>
<td>SUBTRACT (extended BFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SXSTR</td>
<td>SUBTRACT (extended DFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SXTRA</td>
<td>SUBTRACT (extended DFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>SY</td>
<td>SUBTRACT (extended DFP)</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TABORT</td>
<td>TRANSACTION ABORT</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TAM</td>
<td>TRANSACTION ABORT</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TAR</td>
<td>TRANSACTION ABORT</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TB</td>
<td>TRANSACTION ABORT</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TBDR</td>
<td>TRANSACTION ABORT</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TBEGIN</td>
<td>TRANSACTION ABORT</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TBEGINC</td>
<td>TRANSACTION ABORT</td>
<td>RX-a C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TCDT</td>
<td>TEST DATA CLASS (long DFP)</td>
<td>RXE C ^2 ^2 D</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TCEB</td>
<td>TEST DATA CLASS (short DFP)</td>
<td>RXE C ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TCXB</td>
<td>TEST DATA CLASS (extended BFP)</td>
<td>RXE C ^2 ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TDCET</td>
<td>TEST DATA CLASS (short DFP)</td>
<td>RXE C ^2 ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TDCT</td>
<td>TEST DATA CLASS (extended DFP)</td>
<td>RXE C ^2 ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TDGDT</td>
<td>TEST DATA GROUP (long DFP)</td>
<td>RXE C ^2 ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TDGET</td>
<td>TEST DATA GROUP (short DFP)</td>
<td>RXE C ^2 ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TDGXT</td>
<td>TEST DATA GROUP (extended DFP)</td>
<td>RXE C ^2 ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TEND</td>
<td>TRANSACTION ABORT</td>
<td>RXE C ^2 ^2 A</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>THER</td>
<td>CONVERT HFP TO BFP (long)</td>
<td>RXE C ^2 ^2 D</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>ThDR</td>
<td>CONVERT HFP TO BFP (long)</td>
<td>RXE C ^2 ^2 D</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TM</td>
<td>TEST UNDER MASK</td>
<td>RXE C ^2 ^2 D</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>TMH</td>
<td>TEST UNDER MASK</td>
<td>RXE C ^2 ^2 D</td>
<td>ST</td>
<td>B3</td>
</tr>
<tr>
<td>Mnemonic</td>
<td>Name</td>
<td>Characteristics</td>
<td>Op-code</td>
<td>Page</td>
</tr>
<tr>
<td>-------------------</td>
<td>-------------------------------------------</td>
<td>-----------------</td>
<td>---------</td>
<td>------</td>
</tr>
<tr>
<td>TP</td>
<td>TEST DECIMAL</td>
<td>$o^7$ A</td>
<td>$B_1$, $B_2$</td>
<td>EBC0</td>
</tr>
<tr>
<td>TPI</td>
<td>TEST PENDING INTERRUPTION</td>
<td>$P$ $A^P$ SP $c$</td>
<td>$B_3$, $B_2$</td>
<td>B236</td>
</tr>
<tr>
<td>TPROT</td>
<td>TEST PROTECTION</td>
<td>$P$ $A^P$</td>
<td>$B_4$,</td>
<td></td>
</tr>
<tr>
<td>TR</td>
<td>TRANSLATE</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>TRACG</td>
<td>TRACG (64)</td>
<td>$P$ $A$ SP $T$ $c$</td>
<td>$B_4$</td>
<td>10-166</td>
</tr>
<tr>
<td>TRAP2</td>
<td>TRAP</td>
<td>$p^i$ A</td>
<td>ST $T$</td>
<td>B2FF</td>
</tr>
<tr>
<td>TRAP4</td>
<td>TRAP</td>
<td>$p^i$ A</td>
<td>ST $T$</td>
<td>B2FF</td>
</tr>
<tr>
<td>TR</td>
<td>TRANSLATE EXTENDED</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>TRO</td>
<td>TRANSLATE ONE TO ONE</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>TROT</td>
<td>TRANSLATE ONE TO TWO</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>TRT</td>
<td>TRANSLATE AND TEST</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>TRTRE</td>
<td>TRANSLATE AND TEST REVERSE</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>TS</td>
<td>TEST AND SET</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>TSCH</td>
<td>TEST SUBCHANNEL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>UNPKA</td>
<td>UNPACK ASCII</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>UNPKU</td>
<td>UNPACK UNICODE</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>UPT</td>
<td>UPDATE TREE</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VA</td>
<td>VECTOR ADD</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VAC</td>
<td>VECTOR ADD WITH CARRY</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VACC</td>
<td>VECTOR ADD COMPUTE CARRY</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VACC1</td>
<td>VECTOR ADD WITH CARRY COMPUTE CARRY</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VAVG</td>
<td>VECTOR AVERAGE</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VAVGL</td>
<td>VECTOR AVERAGE LOGICAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCDG</td>
<td>VECTOR FP CONVERT FROM FIXED 64-BIT</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCDLG</td>
<td>VECTOR FP CONVERT FROM LOGICAL 64-BIT</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCEQ</td>
<td>VECTOR COMPARE EQUAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCGD</td>
<td>VECTOR FP CONVERT TO FIXED 64-BIT</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCH</td>
<td>VECTOR COMPARE HIGH</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCHL</td>
<td>VECTOR COMPARE HIGH LOGICAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCKSM</td>
<td>VECTOR CHECKSUM</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCLGD</td>
<td>VECTOR FP CONVERT TO LOGICAL 64-BIT</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCLZ</td>
<td>VECTOR COUNT LEADING ZEROS</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VCTZ</td>
<td>VECTOR COUNT TRAILING ZEROS</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VEC</td>
<td>VECTOR ELEMENT COMPARE</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VECL</td>
<td>VECTOR ELEMENT COMPARE LOGICAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VERIM</td>
<td>VECTOR ELEMENT ROTATE AND INSERT UNDER MASK</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VERLL</td>
<td>VECTOR ELEMENT ROTATE LEFT LOGICAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VERLLV</td>
<td>VECTOR ELEMENT ROTATE LEFT LOGICAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VESL</td>
<td>VECTOR ELEMENT SHIFT LEFT</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VESLV</td>
<td>VECTOR ELEMENT SHIFT LEFT</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VESRA</td>
<td>VECTOR ELEMENT SHIFT RIGHT ARITHMETIC</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VESRAV</td>
<td>VECTOR ELEMENT SHIFT RIGHT ARITHMETIC</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VESRAL</td>
<td>VECTOR ELEMENT SHIFT RIGHT LOGICAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VESRLV</td>
<td>VECTOR ELEMENT SHIFT RIGHT LOGICAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VFA</td>
<td>VECTOR FP ADD</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VFAE</td>
<td>VECTOR FIND ANY ELEMENT EQUAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VFCE</td>
<td>VECTOR FP COMPARE EQUAL</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
<tr>
<td>VFCH</td>
<td>VECTOR FP COMPARE HIGH</td>
<td>$o^7$ A</td>
<td>$B_2$</td>
<td></td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 19 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VFCHIE</td>
<td>VECTOR FP COMPARE HIGH OR EQUAL</td>
<td>VRR-c C* VF η SP Dv Xi</td>
<td>E7EA 24-12</td>
</tr>
<tr>
<td>VFDFD</td>
<td>VECTOR FP DIVIDE</td>
<td>VRR-c VF η SP Dv Xi Xz Xo Xx</td>
<td>E7E5 24-20</td>
</tr>
<tr>
<td>VFEE</td>
<td>VECTOR FIND ELEMENT EQUAL</td>
<td>VRR-b C* VF η SP Dv</td>
<td>E7B0 23-3</td>
</tr>
<tr>
<td>VFEN</td>
<td>VECTOR FIND ELEMENT NOT EQUAL</td>
<td>VRR-c C* VF η SP Dv</td>
<td>E7B1 23-4</td>
</tr>
<tr>
<td>VFI</td>
<td>VECTOR LOAD FP INTEGER</td>
<td>VRR-a VF η SP Dv Xi Xx</td>
<td>E7C7 24-22</td>
</tr>
<tr>
<td>VFM</td>
<td>VECTOR FP MULTIPLY</td>
<td>VRR-c VF η SP Dv Xi Xo Xx</td>
<td>E7E7 24-26</td>
</tr>
<tr>
<td>VFMA</td>
<td>VECTOR FP MULTIPLY AND ADD</td>
<td>VRR-e VF η SP Dv Xi Xo Xx</td>
<td>E7BF 24-27</td>
</tr>
<tr>
<td>VFMS</td>
<td>VECTOR FP MULTIPLY AND SUBTRACT</td>
<td>VRR-e VF η SP Dv Xi Xo Xx</td>
<td>E7BE 24-27</td>
</tr>
<tr>
<td>VFPSO</td>
<td>VECTOR FP PERFORM SIGN OPERATION</td>
<td>VRR-a VF η SP Dv</td>
<td>E7CC 24-29</td>
</tr>
<tr>
<td>VFS</td>
<td>VECTOR FP SUBTRACT</td>
<td>VRR-c VF η SP Dv Xi Xo Xx</td>
<td>E7E2 24-31</td>
</tr>
<tr>
<td>VFSQ</td>
<td>VECTOR FP SQUARE ROOT</td>
<td>VRR-a VF η SP Dv Xi Xx</td>
<td>E7CE 24-30</td>
</tr>
<tr>
<td>VFTCI</td>
<td>VECTOR FP TEST DATA CLASS IMMEDIATE</td>
<td>VRI-e C VF η SP Dv</td>
<td>E74A 24-31</td>
</tr>
<tr>
<td>VGBM</td>
<td>VECTOR GENERATE BYTE MASK</td>
<td>VRI-a VF η SP Dv</td>
<td>E744 21-4</td>
</tr>
<tr>
<td>VGEF</td>
<td>VECTOR GATHER ELEMENT (32)</td>
<td>VRR-c VF η SP Dv</td>
<td>E713 21-4</td>
</tr>
<tr>
<td>VGEQ</td>
<td>VECTOR GATHER ELEMENT (64)</td>
<td>VRR-c VF η SP Dv</td>
<td>E712 21-4</td>
</tr>
<tr>
<td>VGFMA</td>
<td>VECTOR GALOIS FIELD MULTIPLY SUM</td>
<td>VRR-c VF η SP Dv</td>
<td>E784 22-11</td>
</tr>
<tr>
<td>VGMF</td>
<td>VECTOR GALOIS FIELD MULTIPLY SUM AND ACCUMULATE</td>
<td>VRR-d VF η SP Dv</td>
<td>E78C 22-11</td>
</tr>
<tr>
<td>VFM</td>
<td>VECTOR GENERATE MASK</td>
<td>VRI-a VF η SP Dv</td>
<td>E746 21-4</td>
</tr>
<tr>
<td>VISTR</td>
<td>VECTOR ISOLATE STRING</td>
<td>VRR-a C* VF η SP Dv</td>
<td>E75C 23-5</td>
</tr>
<tr>
<td>VL</td>
<td>VECTOR LOAD</td>
<td>VRR-c VF η SP Dv</td>
<td>E706 21-5</td>
</tr>
<tr>
<td>VLBB</td>
<td>VECTOR LOAD TO BLOCK BOUNDARY</td>
<td>VRR-c VF η SP Dv</td>
<td>E707 21-8</td>
</tr>
<tr>
<td>VLC</td>
<td>VECTOR LOAD COMPLEMENT</td>
<td>VRR-d VF η SP Dv</td>
<td>E70A 22-12</td>
</tr>
<tr>
<td>VLDE</td>
<td>VECTOR FP LOAD LENGTHENED</td>
<td>VRR-a VF η SP Dv Xi</td>
<td>E7C4 24-24</td>
</tr>
<tr>
<td>VLEB</td>
<td>VECTOR LOAD ELEMENT (8)</td>
<td>VRR-a VF η SP Dv</td>
<td>E700 21-6</td>
</tr>
<tr>
<td>VLED</td>
<td>VECTOR LOAD LENGTHENED</td>
<td>VRR-a VF η SP Dv</td>
<td>E701 21-6</td>
</tr>
<tr>
<td>VLEF</td>
<td>VECTOR LOAD ELEMENT (32)</td>
<td>VRR-a VF η SP Dv</td>
<td>E703 21-6</td>
</tr>
<tr>
<td>VLEG</td>
<td>VECTOR LOAD ELEMENT (64)</td>
<td>VRR-a VF η SP Dv</td>
<td>E702 21-6</td>
</tr>
<tr>
<td>VLEH</td>
<td>VECTOR LOAD ELEMENT (16)</td>
<td>VRR-a VF η SP Dv</td>
<td>E701 21-6</td>
</tr>
<tr>
<td>VLEIB</td>
<td>VECTOR LOAD ELEMENT IMMEDIATE (8)</td>
<td>VRR-a VF η SP Dv</td>
<td>E740 21-6</td>
</tr>
<tr>
<td>VLEIF</td>
<td>VECTOR LOAD ELEMENT IMMEDIATE (32)</td>
<td>VRR-a VF η SP Dv</td>
<td>E743 21-6</td>
</tr>
<tr>
<td>VLEGH</td>
<td>VECTOR LOAD ELEMENT IMMEDIATE (64)</td>
<td>VRR-a VF η SP Dv</td>
<td>E742 21-6</td>
</tr>
<tr>
<td>VLEIH</td>
<td>VECTOR LOAD ELEMENT IMMEDIATE (16)</td>
<td>VRR-a VF η SP Dv</td>
<td>E741 21-6</td>
</tr>
<tr>
<td>VLGV</td>
<td>VECTOR LOAD OR FROM VR ELEMENT</td>
<td>VRS-c VF η SP Dv</td>
<td>E721 21-7</td>
</tr>
<tr>
<td>VLL</td>
<td>VECTOR LOAD WITH LENGTH</td>
<td>VRS-a VF η SP Dv</td>
<td>E737 21-10</td>
</tr>
<tr>
<td>VLLZ</td>
<td>VECTOR LOAD LOGICAL ELEMENT AND ZERO</td>
<td>VRS-b VF η SP Dv</td>
<td>E704 21-7</td>
</tr>
<tr>
<td>VLML</td>
<td>VECTOR LOAD MULTIPLE</td>
<td>VRS-a VF η SP Dv</td>
<td>E736 21-8</td>
</tr>
<tr>
<td>VLP</td>
<td>VECTOR LOAD POSITIVE</td>
<td>VRR-a VF η SP Dv</td>
<td>E70F 22-12</td>
</tr>
<tr>
<td>VLR</td>
<td>VECTOR LOAD</td>
<td>VRR-a VF η SP Dv</td>
<td>E756 21-5</td>
</tr>
<tr>
<td>VLREP</td>
<td>VECTOR LOAD AND REPLICATE</td>
<td>VRR-a VF η SP Dv</td>
<td>E705 21-5</td>
</tr>
<tr>
<td>VLVG</td>
<td>VECTOR LOAD VR ELEMENT FROM GR</td>
<td>VRS-b VF η SP Dv</td>
<td>E722 21-9</td>
</tr>
<tr>
<td>VLVGP</td>
<td>VECTOR LOAD VR FROM GR DISJOINT</td>
<td>VRS-b VF η SP Dv</td>
<td>E762 21-9</td>
</tr>
<tr>
<td>VMAE</td>
<td>VECTOR MULTIPLY AND ADD EVEN</td>
<td>VRR-d VF η SP Dv</td>
<td>E7A8 22-15</td>
</tr>
<tr>
<td>VMAH</td>
<td>VECTOR MULTIPLY AND ADD HIGH</td>
<td>VRR-d VF η SP Dv</td>
<td>E7AB 22-14</td>
</tr>
<tr>
<td>VMAL</td>
<td>VECTOR MULTIPLY AND ADD LOW</td>
<td>VRR-d VF η SP Dv</td>
<td>E7AA 22-14</td>
</tr>
<tr>
<td>VMALE</td>
<td>VECTOR MULTIPLY AND ADD LOGICAL EVEN</td>
<td>VRR-d VF η SP Dv</td>
<td>E7AC 22-15</td>
</tr>
<tr>
<td>VMALH</td>
<td>VECTOR MULTIPLY AND ADD LOGICAL HIGH</td>
<td>VRR-d VF η SP Dv</td>
<td>E7A9 22-15</td>
</tr>
<tr>
<td>VMALO</td>
<td>VECTOR MULTIPLY AND ADD LOGICAL ODD</td>
<td>VRR-d VF η SP Dv</td>
<td>E7AD 22-16</td>
</tr>
<tr>
<td>VMAO</td>
<td>VECTOR MULTIPLY AND ADD ODD</td>
<td>VRR-d VF η SP Dv</td>
<td>E7AF 22-16</td>
</tr>
<tr>
<td>VME</td>
<td>VECTOR MULTIPLY EVEN</td>
<td>VRR-c VF η SP Dv</td>
<td>E7A6 22-17</td>
</tr>
<tr>
<td>VMH</td>
<td>VECTOR MULTIPLY HIGH</td>
<td>VRR-c VF η SP Dv</td>
<td>E7A3 22-16</td>
</tr>
<tr>
<td>VML</td>
<td>VECTOR MULTIPLY LOW</td>
<td>VRR-c VF η SP Dv</td>
<td>E7A2 22-17</td>
</tr>
<tr>
<td>VMLE</td>
<td>VECTOR MULTIPLY LOGICAL EVEN</td>
<td>VRR-c VF η SP Dv</td>
<td>E7A4 22-18</td>
</tr>
<tr>
<td>VMLH</td>
<td>VECTOR MULTIPLY LOGICAL HIGH</td>
<td>VRR-c VF η SP Dv</td>
<td>E7A1 22-16</td>
</tr>
<tr>
<td>VMLO</td>
<td>VECTOR MULTIPLY LOGICAL ODD</td>
<td>VRR-c VF η SP Dv</td>
<td>E7A5 22-18</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 20 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Opcode Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>VMN</td>
<td>VECTOR MINIMUM</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E7F</td>
</tr>
<tr>
<td>VMNL</td>
<td>VECTOR MINIMUM LOGICAL</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E7F</td>
</tr>
<tr>
<td>VMO</td>
<td>VECTOR MULTIPLY ODD</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E7A</td>
</tr>
<tr>
<td>VMRH</td>
<td>VECTOR MERGE HIGH</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E76</td>
</tr>
<tr>
<td>VMLR</td>
<td>VECTOR MERGE LOW</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E76</td>
</tr>
<tr>
<td>VMX</td>
<td>VECTOR MAXIMUM</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E7F</td>
</tr>
<tr>
<td>VMXL</td>
<td>VECTOR MAXIMUM LOGICAL</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E7F</td>
</tr>
<tr>
<td>VN</td>
<td>VECTOR AND</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E78</td>
</tr>
<tr>
<td>VNC</td>
<td>VECTOR AND WITH COMPLEMENT</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E79</td>
</tr>
<tr>
<td>VNO</td>
<td>VECTOR NOR</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E78</td>
</tr>
<tr>
<td>VO</td>
<td>VECTOR OR</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E7A</td>
</tr>
<tr>
<td>VPDIP</td>
<td>VECTOR PERMUTE DOUBLEWORD IMMEDIATE</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E7A</td>
</tr>
<tr>
<td>VPERM</td>
<td>VECTOR PERMUTE</td>
<td>VRR-e VF $^{7}_{3}$ Dv</td>
<td>E7C</td>
</tr>
<tr>
<td>VPX</td>
<td>VECTOR PACK</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E79</td>
</tr>
<tr>
<td>VPKLS</td>
<td>VECTOR PACK LOGICAL SATURATE</td>
<td>VRR-b C* VF $^{7}_{3}$ SP Dv</td>
<td>E79</td>
</tr>
<tr>
<td>VPKS</td>
<td>VECTOR PACK SATURATE</td>
<td>VRR-b C* VF $^{7}_{3}$ SP Dv</td>
<td>E77</td>
</tr>
<tr>
<td>VPOPC</td>
<td>VECTOR POPULATION COUNT</td>
<td>VRR-a VF $^{7}_{3}$ SP Dv</td>
<td>E75</td>
</tr>
<tr>
<td>VRP</td>
<td>VECTOR REPLICATE</td>
<td>VRI-c VF $^{7}_{3}$ SP Dv</td>
<td>E74</td>
</tr>
<tr>
<td>VREPI</td>
<td>VECTOR REPLICATE IMMEDIATE</td>
<td>VRI-a VF $^{7}_{3}$ SP Dv</td>
<td>E74</td>
</tr>
<tr>
<td>VS</td>
<td>VECTOR SUBTRACT</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E7F</td>
</tr>
<tr>
<td>VSBCBI</td>
<td>VECTOR SUBTRACT WITH BORROW COMPUTE BORROW INDICATION</td>
<td>VRR-d VF $^{7}_{3}$ SP Dv</td>
<td>E7B</td>
</tr>
<tr>
<td>VSBI</td>
<td>VECTOR SUBTRACT WITH BORROW INDICATION</td>
<td>VRR-d VF $^{7}_{3}$ SP Dv</td>
<td>E7B</td>
</tr>
<tr>
<td>VSCBI</td>
<td>VECTOR SUBTRACT COMPUTE BORROW INDICATION</td>
<td>VRR-d VF $^{7}_{3}$ SP Dv</td>
<td>E7F</td>
</tr>
<tr>
<td>VSCEF</td>
<td>VECTOR SCATTER ELEMENT (32)</td>
<td>VRR VF $^{7}_{3}$ A SP Dv</td>
<td>ST B3 E7B</td>
</tr>
<tr>
<td>VSCEG</td>
<td>VECTOR SCATTER ELEMENT (64)</td>
<td>VRR VF $^{7}_{3}$ A SP Dv</td>
<td>ST B3 E7B</td>
</tr>
<tr>
<td>VSEG</td>
<td>VECTOR SIGN EXTEND TO DOUBLEWORD</td>
<td>VRR-a VF $^{7}_{3}$ SP Dv</td>
<td>E75</td>
</tr>
<tr>
<td>VSEL</td>
<td>VECTOR SELECT</td>
<td>VRR-e VF $^{7}_{3}$ Dv</td>
<td>E78</td>
</tr>
<tr>
<td>VSL</td>
<td>VECTOR SHIFT LEFT</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E77</td>
</tr>
<tr>
<td>VSLB</td>
<td>VECTOR SHIFT LEFT BY BYTE</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E77</td>
</tr>
<tr>
<td>VSLDB</td>
<td>VECTOR SHIFT LEFT DOUBLE BY BYTE</td>
<td>VRI-d VF $^{7}_{3}$ Dv</td>
<td>E77</td>
</tr>
<tr>
<td>VSRA</td>
<td>VECTOR SHIFT RIGHT ARITHMETIC</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E77</td>
</tr>
<tr>
<td>VSRAB</td>
<td>VECTOR SHIFT RIGHT ARITHMETIC BY BYTE</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E77</td>
</tr>
<tr>
<td>VSRCL</td>
<td>VECTOR SHIFT RIGHT LOGICAL</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E77</td>
</tr>
<tr>
<td>VSRCLB</td>
<td>VECTOR SHIFT RIGHT LOGICAL BY BYTE</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E77</td>
</tr>
<tr>
<td>VST</td>
<td>VECTOR STORE</td>
<td>VRX VF $^{7}_{3}$ A Dv</td>
<td>ST B3 E70</td>
</tr>
<tr>
<td>VSTEB</td>
<td>VECTOR STORE ELEMENT (8)</td>
<td>VRX VF $^{7}_{3}$ A SP Dv</td>
<td>ST B3 E70</td>
</tr>
<tr>
<td>VSTEF</td>
<td>VECTOR STORE ELEMENT (32)</td>
<td>VRX VF $^{7}_{3}$ A SP Dv</td>
<td>ST B3 E70</td>
</tr>
<tr>
<td>VSTEG</td>
<td>VECTOR STORE ELEMENT (64)</td>
<td>VRX VF $^{7}_{3}$ A SP Dv</td>
<td>ST B3 E70</td>
</tr>
<tr>
<td>VSTEH</td>
<td>VECTOR STORE ELEMENT (16)</td>
<td>VRX VF $^{7}_{3}$ A SP Dv</td>
<td>ST B3 E70</td>
</tr>
<tr>
<td>VSTL</td>
<td>VECTOR STORE WITH LENGTH</td>
<td>VRS-b VF $^{7}_{3}$ A Dv</td>
<td>ST B3 E73</td>
</tr>
<tr>
<td>VSTM</td>
<td>VECTOR STORE MULTIPLE</td>
<td>VRS-a VF $^{7}_{3}$ A SP Dv</td>
<td>ST B3 E73</td>
</tr>
<tr>
<td>VSTRC</td>
<td>VECTOR STRING RANGE COMPARE</td>
<td>VRR-d C* VF $^{7}_{3}$ SP Dv</td>
<td>E7A</td>
</tr>
<tr>
<td>VSUM</td>
<td>VECTOR SUM ACROSS WORD</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E74</td>
</tr>
<tr>
<td>VSUMG</td>
<td>VECTOR SUM ACROSS DOUBLEWORD</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E75</td>
</tr>
<tr>
<td>VSUMQ</td>
<td>VECTOR SUM ACROSS QUADWORD</td>
<td>VRR-c VF $^{7}_{3}$ SP Dv</td>
<td>E76</td>
</tr>
<tr>
<td>VTM</td>
<td>VECTOR TEST UNDER MASK</td>
<td>VRR-a C VF $^{7}_{3}$ Dv</td>
<td>E7D</td>
</tr>
<tr>
<td>VUPH</td>
<td>VECTOR UNPACK HIGH</td>
<td>VRR-a VF $^{7}_{3}$ SP Dv</td>
<td>E7D</td>
</tr>
<tr>
<td>VUPL</td>
<td>VECTOR UNPACK LOW</td>
<td>VRR-a VF $^{7}_{3}$ SP Dv</td>
<td>E7D</td>
</tr>
<tr>
<td>VUPLH</td>
<td>VECTOR UNPACK LOGICAL HIGH</td>
<td>VRR-a VF $^{7}_{3}$ SP Dv</td>
<td>E7D</td>
</tr>
<tr>
<td>VUPLL</td>
<td>VECTOR UNPACK LOGICAL LOW</td>
<td>VRR-a VF $^{7}_{3}$ SP Dv</td>
<td>E7D</td>
</tr>
<tr>
<td>VX</td>
<td>VECTOR EXCLUSIVE OR</td>
<td>VRR-c VF $^{7}_{3}$ Dv</td>
<td>E7D</td>
</tr>
<tr>
<td>WFC</td>
<td>VECTOR FP COMPARE SCALAR</td>
<td>VRR-a C VF $^{7}_{3}$ SP Dv Xi</td>
<td>E7C</td>
</tr>
<tr>
<td>WFK</td>
<td>VECTOR FP COMPARE AND SIGNAL SCALAR</td>
<td>VRR-a C VF $^{7}_{3}$ SP Dv Xi</td>
<td>E7C</td>
</tr>
</tbody>
</table>

Figure B-2. Instructions Arranged by Mnemonic (Part 21 of 22)
<table>
<thead>
<tr>
<th>Mnemonic</th>
<th>Name</th>
<th>Characteristics</th>
<th>Op-code</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>X</td>
<td>EXCLUSIVE OR (32)</td>
<td>RX-a C</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>XC</td>
<td>EXCLUSIVE OR (character)</td>
<td>SS-a C</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>XG</td>
<td>EXCLUSIVE OR (64)</td>
<td>RXY-a C N A</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>XGR</td>
<td>EXCLUSIVE OR (64)</td>
<td>RRF-a C DO A</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>XI</td>
<td>EXCLUSIVE OR (immediate)</td>
<td>SI C A ST</td>
<td>C06</td>
<td>7-214</td>
</tr>
<tr>
<td>XIHF</td>
<td>EXCLUSIVE OR IMMEDIATE (high)</td>
<td>RIL-a C EI</td>
<td>C07</td>
<td>7-214</td>
</tr>
<tr>
<td>XIHF</td>
<td>EXCLUSIVE OR IMMEDIATE (low)</td>
<td>RIL-a C EI</td>
<td>C07</td>
<td>7-214</td>
</tr>
<tr>
<td>XIY</td>
<td>EXCLUSIVE OR (immediate)</td>
<td>SIY C LD A</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>XR</td>
<td>EXCLUSIVE OR (32)</td>
<td>RR C</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>XRF</td>
<td>EXCLUSIVE OR (32)</td>
<td>RRF-a C DO</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>XSCH</td>
<td>CANCEL SUBCHANNEL</td>
<td>S C P OP c GS</td>
<td>B276</td>
<td>14-3</td>
</tr>
<tr>
<td>XY</td>
<td>EXCLUSIVE OR (32)</td>
<td>RXY-a C LD A</td>
<td>ST</td>
<td>B1</td>
</tr>
<tr>
<td>ZAP</td>
<td>ZERO AND ADD</td>
<td>SS-b C</td>
<td>ST</td>
<td>B1</td>
</tr>
</tbody>
</table>

*Figure B-2: Instructions Arranged by Mnemonic (Part 22 of 22)*
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>0101</td>
<td>PROGRAM RETURN</td>
<td>PR</td>
<td>E L o<em>i A</em>i SP</td>
<td>B ST</td>
</tr>
<tr>
<td>0102</td>
<td>UPDATE TREE</td>
<td>UPT</td>
<td>E C o*i A SP</td>
<td>II GM I4</td>
</tr>
<tr>
<td>0104</td>
<td>PERFORM TIMING FACILITY FUNCTION</td>
<td>PTFF</td>
<td>E C TS Q A SP</td>
<td>GM ST</td>
</tr>
<tr>
<td>0107</td>
<td>SET CLOCK PROGRAMMABLE FIELD</td>
<td>SCKPF</td>
<td>E P SP</td>
<td>G0</td>
</tr>
<tr>
<td>010A</td>
<td>PERFORM FLOATING-POINT OPERATION</td>
<td>PFFO</td>
<td>E PF o*i SP Da</td>
<td>Xi Xo Xu Xq</td>
</tr>
<tr>
<td>010B</td>
<td>TEST ADDRESSING MODE</td>
<td>TAM</td>
<td>E C N3 o*i</td>
<td></td>
</tr>
<tr>
<td>010C</td>
<td>SET ADDRESSING MODE (24)</td>
<td>SAM24</td>
<td>E N3 o*i SP T</td>
<td></td>
</tr>
<tr>
<td>010D</td>
<td>SET ADDRESSING MODE (31)</td>
<td>SAM31</td>
<td>E N3 o*i SP T</td>
<td></td>
</tr>
<tr>
<td>010E</td>
<td>SET ADDRESSING MODE (64)</td>
<td>SAM64</td>
<td>E N o*i T</td>
<td></td>
</tr>
<tr>
<td>01FF</td>
<td>TRAP</td>
<td>TRAP2</td>
<td>E o<em>i A</em> SO T</td>
<td>B ST</td>
</tr>
<tr>
<td>04</td>
<td>SET PROGRAM MASK</td>
<td>SPM</td>
<td>RR L o*i</td>
<td></td>
</tr>
<tr>
<td>05</td>
<td>BRANCH AND LINK</td>
<td>BALR</td>
<td>RR o*i T</td>
<td>B</td>
</tr>
<tr>
<td>06</td>
<td>BRANCH ON COUNT (32)</td>
<td>BCTR</td>
<td>RR o*i</td>
<td></td>
</tr>
<tr>
<td>07</td>
<td>BRANCH ON CONDITION</td>
<td>BCR</td>
<td>RR o*i c</td>
<td>B</td>
</tr>
<tr>
<td>0A</td>
<td>SUPERVISOR CALL</td>
<td>SVC</td>
<td>I o*i c</td>
<td></td>
</tr>
<tr>
<td>0B</td>
<td>BRANCH AND SET MODE</td>
<td>BSM</td>
<td>RR o*i T</td>
<td>B</td>
</tr>
<tr>
<td>0C</td>
<td>BRANCH AND SAVE AND SET MODE</td>
<td>BASM</td>
<td>RR o*i,3 T</td>
<td>B</td>
</tr>
<tr>
<td>0D</td>
<td>BRANCH AND SAVE</td>
<td>BASR</td>
<td>RR o*i T</td>
<td>B</td>
</tr>
<tr>
<td>0E</td>
<td>MOVE LONG</td>
<td>MVCL</td>
<td>RR C o*i A SP</td>
<td>II ST</td>
</tr>
<tr>
<td>0F</td>
<td>COMPARE LOGICAL LONG</td>
<td>CLCL</td>
<td>RR C o*i A SP</td>
<td>II</td>
</tr>
<tr>
<td>10</td>
<td>LOAD POSITIVE (32)</td>
<td>LPR</td>
<td>RR C</td>
<td>IF</td>
</tr>
<tr>
<td>11</td>
<td>LOAD NEGATIVE (32)</td>
<td>LNR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>LOAD AND TEST (32)</td>
<td>LTR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>LOAD COMPLEMENT (32)</td>
<td>LCR</td>
<td>RR C</td>
<td>IF</td>
</tr>
<tr>
<td>14</td>
<td>AND (32)</td>
<td>NR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>COMPARE LOGICAL (32)</td>
<td>CLR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>OR (32)</td>
<td>OR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>EXCLUSIVE OR (32)</td>
<td>XR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>LOAD (32)</td>
<td>LR</td>
<td>RR</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>COMPARE (32)</td>
<td>CR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>1A</td>
<td>ADD (32)</td>
<td>AR</td>
<td>RR C</td>
<td>IF</td>
</tr>
<tr>
<td>1B</td>
<td>SUBTRACT (32)</td>
<td>SR</td>
<td>RR C</td>
<td>IF</td>
</tr>
<tr>
<td>1C</td>
<td>MULTIPLY (64+-32)</td>
<td>MR</td>
<td>RR SP</td>
<td></td>
</tr>
<tr>
<td>1D</td>
<td>DIVIDE (32+-64)</td>
<td>DR</td>
<td>RR o*i SP</td>
<td>IK</td>
</tr>
<tr>
<td>1E</td>
<td>ADD LOGICAL (32)</td>
<td>ALR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>1F</td>
<td>SUBTRACT LOGICAL (32)</td>
<td>SLR</td>
<td>RR C</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>LOAD POSITIVE (long HFP)</td>
<td>LPDR</td>
<td>RR C o*i</td>
<td>Da</td>
</tr>
<tr>
<td>21</td>
<td>LOAD NEGATIVE (long HFP)</td>
<td>LNDR</td>
<td>RR C o*i</td>
<td>Da</td>
</tr>
<tr>
<td>22</td>
<td>LOAD AND TEST (long HFP)</td>
<td>LTDGR</td>
<td>RR C o*i</td>
<td>Da</td>
</tr>
<tr>
<td>23</td>
<td>LOAD COMPLEMENT (long HFP)</td>
<td>LCGR</td>
<td>RR C o*i</td>
<td>Da</td>
</tr>
<tr>
<td>24</td>
<td>HALVE (long HFP)</td>
<td>HDR</td>
<td>RR o*i</td>
<td>Da EU</td>
</tr>
<tr>
<td>25</td>
<td>LOAD ROUNDED (extended to long HFP)</td>
<td>LDXR</td>
<td>RR o*i SP Da</td>
<td>EO</td>
</tr>
<tr>
<td>25</td>
<td>LOAD ROUNDED (extended to long HFP)</td>
<td>LDXR</td>
<td>RR o*i SP Da</td>
<td>EO</td>
</tr>
<tr>
<td>26</td>
<td>MULTIPLY (extended HFP)</td>
<td>MXR</td>
<td>RR o*i SP Da</td>
<td>EU EO</td>
</tr>
<tr>
<td>27</td>
<td>MULTIPLY (long to extended HFP)</td>
<td>MXHR</td>
<td>RR o*i SP Da</td>
<td>EU EO</td>
</tr>
<tr>
<td>28</td>
<td>LOAD (long)</td>
<td>LDLR</td>
<td>RR o*i</td>
<td>Da</td>
</tr>
<tr>
<td>29</td>
<td>COMPARE (long HFP)</td>
<td>CDR</td>
<td>RR C o*i</td>
<td>Da</td>
</tr>
<tr>
<td>2A</td>
<td>ADD NORMALIZED (long HFP)</td>
<td>ADXR</td>
<td>RR C o*i</td>
<td>Da EU EO LS</td>
</tr>
<tr>
<td>2B</td>
<td>SUBTRACT NORMALIZED (long HFP)</td>
<td>SDR</td>
<td>RR C o*i</td>
<td>Da EU EO LS</td>
</tr>
<tr>
<td>2C</td>
<td>MULTIPLY (long HFP)</td>
<td>MDR</td>
<td>RR o*i</td>
<td>Da EU EO</td>
</tr>
<tr>
<td>2D</td>
<td>DIVIDE (long HFP)</td>
<td>DDR</td>
<td>RR o*i</td>
<td>Da EU EO FK</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 1 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>2E</td>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>AWR</td>
<td>Da EO LS</td>
<td>18-9</td>
</tr>
<tr>
<td>2F</td>
<td>SUBTRACT UNNORMALIZED (long HFP)</td>
<td>SWR</td>
<td>Da EO LS</td>
<td>18-25</td>
</tr>
<tr>
<td>30</td>
<td>LOAD POSITIVE (short HFP)</td>
<td>LPER</td>
<td>Da</td>
<td>18-16</td>
</tr>
<tr>
<td>31</td>
<td>LOAD NEGATIVE (short HFP)</td>
<td>LNER</td>
<td>Da</td>
<td>18-16</td>
</tr>
<tr>
<td>32</td>
<td>LOAD AND TEST (short HFP)</td>
<td>LTER</td>
<td>Da</td>
<td>18-13</td>
</tr>
<tr>
<td>33</td>
<td>LOAD COMPLEMENT (short HFP)</td>
<td>LCER</td>
<td>Da</td>
<td>18-14</td>
</tr>
<tr>
<td>34</td>
<td>HALVE (short HFP)</td>
<td>HER</td>
<td>Da EU</td>
<td>18-13</td>
</tr>
<tr>
<td>35</td>
<td>LOAD ROUNDED (long to short HFP)</td>
<td>LEDR</td>
<td>Da EO</td>
<td>18-17</td>
</tr>
<tr>
<td>35</td>
<td>LOAD ROUNDED (long to short HFP)</td>
<td>LRER</td>
<td>Da EO</td>
<td>18-17</td>
</tr>
<tr>
<td>36</td>
<td>ADD NORMALIZED (extended HFP)</td>
<td>AXR</td>
<td>Da EU EO LS</td>
<td>18-8</td>
</tr>
<tr>
<td>37</td>
<td>SUBTRACT NORMALIZED (extended HFP)</td>
<td>SXR</td>
<td>Da EU EO LS</td>
<td>18-24</td>
</tr>
<tr>
<td>38</td>
<td>LOAD (short)</td>
<td>LER</td>
<td>Da</td>
<td>9-31</td>
</tr>
<tr>
<td>39</td>
<td>COMPARE (short HFP)</td>
<td>CER</td>
<td>Da</td>
<td>18-10</td>
</tr>
<tr>
<td>3A</td>
<td>ADD NORMALIZED (short HFP)</td>
<td>AER</td>
<td>Da EU EO LS</td>
<td>18-8</td>
</tr>
<tr>
<td>3B</td>
<td>SUBTRACT NORMALIZED (short HFP)</td>
<td>SER</td>
<td>Da EU EO LS</td>
<td>18-24</td>
</tr>
<tr>
<td>3C</td>
<td>MULTIPLY (short to long HFP)</td>
<td>MDER</td>
<td>Da EU EO</td>
<td>18-17</td>
</tr>
<tr>
<td>3C</td>
<td>MULTIPLY (short to long HFP)</td>
<td>MER</td>
<td>Da EU EO</td>
<td>18-18</td>
</tr>
<tr>
<td>3D</td>
<td>DIVIDE (short HFP)</td>
<td>DER</td>
<td>Da EU EO FK</td>
<td>18-12</td>
</tr>
<tr>
<td>3E</td>
<td>ADD UNNORMALIZED (short HFP)</td>
<td>AUR</td>
<td>Da EU EO LS</td>
<td>18-9</td>
</tr>
<tr>
<td>3F</td>
<td>SUBTRACT UNNORMALIZED (short HFP)</td>
<td>SXR</td>
<td>Da EO LS</td>
<td>18-25</td>
</tr>
<tr>
<td>40</td>
<td>STORE HALFWORD (16)</td>
<td>STH</td>
<td>ST B2</td>
<td>7-334</td>
</tr>
<tr>
<td>41</td>
<td>LOAD ADDRESS</td>
<td>LA</td>
<td>7-223</td>
<td></td>
</tr>
<tr>
<td>42</td>
<td>STORE CHARACTER</td>
<td>STC</td>
<td>B2</td>
<td>7-329</td>
</tr>
<tr>
<td>43</td>
<td>INSERT CHARACTER</td>
<td>IC</td>
<td>B2</td>
<td>7-219</td>
</tr>
<tr>
<td>44</td>
<td>EXECUTE</td>
<td>EX</td>
<td>B2</td>
<td>7-214</td>
</tr>
<tr>
<td>45</td>
<td>BRANCH AND LINK</td>
<td>BAL</td>
<td>B2</td>
<td>7-34</td>
</tr>
<tr>
<td>46</td>
<td>BRANCH ON COUNT (32)</td>
<td>BCT</td>
<td>B2</td>
<td>7-38</td>
</tr>
<tr>
<td>47</td>
<td>BRANCH ON CONDITION</td>
<td>BC</td>
<td>B2</td>
<td>7-37</td>
</tr>
<tr>
<td>48</td>
<td>LOAD HALFWORD (32→16)</td>
<td>LH</td>
<td>B2</td>
<td>7-231</td>
</tr>
<tr>
<td>49</td>
<td>COMPARE HALFWORD (32→16)</td>
<td>CH</td>
<td>B2</td>
<td>7-133</td>
</tr>
<tr>
<td>4A</td>
<td>ADD HALFWORD (32→16)</td>
<td>AH</td>
<td>B2</td>
<td>7-27</td>
</tr>
<tr>
<td>4B</td>
<td>SUBTRACT HALFWORD (32→16)</td>
<td>SH</td>
<td>B2</td>
<td>7-303</td>
</tr>
<tr>
<td>4C</td>
<td>MULTIPLY HALFWORD (32→16)</td>
<td>MH</td>
<td>B2</td>
<td>7-260</td>
</tr>
<tr>
<td>4D</td>
<td>BRANCH AND SAVE</td>
<td>BAS</td>
<td>B2</td>
<td>7-35</td>
</tr>
<tr>
<td>4E</td>
<td>CONVERT TO DECIMAL (32)</td>
<td>CVD</td>
<td>B2</td>
<td>7-189</td>
</tr>
<tr>
<td>4F</td>
<td>CONVERT TO BINARY (32)</td>
<td>CVB</td>
<td>B2</td>
<td>7-188</td>
</tr>
<tr>
<td>50</td>
<td>STORE (32)</td>
<td>ST</td>
<td>B2</td>
<td>7-327</td>
</tr>
<tr>
<td>51</td>
<td>LOAD ADDRESS EXTENDED</td>
<td>LAE</td>
<td>B2</td>
<td>7-223</td>
</tr>
<tr>
<td>54</td>
<td>AND (32)</td>
<td>N</td>
<td>B2</td>
<td>7-32</td>
</tr>
<tr>
<td>55</td>
<td>COMPARE LOGICAL (32)</td>
<td>CL</td>
<td>B2</td>
<td>7-135</td>
</tr>
<tr>
<td>56</td>
<td>OR (32)</td>
<td>O</td>
<td>B2</td>
<td>7-264</td>
</tr>
<tr>
<td>57</td>
<td>EXCLUSIVE OR (32)</td>
<td>X</td>
<td>B2</td>
<td>7-212</td>
</tr>
<tr>
<td>58</td>
<td>LOAD (32)</td>
<td>L</td>
<td>B2</td>
<td>7-221</td>
</tr>
<tr>
<td>59</td>
<td>COMPARE (32)</td>
<td>C</td>
<td>B2</td>
<td>7-117</td>
</tr>
<tr>
<td>5A</td>
<td>ADD (32)</td>
<td>A</td>
<td>B2</td>
<td>7-25</td>
</tr>
<tr>
<td>5B</td>
<td>SUBTRACT (32)</td>
<td>S</td>
<td>B2</td>
<td>7-338</td>
</tr>
<tr>
<td>5C</td>
<td>MULTIPLY (64→32)</td>
<td>M</td>
<td>B2</td>
<td>7-259</td>
</tr>
<tr>
<td>5D</td>
<td>DIVIDE (32→64)</td>
<td>D</td>
<td>B2</td>
<td>7-210</td>
</tr>
<tr>
<td>5E</td>
<td>ADD LOGICAL (32)</td>
<td>AL</td>
<td>B2</td>
<td>7-29</td>
</tr>
<tr>
<td>5F</td>
<td>SUBTRACT LOGICAL (32)</td>
<td>SL</td>
<td>B2</td>
<td>7-340</td>
</tr>
<tr>
<td>60</td>
<td>STORE (long)</td>
<td>STD</td>
<td>B2</td>
<td>9-48</td>
</tr>
<tr>
<td>67</td>
<td>MULTIPLY (long to extended HFP)</td>
<td>MXD</td>
<td>B2</td>
<td>18-18</td>
</tr>
<tr>
<td>68</td>
<td>LOAD (long)</td>
<td>LD</td>
<td>B2</td>
<td>9-31</td>
</tr>
<tr>
<td>69</td>
<td>COMPARE (long HFP)</td>
<td>CD</td>
<td>B2</td>
<td>18-10</td>
</tr>
<tr>
<td>6A</td>
<td>ADD NORMALIZED (long HFP)</td>
<td>AD</td>
<td>B2</td>
<td>18-8</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 2 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
</tr>
</thead>
<tbody>
<tr>
<td>6B</td>
<td>SUBTRACT NORMALIZED (long HFP)</td>
<td>SD RX-a C d12 A</td>
<td>Da EU EO LS B5 18-24</td>
</tr>
<tr>
<td>6C</td>
<td>MULTIPLY (long HFP)</td>
<td>MD RX-a d13 A</td>
<td>Da EU EO B5 18-18</td>
</tr>
<tr>
<td>6D</td>
<td>DIVIDE (long HFP)</td>
<td>DD RX-a d13 A</td>
<td>Da EU EO FK B5 18-12</td>
</tr>
<tr>
<td>6E</td>
<td>ADD UNNORMALIZED (long HFP)</td>
<td>AW RX-a C d13 A</td>
<td>Da EU EO LS B5 18-9</td>
</tr>
<tr>
<td>6F</td>
<td>SUBTRACT UNNORMALIZED (long HFP)</td>
<td>SW RX-a C d12 A</td>
<td>Da EU LS B5 18-25</td>
</tr>
<tr>
<td>70</td>
<td>STORE (short)</td>
<td>STE RX-a C d13 A</td>
<td>Da B2 9-48</td>
</tr>
<tr>
<td>71</td>
<td>MULTIPLY SINGLE (32)</td>
<td>MS RX-a A</td>
<td>B2 7-261</td>
</tr>
<tr>
<td>78</td>
<td>LOAD (short)</td>
<td>LE RX-a d13 A</td>
<td>Da B2 9-31</td>
</tr>
<tr>
<td>79</td>
<td>COMPARE (short HFP)</td>
<td>CE RX-a C d13 A</td>
<td>Da B2 18-10</td>
</tr>
<tr>
<td>7A</td>
<td>ADD NORMALIZED (short HFP)</td>
<td>AE RX-a C d12 A</td>
<td>Da EU EO LS B5 18-8</td>
</tr>
<tr>
<td>7B</td>
<td>SUBTRACT NORMALIZED (short HFP)</td>
<td>SE RX-a C d12 A</td>
<td>Da EU EO LS B5 18-24</td>
</tr>
<tr>
<td>7C</td>
<td>MULTIPLY (short to long HFP)</td>
<td>MDE RX-a C d13 A</td>
<td>Da EU EO B2 18-18</td>
</tr>
<tr>
<td>7D</td>
<td>DIVIDE (short HFP)</td>
<td>DE RX-a C d13 A</td>
<td>Da EU EO FK B2 18-12</td>
</tr>
<tr>
<td>7E</td>
<td>ADD UNNORMALIZED (short HFP)</td>
<td>AU RX-a C d12 A</td>
<td>Da EU LS B5 18-9</td>
</tr>
<tr>
<td>7F</td>
<td>SUBTRACT UNNORMALIZED (short HFP)</td>
<td>SU RX-a C d12 A</td>
<td>Da EU LS B5 18-25</td>
</tr>
<tr>
<td>80</td>
<td>SET SYSTEM MASK</td>
<td>SSM S P A SP SO</td>
<td>B2 10-129</td>
</tr>
<tr>
<td>82</td>
<td>LOAD PSW</td>
<td>LPSW S L P A SP c</td>
<td>B2 10-53</td>
</tr>
<tr>
<td>83</td>
<td>DIAGNOSE</td>
<td>DSM P DM B2 10-22</td>
<td></td>
</tr>
<tr>
<td>84</td>
<td>BRANCH RELATIVE ON INDEX HIGH (32)</td>
<td>BRXH RSI</td>
<td>B5 7-45</td>
</tr>
<tr>
<td>85</td>
<td>BRANCH RELATIVE ON INDEX LOW OR EQ. (32)</td>
<td>BRXLE RSI</td>
<td>B5 7-46</td>
</tr>
<tr>
<td>86</td>
<td>BRANCH ON INDEX HIGH (32)</td>
<td>BXH RS-a C d3</td>
<td>B5 7-39</td>
</tr>
<tr>
<td>87</td>
<td>BRANCH ON INDEX LOW OR EQUAL (32)</td>
<td>BXLE RS-a C d3</td>
<td>B5 7-39</td>
</tr>
<tr>
<td>88</td>
<td>SHIFT RIGHT SINGLE LOGICAL (32)</td>
<td>SRL RS-a</td>
<td>7-327</td>
</tr>
<tr>
<td>89</td>
<td>SHIFT LEFT SINGLE LOGICAL (32)</td>
<td>SLL RS-a</td>
<td>7-324</td>
</tr>
<tr>
<td>9A</td>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>SRA RS-a C</td>
<td>7-326</td>
</tr>
<tr>
<td>9B</td>
<td>SHIFT LEFT SINGLE (32)</td>
<td>SLA RS-a C</td>
<td>7-323</td>
</tr>
<tr>
<td>8C</td>
<td>SHIFT RIGHT DOUBLE LOGICAL (64)</td>
<td>SRDL RS-a SP</td>
<td>7-325</td>
</tr>
<tr>
<td>9C</td>
<td>SHIFT LEFT DOUBLE LOGICAL (64)</td>
<td>SLDL RS-a SP</td>
<td>7-323</td>
</tr>
<tr>
<td>9D</td>
<td>SHIFT RIGHT DOUBLE (64)</td>
<td>SRDA RS-a C SP</td>
<td>7-325</td>
</tr>
<tr>
<td>9E</td>
<td>SHIFT LEFT DOUBLE (64)</td>
<td>SDLA RS-a C SP</td>
<td>7-322</td>
</tr>
<tr>
<td>90</td>
<td>STORE MULTIPLE (32)</td>
<td>STM RS-a A</td>
<td>ST B5 7-335</td>
</tr>
<tr>
<td>91</td>
<td>TEST UNDER MASK</td>
<td>TM SI C A</td>
<td>B2 7-343</td>
</tr>
<tr>
<td>92</td>
<td>MOVE (immediate)</td>
<td>MVI SI C A</td>
<td>ST B2 7-245</td>
</tr>
<tr>
<td>93</td>
<td>TEST AND SET</td>
<td>TS S C d7 A $</td>
<td>ST B5 7-342</td>
</tr>
<tr>
<td>94</td>
<td>AND (immediate)</td>
<td>NI SI C A £2</td>
<td>ST B2 7-32</td>
</tr>
<tr>
<td>95</td>
<td>COMPARE LOGICAL (immediate)</td>
<td>CMI SI C A</td>
<td>B2 7-135</td>
</tr>
<tr>
<td>96</td>
<td>OR (immediate)</td>
<td>OR SI C A</td>
<td>ST B2 7-264</td>
</tr>
<tr>
<td>98</td>
<td>LOAD MULTIPLE (32)</td>
<td>LM RS-a A</td>
<td>B2 7-237</td>
</tr>
<tr>
<td>99</td>
<td>LOAD ACCESS MULTIPLE</td>
<td>TRACEM RS-a P A SP T c</td>
<td>B2 10-166</td>
</tr>
<tr>
<td>9A</td>
<td>STORE ACCESS MULTIPLE</td>
<td>STAM RS-a C A SP</td>
<td>UB 7-222</td>
</tr>
<tr>
<td>9B</td>
<td>STORE ACCESS MULTIPLE</td>
<td>STAM RS-a A SP</td>
<td>ST UB 7-328</td>
</tr>
<tr>
<td>A50</td>
<td>INSERT IMMEDIATE (high high)</td>
<td>IIHH Rl-a N</td>
<td>B2 7-221</td>
</tr>
<tr>
<td>A51</td>
<td>INSERT IMMEDIATE (high low)</td>
<td>IIHL Rl-a N</td>
<td>B2 7-221</td>
</tr>
<tr>
<td>A52</td>
<td>INSERT IMMEDIATE (low high)</td>
<td>IILH Rl-a N</td>
<td>B2 7-221</td>
</tr>
<tr>
<td>A53</td>
<td>INSERT IMMEDIATE (low low)</td>
<td>IILL Rl-a N</td>
<td>B2 7-221</td>
</tr>
<tr>
<td>A54</td>
<td>AND IMMEDIATE (high high)</td>
<td>NIHH Rl-a C N</td>
<td>B2 7-33</td>
</tr>
<tr>
<td>A55</td>
<td>AND IMMEDIATE (high low)</td>
<td>NIHL Rl-a C N</td>
<td>B2 7-33</td>
</tr>
<tr>
<td>A56</td>
<td>AND IMMEDIATE (low high)</td>
<td>NIIH Rl-a C N</td>
<td>B2 7-33</td>
</tr>
<tr>
<td>A57</td>
<td>AND IMMEDIATE (low low)</td>
<td>NILH Rl-a C N</td>
<td>B2 7-33</td>
</tr>
<tr>
<td>A58</td>
<td>OR IMMEDIATE (high high)</td>
<td>OIHH Rl-a C N</td>
<td>B2 7-265</td>
</tr>
<tr>
<td>A59</td>
<td>OR IMMEDIATE (high low)</td>
<td>OIHL Rl-a C N</td>
<td>B2 7-265</td>
</tr>
<tr>
<td>A5A</td>
<td>OR IMMEDIATE (low high)</td>
<td>OIII Rl-a C N</td>
<td>B2 7-266</td>
</tr>
<tr>
<td>A5B</td>
<td>OR IMMEDIATE (low low)</td>
<td>OILL Rl-a C N</td>
<td>B2 7-266</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 3 of 22)
<table>
<thead>
<tr>
<th>Opcode</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>A5C</td>
<td>LOAD LOGICAL IMMEDIATE (high high)</td>
<td>LLIHH</td>
<td>Ri-a N</td>
<td>7-236</td>
</tr>
<tr>
<td>A5D</td>
<td>LOAD LOGICAL IMMEDIATE (high low)</td>
<td>LLIHL</td>
<td>Ri-a N</td>
<td>7-236</td>
</tr>
<tr>
<td>A5E</td>
<td>LOAD LOGICAL IMMEDIATE (low high)</td>
<td>LLIH</td>
<td>Ri-a N</td>
<td>7-236</td>
</tr>
<tr>
<td>A5F</td>
<td>LOAD LOGICAL IMMEDIATE (low low)</td>
<td>LLLH</td>
<td>Ri-a N</td>
<td>7-236</td>
</tr>
<tr>
<td>A70</td>
<td>TEST UNDER MASK (low high)</td>
<td>TMLH</td>
<td>Ri-a C N</td>
<td>7-343</td>
</tr>
<tr>
<td>A71</td>
<td>TEST UNDER MASK (low low)</td>
<td>TMLL</td>
<td>Ri-a C N</td>
<td>7-343</td>
</tr>
<tr>
<td>A72</td>
<td>TEST UNDER MASK (high high)</td>
<td>TMH</td>
<td>Ri-a C</td>
<td>7-343</td>
</tr>
<tr>
<td>A73</td>
<td>TEST UNDER MASK (high low)</td>
<td>TMHL</td>
<td>Ri-a C N</td>
<td>7-343</td>
</tr>
<tr>
<td>A74</td>
<td>BRANCH RELATIVE ON COUNT (32)</td>
<td>BRCT</td>
<td>Ri-b</td>
<td>7-238</td>
</tr>
<tr>
<td>A75</td>
<td>BRANCH RELATIVE AND SAVE</td>
<td>BRAS</td>
<td>Ri-b</td>
<td>7-238</td>
</tr>
<tr>
<td>A76</td>
<td>BRANCH RELATIVE ON COUNT (64)</td>
<td>BRCTG</td>
<td>Ri-b</td>
<td>7-238</td>
</tr>
<tr>
<td>A77</td>
<td>BRANCH RELATIVE ON COUNT (64)</td>
<td>BRCTG</td>
<td>Ri-b</td>
<td>7-238</td>
</tr>
<tr>
<td>A78</td>
<td>LOAD HALFWORD IMMEDIATE (32)</td>
<td>LHIH</td>
<td>Ri-a</td>
<td>7-231</td>
</tr>
<tr>
<td>A79</td>
<td>LOAD HALFWORD IMMEDIATE (64)</td>
<td>LGHI</td>
<td>Ri-a C N</td>
<td>7-231</td>
</tr>
<tr>
<td>A7A</td>
<td>ADD HALFWORD IMMEDIATE (32)</td>
<td>AHII</td>
<td>Ri-a C</td>
<td>7-27</td>
</tr>
<tr>
<td>A7B</td>
<td>ADD HALFWORD IMMEDIATE (64)</td>
<td>AGHI</td>
<td>Ri-a C N</td>
<td>7-27</td>
</tr>
<tr>
<td>A7C</td>
<td>ADD HALFWORD IMMEDIATE (32)</td>
<td>MGHI</td>
<td>Ri-a N</td>
<td>7-260</td>
</tr>
<tr>
<td>A7D</td>
<td>ADD HALFWORD IMMEDIATE (64)</td>
<td>CHI</td>
<td>Ri-a C</td>
<td>7-133</td>
</tr>
<tr>
<td>A7E</td>
<td>ADD HALFWORD IMMEDIATE (32)</td>
<td>CBHI</td>
<td>Ri-a C N</td>
<td>7-133</td>
</tr>
<tr>
<td>A7F</td>
<td>ADD HALFWORD IMMEDIATE (64)</td>
<td>CBHI</td>
<td>Ri-a C N</td>
<td>7-133</td>
</tr>
<tr>
<td>A7A</td>
<td>ADD HALFWORD IMMEDIATE (32)</td>
<td>MGHI</td>
<td>Ri-a N</td>
<td>7-260</td>
</tr>
<tr>
<td>A8</td>
<td>MOVE LONG EXTENDED</td>
<td>MVCLE</td>
<td>Rs-a C</td>
<td>7-250</td>
</tr>
<tr>
<td>A9</td>
<td>COMPARE LOGICAL LONG EXTENDED</td>
<td>CLCLE</td>
<td>Rs-a C</td>
<td>7-143</td>
</tr>
<tr>
<td>A7G</td>
<td>STORE THEN AND SYSTEM MASK</td>
<td>STNSM</td>
<td>Si P A</td>
<td>10-158</td>
</tr>
<tr>
<td>A7H</td>
<td>STORE THEN OR SYSTEM MASK</td>
<td>STOSM</td>
<td>Si P A</td>
<td>10-158</td>
</tr>
<tr>
<td>A7I</td>
<td>SIGNAL PROCESSOR</td>
<td>SIGP</td>
<td>Rs-a C P</td>
<td>10-129</td>
</tr>
<tr>
<td>A7J</td>
<td>MONITOR CALL</td>
<td>MC</td>
<td>Si C</td>
<td>7-133</td>
</tr>
<tr>
<td>A7K</td>
<td>LOAD REAL ADDRESS (32)</td>
<td>LRA</td>
<td>Rx-a C P A</td>
<td>10-54</td>
</tr>
<tr>
<td>B202</td>
<td>STORE CPU ID</td>
<td>STIDP</td>
<td>S P A</td>
<td>10-132</td>
</tr>
<tr>
<td>B204</td>
<td>STORE CLOCK</td>
<td>SCK</td>
<td>S C P A</td>
<td>10-117</td>
</tr>
<tr>
<td>B205</td>
<td>STORE CLOCK COMPARETOR</td>
<td>STCK</td>
<td>S C P A</td>
<td>7-330</td>
</tr>
<tr>
<td>B206</td>
<td>STORE CLOCK COMPARETOR</td>
<td>STCKC</td>
<td>S P A</td>
<td>10-118</td>
</tr>
<tr>
<td>B207</td>
<td>STORE CLOCK COMPARETOR</td>
<td>STCKC</td>
<td>S P A</td>
<td>10-131</td>
</tr>
<tr>
<td>B208</td>
<td>STORE CPU TIMER</td>
<td>SPT</td>
<td>S P A</td>
<td>10-119</td>
</tr>
<tr>
<td>B209</td>
<td>STORE CPU TIMER</td>
<td>STPT</td>
<td>S P A</td>
<td>10-133</td>
</tr>
<tr>
<td>B210</td>
<td>STORE PSW KEY ADDRESS</td>
<td>SPKX</td>
<td>S Q</td>
<td>10-120</td>
</tr>
<tr>
<td>B211</td>
<td>INSERT PSW KEY</td>
<td>IPK</td>
<td>S Q</td>
<td>10-29</td>
</tr>
<tr>
<td>B212</td>
<td>PURGE TLB</td>
<td>PTLB</td>
<td>S P</td>
<td>10-112</td>
</tr>
<tr>
<td>B213</td>
<td>SET PSW KEY</td>
<td>SPX</td>
<td>S P A</td>
<td>10-119</td>
</tr>
<tr>
<td>B214</td>
<td>STORE PREADDRESS</td>
<td>STPX</td>
<td>S P A</td>
<td>10-134</td>
</tr>
<tr>
<td>B215</td>
<td>STORE CPU ADDRESS</td>
<td>STAP</td>
<td>S P A</td>
<td>10-132</td>
</tr>
<tr>
<td>B216</td>
<td>PROGRAM CALL</td>
<td>PC</td>
<td>Q A</td>
<td>7-86</td>
</tr>
<tr>
<td>B217</td>
<td>ADDRESS SPACE CONTROL</td>
<td>SAC</td>
<td>S Q SP SW</td>
<td>10-115</td>
</tr>
<tr>
<td>B218</td>
<td>COMPARE AND FORM CODER WORD</td>
<td>CFC</td>
<td>S C</td>
<td>7-120</td>
</tr>
<tr>
<td>B219</td>
<td>INVALIDATE PAGE TABLE ENTRY</td>
<td>IPTE</td>
<td>P A</td>
<td>10-36</td>
</tr>
<tr>
<td>B220</td>
<td>INSERT PROGRAM MASK</td>
<td>IPM</td>
<td>RRE</td>
<td>7-221</td>
</tr>
<tr>
<td>B221</td>
<td>INSERT VIRTUAL STORAGE KEY</td>
<td>IVSK</td>
<td>Q A</td>
<td>10-30</td>
</tr>
<tr>
<td>B222</td>
<td>INSERT ADDRESS SPACE CONTROL</td>
<td>IAC</td>
<td>RRE Q</td>
<td>10-28</td>
</tr>
<tr>
<td>B223</td>
<td>SET SECONDARY ASN</td>
<td>SSAR</td>
<td>RRE</td>
<td>10-120</td>
</tr>
<tr>
<td>B224</td>
<td>EXTRACT PRIMARY ASN</td>
<td>EPAR</td>
<td>RRE</td>
<td>10-23</td>
</tr>
<tr>
<td>B225</td>
<td>EXTRACT SECONDARY ASN</td>
<td>ESAR</td>
<td>RRE</td>
<td>10-24</td>
</tr>
<tr>
<td>B226</td>
<td>PROGRAM TRANSFER</td>
<td>PT</td>
<td>Q A</td>
<td>10-103</td>
</tr>
<tr>
<td>B227</td>
<td>INSERT STORAGE KEY EXTENDED</td>
<td>ISKE</td>
<td>RRE</td>
<td>10-29</td>
</tr>
<tr>
<td>B228</td>
<td>RESET REFERENCE BIT EXTENDED</td>
<td>RRRBE</td>
<td>RRE C P A</td>
<td>10-112</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 4 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>B22B</td>
<td>SET STORAGE KEY EXTENDED</td>
<td>SSKE RRF-c C P A&quot; II €</td>
<td>15-126</td>
</tr>
<tr>
<td>B22C</td>
<td>TEST BLOCK</td>
<td>TB RRE C P A&quot; II $ G0</td>
<td>10-161</td>
</tr>
<tr>
<td>B22D</td>
<td>DIVIDE (extended HFP)</td>
<td>DXR RRE 2^3 SP Da EU EO FK</td>
<td>18-12</td>
</tr>
<tr>
<td>B22E</td>
<td>PAGE IN</td>
<td>PGIN RRE C ES P A&quot; €</td>
<td>10-70</td>
</tr>
<tr>
<td>B22F</td>
<td>PAGE OUT</td>
<td>PGOUT RRE C ES P A&quot; €</td>
<td>10-71</td>
</tr>
<tr>
<td>B230</td>
<td>CLEAR SUBCHANNEL</td>
<td>CSCH S C P OP € GS</td>
<td>14-5</td>
</tr>
<tr>
<td>B231</td>
<td>HALT SUBCHANNEL</td>
<td>HSCH S C P OP € GS</td>
<td>14-6</td>
</tr>
<tr>
<td>B232</td>
<td>MODIFY SUBCHANNEL</td>
<td>MSCH S C P A SP OP € GS</td>
<td>B2</td>
</tr>
<tr>
<td>B233</td>
<td>START SUBCHANNEL</td>
<td>SSCH S C P A SP OP € GS</td>
<td>B2</td>
</tr>
<tr>
<td>B234</td>
<td>STORE SUBCHANNEL</td>
<td>STSCH S C P A SP OP € GS</td>
<td>ST B2</td>
</tr>
<tr>
<td>B235</td>
<td>TEST SUBCHANNEL</td>
<td>TSCH S C P A SP OP € GS</td>
<td>ST B2</td>
</tr>
<tr>
<td>B236</td>
<td>TEST PENDING INTERRUPTION</td>
<td>TPI S C P A SP €</td>
<td>ST B2</td>
</tr>
<tr>
<td>B237</td>
<td>SET ADDRESS LIMIT</td>
<td>SAL S P OP € G1</td>
<td>14-12</td>
</tr>
<tr>
<td>B238</td>
<td>RESUME SUBCHANNEL</td>
<td>RSCH S C P OP € GS</td>
<td>14-10</td>
</tr>
<tr>
<td>B239</td>
<td>STORE CHANNEL REPORT WORD</td>
<td>STCRW S C P A SP €</td>
<td>ST B2</td>
</tr>
<tr>
<td>B23A</td>
<td>STORE CHANNEL PATH STATUS</td>
<td>STCPS S C P A SP €</td>
<td>ST B2</td>
</tr>
<tr>
<td>B23B</td>
<td>RESET CHANNEL PATH</td>
<td>RCHP S C P</td>
<td>14-9</td>
</tr>
<tr>
<td>B23C</td>
<td>SET CHANNEL MONITOR</td>
<td>SOHM S P OP € GS</td>
<td>14-13</td>
</tr>
<tr>
<td>B240</td>
<td>BRANCH AND STACK</td>
<td>BAKR RRE 2^1 A* Z T</td>
<td>ST B2</td>
</tr>
<tr>
<td>B241</td>
<td>CHECKSUM</td>
<td>CKSM RRE C 2^9 A SP IC</td>
<td>R2</td>
</tr>
<tr>
<td>B244</td>
<td>SQUARE ROOT (long HFP)</td>
<td>SQDR RRE 2^3 Da SQ</td>
<td>18-23</td>
</tr>
<tr>
<td>B245</td>
<td>SQUARE ROOT (short HFP)</td>
<td>SQER RRE 2^3 Da SQ</td>
<td>18-23</td>
</tr>
<tr>
<td>B246</td>
<td>STORE USING REAL ADDRESS (32)</td>
<td>STURA RRE P A SP</td>
<td>SU</td>
</tr>
<tr>
<td>B247</td>
<td>MODIFY STACKED STATE</td>
<td>MSTA RRE 2^1 A* SP SE</td>
<td>ST</td>
</tr>
<tr>
<td>B248</td>
<td>PURGE ALB</td>
<td>PALB RRE P 2^1 $</td>
<td>10-112</td>
</tr>
<tr>
<td>B249</td>
<td>EXTRACT STACKED REGISTERS (32)</td>
<td>EREG RRE 2^1 A* SE</td>
<td>U1, U2</td>
</tr>
<tr>
<td>B24A</td>
<td>EXTRACT STACKED STATE</td>
<td>ESTA RRE C 2^1 A* SP SE</td>
<td>ST</td>
</tr>
<tr>
<td>B24B</td>
<td>LOAD USING REAL ADDRESS (32)</td>
<td>LLRA RRE P A SP</td>
<td>10-59</td>
</tr>
<tr>
<td>B24C</td>
<td>TEST ACCESS</td>
<td>TAR RRE C 2^1 A*</td>
<td>U1</td>
</tr>
<tr>
<td>B24D</td>
<td>COPY ACCESS</td>
<td>CPYA RRE 2^0</td>
<td>U1, U2</td>
</tr>
<tr>
<td>B24E</td>
<td>SET ACCESS</td>
<td>SAR RRE 2^0</td>
<td>U1</td>
</tr>
<tr>
<td>B24F</td>
<td>EXTRACT ACCESS</td>
<td>EAR RRE 2^0</td>
<td>U1</td>
</tr>
<tr>
<td>B250</td>
<td>COMPARE AND SWAP AND PURGE (32)</td>
<td>CSP RRE C P A SP $</td>
<td>ST R2</td>
</tr>
<tr>
<td>B252</td>
<td>MULTIPLY SINGLE (32)</td>
<td>MSR RRE</td>
<td>7-261</td>
</tr>
<tr>
<td>B254</td>
<td>MOVE PAGE</td>
<td>MVPG RRE C Q A SP G0</td>
<td>ST R1, R2</td>
</tr>
<tr>
<td>B255</td>
<td>MOVE STRING</td>
<td>MVST RRE C 2^3 A SP IC G0</td>
<td>ST R1, R2</td>
</tr>
<tr>
<td>B257</td>
<td>COMPARE UNTIL SUBSTRING EQUAL</td>
<td>CUSE RRE C 2^3 A SP II GM</td>
<td>ST R1, R2</td>
</tr>
<tr>
<td>B258</td>
<td>BRANCH IN SUBSPACE GROUP</td>
<td>BSS RRE 2^1 A* SO T</td>
<td>B</td>
</tr>
<tr>
<td>B259</td>
<td>BRANCH AND SET AUTHORITY</td>
<td>BSA RRE 2^0 A* SO T</td>
<td>B</td>
</tr>
<tr>
<td>B25D</td>
<td>COMPARE LOGICAL STRING</td>
<td>CLST RRE C 2^9 A SP IC G0</td>
<td>R1, R2</td>
</tr>
<tr>
<td>B25E</td>
<td>SEARCH STRING</td>
<td>SRST RRE C 2^9 A SP IC G0</td>
<td>R1, R2</td>
</tr>
<tr>
<td>B253</td>
<td>COMPRESSION CALL</td>
<td>CMPSC RRE C 2^5 A SP II Dg GM</td>
<td>ST R1, R2</td>
</tr>
<tr>
<td>B260</td>
<td>CANCEL SUBCHANNEL</td>
<td>XSCS RRE C P OP € GS</td>
<td>14-3</td>
</tr>
<tr>
<td>B277</td>
<td>RESUME PROGRAM</td>
<td>RP S L Q A SP WE T</td>
<td>B</td>
</tr>
<tr>
<td>B278</td>
<td>STORE CLOCK EXTENDED</td>
<td>STCKE S C 2^5 A SP $</td>
<td>ST B2</td>
</tr>
<tr>
<td>B279</td>
<td>SET ADDRESS SPACE CONTROL FAST</td>
<td>SACF S Q SP SW</td>
<td>10-116</td>
</tr>
<tr>
<td>B27C</td>
<td>STORE CLOCK FAST</td>
<td>STCKF S C SC 2^3 A</td>
<td>ST B2</td>
</tr>
<tr>
<td>B27D</td>
<td>STORE SYSTEM INFORMATION</td>
<td>STSI S C P A SP GM</td>
<td>ST B2</td>
</tr>
<tr>
<td>B279</td>
<td>SET BFP ROUNDING MODE (2 bit)</td>
<td>SRNM S 2^3 Db</td>
<td>9-47</td>
</tr>
<tr>
<td>B29C</td>
<td>STORE FPC</td>
<td>STFPC S 2^3 A Db</td>
<td>ST B2</td>
</tr>
<tr>
<td>B29D</td>
<td>LOAD FPC</td>
<td>LFPC S 2^3 A SP Db</td>
<td>ST B2</td>
</tr>
<tr>
<td>B2A5</td>
<td>TRANSLATE EXTENDED</td>
<td>TRE RRE C 2^3 A SP IC</td>
<td>ST R1, R2</td>
</tr>
<tr>
<td>B2A6</td>
<td>CONVERT UNICODE TO UTF-8</td>
<td>CUUTF RRF-c C 2^3 A SP IC</td>
<td>ST R1, R2</td>
</tr>
<tr>
<td>B2A6</td>
<td>CONVERT UTF-16 TO UTF-8</td>
<td>CU21 RRF-c C 2^3 A SP IC</td>
<td>ST R1, R2</td>
</tr>
<tr>
<td>B2AY</td>
<td>CONVERT UTF-8 TO UNICODE</td>
<td>CUTFU RRF-c C 2^3 A SP IC</td>
<td>ST R1, R2</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 5 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>B2A7</td>
<td>CONVERUTF8 TOUTF16</td>
<td>CU12</td>
<td>D1 A SP IC</td>
<td>7-202</td>
</tr>
<tr>
<td>B2B0</td>
<td>STORE FACILITY LIST EXTENDED</td>
<td>STFLE</td>
<td>A SP G0 ST</td>
<td>7-333</td>
</tr>
<tr>
<td>B2B1</td>
<td>STORE FACILITY LIST</td>
<td>STFL</td>
<td>N3 P</td>
<td>10-134</td>
</tr>
<tr>
<td>B2B2</td>
<td>LOAD PSW EXTENDED</td>
<td>LPSWE</td>
<td>L N P A SP c</td>
<td>10-53</td>
</tr>
<tr>
<td>B2B8</td>
<td>SET BFP ROUNING MODE (3 bit)</td>
<td>SRNMB</td>
<td>F SP D0</td>
<td>9-47</td>
</tr>
<tr>
<td>B2B9</td>
<td>SET DFP ROUNING MODE</td>
<td>SRNMT</td>
<td>TR D1 Xg</td>
<td>9-47</td>
</tr>
<tr>
<td>B2B2D</td>
<td>LOAD FPC AND SIGNAL</td>
<td>LFAS</td>
<td>XF A SP D1</td>
<td>9-32</td>
</tr>
<tr>
<td>B2B8</td>
<td>PERFORM PROCESSOR ASSIST</td>
<td>PPA</td>
<td>RRF-c PA D1</td>
<td>7-298</td>
</tr>
<tr>
<td>B2E8</td>
<td>TRANSACTION TRANSACTION NESTING DEPTH</td>
<td>ETND</td>
<td>RRE TX SO</td>
<td>7-218</td>
</tr>
<tr>
<td>B2FA</td>
<td>TRANSACTION END</td>
<td>TEND</td>
<td>C TX SO EX</td>
<td>7-351</td>
</tr>
<tr>
<td>B2FC</td>
<td>TRANSACTION ABORT</td>
<td>TABORT</td>
<td>S TX SO EX</td>
<td>7-344</td>
</tr>
<tr>
<td>B2FF</td>
<td>TRAP</td>
<td>TRAP4</td>
<td>C A* SO T B</td>
<td>10-167</td>
</tr>
<tr>
<td>B300</td>
<td>LOAD POSITIVE (short BFP)</td>
<td>LNEBR</td>
<td>RRE C D1</td>
<td>19-34</td>
</tr>
<tr>
<td>B301</td>
<td>LOAD NEGATIVE (short BFP)</td>
<td>LTEBR</td>
<td>RRE C D1</td>
<td>19-31</td>
</tr>
<tr>
<td>B302</td>
<td>LOAD AND TEST (short BFP)</td>
<td>LCEBR</td>
<td>RRE C D1</td>
<td>19-31</td>
</tr>
<tr>
<td>B304</td>
<td>LOAD LENGTHENED (short to long BFP)</td>
<td>LDEBR</td>
<td>RRE C D1</td>
<td>19-33</td>
</tr>
<tr>
<td>B305</td>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>LXDBR</td>
<td>RRE C D1</td>
<td>19-33</td>
</tr>
<tr>
<td>B306</td>
<td>LOAD LENGTHENED (short to extended BFP)</td>
<td>LXEBR</td>
<td>RRE C D1</td>
<td>19-33</td>
</tr>
<tr>
<td>B307</td>
<td>MULTIPLY (long to extended BFP)</td>
<td>MXDBR</td>
<td>RRE C D1</td>
<td>19-37</td>
</tr>
<tr>
<td>B308</td>
<td>COMPARE AND SIGNAL (short BFP)</td>
<td>KEBR</td>
<td>RRE C D1</td>
<td>19-18</td>
</tr>
<tr>
<td>B309</td>
<td>COMPARE (short BFP)</td>
<td>CEBR</td>
<td>RRE C D1</td>
<td>19-17</td>
</tr>
<tr>
<td>B30A</td>
<td>ADD (short BFP)</td>
<td>AEBR</td>
<td>RRE C D1</td>
<td>19-15</td>
</tr>
<tr>
<td>B30B</td>
<td>SUBTRACT (short BFP)</td>
<td>SEBR</td>
<td>RRE C D1</td>
<td>19-40</td>
</tr>
<tr>
<td>B30C</td>
<td>MULTIPLY (short to long BFP)</td>
<td>MDEBR</td>
<td>RRE C D1</td>
<td>19-37</td>
</tr>
<tr>
<td>B30D</td>
<td>DIVIDE (short BFP)</td>
<td>DEBR</td>
<td>RRE C D1</td>
<td>19-27</td>
</tr>
<tr>
<td>B30E</td>
<td>MULTIPLY AND ADD (short BFP)</td>
<td>MAEBR</td>
<td>RRD D1</td>
<td>19-38</td>
</tr>
<tr>
<td>B30F</td>
<td>MULTIPLY AND SUBTRACT (short BFP)</td>
<td>MSEBR</td>
<td>RRD D1</td>
<td>19-38</td>
</tr>
<tr>
<td>B310</td>
<td>LOAD POSITIVE (long BFP)</td>
<td>LPDBR</td>
<td>RRE C D1</td>
<td>19-35</td>
</tr>
<tr>
<td>B311</td>
<td>LOAD NEGATIVE (long BFP)</td>
<td>LNDBR</td>
<td>RRE C D1</td>
<td>19-34</td>
</tr>
<tr>
<td>B312</td>
<td>LOAD AND TEST (long BFP)</td>
<td>LTDBR</td>
<td>RRE C D1</td>
<td>19-31</td>
</tr>
<tr>
<td>B313</td>
<td>LOAD COMPLEMENT (long BFP)</td>
<td>LCDBR</td>
<td>RRE C D1</td>
<td>19-31</td>
</tr>
<tr>
<td>B314</td>
<td>SQUARE ROOT (short BFP)</td>
<td>SQEBR</td>
<td>RRE C D1</td>
<td>19-19</td>
</tr>
<tr>
<td>B315</td>
<td>SQUARE ROOT (long BFP)</td>
<td>SQDBR</td>
<td>RRE C D1</td>
<td>19-40</td>
</tr>
<tr>
<td>B316</td>
<td>SQUARE ROOT (extended BFP)</td>
<td>SQXBR</td>
<td>RRE C D1</td>
<td>19-40</td>
</tr>
<tr>
<td>B317</td>
<td>MULTIPLY (short BFP)</td>
<td>SQEBR</td>
<td>RRE C D1</td>
<td>19-37</td>
</tr>
<tr>
<td>B318</td>
<td>COMPARE AND SIGNAL (long BFP)</td>
<td>KDDBR</td>
<td>RRE C D1</td>
<td>19-18</td>
</tr>
<tr>
<td>B319</td>
<td>COMPARE (long BFP)</td>
<td>KDBR</td>
<td>RRE C D1</td>
<td>19-17</td>
</tr>
<tr>
<td>B31A</td>
<td>ADD (long BFP)</td>
<td>SDBR</td>
<td>RRE C D1</td>
<td>19-15</td>
</tr>
<tr>
<td>B31B</td>
<td>SUBTRACT (long BFP)</td>
<td>SDBR</td>
<td>RRE C D1</td>
<td>19-40</td>
</tr>
<tr>
<td>B31C</td>
<td>MULTIPLY (long BFP)</td>
<td>MDRBR</td>
<td>RRE C D1</td>
<td>19-37</td>
</tr>
<tr>
<td>B31D</td>
<td>DIVIDE (long BFP)</td>
<td>DDBR</td>
<td>RRE C D1</td>
<td>19-27</td>
</tr>
<tr>
<td>B31E</td>
<td>MULTIPLY AND ADD (long BFP)</td>
<td>MADDDBR</td>
<td>RRD D1</td>
<td>19-38</td>
</tr>
<tr>
<td>B31F</td>
<td>MULTIPLY AND SUBTRACT (long BFP)</td>
<td>MSDBR</td>
<td>RRD D1</td>
<td>19-38</td>
</tr>
<tr>
<td>B324</td>
<td>LOAD LENGTHENED (short to long HFP)</td>
<td>LDER</td>
<td>RRE D1</td>
<td>18-15</td>
</tr>
<tr>
<td>B325</td>
<td>LOAD LENGTHENED (long to extended HFP)</td>
<td>LXER</td>
<td>RRE D1</td>
<td>18-15</td>
</tr>
<tr>
<td>B326</td>
<td>LOAD LENGTHENED (short to extended HFP)</td>
<td>LXER</td>
<td>RRE D1</td>
<td>18-15</td>
</tr>
<tr>
<td>B32E</td>
<td>MULTIPLY AND ADD (short HFP)</td>
<td>MAER</td>
<td>RRD HM D1</td>
<td>18-19</td>
</tr>
<tr>
<td>B32F</td>
<td>MULTIPLY AND SUBTRACT (short HFP)</td>
<td>MSER</td>
<td>RRD HM D1</td>
<td>18-19</td>
</tr>
<tr>
<td>B336</td>
<td>SQUARE ROOT (extended HFP)</td>
<td>SQXBR</td>
<td>RRE C D1</td>
<td>18-23</td>
</tr>
<tr>
<td>B337</td>
<td>MULTIPLY (short HFP)</td>
<td>MEBR</td>
<td>RRE C D1</td>
<td>18-17</td>
</tr>
<tr>
<td>B338</td>
<td>MULTIPLY AND ADD UNNORM. (long to ext. low HFP)</td>
<td>MAYLB</td>
<td>RRD UE D1</td>
<td>18-20</td>
</tr>
<tr>
<td>B339</td>
<td>MULTIPLY UNNORM. (long to ext. low HFP)</td>
<td>MYLB</td>
<td>RRD UE D1</td>
<td>18-22</td>
</tr>
<tr>
<td>B33A</td>
<td>MULTIPLY &amp; ADD UNNORMALIZED (long to ext. HFP)</td>
<td>MAYRB</td>
<td>RRD UE D1</td>
<td>18-20</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 6 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>B33B</td>
<td>MULTIPLY UNNORMALIZED (long to ext. HFP)</td>
<td>MYR</td>
<td>RRD UE c^3 SP Da</td>
<td>18-22</td>
</tr>
<tr>
<td>B33C</td>
<td>MULTIPLY AND ADD UNRMR. (long to ext. high HFP)</td>
<td>MAYHR</td>
<td>RRD UE c^3 Da</td>
<td>18-20</td>
</tr>
<tr>
<td>B33D</td>
<td>MULTIPLY UNNORM. (long to ext. high HFP)</td>
<td>MYHR</td>
<td>RRD UE c^3 Da</td>
<td>18-22</td>
</tr>
<tr>
<td>B33E</td>
<td>MULTIPLY AND ADD (long HFP)</td>
<td>MADR</td>
<td>RRD HM c^3 Da EU EO</td>
<td>18-19</td>
</tr>
<tr>
<td>B33F</td>
<td>MULTIPLY AND SUBTRACT (long HFP)</td>
<td>MSDR</td>
<td>RRD HM c^3 Da EU EO</td>
<td>18-19</td>
</tr>
<tr>
<td>B340</td>
<td>LOAD POSITIVE (extended BFP)</td>
<td>LPXBR</td>
<td>RRE C g^3 SP Db Xi Xo Xu Xx</td>
<td>19-35</td>
</tr>
<tr>
<td>B341</td>
<td>LOAD NEGATIVE (extended BFP)</td>
<td>LNXBR</td>
<td>RRE C g^3 SP Db Xi Xo Xu Xx</td>
<td>19-34</td>
</tr>
<tr>
<td>B342</td>
<td>LOAD AND TEST (extended BFP)</td>
<td>LTXBR</td>
<td>RRE C g^3 SP Db Xi Xo Xu Xx</td>
<td>19-34</td>
</tr>
<tr>
<td>B343</td>
<td>LOAD COMPLEMENT (extended BFP)</td>
<td>LCXBR</td>
<td>RRE C g^3 SP Db Xi Xo Xu Xx</td>
<td>19-35</td>
</tr>
<tr>
<td>B344</td>
<td>LOAD ROUNDED (long to short BFP)</td>
<td>LEDBR</td>
<td>RRE g^3 Db Xi Xo Xu Xx</td>
<td>19-35</td>
</tr>
<tr>
<td>B345</td>
<td>LOAD ROUNDED (long to short BFP)</td>
<td>LEDBRA</td>
<td>RRF-e F g^3 SP Db Xi Xo Xu Xx</td>
<td>19-35</td>
</tr>
<tr>
<td>B346</td>
<td>LOAD ROUNDED (long to short BFP)</td>
<td>LEXBRA</td>
<td>RRF-e F g^3 SP Db Xi Xo Xu Xx</td>
<td>19-35</td>
</tr>
<tr>
<td>B347</td>
<td>LOAD FP INTEGER (extended BFP)</td>
<td>FIXBR</td>
<td>RRF-e C g^3 SP Db Xi Xx</td>
<td>19-32</td>
</tr>
<tr>
<td>B348</td>
<td>COMPARE AND SIGNAL (extended BFP)</td>
<td>KXBRA</td>
<td>RRE C g^3 SP Db Xi Xx</td>
<td>19-18</td>
</tr>
<tr>
<td>B349</td>
<td>COMPARE (extended BFP)</td>
<td>CXBR</td>
<td>RRE C g^3 SP Db Xi Xx</td>
<td>19-17</td>
</tr>
<tr>
<td>B34A</td>
<td>ADD (extended BFP)</td>
<td>AXBR</td>
<td>RRE C g^3 SP Db Xi Xo Xu Xx</td>
<td>19-15</td>
</tr>
<tr>
<td>B34B</td>
<td>SUBTRACT (extended BFP)</td>
<td>SXBR</td>
<td>RRE C g^3 SP Db Xi Xo Xu Xx</td>
<td>19-40</td>
</tr>
<tr>
<td>B34C</td>
<td>MULTIPLY (extended BFP)</td>
<td>MXBR</td>
<td>RRE C g^3 SP Db Xi Xo Xu Xx</td>
<td>19-37</td>
</tr>
<tr>
<td>B34D</td>
<td>DIVIDE (extended BFP)</td>
<td>DXBR</td>
<td>RRE C g^3 SP Db Xi Xz Xo Xu Xx</td>
<td>19-27</td>
</tr>
<tr>
<td>B350</td>
<td>CONVERT HFP TO BFP (long to short)</td>
<td>TBEDR</td>
<td>RRF-e C g^3 SP Da</td>
<td>9-28</td>
</tr>
<tr>
<td>B351</td>
<td>CONVERT HFP TO BFP (long)</td>
<td>TBR</td>
<td>RRF-e C g^3 SP Da</td>
<td>9-28</td>
</tr>
<tr>
<td>B352</td>
<td>DIVIDE TO INTEGER (short BFP)</td>
<td>DIEBR</td>
<td>RRF-b C g^3 SP Db Xi Xu Xx</td>
<td>19-28</td>
</tr>
<tr>
<td>B353</td>
<td>LOAD FP INTEGER (short BFP)</td>
<td>FIEBR</td>
<td>RRF-e C g^3 SP Db Xi Xx</td>
<td>19-32</td>
</tr>
<tr>
<td>B354</td>
<td>LOAD FP INTEGER (short BFP)</td>
<td>FIEBRA</td>
<td>RRF-e F g^3 SP Db Xi Xx</td>
<td>19-32</td>
</tr>
<tr>
<td>B355</td>
<td>CONVERT BFP TO HFP (short to long)</td>
<td>THDER</td>
<td>RRE C g^3 Da</td>
<td>9-27</td>
</tr>
<tr>
<td>B356</td>
<td>CONVERT BFP TO HFP (long)</td>
<td>THDR</td>
<td>RRE C g^3 Da</td>
<td>9-27</td>
</tr>
<tr>
<td>B35B</td>
<td>DIVIDE TO INTEGER (long BFP)</td>
<td>DIDBR</td>
<td>RRF-b C g^3 SP Db Xi Xu Xx</td>
<td>19-28</td>
</tr>
<tr>
<td>B35C</td>
<td>LOAD FP INTEGER (long BFP)</td>
<td>FIDBR</td>
<td>RRF-e C g^3 SP Db Xi Xx</td>
<td>19-32</td>
</tr>
<tr>
<td>B35D</td>
<td>LOAD FP INTEGER (long BFP)</td>
<td>FIDBRA</td>
<td>RRF-e F g^3 SP Db Xi Xx</td>
<td>19-32</td>
</tr>
<tr>
<td>B360</td>
<td>LOAD POSITIVE (extended HFP)</td>
<td>LPXR</td>
<td>RRE C g^3 SP Da</td>
<td>18-16</td>
</tr>
<tr>
<td>B361</td>
<td>LOAD NEGATIVE (extended HFP)</td>
<td>LNXR</td>
<td>RRE C g^3 SP Da</td>
<td>18-16</td>
</tr>
<tr>
<td>B362</td>
<td>LOAD AND TEST (extended HFP)</td>
<td>LTXR</td>
<td>RRE C g^3 SP Da</td>
<td>18-14</td>
</tr>
<tr>
<td>B363</td>
<td>LOAD COMPLEMENT (extended HFP)</td>
<td>LCXR</td>
<td>RRE C g^3 SP Da</td>
<td>18-14</td>
</tr>
<tr>
<td>B365</td>
<td>LOAD (extended)</td>
<td>LXR</td>
<td>RRE g^3 SP Da</td>
<td>9-31</td>
</tr>
<tr>
<td>B366</td>
<td>LOAD ROUNDED (extended to short HFP)</td>
<td>LEXR</td>
<td>RRE g^3 SP Da EO</td>
<td>18-17</td>
</tr>
<tr>
<td>B367</td>
<td>LOAD FP INTEGER (extended HFP)</td>
<td>FIXR</td>
<td>RRE g^3 SP Da</td>
<td>18-15</td>
</tr>
<tr>
<td>B369</td>
<td>COMPARE (extended HFP)</td>
<td>CXR</td>
<td>RRE C g^3 SP Da</td>
<td>18-10</td>
</tr>
<tr>
<td>B370</td>
<td>LOAD POSITIVE (long)</td>
<td>LPDFR</td>
<td>RRE FS g^3 Da</td>
<td>9-34</td>
</tr>
<tr>
<td>B371</td>
<td>LOAD NEGATIVE (long)</td>
<td>LNDFR</td>
<td>RRE FS g^3 Da</td>
<td>9-34</td>
</tr>
<tr>
<td>B372</td>
<td>COPY SIGN (long)</td>
<td>CPSDR</td>
<td>RRF-b FS g^3 Da</td>
<td>9-30</td>
</tr>
<tr>
<td>B373</td>
<td>LOAD COMPLEMENT (long)</td>
<td>LCDFR</td>
<td>RRE FS g^3 Da</td>
<td>9-31</td>
</tr>
<tr>
<td>B374</td>
<td>LOAD ZERO (short)</td>
<td>LZER</td>
<td>RRE g^3 Da</td>
<td>9-35</td>
</tr>
<tr>
<td>B375</td>
<td>LOAD ZERO (long)</td>
<td>LZDR</td>
<td>RRE g^3 Da</td>
<td>9-35</td>
</tr>
<tr>
<td>B376</td>
<td>LOAD ZERO (extended)</td>
<td>LZXR</td>
<td>RRE g^3 SP Da</td>
<td>9-35</td>
</tr>
<tr>
<td>B377</td>
<td>LOAD FP INTEGER (short HFP)</td>
<td>FIER</td>
<td>RRE g^3 Da</td>
<td>18-15</td>
</tr>
<tr>
<td>B378</td>
<td>LOAD FP INTEGER (long HFP)</td>
<td>FIDR</td>
<td>RRE g^3 Da</td>
<td>18-15</td>
</tr>
<tr>
<td>B384</td>
<td>SET FPC</td>
<td>SFPF</td>
<td>RRE g^3 SP Db</td>
<td>9-47</td>
</tr>
<tr>
<td>B385</td>
<td>SET FFC AND SIGNAL</td>
<td>SFASR</td>
<td>RRE XF g^3 SP Dt Xg</td>
<td>9-48</td>
</tr>
<tr>
<td>B38C</td>
<td>EXTRACT FPC</td>
<td>EFPC</td>
<td>RRE g^3 Db</td>
<td>9-30</td>
</tr>
<tr>
<td>B390</td>
<td>CONVERT FROM LOGICAL (32 to short BFP)</td>
<td>CELFBR</td>
<td>RRF-e F g^3 SP Db Xx</td>
<td>19-21</td>
</tr>
<tr>
<td>B391</td>
<td>CONVERT FROM LOGICAL (32 to long BFP)</td>
<td>CDFFB</td>
<td>RRF-e F g^3 SP Db</td>
<td>19-21</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 7 of 22)
Figure B-3. Instructions Arranged by Operation Code (Part 8 of 22)
<table>
<thead>
<tr>
<th>Opcode</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>B3D3</td>
<td>SUBTRACT (long DFP)</td>
<td>SDTRA</td>
<td>RRF-a C F $o^{2}$</td>
<td>Di Xi Xo Xu Xx Xq</td>
</tr>
<tr>
<td>B3D4</td>
<td>LOAD LENGTHENED (short to long DFP)</td>
<td>LDTR</td>
<td>RRF-d TF $o^{3}$</td>
<td>Di Xi</td>
</tr>
<tr>
<td>B3D5</td>
<td>LOAD ROUNDED (long to short DFP)</td>
<td>LEDTR</td>
<td>RRF-e TF $o^{3}$</td>
<td>Di Xi Xo Xu Xx Xq</td>
</tr>
<tr>
<td>B3D6</td>
<td>LOAD AND TEST (long DFP)</td>
<td>LTDTR</td>
<td>RRE C TF $o^{3}$</td>
<td>Di Xi</td>
</tr>
<tr>
<td>B3D7</td>
<td>LOAD FP INTEGER (long DFP)</td>
<td>FIDTR</td>
<td>RRF-e TF $o^{2}$</td>
<td>Di Xi Xx Xq</td>
</tr>
<tr>
<td>B3D8</td>
<td>MULTIPLY (extended DFP)</td>
<td>MXTR</td>
<td>RRF-a TF $o^{3}$</td>
<td>SP Di Xi Xo Xu Xx</td>
</tr>
<tr>
<td>B3D9</td>
<td>DIVIDE (extended DFP)</td>
<td>DXTR</td>
<td>RRF-a TF $o^{3}$</td>
<td>SP Di Xi Xz Xo Xu Xx</td>
</tr>
<tr>
<td>B3DA</td>
<td>ADD (extended DFP)</td>
<td>AXTR</td>
<td>RRF-a C TF $o^{3}$</td>
<td>SP Di Xi Xo Xu Xx</td>
</tr>
<tr>
<td>B3DB</td>
<td>SUBTRACT (extended DFP)</td>
<td>SXTR</td>
<td>RRF-a C TF $o^{3}$</td>
<td>SP Di Xi Xo Xu Xx Xq</td>
</tr>
<tr>
<td>B3DC</td>
<td>LOAD LENGTHENED (long to extended DFP)</td>
<td>LXDTTR</td>
<td>RRF-d TF $o^{3}$</td>
<td>SP Di Xi</td>
</tr>
<tr>
<td>B3DD</td>
<td>LOAD ROUNDED (extended to long DFP)</td>
<td>LDXTTR</td>
<td>RRF-e TF $o^{2}$</td>
<td>SP Di Xi Xo Xu Xx Xq</td>
</tr>
<tr>
<td>B3DE</td>
<td>LOAD AND TEST (extended DFP)</td>
<td>LXTR</td>
<td>RRE C TF $o^{3}$</td>
<td>SP Di Xi</td>
</tr>
<tr>
<td>B3DF</td>
<td>LOAD FP INTEGER (extended DFP)</td>
<td>FXTR</td>
<td>RRF-e TF $o^{3}$</td>
<td>SP Di Xi Xo Xu Xx</td>
</tr>
<tr>
<td>B3E0</td>
<td>COMPARE AND SIGNAL (long DFP)</td>
<td>KDTR</td>
<td>RRE C TF $o^{3}$</td>
<td>Di Xi</td>
</tr>
<tr>
<td>B3E1</td>
<td>CONVERT TO FIXED (long DFP to 64)</td>
<td>CDFTR</td>
<td>RRF-e C TF $o^{3}$</td>
<td>Di Xi Xx</td>
</tr>
<tr>
<td>B3E2</td>
<td>CONVERT TO UNSIGNED PACKED (long DFP to 64)</td>
<td>CUDTR</td>
<td>RRE TF $o^{3}$</td>
<td>Di</td>
</tr>
<tr>
<td>B3E3</td>
<td>CONVERT TO SIGNED PACKED (long DFP to 64)</td>
<td>CSQTR</td>
<td>RRF-d TF $o^{3}$</td>
<td>Di</td>
</tr>
<tr>
<td>B3E4</td>
<td>COMPARE (long DFP)</td>
<td>CDTR</td>
<td>RRE C TF $o^{3}$</td>
<td>Di Xi</td>
</tr>
<tr>
<td>B3E5</td>
<td>EXTRACT BIASED EXPONENT (long DFP to 64)</td>
<td>EEDTR</td>
<td>RRE TF $o^{3}$</td>
<td>Di</td>
</tr>
<tr>
<td>B3E7</td>
<td>EXTRACT SIGNIFICANCE (long DFP to 64)</td>
<td>ESQTR</td>
<td>RRE TF $o^{3}$</td>
<td>Di</td>
</tr>
<tr>
<td>B3E8</td>
<td>COMPARE AND SIGNAL (extended DFP)</td>
<td>KXTR</td>
<td>RRE C TF $o^{3}$</td>
<td>SP Di Xi</td>
</tr>
<tr>
<td>B3E9</td>
<td>CONVERT TO FIXED (extended DFP to 64)</td>
<td>CGQTR</td>
<td>RRF-e C TF $o^{3}$</td>
<td>SP Di Xi Xx</td>
</tr>
<tr>
<td>B3E9</td>
<td>CONVERT TO FIXED (extended DFP to 128)</td>
<td>CLXTR</td>
<td>RRE TF $o^{3}$</td>
<td>SP Di Xi Xx</td>
</tr>
<tr>
<td>B3EA</td>
<td>CONVERT TO UNSIGNED PACKED (extended DFP to 128)</td>
<td>CUXTR</td>
<td>RRE TF $o^{3}$</td>
<td>SP Di Xi Xx</td>
</tr>
<tr>
<td>B3EB</td>
<td>CONVERT TO SIGNED PACKED (extended DFP to 128)</td>
<td>CXSTR</td>
<td>RRF-d TF $o^{3}$</td>
<td>SP Di</td>
</tr>
<tr>
<td>B3E9</td>
<td>COMPARE (extended DFP)</td>
<td>CXTR</td>
<td>RRE TF $o^{3}$</td>
<td>SP Di Xi</td>
</tr>
<tr>
<td>B3ED</td>
<td>EXTRACT BIASED EXPONENT (extended DFP to 64)</td>
<td>CEEXTR</td>
<td>RRE TF $o^{3}$</td>
<td>SP Di</td>
</tr>
<tr>
<td>B3E9</td>
<td>EXTRACT SIGNIFICANCE (extended DFP to 64)</td>
<td>CEQTR</td>
<td>RRE TF $o^{3}$</td>
<td>SP Di</td>
</tr>
<tr>
<td>B3F1</td>
<td>CONVERT FROM FIXED (64 to long DFP)</td>
<td>CDGTR</td>
<td>RRE TF $o^{3}$</td>
<td>Di</td>
</tr>
<tr>
<td>B3F2</td>
<td>CONVERT FROM FIXED (64 to long DFP)</td>
<td>CDQTR</td>
<td>RRF-e F $o^{3}$</td>
<td>Di Xx Xq</td>
</tr>
<tr>
<td>B3F3</td>
<td>CONVERT FROM UNSIGNED PACKED (64 to long DFP)</td>
<td>CQUTR</td>
<td>RRE TF $o^{3}$</td>
<td>Di Dg</td>
</tr>
<tr>
<td>B3F4</td>
<td>CONVERT FROM SIGNED PACKED (64 to long DFP)</td>
<td>CQSTR</td>
<td>RRE TF $o^{3}$</td>
<td>Di Dg</td>
</tr>
<tr>
<td>B3F5</td>
<td>COMPARE (long DFP)</td>
<td>SDDTR</td>
<td>RRF-b TF $o^{3}$</td>
<td>Di Xi Xx Xq</td>
</tr>
<tr>
<td>B3F6</td>
<td>INSERT BIASED EXPONENT (64 to long DFP)</td>
<td>IEDTR</td>
<td>RRF-b TF $o^{3}$</td>
<td>Di</td>
</tr>
<tr>
<td>B3F7</td>
<td>REROUND (long DFP)</td>
<td>RRDRTR</td>
<td>RRF-b TF $o^{3}$</td>
<td>Di Xi Xx Xq</td>
</tr>
<tr>
<td>B3F8</td>
<td>CONVERT FROM FIXED (64 to extended DFP)</td>
<td>CXQTR</td>
<td>RRF-e F $o^{3}$</td>
<td>SP Di</td>
</tr>
<tr>
<td>B3F9</td>
<td>CONVERT FROM FIXED (64 to extended DFP)</td>
<td>CXQTRA</td>
<td>RRF-e F $o^{3}$</td>
<td>SP Di</td>
</tr>
<tr>
<td>B3FA</td>
<td>CONVERT FROM UNSIGNED PACKED (128 to ext. DFP)</td>
<td>CXUTR</td>
<td>RRE TF $o^{3}$</td>
<td>SP Dg</td>
</tr>
<tr>
<td>B3FB</td>
<td>CONVERT FROM SIGNED PACKED (128 to extended DFP)</td>
<td>CXSTR</td>
<td>RRE TF $o^{3}$</td>
<td>SP Di Dg</td>
</tr>
<tr>
<td>B3FC</td>
<td>COMPARE BIASED EXPONENT (extended DFP)</td>
<td>CEXTR</td>
<td>RRE C TF $o^{3}$</td>
<td>SP Di</td>
</tr>
<tr>
<td>B3FD</td>
<td>QUANTIZE (extended DFP)</td>
<td>CQXTR</td>
<td>RRF-b TF $o^{3}$</td>
<td>SP Di Xi Xx Xq</td>
</tr>
<tr>
<td>B3FE</td>
<td>INSERT BIASED EXPONENT (64 to extended DFP)</td>
<td>IEXTR</td>
<td>RRF-b TF $o^{3}$</td>
<td>SP Di</td>
</tr>
<tr>
<td>B3FF</td>
<td>REROUND (extended DFP)</td>
<td>RRXTR</td>
<td>RRF-b TF $o^{3}$</td>
<td>SP Di Xi Xx Xq</td>
</tr>
</tbody>
</table>

**Figure B-3. Instructions Arranged by Operation Code (Part 9 of 22)**
<table>
<thead>
<tr>
<th>Opcode</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>B900</td>
<td>LOAD POSITIVE (64)</td>
<td>LPGGR</td>
<td>C N</td>
<td>7-242</td>
</tr>
<tr>
<td>B901</td>
<td>LOAD NEGATIVE (64)</td>
<td>LNGR</td>
<td>C N</td>
<td>7-239</td>
</tr>
<tr>
<td>B902</td>
<td>LOAD AND TEST (64)</td>
<td>LTGR</td>
<td>C N</td>
<td>7-228</td>
</tr>
<tr>
<td>B903</td>
<td>LOAD COMPLEMENT (64)</td>
<td>LCGR</td>
<td>C N</td>
<td>7-230</td>
</tr>
<tr>
<td>B904</td>
<td>LOAD (64)</td>
<td>LGR</td>
<td>N</td>
<td>7-221</td>
</tr>
<tr>
<td>B905</td>
<td>LOAD USING REAL ADDRESS (64)</td>
<td>LURGR</td>
<td>N</td>
<td>10-59</td>
</tr>
<tr>
<td>B906</td>
<td>LOAD BYTE (64→8)</td>
<td>LGBR</td>
<td>Ei</td>
<td>7-229</td>
</tr>
<tr>
<td>B907</td>
<td>LOAD HALFWORD (64→16)</td>
<td>LGHR</td>
<td>Ei</td>
<td>7-231</td>
</tr>
<tr>
<td>B908</td>
<td>ADD (64)</td>
<td>AGR</td>
<td>C N</td>
<td>7-25</td>
</tr>
<tr>
<td>B909</td>
<td>SUBTRACT (64)</td>
<td>SGR</td>
<td>C N</td>
<td>7-338</td>
</tr>
<tr>
<td>B90A</td>
<td>ADD LOGICAL (64)</td>
<td>ALGR</td>
<td>C N</td>
<td>7-29</td>
</tr>
<tr>
<td>B90B</td>
<td>SUBTRACT LOGICAL (64)</td>
<td>SLGR</td>
<td>C N</td>
<td>7-340</td>
</tr>
<tr>
<td>B90C</td>
<td>MULTIPLE SINGLE (64)</td>
<td>MSGR</td>
<td>N</td>
<td>7-261</td>
</tr>
<tr>
<td>B90D</td>
<td>DIVIDE SINGLE (64)</td>
<td>DSGR</td>
<td>N</td>
<td>7-212</td>
</tr>
<tr>
<td>B90E</td>
<td>EXTRACT STACKED REGISTERS (64)</td>
<td>EREGG</td>
<td>N</td>
<td>7-225</td>
</tr>
<tr>
<td>B90F</td>
<td>LOAD REVERSED (64)</td>
<td>LRGR</td>
<td>N</td>
<td>7-243</td>
</tr>
<tr>
<td>B910</td>
<td>LOAD POSITIVE (64→32)</td>
<td>LPGFR</td>
<td>C N</td>
<td>7-242</td>
</tr>
<tr>
<td>B911</td>
<td>LOAD NEGATIVE (64→32)</td>
<td>LNGFR</td>
<td>C N</td>
<td>7-239</td>
</tr>
<tr>
<td>B912</td>
<td>LOAD AND TEST (64→32)</td>
<td>LTGFR</td>
<td>C N</td>
<td>7-228</td>
</tr>
<tr>
<td>B913</td>
<td>LOAD COMPLEMENT (64→32)</td>
<td>LCGFR</td>
<td>C N</td>
<td>7-230</td>
</tr>
<tr>
<td>B914</td>
<td>LOAD (64→32)</td>
<td>LGFR</td>
<td>N</td>
<td>7-221</td>
</tr>
<tr>
<td>B915</td>
<td>LOAD LOGICAL (64→32)</td>
<td>LLGFR</td>
<td>N</td>
<td>7-233</td>
</tr>
<tr>
<td>B916</td>
<td>LOAD LOGICAL THIRTY ONE BITS (64→31)</td>
<td>LLGTR</td>
<td>N</td>
<td>7-237</td>
</tr>
<tr>
<td>B918</td>
<td>ADD (64→32)</td>
<td>AGFR</td>
<td>C N</td>
<td>7-25</td>
</tr>
<tr>
<td>B919</td>
<td>SUBTRACT (64→32)</td>
<td>SGFR</td>
<td>C N</td>
<td>7-338</td>
</tr>
<tr>
<td>B91A</td>
<td>ADD LOGICAL (64→32)</td>
<td>ALGFR</td>
<td>C N</td>
<td>7-29</td>
</tr>
<tr>
<td>B91B</td>
<td>SUBTRACT LOGICAL (64→32)</td>
<td>SLGFR</td>
<td>C N</td>
<td>7-340</td>
</tr>
<tr>
<td>B91C</td>
<td>MULTIPLE SINGLE (64→32)</td>
<td>MSGFR</td>
<td>N</td>
<td>7-261</td>
</tr>
<tr>
<td>B91D</td>
<td>DIVIDE SINGLE (64→32)</td>
<td>DSGFR</td>
<td>N</td>
<td>7-212</td>
</tr>
<tr>
<td>B91E</td>
<td>COMPUTE MESSAGE AUTHENTICATION CODE</td>
<td>KMACE</td>
<td>C</td>
<td>7-178</td>
</tr>
<tr>
<td>B91F</td>
<td>LOAD REVERSED (32)</td>
<td>LRVR</td>
<td>N3</td>
<td>7-242</td>
</tr>
<tr>
<td>B920</td>
<td>COMPARE (64)</td>
<td>CGR</td>
<td>C N</td>
<td>7-117</td>
</tr>
<tr>
<td>B921</td>
<td>COMPARE LOGICAL (64)</td>
<td>CLGR</td>
<td>C N</td>
<td>7-135</td>
</tr>
<tr>
<td>B925</td>
<td>STORE USING REAL ADDRESS (64)</td>
<td>STURG</td>
<td>N</td>
<td>10-159</td>
</tr>
<tr>
<td>B926</td>
<td>LOAD BYTE (32→8)</td>
<td>LBR</td>
<td>Ei</td>
<td>7-229</td>
</tr>
<tr>
<td>B927</td>
<td>LOAD HALFWORD (32→16)</td>
<td>LHR</td>
<td>Ei</td>
<td>7-231</td>
</tr>
<tr>
<td>B928</td>
<td>PERFORM CRYPTOGRAPHIC KEY MGMT. OPERATIONS</td>
<td>PCKMO</td>
<td>M3</td>
<td>10-72</td>
</tr>
<tr>
<td>B929</td>
<td>CIPHER MESSAGE WITH CIPHER FEEDBACK</td>
<td>KMF</td>
<td>C M4</td>
<td>7-75</td>
</tr>
<tr>
<td>B92B</td>
<td>CIPHER MESSAGE WITH OUTPUT FEEDBACK</td>
<td>KMO</td>
<td>C M4</td>
<td>7-103</td>
</tr>
<tr>
<td>B92C</td>
<td>CIPHER MESSAGE WITH COUNTER</td>
<td>KMCTR</td>
<td>C M4</td>
<td>7-269</td>
</tr>
<tr>
<td>B92D</td>
<td>CIPHER MESSAGE WITH CHAINING</td>
<td>KMC</td>
<td>C MS</td>
<td>7-90</td>
</tr>
<tr>
<td>B92E</td>
<td>CIPHER MESSAGE WITH CHAINING</td>
<td>KMC</td>
<td>C MS</td>
<td>7-50</td>
</tr>
<tr>
<td>B930</td>
<td>COMPARE (64→32)</td>
<td>CGFR</td>
<td>C N</td>
<td>7-117</td>
</tr>
<tr>
<td>B931</td>
<td>COMPARE LOGICAL (64→32)</td>
<td>CLGR</td>
<td>C N</td>
<td>7-135</td>
</tr>
<tr>
<td>B932</td>
<td>COMPUTE PSEUDORANDOM NUMBER</td>
<td>PPNO</td>
<td>C M5</td>
<td>7-299</td>
</tr>
<tr>
<td>B933</td>
<td>COMPUTE INTERMEDIATE MESSAGE DIGEST</td>
<td>KIMD</td>
<td>C MS</td>
<td>7-165</td>
</tr>
<tr>
<td>B934</td>
<td>COMPUTE LAST MESSAGE DIGEST</td>
<td>KLMID</td>
<td>C MS</td>
<td>7-165</td>
</tr>
<tr>
<td>B941</td>
<td>CONVERT TO FIXED (long DFP to 32)</td>
<td>CFDTR</td>
<td>RF-e</td>
<td>20-29</td>
</tr>
<tr>
<td>B942</td>
<td>CONVERT TO LOGICAL (long DFP to 64)</td>
<td>CFDTR</td>
<td>RF-e</td>
<td>20-31</td>
</tr>
<tr>
<td>B943</td>
<td>CONVERT TO LOGICAL (long DFP to 32)</td>
<td>CFDTR</td>
<td>RF-e</td>
<td>20-31</td>
</tr>
<tr>
<td>B946</td>
<td>BRANCH ON COUNT (64)</td>
<td>BCTGR</td>
<td>RF-e</td>
<td>7-38</td>
</tr>
<tr>
<td>B949</td>
<td>CONVERT TO FIXED (extended DFP to 32)</td>
<td>CFXT</td>
<td>RF-e</td>
<td>20-29</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 10 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>B94A</td>
<td>CONVERT TO LOGICAL (extended DFP to 64)</td>
<td>CLGXRTR</td>
<td>RRF-e C F $^{2^{32}}$ SP Dt Xi Xx</td>
<td>20-31</td>
</tr>
<tr>
<td>B94B</td>
<td>CONVERT TO LOGICAL (extended DFP to 32)</td>
<td>CLFXTR</td>
<td>RRF-e C F $^{2^{24}}$ SP Dt Xi Xx</td>
<td>20-31</td>
</tr>
<tr>
<td>B951</td>
<td>CONVERT FROM FIXED (32 to long DFP)</td>
<td>CDFTR</td>
<td>RRF-e F $^{2^{32}}$ Dtt</td>
<td>20-23</td>
</tr>
<tr>
<td>B952</td>
<td>CONVERT FROM LOGICAL (64 to long DFP)</td>
<td>CDLGRTR</td>
<td>RRF-e F $^{2^{32}}$ Dtt</td>
<td>20-24</td>
</tr>
<tr>
<td>B953</td>
<td>CONVERT FROM LOGICAL (32 to long DFP)</td>
<td>CDLFR</td>
<td>RRF-e F $^{2^{32}}$ Dtt</td>
<td>20-24</td>
</tr>
<tr>
<td>B959</td>
<td>CONVERT FROM FIXED (32 to extended DFP)</td>
<td>CXFTR</td>
<td>RRF-e F $^{2^{32}}$ SP Dtt</td>
<td>20-23</td>
</tr>
<tr>
<td>B95A</td>
<td>CONVERT FROM LOGICAL (extended DFP to 32)</td>
<td>CXLGRTR</td>
<td>RRF-e F $^{2^{32}}$ SP Dtt</td>
<td>20-24</td>
</tr>
<tr>
<td>B960</td>
<td>COMPARE AND TRAP (64)</td>
<td>CGRT</td>
<td>RRF-c GE Dc</td>
<td>7-132</td>
</tr>
<tr>
<td>B961</td>
<td>COMPARE LOGICAL AND TRAP (64)</td>
<td>CLGRT</td>
<td>RRF-c GE Dc</td>
<td>7-138</td>
</tr>
<tr>
<td>B972</td>
<td>COMPARE AND TRAP (32)</td>
<td>CRT</td>
<td>RRF-c GE Dc</td>
<td>7-132</td>
</tr>
<tr>
<td>B973</td>
<td>COMPARE LOGICAL AND TRAP (32)</td>
<td>CLR</td>
<td>RRF-c GE Dc</td>
<td>7-138</td>
</tr>
<tr>
<td>B980</td>
<td>AND (64)</td>
<td>NGR</td>
<td>RRE C N</td>
<td>7-32</td>
</tr>
<tr>
<td>B981</td>
<td>OR (64)</td>
<td>OGR</td>
<td>RRE C N</td>
<td>7-264</td>
</tr>
<tr>
<td>B982</td>
<td>EXCLUSIVE OR (64)</td>
<td>XGR</td>
<td>RRE C N</td>
<td>7-212</td>
</tr>
<tr>
<td>B983</td>
<td>FIND LEFTMOST ONE</td>
<td>FLOGR</td>
<td>RRE C EI SP</td>
<td>7-219</td>
</tr>
<tr>
<td>B988</td>
<td>ADD LOGICAL WITH CARRY (64)</td>
<td>ALCLGR</td>
<td>RRE C N</td>
<td>7-30</td>
</tr>
<tr>
<td>B989</td>
<td>SUBTRACT LOGICAL WITH BORROW (64)</td>
<td>SLBGR</td>
<td>RRE C N</td>
<td>7-341</td>
</tr>
<tr>
<td>B98A</td>
<td>COMPARE AND SWAP AND PURGE (64)</td>
<td>CSPG</td>
<td>RRE C DE P $^{A}$ SP $^{+}$</td>
<td>ST R2</td>
</tr>
<tr>
<td>B98D</td>
<td>EXTRACT PSW</td>
<td>EPSW</td>
<td>RRE N3 $^{2^{32}}$ SP IK</td>
<td>7-218</td>
</tr>
<tr>
<td>B98E</td>
<td>INVALIDATE DAT TABLE ENTRY</td>
<td>IDTE</td>
<td>RRF-b U DE P $^{A}$ SP $^{+}$</td>
<td>$^{+}$</td>
</tr>
<tr>
<td>B99F</td>
<td>COMPARE AND REPLACE DAT TABLE ENTRY</td>
<td>CRDTE</td>
<td>RRF-b ED2 P $^{A}$ SP $^{+}$</td>
<td>$^{+}$</td>
</tr>
<tr>
<td>B990</td>
<td>TRANSLATE TWO TO TWO</td>
<td>TRTT</td>
<td>RRF-c C E2 $^{A}$ SP IC GM</td>
<td>ST RM R2</td>
</tr>
<tr>
<td>B991</td>
<td>TRANSLATE TWO TO ONE</td>
<td>TRTO</td>
<td>RRF-c C E2 $^{A}$ SP IC GM</td>
<td>ST RM R2</td>
</tr>
<tr>
<td>B992</td>
<td>TRANSLATE ONE TO TWO</td>
<td>TROT</td>
<td>RRF-c C E2 $^{A}$ SP IC GM</td>
<td>ST RM R2</td>
</tr>
<tr>
<td>B993</td>
<td>TRANSLATE ONE TO ONE</td>
<td>TROO</td>
<td>RRF-c C E2 $^{A}$ SP IC GM</td>
<td>ST RM R2</td>
</tr>
<tr>
<td>B994</td>
<td>LOAD LOGICAL CHARACTER (32÷8)</td>
<td>LCLCR</td>
<td>RRE E1</td>
<td>7-234</td>
</tr>
<tr>
<td>B995</td>
<td>LOAD LOGICAL HALFWORD (32÷16)</td>
<td>LLHR</td>
<td>RRE E1</td>
<td>7-235</td>
</tr>
<tr>
<td>B996</td>
<td>MULTIPLY LOGICAL (64÷32)</td>
<td>MLR</td>
<td>RRE N3 SP</td>
<td>7-260</td>
</tr>
<tr>
<td>B997</td>
<td>DIVIDE LOGICAL (32÷64)</td>
<td>DLR</td>
<td>RRE N3 $^{2^{32}}$ SP IK</td>
<td>7-211</td>
</tr>
<tr>
<td>B998</td>
<td>ADD LOGICAL WITH CARRY (32)</td>
<td>ALCR</td>
<td>RRE C N3</td>
<td>7-30</td>
</tr>
<tr>
<td>B999</td>
<td>SUBTRACT LOGICAL WITH BORROW (32)</td>
<td>SLBR</td>
<td>RRE C N3</td>
<td>7-341</td>
</tr>
<tr>
<td>B99A</td>
<td>EXTRACT PRIMARY ASN AND INSTANCE</td>
<td>EPAIR</td>
<td>RRE RA Q SO</td>
<td>10-23</td>
</tr>
<tr>
<td>B99B</td>
<td>EXTRACT SECONDARY ASN AND INSTANCE</td>
<td>ESAIR</td>
<td>RRE RA Q SO</td>
<td>10-24</td>
</tr>
<tr>
<td>B99D</td>
<td>EXTRACT AND SET EXTENDED AUTHORITY</td>
<td>ESEA</td>
<td>RRE N P</td>
<td>10-23</td>
</tr>
<tr>
<td>B9BE</td>
<td>PROGRAM TRANSFER WITH INSTANCE</td>
<td>PTI</td>
<td>RRE RA Q $^{A}$ SP $^{Z1}$ T $^{c}$ B</td>
<td>10-103</td>
</tr>
<tr>
<td>B99F</td>
<td>SET SECONDARY ASN WITH INSTANCE</td>
<td>SSAIR</td>
<td>RRE RA $^{A}$ $^{Z1}$ T $^{c}$</td>
<td>10-120</td>
</tr>
<tr>
<td>B9A2</td>
<td>PERFORM TOPOLOGY FUNCTION</td>
<td>PTF</td>
<td>RRE C CT P SP</td>
<td>10-85</td>
</tr>
<tr>
<td>B9AA</td>
<td>LOAD PAGE TABLE ENTRY ADDRESS</td>
<td>LPTEA</td>
<td>RRF-b C D2 P $^{A}$ SP SO</td>
<td>R2</td>
</tr>
<tr>
<td>B9AE</td>
<td>RESET REFERENCE BITS MULTIPLE</td>
<td>RRBM</td>
<td>RRE RB P $^{A}$</td>
<td>10-113</td>
</tr>
<tr>
<td>B9AF</td>
<td>PERFORM FRAME MANAGEMENT FUNCTION</td>
<td>PFMF</td>
<td>RRE ED1 P $^{A}$ SP</td>
<td>10-76</td>
</tr>
<tr>
<td>B9BD</td>
<td>CONVERT UTF-8 TO UTF-32</td>
<td>CU14</td>
<td>RRF-c C E3 $^{2^{8}}$ A SP IC</td>
<td>ST R2</td>
</tr>
<tr>
<td>B9BE</td>
<td>SEARCH STRING UNICODE</td>
<td>SRSTU</td>
<td>RRE C E3 $^{2^{8}}$ A SP IC G0</td>
<td>ST R2</td>
</tr>
<tr>
<td>B9BF</td>
<td>TRANSLATE AND TEST EXTENDED</td>
<td>TRTE</td>
<td>RRF-c C PE $^{2^{8}}$ A SP IC</td>
<td>ST RM R2</td>
</tr>
<tr>
<td>B9CA</td>
<td>ADD LOGICAL HIGH (32)</td>
<td>ALHHR</td>
<td>RRF-a C HW IF</td>
<td>7-30</td>
</tr>
<tr>
<td>B9CB</td>
<td>ADD LOGICAL HIGH (32)</td>
<td>AHHR</td>
<td>RRF-a C HW IF</td>
<td>7-339</td>
</tr>
<tr>
<td>B9CC</td>
<td>ADD LOGICAL HIGH (32)</td>
<td>SHHHR</td>
<td>RRF-a C HW IF</td>
<td>7-28</td>
</tr>
</tbody>
</table>

**Figure B-3. Instructions Arranged by Operation Code (Part 11 of 22)**
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>B9CB</td>
<td>SUBTRACT LOGICAL HIGH (32)</td>
<td>SLHHR</td>
<td>RRF-a C HW</td>
<td>7-341</td>
</tr>
<tr>
<td>B9CD</td>
<td>COMPARE HIGH (32)</td>
<td>CHHR</td>
<td>ARE C HW</td>
<td>7-134</td>
</tr>
<tr>
<td>B9CF</td>
<td>COMPARE LOGICAL HIGH (32)</td>
<td>CLHHR</td>
<td>ARE C HW</td>
<td>7-140</td>
</tr>
<tr>
<td>B9D8</td>
<td>ADD HIGH (32)</td>
<td>AHHLR</td>
<td>RRF-a C HW</td>
<td>7-28</td>
</tr>
<tr>
<td>B9D9</td>
<td>SUBTRACT HIGH (32)</td>
<td>SHHHR</td>
<td>RRF-a C HW</td>
<td>7-339</td>
</tr>
<tr>
<td>B9DA</td>
<td>ADD LOGICAL HIGH (32)</td>
<td>ALHHLR</td>
<td>RRF-a C HW</td>
<td>7-30</td>
</tr>
<tr>
<td>B9DB</td>
<td>SUBTRACT LOGICAL HIGH (32)</td>
<td>SLHHLR</td>
<td>RRF-a C HW</td>
<td>7-341</td>
</tr>
<tr>
<td>B9D8</td>
<td>COMPARE HIGH (32)</td>
<td>CHLR</td>
<td>ARE C HW</td>
<td>7-134</td>
</tr>
<tr>
<td>B9DF</td>
<td>COMPARE LOGICAL HIGH (32)</td>
<td>CLHLR</td>
<td>ARE C HW</td>
<td>7-140</td>
</tr>
<tr>
<td>B9E0</td>
<td>LOAD HIGH ON CONDITION (32)</td>
<td>LOCFHR</td>
<td>RRF-c L2</td>
<td>7-239</td>
</tr>
<tr>
<td>B9E1</td>
<td>POPULATION COUNT</td>
<td>POPCMT</td>
<td>RRE C PK</td>
<td>7-310</td>
</tr>
<tr>
<td>B9E2</td>
<td>LOAD ON CONDITION (64)</td>
<td>LOCGR</td>
<td>RRF-c L1 A</td>
<td>7-239</td>
</tr>
<tr>
<td>B9E4</td>
<td>AND (64)</td>
<td>NGRK</td>
<td>RRF-a C DO</td>
<td>7-32</td>
</tr>
<tr>
<td>B9E6</td>
<td>OR (64)</td>
<td>OGRK</td>
<td>RRF-a C DO</td>
<td>7-264</td>
</tr>
<tr>
<td>B9E7</td>
<td>EXCLUSIVE OR (64)</td>
<td>XGRK</td>
<td>RRF-a C DO</td>
<td>7-212</td>
</tr>
<tr>
<td>B9E8</td>
<td>ADD (64)</td>
<td>AGRK</td>
<td>RRF-a C DO</td>
<td>7-25</td>
</tr>
<tr>
<td>B9E9</td>
<td>SUBTRACT (64)</td>
<td>SG RK</td>
<td>RRF-a C DO</td>
<td>7-338</td>
</tr>
<tr>
<td>B9EA</td>
<td>ADD LOGICAL (64)</td>
<td>ALGRK</td>
<td>RRF-a C DO</td>
<td>7-29</td>
</tr>
<tr>
<td>B9EB</td>
<td>SUBTRACT LOGICAL (64)</td>
<td>SLGRK</td>
<td>RRF-a C DO</td>
<td>7-340</td>
</tr>
<tr>
<td>B9F2</td>
<td>LOAD ON CONDITION (32)</td>
<td>LOCR</td>
<td>RRF-c L1 A</td>
<td>7-239</td>
</tr>
<tr>
<td>B9F4</td>
<td>AND (32)</td>
<td>NRK</td>
<td>RRF-a C DO</td>
<td>7-32</td>
</tr>
<tr>
<td>B9F6</td>
<td>OR (32)</td>
<td>ORK</td>
<td>RRF-a C DO</td>
<td>7-264</td>
</tr>
<tr>
<td>B9F7</td>
<td>EXCLUSIVE OR (32)</td>
<td>XRK</td>
<td>RRF-a C DO</td>
<td>7-212</td>
</tr>
<tr>
<td>B9F8</td>
<td>ADD (32)</td>
<td>ARK</td>
<td>RRF-a C DO</td>
<td>7-25</td>
</tr>
<tr>
<td>B9F9</td>
<td>SUBTRACT (32)</td>
<td>SRK</td>
<td>RRF-a C DO</td>
<td>7-338</td>
</tr>
<tr>
<td>B9FA</td>
<td>ADD LOGICAL (32)</td>
<td>ALRKR</td>
<td>RRF-a C DO</td>
<td>7-29</td>
</tr>
<tr>
<td>B9FB</td>
<td>SUBTRACT LOGICAL (32)</td>
<td>SLRKR</td>
<td>RRF-a C DO</td>
<td>7-340</td>
</tr>
<tr>
<td>BA</td>
<td>COMPARE AND SWAP (32)</td>
<td>CS</td>
<td>RS-a C a3 A SP S ST B2</td>
<td>7-127</td>
</tr>
<tr>
<td>BB</td>
<td>COMPARE DOUBLE AND SWAP (32)</td>
<td>CDS</td>
<td>RS-a C a3 A SP S ST B2</td>
<td>7-127</td>
</tr>
<tr>
<td>BD</td>
<td>COMPARE LOGICAL CHAR. UNDER MASK (low)</td>
<td>CLM</td>
<td>RS-b C A</td>
<td>7-140</td>
</tr>
<tr>
<td>BE</td>
<td>STORE CHARACTERS UNDER MASK (low)</td>
<td>STCM</td>
<td>RS-b A</td>
<td>7-329</td>
</tr>
<tr>
<td>BF</td>
<td>INSERT CHARACTERS UNDER MASK (low)</td>
<td>ICM</td>
<td>RS-b C</td>
<td>7-329</td>
</tr>
<tr>
<td>C00</td>
<td>LOAD ADDRESS RELATIVE LONG</td>
<td>LARL</td>
<td>RIL-b N3</td>
<td>7-224</td>
</tr>
<tr>
<td>C01</td>
<td>LOAD IMMEDIATE (64≤32)</td>
<td>LGFI</td>
<td>RIL-a Ei</td>
<td>7-222</td>
</tr>
<tr>
<td>C04</td>
<td>BRANCH RELATIVE ON CONDITION LONG</td>
<td>BRCL</td>
<td>RIL-c N3 a10</td>
<td>7-44</td>
</tr>
<tr>
<td>C05</td>
<td>BRANCH RELATIVE AND SAVE LONG</td>
<td>BRASL</td>
<td>RIL-b N3 a2</td>
<td>7-43</td>
</tr>
<tr>
<td>C06</td>
<td>EXCLUSIVE OR IMMEDIATE (high)</td>
<td>XIFH</td>
<td>RIL-a C Ei</td>
<td>7-214</td>
</tr>
<tr>
<td>C07</td>
<td>EXCLUSIVE OR IMMEDIATE (low)</td>
<td>XIFL</td>
<td>RIL-a C Ei</td>
<td>7-214</td>
</tr>
<tr>
<td>C08</td>
<td>INSERT IMMEDIATE (high)</td>
<td>IIFH</td>
<td>RIL-a Ei</td>
<td>7-221</td>
</tr>
<tr>
<td>C09</td>
<td>INSERT IMMEDIATE (low)</td>
<td>IILF</td>
<td>RIL-a Ei</td>
<td>7-221</td>
</tr>
<tr>
<td>C0A</td>
<td>AND IMMEDIATE (high)</td>
<td>NIIFH</td>
<td>RIL-a C Ei</td>
<td>7-33</td>
</tr>
<tr>
<td>C0B</td>
<td>AND IMMEDIATE (low)</td>
<td>NILF</td>
<td>RIL-a C Ei</td>
<td>7-34</td>
</tr>
<tr>
<td>C0C</td>
<td>OR IMMEDIATE (high)</td>
<td>OIH</td>
<td>RIL-a C Ei</td>
<td>7-265</td>
</tr>
<tr>
<td>C0D</td>
<td>OR IMMEDIATE (low)</td>
<td>OILF</td>
<td>RIL-a C Ei</td>
<td>7-265</td>
</tr>
<tr>
<td>C0E</td>
<td>LOAD LOGICAL IMMEDIATE (high)</td>
<td>LLIFH</td>
<td>RIL-a Ei</td>
<td>7-236</td>
</tr>
<tr>
<td>C0F</td>
<td>LOAD LOGICAL IMMEDIATE (low)</td>
<td>LULF</td>
<td>RIL-a Ei</td>
<td>7-236</td>
</tr>
<tr>
<td>C20</td>
<td>MULTIPLY SINGLE IMMEDIATE (64≤32)</td>
<td>MSGFI</td>
<td>RIL-a GE</td>
<td>7-262</td>
</tr>
<tr>
<td>C21</td>
<td>MULTIPLY SINGLE IMMEDIATE (32)</td>
<td>MSFI</td>
<td>RIL-a GE</td>
<td>7-262</td>
</tr>
<tr>
<td>C24</td>
<td>SUBTRACT LOGICAL IMMEDIATE (64≤32)</td>
<td>SLGFI</td>
<td>RIL-a C Ei</td>
<td>7-340</td>
</tr>
<tr>
<td>C25</td>
<td>SUBTRACT LOGICAL IMMEDIATE (32)</td>
<td>SLFI</td>
<td>RIL-a C Ei</td>
<td>7-340</td>
</tr>
<tr>
<td>C28</td>
<td>ADD IMMEDIATE (64≤32)</td>
<td>AGFI</td>
<td>RIL-a C Ei</td>
<td>7-26</td>
</tr>
<tr>
<td>C29</td>
<td>ADD IMMEDIATE (32)</td>
<td>AFI</td>
<td>RIL-a C Ei</td>
<td>7-26</td>
</tr>
<tr>
<td>C2A</td>
<td>ADD LOGICAL IMMEDIATE (64≤32)</td>
<td>ALGFI</td>
<td>RIL-a C Ei</td>
<td>7-29</td>
</tr>
<tr>
<td>C2B</td>
<td>ADD LOGICAL IMMEDIATE (32)</td>
<td>ALFI</td>
<td>RIL-a C Ei</td>
<td>7-29</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 12 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>C2D</td>
<td>COMPARE IMMEDIATE (32)</td>
<td>CFI</td>
<td>RIL-a C Ei</td>
<td>7-117</td>
</tr>
<tr>
<td>C2E</td>
<td>COMPARE LOGICAL IMMEDIATE (64←32)</td>
<td>CLGFI</td>
<td>RIL-a C Ei</td>
<td>7-135</td>
</tr>
<tr>
<td>C2F</td>
<td>COMPARE LOGICAL IMMEDIATE (32)</td>
<td>CLFI</td>
<td>RIL-a C Ei</td>
<td>7-135</td>
</tr>
<tr>
<td>C42</td>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (32←16)</td>
<td>LLHRL</td>
<td>RIL-b GE A*</td>
<td>7-235</td>
</tr>
<tr>
<td>C44</td>
<td>LOAD HALFWORD RELATIVE LONG (64←16)</td>
<td>LGHRL</td>
<td>RIL-b GE A*</td>
<td>7-231</td>
</tr>
<tr>
<td>C45</td>
<td>LOAD HALFWORD RELATIVE LONG (32←16)</td>
<td>LHRL</td>
<td>RIL-b GE A*</td>
<td>7-231</td>
</tr>
<tr>
<td>C46</td>
<td>LOAD LOGICAL HALFWORD RELATIVE LONG (64←16)</td>
<td>LLGHRL</td>
<td>RIL-b GE A*</td>
<td>7-235</td>
</tr>
<tr>
<td>C47</td>
<td>STORE HALFWORD RELATIVE LONG (16)</td>
<td>STHRL</td>
<td>RIL-b GE A*</td>
<td>7-334</td>
</tr>
<tr>
<td>C48</td>
<td>LOAD RELATIVE LONG (64)</td>
<td>LGRL</td>
<td>RIL-b GE A* SP</td>
<td>7-222</td>
</tr>
<tr>
<td>C4B</td>
<td>STORE RELATIVE LONG (64)</td>
<td>STRL</td>
<td>RIL-b GE A* SP</td>
<td>7-328</td>
</tr>
<tr>
<td>C4C</td>
<td>LOAD RELATIVE LONG (64←32)</td>
<td>LGFR</td>
<td>RIL-b GE A* SP</td>
<td>7-222</td>
</tr>
<tr>
<td>C4D</td>
<td>LOAD RELATIVE LONG (32)</td>
<td>LRL</td>
<td>RIL-b GE A SP</td>
<td>7-222</td>
</tr>
<tr>
<td>C4E</td>
<td>LOAD HALFWORD RELATIVE LONG (64←32)</td>
<td>LLGFR</td>
<td>RIL-b GE A* SP</td>
<td>7-233</td>
</tr>
<tr>
<td>C4F</td>
<td>STORE RELATIVE LONG (32)</td>
<td>STRL</td>
<td>RIL-b GE A* SP</td>
<td>7-328</td>
</tr>
<tr>
<td>C5</td>
<td>BRANCH PREDICTION RELATIVE PRELOAD</td>
<td>BPRP</td>
<td>Miil EH (c^0)</td>
<td>7-40</td>
</tr>
<tr>
<td>C60</td>
<td>EXECUTE RELATIVE LONG</td>
<td>EXRL</td>
<td>RIL-b XX (c^{0,1}) Al*</td>
<td>EX</td>
</tr>
<tr>
<td>C62</td>
<td>PREFETCH DATA RELATIVE LONG</td>
<td>PFDRL</td>
<td>RIL-c GE (c^{1,1})</td>
<td>7-310</td>
</tr>
<tr>
<td>C64</td>
<td>COMPARE HALFWORD RELATIVE LONG (64←16)</td>
<td>CGHRL</td>
<td>RIL-b C GE A*</td>
<td>7-133</td>
</tr>
<tr>
<td>C65</td>
<td>COMPARE HALFWORD RELATIVE LONG (32←16)</td>
<td>CHRL</td>
<td>RIL-b C GE A*</td>
<td>7-133</td>
</tr>
<tr>
<td>C66</td>
<td>COMPARE LOGICAL RELATIVE LONG (64←16)</td>
<td>CLGHR</td>
<td>RIL-b C GE A*</td>
<td>7-136</td>
</tr>
<tr>
<td>C67</td>
<td>COMPARE LOGICAL RELATIVE LONG (32←16)</td>
<td>CLHR</td>
<td>RIL-b C GE A*</td>
<td>7-136</td>
</tr>
<tr>
<td>C68</td>
<td>COMPARE RELATIVE LONG (64)</td>
<td>CHRL</td>
<td>RIL-b C GE A* SP</td>
<td>7-118</td>
</tr>
<tr>
<td>C69</td>
<td>COMPARE RELATIVE LONG (64←32)</td>
<td>CGFR</td>
<td>RIL-b C GE A* SP</td>
<td>7-118</td>
</tr>
<tr>
<td>C6A</td>
<td>COMPARE LOGICAL RELATIVE LONG (64←32)</td>
<td>CLGFR</td>
<td>RIL-b C GE A* SP</td>
<td>7-136</td>
</tr>
<tr>
<td>C6B</td>
<td>COMPARE LOGICAL RELATIVE LONG (32)</td>
<td>CRL</td>
<td>RIL-b C GE A* SP</td>
<td>7-136</td>
</tr>
<tr>
<td>C6C</td>
<td>COMPARE LOGICAL RELATIVE LONG (64)</td>
<td>CLGFR</td>
<td>RIL-b C GE A* SP</td>
<td>7-136</td>
</tr>
<tr>
<td>C6D</td>
<td>BRANCH PREDICTION RELATIVE PRELOAD</td>
<td>BPRP</td>
<td>Miil EH (c^0)</td>
<td>7-40</td>
</tr>
<tr>
<td>C6E</td>
<td>COMPARE LOGICAL RELATIVE LONG (64←32)</td>
<td>CLGFR</td>
<td>RIL-b C GE A* SP</td>
<td>7-136</td>
</tr>
<tr>
<td>C6F</td>
<td>COMPARE LOGICAL RELATIVE LONG (32)</td>
<td>CRL</td>
<td>RIL-b C GE A* SP</td>
<td>7-136</td>
</tr>
<tr>
<td>C7</td>
<td>BRANCH PREDICTION PRELOAD</td>
<td>BPRP</td>
<td>Miil EH (c^0)</td>
<td>7-40</td>
</tr>
<tr>
<td>C80</td>
<td>MOVE WITH OPTIONAL SPECIFICATIONS</td>
<td>MVCOS</td>
<td>SSF C MO Q A SO G0</td>
<td>ST</td>
</tr>
<tr>
<td>C81</td>
<td>EXTRACT CPU TIME</td>
<td>ECTG</td>
<td>SSF ET (c^{0,3}) A</td>
<td>GM</td>
</tr>
<tr>
<td>C82</td>
<td>COMPARE AND SWAP AND STORE</td>
<td>CSST</td>
<td>SSF C CS (c^0) A SP</td>
<td>$ GM</td>
</tr>
<tr>
<td>C84</td>
<td>LOAD PAIR DISJOINT (32)</td>
<td>LPD</td>
<td>SSF C IA A SP</td>
<td>GM</td>
</tr>
<tr>
<td>C85</td>
<td>LOAD PAIR DISJOINT (64)</td>
<td>LPDG</td>
<td>SSF C IA A SP</td>
<td>GM</td>
</tr>
<tr>
<td>C86</td>
<td>BRANCH RELATIVE ON COUNT HIGH (32)</td>
<td>BRCTH</td>
<td>RIL-b HIW (c^0)</td>
<td>B</td>
</tr>
<tr>
<td>C88</td>
<td>ADD IMMEDIATE HIGH (32)</td>
<td>AH</td>
<td>RIL-a C HIW (c^0)</td>
<td>IF</td>
</tr>
<tr>
<td>CCA</td>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE HIGH (32)</td>
<td>ALSIH</td>
<td>RIL-a C HW (c^0)</td>
<td>7-32</td>
</tr>
<tr>
<td>CCB</td>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE HIGH (32)</td>
<td>ALSIH</td>
<td>RIL-a C HW (c^0)</td>
<td>7-32</td>
</tr>
<tr>
<td>CCD</td>
<td>COMPARE IMMEDIATE HIGH (32)</td>
<td>CIE</td>
<td>RIL-a C HW</td>
<td>7-134</td>
</tr>
<tr>
<td>CCE</td>
<td>COMPARE LOGICAL IMMEDIATE HIGH (32)</td>
<td>CIE</td>
<td>RIL-a C HW</td>
<td>7-141</td>
</tr>
<tr>
<td>D0</td>
<td>TRANSLATE AND TEST REVERSE</td>
<td>TRTR</td>
<td>SS-a C E3 (c^0) A</td>
<td>GM</td>
</tr>
<tr>
<td>D1</td>
<td>MOVE NUMERICs</td>
<td>MIVN</td>
<td>SS-a (c^0) A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>D2</td>
<td>MOVE (character)</td>
<td>MVC</td>
<td>SS-a (c^0) A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>D3</td>
<td>MOVE ZONES</td>
<td>MVZ</td>
<td>SS-a (c^0) A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>D4</td>
<td>AND (character)</td>
<td>NC</td>
<td>SS-a (c^0) A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>D5</td>
<td>COMPARE LOGICAL (character)</td>
<td>CLC</td>
<td>SS-a (c^0) A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>D6</td>
<td>OR (character)</td>
<td>OC</td>
<td>SS-a (c^0) A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>D7</td>
<td>EXCLUSIVE OR (character)</td>
<td>XG</td>
<td>SS-a (c^0) A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>D9</td>
<td>MOVE WITH KEY</td>
<td>MVK</td>
<td>SS-d C Q A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>DA</td>
<td>MOVE TO PRIMARY</td>
<td>MCP</td>
<td>SS-d C Q A</td>
<td>SO c</td>
</tr>
<tr>
<td>DB</td>
<td>MOVE TO SECONDARY</td>
<td>MCVS</td>
<td>SS-d C Q A</td>
<td>SO c</td>
</tr>
<tr>
<td>DC</td>
<td>TRANSLATE</td>
<td>TR</td>
<td>SS-a (c^0) A</td>
<td>ST B(<em>\uparrow) B(</em>\downarrow)</td>
</tr>
<tr>
<td>DD</td>
<td>TRANSLATE AND TEST</td>
<td>TRT</td>
<td>SS-a (c^0) A</td>
<td>GM</td>
</tr>
<tr>
<td>DE</td>
<td>EDIT</td>
<td>ED</td>
<td>SS-a (c^0) A</td>
<td>Dg</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 13 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>DF</td>
<td>EDIT AND MARK</td>
<td>EDMK</td>
<td>SF-a C</td>
<td>8-11</td>
</tr>
<tr>
<td>E1</td>
<td>PACK UNICODE</td>
<td>PKU</td>
<td>SF-f</td>
<td></td>
</tr>
<tr>
<td>E2</td>
<td>UNPACK UNICODE</td>
<td>UNPKU</td>
<td>SF-a C E2</td>
<td></td>
</tr>
<tr>
<td>E302</td>
<td>LOAD AND TEST (64)</td>
<td>LGT</td>
<td>RX-y-a C EI A</td>
<td></td>
</tr>
<tr>
<td>E303</td>
<td>LOAD REAL ADDRESS (64)</td>
<td>LLAG</td>
<td>RX-y-a C N P A*</td>
<td></td>
</tr>
<tr>
<td>E304</td>
<td>LOAD (64)</td>
<td>LG</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E306</td>
<td>CONVERT TO BINARY (32)</td>
<td>CVBY</td>
<td>RX-y-a LD A* A</td>
<td></td>
</tr>
<tr>
<td>E308</td>
<td>ADD (64)</td>
<td>AG</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E309</td>
<td>SUBTRACT (64)</td>
<td>SG</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E30A</td>
<td>ADD LOGICAL (64)</td>
<td>ALG</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E30B</td>
<td>SUBTRACT LOGICAL (64)</td>
<td>SLG</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E30C</td>
<td>MULTIPY SINGLE (64)</td>
<td>MSG</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E30D</td>
<td>DIVIDE SINGLE (64)</td>
<td>DSG</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E30E</td>
<td>CONVERT TO BINARY (64)</td>
<td>CBVG</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E312</td>
<td>LOAD AND TEST (32)</td>
<td>LT</td>
<td>RX-y-a C EI A</td>
<td></td>
</tr>
<tr>
<td>E313</td>
<td>LOAD REAL ADDRESS (32)</td>
<td>LRAJ</td>
<td>RX-y-a C LD P A*</td>
<td></td>
</tr>
<tr>
<td>E314</td>
<td>LOAD (64--32)</td>
<td>LGF</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E315</td>
<td>LOAD HALFWORD (64--16)</td>
<td>LGH</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E316</td>
<td>LOAD LOGICAL (64--32)</td>
<td>LLGF</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E317</td>
<td>LOAD LOGICAL THIRTY ONE BITS (64--31)</td>
<td>LGJT</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E318</td>
<td>ADD (64--32)</td>
<td>AGF</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E319</td>
<td>SUBTRACT (64--32)</td>
<td>MSGF</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E31A</td>
<td>ADD LOGICAL (64--32)</td>
<td>ALGF</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E31B</td>
<td>SUBTRACT LOGICAL (64--32)</td>
<td>SLGF</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E31C</td>
<td>MULTIPY SINGLE (64--32)</td>
<td>MSGF</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E31D</td>
<td>DIVIDE SINGLE (64--32)</td>
<td>DSGF</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E31E</td>
<td>LOAD REVERSED (32)</td>
<td>LRV</td>
<td>RX-y-a N3 A</td>
<td></td>
</tr>
<tr>
<td>E31F</td>
<td>LOAD REVERSED (16)</td>
<td>LRVH</td>
<td>RX-y-a N3 A</td>
<td></td>
</tr>
<tr>
<td>E320</td>
<td>COMPARE (64)</td>
<td>CG</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E321</td>
<td>COMPARE LOGICAL (64)</td>
<td>CLG</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E324</td>
<td>STORE (64)</td>
<td>STG</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E325</td>
<td>NONTXASNLATIONAL STORE (64)</td>
<td>NSTG</td>
<td>RX-y-a TX A* A</td>
<td></td>
</tr>
<tr>
<td>E326</td>
<td>CONVERT TO DECIMAL (32)</td>
<td>CVDY</td>
<td>RX-y-a LD A</td>
<td></td>
</tr>
<tr>
<td>E32A</td>
<td>LOAD AND ZERO RIGHTMOST BYTE (64)</td>
<td>LZRG</td>
<td>RX-y-a LZ A</td>
<td></td>
</tr>
<tr>
<td>E32E</td>
<td>CONVERT TO DECIMAL (64)</td>
<td>CVDG</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E32F</td>
<td>STORE REVERSED (64)</td>
<td>STRVG</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E330</td>
<td>COMPARE (64--32)</td>
<td>CGF</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E331</td>
<td>COMPARE LOGICAL (64--32)</td>
<td>CLGF</td>
<td>RX-y-a C N A</td>
<td></td>
</tr>
<tr>
<td>E332</td>
<td>LOAD AND TEST (64--32)</td>
<td>LGT</td>
<td>RX-y-a C GE A</td>
<td></td>
</tr>
<tr>
<td>E333</td>
<td>COMPARE HALFWORD (64--16)</td>
<td>CGH</td>
<td>RX-y-a C GE A</td>
<td></td>
</tr>
<tr>
<td>E336</td>
<td>PREFETCH DATA</td>
<td>PFD</td>
<td>RX-y-b GE A* A*</td>
<td></td>
</tr>
<tr>
<td>E33A</td>
<td>LOAD LOGICAL AND ZERO RIGHTMOST BYTE (64--32)</td>
<td>LLZRGF</td>
<td>RX-y-a LZ A</td>
<td></td>
</tr>
<tr>
<td>E33B</td>
<td>LOAD AND ZERO RIGHTMOST BYTE (32)</td>
<td>LZRF</td>
<td>RX-y-a LZ A</td>
<td></td>
</tr>
<tr>
<td>E33E</td>
<td>STORE REVERSED (32)</td>
<td>STRV</td>
<td>RX-y-a N3 A</td>
<td></td>
</tr>
<tr>
<td>E33F</td>
<td>STORE REVERSED (16)</td>
<td>STRVH</td>
<td>RX-y-a N3 A</td>
<td></td>
</tr>
<tr>
<td>E346</td>
<td>BRANCH ON COUNT (64)</td>
<td>BCTG</td>
<td>RX-y-a N A</td>
<td></td>
</tr>
<tr>
<td>E350</td>
<td>STORE (32)</td>
<td>STY</td>
<td>RX-y-a LD A</td>
<td></td>
</tr>
<tr>
<td>E351</td>
<td>MULTIPLY SINGLE (32)</td>
<td>MSY</td>
<td>RX-y-a LD A</td>
<td></td>
</tr>
<tr>
<td>E354</td>
<td>AND (32)</td>
<td>NY</td>
<td>RX-y-a C LD A</td>
<td></td>
</tr>
<tr>
<td>E355</td>
<td>COMPARE LOGICAL (32)</td>
<td>CLY</td>
<td>RX-y-a C LD A</td>
<td></td>
</tr>
<tr>
<td>E356</td>
<td>OR (32)</td>
<td>OY</td>
<td>RX-y-a C LD A</td>
<td></td>
</tr>
<tr>
<td>E357</td>
<td>EXCLUSIVE OR (32)</td>
<td>XY</td>
<td>RX-y-a C LD A</td>
<td></td>
</tr>
<tr>
<td>E358</td>
<td>LOAD (32)</td>
<td>LY</td>
<td>RX-y-a LD A</td>
<td></td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 14 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>E359</td>
<td>COMPARE (32)</td>
<td>CY</td>
<td>RX-Y C LD A</td>
<td>B2</td>
</tr>
<tr>
<td>E35A</td>
<td>ADD (32)</td>
<td>AY</td>
<td>RX-Y C LD A IF</td>
<td>B2</td>
</tr>
<tr>
<td>E35B</td>
<td>SUBTRACT (32)</td>
<td>SY</td>
<td>RX-Y C LD A IF</td>
<td>B2</td>
</tr>
<tr>
<td>E35C</td>
<td>MULTIPLY (64–32)</td>
<td>MFY</td>
<td>RX-Y a GE A SP</td>
<td>B2</td>
</tr>
<tr>
<td>E35E</td>
<td>ADD LOGICAL (32)</td>
<td>ALY</td>
<td>RX-Y C LD A</td>
<td>B2</td>
</tr>
<tr>
<td>E35F</td>
<td>SUBTRACT LOGICAL (32)</td>
<td>SLY</td>
<td>RX-Y C LD A</td>
<td>B2</td>
</tr>
<tr>
<td>E370</td>
<td>STORE HALFWORD (16)</td>
<td>STHY</td>
<td>RX-Y A LD A</td>
<td>ST B2</td>
</tr>
<tr>
<td>E371</td>
<td>LOAD ADDRESS</td>
<td>LAY</td>
<td>RX-Y a LD</td>
<td></td>
</tr>
<tr>
<td>E372</td>
<td>STORE CHARACTER</td>
<td>STCY</td>
<td>RX-Y a LD A</td>
<td>ST</td>
</tr>
<tr>
<td>E373</td>
<td>LOAD CHARACTER</td>
<td>LBY</td>
<td>RX-Y a LD A</td>
<td></td>
</tr>
<tr>
<td>E374</td>
<td>STORE CHARACTER</td>
<td>STCH</td>
<td>RX-Y a LD A</td>
<td>ST</td>
</tr>
<tr>
<td>E375</td>
<td>LOAD ADDRESS EXTENDED</td>
<td>LAEY</td>
<td>RX-Y a GE c↑</td>
<td>U1 BP</td>
</tr>
<tr>
<td>E376</td>
<td>LOAD BYTE (32–8)</td>
<td>LB</td>
<td>RX-Y a LD A</td>
<td></td>
</tr>
<tr>
<td>E377</td>
<td>LOAD BYTE (64–8)</td>
<td>LGB</td>
<td>RX-Y a LD A</td>
<td></td>
</tr>
<tr>
<td>E378</td>
<td>LOAD HALFWORD (32)–16</td>
<td>LHY</td>
<td>RX-Y a LD A</td>
<td>B2</td>
</tr>
<tr>
<td>E379</td>
<td>COMPARE HALFWORD (32–16)</td>
<td>CHY</td>
<td>RX-Y a LD A</td>
<td>B2</td>
</tr>
<tr>
<td>E37A</td>
<td>ADD HALFWORD (32–16)</td>
<td>AHY</td>
<td>RX-Y a LD A</td>
<td>B2</td>
</tr>
<tr>
<td>E37B</td>
<td>SUBTRACT HALFWORD (32–16)</td>
<td>SHY</td>
<td>RX-Y a LD A</td>
<td>B2</td>
</tr>
<tr>
<td>E37C</td>
<td>MULTIPLY HALFWORD (32–16)</td>
<td>MHY</td>
<td>RX-Y a GE A</td>
<td>B2</td>
</tr>
<tr>
<td>E380</td>
<td>AND (64)</td>
<td>NG</td>
<td>RX-Y a C N A</td>
<td>B2</td>
</tr>
<tr>
<td>E381</td>
<td>OR (64)</td>
<td>OG</td>
<td>RX-Y a C N A</td>
<td>B2</td>
</tr>
<tr>
<td>E382</td>
<td>EXCLUSIVE OR (64)</td>
<td>XG</td>
<td>RX-Y a C N A</td>
<td>B2</td>
</tr>
<tr>
<td>E385</td>
<td>LOAD AND TRAP (64)</td>
<td>LGAT</td>
<td>RX-Y a LT A Dc</td>
<td>B2</td>
</tr>
<tr>
<td>E386</td>
<td>MULTIPLY LOGICAL (128–64)</td>
<td>MLG</td>
<td>RX-Y a N A SP</td>
<td>B2</td>
</tr>
<tr>
<td>E387</td>
<td>DIVIDE LOGICAL (64–128)</td>
<td>DLG</td>
<td>RX-Y a N c↑ A SP</td>
<td>IK</td>
</tr>
<tr>
<td>E388</td>
<td>ADD LOGICAL WITH CARRY (64)</td>
<td>ALC</td>
<td>RX-Y a C N A</td>
<td>B2</td>
</tr>
<tr>
<td>E389</td>
<td>SUBTRACT LOGICAL WITH BORROW (64)</td>
<td>SLB</td>
<td>RX-Y a C N A</td>
<td>B2</td>
</tr>
<tr>
<td>E390</td>
<td>STORE PAIR TO QUADWORD</td>
<td>STPQ</td>
<td>RX-Y a N c↑ A SP</td>
<td>ST</td>
</tr>
<tr>
<td>E391</td>
<td>LOAD PAIR FROM QUADWORD (64&amp;64–128)</td>
<td>LPG</td>
<td>RX-Y a N c↑ A SP</td>
<td>B2</td>
</tr>
<tr>
<td>E392</td>
<td>LOAD LOGICAL CHARACTER (64–8)</td>
<td>LLGC</td>
<td>RX-Y a N A</td>
<td>B2</td>
</tr>
<tr>
<td>E391</td>
<td>LOAD LOGICAL HALFWORD (64–16)</td>
<td>LLGH</td>
<td>RX-Y a N A</td>
<td>B2</td>
</tr>
<tr>
<td>E394</td>
<td>LOAD LOGICAL CHARACTER (32–8)</td>
<td>LLC</td>
<td>RX-Y a EI A</td>
<td>B2</td>
</tr>
<tr>
<td>E395</td>
<td>LOAD LOGICAL HALFWORD (32–16)</td>
<td>LLH</td>
<td>RX-Y a EI A</td>
<td>B2</td>
</tr>
<tr>
<td>E396</td>
<td>MULTIPLY LOGICAL (64–32)</td>
<td>ML</td>
<td>RX-Y a N3 A SP</td>
<td>B2</td>
</tr>
<tr>
<td>E397</td>
<td>DIVIDE LOGICAL (32–64)</td>
<td>DL</td>
<td>RX-Y a N3 c↑ A SP</td>
<td>IK</td>
</tr>
<tr>
<td>E398</td>
<td>ADD LOGICAL WITH CARRY (32)</td>
<td>ALC</td>
<td>RX-Y a C N3 A</td>
<td>B2</td>
</tr>
<tr>
<td>E399</td>
<td>SUBTRACT LOGICAL WITH BORROW (32)</td>
<td>SLB</td>
<td>RX-Y a C N3 A</td>
<td>B2</td>
</tr>
<tr>
<td>E39C</td>
<td>LOAD LOGICAL THIRTY ONE BITS AND TRAP (64–31)</td>
<td>LLGST</td>
<td>RX-Y a LT A Dc</td>
<td>B2</td>
</tr>
<tr>
<td>E39D</td>
<td>LOAD LOGICAL AND TRAP (64–32)</td>
<td>LLGFAT</td>
<td>RX-Y a LT A Dc</td>
<td>B2</td>
</tr>
<tr>
<td>E39F</td>
<td>LOAD AND TRAP (32L–32)</td>
<td>LAT</td>
<td>RX-Y a LT A Dc</td>
<td>B2</td>
</tr>
<tr>
<td>E3C0</td>
<td>LOAD BYTE HIGH (32–8)</td>
<td>LBH</td>
<td>RX-Y a HW A</td>
<td>B2</td>
</tr>
<tr>
<td>E3C1</td>
<td>LOAD LOGICAL CHARACTER HIGH (32–8)</td>
<td>LLCH</td>
<td>RX-Y a HW A</td>
<td>B2</td>
</tr>
<tr>
<td>E3C2</td>
<td>STORE CHARACTER HIGH (8)</td>
<td>STCH</td>
<td>RX-Y a HW A</td>
<td>ST B2</td>
</tr>
<tr>
<td>E3C3</td>
<td>LOAD CHARACTER HIGH (32)</td>
<td>LCH</td>
<td>RX-Y a HW A</td>
<td>ST B2</td>
</tr>
<tr>
<td>E3C4</td>
<td>LOAD LOGICAL HALFWORD HIGH (32–16)</td>
<td>LHH</td>
<td>RX-Y a HW A</td>
<td>ST B2</td>
</tr>
<tr>
<td>E3C5</td>
<td>LOAD LOGICAL HALFWORD HIGH (32–16)</td>
<td>LLH</td>
<td>RX-Y a HW A</td>
<td>ST B2</td>
</tr>
<tr>
<td>E3C7</td>
<td>STORE LOGICAL HALFWORD HIGH (32–16)</td>
<td>STH</td>
<td>RX-Y a HW A</td>
<td>ST B2</td>
</tr>
<tr>
<td>E3C8</td>
<td>LOAD HIGH AND TRAP (32H–32)</td>
<td>LFHAT</td>
<td>RX-Y a LT A Dc</td>
<td>B2</td>
</tr>
<tr>
<td>E3C9</td>
<td>LOAD HIGH (32)</td>
<td>LHF</td>
<td>RX-Y a HW A</td>
<td>B2</td>
</tr>
<tr>
<td>E3CB</td>
<td>STORE HIGH (32)</td>
<td>STFH</td>
<td>RX-Y a HW A</td>
<td>ST B2</td>
</tr>
<tr>
<td>E3CD</td>
<td>COMPARE HIGH (32)</td>
<td>CHF</td>
<td>RX-Y a C HW A</td>
<td>B2</td>
</tr>
<tr>
<td>E3CF</td>
<td>COMPARE LOGICAL HIGH (32)</td>
<td>CLHF</td>
<td>RX-Y a C HW A</td>
<td>B2</td>
</tr>
<tr>
<td>E500</td>
<td>LOAD ADDRESS SPACE PARAMETERS</td>
<td>LSP</td>
<td>RX-Y a C P A’ SP</td>
<td>SO B2</td>
</tr>
<tr>
<td>E501</td>
<td>TEST PROTECTION</td>
<td>TPRT</td>
<td>RX-Y a C P A’&quot;</td>
<td>B2</td>
</tr>
<tr>
<td>E502</td>
<td>STORE REAL ADDRESS</td>
<td>STRAG</td>
<td>RX-Y a C P A’ SP</td>
<td>ST B2</td>
</tr>
<tr>
<td>E50E</td>
<td>MOVE WITH SOURCE KEY</td>
<td>MVCFSK</td>
<td>RX-Y a C HW A</td>
<td>B2</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 15 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>E50F</td>
<td>MOVE WITH DESTINATION KEY</td>
<td>MVCDK</td>
<td>SS     Q A</td>
<td>GM</td>
</tr>
<tr>
<td>E544</td>
<td>MOVE (16→16)</td>
<td>MVHHI</td>
<td>SIL GE A</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E548</td>
<td>MOVE (64→16)</td>
<td>MVGHI</td>
<td>SIL GE A</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E54C</td>
<td>MOVE (32→16)</td>
<td>MVHI</td>
<td>SIL GE A</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E554</td>
<td>COMPARE HALFWORD IMMEDIATE (16→16)</td>
<td>CHHSI</td>
<td>SIL C GE A</td>
<td>$B_1</td>
</tr>
<tr>
<td>E555</td>
<td>COMPARE LOGICAL IMMEDIATE (16→16)</td>
<td>CLHHSI</td>
<td>SIL C GE A</td>
<td>$B_1</td>
</tr>
<tr>
<td>E558</td>
<td>COMPARE HALFWORD IMMEDIATE (64→16)</td>
<td>CGHSI</td>
<td>SIL C GE A</td>
<td>$B_1</td>
</tr>
<tr>
<td>E559</td>
<td>COMPARE LOGICAL IMMEDIATE (64→16)</td>
<td>CLGHSI</td>
<td>SIL C GE A</td>
<td>$B_1</td>
</tr>
<tr>
<td>E55C</td>
<td>COMPARE HALFWORD IMMEDIATE (32→16)</td>
<td>CHSI</td>
<td>SIL C GE A</td>
<td>$B_1</td>
</tr>
<tr>
<td>E55D</td>
<td>COMPARE LOGICAL IMMEDIATE (32→16)</td>
<td>CLFSI</td>
<td>SIL C GE A</td>
<td>$B_1</td>
</tr>
<tr>
<td>E560</td>
<td>TRANSACTION BEGIN (nonconstrained)</td>
<td>TBEGIN</td>
<td>SIL C TX $A SP $ SO $EX</td>
<td>ST</td>
</tr>
<tr>
<td>E561</td>
<td>TRANSACTION BEGIN (constrained)</td>
<td>TBEGINC</td>
<td>SIL C CX $A SP $ SO $EX</td>
<td></td>
</tr>
<tr>
<td>E700</td>
<td>VECTOR LOAD ELEMENT (8)</td>
<td>VLEB</td>
<td>VRX VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E701</td>
<td>VECTOR LOAD ELEMENT (16)</td>
<td>VLEH</td>
<td>VRX VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E702</td>
<td>VECTOR LOAD ELEMENT (64)</td>
<td>VLEG</td>
<td>VRX VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E703</td>
<td>VECTOR LOAD ELEMENT (32)</td>
<td>VLEF</td>
<td>VRX VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E704</td>
<td>VECTOR LOAD LOGICAL ELEMENT AND ZERO</td>
<td>VLEZ</td>
<td>VRX VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E705</td>
<td>VECTOR LOAD AND REPLICATE</td>
<td>VLREP</td>
<td>VRX VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E706</td>
<td>VECTOR LOAD</td>
<td>VL</td>
<td>VRX VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E707</td>
<td>VECTOR LOAD TO BLOCK BOUNDARY</td>
<td>VLBB</td>
<td>VRX VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E708</td>
<td>VECTOR STORE ELEMENT (8)</td>
<td>VSTEB</td>
<td>VRX VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E709</td>
<td>VECTOR STORE ELEMENT (16)</td>
<td>VSTEH</td>
<td>VRX VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E70A</td>
<td>VECTOR STORE ELEMENT (64)</td>
<td>VSTEG</td>
<td>VRX VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E70B</td>
<td>VECTOR STORE ELEMENT (32)</td>
<td>VSTEF</td>
<td>VRX VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E70E</td>
<td>VECTOR STORE</td>
<td>VST</td>
<td>VRX VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E712</td>
<td>VECTOR GATHER ELEMENT (64)</td>
<td>VGEG</td>
<td>VRV VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E713</td>
<td>VECTOR GATHER ELEMENT (32)</td>
<td>VGFR</td>
<td>VRV VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E71A</td>
<td>VECTOR SCATTER ELEMENT (64)</td>
<td>VSCEG</td>
<td>VRV VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E71B</td>
<td>VECTOR SCATTER ELEMENT (32)</td>
<td>VSCEF</td>
<td>VRV VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E721</td>
<td>VECTOR LOAD GR FROM VR ELEMENT</td>
<td>VLSG</td>
<td>VRS-c VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E722</td>
<td>VECTOR LOAD VR ELEMENT FROM GR</td>
<td>VLVG</td>
<td>VRS-b VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E727</td>
<td>LOAD COUNT TO BLOCK BOUNDARY</td>
<td>LCBB</td>
<td>RXE C VF $SP</td>
<td></td>
</tr>
<tr>
<td>E730</td>
<td>VECTOR ELEMENT SHIFT LEFT</td>
<td>VESL</td>
<td>VRS-a VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E733</td>
<td>VECTOR ELEMENT ROTATE LEFT LOGICAL</td>
<td>VERLL</td>
<td>VRS-a VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E736</td>
<td>VECTOR LOAD MULTIPLE</td>
<td>VLM</td>
<td>VRS-a VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E737</td>
<td>VECTOR LOAD WITH LENGTH</td>
<td>VLL</td>
<td>VRS-b VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E738</td>
<td>VECTOR ELEMENT SHIFT RIGHT LOGICAL</td>
<td>VESR</td>
<td>VRS-a VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E739</td>
<td>VECTOR ELEMENT SHIFT RIGHT ARITHMETIC</td>
<td>VESRA</td>
<td>VRS-a VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E73E</td>
<td>VECTOR STORE MULTIPLE</td>
<td>VSTM</td>
<td>VRS-a VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E73F</td>
<td>VECTOR STORE WITH LENGTH</td>
<td>VSTL</td>
<td>VRS-b VF $A $ SP Dv</td>
<td>ST $B_1</td>
</tr>
<tr>
<td>E740</td>
<td>VECTOR LOAD ELEMENT IMMEDIATE (8)</td>
<td>VLEIB</td>
<td>VRI-a VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E741</td>
<td>VECTOR LOAD ELEMENT IMMEDIATE (16)</td>
<td>VLEIH</td>
<td>VRI-a VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E742</td>
<td>VECTOR LOAD ELEMENT IMMEDIATE (64)</td>
<td>VLEIG</td>
<td>VRI-a VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E743</td>
<td>VECTOR LOAD ELEMENT IMMEDIATE (32)</td>
<td>VLEIF</td>
<td>VRI-a VF $A $ SP Dv</td>
<td>$B_1</td>
</tr>
<tr>
<td>E744</td>
<td>VECTOR GENERATE BYTE MASK</td>
<td>VGBM</td>
<td>VRI-a VF $A $ Dv</td>
<td></td>
</tr>
<tr>
<td>E745</td>
<td>VECTOR REPLICATE IMMEDIATE</td>
<td>VREPI</td>
<td>VRI-a VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E746</td>
<td>VECTOR GENERATE MASK</td>
<td>VGM</td>
<td>VRI-b VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E74A</td>
<td>VECTOR FP TEST DATA CLASS IMMEDIATE</td>
<td>VFTCI</td>
<td>VRHI C VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E74D</td>
<td>VECTOR REPLICATE</td>
<td>VREP</td>
<td>VRH-c VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E750</td>
<td>VECTOR POPULATION COUNT</td>
<td>VPOPCT</td>
<td>VRH-a VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E752</td>
<td>VECTOR COUNT TRAILING ZEROS</td>
<td>VCTZ</td>
<td>VRH-a VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E753</td>
<td>VECTOR COUNT LEADING ZEROS</td>
<td>VCLZ</td>
<td>VRH-a VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E756</td>
<td>VECTOR LOAD</td>
<td>VLR</td>
<td>VRH-a VF $A $ Dv</td>
<td></td>
</tr>
<tr>
<td>E75C</td>
<td>VECTOR ISOLATE STRING</td>
<td>VISTR</td>
<td>VRH-a CI* VF $A $ SP Dv</td>
<td></td>
</tr>
<tr>
<td>E75F</td>
<td>VECTOR SIGN EXTEND TO DOUBLEWORD</td>
<td>VSEG</td>
<td>VRH-a VF $A $ SP Dv</td>
<td></td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 16 of 22)
<table>
<thead>
<tr>
<th>Opcode</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
</tr>
</thead>
<tbody>
<tr>
<td>E760</td>
<td>VECTOR MERGE LOW</td>
<td>VMRL</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E761</td>
<td>VECTOR MERGE HIGH</td>
<td>VMRH</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E762</td>
<td>VECTOR LOAD VR FROM GRS DISJOINT</td>
<td>VLVGP</td>
<td>VRR-f VF g^3 SP Dv</td>
</tr>
<tr>
<td>E764</td>
<td>VECTOR SUM ACROSS WORD</td>
<td>VSUM</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E765</td>
<td>VECTOR SUM ACROSS DOUBLEWORD</td>
<td>VSUMG</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E766</td>
<td>VECTOR CHECKSUM</td>
<td>VCKSM</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E767</td>
<td>VECTOR SUM ACROSS QUADWORD</td>
<td>VSUMQ</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E768</td>
<td>VECTOR AND</td>
<td>VN</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E769</td>
<td>VECTOR AND WITH COMPLEMENT</td>
<td>VNC</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E76A</td>
<td>VECTOR OR</td>
<td>VO</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E76B</td>
<td>VECTOR NOR</td>
<td>VNO</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E76D</td>
<td>VECTOR EXCLUSIVE OR</td>
<td>VX</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E770</td>
<td>VECTOR ELEMENT SHIFT LEFT</td>
<td>VESLV</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E772</td>
<td>VECTOR ELEMENT ROTATE AND INSERT UNDER MASK</td>
<td>VERIM</td>
<td>VRI-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E773</td>
<td>VECTOR ELEMENT ROTATE LEFT LOGICAL</td>
<td>VERLLV</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E774</td>
<td>VECTOR SHIFT LEFT</td>
<td>VSL</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E775</td>
<td>VECTOR SHIFT LEFT BY BYTE</td>
<td>VSLB</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E777</td>
<td>VECTOR SHIFT LEFT DOUBLE BY BYTE</td>
<td>VSLDB</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E778</td>
<td>VECTOR ELEMENT SHIFT RIGHT LOGICAL</td>
<td>VESRLV</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E779</td>
<td>VECTOR ELEMENT SHIFT RIGHT ARITHMETIC</td>
<td>VESRAV</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E77C</td>
<td>VECTOR SHIFT RIGHT LOGICAL</td>
<td>VSRL</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E77D</td>
<td>VECTOR SHIFT RIGHT LOGICAL BY BYTE</td>
<td>VSRLOB</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E77E</td>
<td>VECTOR SHIFT RIGHT ARITHMETIC</td>
<td>VSRA</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E77F</td>
<td>VECTOR SHIFT RIGHT ARITHMETIC BY BYTE</td>
<td>VSRAB</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E780</td>
<td>VECTOR FIND ELEMENT EQUAL</td>
<td>VFEE</td>
<td>VRR-b C* VF g^3 SP Dv</td>
</tr>
<tr>
<td>E781</td>
<td>VECTOR FIND ELEMENT NOT EQUAL</td>
<td>VFENE</td>
<td>VRR-b C* VF g^3 SP Dv</td>
</tr>
<tr>
<td>E782</td>
<td>VECTOR FIND ANY ELEMENT EQUAL</td>
<td>VFAE</td>
<td>VRR-b C* VF g^3 SP Dv</td>
</tr>
<tr>
<td>E784</td>
<td>VECTOR PERMUTE DOUBLEWORD IMMEDIATE</td>
<td>VPDI</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E78A</td>
<td>VECTOR STRING RANGE COMPARE</td>
<td>VSTRC</td>
<td>VRR-d C* VF g^3 SP Dv</td>
</tr>
<tr>
<td>E78C</td>
<td>VECTOR PERMUTE</td>
<td>VPERM</td>
<td>VRR-e VF g^3 SP Dv</td>
</tr>
<tr>
<td>E78D</td>
<td>VECTOR SELECT</td>
<td>VSEL</td>
<td>VRR-e VF g^3 SP Dv</td>
</tr>
<tr>
<td>E78E</td>
<td>VECTOR FP MULTIPLY AND SUBTRACT</td>
<td>VFMS</td>
<td>VRR-e VF g^3 SP Dv</td>
</tr>
<tr>
<td>E78F</td>
<td>VECTOR FP MULTIPLY AND ADD</td>
<td>VFMA</td>
<td>VRR-e VF g^3 SP Dv</td>
</tr>
<tr>
<td>E794</td>
<td>VECTOR PACK</td>
<td>VPK</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E795</td>
<td>VECTOR PACK LOGICAL SATURATE</td>
<td>VPKLS</td>
<td>VRR-b C* VF g^3 SP Dv</td>
</tr>
<tr>
<td>E797</td>
<td>VECTOR PACK SATURATE</td>
<td>VPKS</td>
<td>VRR-b C* VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A1</td>
<td>VECTOR MULTIPLY LOGICAL HIGH</td>
<td>VMLH</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A2</td>
<td>VECTOR MULTIPLY LOW</td>
<td>VML</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A3</td>
<td>VECTOR MULTIPLY HIGH</td>
<td>VMH</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A4</td>
<td>VECTOR MULTIPLY LOGICAL EVEN</td>
<td>VMLE</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A5</td>
<td>VECTOR MULTIPLY LOGICAL ODD</td>
<td>VMLO</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A6</td>
<td>VECTOR MULTIPLY EVEN</td>
<td>VME</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A7</td>
<td>VECTOR MULTIPLY ODD</td>
<td>VMO</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A9</td>
<td>VECTOR MULTIPLY AND ADD LOGICAL HIGH</td>
<td>VMALH</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A8</td>
<td>VECTOR MULTIPLY AND ADD LOW</td>
<td>VMAL</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7A7</td>
<td>VECTOR MULTIPLY AND ADD HIGH</td>
<td>VMAH</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7AC</td>
<td>VECTOR MULTIPLY AND ADD LOGICAL EVEN</td>
<td>VMALE</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7AD</td>
<td>VECTOR MULTIPLY AND ADD LOGICAL ODD</td>
<td>VMALO</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7AE</td>
<td>VECTOR MULTIPLY AND ADD EVEN</td>
<td>VMAE</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7AF</td>
<td>VECTOR MULTIPLY AND ADD ODD</td>
<td>VMAO</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7B4</td>
<td>VECTOR GALOIS FIELD MULTIPLY SUM</td>
<td>VGFM</td>
<td>VRR-c VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7B9</td>
<td>VECTOR ADD WITH CARRY COMPUTE CARRY</td>
<td>VACCC</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
<tr>
<td>E7BB</td>
<td>VECTOR ADD WITH CARRY</td>
<td>VAC</td>
<td>VRR-d VF g^3 SP Dv</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 17 of 22)
<table>
<thead>
<tr>
<th>OpCode</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>E7BC</td>
<td>VECTOR GALOIS FIELD MULTIPLY SUM AND ACCUMULATE</td>
<td>VGFMA</td>
<td>VF (d \times d) SP Dv</td>
<td>22-11</td>
</tr>
<tr>
<td>E7BD</td>
<td>VECTOR SUBTRACT WITH BORROW COMPUTE BORROW INDICATION</td>
<td>VSBCBI</td>
<td>VF (d - d) SP Dv</td>
<td>22-26</td>
</tr>
<tr>
<td>E7BF</td>
<td>VECTOR SUBTRACT WITH BORROW INDICATION</td>
<td>VSBI</td>
<td>VF (d - d) SP Dv Xi Xx</td>
<td>24-18</td>
</tr>
<tr>
<td>E7C0</td>
<td>VECTOR FP CONVERT TO LOGICAL 64-BIT</td>
<td>VCLDG</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-15</td>
</tr>
<tr>
<td>E7C1</td>
<td>VECTOR FP CONVERT FROM LOGICAL 64-BIT</td>
<td>VCDLG</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-16</td>
</tr>
<tr>
<td>E7C2</td>
<td>VECTOR FP CONVERT TO FIXED 64-BIT</td>
<td>VCGD</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-16</td>
</tr>
<tr>
<td>E7C3</td>
<td>VECTOR FP CONVERT FROM FIXED 64-BIT</td>
<td>VCDG</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-14</td>
</tr>
<tr>
<td>E7C4</td>
<td>VECTOR FP LOAD LENGTHENED</td>
<td>VLDE</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-24</td>
</tr>
<tr>
<td>E7C5</td>
<td>VECTOR FP LOAD ROUNDED</td>
<td>VLED</td>
<td>VF (a) SP Dv Xi Xx Xx</td>
<td>24-25</td>
</tr>
<tr>
<td>E7C7</td>
<td>VECTOR LOAD FP INTEGER</td>
<td>VFI</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-22</td>
</tr>
<tr>
<td>E7CA</td>
<td>VECTOR FP COMPARE AND SIGNAL SCALAR</td>
<td>WFK</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-8</td>
</tr>
<tr>
<td>E7CB</td>
<td>VECTOR FP COMPARE SCALAR</td>
<td>WFC</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-7</td>
</tr>
<tr>
<td>E7CC</td>
<td>VECTOR FP PERFORM SIGN OPERATION</td>
<td>VFPSO</td>
<td>VF (a) SP Dv Xi Xx</td>
<td>24-29</td>
</tr>
<tr>
<td>E7CE</td>
<td>VECTOR FP SQUARE ROOT</td>
<td>VFSQ</td>
<td>VF (a) SP Dv Xi Xx Xx</td>
<td>24-30</td>
</tr>
<tr>
<td>E7D0</td>
<td>VECTOR UNPACK LOGICAL LOW</td>
<td>VUPLL</td>
<td>VF (a) SP Dv</td>
<td>21-18</td>
</tr>
<tr>
<td>E7D5</td>
<td>VECTOR UNPACK LOGICAL HIGH</td>
<td>VUPLH</td>
<td>VF (a) SP Dv</td>
<td>21-18</td>
</tr>
<tr>
<td>E7D6</td>
<td>VECTOR UNPACK LOW</td>
<td>VUPL</td>
<td>VF (a) SP Dv</td>
<td>21-19</td>
</tr>
<tr>
<td>E7D7</td>
<td>VECTOR UNPACK HIGH</td>
<td>VUPH</td>
<td>VF (a) SP Dv</td>
<td>21-17</td>
</tr>
<tr>
<td>E7D8</td>
<td>VECTOR TEST UNDER MASK</td>
<td>VTM</td>
<td>VF (a) SP Dv</td>
<td>22-28</td>
</tr>
<tr>
<td>E7D9</td>
<td>VECTOR ELEMENT COMPARE LOGICAL</td>
<td>VECL</td>
<td>VF (a) SP Dv</td>
<td>22-7</td>
</tr>
<tr>
<td>E7DB</td>
<td>VECTOR ELEMENT COMPARE</td>
<td>VEC</td>
<td>VF (a) SP Dv</td>
<td>22-7</td>
</tr>
<tr>
<td>E7E0</td>
<td>VECTOR LOAD COMPLEMENT</td>
<td>VLC</td>
<td>VF (a) SP Dv</td>
<td>22-12</td>
</tr>
<tr>
<td>E7E1</td>
<td>VECTOR LOAD POSITIVE</td>
<td>VLP</td>
<td>VF (a) SP Dv</td>
<td>22-12</td>
</tr>
<tr>
<td>E7E2</td>
<td>VECTOR FP SUBTRACT</td>
<td>VFS</td>
<td>VF (c) SP Dv Xi Xo XU Xx</td>
<td>24-31</td>
</tr>
<tr>
<td>E7E3</td>
<td>VECTOR FP ADD</td>
<td>VFA</td>
<td>VF (c) SP Dv Xi Xo XU Xx</td>
<td>24-3</td>
</tr>
<tr>
<td>E7E4</td>
<td>VECTOR FP DIVIDE</td>
<td>VF D</td>
<td>VF (c) SP Dv</td>
<td>24-37</td>
</tr>
<tr>
<td>E7E7</td>
<td>VECTOR FP MULTIPLY</td>
<td>VFM</td>
<td>VF (c) SP Dv Xi Xo XU Xx</td>
<td>24-26</td>
</tr>
<tr>
<td>E7E8</td>
<td>VECTOR FP COMPARE EQUAL</td>
<td>VFCE</td>
<td>VF (c) SP Dv Xi Xo XU Xx</td>
<td>24-9</td>
</tr>
<tr>
<td>E7E9</td>
<td>VECTOR FP COMPARE HIGH OR EQUAL</td>
<td>VFCE</td>
<td>VF (c) SP Dv Xi</td>
<td>24-12</td>
</tr>
<tr>
<td>E7EB</td>
<td>VECTOR FP COMPARE HIGH</td>
<td>VFCH</td>
<td>VF (c) SP Dv Xi</td>
<td>24-10</td>
</tr>
<tr>
<td>E7F0</td>
<td>VECTOR AVERAGE LOGICAL</td>
<td>WAVGL</td>
<td>VF (c) SP Dv</td>
<td>22-6</td>
</tr>
<tr>
<td>E7F1</td>
<td>VECTOR ADD COMPUTE CARRY</td>
<td>VACC</td>
<td>VF (c) SP Dv</td>
<td>22-4</td>
</tr>
<tr>
<td>E7F2</td>
<td>VECTOR AVERAGE</td>
<td>WAVG</td>
<td>VF (c) SP Dv</td>
<td>22-5</td>
</tr>
<tr>
<td>E7F3</td>
<td>VECTOR ADD</td>
<td>VAC</td>
<td>VF (c) SP Dv</td>
<td>22-3</td>
</tr>
<tr>
<td>E7F5</td>
<td>VECTOR SUBTRACT COMPUTE BORROW INDICATION</td>
<td>VSCBI</td>
<td>VF (c) SP Dv</td>
<td>22-25</td>
</tr>
<tr>
<td>E7F7</td>
<td>VECTOR SUBTRACT</td>
<td>VSC</td>
<td>VF (c) SP Dv</td>
<td>22-25</td>
</tr>
<tr>
<td>E7F8</td>
<td>VECTOR COMPARE EQUAL</td>
<td>VCEG</td>
<td>VF (c) SP Dv</td>
<td>22-7</td>
</tr>
<tr>
<td>E7F9</td>
<td>VECTOR COMPARE HIGH LOGICAL</td>
<td>VCHL</td>
<td>VF (c) SP Dv</td>
<td>22-9</td>
</tr>
<tr>
<td>E7FB</td>
<td>VECTOR COMPARE HIGH</td>
<td>VCH</td>
<td>VF (c) SP Dv</td>
<td>22-8</td>
</tr>
<tr>
<td>E7FC</td>
<td>VECTOR MINIMUM LOGICAL</td>
<td>VMNL</td>
<td>VF (c) SP Dv</td>
<td>22-13</td>
</tr>
<tr>
<td>E7FD</td>
<td>VECTOR MAXIMUM LOGICAL</td>
<td>VMXL</td>
<td>VF (c) SP Dv</td>
<td>22-13</td>
</tr>
<tr>
<td>E7FE</td>
<td>VECTOR MINIMUM</td>
<td>VMN</td>
<td>VF (c) SP Dv</td>
<td>22-13</td>
</tr>
<tr>
<td>E7FF</td>
<td>VECTOR MAXIMUM</td>
<td>VMX</td>
<td>VF (c) SP Dv</td>
<td>22-13</td>
</tr>
<tr>
<td>E8</td>
<td>MOVE INVERSE</td>
<td>MVCIN</td>
<td>Sa (a) AS ST B1 B2</td>
<td>7-245</td>
</tr>
<tr>
<td>E9</td>
<td>PACK ASCII</td>
<td>PKA</td>
<td>SS-f E2 (a) AS ST B1 B2</td>
<td>7-267</td>
</tr>
<tr>
<td>EA</td>
<td>UNPACK ASCII</td>
<td>UNPKA</td>
<td>SS-a C E2 (a) AS ST B1 B2</td>
<td>7-367</td>
</tr>
<tr>
<td>EB04</td>
<td>LOAD MULTIPLE (64)</td>
<td>LMG</td>
<td>RSY-a N</td>
<td>7-237</td>
</tr>
<tr>
<td>EB0A</td>
<td>SHIFT RIGHT SINGLE (64)</td>
<td>SRAG</td>
<td>RSY-a C N</td>
<td>7-326</td>
</tr>
<tr>
<td>EB0B</td>
<td>SHIFT LEFT SINGLE (64)</td>
<td>SLAG</td>
<td>RSY-a C N</td>
<td>7-323</td>
</tr>
<tr>
<td>EB0C</td>
<td>SHIFT RIGHT SINGLE LOGICAL (64)</td>
<td>SRLG</td>
<td>RSY-a N</td>
<td>7-327</td>
</tr>
<tr>
<td>EB0D</td>
<td>SHIFT LEFT SINGLE LOGICAL (64)</td>
<td>SLLG</td>
<td>RSY-a N</td>
<td>7-324</td>
</tr>
<tr>
<td>EB0F</td>
<td>TRACE (64)</td>
<td>TRACG</td>
<td>RSY-a N</td>
<td>10-166</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 18 of 22)
<table>
<thead>
<tr>
<th>Op-</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>EB14</td>
<td>COMPARE AND SWAP (32)</td>
<td>CST</td>
<td>RSY-a C LD $ A SP $</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB1C</td>
<td>ROTATE LEFT SINGLE LOGICAL (64)</td>
<td>RLLG</td>
<td>RSY-a N</td>
<td>7-312</td>
</tr>
<tr>
<td>EB1D</td>
<td>ROTATE LEFT SINGLE LOGICAL (32)</td>
<td>RLL</td>
<td>RSY-a N3</td>
<td>7-312</td>
</tr>
<tr>
<td>EB20</td>
<td>COMPARE LOGICAL CHAR. UNDER MASK (high)</td>
<td>CLMH</td>
<td>RSY-b C N A</td>
<td>B2</td>
</tr>
<tr>
<td>EB21</td>
<td>COMPARE LOGICAL CHAR. UNDER MASK (low)</td>
<td>CLMY</td>
<td>RSY-b C LD A</td>
<td>B2</td>
</tr>
<tr>
<td>EB23</td>
<td>COMPARE LOGICAL AND TRAP (32)</td>
<td>CLT</td>
<td>RSY-b Mi A Dc</td>
<td>B2</td>
</tr>
<tr>
<td>EB24</td>
<td>STORE MULTIPLE (64)</td>
<td>STMG</td>
<td>RSY-a N A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB25</td>
<td>STORE CONTROL (64)</td>
<td>STCTG</td>
<td>RSY-a N P A SP</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB26</td>
<td>STORE MULTIPLE HIGH (32)</td>
<td>STMH</td>
<td>RSY-a N A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB2B</td>
<td>COMPARE LOGICAL AND TRAP (64)</td>
<td>CLGT</td>
<td>RSY-b Mi A Dc</td>
<td>B2</td>
</tr>
<tr>
<td>EB2C</td>
<td>STORE CHARACTERS UNDER MASK (high)</td>
<td>STCMH</td>
<td>RSY-b N $ A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB2D</td>
<td>STORE CHARACTERS UNDER MASK (low)</td>
<td>STCMY</td>
<td>RSY-b LD A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB2F</td>
<td>LOAD CONTROL (64)</td>
<td>LCTLG</td>
<td>RSY-a N P A SP</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB30</td>
<td>COMPARE AND SWAP (64)</td>
<td>CSG</td>
<td>RSY-a C N $ A SP $</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB31</td>
<td>COMPARE DOUBLE AND SWAP (32)</td>
<td>CDSY</td>
<td>RSY-a C LD $ A SP $</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB32</td>
<td>COMPARE DOUBLE AND SWAP (64)</td>
<td>CDSG</td>
<td>RSY-a C N $ A SP $</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB44</td>
<td>BRANCH ON INDEX HIGH (64)</td>
<td>BXHG</td>
<td>RSY-a N $ A B</td>
<td>B2</td>
</tr>
<tr>
<td>EB45</td>
<td>BRANCH ON INDEX LOW OR EQUAL (64)</td>
<td>BXLEG</td>
<td>RSY-a N $ A B</td>
<td>B2</td>
</tr>
<tr>
<td>EB4C</td>
<td>EXTRACT CPU ATTRIBUTE</td>
<td>ECAG</td>
<td>RSY-a C GE $</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB51</td>
<td>TEST UNDER MASK</td>
<td>TMY</td>
<td>SIY C LD A</td>
<td>B2</td>
</tr>
<tr>
<td>EB52</td>
<td>MOVE (immediate)</td>
<td>MVY</td>
<td>SIY LD A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB54</td>
<td>AND (immediate)</td>
<td>NIY</td>
<td>SIY C LD A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB55</td>
<td>COMPARE LOGICAL (immediate)</td>
<td>CLY</td>
<td>SIY C LD A</td>
<td>B2</td>
</tr>
<tr>
<td>EB56</td>
<td>OR (immediate)</td>
<td>OIY</td>
<td>SIY C LD A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB57</td>
<td>EXCLUSIVE OR (immediate)</td>
<td>XIY</td>
<td>SIY C LD A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB6A</td>
<td>ADD IMMEDIATE (32&lt;8)</td>
<td>ASI</td>
<td>SIY C GE A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB6E</td>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (32&lt;8)</td>
<td>ALSI</td>
<td>SIY C GE A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB7A</td>
<td>ADD IMMEDIATE (64&lt;8)</td>
<td>AGSI</td>
<td>SIY C GE A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB7E</td>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (64&lt;8)</td>
<td>ALGSI</td>
<td>SIY C GE A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB80</td>
<td>INSERT CHARACTERS UNDER MASK (high)</td>
<td>ICMH</td>
<td>RSY-b C N A</td>
<td>B2</td>
</tr>
<tr>
<td>EB81</td>
<td>INSERT CHARACTERS UNDER MASK (low)</td>
<td>ICMI</td>
<td>RSY-b C LD A</td>
<td>B2</td>
</tr>
<tr>
<td>EB8E</td>
<td>MOVE LONG UNICODE</td>
<td>MVCLU</td>
<td>RSY-a C E2 $ A SP IC</td>
<td>ST R1</td>
</tr>
<tr>
<td>EB8F</td>
<td>COMPARE LOGICAL LONG UNICODE</td>
<td>CCLU</td>
<td>RSY-a C E2 $ A SP IC</td>
<td>ST R1</td>
</tr>
<tr>
<td>EB90</td>
<td>STORE MULTIPLE (32)</td>
<td>STMY</td>
<td>RSY-a LD A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EB96</td>
<td>LOAD MULTIPLE HIGH (32)</td>
<td>LMH</td>
<td>RSY-a N A</td>
<td>B2</td>
</tr>
<tr>
<td>EB9B</td>
<td>LOAD MULTIPLE (32)</td>
<td>LMY</td>
<td>RSY-a LD A</td>
<td>B2</td>
</tr>
<tr>
<td>EB9A</td>
<td>LOAD ACCESS MULTIPLE</td>
<td>LAMY</td>
<td>RSY-a LD $ A SP</td>
<td>UB</td>
</tr>
<tr>
<td>EB98</td>
<td>STORE ACCESS MULTIPLE</td>
<td>STAMY</td>
<td>RSY-a LD A</td>
<td>UB</td>
</tr>
<tr>
<td>ECB0</td>
<td>TEST DECIMAL</td>
<td>TP</td>
<td>RSL-a C E2 $ A</td>
<td>B2</td>
</tr>
<tr>
<td>EBC0</td>
<td>SHIFT RIGHT SINGLE (32)</td>
<td>SRAK</td>
<td>RSY-a C DO</td>
<td>7-326</td>
</tr>
<tr>
<td>EBD0</td>
<td>SHIFT LEFT SINGLE (32)</td>
<td>SLAK</td>
<td>RSY-a C DO</td>
<td>7-323</td>
</tr>
<tr>
<td>EBD4</td>
<td>SHIFT RIGHT SINGLE LOGICAL (32)</td>
<td>SRLK</td>
<td>RSY-a DO</td>
<td>7-327</td>
</tr>
<tr>
<td>EBE1</td>
<td>SHIFT LEFT SINGLE LOGICAL (32)</td>
<td>SLK</td>
<td>RSY-a DO</td>
<td>7-324</td>
</tr>
<tr>
<td>EBE0</td>
<td>HIGH ON CONDITION (32)</td>
<td>LOCFH</td>
<td>RSY-b L2 A</td>
<td>B2</td>
</tr>
<tr>
<td>EBE1</td>
<td>HIGH ON CONDITION</td>
<td>STOFCF</td>
<td>RSY-b L2 A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EBE2</td>
<td>LOAD ON CONDITION (64)</td>
<td>LOGC</td>
<td>RSY-b L1 A</td>
<td>B2</td>
</tr>
<tr>
<td>EBE3</td>
<td>STORE ON CONDITION (64)</td>
<td>STOOC</td>
<td>RSY-b L1 A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EBE4</td>
<td>LOAD AND AND (64)</td>
<td>LANG</td>
<td>RSY-a C IA $ A SP £</td>
<td>ST B2</td>
</tr>
<tr>
<td>EBE6</td>
<td>LOAD AND OR (64)</td>
<td>LAOOG</td>
<td>RSY-a C IA $ A SP £</td>
<td>ST B2</td>
</tr>
<tr>
<td>EBE7</td>
<td>LOAD AND EXCLUSIVE OR (64)</td>
<td>LAXG</td>
<td>RSY-a C IA $ A SP £</td>
<td>ST B2</td>
</tr>
<tr>
<td>EBE8</td>
<td>LOAD AND ADD (64)</td>
<td>LAAAG</td>
<td>RSY-a C IA $ A SP IF £</td>
<td>ST B2</td>
</tr>
<tr>
<td>EBEA</td>
<td>LOAD AND ADD LOGICAL (64)</td>
<td>LAALG</td>
<td>RSY-a C IA $ A SP £</td>
<td>ST B2</td>
</tr>
<tr>
<td>EBF2</td>
<td>LOAD ON CONDITION (32)</td>
<td>LOC</td>
<td>RSY-b L1 A</td>
<td>B2</td>
</tr>
<tr>
<td>EBF3</td>
<td>STORE ON CONDITION (32)</td>
<td>STOC</td>
<td>RSY-b L1 A</td>
<td>ST B2</td>
</tr>
<tr>
<td>EBF4</td>
<td>LOAD AND AND (32)</td>
<td>LAN</td>
<td>RSY-a C IA $ A SP £</td>
<td>ST B2</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 19 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>EBF6</td>
<td>LOAD AND OR (32)</td>
<td>LAO</td>
<td>RSY-a C IA A A SP £ ST B2</td>
<td>7-227</td>
</tr>
<tr>
<td>EBF7</td>
<td>LOAD AND EXCLUSIVE OR (32)</td>
<td>LAX</td>
<td>RSY-a C IA A A SP £ ST B2</td>
<td>7-226</td>
</tr>
<tr>
<td>EBF8</td>
<td>LOAD AND ADD (32)</td>
<td>LAA</td>
<td>RSY-a C IA A A SP IF £ ST B2</td>
<td>7-225</td>
</tr>
<tr>
<td>EBF9</td>
<td>LOAD AND ADD LOGICAL (32)</td>
<td>LAAL</td>
<td>RSY-a C IA A A SP £ ST B2</td>
<td>7-225</td>
</tr>
<tr>
<td>EC42</td>
<td>LOAD HALFWORD IMMEDIATE ON CONDITION (32-16)</td>
<td>LOCHI</td>
<td>RIE-g L2</td>
<td>7-232</td>
</tr>
<tr>
<td>EC44</td>
<td>BRANCH RELATIVE ON INDEX HIGH (64)</td>
<td>BRXHG</td>
<td>RIE-e N A² B</td>
<td>7-45</td>
</tr>
<tr>
<td>EC45</td>
<td>BRANCH RELATIVE ON INDEX LOW OR EQ. (64)</td>
<td>BRXLG</td>
<td>RIE-e N A² B</td>
<td>7-46</td>
</tr>
<tr>
<td>EC46</td>
<td>LOAD HALFWORD IMMEDIATE ON CONDITION (64-16)</td>
<td>LOCghi</td>
<td>RIE-g L2</td>
<td>7-232</td>
</tr>
<tr>
<td>EC4E</td>
<td>LOAD HALFWORD HIGH IMMEDIATE ON CONDITION (32-16)</td>
<td>LOCHHI</td>
<td>RIE-g L2</td>
<td>7-232</td>
</tr>
<tr>
<td>EC51</td>
<td>ROTATE THEN INSERT SELECTED BITS LOW (64)</td>
<td>RISBLG</td>
<td>RIE-f HW</td>
<td>7-316</td>
</tr>
<tr>
<td>EC54</td>
<td>ROTATE THEN AND SELECTED BITS (64)</td>
<td>RNSBG</td>
<td>RIE-f C GE</td>
<td>7-312</td>
</tr>
<tr>
<td>EC55</td>
<td>ROTATE THEN INSERT SELECTED BITS (64)</td>
<td>RISBG</td>
<td>RIE-f C GE</td>
<td>7-314</td>
</tr>
<tr>
<td>EC56</td>
<td>LOAD THEN OR SELECTED BITS (64)</td>
<td>ROSBG</td>
<td>RIE-f C GE</td>
<td>7-313</td>
</tr>
<tr>
<td>EC57</td>
<td>LOAD THEN AND SELECTED BITS (64)</td>
<td>RXSBG</td>
<td>RIE-f C GE</td>
<td>7-312</td>
</tr>
<tr>
<td>EC59</td>
<td>BRANCH RELATIVE ON SELECTED BITS HIGH (64)</td>
<td>RISBG</td>
<td>RIE-f MI</td>
<td>7-314</td>
</tr>
<tr>
<td>EC60</td>
<td>BRANCH RELATIVE ON SELECTED BITS HIGH (64)</td>
<td>RISBG</td>
<td>RIE-f HW</td>
<td>7-315</td>
</tr>
<tr>
<td>EC64</td>
<td>COMPARE AND BRANCH RELATIVE (64)</td>
<td>CGRJ</td>
<td>RIE-b GE A² B</td>
<td>7-118</td>
</tr>
<tr>
<td>EC65</td>
<td>COMPARE LOGICAL AND BRANCH RELATIVE (64)</td>
<td>CLGRIJ</td>
<td>RIE-b GE A² B</td>
<td>7-137</td>
</tr>
<tr>
<td>EC70</td>
<td>COMPARE IMMEDIATE AND TRAP (64-16)</td>
<td>CGIT</td>
<td>RIE-a GE</td>
<td>7-132</td>
</tr>
<tr>
<td>EC71</td>
<td>COMPARE IMMEDIATE AND BRANCH (64-16)</td>
<td>CLGIJ</td>
<td>RIE-c GE A²</td>
<td>7-119</td>
</tr>
<tr>
<td>EC72</td>
<td>COMPARE IMMEDIATE AND TRAP (64-16)</td>
<td>CIT</td>
<td>RIE-a GE Dc</td>
<td>7-132</td>
</tr>
<tr>
<td>EC73</td>
<td>COMPARE IMMEDIATE AND BRANCH (32-16)</td>
<td>CLFIT</td>
<td>RIE-a GE Dc</td>
<td>7-139</td>
</tr>
<tr>
<td>EC76</td>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (32)</td>
<td>CRJ</td>
<td>RIE-b GE A² B</td>
<td>7-118</td>
</tr>
<tr>
<td>EC77</td>
<td>COMPARELOGICAL AND BRANCH RELATIVE (32)</td>
<td>CLRJ</td>
<td>RIE-b GE A² B</td>
<td>7-137</td>
</tr>
<tr>
<td>EC7C</td>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (64-8)</td>
<td>CGIJ</td>
<td>RIE-c GE A² B</td>
<td>7-119</td>
</tr>
<tr>
<td>EC7D</td>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (64-8)</td>
<td>CLGIIJ</td>
<td>RIE-c GE A² B</td>
<td>7-137</td>
</tr>
<tr>
<td>EC7E</td>
<td>COMPARE IMMEDIATE AND BRANCH RELATIVE (32-8)</td>
<td>CJ</td>
<td>RIE-c GE A² B</td>
<td>7-119</td>
</tr>
<tr>
<td>EC7F</td>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (32-8)</td>
<td>CLJ</td>
<td>RIE-c GE A² B</td>
<td>7-137</td>
</tr>
<tr>
<td>ECD8</td>
<td>ADD IMMEDIATE (32-16)</td>
<td>AHK</td>
<td>RIE-d C DO IF</td>
<td>7-26</td>
</tr>
<tr>
<td>ECD9</td>
<td>ADD IMMEDIATE (64-16)</td>
<td>AGHIIK</td>
<td>RIE-d C DO</td>
<td>7-26</td>
</tr>
<tr>
<td>ECDA</td>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (32-16)</td>
<td>ALHSIK</td>
<td>RIE-d C DO</td>
<td>7-31</td>
</tr>
<tr>
<td>ECDB</td>
<td>ADD LOGICAL WITH SIGNED IMMEDIATE (64-16)</td>
<td>AGLHSIK</td>
<td>RIE-d C DO</td>
<td>7-31</td>
</tr>
<tr>
<td>ECE4</td>
<td>COMPARE AND BRANCH (64)</td>
<td>CGRB</td>
<td>RRS GE A² B</td>
<td>7-118</td>
</tr>
<tr>
<td>ECE5</td>
<td>COMPARE LOGICAL AND BRANCH (64)</td>
<td>CLGRB</td>
<td>RRS GE A² B</td>
<td>7-137</td>
</tr>
<tr>
<td>ECF6</td>
<td>COMPARE AND BRANCH (32)</td>
<td>CRB</td>
<td>RRS GE A² B</td>
<td>7-118</td>
</tr>
<tr>
<td>ECF7</td>
<td>COMPARE LOGICAL AND BRANCH (32)</td>
<td>CLR</td>
<td>RRS GE A² B</td>
<td>7-137</td>
</tr>
<tr>
<td>ECF8</td>
<td>COMPARE IMMEDIATE AND BRANCH (64-8)</td>
<td>CGIB</td>
<td>RRS GE A² B</td>
<td>7-119</td>
</tr>
<tr>
<td>ECF9</td>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (64-8)</td>
<td>CLGIB</td>
<td>RRS GE A² B</td>
<td>7-137</td>
</tr>
<tr>
<td>ECFF</td>
<td>COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE (32-8)</td>
<td>CLIB</td>
<td>RRS GE A² B</td>
<td>7-137</td>
</tr>
<tr>
<td>ED04</td>
<td>LOAD LENGTHENED (short to long BFP)</td>
<td>LDEB</td>
<td>RXE A³ A Db Xi</td>
<td>B2</td>
</tr>
<tr>
<td>ED05</td>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>LXDB</td>
<td>RXE A³ A SP Db Xi</td>
<td>B2</td>
</tr>
<tr>
<td>ED06</td>
<td>LOAD LENGTHENED (short to extended BFP)</td>
<td>LXE</td>
<td>RXE A³ A SP Db Xi</td>
<td>B2</td>
</tr>
<tr>
<td>ED07</td>
<td>LOAD LENGTHENED (long to extended BFP)</td>
<td>MXDB</td>
<td>RXE A³ A SP Db Xi</td>
<td>B2</td>
</tr>
<tr>
<td>ED08</td>
<td>COMPARE AND SIGNAL (short BFP)</td>
<td>KEB</td>
<td>RXE C A³ A Db Xi</td>
<td>B2</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 20 of 22)
Figure B-3. Instructions Arranged by Operation Code (Part 21 of 22)
<table>
<thead>
<tr>
<th>Op-code</th>
<th>Name</th>
<th>Mnemonic</th>
<th>Characteristics</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>EDAC</td>
<td>CONVERT TO PACKED (from long DFP)</td>
<td>CPDT</td>
<td>A^9 A SP DF</td>
<td>ST</td>
</tr>
<tr>
<td>EDAD</td>
<td>CONVERT TO PACKED (from extended DFP)</td>
<td>CPXT</td>
<td>A^9 A SP DF</td>
<td>ST</td>
</tr>
<tr>
<td>EDAE</td>
<td>CONVERT FROM PACKED (to long DFP)</td>
<td>CDPT</td>
<td>A^9 A SP Dg</td>
<td>B2</td>
</tr>
<tr>
<td>EDAF</td>
<td>CONVERT FROM PACKED (to extended DFP)</td>
<td>CXPT</td>
<td>A^9 A SP Dg</td>
<td>B2</td>
</tr>
<tr>
<td>EE</td>
<td>PERFORM LOCKED OPERATION</td>
<td>PLO</td>
<td>$ GM</td>
<td>ST</td>
</tr>
<tr>
<td>EF</td>
<td>LOAD MULTIPLE DISJOINT (64+32&amp;32)</td>
<td>LMD</td>
<td></td>
<td>B2</td>
</tr>
<tr>
<td>F0</td>
<td>SHIFT AND ROUND DECIMAL</td>
<td>SRP</td>
<td>Dg DF</td>
<td>ST</td>
</tr>
<tr>
<td>F1</td>
<td>MOVE WITH OFFSET</td>
<td>MVO</td>
<td></td>
<td>B2</td>
</tr>
<tr>
<td>F2</td>
<td>PACK</td>
<td>PACK</td>
<td></td>
<td>B2</td>
</tr>
<tr>
<td>F3</td>
<td>UNPACK</td>
<td>UNPK</td>
<td></td>
<td>ST</td>
</tr>
<tr>
<td>F8</td>
<td>ZERO AND ADD</td>
<td>ZAP</td>
<td>Dg DF</td>
<td>ST</td>
</tr>
<tr>
<td>F9</td>
<td>COMPARE DECIMAL</td>
<td>CP</td>
<td>Dg</td>
<td>B2</td>
</tr>
<tr>
<td>FA</td>
<td>ADD DECIMAL</td>
<td>AP</td>
<td>Dg DF</td>
<td>ST</td>
</tr>
<tr>
<td>FB</td>
<td>SUBTRACT DECIMAL</td>
<td>SP</td>
<td>Dg DF</td>
<td>ST</td>
</tr>
<tr>
<td>FC</td>
<td>MULTIPLY DECIMAL</td>
<td>MP</td>
<td>Dg</td>
<td>ST</td>
</tr>
<tr>
<td>FD</td>
<td>DIVIDE DECIMAL</td>
<td>DP</td>
<td>Dg DK</td>
<td>ST</td>
</tr>
</tbody>
</table>

Figure B-3. Instructions Arranged by Operation Code (Part 22 of 22)
Appendix C. Condition-Code Settings

This appendix lists the condition-code setting for instructions in z/Architecture which set the condition code. In addition to those instructions listed which set the condition code, the condition code may be changed by DIAGNOSE and the target of EXECUTE. The condition code is loaded by LOAD PSW, LOAD PSW EXTENDED, PROGRAM RETURN, RESUME PROGRAM, and SET PROGRAM MASK and by an interruption. The condition code is set to zero by initial CPU reset and is loaded by the successful conclusion of the initial-program-loading sequence.

Some models may offer instructions which set the condition code and do not appear in this document, such as those provided for assists or as part of special or custom features.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Condition Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD (BFP, DFP)</td>
<td>Zero &lt; zero &gt; zero NaN</td>
</tr>
<tr>
<td>ADD (general)</td>
<td>Zero &lt; zero &gt; zero Overflow</td>
</tr>
<tr>
<td>ADD DECIMAL</td>
<td>Zero &lt; zero &gt; zero Overflow</td>
</tr>
<tr>
<td>ADD HALFWORD</td>
<td>Zero &lt; zero &gt; zero Overflow</td>
</tr>
<tr>
<td>ADD HALFWORD IMMEDIATE</td>
<td>Zero &lt; zero &gt; zero Overflow</td>
</tr>
<tr>
<td>ADD HIGH</td>
<td>Zero &lt; zero &gt; zero Overflow</td>
</tr>
<tr>
<td>ADD IMMEDIATE</td>
<td>Zero &lt; zero &gt; zero Overflow</td>
</tr>
<tr>
<td>ADD IMMEDIATE HIGH</td>
<td>Zero &lt; zero &gt; zero Overflow</td>
</tr>
<tr>
<td>ADD LOGICAL</td>
<td>Zero, no carry Not zero, no carry Zero, carry Not zero, carry</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE</td>
<td>Zero, no carry Not zero, no carry Zero, carry Not zero, carry</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE HIGH</td>
<td>Zero, no carry Not zero, no carry Zero, carry Not zero, carry</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE HIGH</td>
<td>Zero&lt; zero &gt; zero —</td>
</tr>
<tr>
<td>ADD LOGICAL IMMEDIATE HIGH</td>
<td>—</td>
</tr>
<tr>
<td>AND</td>
<td>Zero Not zero — —</td>
</tr>
<tr>
<td>AND IMMEDIATE</td>
<td>Zero Not zero — —</td>
</tr>
<tr>
<td>CANCEL SUBCHANNEL</td>
<td>Function initiated — — Not operational</td>
</tr>
<tr>
<td>CHECKSUM</td>
<td>Checksum complete — — CPU-determined completion</td>
</tr>
<tr>
<td>CIPHER MESSAGE</td>
<td>Normal completion Verification mismatch — Partial completion</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH CHAINING</td>
<td>Normal completion Verification mismatch — Partial completion</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH CIPHER FEEDBACK</td>
<td>Normal completion Verification mismatch — Partial completion</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH COUNTER</td>
<td>Normal completion Verification mismatch — Partial completion</td>
</tr>
<tr>
<td>CIPHER MESSAGE WITH OUTPUT FEEDBACK</td>
<td>Normal completion Verification mismatch — Partial completion</td>
</tr>
<tr>
<td>CLEAR SUBCHANNEL</td>
<td>Function initiated — — Not operational</td>
</tr>
<tr>
<td>COMPARE (BFP, DFP)</td>
<td>Equal Low High Unordered</td>
</tr>
<tr>
<td>COMPARE (general, HFP)</td>
<td>Equal Low High —</td>
</tr>
<tr>
<td>COMPARE AND FORM CODEWORD</td>
<td>Equal OCB=0: low OCB=0: high —</td>
</tr>
<tr>
<td>COMPARE AND REPLACEDAT TABLE ENTRY</td>
<td>Equal Not equal — —</td>
</tr>
<tr>
<td>COMPARE AND SIGNAL</td>
<td>Equal Low High Unordered</td>
</tr>
<tr>
<td>COMPARE AND SWAP</td>
<td>Equal Not equal — —</td>
</tr>
<tr>
<td>COMPARE AND SWAP AND PURGE</td>
<td>Equal Not equal — —</td>
</tr>
</tbody>
</table>

Figure C-1. Summary of Condition-Code Settings (Part 1 of 7)
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Condition Code</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARE AND SWAP AND STORE</td>
<td>Equal</td>
<td>Not equal</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE BISCUITED EXPONENT</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td>Unordered</td>
</tr>
<tr>
<td>COMPARE DECIMAL</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE DOUBLE AND SWAP</td>
<td>Equal</td>
<td>Not equal</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HALFWORD</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HALFWORD IMMEDIATE</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HALFWORD RELATIVE LONG</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE HIGH</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE IMMEDIATE</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE IMMEDIATE HIGH</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL CHARACTERS UNDER MASK</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL HIGH</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL IMMEDIATE HIGH</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL LONG</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL LONG EXTENDED</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL LONG UNICODE</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL RELATIVE LONG</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE LOGICAL STRING</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE RELATIVE LONG</td>
<td>Equal</td>
<td>Low</td>
<td>High</td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPARE UNTIL SUBSTRING EQUAL</td>
<td>Equal substrings</td>
<td>Last bytes equal</td>
<td>Last bytes unequal</td>
<td>CPU-determined completion</td>
<td></td>
</tr>
<tr>
<td>COMPRESSION CALL</td>
<td>Op2 processed</td>
<td>Op1 full and op2 not processed</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>COMPUTE INTERMEDIATE MESSAGE DIGEST</td>
<td>Normal completion</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>CPU-determined completion</td>
</tr>
<tr>
<td>COMPUTE LAST MESSAGE DIGEST</td>
<td>Normal completion</td>
<td>Verification mismatch</td>
<td>—</td>
<td>—</td>
<td>Partial completion</td>
</tr>
<tr>
<td>COMPUTE MESSAGE AUTHENTICATION CODE</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>—</td>
<td>Special case</td>
</tr>
<tr>
<td>CONVERT BFP TO HFP</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>—</td>
<td>Special case</td>
</tr>
<tr>
<td>CONVERT TO FIXED</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>—</td>
<td>Special case</td>
</tr>
<tr>
<td>CONVERT TO LOGICAL</td>
<td>Zero</td>
<td>Source is zero</td>
<td>Source is greater than zero</td>
<td>Infinity, QNaN, SNaN, Partial result</td>
<td></td>
</tr>
<tr>
<td>CONVERT TO PACKED</td>
<td>Source is zero</td>
<td>Source is less than zero</td>
<td>Source is greater than zero</td>
<td>Infinity, QNaN, SNaN, Partial result</td>
<td></td>
</tr>
<tr>
<td>CONVERT TO ZONED</td>
<td>Source is zero</td>
<td>Source is less than zero</td>
<td>Source is greater than zero</td>
<td>CPU-determined completion</td>
<td></td>
</tr>
<tr>
<td>CONVERT UTF-16 TO UTF-32</td>
<td>Data processed</td>
<td>Op1 full</td>
<td>Invalid low surrogate</td>
<td>CPU-determined completion</td>
<td></td>
</tr>
<tr>
<td>CONVERT UTF-16 TO UTF-8</td>
<td>Data processed</td>
<td>Op1 full</td>
<td>Invalid low surrogate</td>
<td>CPU-determined completion</td>
<td></td>
</tr>
<tr>
<td>CONVERT UTF-32 TO UTF-16</td>
<td>Data processed</td>
<td>Op1 full</td>
<td>Invalid UTF-32 character</td>
<td>CPU-determined completion</td>
<td></td>
</tr>
<tr>
<td>CONVERT UTF-32 TO UTF-8</td>
<td>Data processed</td>
<td>Op1 full</td>
<td>Invalid UTF-32 character</td>
<td>CPU-determined completion</td>
<td></td>
</tr>
</tbody>
</table>

Figure C-1. Summary of Condition-Code Settings (Part 2 of 7)
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Condition Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>CONVERT UTF-8 TO UTF-16</td>
<td>Data processed Op1 full Invalid UTF-8 character CPU-determined completion</td>
</tr>
<tr>
<td>CONVERT UTF-8 TO UTF-32</td>
<td>Data processed Op1 full Invalid UTF-8 character CPU-determined completion</td>
</tr>
<tr>
<td>DIAGNOSE¹</td>
<td>See note Remnant complete; normal quotient CPU-determined completion</td>
</tr>
<tr>
<td>DIVIDE TO INTEGER</td>
<td>Remainder complete; quotient overflow or NaN CPU-determined completion</td>
</tr>
<tr>
<td>EDIT</td>
<td>Zero &lt; zero &gt; zero —</td>
</tr>
<tr>
<td>EDIT AND MARK</td>
<td>Zero &lt; zero &gt; zero —</td>
</tr>
<tr>
<td>EXCLUSIVE OR</td>
<td>Zero Not zero — —</td>
</tr>
<tr>
<td>EXCLUSIVE OR IMMEDIATE</td>
<td>Zero Not zero — —</td>
</tr>
<tr>
<td>EXTRACT STACKED STATE</td>
<td>Branch state entry Program-call state entry</td>
</tr>
<tr>
<td>FIND LEFTMOST ONE</td>
<td>No one bit found One bit found —</td>
</tr>
<tr>
<td>HALT SUBCHANNEL</td>
<td>Function initiated Status-pending with other than intermediate status —</td>
</tr>
<tr>
<td>INSERT ADDRESS SPACE CONTROL</td>
<td>Primary-space mode Secondary-space mode Access-register mode Home-space mode</td>
</tr>
<tr>
<td>INSERT CHARACTERS UNDER MASK</td>
<td>All zeros First bit one First bit zero —</td>
</tr>
<tr>
<td>LOAD ADDRESS SPACE PARAMETERS</td>
<td>Parameters loaded Primary ASN not available or not authorized —</td>
</tr>
<tr>
<td>LOAD AND TEST (BFP, DFP)</td>
<td>Zero &lt; zero &gt; zero NaN</td>
</tr>
<tr>
<td>LOAD AND TEST (general, HFP)</td>
<td>Zero &lt; zero &gt; zero —</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (BFP)</td>
<td>Zero &lt; zero &gt; zero NaN</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (gen)</td>
<td>Zero &lt; zero &gt; zero —</td>
</tr>
<tr>
<td>LOAD COMPLEMENT (HFP)</td>
<td>Zero &lt; zero &gt; zero —</td>
</tr>
<tr>
<td>LOAD COUNT TO BLOCK BOUNDARY</td>
<td>Operand 1 = 16 — —</td>
</tr>
<tr>
<td>LOAD NEGATIVE (BFP)</td>
<td>Zero &lt; zero &gt; zero —</td>
</tr>
<tr>
<td>LOAD NEGATIVE (gen, HFP)</td>
<td>Zero &lt; zero &gt; zero —</td>
</tr>
<tr>
<td>LOAD PAGE TABLE ENTRY ADDRESS</td>
<td>Translation, STE.P = 0 Translation, STE.P = 1 I bit on in RTE or STE, or enhanced-DAT applies and STE.FC=1 Exception condition exists</td>
</tr>
<tr>
<td>LOAD POSITIVE (BFP)</td>
<td>Zero — &gt; zero NaN</td>
</tr>
<tr>
<td>LOAD POSITIVE (gen)</td>
<td>Zero — &gt; zero — —</td>
</tr>
<tr>
<td>LOAD POSITIVE (HFP)</td>
<td>Zero — &gt; zero — —</td>
</tr>
<tr>
<td>LOAD PSW² / LOAD PSW EXTENDED²</td>
<td>See note Translation available ST entry invalid PT entry invalid —</td>
</tr>
<tr>
<td>LOAD REAL ADDRESS ²</td>
<td>Translation available ST entry invalid PT entry invalid —</td>
</tr>
<tr>
<td>MODIFY SUBCHANNEL</td>
<td>SCHIB information placed in subchannel Status-pending Busy —</td>
</tr>
<tr>
<td>MOVE LONG</td>
<td>Length equal Length low Length high Destructive overlap CPU-determined completion</td>
</tr>
<tr>
<td>MOVE LONG EXTENDED</td>
<td>Length equal Length low Length high CPU-determined completion</td>
</tr>
</tbody>
</table>

*Figure C-1. Summary of Condition-Code Settings (Part 3 of 7)*
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Condition Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>MOVE LONG UNICODE</td>
<td>Length equal</td>
</tr>
<tr>
<td>MOVE PAGE</td>
<td>Data moved</td>
</tr>
<tr>
<td>MOVE STRING</td>
<td>—</td>
</tr>
<tr>
<td>MOVE TO PRIMARY</td>
<td>Length ≤ 256</td>
</tr>
<tr>
<td>MOVE TO SECONDARY</td>
<td>Length ≤ 256</td>
</tr>
<tr>
<td>MOVE WITH KEY</td>
<td>Length ≤ 256</td>
</tr>
<tr>
<td>MOVE WITH OPTIONAL SPECIFICATIONS</td>
<td>Length ≤ 4,096</td>
</tr>
<tr>
<td>OR</td>
<td>Zero</td>
</tr>
<tr>
<td>OR IMMEDIATE</td>
<td>Zero</td>
</tr>
<tr>
<td>PAGE IN</td>
<td>Page-in operation completed</td>
</tr>
<tr>
<td>PAGE OUT</td>
<td>Page-out operation completed</td>
</tr>
<tr>
<td>PERFORM CRYPTOGRAPHIC COMPUTATION</td>
<td>Normal completion</td>
</tr>
<tr>
<td>PERFORM FLOATING-POINT OPERATION (test bit one)</td>
<td>Function code valid</td>
</tr>
<tr>
<td>PERFORM FLOATING-POINT OPERATION (test bit zero)</td>
<td>Normal result</td>
</tr>
<tr>
<td>PERFORM LOCKED OPERATION (test bit one)</td>
<td>Function code valid</td>
</tr>
<tr>
<td>PERFORM LOCKED OPERATION (test bit zero)</td>
<td>Equal</td>
</tr>
<tr>
<td>PERFORM PSEUDORANDOM NUMBER OPERATION</td>
<td>Normal completion</td>
</tr>
<tr>
<td>PERFORM TIMING FACILITY FUNCTION</td>
<td>Function performed</td>
</tr>
<tr>
<td>PERFORM TOPOLOGY FUNCTION (FC 0 or 1)</td>
<td>Change initiated</td>
</tr>
<tr>
<td>PERFORM TOPOLOGY FUNCTION (FC 2)</td>
<td>Report not pending</td>
</tr>
<tr>
<td>POPULATION COUNT</td>
<td>Zero</td>
</tr>
<tr>
<td>PROGRAM RETURN</td>
<td>See note</td>
</tr>
<tr>
<td>RESET CHANNEL PATH</td>
<td>Function initiated</td>
</tr>
<tr>
<td>RESET REFERENCE BIT EXTENDED</td>
<td>R bit zero, C bit zero</td>
</tr>
<tr>
<td>RESUME PROGRAM²</td>
<td>See note</td>
</tr>
<tr>
<td>RESUME SUBCHANNEL</td>
<td>Function initiated</td>
</tr>
<tr>
<td>ROTATE THEN AND SELECTED BITS</td>
<td>Zero</td>
</tr>
<tr>
<td>ROTATE THEN EXCLUSIVE OR SELECTED BITS</td>
<td>Zero</td>
</tr>
<tr>
<td>ROTATE THEN INSERT SELECTED BITS</td>
<td>Zero</td>
</tr>
<tr>
<td>ROTATE THEN OR SELECTED BITS</td>
<td>Zero</td>
</tr>
<tr>
<td>SEARCH STRING</td>
<td>—</td>
</tr>
<tr>
<td>SEARCH STRING UNICODE</td>
<td>—</td>
</tr>
<tr>
<td>SET CLOCK</td>
<td>Set</td>
</tr>
<tr>
<td>SET PROGRAM MASK⁴</td>
<td>See note</td>
</tr>
</tbody>
</table>

Figure C-1. Summary of Condition-Code Settings (Part 4 of 7)
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Condition Code</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
</tr>
</thead>
<tbody>
<tr>
<td>C-5 SET STORAGE KEY EXTENDED</td>
<td>Storage key not set</td>
<td>Entire storage key set</td>
<td>Partial storage key set</td>
<td>Entire storage key set; bits 48-55 of GR R1 unpredictable</td>
<td></td>
</tr>
<tr>
<td>SHIFT AND ROUND DECIMAL</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>Overflow</td>
<td></td>
</tr>
<tr>
<td>SHIFT LEFT (DOUBLE/SINGLE)</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>Overflow</td>
<td></td>
</tr>
<tr>
<td>SHIFT RIGHT (DOUBLE/SINGLE)</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SIGNAL PROCESSOR</td>
<td>Order accepted</td>
<td>Status stored</td>
<td>Busy</td>
<td>Not operational</td>
<td></td>
</tr>
<tr>
<td>START SUBCHANNEL</td>
<td>Function initiated</td>
<td>Status-pending</td>
<td>Busy</td>
<td>Not operational</td>
<td></td>
</tr>
<tr>
<td>STORE CHANNEL REPORT WORD</td>
<td>CRW stored</td>
<td>Zeros stored</td>
<td>—</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>STORE CLOCK</td>
<td>Set</td>
<td>Not set</td>
<td>Error</td>
<td>Stopped or not operational</td>
<td></td>
</tr>
<tr>
<td>STORE CLOCK FAST</td>
<td>Set</td>
<td>Not set</td>
<td>Error</td>
<td>Stopped or not operational</td>
<td></td>
</tr>
<tr>
<td>STORE FACILITY LIST EXTENDED</td>
<td>Complete facility list stored</td>
<td>—</td>
<td>—</td>
<td>Incomplete facility list stored</td>
<td></td>
</tr>
<tr>
<td>STORE SUBCHANNEL</td>
<td>SCHIB stored</td>
<td>—</td>
<td>—</td>
<td>Not operational</td>
<td></td>
</tr>
<tr>
<td>STORE SYSTEM INFORMATION</td>
<td>Information provided</td>
<td>—</td>
<td>—</td>
<td>Information not available</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT (BFP, DFP)</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>NaN</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT (general)</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>Overflow</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT DECIMAL</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>Overflow</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT HALFWORD</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>Overflow</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT HIGH</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>Overflow</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT LOGICAL</td>
<td>Not zero, borrow</td>
<td>Zero, no borrow</td>
<td>Not zero, no borrow</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SUBTRACT LOGICAL HIGH</td>
<td>Not zero, borrow</td>
<td>Zero, no borrow</td>
<td>Not zero, no borrow</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SUBTRACT LOGICAL IMMEDIATE</td>
<td>Not zero, borrow</td>
<td>Zero, no borrow</td>
<td>Not zero, no borrow</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SUBTRACT LOGICAL WITH BORROW</td>
<td>Zero, borrow</td>
<td>Not zero, borrow</td>
<td>Zero, no borrow</td>
<td>Not zero, no borrow</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT NORMALIZED (HFP)</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>SUBTRACT UNNORMALIZED (HFP)</td>
<td>Zero</td>
<td>&lt; zero</td>
<td>&gt; zero</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>TEST ADDRESSING MODE</td>
<td>Twenty-four bit mode</td>
<td>Thirty-one bit mode</td>
<td>—</td>
<td>Sixty-four bit mode</td>
<td></td>
</tr>
<tr>
<td>TEST AND SET</td>
<td>Left bit zero</td>
<td>Left bit one</td>
<td>—</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>TEST BLOCK</td>
<td>Usable</td>
<td>Not usable</td>
<td>—</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>TEST DATA CLASS</td>
<td>Zero (no match)</td>
<td>One (match)</td>
<td>—</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>TEST DATA GROUP</td>
<td>Zero (no match)</td>
<td>One (match)</td>
<td>—</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>TEST DECIMAL</td>
<td>Digits and sign valid</td>
<td>Sign invalid</td>
<td>Digit invalid</td>
<td>Sign and digit invalid</td>
<td></td>
</tr>
<tr>
<td>TEST PENDING INTERRUPTION</td>
<td>Interruption code not stored</td>
<td>Interruption code stored</td>
<td>—</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>TEST PROTECTION</td>
<td>Can fetch, can store</td>
<td>Can fetch, cannot store</td>
<td>Cannot fetch, cannot store</td>
<td>Translation not available</td>
<td></td>
</tr>
<tr>
<td>TEST SUBCHANNEL</td>
<td>IRB stored; subchannel status-pending</td>
<td>IRB stored; subchannel not status-pending</td>
<td>—</td>
<td>Not operational</td>
<td></td>
</tr>
<tr>
<td>TEST UNDER MASK</td>
<td>All zeros</td>
<td>Mixed</td>
<td>—</td>
<td>All ones</td>
<td></td>
</tr>
<tr>
<td>TEST UNDER MASK (HIGH/LOW)</td>
<td>All zeros</td>
<td>Mixed, left bit zero</td>
<td>Mixed, left bit one</td>
<td>All ones</td>
<td></td>
</tr>
</tbody>
</table>

Figure C-1. Summary of Condition-Code Settings (Part 5 of 7)
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Condition Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRANSACTION BEGIN</td>
<td>Initiated successfully</td>
</tr>
<tr>
<td>TRANSACTION END</td>
<td>CPU in transactional-execution mode at start of instruction</td>
</tr>
<tr>
<td>TRANSLATE AND TEST</td>
<td>All zeros Incomplete Complete</td>
</tr>
<tr>
<td>TRANSLATE AND TEST EXTENDED</td>
<td>All zeros Nonzero code selected Complete CPU-determined completion</td>
</tr>
<tr>
<td>TRANSLATE AND TEST REVERSE</td>
<td>All zeros Incomplete Complete</td>
</tr>
<tr>
<td>TRANSLATE AND TEST REVERSE EXTENDED</td>
<td>All zeros Nonzero code selected Complete CPU-determined completion</td>
</tr>
<tr>
<td>TRANSLATE EXTENDED</td>
<td>Data processed Op1 byte equal test byte</td>
</tr>
<tr>
<td>TRANSLATE ONE TO ONE, ONE TO TWO, TWO TO TWO</td>
<td>Character equal test character not found Character equal test character found</td>
</tr>
<tr>
<td>UNPACK ASCII</td>
<td>Sign plus Sign minus</td>
</tr>
<tr>
<td>UNPACK UNICODE</td>
<td>Sign plus Sign minus</td>
</tr>
<tr>
<td>UPDATE TREE</td>
<td>Equal Not equal or no comparison</td>
</tr>
<tr>
<td>VECTOR COMPARE EQUAL</td>
<td>All elements equal Some elements equal</td>
</tr>
<tr>
<td>VECTOR COMPARE HIGH LOGICAL</td>
<td>All elements high Some elements high</td>
</tr>
<tr>
<td>VECTOR COMPARE HIGH</td>
<td>All elements high Some elements high</td>
</tr>
<tr>
<td>VECTOR ELEMENT COMPARE</td>
<td>Equal Low High</td>
</tr>
<tr>
<td>VECTOR ELEMENT COMPARE LOGICAL</td>
<td>Equal Low High</td>
</tr>
<tr>
<td>VECTOR FIND ANY ELEMENT EQUAL</td>
<td>None equal, zero found Equal element found, no zeros if ZS=1</td>
</tr>
<tr>
<td>VECTOR FIND ELEMENT EQUAL</td>
<td>Zero found Equal element found, no zeros</td>
</tr>
<tr>
<td>VECTOR FIND ELEMENT NOT EQUAL</td>
<td>Zero found Not equal element found, less than</td>
</tr>
<tr>
<td>VECTOR FP COMPARE AND SIGNAL SCALAR</td>
<td>Elements equal First element low First element high Elements unordered</td>
</tr>
<tr>
<td>VECTOR FP COMPARE EQUAL</td>
<td>All elements equal Mix of equal and unequal (or unordered) elements</td>
</tr>
<tr>
<td>VECTOR FP COMPARE HIGH OR EQUAL</td>
<td>All elements &gt; Mix of &gt; and &lt;</td>
</tr>
<tr>
<td>VECTOR FP COMPARE HIGH</td>
<td>All elements &gt; Mix of &gt; and &lt;</td>
</tr>
<tr>
<td>VECTOR FP COMPARE SCALAR</td>
<td>Elements equal First element low First element high Elements unordered</td>
</tr>
<tr>
<td>VECTOR FP TEST DATA CLASS IMMEDIATE</td>
<td>Match Selected bit 1 for some (but not all) elements</td>
</tr>
<tr>
<td>VECTOR ISOLATE STRING</td>
<td>Zero element found</td>
</tr>
<tr>
<td>VECTOR PACK LOGICAL SATURATE</td>
<td>No saturation Some saturated</td>
</tr>
<tr>
<td>VECTOR PACK SATURATE</td>
<td>No saturation Some saturated</td>
</tr>
<tr>
<td>VECTOR STRING RANGE COMPARE</td>
<td>Zero found At least one in ranges, zero found</td>
</tr>
<tr>
<td>VECTOR TEST UNDER MASK</td>
<td>All zeros or mask zero Mixed</td>
</tr>
<tr>
<td>ZERO AND ADD</td>
<td>Zero &lt; zero &gt; zero Overflow</td>
</tr>
</tbody>
</table>

Figure C-1. Summary of Condition-Code Settings (Part 6 of 7)
### Explanation and Notes:

1. Code is not set by the instruction.
2. For DIAGNOSE, the resulting condition code is model-dependent.
3. For LOAD REAL ADDRESS, condition code 3 is set if address-space-control element not available, region-table entry outside table or invalid, segment-table entry outside table, or, for LRA in 24- or 31-bit mode when bits 0-32 of entry address not all zeros, segment- or page-table entry invalid.
4. For LOAD PSW, LOAD PSW EXTENDED, and RESUME PROGRAM, the condition code is loaded from the condition-code field of the second operand.
5. For SET PROGRAM MASK, the condition code is loaded from bit positions 2 and 3 of the first operand.
6. For various vector-facility instructions, the condition code is optionally set based on the CS control in the M₃ field of the instruction.

### Figure C-1. Summary of Condition-Code Settings (Part 7 of 7)

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Condition Code</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>3</td>
</tr>
</tbody>
</table>
# Appendix G. Table of Powers of 2

<table>
<thead>
<tr>
<th>Plus</th>
<th>Minus</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0.5</td>
</tr>
<tr>
<td>2</td>
<td>0.25</td>
</tr>
<tr>
<td>4</td>
<td>0.125</td>
</tr>
<tr>
<td>8</td>
<td>0.0625</td>
</tr>
<tr>
<td>16</td>
<td>0.03125</td>
</tr>
<tr>
<td>32</td>
<td>0.01562</td>
</tr>
<tr>
<td>64</td>
<td>0.00781</td>
</tr>
<tr>
<td>128</td>
<td>0.00390</td>
</tr>
<tr>
<td>256</td>
<td>0.00195</td>
</tr>
<tr>
<td>512</td>
<td>0.00097</td>
</tr>
<tr>
<td>1,024</td>
<td>0.00048</td>
</tr>
<tr>
<td>2,048</td>
<td>0.00024</td>
</tr>
<tr>
<td>4,096</td>
<td>0.00012</td>
</tr>
<tr>
<td>8,192</td>
<td>0.00006</td>
</tr>
<tr>
<td>16,384</td>
<td>0.00003</td>
</tr>
<tr>
<td>32,768</td>
<td>0.000015</td>
</tr>
<tr>
<td>65,536</td>
<td>0.0000075</td>
</tr>
<tr>
<td>131,072</td>
<td>0.00000375</td>
</tr>
<tr>
<td>262,144</td>
<td>0.000001875</td>
</tr>
<tr>
<td>524,288</td>
<td>0.0000009375</td>
</tr>
<tr>
<td>1,048,576</td>
<td>0.00000046875</td>
</tr>
<tr>
<td>2,097,152</td>
<td>0.000000234375</td>
</tr>
<tr>
<td>4,194,304</td>
<td>0.0000001171875</td>
</tr>
<tr>
<td>8,388,608</td>
<td>0.00000005859375</td>
</tr>
<tr>
<td>16,777,216</td>
<td>0.000000029296875</td>
</tr>
<tr>
<td>33,554,432</td>
<td>0.0000000146484375</td>
</tr>
<tr>
<td>67,108,864</td>
<td>0.00000000732421875</td>
</tr>
<tr>
<td>134,217,728</td>
<td>0.000000003662109375</td>
</tr>
<tr>
<td>268,435,456</td>
<td>0.0000000018310546875</td>
</tr>
<tr>
<td>536,870,912</td>
<td>0.00000000091552734375</td>
</tr>
<tr>
<td>1,073,741,824</td>
<td>0.0000000004577636875</td>
</tr>
<tr>
<td>2,147,483,648</td>
<td>0.00000000022888184375</td>
</tr>
<tr>
<td>4,294,967,296</td>
<td>0.000000000114440921875</td>
</tr>
<tr>
<td>8,589,934,592</td>
<td>0.0000000000572204609375</td>
</tr>
<tr>
<td>17,179,869,184</td>
<td>0.0000000000286102309375</td>
</tr>
<tr>
<td>34,359,738,368</td>
<td>0.00000000001430511546875</td>
</tr>
<tr>
<td>68,719,476,736</td>
<td>0.000000000007152577734375</td>
</tr>
<tr>
<td>137,438,953,472</td>
<td>0.000000000003576288690625</td>
</tr>
<tr>
<td>274,877,906,944</td>
<td>0.0000000000017881443475</td>
</tr>
<tr>
<td>549,755,813,888</td>
<td>0.0000000000008940721875</td>
</tr>
<tr>
<td>1,099,511,627,776</td>
<td>0.00000000000044703609375</td>
</tr>
<tr>
<td>2,199,023,255,552</td>
<td>0.000000000000223518046875</td>
</tr>
<tr>
<td>4,398,046,511,104</td>
<td>0.0000000000001117590234375</td>
</tr>
<tr>
<td>8,796,093,022,208</td>
<td>0.00000000000005587951171875</td>
</tr>
<tr>
<td>17,592,186,044,416</td>
<td>0.000000000000027939765625</td>
</tr>
<tr>
<td>35,184,372,088,832</td>
<td>0.0000000000000139698828125</td>
</tr>
<tr>
<td>70,368,744,177,664</td>
<td>0.000000000000006984944140625</td>
</tr>
<tr>
<td>140,737,488,355,328</td>
<td>0.0000000000000034924721875</td>
</tr>
<tr>
<td>281,474,976,710,656</td>
<td>0.0000000000000017462365625</td>
</tr>
<tr>
<td>562,949,953,421,312</td>
<td>0.00000000000000087311828125</td>
</tr>
<tr>
<td>1,125,899,906,842,624</td>
<td>0.000000000000000436559109375</td>
</tr>
<tr>
<td>2,251,799,813,685,248</td>
<td>0.00000000000000021827953125</td>
</tr>
<tr>
<td>4,503,599,627,370,496</td>
<td>0.000000000000000109139765625</td>
</tr>
<tr>
<td>9,007,199,254,741,992</td>
<td>0.0000000000000000545698775890625</td>
</tr>
<tr>
<td>18,014,398,509,483,984</td>
<td>0.0000000000000000272849382740625</td>
</tr>
<tr>
<td>36,028,797,018,967,968</td>
<td>0.000000000000000013642469137890625</td>
</tr>
<tr>
<td>72,057,594,037,935,936</td>
<td>0.00000000000000000682123471875</td>
</tr>
<tr>
<td>144,115,188,075,871,872</td>
<td>0.000000000000000003410617890625</td>
</tr>
<tr>
<td>288,230,376,151,743,744</td>
<td>0.00000000000000000170530894765625</td>
</tr>
<tr>
<td>576,460,752,303,487,488</td>
<td>0.0000000000000000008526544765625</td>
</tr>
<tr>
<td>1,152,921,504,606,814,976</td>
<td>0.000000000000000000426327234375</td>
</tr>
<tr>
<td>2,305,843,009,213,639,952</td>
<td>0.000000000000000000213163609375</td>
</tr>
<tr>
<td>4,611,686,018,427,387,904</td>
<td>0.00000000000000000010658125390625</td>
</tr>
<tr>
<td>9,223,372,036,854,775,808</td>
<td>0.000000000000000000053290625390625</td>
</tr>
</tbody>
</table>

Figure G-1. Powers of 2
### Plus

<table>
<thead>
<tr>
<th>Number</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>18,446,744,073,705,551,616</td>
<td>64</td>
</tr>
<tr>
<td>36,893,488,147,419,103,322</td>
<td>65</td>
</tr>
<tr>
<td>73,786,976,294,838,020,646</td>
<td>66</td>
</tr>
<tr>
<td>147,573,952,589,676,676,928</td>
<td>67</td>
</tr>
<tr>
<td>295,147,905,179,352,825,856</td>
<td>68</td>
</tr>
<tr>
<td>590,295,810,358,705,651,712</td>
<td>69</td>
</tr>
<tr>
<td>1,180,591,620,717,411,303,424</td>
<td>70</td>
</tr>
<tr>
<td>2,361,183,241,434,822,606,848</td>
<td>71</td>
</tr>
<tr>
<td>4,722,366,482,869,645,213,696</td>
<td>72</td>
</tr>
<tr>
<td>9,444,732,965,739,290,427,392</td>
<td>73</td>
</tr>
<tr>
<td>18,889,465,931,478,580,854,784</td>
<td>74</td>
</tr>
<tr>
<td>37,778,931,862,957,161,709,568</td>
<td>75</td>
</tr>
<tr>
<td>75,557,863,725,914,323,419,136</td>
<td>76</td>
</tr>
<tr>
<td>151,115,727,451,828,646,838,272</td>
<td>77</td>
</tr>
<tr>
<td>302,231,454,903,657,293,676,544</td>
<td>78</td>
</tr>
<tr>
<td>604,462,909,807,314,587,353,088</td>
<td>79</td>
</tr>
<tr>
<td>1,208,925,819,614,629,174,706,176</td>
<td>80</td>
</tr>
<tr>
<td>2,417,851,639,229,258,349,412,352</td>
<td>81</td>
</tr>
<tr>
<td>4,835,703,278,458,516,698,624,704</td>
<td>82</td>
</tr>
<tr>
<td>9,671,406,556,914,323,419,136</td>
<td>83</td>
</tr>
<tr>
<td>19,342,813,113,834,066,795,298,816</td>
<td>84</td>
</tr>
<tr>
<td>38,685,626,227,668,133,590,597,632</td>
<td>85</td>
</tr>
<tr>
<td>77,371,252,455,356,267,181,195,264</td>
<td>86</td>
</tr>
<tr>
<td>154,742,504,910,672,534,362,390,528</td>
<td>87</td>
</tr>
<tr>
<td>309,485,009,821,345,066,724,781,036</td>
<td>88</td>
</tr>
<tr>
<td>618,970,019,642,690,132,749,511,212</td>
<td>89</td>
</tr>
<tr>
<td>1,237,940,039,285,380,265,429,024</td>
<td>90</td>
</tr>
<tr>
<td>2,475,880,078,570,760,530,858,048</td>
<td>91</td>
</tr>
<tr>
<td>4,951,760,157,141,521,099,198,396</td>
<td>92</td>
</tr>
<tr>
<td>9,903,520,314,283,042,199,993,792</td>
<td>93</td>
</tr>
<tr>
<td>19,807,040,628,566,084,397,597,804</td>
<td>94</td>
</tr>
<tr>
<td>39,614,081,257,132,168,795,195,608</td>
<td>95</td>
</tr>
<tr>
<td>79,228,162,514,522,087,595,395,536</td>
<td>96</td>
</tr>
<tr>
<td>158,456,325,028,125,576,790,791,072</td>
<td>97</td>
</tr>
<tr>
<td>316,912,650,057,354,709,581,582,144</td>
<td>98</td>
</tr>
<tr>
<td>633,825,300,114,708,748,351,602,688</td>
<td>99</td>
</tr>
<tr>
<td>1,267,650,600,228,249,401,946,703,055</td>
<td>100</td>
</tr>
<tr>
<td>2,535,301,200,456,502,809,993,040,010</td>
<td>101</td>
</tr>
<tr>
<td>5,070,602,400,912,917,605,996,812,821</td>
<td>102</td>
</tr>
<tr>
<td>10,141,204,801,825,833,581,973,625,643</td>
<td>103</td>
</tr>
<tr>
<td>20,282,409,603,651,670,423,251,286,016</td>
<td>104</td>
</tr>
<tr>
<td>40,564,819,207,303,340,647,894,502,572</td>
<td>105</td>
</tr>
<tr>
<td>81,129,638,414,606,681,695,789,005</td>
<td>106</td>
</tr>
<tr>
<td>162,259,278,829,213,363,391,578,010</td>
<td>107</td>
</tr>
<tr>
<td>324,518,553,658,426,728,783,156,020</td>
<td>108</td>
</tr>
<tr>
<td>649,037,107,316,853,456,656,301,042</td>
<td>109</td>
</tr>
<tr>
<td>1,298,074,214,633,706,907,132,624</td>
<td>110</td>
</tr>
<tr>
<td>2,596,148,429,267,413,814,265,248</td>
<td>111</td>
</tr>
<tr>
<td>5,192,296,858,534,827,628,530,496</td>
<td>112</td>
</tr>
<tr>
<td>10,384,593,717,069,655,256,060</td>
<td>113</td>
</tr>
<tr>
<td>20,769,187,434,139,310,154,121</td>
<td>114</td>
</tr>
<tr>
<td>41,538,374,868,866,272,682,028</td>
<td>115</td>
</tr>
<tr>
<td>83,076,749,736,557,242,056,487</td>
<td>116</td>
</tr>
<tr>
<td>166,153,499,743,114,484,112,975</td>
<td>117</td>
</tr>
<tr>
<td>332,306,998,946,228,968,225</td>
<td>118</td>
</tr>
<tr>
<td>664,613,997,892,457,936,451,303</td>
<td>119</td>
</tr>
<tr>
<td>1,329,227,995,784,915,872,903</td>
<td>120</td>
</tr>
<tr>
<td>2,658,455,981,156,831,745,807</td>
<td>121</td>
</tr>
<tr>
<td>5,316,911,983,139,663,491</td>
<td>122</td>
</tr>
<tr>
<td>10,633,823,966,276,328</td>
<td>123</td>
</tr>
<tr>
<td>21,267,647,932,558,653,966,460,360</td>
<td>124</td>
</tr>
<tr>
<td>42,535,295,965,117,307,932</td>
<td>125</td>
</tr>
<tr>
<td>85,070,931,730,234,615,865</td>
<td>126</td>
</tr>
<tr>
<td>170,141,183,460,469,231,723</td>
<td>127</td>
</tr>
<tr>
<td>340,282,365,920,338,463,462</td>
<td>128</td>
</tr>
</tbody>
</table>

### Minus

<table>
<thead>
<tr>
<th>Number</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0.00000</td>
<td>0.00000</td>
</tr>
<tr>
<td>0.00005</td>
<td>42101</td>
</tr>
<tr>
<td>0.0824</td>
<td>27522</td>
</tr>
<tr>
<td>1.0003</td>
<td>72640</td>
</tr>
<tr>
<td>0.04349</td>
<td>70855</td>
</tr>
<tr>
<td>0.71289</td>
<td>71289</td>
</tr>
<tr>
<td>0.0025</td>
<td>0.5825</td>
</tr>
</tbody>
</table>

**Figure G-1. Powers of 2**
Appendix H. Hexadecimal Tables

The following tables aid in converting hexadecimal values to decimal values, or the reverse.

**Direct Conversion Table**

This table provides direct conversion of decimal and hexadecimal numbers in these ranges:

<table>
<thead>
<tr>
<th>Hexadecimal</th>
<th>Decimal</th>
</tr>
</thead>
<tbody>
<tr>
<td>000 to FFF</td>
<td>0000 to 4095</td>
</tr>
</tbody>
</table>

To convert numbers outside these ranges, and to convert fractions, use the hexadecimal and decimal conversion tables that follow the direct conversion table in this appendix.
### Conversion Table: Hexadecimal and Decimal Integers

#### POWERS OF 16 TABLE

<table>
<thead>
<tr>
<th>Hex</th>
<th>Decimal</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>16</td>
</tr>
<tr>
<td>2</td>
<td>256</td>
</tr>
<tr>
<td>3</td>
<td>4096</td>
</tr>
<tr>
<td>4</td>
<td>65536</td>
</tr>
<tr>
<td>5</td>
<td>1048576</td>
</tr>
</tbody>
</table>

#### EXAMPLE

**Conversion of Hexadecimal Value D34**

1. D  = 3328
2. 3  = 48
3. 4  = 4
4. Decimal  = 3380

#### EXAMPLE

**Conversion of Decimal Value 3380**

1. D  = -3328
2. 3  = -48
3. 4  = -4
4. Hexadecimal  = D34

#### TO CONVERT HEXADECIMAL TO DECIMAL

1. Locate the column of the decimal numbers corresponding to the leftmost digit or letter of the hexadecimal; select from this column and record the number that corresponds to the position of the hexadecimal digit or letter.
2. Repeat step 1 for the next (second from the left) position.
3. Repeat step 1 for the units (third from the left) position.
4. Add the numbers selected from the table to form the decimal number.

**HEXADECIMAL TO DECIMAL**

Successive cumulative multiplication from left to right, adding units position.

**Example:**

\[D34_{16} = 3380_{10}\]

\[D = 13\]
\[3 = + 3\]
\[4 = + 4\]
\[3380\]

#### TO CONVERT DECIMAL TO HEXADECIMAL

1. (a) Select from the table the highest decimal number that is equal to or less than the number to be converted.
   (b) Record the hexadecimal of the column containing the selected number.
   (c) Subtract the selected decimal from the number to be converted.
2. Using the remainder from step 1(c), repeat all of step 1 to develop the second position of the hexadecimal (and a remainder)
3. Using the remainder from step 2, repeat all of step 1 to develop the units position of the hexadecimal.
4. Combine the terms to form the hexadecimal number.

**DECIMAL TO HEXADECIMAL**

Divide and collect the remainder in reverse order.

**Example:**

\[3380_{10} = X_{16}\]

\[16\mid 3380 \rightarrow 4\]
\[16\mid 211 \rightarrow 3\]
\[16\mid 13 \rightarrow D\]
\[3380_{10} = D34_{16}\]
## Conversion Table: Hexadecimal and Decimal Fractions

<table>
<thead>
<tr>
<th>Bits 0123</th>
<th>4567</th>
<th>Hex Decimal</th>
<th>Hex Decimal</th>
<th>Hex Decimal</th>
<th>Hex Decimal</th>
<th>Hex Decimal</th>
<th>Hex Decimal</th>
</tr>
</thead>
<tbody>
<tr>
<td>.0</td>
<td>.00</td>
<td>.0000</td>
<td>.0000</td>
<td>.0000</td>
<td>.0000</td>
<td>.0000</td>
<td>.0000</td>
</tr>
<tr>
<td>.1</td>
<td>.0625</td>
<td>.0039</td>
<td>.0625</td>
<td>.0002</td>
<td>.4414</td>
<td>.0625</td>
<td>.0001</td>
</tr>
<tr>
<td>.2</td>
<td>.1250</td>
<td>.0078</td>
<td>.1250</td>
<td>.0004</td>
<td>.8828</td>
<td>.1250</td>
<td>.0002</td>
</tr>
<tr>
<td>.3</td>
<td>.1875</td>
<td>.0117</td>
<td>.1875</td>
<td>.0007</td>
<td>.3242</td>
<td>.1875</td>
<td>.0003</td>
</tr>
<tr>
<td>.4</td>
<td>.2500</td>
<td>.0156</td>
<td>.2500</td>
<td>.0009</td>
<td>.7656</td>
<td>.2500</td>
<td>.0004</td>
</tr>
<tr>
<td>.5</td>
<td>.3125</td>
<td>.0195</td>
<td>.3125</td>
<td>.0012</td>
<td>.2070</td>
<td>.3125</td>
<td>.0005</td>
</tr>
<tr>
<td>.6</td>
<td>.3750</td>
<td>.0234</td>
<td>.3750</td>
<td>.0014</td>
<td>.6484</td>
<td>.3750</td>
<td>.0006</td>
</tr>
<tr>
<td>.7</td>
<td>.4375</td>
<td>.0273</td>
<td>.4375</td>
<td>.0017</td>
<td>.0898</td>
<td>.4375</td>
<td>.0007</td>
</tr>
<tr>
<td>.8</td>
<td>.5000</td>
<td>.0312</td>
<td>.5000</td>
<td>.0019</td>
<td>.5312</td>
<td>.5000</td>
<td>.0008</td>
</tr>
<tr>
<td>.9</td>
<td>.5625</td>
<td>.0351</td>
<td>.5625</td>
<td>.0021</td>
<td>.9726</td>
<td>.5625</td>
<td>.0009</td>
</tr>
<tr>
<td>A</td>
<td>.6250</td>
<td>.0390</td>
<td>.6250</td>
<td>.0024</td>
<td>.4140</td>
<td>.6250</td>
<td>.000A</td>
</tr>
<tr>
<td>B</td>
<td>.6875</td>
<td>.0429</td>
<td>.6875</td>
<td>.0026</td>
<td>.8554</td>
<td>.6875</td>
<td>.000B</td>
</tr>
<tr>
<td>C</td>
<td>.7500</td>
<td>.0468</td>
<td>.7500</td>
<td>.0029</td>
<td>.2968</td>
<td>.7500</td>
<td>.000C</td>
</tr>
<tr>
<td>D</td>
<td>.8125</td>
<td>.0507</td>
<td>.8125</td>
<td>.0031</td>
<td>.7382</td>
<td>.8125</td>
<td>.000D</td>
</tr>
<tr>
<td>E</td>
<td>.8750</td>
<td>.0546</td>
<td>.8750</td>
<td>.0034</td>
<td>.1796</td>
<td>.8750</td>
<td>.000E</td>
</tr>
<tr>
<td>F</td>
<td>.9375</td>
<td>.0585</td>
<td>.9375</td>
<td>.0036</td>
<td>.6210</td>
<td>.9375</td>
<td>.000F</td>
</tr>
</tbody>
</table>

### TO CONVERT .ABC HEXADECIMAL TO DECIMAL

1. Find .A in position 1 = .6250
2. Find .0B in position 2 = .0429 6825
3. Find .00C in position 3 = .0029 2968 7500
4. .ABC is equal to .6708 9843 7500

### TO CONVERT .13 DECIMAL TO HEXADECIMAL

1. Find .1250 next lowest to .1300 subtract = .1250 = .2 Hex
2. Find .0039 0625 next lowest to .0050 0000 subtract = .0039 0625 = .01
3. Find .0009 7656 2500 subtract = .0009 7656 2500 = .004
4. Find .0001 0681 5234 375 subtract = .0001 0681 523 4375 = .0007
5. .13 Decimal is approximately equal to .2147 Hex

---

To convert fractions beyond the capacity of the table, use techniques below:

### HEXADECIMAL TO FRACTION DECIMAL

Convert the hexadecimal fraction to its decimal equivalent using the same technique as for integer numbers. Divide the results by 16^n (n is the number of fraction positions).

**Example:**

\[
.8A7_{16} = \frac{.540771}{16^3} = 0.00000002215_{10}
\]

### DECIMAL FRACTION TO HEXADECIMAL

Collect integer parts of product in the order of calculation.

**Example:**

\[
.5408_{10} = .8A7_{16}
\]
**Hexadecimal Addition and Subtraction Table**

Example: $6 + 2 = 8$, $8 - 2 = 6$, and $8 - 6 = 2$

<table>
<thead>
<tr>
<th></th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>A</th>
<th>B</th>
<th>C</th>
<th>D</th>
<th>E</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>02</td>
<td>03</td>
<td>04</td>
<td>05</td>
<td>06</td>
<td>07</td>
<td>08</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
</tr>
<tr>
<td>2</td>
<td>03</td>
<td>04</td>
<td>05</td>
<td>06</td>
<td>07</td>
<td>08</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
</tr>
<tr>
<td>3</td>
<td>04</td>
<td>05</td>
<td>06</td>
<td>07</td>
<td>08</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
</tr>
<tr>
<td>4</td>
<td>05</td>
<td>06</td>
<td>07</td>
<td>08</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
</tr>
<tr>
<td>5</td>
<td>06</td>
<td>07</td>
<td>08</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
</tr>
<tr>
<td>6</td>
<td>07</td>
<td>08</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
</tr>
<tr>
<td>7</td>
<td>08</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
</tr>
<tr>
<td>8</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
</tr>
<tr>
<td>9</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
</tr>
<tr>
<td>A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
</tr>
<tr>
<td>B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
<td>19</td>
</tr>
<tr>
<td>C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
<td>19</td>
<td>1A</td>
</tr>
<tr>
<td>D</td>
<td>0E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
<td>19</td>
<td>1A</td>
<td>1B</td>
</tr>
<tr>
<td>E</td>
<td>0F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
<td>19</td>
<td>1A</td>
<td>1B</td>
<td>1C</td>
</tr>
<tr>
<td>F</td>
<td>10</td>
<td>11</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
<td>19</td>
<td>1A</td>
<td>1B</td>
<td>1C</td>
<td>1D</td>
</tr>
</tbody>
</table>

**Hexadecimal Multiplication Table**

Example: $2 \times 4 = 08$, $F \times 2 = 1E$

<table>
<thead>
<tr>
<th></th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>A</th>
<th>B</th>
<th>C</th>
<th>D</th>
<th>E</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>01</td>
<td>02</td>
<td>03</td>
<td>04</td>
<td>05</td>
<td>06</td>
<td>07</td>
<td>08</td>
<td>09</td>
<td>0A</td>
<td>0B</td>
<td>0C</td>
<td>0D</td>
<td>0E</td>
<td>0F</td>
</tr>
<tr>
<td>2</td>
<td>02</td>
<td>04</td>
<td>06</td>
<td>08</td>
<td>0A</td>
<td>0C</td>
<td>0E</td>
<td>10</td>
<td>12</td>
<td>14</td>
<td>16</td>
<td>18</td>
<td>1A</td>
<td>1C</td>
<td>1E</td>
</tr>
<tr>
<td>3</td>
<td>03</td>
<td>06</td>
<td>09</td>
<td>0C</td>
<td>0F</td>
<td>12</td>
<td>15</td>
<td>18</td>
<td>1B</td>
<td>1E</td>
<td>21</td>
<td>24</td>
<td>27</td>
<td>2A</td>
<td>2D</td>
</tr>
<tr>
<td>4</td>
<td>04</td>
<td>08</td>
<td>0C</td>
<td>10</td>
<td>14</td>
<td>18</td>
<td>1C</td>
<td>20</td>
<td>24</td>
<td>28</td>
<td>2C</td>
<td>30</td>
<td>34</td>
<td>38</td>
<td>3C</td>
</tr>
<tr>
<td>5</td>
<td>05</td>
<td>0A</td>
<td>0F</td>
<td>14</td>
<td>19</td>
<td>1E</td>
<td>23</td>
<td>28</td>
<td>2D</td>
<td>32</td>
<td>37</td>
<td>3C</td>
<td>41</td>
<td>46</td>
<td>4B</td>
</tr>
<tr>
<td>6</td>
<td>06</td>
<td>0C</td>
<td>12</td>
<td>18</td>
<td>1E</td>
<td>24</td>
<td>2A</td>
<td>30</td>
<td>36</td>
<td>3C</td>
<td>42</td>
<td>48</td>
<td>4E</td>
<td>54</td>
<td>5A</td>
</tr>
<tr>
<td>7</td>
<td>07</td>
<td>0E</td>
<td>15</td>
<td>1C</td>
<td>23</td>
<td>2A</td>
<td>31</td>
<td>38</td>
<td>3F</td>
<td>46</td>
<td>4D</td>
<td>54</td>
<td>5B</td>
<td>62</td>
<td>69</td>
</tr>
<tr>
<td>8</td>
<td>08</td>
<td>10</td>
<td>18</td>
<td>20</td>
<td>2B</td>
<td>30</td>
<td>38</td>
<td>40</td>
<td>48</td>
<td>50</td>
<td>58</td>
<td>60</td>
<td>68</td>
<td>70</td>
<td>78</td>
</tr>
<tr>
<td>9</td>
<td>09</td>
<td>12</td>
<td>1B</td>
<td>24</td>
<td>2D</td>
<td>36</td>
<td>3F</td>
<td>48</td>
<td>51</td>
<td>5A</td>
<td>63</td>
<td>6C</td>
<td>75</td>
<td>7E</td>
<td>87</td>
</tr>
<tr>
<td>A</td>
<td>0A</td>
<td>14</td>
<td>1E</td>
<td>28</td>
<td>32</td>
<td>3C</td>
<td>46</td>
<td>50</td>
<td>51</td>
<td>5A</td>
<td>64</td>
<td>6E</td>
<td>78</td>
<td>82</td>
<td>8C</td>
</tr>
<tr>
<td>B</td>
<td>0B</td>
<td>16</td>
<td>21</td>
<td>2C</td>
<td>37</td>
<td>42</td>
<td>4D</td>
<td>58</td>
<td>63</td>
<td>6E</td>
<td>79</td>
<td>84</td>
<td>8F</td>
<td>99</td>
<td>A5</td>
</tr>
<tr>
<td>C</td>
<td>0C</td>
<td>18</td>
<td>24</td>
<td>30</td>
<td>3C</td>
<td>48</td>
<td>54</td>
<td>60</td>
<td>6C</td>
<td>78</td>
<td>84</td>
<td>90</td>
<td>9C</td>
<td>A8</td>
<td>B4</td>
</tr>
<tr>
<td>D</td>
<td>0D</td>
<td>1A</td>
<td>27</td>
<td>34</td>
<td>41</td>
<td>4E</td>
<td>5B</td>
<td>68</td>
<td>75</td>
<td>82</td>
<td>8F</td>
<td>9C</td>
<td>A9</td>
<td>B6</td>
<td>C3</td>
</tr>
<tr>
<td>E</td>
<td>0E</td>
<td>1C</td>
<td>2A</td>
<td>38</td>
<td>46</td>
<td>54</td>
<td>62</td>
<td>70</td>
<td>7E</td>
<td>8C</td>
<td>9A</td>
<td>A8</td>
<td>B6</td>
<td>C4</td>
<td>D2</td>
</tr>
<tr>
<td>F</td>
<td>0F</td>
<td>1E</td>
<td>2D</td>
<td>3C</td>
<td>4B</td>
<td>5A</td>
<td>69</td>
<td>78</td>
<td>87</td>
<td>96</td>
<td>A5</td>
<td>B4</td>
<td>C3</td>
<td>D2</td>
<td>E1</td>
</tr>
</tbody>
</table>
### Appendix I. EBCDIC and ISO-8 Codes

<table>
<thead>
<tr>
<th>Dec</th>
<th>Hex</th>
<th>EBCDIC-037</th>
<th>ISO-8</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>00</td>
<td>NUL</td>
<td>NUL</td>
</tr>
<tr>
<td>1</td>
<td>01</td>
<td>SOH</td>
<td>SOH</td>
</tr>
<tr>
<td>2</td>
<td>02</td>
<td>STX</td>
<td>STX</td>
</tr>
<tr>
<td>3</td>
<td>03</td>
<td>ETX</td>
<td>ETX</td>
</tr>
<tr>
<td>4</td>
<td>04</td>
<td>SEL</td>
<td>EOF</td>
</tr>
<tr>
<td>5</td>
<td>05</td>
<td>HT</td>
<td>ENQ</td>
</tr>
<tr>
<td>6</td>
<td>06</td>
<td>RNL</td>
<td>ACK</td>
</tr>
<tr>
<td>7</td>
<td>07</td>
<td>DEL</td>
<td>BEL</td>
</tr>
<tr>
<td>8</td>
<td>08</td>
<td>GE</td>
<td>BS</td>
</tr>
<tr>
<td>9</td>
<td>09</td>
<td>SPS</td>
<td>HT</td>
</tr>
<tr>
<td>10</td>
<td>0A</td>
<td>RPT</td>
<td>LF</td>
</tr>
<tr>
<td>11</td>
<td>0B</td>
<td>VT</td>
<td>VT</td>
</tr>
<tr>
<td>12</td>
<td>0C</td>
<td>FF</td>
<td>FF</td>
</tr>
<tr>
<td>13</td>
<td>0D</td>
<td>CR</td>
<td>CR</td>
</tr>
<tr>
<td>14</td>
<td>0E</td>
<td>SO</td>
<td>SO</td>
</tr>
<tr>
<td>15</td>
<td>0F</td>
<td>SI</td>
<td>SI</td>
</tr>
<tr>
<td>16</td>
<td>10</td>
<td>DLE</td>
<td>DLE</td>
</tr>
<tr>
<td>17</td>
<td>11</td>
<td>DC1</td>
<td>DC1</td>
</tr>
<tr>
<td>18</td>
<td>12</td>
<td>DC2</td>
<td>DC2</td>
</tr>
<tr>
<td>19</td>
<td>13</td>
<td>DC3</td>
<td>DC3</td>
</tr>
<tr>
<td>20</td>
<td>14</td>
<td>RES/ERP</td>
<td>RES/ERP</td>
</tr>
<tr>
<td>21</td>
<td>15</td>
<td>NAK</td>
<td>NAK</td>
</tr>
<tr>
<td>22</td>
<td>16</td>
<td>BS</td>
<td>BS</td>
</tr>
<tr>
<td>23</td>
<td>17</td>
<td>POC/ETB</td>
<td>POC/ETB</td>
</tr>
<tr>
<td>24</td>
<td>18</td>
<td>CAN</td>
<td>CAN</td>
</tr>
<tr>
<td>25</td>
<td>19</td>
<td>EM</td>
<td>EM</td>
</tr>
<tr>
<td>26</td>
<td>1A</td>
<td>UBS</td>
<td>UBS</td>
</tr>
<tr>
<td>27</td>
<td>1B</td>
<td>CUI/ESC</td>
<td>CUI/ESC</td>
</tr>
<tr>
<td>28</td>
<td>1C</td>
<td>IFS/IFS</td>
<td>IFS/IFS</td>
</tr>
<tr>
<td>29</td>
<td>1D</td>
<td>IGS/IGS</td>
<td>IGS/IGS</td>
</tr>
<tr>
<td>30</td>
<td>1E</td>
<td>IRS/IRS</td>
<td>IRS/IRS</td>
</tr>
<tr>
<td>31</td>
<td>1F</td>
<td>ITB/IBUS</td>
<td>ITB/IBUS</td>
</tr>
<tr>
<td>32</td>
<td>20</td>
<td>DS</td>
<td>SP</td>
</tr>
<tr>
<td>33</td>
<td>21</td>
<td>SOS</td>
<td>!</td>
</tr>
<tr>
<td>34</td>
<td>22</td>
<td>FS</td>
<td>‘</td>
</tr>
<tr>
<td>35</td>
<td>23</td>
<td>WUS</td>
<td>#</td>
</tr>
<tr>
<td>36</td>
<td>24</td>
<td>BYP/INP</td>
<td>$</td>
</tr>
<tr>
<td>37</td>
<td>25</td>
<td>LF</td>
<td>%</td>
</tr>
<tr>
<td>38</td>
<td>26</td>
<td>ETB</td>
<td>&amp;</td>
</tr>
<tr>
<td>39</td>
<td>27</td>
<td>ESC</td>
<td>*</td>
</tr>
<tr>
<td>40</td>
<td>28</td>
<td>SC4</td>
<td>(</td>
</tr>
<tr>
<td>41</td>
<td>29</td>
<td>SFE</td>
<td>)</td>
</tr>
<tr>
<td>42</td>
<td>2A</td>
<td>SM/SW</td>
<td>‘</td>
</tr>
<tr>
<td>43</td>
<td>2B</td>
<td>CSP</td>
<td>+</td>
</tr>
<tr>
<td>44</td>
<td>2C</td>
<td>MFA</td>
<td>.</td>
</tr>
<tr>
<td>45</td>
<td>2D</td>
<td>ENQ</td>
<td>.</td>
</tr>
<tr>
<td>46</td>
<td>2E</td>
<td>ACK</td>
<td>;</td>
</tr>
<tr>
<td>47</td>
<td>2F</td>
<td>BEL</td>
<td>/</td>
</tr>
<tr>
<td>48</td>
<td>30</td>
<td>SBS</td>
<td>8</td>
</tr>
<tr>
<td>49</td>
<td>31</td>
<td>IT</td>
<td>9</td>
</tr>
<tr>
<td>50</td>
<td>32</td>
<td>SYN</td>
<td>2</td>
</tr>
<tr>
<td>51</td>
<td>33</td>
<td>IR</td>
<td>3</td>
</tr>
<tr>
<td>52</td>
<td>34</td>
<td>FP</td>
<td>4</td>
</tr>
<tr>
<td>53</td>
<td>35</td>
<td>TRN</td>
<td>5</td>
</tr>
<tr>
<td>54</td>
<td>36</td>
<td>NBS</td>
<td>6</td>
</tr>
<tr>
<td>55</td>
<td>37</td>
<td>EOT</td>
<td>7</td>
</tr>
<tr>
<td>56</td>
<td>38</td>
<td>SBS</td>
<td>8</td>
</tr>
<tr>
<td>57</td>
<td>39</td>
<td>IT</td>
<td>9</td>
</tr>
<tr>
<td>58</td>
<td>3A</td>
<td>RFF</td>
<td>:</td>
</tr>
<tr>
<td>59</td>
<td>3B</td>
<td>CUI/ESC</td>
<td>.</td>
</tr>
<tr>
<td>60</td>
<td>3C</td>
<td>DC4</td>
<td>&lt;</td>
</tr>
<tr>
<td>61</td>
<td>3D</td>
<td>NAK</td>
<td>=</td>
</tr>
<tr>
<td>62</td>
<td>3E</td>
<td>SUB</td>
<td>?</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Dec</th>
<th>Hex</th>
<th>EBCDIC-037</th>
<th>ISO-8</th>
</tr>
</thead>
<tbody>
<tr>
<td>64</td>
<td>40</td>
<td>SP</td>
<td>@</td>
</tr>
<tr>
<td>65</td>
<td>41</td>
<td>RSP</td>
<td>A</td>
</tr>
<tr>
<td>66</td>
<td>42</td>
<td>@</td>
<td>B</td>
</tr>
<tr>
<td>67</td>
<td>43</td>
<td>Ï</td>
<td>C</td>
</tr>
<tr>
<td>68</td>
<td>44</td>
<td>a</td>
<td>D</td>
</tr>
<tr>
<td>69</td>
<td>45</td>
<td>e</td>
<td>E</td>
</tr>
<tr>
<td>70</td>
<td>46</td>
<td>f</td>
<td>F</td>
</tr>
<tr>
<td>71</td>
<td>47</td>
<td>g</td>
<td>G</td>
</tr>
<tr>
<td>72</td>
<td>48</td>
<td>c</td>
<td>H</td>
</tr>
<tr>
<td>73</td>
<td>49</td>
<td>i</td>
<td>I</td>
</tr>
<tr>
<td>74</td>
<td>4A</td>
<td>e</td>
<td>J</td>
</tr>
<tr>
<td>75</td>
<td>4B</td>
<td>k</td>
<td>K</td>
</tr>
<tr>
<td>76</td>
<td>4C</td>
<td>&lt;</td>
<td>L</td>
</tr>
<tr>
<td>77</td>
<td>4D</td>
<td>(</td>
<td>M</td>
</tr>
<tr>
<td>78</td>
<td>4E</td>
<td>+</td>
<td>N</td>
</tr>
<tr>
<td>79</td>
<td>4F</td>
<td>&gt;</td>
<td>O</td>
</tr>
<tr>
<td>80</td>
<td>50</td>
<td>&amp;</td>
<td>P</td>
</tr>
<tr>
<td>81</td>
<td>51</td>
<td>’</td>
<td>Q</td>
</tr>
<tr>
<td>82</td>
<td>52</td>
<td>$</td>
<td>R</td>
</tr>
<tr>
<td>83</td>
<td>53</td>
<td>@</td>
<td>S</td>
</tr>
<tr>
<td>84</td>
<td>54</td>
<td>p</td>
<td>T</td>
</tr>
<tr>
<td>85</td>
<td>55</td>
<td>n</td>
<td>U</td>
</tr>
<tr>
<td>86</td>
<td>56</td>
<td>v</td>
<td>V</td>
</tr>
<tr>
<td>87</td>
<td>57</td>
<td>w</td>
<td>W</td>
</tr>
<tr>
<td>88</td>
<td>58</td>
<td>o</td>
<td>X</td>
</tr>
<tr>
<td>89</td>
<td>59</td>
<td>r</td>
<td>Y</td>
</tr>
<tr>
<td>90</td>
<td>5A</td>
<td>s</td>
<td>Z</td>
</tr>
<tr>
<td>91</td>
<td>5B</td>
<td>t</td>
<td>¹</td>
</tr>
<tr>
<td>92</td>
<td>5C</td>
<td>^</td>
<td>¥</td>
</tr>
<tr>
<td>93</td>
<td>5D</td>
<td>_</td>
<td>®</td>
</tr>
<tr>
<td>94</td>
<td>5E</td>
<td>;</td>
<td>¯</td>
</tr>
<tr>
<td>95</td>
<td>5F</td>
<td>:</td>
<td>_</td>
</tr>
<tr>
<td>96</td>
<td>60</td>
<td>’</td>
<td>{</td>
</tr>
<tr>
<td>97</td>
<td>61</td>
<td>[</td>
<td>}</td>
</tr>
<tr>
<td>98</td>
<td>62</td>
<td>b</td>
<td>^</td>
</tr>
<tr>
<td>99</td>
<td>63</td>
<td>c</td>
<td>_</td>
</tr>
<tr>
<td>100</td>
<td>64</td>
<td>d</td>
<td>}</td>
</tr>
<tr>
<td>101</td>
<td>65</td>
<td>e</td>
<td>–</td>
</tr>
<tr>
<td>102</td>
<td>66</td>
<td>f</td>
<td>&gt;</td>
</tr>
<tr>
<td>103</td>
<td>67</td>
<td>g</td>
<td>&lt;</td>
</tr>
<tr>
<td>104</td>
<td>68</td>
<td>h</td>
<td>`</td>
</tr>
<tr>
<td>105</td>
<td>69</td>
<td>i</td>
<td>I</td>
</tr>
<tr>
<td>106</td>
<td>6A</td>
<td>j</td>
<td>J</td>
</tr>
<tr>
<td>107</td>
<td>6B</td>
<td>k</td>
<td>K</td>
</tr>
<tr>
<td>108</td>
<td>6C</td>
<td>l</td>
<td>L</td>
</tr>
<tr>
<td>109</td>
<td>6D</td>
<td>m</td>
<td>M</td>
</tr>
<tr>
<td>110</td>
<td>6E</td>
<td>n</td>
<td>N</td>
</tr>
<tr>
<td>111</td>
<td>6F</td>
<td>o</td>
<td>O</td>
</tr>
<tr>
<td>112</td>
<td>70</td>
<td>p</td>
<td>P</td>
</tr>
<tr>
<td>113</td>
<td>71</td>
<td>q</td>
<td>Q</td>
</tr>
<tr>
<td>114</td>
<td>72</td>
<td>r</td>
<td>R</td>
</tr>
<tr>
<td>115</td>
<td>73</td>
<td>s</td>
<td>S</td>
</tr>
<tr>
<td>116</td>
<td>74</td>
<td>t</td>
<td>T</td>
</tr>
<tr>
<td>117</td>
<td>75</td>
<td>u</td>
<td>U</td>
</tr>
<tr>
<td>118</td>
<td>76</td>
<td>v</td>
<td>V</td>
</tr>
<tr>
<td>119</td>
<td>77</td>
<td>w</td>
<td>W</td>
</tr>
<tr>
<td>120</td>
<td>78</td>
<td>x</td>
<td>X</td>
</tr>
<tr>
<td>121</td>
<td>79</td>
<td>y</td>
<td>Y</td>
</tr>
<tr>
<td>122</td>
<td>7A</td>
<td>z</td>
<td>Z</td>
</tr>
<tr>
<td>123</td>
<td>7B</td>
<td>A</td>
<td>A</td>
</tr>
<tr>
<td>124</td>
<td>7C</td>
<td>B</td>
<td>B</td>
</tr>
<tr>
<td>125</td>
<td>7D</td>
<td>C</td>
<td>C</td>
</tr>
<tr>
<td>126</td>
<td>7E</td>
<td>D</td>
<td>D</td>
</tr>
<tr>
<td>127</td>
<td>7F</td>
<td>E</td>
<td>E</td>
</tr>
</tbody>
</table>

© Copyright IBM Corp. 1990-2015
## Control Character Representations

<table>
<thead>
<tr>
<th>Code</th>
<th>Character</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACK</td>
<td>Acknowledge</td>
</tr>
<tr>
<td>BEL</td>
<td>Bell</td>
</tr>
<tr>
<td>BS</td>
<td>Backspace</td>
</tr>
<tr>
<td>BYP</td>
<td>Bypass</td>
</tr>
<tr>
<td>CAN</td>
<td>Cancel</td>
</tr>
<tr>
<td>CR</td>
<td>Carriage Return</td>
</tr>
<tr>
<td>CXP</td>
<td>Control Sequence Prefix</td>
</tr>
<tr>
<td>CU1</td>
<td>Customer Use 1</td>
</tr>
<tr>
<td>CU3</td>
<td>Customer Use 3</td>
</tr>
<tr>
<td>DC1</td>
<td>Device Control 1</td>
</tr>
<tr>
<td>DC2</td>
<td>Device Control 2</td>
</tr>
<tr>
<td>DC3</td>
<td>Device Control 3</td>
</tr>
<tr>
<td>DC4</td>
<td>Device Control 4</td>
</tr>
<tr>
<td>DEL</td>
<td>Delete</td>
</tr>
<tr>
<td>DLE</td>
<td>Data Link Escape</td>
</tr>
<tr>
<td>DS</td>
<td>Digit Select</td>
</tr>
<tr>
<td>EM</td>
<td>End of Medium</td>
</tr>
<tr>
<td>ENP</td>
<td>Enable Presentation</td>
</tr>
<tr>
<td>ENQ</td>
<td>Enquiry</td>
</tr>
<tr>
<td>EO</td>
<td>Eight Ones</td>
</tr>
<tr>
<td>EOT</td>
<td>End of Transmission</td>
</tr>
<tr>
<td>ESC</td>
<td>Escape</td>
</tr>
<tr>
<td>ETB</td>
<td>End of Transmission Block</td>
</tr>
<tr>
<td>ETX</td>
<td>End of Text</td>
</tr>
<tr>
<td>FF</td>
<td>Form Feed</td>
</tr>
<tr>
<td>FS</td>
<td>Field Separator</td>
</tr>
<tr>
<td>GE</td>
<td>Graphic Escape</td>
</tr>
<tr>
<td>HT</td>
<td>Horizontal Tab</td>
</tr>
<tr>
<td>IFS</td>
<td>Interchange File Separator</td>
</tr>
<tr>
<td>IGS</td>
<td>Interchange Group Separator</td>
</tr>
<tr>
<td>INP</td>
<td>Inhibit Presentation</td>
</tr>
<tr>
<td>IR</td>
<td>Index Return</td>
</tr>
<tr>
<td>IRS</td>
<td>Interchange Record Separator</td>
</tr>
<tr>
<td>IT</td>
<td>Indent Tab</td>
</tr>
<tr>
<td>ITB</td>
<td>Intermediate Transmission Block</td>
</tr>
<tr>
<td>IUS</td>
<td>International Unit Separator</td>
</tr>
<tr>
<td>LF</td>
<td>Line Feed</td>
</tr>
<tr>
<td>MFA</td>
<td>Modify Field Attribute</td>
</tr>
<tr>
<td>NAK</td>
<td>Negative Acknowledge</td>
</tr>
<tr>
<td>NBS</td>
<td>Numeric Backspace</td>
</tr>
<tr>
<td>NL</td>
<td>New Line</td>
</tr>
<tr>
<td>NUL</td>
<td>Null</td>
</tr>
<tr>
<td>POC</td>
<td>Program-Operator Communication</td>
</tr>
<tr>
<td>pp</td>
<td>Presentation Position</td>
</tr>
<tr>
<td>RES</td>
<td>Restore</td>
</tr>
<tr>
<td>RFF</td>
<td>Required Form Feed</td>
</tr>
<tr>
<td>RML</td>
<td>Required New Line</td>
</tr>
<tr>
<td>RPN</td>
<td>Repeat</td>
</tr>
<tr>
<td>SA</td>
<td>Set Attribute</td>
</tr>
<tr>
<td>SBS</td>
<td>Subscript</td>
</tr>
<tr>
<td>SEL</td>
<td>Select</td>
</tr>
<tr>
<td>SFE</td>
<td>Start Field Extended</td>
</tr>
<tr>
<td>SI</td>
<td>Shift In</td>
</tr>
<tr>
<td>SM</td>
<td>Set Mode</td>
</tr>
<tr>
<td>SO</td>
<td>Shift Out</td>
</tr>
<tr>
<td>SQH</td>
<td>Start of Heading</td>
</tr>
<tr>
<td>SOS</td>
<td>Start of Significance</td>
</tr>
<tr>
<td>SPS</td>
<td>Superscript</td>
</tr>
<tr>
<td>STX</td>
<td>Start of Text</td>
</tr>
<tr>
<td>SUB</td>
<td>Substitute</td>
</tr>
<tr>
<td>SW</td>
<td>Switch</td>
</tr>
<tr>
<td>SYN</td>
<td>Synchronous Idle</td>
</tr>
<tr>
<td>TRN</td>
<td>Transparent</td>
</tr>
<tr>
<td>UBS</td>
<td>Unit Backspace</td>
</tr>
<tr>
<td>VT</td>
<td>Vertical Tab</td>
</tr>
<tr>
<td>WUS</td>
<td>Word Underscore</td>
</tr>
</tbody>
</table>

## Formatting Character Representations

<table>
<thead>
<tr>
<th>Code</th>
<th>Character</th>
</tr>
</thead>
<tbody>
<tr>
<td>NSP</td>
<td>Numeric Space</td>
</tr>
<tr>
<td>RSP</td>
<td>Required Space</td>
</tr>
<tr>
<td>SP</td>
<td>Space</td>
</tr>
<tr>
<td>SHY</td>
<td>Syllable Hyphen</td>
</tr>
</tbody>
</table>

## Additional ISO-8 Control Character Representations

<table>
<thead>
<tr>
<th>Code</th>
<th>Character</th>
</tr>
</thead>
<tbody>
<tr>
<td>APC</td>
<td>Application Program Command</td>
</tr>
<tr>
<td>BPH</td>
<td>Break Permitted Here</td>
</tr>
<tr>
<td>CCH</td>
<td>Cancel Character</td>
</tr>
<tr>
<td>CSI</td>
<td>Control Sequence Introducer</td>
</tr>
<tr>
<td>DCS</td>
<td>Device Control String</td>
</tr>
<tr>
<td>EPA</td>
<td>End of Guarded Area</td>
</tr>
<tr>
<td>ESA</td>
<td>End of Selected Area</td>
</tr>
<tr>
<td>HTJ</td>
<td>Character Tabulation with Justification</td>
</tr>
<tr>
<td>HTS</td>
<td>Character Tabulation Set</td>
</tr>
<tr>
<td>IFS</td>
<td>Information Separator Four</td>
</tr>
<tr>
<td>IGS</td>
<td>Information Separator Three</td>
</tr>
<tr>
<td>IND</td>
<td>Index</td>
</tr>
<tr>
<td>IRS</td>
<td>Information Separator Two</td>
</tr>
<tr>
<td>MW</td>
<td>Message Waiting</td>
</tr>
<tr>
<td>NBH</td>
<td>No Break Here</td>
</tr>
<tr>
<td>NEL</td>
<td>Next Line</td>
</tr>
<tr>
<td>OSC</td>
<td>Operating System Command</td>
</tr>
<tr>
<td>PLD</td>
<td>Partial Line Down</td>
</tr>
<tr>
<td>PLU</td>
<td>Partial Line Up</td>
</tr>
<tr>
<td>PM</td>
<td>Privacy Message</td>
</tr>
<tr>
<td>PU1</td>
<td>Private Use One</td>
</tr>
<tr>
<td>PU2</td>
<td>Private Use Two</td>
</tr>
<tr>
<td>RI</td>
<td>Reverse Linefeed (or index)</td>
</tr>
<tr>
<td>SCI</td>
<td>Single Character Introducer</td>
</tr>
<tr>
<td>SOS</td>
<td>Start of String</td>
</tr>
</tbody>
</table>

**Note:** The ISO-8 controls are from ISO 6429, and the graphics are from ISO 8859-1. The ISO-8 graphics are code page 00819, named ISO/ANSI Multilingual.
Index

Numerics
2K-IDAW control  15-28
370-XA architecture  1-29

A
A (ADD) binary instruction  7-25
abort
  transactional execution  5-90
aborted-transaction-instruction-address
  in the transaction diagnostic block  5-96
absolute address  3-4
absolute storage  3-4
access-control bits
  in segment-table entry  3-43, 3-46
access-control bits in storage key  3-9
access-exception-fetch/store-indication facility
  facility indication  4-77
access exceptions  6-45, 6-51
  priority of  6-51
  recognition of  6-45
access key  3-11
  for channel-program execution  3-11, 15-25, 15-30
  for channel-subsystem monitoring  3-11
  for CPU  3-11
access list  5-57
  See also access-list entry
  accessing capability, revocation of  5-52
  allocation and invalidation of entries in  5-50
  authorizing the use of entries in  5-50
  concepts  5-48
  designation (ALD)  5-57
  length (ALL)  5-57
  origin (ALO)  5-57
access-list-controlled protection  3-13
  exception for  6-33
access-list designation  5-57
access-list entry (ALE)  5-57
  authorization index (ALEAX)  5-58
  number
    See ALEN
  sequence exception  6-21
    as an access exception  6-45
  sequence number (ALESN)
    in ALE  5-57
    in ALET  5-55
  token
    See ALET
access-register mode  3-37
access-register translation (ART)  5-54
  as part of LOAD REAL ADDRESS, STORE REAL
  ADDRESS, TEST ACCESS, and TEST
  PROTECTION  5-60
  introduction to  5-48
  lookaside buffer
  See ALB
    sequence of table fetches  5-117
  access-register-translation (ART) tables  5-56
access registers  2-6
  designation of  5-47
  functions of  5-47
  instructions for use of  5-53
  save areas for  3-75
  validity bit for  11-21
  access to storage  5-111
  See also reference
active
  device  16-16, 16-36
  subchannel  16-16, 16-36
active allegiance  15-13
active communication  15-13
activity-control field (SCSW)  16-14, 16-36
  following TEST SUBCHANNEL  14-21
AD (ADD NORMALIZED) HFP instruction  18-8
  example A-41
adaptive dictionary  7-160
ADB (ADD) BFP instruction  19-15
ADBR (ADD) BFP instruction  19-15
ADD BFP instructions  19-15
ADD binary instructions  7-25
ADD DECIMAL instruction  8-6
  example A-36
ADD DFP instructions  20-18
ADD HALFWORD IMMEDIATE instruction  7-27
ADD HALFWORD instruction  7-27
  example A-8
ADD HIGH binary instructions  7-28
ADD IMMEDIATE binary instructions  7-26
ADD IMMEDIATE HIGH binary instructions  7-28
ADD LOGICAL HIGH binary instructions  7-30
ADD LOGICAL IMMEDIATE instructions  7-29
ADD LOGICAL instructions  7-29
ADD LOGICAL WITH CARRY instructions  7-30
ADD LOGICAL WITH SIGNED IMMEDIATE high
  binary instructions  7-32
ADD LOGICAL WITH SIGNED IMMEDIATE
  instructions  7-31
ADD NORMALIZED HFP instructions  18-8
  example A-41
ADD UNNORMALIZED HFP instructions 18-9
example A-42
additional floating-point (AFP) registers 9-9
address 3-2
24-bit, 31-bit, and 64-bit 3-5
in branch-address generation 5-13
in operand address generation 5-12
absolute 3-4
AR-specified virtual
See AR-specified
arithmetic 3-5, 5-11
unsigned binary 7-6
backward stack-entry 5-81
base
See base address
branch
See branch address
channel-program
See channel-program address
comparison 12-1
controls for 12-1
effect on CPU state 4-2
CPU
See CPU address
data (I/O)
See data address
effective
See effective address
failing-storage
See failing-storage address
format 3-3
forward-section header 5-82
generation 5-10
for storage addressing 3-7
home virtual
See home virtual address
I/O 13-5
instruction
See instruction address
invalid 6-19
logical
See logical address
numbering of for byte locations 3-2
PER
See PER address
prefixing
See prefix
primary virtual
See primary virtual address
real 3-4
secondary virtual
See secondary virtual address
size of
controlled by addressing mode 5-10
storage 3-2
summary information 3-65
translation
See dynamic address translation, prefix
types 3-4
virtual 3-5
wraparound
See wraparound
address-limit checking (I/O)
effect of I/O-system reset on 17-15
limit mode (bits in PMCW) 15-3
address-limit-checking control (I/O) 15-27, 16-12
used for IPL 17-17
address of] 15-35
address space 3-20
AR-specified 5-47
changing of 3-20
control bits
control bit 5-77
in the PSW 4-6
use in address translation 3-37
created by DAT 3-35
number
See ASN
address-space-control element (ASCE) 3-39
effective 3-49
home 3-41
in AST entry 3-29
used for access-register translation 5-59
used for subspace groups 5-70
primary 3-39
secondary 3-41
type exception 6-21
addressing
trimodal 7-7
address-and-translation-mode identification (ATMID) 4-27
addressing exception 6-19
as an access exception 6-45, 6-51
addressing mode 5-10
bit in linkage-stack state entry 5-84
bit in the PSW 4-6
effect on address size 3-6
effect on operand-address generation 5-12
effect on sequential instruction-address generation 5-10
effect on wraparound 3-7
in branch-address generation 5-13
in examples A-7
in operand address generation 5-12
set by BRANCH AND SAVE AND SET MODE instruction 7-36
set by BRANCH AND SET MODE instruction 7-37
set by SET ADDRESSING MODE instruction
7-321
use of 5-18
ADR (ADD NORMALIZED) HFP instruction 18-8
ADTR (ADD) DFP instruction 20-18
AE (ADD NORMALIZED) HFP instruction 18-8
example A-41
AEB (ADD) BFP instruction 19-15
AEBR (ADD) BFP instruction 19-15
AER (ADD NORMALIZED) HFP instruction 18-8
AFI (ADD IMMEDIATE) instruction 7-26, 7-28
AFP (additional floating-point) registers 9-9
AFP-register data exception 6-24
AFT (ASN first table) 3-28
AFTE (ASN-first-table entry) 3-28
AFTO (ASN-first-table origin) 3-28
AFX (ASN-first-table index) 3-27
invalid bit 3-28
translation exception 6-20
AG (ADD) binary instruction 7-26
AGF (ADD) binary instruction 7-26
AGFI (ADD IMMEDIATE) instruction 7-26
AGFR (ADD) binary instruction 7-25
AGHI (ADD HALFWORD IMMEDIATE) instruction 7-27
AGHIK (ADD IMMEDIATE) instruction 7-26
AGR (ADD) binary instruction 7-25
AGRK (ADD) binary instruction 7-25
AGSI (ADD IMMEDIATE) instruction 7-26
AH (ADD HALFWORD) instruction 7-27
example A-8
AHHHR (ADD HIGH) binary instruction 7-28
AHI (ADD HALFWORD IMMEDIATE) instruction 7-27
AHIK (ADD IMMEDIATE) instruction 7-26
AHY (ADD HALFWORD) instruction 7-27
AHI (ADD IMMEDIATE HIGH) binary instruction 7-28
AKM (authorization key mask) 5-38
AL (ADD LOGICAL) instruction 7-29
ALB (ART-lookaside buffer) 5-65
entry
    clearing of 5-67
    effect of translation changes on 5-67
    usable state 5-66
ALC (ADD LOGICAL WITH CARRY) instruction 7-30
ALCG (ADD LOGICAL WITH CARRY) instruction 7-30
ALCGR (ADD LOGICAL WITH CARRY) instruction 7-30
ALCR (ADD LOGICAL WITH CARRY) instruction 7-30
ALD (access-list designation) 5-57
ALE
    See access-list entry
ALEAX (access-list-entry authorization index) 5-58
ALEN (access-list-entry number) 5-55
    invalid bit 5-57
    translation exception 6-21
    as an access exception 6-45
alert (class of machine-check condition) 11-11
alert interruption condition (I/O) 16-5
alert-status bit (I/O) 16-17
ALESN (access-list-entry sequence number)
in ALE 5-57
in ALET 5-55
ALET (access-list-entry token) 5-49, 5-55
    specification exception 6-21
    as an access exception 6-45
ALFI (ADD LOGICAL IMMEDIATE) instruction 7-29
ALG (ADD LOGICAL) instruction 7-29
ALGF (ADD LOGICAL) instruction 7-29
ALGFI (ADD LOGICAL IMMEDIATE) instruction 7-29
ALGFR (ADD LOGICAL) instruction 7-29
ALGHSIK (ADD LOGICAL WITH SIGNED IMMEDIATE) instruction 7-31
ALGR (ADD LOGICAL) instruction 7-29
ALGRK (ADD) binary instruction 7-29
ALGSI (ADD LOGICAL WITH SIGNED IMMEDIATE) instruction 7-31
ALHHHR (ADD LOGICAL HIGH) binary instruction 7-30
ALHSIK (ADD LOGICAL WITH SIGNED IMMEDIATE) instruction 7-31
alignment 3-3
ALL (access-list length) 5-57
allegiance
    active 15-13
    channel-path 15-12
    dedicated 15-13
    effect on CLEAR SUBCHANNEL of 15-12
    working 15-12
allowed interruptions 6-5
ALO (access-list origin) 5-57
ALR (ADD LOGICAL) instruction 7-29
ALRK (ADD) binary instruction 7-29
ALSI (ADD LOGICAL WITH SIGNED IMMEDIATE) instruction 7-31
ALSIH (ADD LOGICAL WITH SIGNED IMMEDIATE HIGH) instruction 7-32
ALSIHN (ADD LOGICAL WITH SIGNED IMMEDIATE HIGH) binary instruction 7-32
alter-and-display controls 12-2
alteration
    storage (PER event) 4-33
ALY (ADD LOGICAL) instruction 7-29
ancillary-report bit
    in channel-report word 17-26
<table>
<thead>
<tr>
<th>Page Numbers</th>
<th>Topic</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-17</td>
<td>in machine-check-interruption code</td>
</tr>
<tr>
<td>16-49</td>
<td>in subchannel logout</td>
</tr>
<tr>
<td>7-33</td>
<td>AND IMMEDIATE instructions</td>
</tr>
<tr>
<td>7-32</td>
<td>AND instructions</td>
</tr>
<tr>
<td>A-8</td>
<td>examples</td>
</tr>
<tr>
<td>A-36</td>
<td>example</td>
</tr>
<tr>
<td>7-25</td>
<td>AR (ADD) binary instruction</td>
</tr>
<tr>
<td>3-5, 3-20</td>
<td>AR-specified (access-register-specified) virtual address space, virtual address 3-5</td>
</tr>
<tr>
<td>3-49</td>
<td>effective address-space-control element for access-register-specified virtual address</td>
</tr>
<tr>
<td>3-5, 5-47</td>
<td>architected register context</td>
</tr>
<tr>
<td>3-20</td>
<td>address space</td>
</tr>
<tr>
<td>3-5</td>
<td>virtual address</td>
</tr>
<tr>
<td>11-17</td>
<td>in subchannel logout</td>
</tr>
<tr>
<td>5-38</td>
<td>second-table index in entry-table entry</td>
</tr>
<tr>
<td>3-28</td>
<td>second-table (AST)</td>
</tr>
<tr>
<td>5-38</td>
<td>second-table address in ETE</td>
</tr>
<tr>
<td>3-22</td>
<td>instance exception for subspace groups</td>
</tr>
<tr>
<td>6-45</td>
<td>sequence exception as an access exception</td>
</tr>
<tr>
<td>5-58</td>
<td>sequence number in ALE</td>
</tr>
<tr>
<td>5-59</td>
<td>sequence number in ASTE</td>
</tr>
<tr>
<td>6-23</td>
<td>validity exception</td>
</tr>
<tr>
<td>6-23</td>
<td>validity exception as an access exception</td>
</tr>
<tr>
<td>6-22</td>
<td>sequence exception</td>
</tr>
<tr>
<td>4-12</td>
<td>translation-control bit trace-control bit</td>
</tr>
<tr>
<td>3-27</td>
<td>translation</td>
</tr>
<tr>
<td>6-53</td>
<td>translation-control bit exceptions</td>
</tr>
<tr>
<td>3-28</td>
<td>second-table origin in ASTO</td>
</tr>
<tr>
<td>3-29</td>
<td>AT valid bit in ART</td>
</tr>
<tr>
<td>1-7</td>
<td>ASN-and-LX-reuse facility</td>
</tr>
<tr>
<td>4-27</td>
<td>addressing-and-translation-mode identification ATMID</td>
</tr>
<tr>
<td>4-76</td>
<td>facility indication</td>
</tr>
<tr>
<td>A-7</td>
<td>assembler language instruction formats</td>
</tr>
<tr>
<td>Appendix B</td>
<td>in assembler language instruction formats in Appendix B</td>
</tr>
<tr>
<td>3-68</td>
<td>assigned storage locations</td>
</tr>
<tr>
<td>3-28</td>
<td>AST (ASN second table)</td>
</tr>
<tr>
<td>5-58</td>
<td>AST entry in ALE</td>
</tr>
<tr>
<td>5-59</td>
<td>AST entry in ASTE</td>
</tr>
<tr>
<td>3-28</td>
<td>ASTO (ASN-second-table origin) in ASTE</td>
</tr>
<tr>
<td>3-27</td>
<td>ASX (ASN-second-table index) invalid bit in ART</td>
</tr>
<tr>
<td>5-59</td>
<td>use in ART</td>
</tr>
<tr>
<td>6-23</td>
<td>translation exception in ART</td>
</tr>
<tr>
<td>5-29</td>
<td>ASN-and-LX-reuse-control bit in ASTO</td>
</tr>
<tr>
<td>3-22</td>
<td>ASN-and-LX-reuse facility</td>
</tr>
<tr>
<td>3-22</td>
<td>in assembly language in ASA and IEA</td>
</tr>
<tr>
<td>3-29</td>
<td>AT valid bit in ART</td>
</tr>
<tr>
<td>3-28</td>
<td>second-table origin in ASTO</td>
</tr>
<tr>
<td>3-29</td>
<td>AT valid bit in ART</td>
</tr>
<tr>
<td>4-27</td>
<td>ATMID (addressing-and-translation-mode identification) in ATMID</td>
</tr>
<tr>
<td>3-68</td>
<td>assigned storage locations</td>
</tr>
<tr>
<td>3-28</td>
<td>AST (ASN second table) in ATAL</td>
</tr>
<tr>
<td>5-59</td>
<td>use in ART in ATAL</td>
</tr>
<tr>
<td>5-59</td>
<td>use in ART in ATMID</td>
</tr>
<tr>
<td>xxvii</td>
<td>handled by architecture ASCII character code</td>
</tr>
<tr>
<td>A-2</td>
<td>examples in address arithmetic binary</td>
</tr>
<tr>
<td>A-4, A-36</td>
<td>examples in address arithmetic decimal</td>
</tr>
<tr>
<td>A-5, A-41</td>
<td>examples in address arithmetic floating-point</td>
</tr>
<tr>
<td>A-3</td>
<td>examples in address arithmetic logical (unsigned binary)</td>
</tr>
<tr>
<td>5-58</td>
<td>AST entry AST second-table entry in ALE</td>
</tr>
<tr>
<td>5-59</td>
<td>AST entry AST second-table entry in ASTE</td>
</tr>
<tr>
<td>5-58</td>
<td>AST entry ASTE-entry sequence number in ALE</td>
</tr>
<tr>
<td>5-59</td>
<td>AST entry ASTE-entry sequence number in ASTE</td>
</tr>
<tr>
<td>3-28</td>
<td>AT valid bit in ART</td>
</tr>
<tr>
<td>5-59</td>
<td>AT valid bit in ART</td>
</tr>
<tr>
<td>5-59</td>
<td>AT valid bit in ART</td>
</tr>
</tbody>
</table>
attached ART-table entry 5-66
attached region-table, segment-table, or page-table entry 3-59
attachment of I/O devices 13-3
AU (ADD UNNORMALIZED) HFP instruction 18-9
example A-42
AUR (ADD UNNORMALIZED) HFP instruction 18-9
authority table (AT) 5-30
designation 3-29, 5-59
length 3-29, 5-59
origin 3-29, 5-59
authorization
ASN 3-32
index (AX) 3-32, 5-30
key mask (AKM) 5-38
mechanisms 5-28
summary of 5-32
testing of 5-75
authorization check 16-52
indicator for (in ERW) 16-52
automatic reconfiguration 1-28
auxiliary storage 3-2, 3-35
availability (characteristic of a system) 1-32
AW (ADD UNNORMALIZED) HFP instruction 18-9
AWR (ADD UNNORMALIZED) HFP instruction 18-9
AX (authorization index) 3-32, 5-30
AXBR (ADD) BFP instruction 19-15
AXR (ADD NORMALIZED) HFP instruction 18-8
AY (ADD) binary instruction 7-25

B
B field of instruction 5-11
backed-up bit (machine-check condition) 11-17
backup
processing (synchronous machine-check condition) 11-17
backward stack-entry address 5-81
backward stack-entry validity bit 5-81
BAKR (BRANCH AND STACK) instruction 10-10
examples A-10
BAL (BRANCH AND LINK) instruction 7-34
examples A-8
BALR (BRANCH AND LINK) instruction 7-34
examples A-8
BAS (BRANCH AND SAVE) instruction 7-35
example A-8
base address 5-11
register for 2-4
base-AST-entry origin (BASTEO) 5-68
base-authority state 10-7
base space 5-17
base-space bit 5-69
basic addressing mode
bit in entry-table entry 5-38
basic I/O functions 15-1
basic PROGRAM CALL 5-73, 10-89
BASR (BRANCH AND SAVE) instruction 7-35
example A-8
BASSM (BRANCH AND SAVE AND SET MODE) instruction 7-36
example A-8
BASTEO (base-AST-entry origin) 5-68
BC (BRANCH ON CONDITION) instruction 7-37
example A-12
BCR (BRANCH ON CONDITION) instruction 7-37
BCT (BRANCH ON COUNT) instruction 7-38
example A-12
BCTG (BRANCH ON COUNT) instruction 7-38
BCTGR (BRANCH ON COUNT) instruction 7-38
BCTR (BRANCH ON COUNT) instruction 7-38
example A-12
BFP
data class
testing of 19-41
BFP (binary floating point) 9-4
BFP data 19-2
conversion of 9-27
BFP facility 19-1
BFP-instruction data exception 6-24
bias for exponent 9-2, 19-2, 20-3
function of view 9-2
summary for BFP 19-2, 19-3
summary for DFP 20-3, 20-6
biased exponent 9-2, 19-2, 20-3
big endian 7-243, 7-337
bimodal addressing
See addressing mode
binary
See also fixed point arithmetic 7-5
examples A-2
negative zero 7-4
number representation 7-4
examples A-2
overflow 7-5
example A-2
See also fixed point sign bit 7-4
binary floating point (BFP) 9-4
binary integer
cconversion from floating point 18-11, 19-22, 19-25, 20-28, 20-31
cconversion to floating point 18-11, 19-19, 20-23, 20-24
binary-to-decimal conversion 7-189
example A-19
bit 3-2
numbering of within a group of bytes 3-3
bits to left of compressed data 7-157
bits to right of compressed data 7-157
block-concurrent storage references 5-124
block number
expanded storage 2-2
block of I/O data 15-24
block of storage 3-4
See also page testing for usability of 10-161
borrow 7-341
boundary alignment 3-3
for instructions 5-3
BPP (BRANCH PREDICTION PRELOAD) instruction 7-40
BPRP (BRANCH PREDICTION RELATIVE PRELOAD) instruction 7-40
branch address 5-12
control bit 4-25
in linkage-stack state entry 5-84
in trace entry 4-19
BRANCH AND LINK instructions 7-34
examples A-8
BRANCH AND SAVE AND SET MODE instruction 7-36
examples A-8
BRANCH AND SAVE instructions 7-35
examples A-8
BRANCH AND SET AUTHORITY instruction 10-6
examples A-8
BRANCH AND SET MODE instruction 7-37
examples A-8
BRANCH AND STACK instruction 10-10
examples A-10
BRANCH IN SUBSPACE GROUP instruction 10-12
BRANCH ON CONDITION instructions 7-37
example A-12
BRANCH ON COUNT instructions 7-38
example A-12
BRANCH ON INDEX HIGH instruction 7-39
examples A-12
BRANCH ON INDEX LOW OR EQUAL instruction 7-39
examples A-13
BRANCH RELATIVE AND SAVE instruction 7-43
BRANCH RELATIVE AND SAVE LONG instruction 7-43
BRANCH RELATIVE ON CONDITION instruction 7-44
BRANCH RELATIVE ON CONDITION LONG instruction 7-44
BRANCH RELATIVE ON COUNT HIGH instruction 7-45
BRANCH RELATIVE ON COUNT instruction 7-45
BRANCH RELATIVE ON INDEX HIGH instruction 7-45
BRANCH RELATIVE ON INDEX LOW OR EQUAL instruction 7-46
branch state entry 5-82, 10-10
branch-trace-control bit 4-12
branching
branch-address generation 5-12
in a channel program 15-76
relative 5-12
to perform decision making, loop control, and
subroutine linkage 5-13
using the linkage stack 5-74
BRAS (BRANCH RELATIVE AND SAVE) instruction 7-43
BRASL (BRANCH RELATIVE AND SAVE LONG) instruction 7-43
BRC (BRANCH RELATIVE ON CONDITION) instruction 7-44
BRCL (BRANCH RELATIVE ON CONDITION LONG) instruction 7-44
BRCT (BRANCH RELATIVE ON COUNT) instruction 7-45
BRCTG (BRANCH RELATIVE ON COUNT) instruction 7-45
BRCTH (BRANCH RELATIVE ON COUNT HIGH) instruction 7-45
breaking-event address
 in the transaction diagnostic block 5-97
 assigned storage locations for 3-73
breaking-event-address register 4-40
broadcasted-purging facility 1-24
BRXH (BRANCH RELATIVE ON INDEX HIGH) instruction 7-45
BRXHG (BRANCH RELATIVE ON INDEX HIGH) instruction 7-45
BRXLE (BRANCH RELATIVE ON INDEX LOW OR EQUAL) instruction 7-46
BRXLG (BRANCH RELATIVE ON INDEX LOW OR EQUAL) instruction 7-46
BSA (BRANCH AND SET AUTHORITY) instruction 10-6
BSG (BRANCH IN SUBSPACE GROUP) instruction 10-12
BSM (BRANCH AND SET MODE) instruction 7-37
example A-8
buffer storage (cache) 3-2
burst mode (channel-path operation) 13-3
busy
 in I/O operations 13-10
 in SIGNAL PROCESSOR 4-71
BX (byte index) 3-36
BXH (BRANCH ON INDEX HIGH) instruction 7-39
examples A-12
BXHG (BRANCH ON INDEX HIGH) instruction 7-39
BXLE (BRANCH ON INDEX LOW OR EQUAL) instruction 7-39
examples A-13
BXLEG (BRANCH ON INDEX LOW OR EQUAL) instruction 7-39
byte 3-2
numbering of in storage 3-2
byte index (BX) 3-36
byte-multiplex mode (channel-path operation) 13-3

C
C (COMPARE) binary instruction 7-117
cache 3-2
called-space identification 5-84
cancel-I/O facility 1-25
CANCEL SUBCHANNEL instruction 14-3
candidates
selection of 9-13
canonical
declets 20-6
canonicalization
of DFP data 20-7
capability list 5-32
carry 7-5
CBC (checking-block code) 11-2
invalid 11-2
in registers 11-9
in storage 11-7
in storage keys 11-7
near-valid 11-2
valid 11-2
CBN (compressed-data bit number) 7-155
example of 7-160
CCC (channel-control check) 16-29
CCW (channel-command word) 15-30
address of 16-19
byte count in 15-23
check (in subchannel logout) 16-48
command codes
See commands
contents of 15-31
current 15-31
designation of storage area in 15-32
format-0 and format-1 15-31
format control 16-11, 16-12, 16-35, 16-36
used for IPL 17-17
IDA flag in 15-32
indirect data addressing used in 13-9, 15-66
invalid format of 16-27
invalid specification of 16-25, 16-40
MIDA flag in 15-33
modified indirect data addressing used in 15-68
PCI flag in 15-32
prefetch control in 16-11
used for IPL 17-17
prefetching 15-62
retry of
See command retry
skip flag in 15-32
suspend flag in 15-32
CCW channel program 13-7
CCW-format control 15-27
CCW-type IPL (CCW-type initial program loading) 17-17
CD (COMPARE) HFP instruction 18-10
CDB (COMPARE) BFP instruction 19-17
CDBR (COMPARE) BFP instruction 19-17
CDFBR (CONVERT FROM FIXED) BFP instruction 19-19, 19-21
CDFBRA (CONVERT FROM FIXED) BFP instruction 19-19
CDFR (CONVERT FROM FIXED) HFP instruction 18-11
CDFTR (CONVERT FROM FIXED) DFP instruction 20-23
CDGBR (CONVERT FROM FIXED) BFP instruction 19-19, 19-21
CDGBRA (CONVERT FROM FIXED) BFP instruction 19-19
CDGR (CONVERT FROM FIXED) HFP instruction 18-11
CDGTR (CONVERT FROM FIXED) DFP instruction 20-23
CDGTRA (CONVERT FROM FIXED) DFP instruction 20-23
CDLFBR (CONVERT FROM LOGICAL) BFP instruction 19-21
CDLFTR (CONVERT FROM LOGICAL) DFP instruction 20-24
CDLGBR (CONVERT FROM LOGICAL) BFP instruction 19-21
CDLGTR (CONVERT FROM LOGICAL) DFP instruction 20-24
CDPT (CONVERT FROM PACKED) instruction 20-25
CDR (COMPARE) HFP instruction 18-10
examples A-42
CDS (COMPARE DOUBLE AND SWAP) instruction 7-127
examples A-46
CDSG (COMPARE DOUBLE AND SWAP) instruction 7-127
CDSS (compressed-data symbol size) 7-156
CDSTR (CONVERT FROM SIGNED PACKED) DFP instruction 20-27
CDSY (COMPARE DOUBLE AND SWAP) instruction 7-127
CDTR (COMPARE) DFP instruction 20-20
CDUTR (CONVERT FROM UNSIGNED PACKED) DFP instruction 20-27
CDZT “????” Zoned-decimal source, long DFP result 20-28, 20-35
CE (COMPARE) HFP instruction 18-10
CEB (COMPARE) BFP instruction 19-17
CEBR (COMPARE) BFP instruction 19-17
CEDTR (COMPARE BIASED EXPONENT) DFP instruction 20-22
CEFBR (CONVERT FROM FIXED) BFP instruction 19-19, 19-21
CEFBR (CONVERT FROM FIXED) BFP instruction 19-19
CEFBR (CONVERT FROM FIXED) HFP instruction 18-11
CEGBR (CONVERT FROM FIXED) BFP instruction 19-19, 19-21
CEGBRA (CONVERT FROM FIXED) BFP instruction 19-19
CEGR (CONVERT FROM FIXED) HFP instruction 18-11
CELFBR (CONVERT FROM LOGICAL) BFP instruction 19-21
CELGBR (CONVERT FROM LOGICAL) BFP instruction 19-21
central processing unit
See CPU
CER (COMPARE) HFP instruction 18-10
CEXTR (COMPARE BIASED EXPONENT) DFP instruction 20-22
CFC (COMPARE AND FORM CODEWORD) instruction 7-120
example A-53
CFDBR (CONVERT TO FIXED) BFP instruction 19-22
CFDBRA (CONVERT TO FIXED) BFP instruction 19-22
CFDR (CONVERT TO FIXED) HFP instruction 18-11
CFEBR (CONVERT TO FIXED) BFP instruction 19-22
CFEBRA (CONVERT TO FIXED) BFP instruction 19-22
CFEBR (CONVERT TO FIXED) HFP instruction 18-11
CFEBRA (CONVERT TO FIXED) BFP instruction 19-22
CG (COMPARE) binary instruction 7-117
CGF (COMPARE) binary instruction 7-117
CGFI (COMPARE IMMEDIATE) instruction 7-117
CGFR (COMPARE) binary instruction 7-117
CGFRL (COMPARE RELATIVE LONG) instruction 7-118
CGH (COMPARE HALFWORD) binary instruction 7-133
CGHI (COMPARE HALFWORD IMMEDIATE) instruction 7-133
CGHRL (COMPARE HALFWORD RELATIVE LONG) binary instruction 7-133
CGHSI (COMPARE HALFWORD IMMEDIATE) instruction 7-133
CGIB (COMPARE IMMEDIATE AND BRANCH) instruction 7-119
CGIJ (COMPARE IMMEDIATE AND BRANCH RELATIVE) instruction 7-119
CGIT (COMPARE IMMEDIATE AND TRAP) instruction 7-132
CGR (COMPARE) binary instruction 7-117
CGRB (COMPARE AND BRANCH) instruction 7-118
CGRJ (COMPARE AND BRANCH RELATIVE) instruction 7-118
CGLR (COMPARE RELATIVE LONG) binary instruction 7-118
CGRRT (COMPARE AND TRAP) instruction 7-132
CGXBR (CONVERT TO FIXED) BFP instruction 19-22
CGXBRA (CONVERT TO FIXED) BFP instruction 19-22
CGXR (COMPARE TO FIXED) HFP instruction 18-11
CGXTR (COMPARE TO FIXED) DFP instruction 20-28, 20-29, 20-31
CH (COMPARE HALFWORD) instruction 7-133
example A-14
chaining check (subchannel status) 16-30
chaining of CCWs 15-63
command
See command chaining of CCWs

X-8 IBM z/Architecture Principles of Operation
data
   See data chaining of CCWs
chaining of CRWs 17-25, 17-26
change bit in storage key 3-9
change recording 3-17
channel-command word
   See CCW
channel commands
   See commands (I/O)
channel-control check (subchannel status) 16-29
channel-data check (subchannel status) 16-28, 16-35, 16-44
channel path 13-3
   active allegiance for 15-13
   available for selection 15-13
   dedicated allegiance for 15-13
   effect of I/O-system reset on 17-14
   masks in SCHIB
   See LPM, LPUM, PAM, PIM, PNOM, POM
   multipath mode of 15-4, 15-23
   not operational 16-13
   parallel-I/O-interface type 13-3
   serial-I/O-interface type 13-3
   storing of status for 14-16
   type of 13-3, 13-6
   working allegiance for 15-12
channel-path identifier
   See CHPID
channel-path reset 17-13
   effect of I/O-system reset on 17-15
channel-path-reset function 15-80
   completion of 15-81
   initiation by RESET CHANNEL PATH 14-9
   reset signal issued as part of 17-12
   signaling for 15-81
channel-path-status word 14-16
channel-path timeout
   indicator for (in ERW) 16-52
channel program 15-31
   2K-IDAW control for 15-28
   branching in
   See TIC
   CCW channel program 13-7
   execution of 13-11, 15-23
      resumption of 14-11
      suspension of 13-11, 15-73
   format-2-IDAW control for 15-27
   modification control for 15-26
   serialization 5-130
   streaming-mode control for 15-25
   suspend control for 15-25
   synchronization control for 15-26
   TCW channel program 13-7
channel-program address 16-19
   field-validity flag for in IRB 16-49
   used for IPL 17-17
channel-program type
   CCW channel program 13-7
   TCW channel program 13-7
channel-program-type control 15-27
channel report 17-24
   generated as a result of RCHP 14-9
   channel report pending 11-16, 17-25
   effect of I/O-system reset on 17-15
   subclass-mask bit for 11-24
channel-report word
   See CRW
channel subsystem 2-7, 13-1
   addressing used in 13-5
   damage 11-17
   effect of I/O-system reset on 17-13
   effect of power-on reset on 4-61
   isolated state of 16-52
channel-subsystem-call facility 1-28
channel-subsystem monitoring 17-1
   effect of I/O-system reset on 17-15
channel-subsystem recovery 11-5, 17-24
channel-subsystem timer 17-2
   effect of I/O-system reset on 17-15
channel-subsystem timing 17-2
channel-subsystem timing-facility bit (in PMCW) 15-4
characteristic (of HFP number) 18-1
See also exponent
characters
   represented by eight-bit code xxvii
check bits 3-3, 11-2
check stop 4-3, 11-10
   as signal-processor status 4-74
   during manual operation 12-1
   effect on CPU timer 4-54
   entering of 11-13
   indicator 12-3
   malfunction alert for 6-13
   system 11-10
checking block 11-2
checking-block code
   See CBC
checkpoint 11-2
checkpoint synchronization 11-3
   action 11-4
   operations 11-4
CHECKSUM instruction 7-47
CHH (COMPARE HIGH) instruction 7-134
CHHR (COMPARE HIGH) instruction 7-134
CHHSI (COMPARE HALFWORD IMMEDIATE) instruction 7-133
CHI (COMPARE HALFWORD IMMEDIATE) instruction 7-133
CHLR (COMPARE HIGH) instruction 7-134
CHPID (channel-path identifier) 13-5
    in PMCW 15-8
    used in RESET CHANNEL PATH 14-9
CHRL (COMPARE HALFWORD RELATIVE LONG)
    binary instruction 7-133
CHSI (COMPARE HALFWORD IMMEDIATE)
    instruction 7-133
CHY (COMPARE HALFWORD) instruction 7-133
CIB (COMPARE IMMEDIATE AND BRANCH)
    instruction 7-119
CIH (COMPARE IMMEDIATE HIGH) instruction
    7-134
CIJ (COMPARE IMMEDIATE AND BRANCH
    RELATIVE) instruction 7-119
CIPHER MESSAGE instruction 7-50
CIPHER MESSAGE WITH CHAINING instruction
    7-50
CIPHER MESSAGE WITH CIPHER FEEDBACK
    instruction 7-75
CIPHER MESSAGE WITH COUNTER instruction
    7-90
CIPHER MESSAGE WITH OUTPUT FEEDBACK
    instruction 7-103
CIT (COMPARE IMMEDIATE AND TRAP) instruction
    7-132
CKSM (CHECKSUM) instruction 7-47
CL (COMPARE LOGICAL) instruction 7-135
    class
        of BFP data 19-4
        testing of 19-41
        of DFP data
        testing of 20-55
CLC (COMPARE LOGICAL) instruction 7-135
    example A-15
CLCL (COMPARE LOGICAL LONG) instruction
    7-141
    example A-16
CLCLE (COMPARE LOGICAL LONG EXTENDED)
    instruction 7-143
CLCLU (COMPARE LOGICAL LONG UNICODE)
    instruction 7-146
clear function 15-14, 15-22
    bit in SCSW for 16-14
    completion of 15-15
    initiated by CLEAR SUBCHANNEL 14-5
    path management for 15-14, 15-22
    pending 16-16
    signaling for 15-15
    subchannel modification by 15-15
clear reset 4-60
clear signal 17-12
    issued as part of clear function 15-15
CLEAR SUBCHANNEL instruction 14-5
See also clear function
    effect on device status of 15-16
    function initiated by 15-14, 15-22
    use of after RESET CHANNEL PATH 14-10
    clearing operation
        by clear-reset function 4-60
        by load-clear key 12-3
        by load-clear-list-directed key 12-4
        by system-reset-clear key 12-6
        by TEST BLOCK instruction 10-161
CLFDBR (CONVERT TO FIXED) BFP instruction
    19-25
CLFDTR (CONVERT TO LOGICAL) DFP instruction
    20-31
CLFEBR (CONVERT TO FIXED) BFP instruction
    19-25
CLFHSI (COMPARE LOGICAL IMMEDIATE)
    instruction 7-135
CLFI (COMPARE LOGICAL IMMEDIATE) instruction
    7-135
CLFIT (COMPARE LOGICAL IMMEDIATE AND
    TRAP) instruction 7-139
CLFT (COMPARE LOGICAL AND TRAP) instruction
    7-138
CLFXBR (CONVERT TO FIXED) BFP instruction
    19-25
CLG (COMPARE LOGICAL) binary instruction
    7-135
CLGF (COMPARE LOGICAL) binary instruction
    7-135
CLGFRL (COMPARE LOGICAL RELATIVE LONG)
    binary instruction
CLGFR (COMPARE LOGICAL) binary instruction
    7-135
CLGHRL (COMPARE LOGICAL RELATIVE LONG)
    binary instruction 7-136
CLGHSI (COMPARE LOGICAL IMMEDIATE)
    instruction 7-135
CLGIB (COMPARE LOGICAL IMMEDIATE AND
    BRANCH) instruction 7-137
CLGIJ (COMPARE LOGICAL IMMEDIATE AND
    BRANCH RELATIVE) instruction 7-137
CLGIT (COMPARE LOGICAL IMMEDIATE AND
    TRAP) instruction 7-139
CLGR (COMPARE LOGICAL) binary instruction
    7-135
CLGRB (COMPARE LOGICAL AND BRANCH) instruction 7-137
CLGRJ (COMPARE LOGICAL AND BRANCH RELATIVE) instruction 7-137
CLGRL (COMPARE LOGICAL RELATIVE LONG) binary instruction 7-136
CLGRT (COMPARE LOGICAL AND TRAP) instruction 7-138
CLGT (COMPARE LOGICAL AND TRAP) instruction 7-138
CLGRL (COMPARE LOGICAL RELATIVE LONG) binary instruction 7-136
CLGRT (COMPARE LOGICAL AND TRAP) instruction 7-138
CLGRL (COMPARE LOGICAL RELATIVE LONG) binary instruction 7-136
CLGRJ (COMPARE LOGICAL AND BRANCH RELATIVE) instruction 7-137
CLGXR (CONVERT TO FIXED) BFP instruction 19-25
CLGXTR (CONVERT TO LOGICAL) DFP instruction 20-31
CLHH (COMPARE LOGICAL HIGH) instruction 7-140
CLHHR (COMPARE LOGICAL HIGH) instruction 7-140
CLHHISI (COMPARE LOGICAL IMMEDIATE) instruction 7-135
CLHLR (COMPARE LOGICAL HIGH) instruction 7-140
CLHRL (COMPARE LOGICAL RELATIVE LONG) binary instruction 7-136
CLI (COMPARE LOGICAL) instruction 7-135
example A-15
CLIB (COMPARE LOGICAL IMMEDIATE AND BRANCH) instruction 7-137
CLIH (COMPARE LOGICAL IMMEDIATE HIGH) instruction 7-141
CLIJ (COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE) instruction 7-137
CLIY (COMPARE LOGICAL) instruction 7-135
CLM (COMPARE LOGICAL CHARACTERS UNDER MASK) instruction 7-140
example A-16
CLMH (COMPARE LOGICAL CHARACTERS UNDER MASK) instruction 7-140
CLMY (COMPARE LOGICAL CHARACTERS UNDER MASK) instruction 7-140
clock
See TOD clock
clock comparator 4-53
external interruption 6-11
save areas for 3-75
validity bit for 11-21
clock unit 4-46, 7-333
CLR (COMPARE LOGICAL) instruction 7-135
example A-15
CLRB (COMPARE LOGICAL AND BRANCH) instruction 7-137
CLRJ (COMPARE LOGICAL AND BRANCH RELATIVE) instruction 7-137
CLRL (COMPARE LOGICAL RELATIVE LONG) binary instruction 7-136
CLRT (COMPARE LOGICAL AND TRAP) instruction 7-138
CLST (COMPARE LOGICAL STRING) instruction 7-149
examples A-18
CLY (COMPARE LOGICAL) instruction 7-135
CMPSC (COMPRESSION CALL) instruction 7-153
CMPSC-enhancement facility 1-7
facility indication CMPSC enhancement facility 4-77
code
ASCII handled by architecture xxvii
checking-block
See CBC
command (in CCW)
See command code in CCW
condition
See condition code
data-exception (DXC) 6-16, 20-14
decimal digit and sign 8-2
deferred condition (I/O) 16-9
EBCDIC handled by architecture xxvii
table for I-2
eight-bit handled by architecture xxvii
error-recovery (I/O) 17-27
external-damage 11-22
validity bit for 11-20
I/O-interruption subclass 15-2
instruction-length
See ILC
interruption
See interruption code
linkage-stack-entry type 5-80
monitor
See monitor code
operation 5-3
PER
See PER code
reporting-source (I/O) 17-26
storage-access (in subchannel logout) 16-50
vector-exception (VXC) 6-19
version 10-133
codeword (for sorting operations) 7-120
example A-54
cohort 20-2
combination field
in DFP data format 20-4
command chaining of CCWs 15-63
effect of status modifier on 15-63
flag in CCW for 15-32
command chaining of TCWs
overview of 13-11
command code in CCW 15-57
See also commands
See also common I/O-device commands
invalid 16-25
command codes
See command code in CCW
command mode 13-9
command retry 15-77
effect on PCI of 15-65
commands (I/O) 15-57
See also common I/O-device commands
transfer in channel 15-77
commit
transactional execution 5-91
common I/O-device commands
publication referenced xxvii
common-region bit 3-44
common-segment bit 3-46
common-rounding-point view 9-13
COMPARE AND BRANCH instructions 7-118
COMPARE AND BRANCH RELATIVE instructions 7-118
COMPARE AND FORM CODEWORD instruction 7-120
example A-53
COMPARE AND REPLACE DAT TABLE ENTRY
instruction 10-17
COMPARE AND SIGNAL BFP instructions 19-18
COMPARE AND SIGNAL DFP instructions 20-22
COMPARE AND SWAP AND PURGE instruction 10-20
compare-and-swap-and-store facility 1-7
facility indication 4-76
COMPARE AND SWAP AND STORE instruction 10-20
compare-and-swap-and-store facility 2 1-8
facility indication 4-76
COMPARE AND SWAP AND STORE instruction 7-129
COMPARE AND SWAP instruction 7-127
examples A-46
compare-and-trap-instruction data exception 6-24
COMPARE AND TRAP instructions 7-132
COMPARE BFP instructions 19-17
COMPARE BIASED EXPONENT DFP instructions 20-22
COMPARE binary instructions 7-117
COMPARE DECIMAL instruction 8-7
example A-36
COMPARE DFP instructions 20-20
COMPARE DOUBLE AND SWAP instruction 7-127
examples A-46
COMPARE HALFWORD IMMEDIATE instructions 7-133
COMPARE HALFWORD instruction 7-133
example A-14
COMPARE HFP instructions 18-10
examples A-42
COMPARE HIGH instructions 7-134
COMPARE IMMEDIATE AND BRANCH instructions 7-119
COMPARE IMMEDIATE AND BRANCH RELATIVE instructions 7-119
COMPARE IMMEDIATE AND TRAP instructions 7-132
COMPARE IMMEDIATE binary instructions 7-117
COMPARE IMMEDIATE HIGH instruction 7-134
COMPARE LOGICAL AND BRANCH instructions 7-137
COMPARE LOGICAL AND BRANCH RELATIVE instructions 7-137
COMPARE LOGICAL AND TRAP instructions 7-138
COMPARE LOGICAL CHARACTERS UNDER MASK instruction 7-140
example A-16
COMPARE LOGICAL HIGH instruction 7-140
COMPARE LOGICAL IMMEDIATE AND BRANCH instructions 7-137
COMPARE LOGICAL IMMEDIATE AND BRANCH RELATIVE instructions 7-137
COMPARE LOGICAL IMMEDIATE AND TRAP instructions 7-139
COMPARE LOGICAL IMMEDIATE HIGH instruction 7-141
COMPARE LOGICAL IMMEDIATE instructions 7-135
COMPARE LOGICAL instructions 7-135
examples A-15
COMPARE LOGICAL LONG EXTENDED instruction 7-143
COMPARE LOGICAL LONG instruction 7-141
example A-16
COMPARE LOGICAL LONG UNICODE instruction 7-146
COMPARE LOGICAL STRING instruction 7-149
examples A-18
COMPARE RELATIVE LONG instructions 7-118
COMPARE UNTIL SUBSTRING EQUAL instruction 7-150
comparison
address
See address comparison
decimal 8-7
example A-36
hexadecimal-floating-point
examples A-42
logical 7-6
examples A-15
of IEEE data 9-24
signed-binary 7-6
TOD-clock 4-53
compatibility 1-31
among systems implementing different architectures 1-31
among systems implementing same architecture 1-31
control-program 1-31
problem-state 1-31
completion of I/O functions
by channel-path-reset function 15-81
by clear function 15-15
by halt function 15-17
during initiation 15-78
completion of instruction execution 5-22
completion of unit of operation 5-24
compressed-data bit number (CBN) 7-155
example of 7-160
compressed-data symbol size (CDSS) 7-156
COMPRESSION CALL instruction 7-153
restriction related to
on leftmost bits in symbol-translation-table entry 7-158
on length of chain of compression-dictionary entries 7-158
on length of chain of expansion-dictionary entries 7-159
on length of character symbol during compression 7-158
on length of character symbol during expansion 7-159
on number of children 7-159, 7-160
on offset to symbol-translation table 7-156
on symbol translation with format-1 sibling descriptors 7-156
compression dictionary
size of with symbol translation 7-156
compression facility
publication referenced xxvii
COMPUTE INTERMEDIATE MESSAGE DIGEST instruction 7-165
COMPUTE LAST MESSAGE DIGEST instruction 7-165
COMPUTE MESSAGE AUTHENTICATION CODE instruction 7-178
conceptual sequence 5-111
as related to storage-operand accesses 5-126
conclusion of I/O operations 13-10, 16-1
during initiation 15-78
conclusion of instruction execution 5-22
concurrency of access for storage references 5-124
concurrent sense
in ECW 16-56
indicator for (in ERW) 16-52
concurrent-sense count (in ERW) 16-52
concurrent-sense facility 17-24
condition code 4-6
deferred 16-9
for IEEE instructions 9-24
in the PSW 4-6
inserted by INSERT PROGRAM MASK 7-221
preserved by BRANCH AND LINK 5-14, 7-35
set by SET PROGRAM MASK 7-321
summary C-1
tested by BRANCH ON CONDITION instruction 7-37
used for decision making 5-14
validity bit for 11-20
conditional emergency signal (external interruption)
signal-processor order 4-68
conditional-SSKE facility 1-8
and invalid CBC in storage key 11-8
conditional-swapping instructions
See COMPARE AND SWAP instruction,
COMPARE DOUBLE AND SWAP instruction
conditional-SSKE facility
facility indication 4-76
conditions for interruption
See interruption conditions
configuration 2-1
of storage 3-4
configuration-alert facility (I/O) 17-23
configuration-topology facility 1-8
facility indication 4-76
conflict
transactional execution 5-91
conflict token
in the transaction diagnostic block 5-96
connective
See logical connective
consistency (storage operand) 5-123
examples A-49, A-51
console device 12-1
console integration 1-28
constrained transaction
transactional execution 5-91
constrained transactional-execution facility
facility indication 4-77
constrained-transactional-execution facility 1-8
constrained transaction-execution mode
transactional execution 5-91
contraction 4-64
control 4-1
instructions 10-1
manual
See manual operation
control-program compatibility 1-31
control register 2-6, 4-7
save areas for 3-75
validity bit 11-20
control-register assignment 4-8
(CRx.y indicates control register x, bit position y)
CR0.15:
See (SA23-2260)
CR0.33:
SSM-suppression-control bit 6-36, 10-129
CR0.34:
TOD-clock-sync-control bit 4-42, 4-47
CR0.35:
low-address-protection-control bit 3-14
CR0.36:
extraction-authority-control bit 5-29
CR0.37:
secondary-space-control bit 3-38, 5-29
CR0.38:
fetched-protection-override-control bit 3-12
CR0.39:
storage-protection-override-control bit 3-12
CR0.40:
enhanced-DAT-enablement-control bit 3-38
CR0.44:
ASN-and-LX-reuse-control bit 3-22
CR0.45:
AFP-register-control bit 9-11
CR0.48:
malfunction-alert subclass-mask bit 6-13
CR0.49:
emergency-signal subclass-mask bit 6-12
CR0.50:
external-call subclass-mask bit 6-12
CR0.52:
clock-comparator subclass-mask bit 6-12
CR0.53:
CPU-timer subclass-mask bit 6-12
CR0.54:
service-signal subclass-mask bit 6-13
CR0.57:
interrupt-key subclass-mask bit 6-13
CR0.58:
See (SA23-2260)
CR0.59:
timing-alert subclass-mask bit 6-13
CR0.61:
crypto-control bit 6-23
CR0.8:
transactional-execution control 5-93
CR0.9:
transactional-execution program-interruption-filtering override 5-93

CR1:
primary address-space-control element (PASCE) 3-39
CR1.0-51:
primary real-space token origin (PRSTKO) 3-41
primary region-table origin (PRTO) 3-39
primary segment-table origin (PSTO) 3-39
CR1.54:
primary subspace-group-control bit 3-39
CR1.55:
primary private-space-control bit 3-39
CR1.56:
primary storage-alteration-event-control bit 3-40
CR1.57:
primary space-switch-event-control bit 3-40, 6-35
CR1.58:
primary real-space-control bit 3-40
CR1.60-61:
primary designation-type-control bits 3-41
CR1.62-63:
primary region-table length (PRTL) 3-41
primary segment-table length (PSTL) 3-41
CR2.33-57:
dispatchable-unit-control-table origin (DUCTO) 5-54
CR2.61:
transaction-diagnostic-scope control 5-93
CR2.62-63:
transaction-diagnostic control 5-93
CR3.0-31:
secondary ASTEIN (SASTEIN) 3-23
CR3.32-47:
PSW-key mask (PKM) 5-29
CR3.48-63:
secondary ASN (SASN) 3-21
CR4.0-31:
primary ASTEIN (PASTEIN) 3-23
CR4.32-47:
authorization index (AX) 3-32, 5-30
CR4.48-63:
primary ASN (PASN) 3-21
CR5.33-57:
primary-AST-entry origin (PASTE0) 5-35, 5-55
CR6.32-39:
I/O-interruption subclass mask 6-15
CR7:
secondary address-space-control element (SASCE) 3-41
CR7.0-51:
control unit defer time interval (in measurement block) 17-6
control-unit-queuing measurement (I/O) 17-9
control-unit-queuing-time interval (in measurement block) 17-5
controlled-ASN bit 3-22
conversion
  between HFP and BFP data 9-27
  binary-to-decimal 7-189
    example A-19
  decimal-to-binary 7-188
    example A-18
  hexadecimal-floating-point-number
    basic example A-6
    examples with instructions A-44
  of floating-point format 9-23, 19-5
CONVERT BFP TO HFP floating-point-support instructions 9-27
CONVERT FROM FIXED BFP instructions 19-19, 19-22, 19-33
CONVERT FROM FIXED DFP instructions 20-23
CONVERT FROM FIXED HFP instructions 18-11
CONVERT FROM LOGICAL DFP instructions 20-24
CONVERT FROM SIGNED PACKED DFP
  instructions 20-27
CONVERT FROM UNSIGNED PACKED DFP
  instructions 20-27
CONVERT HFP TO BFP floating-point-support instructions 9-28
CONVERT TO BINARY instruction
  example A-18
CONVERT TO BINARY instructions 7-188
CONVERT TO DECIMAL instruction
  example A-19
CONVERT TO DECIMAL instructions 7-189
CONVERT TO FIXED BFP instructions 19-22, 19-25
CONVERT TO FIXED DFP instructions 20-28
CONVERT TO FIXED HFP instructions 18-11
CONVERT TO LOGICAL DFP instructions 20-31
CONVERT TO SIGNED PACKED DFP instructions 20-34
CONVERT TO UNSIGNED PACKED DFP
  instructions 20-34
CONVERT UNICODE TO UTF-8 instruction 7-193
CONVERT UTF-16 TO UTF-32 instruction 7-190
CONVERT UTF-16 TO UTF-8 instruction 7-193
CONVERT UTF-32 TO UTF-16 instruction 7-196
CONVERT UTF-32 TO UTF-8 instruction 7-199
CONVERT UTF-8 TO UNICODE instruction 7-202
CONVERT UTF-8 TO UTF-16 instruction 7-202
CONVERT UTF-8 TO UTF-32 instruction 7-206

Coordinated Universal Time (UTC) used in TOD epoch 4-45
COPY ACCESS instruction 7-210
COPY SIGN floating-point-support instruction 9-30
  core identification (ID) 2-3, 4-63, 4-64, 12-3, 12-7
  multithreading 2-3
count field
  in CCW 15-33
    invalid 16-25
  in SCSW 16-31, 16-44
counter updating (example) A-47
counting operations 7-38
coupling facility 1-29
CP (COMPARE DECIMAL) instruction 8-7
  example A-36
CPA
  See channel-program address
CPDT (CONVERT TO PACKED) instruction 20-32
CPSDR (COPY SIGN) floating-point-support instruction 9-30
CPU (central processing unit) 2-2
  address 4-63, 4-64
    assigned storage locations for 3-69
    when stored during external interruptions 6-10
  architected register context 2-3, 4-70
  checkpoint 11-2
  effect of power-on reset on 4-61
  hangup due to string of interruptions 4-3
  identification (ID) 10-132
  machine-type number 10-132
  model number 10-132
  registers 2-3
    save areas for 3-74
  reset 4-58
    signal-processor order 4-65
  retry 11-2
  serialization 5-128
    effects of transactional execution 5-128
  signaling 4-64
  state 4-2
    check-stop 4-3
    load 4-3
    no effect on TOD clock 4-41
    operating 4-2
    stopped 4-2
  types 2-3
    primary 2-3, 4-61, 12-7
    secondary 2-3
  version code 10-133
CPU-measurement-counter facility
  facility indication 4-77
CPU-measurement-sampling facility
  facility indication 4-77
CPU state 4-2
CPU timer 4-54
  external interruption 6-12
  save areas for 3-75
  validity bit for 11-21
CPUs-per-core
  operator indicator 12-3
CPXT (CONVERT TO PACKED) instruction 20-32
CPYA (COPY ACCESS) instruction 7-210
CR
  See control register
CR (COMPARE) binary instruction 7-117
CRB (COMPARE AND BRANCH) instruction 7-118
CRDTE (COMPARE AND REPLACE DAT TABLE ENTRY) instruction 10-17
CRJ (COMPARE AND BRANCH RELATIVE) instruction 7-118
CRL (COMPARE RELATIVE LONG) binary instruction 7-118
CRT (COMPARE AND TRAP) instruction 7-132
CRW (channel-report word)
  chaining of 17-25, 17-26
  error-recovery code (ERC) in 17-27
  overflow in 17-26
  reporting-source code (RSC) in 17-26
  reporting-source ID (RSID) in 17-27
  solicited 17-26
  storing of 14-17
crypto-operation exception 6-23
cryptographic facility 1-27, 2-7
CS (COMPARE AND SWAP) instruction 7-127
  examples A-46
CSCH (CLEAR SUBCHANNEL) instruction 14-5
CSDTR (CONVERT TO SIGNED PACKED) DFP instruction 20-34
C SG (COMPARE AND SWAP) instruction 7-127
CSP (COMPARE AND SWAP AND PURGE) instruction 10-20
CSPG (COMPARE AND SWAP AND PURGE) instruction 10-20
CSS priority 15-29
CSST (COMPARE AND SWAP AND STORE) instruction 7-129
CSXTR (CONVERT TO SIGNED PACKED) DFP instruction 20-34
CSY (COMPARE AND SWAP) instruction 7-127
CTN configuration change (machine-check condition) 11-22
CU12 (CONVERT UTF-8 TO UTF-16) instruction 7-202
CU14 (CONVERT UTF-8 TO UTF-32) instruction 7-206
CU21 (CONVERT UTF-16 TO UTF-8) instruction 7-193
CU24 (CONVERT UTF-16 TO UTF-32) instruction 7-190
CU41 (CONVERT UTF-32 TO UTF-8) instruction 7-199
CU42 (CONVERT UTF-32 TO UTF-16) instruction 7-196
CUDTR (CONVERT TO UNSIGNED PACKED) DFP instruction 20-34
current CCW 15-31
  See also CCW
  stored during interruption 6-2
CUSE (COMPARE UNTIL SUBSTRING EQUAL) instruction 7-150
CUTFU (CONVERT UTF-8 TO UNICODE) instruction 7-202
CUUTF (CONVERT UNICODE TO UTF-8) instruction 7-193
CUXT (CONVERT UTF-8 TO UTF-32) instruction 7-190
CVB (CONVERT TO BINARY) instruction 7-188
  example A-18
CVBG (CONVERT TO BINARY) instruction 7-188
CVBY (CONVERT TO BINARY) instruction 7-188
CVD (CONVERT TO DECIMAL) instruction 7-189
  example A-19
CVDG (CONVERT TO DECIMAL) instruction 7-189
CVDY (CONVERT TO DECIMAL) instruction 7-189
CXR (COMPARE) BFP instruction 19-17
CXFBR (CONVERT FROM FIXED) BFP instruction 19-19, 19-21
CXFBRA (CONVERT FROM FIXED) BFP instruction 19-19
CXFR (CONVERT FROM FIXED) HFP instruction 18-11
CXFTR (CONVERT FROM FIXED) DFP instruction 20-23
CXGBR (CONVERT FROM FIXED) BFP instruction 19-19, 19-21
CXGBRA (CONVERT FROM FIXED) BFP instruction 19-19
CXGR (CONVERT FROM FIXED) HFP instruction 18-11
CXGTR (CONVERT FROM FIXED) DFP instruction 20-23
CXGTRA (CONVERT FROM FIXED) DFP instruction 20-23
CXLFB (CONVERT FROM LOGICAL) BFP instruction 19-21
CXLFT (CONVERT FROM LOGICAL) DFP instruction 20-24
CXLGBR (CONVERT FROM LOGICAL) BFP instruction 19-21
CXLGTR (CONVERT FROM LOGICAL) DFP instruction 20-24
CXPT (CONVERT FROM PACKED) instruction 20-25
CXR (COMPARE) HFP instruction 18-10
CXSTR (CONVERT FROM SIGNED PACKED) DFP instruction 20-27
CXTR (COMPARE) DFP instruction 20-20
CXUTR (CONVERT FROM UNSIGNED PACKED) DFP instruction 20-27
CY (COMPARE) binary instruction 7-117

D
D (DIVIDE) binary instruction 7-210
example A-19
D field of instruction 5-11
damage
channel-subsystem 11-17
code (external) 11-22
validity bit for 11-20
external 11-16
subclass-mask bit for 11-24
instruction-processing 11-15
processing 11-18
service-processor 11-17
system 11-15
timing-facility 11-15
DAT
See dynamic address translation
DAT-enhancement facility
facility indication 4-76
DAT-enhancement facility 1 1-8
DAT-enhancement facility 2 1-8
DAT mode (bit in PSW)
use in address translation 3-37
DAT mode (bit in the PSW) 4-5
DAT protection 3-13
bit for in page-table entry 3-48
bit for in region-table entry 3-43
bit for in segment-table entry 3-46
DAT-table format error 6-44
data
blocking of (I/O) 15-24
format for
binary-floating-point instructions 19-2
decimal instructions 8-1
decimal-floating-point instructions 20-3
general instructions 7-3
hexadecimal-floating-point instructions 18-2
indirect addressing of (I/O) 13-9, 15-66
measurement (I/O)
See measurement data
modified indirect addressing of (I/O) 15-68
prefetching of for I/O operation 15-59
transport indirect addressing of (I/O) 15-70
data address (I/O)
invalid 16-26
invalid specification of 16-26
data chaining of CCWs 15-61
flag in CCW for 15-32
overview of 13-11
data check
measurement-block 16-48
data exception 6-24
AFP-register 6-24
BFP-instruction 6-24
compare-and-trap-instruction 6-24
DFP-instruction 6-24
general-operand 6-24, 8-4
IEEE-exception 6-24, 9-18
priority of program interruptions for 6-16
simulated IEEE exception 6-24
data exception code
in the transaction diagnostic block 5-97
data-exception code (DXC) 6-16, 20-14
data signaling and quiet NaNs
classes of BFP data 19-4
classes of DFP data 20-7
data streaming (I/O) 13-4
effect of CCW count on 15-63
DCTI (device-connect-time interval)
in ESW 16-54
in extended-measurement word 16-57
in measurement block 17-4
DCW (device-command word)
contents of 15-38
current 15-38
DD (DIVIDE) HFP instruction 18-12
DDB (DIVIDE) BFP instruction 19-27
DDBR (DIVIDE) BFP instruction 19-27
DDR (DIVIDE) HFP instruction 18-12
DDTR (DIVIDE) DFP instruction 20-36
DDTRA (DIVIDE) DFP instruction 20-36
DE (DIVIDE) HFP instruction 18-12
DEB (DIVIDE) BFP instruction 19-27
DEBR (DIVIDE) BFP instruction 19-27
decimal
arithmetic 8-3
comparison 8-7
digit codes 8-2
divide exception 6-25
instructions 8-1
examples A-36
number representation 8-1
examples A-4
operand overlap 8-3
overflow
exception 6-25
mask in PSW 4-6
sign codes 8-2
decimal (DFP)
data formats 20-3
decimal-floating-point
packed-conversion facility 1-9
zoned-conversion facility 1-9
decimal floating point (DFP) 9-4
See also DFP
decimal-floating-point (DFP) facility 20-1
decimal-floating-point (DFP) facility
facility indication 4-77
decimal-floating-point facility 1-8
decimal floating point packed conversion facility
facility indication 4-77
decimal-floating-point packed-conversion facility 1-9
decimal-floating-point-rounding facility 1-9
decimal-floating-point zoned-conversion facility 1-9
facility indication 4-77
decimal-to-binary conversion 7-188
example A-18
decimal-floating-point (DFP)
facility 1-8
rounding facility 1-9
dedicated allegiance 15-13
default QNaN 9-3, 19-4, 20-7
deferred condition code 16-9
degradation (machine-check condition) 11-16
subclass-mask bit for 11-24
degradation, storage (machine-check condition) 11-19
delay in storing 5-121
delayed access exception (machine-check condition) 11-17
deletion of malfunctioning unit 11-5
denormalization rounding 9-12
denormalized value 9-12
DER (DIVIDE) HFP instruction 18-12
examples A-42
derived quantum 20-3
designation
authority-table 3-29
entry-table 5-36, 5-37
home real-space (HRSD) 3-42
home region-table 3-42
home segment-table 3-42
linkage-first-table 5-36
linkage-table 5-35
primary real-space 3-39
primary region-table 3-39
primary segment-table 3-39
real-space 3-39
in AST entry 3-29
used for access-register translation 5-59
used for subspace groups 5-70
region-table 3-39
in AST entry 3-29
used for access-register translation 5-59
used for subspace groups 5-70
secondary real-space 3-41
secondary region-table 3-41
secondary segment-table 3-41
segment-table 3-39
in AST entry 3-29
used for access-register translation 5-59
used for subspace groups 5-70
designation (origin and length)
access-list 5-56
designation-type-control bits
home 3-42
primary 3-40
secondary 3-41
destructive overlap 5-126, 7-246, 7-250, 7-254
in the access-register mode 5-114
device 2-8, 13-5
console 12-1
effect of I/O-system reset on 17-14
device-active bit 16-16, 16-36
device-active-only measurement (I/O) 17-9
device-active-only-time interval (in measurement
block) 17-6
device address 13-6
device-busy time (in extended measurement word) 16-57
device-busy time (in measurement block) 17-6
device-command word
See DCW
device-connect-time interval
See DCTI
device-connect-time measurement 17-10
effect of suspension on 15-75
enable 15-4
device-disconnect-time interval (in measurement
block) 17-5
device identifier 13-6
device number 13-6
assignment of 13-6
in PMCW 15-5
device-number valid (bit in PMCW) 15-4
device status 16-24
field-validity flag for (in subchannel logout) 16-29,
16-49
with inappropriate bit combination 16-50
device status check 16-50
DFP
canonical data 20-6
canonical decls 20-6
classes of DFP data 20-6
data signaling and quiet NaNs 20-7
infinities 20-7
normal numbers 20-7
subnormal numbers 20-6
zero 20-6
cohort 20-2
data class
testing of 20-55
data formats 20-3
combination field 20-4
encoded trailing significand field 20-5
values of finite numbers 20-5
derived quantum 20-3
format conversion 20-7
formatting instructions 20-7
signed-packed-decimal format 20-27, 20-34
unsigned-packed-decimal format 20-27, 20-34
of DFP data
canonicalization 20-7
preferred quantum 20-2, 20-9
quantum 20-2
scaled preferred quantum 20-3
significant digits 20-5
special quantum-handling operations 20-3
DFP (decimal floating point) 9-4
DFP-instruction data exception 6-24
DIAGNOSE instruction 10-22
dictionary
  adaptive 7-160
DIDBR (DIVIDE TO INTEGER) BFP instruction 19-28
DIEBR (DIVIDE TO INTEGER) BFP instruction 19-28
digit codes (decimal) 8-2
digit selector (in EDIT) 8-8
direct-access storage 3-2
disabling for interruptions 6-5
disallowed interruptions 6-5
dispatchable unit (DU) 5-49
  access-list designation (DUALD) 5-56
  control table (DUCT) 5-56
  origin (DUCTO) 5-54
  when subspace-group facility installed 5-67
  when trap facility installed 10-167
displacement (in relative addressing) 5-11
display (manual controls) 12-2
distinct-operands facility 1-9
classification 4-77
DIVIDE BFP instructions 19-27
DIVIDE binary instructions 7-210
example A-19
DIVIDE DECIMAL instruction 8-7
example A-37
DIVIDE DFP instructions 20-36
divide exception
decimal 6-25
fixed-point 6-26
HFP 6-26
DIVIDE HFP instructions 18-12
examples A-42
DIVIDE LOGICAL instructions 7-211
DIVIDE SINGLE binary instructions 7-212
DIVIDE TO INTEGER BFP instructions 19-28
  remainder result of 19-5
divisible instruction execution 5-113
DL (DIVIDE LOGICAL) instruction 7-211
DLP (DIVIDE LOGICAL) binary instruction 7-211
DLPFR (DIVIDE LOGICAL) binary instruction 7-211
DLR (DIVIDE LOGICAL) instruction 7-211
doubleword 3-3
doubleword-concurrent storage references 5-124
DP (DIVIDE DECIMAL) instruction 8-7
example A-37
DR (DIVIDE) binary instruction 7-210
DSG (DIVIDE SINGLE) binary instruction 7-212
DSGF (DIVIDE SINGLE) binary instruction 7-212
DSGR (DIVIDE SINGLE) binary instruction 7-212
DU (dispatchable unit) 5-49
DUALD (dispatchable-unit access-list designation) 5-56
DUCT (dispatchable-unit control table) 5-56, 5-67
DUCTO (dispatchable-unit-control-table origin) 5-54
dump (standalone) 12-5
DXBR (DIVIDE) BFP instruction 19-27
DXC (data-exception code) 6-16, 19-10, 20-14
  summary figures 6-16, 6-17
DXR (DIVIDE) HFP instruction 18-12
DXTRA (DIVIDE) DFP instruction 20-36
dynamic address translation (DAT) 3-35
  by LOAD REAL ADDRESS instruction 10-54
  by STORE REAL ADDRESS instruction 10-134
control of 3-37
  explicit and implicit 3-48
  mode bit in PSW
    use in address translation 3-37
    mode bit in the PSW 4-5
  sequence of table fetches 5-117
dynamic-reconnection feature 13-3

E
E (exa) xxvi
E instruction format 5-6
EAR (EXTRACT ACCESS) instruction 7-215
early exception recognition 6-9
EAX
See extended authorization index
EBCDIC (Extended Binary-Coded-Decimal Interchange Code)
architecture designed for xxvii
character code
table for 1-2
ECAG (EXTRACT CPU ATTRIBUTE) instruction 7-215
ECC (error checking and correction) 11-2
ECTG (EXTRACT CPU TIME) instruction 7-217
ECW (extended-control word) 16-56
indication in SCSW 16-12
ED (EDIT) instruction 8-8
examples A-37
EDIT AND MARK instruction 8-11
example A-38
EDIT instruction 8-8
examples A-37
editing instructions 8-4
See also ED instruction, EDMK instruction
EDMK (EDIT AND MARK) instruction 8-11
example A-38
EEDTR (EXTRACT BIASED EXPONENT) DFP instruction 20-38
EEXTR (EXTRACT BIASED EXPONENT) DFP instruction 20-38
effective access-list designation 5-56
effective address 3-5
controlled by addressing mode 5-10
generation 5-10
used for storage interlocks 5-113
effective address-space-control element 3-49
EFPC (EXTRACT FPC) floating-point-support instruction 9-30
EKM (entry key mask) 5-38
emergency signal (external interruption) 6-12
signal-processor order 4-65
EMIF (ESCON-multiple-image facility) 1-28
EMW (extended-measurement word) 16-56
in IRB 16-56
enabled (bit for TRAP) 10-168
enabled (bit in PMCW) 15-3
enabling for interruptions 6-5
subchannel 16-6
enabling of subchannel 15-3, 16-6
encoded trailing significand field
in DFP data format 20-5
endian 7-243, 7-337
ending of instruction execution 5-22
enhanced-DAT facility 1-10
and change-bit override 3-10
and DAT protection 3-14
and format-control in R3TE 3-16
and format-control in STE 3-10, 3-16
enhanced-DAT facility 1 1-9
facility indication 4-76
enhanced-DAT facility 2
facility indication 4-77
enhanced-monitor facility 1-10
counter-array origin 5-110
counter-array size 5-110
exception count 5-110
facility indication 4-77
monitor masks 5-110
enhanced-monitor masks 4-9
enhanced-DAT-enablement control
and enhanced-DAT applicability 3-39
and the P bit in RTEs 3-44
definition 3-38
in control register 0 4-8
Enterprise Systems Connection Architecture
(ESCON) I/O interface
publication referenced xxvii
entry
tended authorization index 5-77
key 5-77
entry (for tracing) 4-12
entry descriptor 5-80
entry index (EX) 5-34
entry key mask (EKM) 5-38
entry table (ET)
designation 5-36, 5-37
length (ETL) 5-36, 5-37
origin (ETO) 5-36, 5-37
tentry-table entry (ETE) 5-37, 5-76
tentry-type code 5-80
EPAIR (EXTRACT PRIMARY ASN AND INSTANCE) instruction 10-23
EPAR (EXTRACT PRIMARY ASN) instruction 10-23
epoch (for TOD clock) 4-45
EPSW (EXTRACT PSW) instruction 7-218
equipment check
in signal-processor status 4-73
ERC (error-recovery code) 17-27
See also CRW
EREG (EXTRACT STACKED REGISTERS) instruction 10-25
EREGG (EXTRACT STACKED REGISTERS) instruction 10-25
error
checking and correction 11-2
from DIAGNOSE instruction 10-23
I/O-error alert 16-50
indirect storage 11-19
intermittent 11-6
PSW-format 6-9
secondary (I/O) 16-50
solid 11-6
state of TOD clock 4-42
storage 11-18
storage-key 11-19
error-recovery code (ERC) 17-27
See also CRW
ERW (extended-report word) 16-47, 16-51
as result of channel-control check 16-29, 16-43
as result of channel-data check 16-28, 16-42,
16-43
ESA/370 architecture 1-29
ESA/390
compatibility with z/Architecture 1-31
ESA/390 architecture
architectural-mode controls 12-3
ESAIR (EXTRACT SECONDARY ASN AND
INSTANCE) instruction 10-24
ESAR (EXTRACT SECONDARY ASN) instruction
10-24
ESCON (Enterprise Systems Connection
Architecture) 13-3
ESCON (Enterprise Systems Connection
Architecture) I/O interface
publication referenced xxvii
ESCON channel-to-channel adapter
publication referenced xxvii
ESCON-multiple-image facility (EMIF) 1-28
ESDTR (EXTRACT SIGNIFICANCE) DFP instruction
20-38
ESEA (EXTRACT AND SET EXTENDED
AUTHORITY) instruction 10-23
ESTA (EXTRACT STACKED STATE) instruction
10-26
ESW (extended-status word) 16-47
See also extended status
ESW format bit (in SCSW) 16-9
ESXTR (EXTRACT SIGNIFICANCE) DFP instruction
20-38
ET
See entry table
ETE
See entry-table entry
ETF2-enhancement facility 1-11
facility indication 4-76
ETF3-enhancement facility 1-11
facility indication 4-76
ETL (entry-table length) 5-36, 5-37
ETND (EXTRACT TRANSACTION NESTING
DEPTH) instruction 7-218
ETO (entry-table origin) 5-36, 5-37
ETR (external time reference) 2-7
ETR (external time reference) facility 1-28
ETR sync check (machine-check condition) 11-22
ETR-timing-alert condition
See timing alert
event 6-15
monitor 7-243
PER 4-23
space-switch 6-35
transactional-execution aborted 6-44
EX (entry index) 5-34
translation exception 6-25
EX (EXECUTE)
See EXECUTE instruction
EX-translation exception 6-25
exception access identification 3-69
in the transaction diagnostic block 5-97
exceptions 6-15
access (collective program-interruption name)
6-45, 6-51
addressing 6-19
AFX-translation 6-20
ALE-sequence 6-21
ALEN-translation 6-21
ALET-specification 6-21
ASCE-type 6-21
ASN-translation (collective program-interruption
name) 6-53
associated with
ART 5-65
stacking process 5-87
unstacking process 5-90
ASTE-instance 6-22
ASTE-sequence 6-22
ASTE-validity 6-23
ASX-validity 6-23
crypto-operation 6-23
data 6-24
decimal-divide 6-25
decimal-overflow 6-25
delayed access (machine-check condition) 11-17
during translation 3-58
EX-translation 6-25
extended-authority 6-26
fixed-point-divide 6-26
fixed-point-overflow 6-26
HFP-divide 6-26
HFP-exponent-overflow 6-27
HFP-exponent-underflow 6-27
HFP-significance 6-27
HFP-square-root 6-27
IEEE 9-18
LFX-translation 6-27
LSTE-sequence 6-28
LSX-translation 6-28
LX-translation 6-28
extended-translation facility 2 1-12
  facility indication 4-76
extended-translation facility 3 1-12
  facility indication 4-76
external call
  external interruption 6-12
  pending (signal-processor status) 4-74
  signal-processor order 4-65
external damage 11-16
  subclass-mask bit for 11-24
external-damage code 11-22
  assigned storage locations for 3-73
  validity bit for 11-20
external interruption 6-10
  clock-comparator 6-11, 4-53
  CPU-timer 4-54, 6-12
  direct conditions 6-10
  emergency-signal 6-12
  external-call 6-12
  interrupt-key 6-12
  malfunction-alert 6-13
  mask in the PSW 4-5
  measurement-alert 6-13
  parameter 6-10
    assigned storage locations for 3-68
    pending conditions 6-10
    priority of conditions 6-11
    service-signal 6-13
    timing-alert 6-13
external time reference (ETR) 2-7
external-time-reference (ETR) facility 1-28
externally initiated functions 4-55
I/O 17-16
EXTRACT ACCESS instruction 7-215
EXTRACT AND SET EXTENDED AUTHORITY instruction 10-23
EXTRACT BIASED EXPONENT DFP instructions 20-38
EXTRACT CPU ATTRIBUTE instruction 7-215
extract-CPU-time facility 1-13, 7-218
  facility indication 4-76
EXTRACT CPU TIME instruction 7-217
EXTRACT FPC floating-point-support instruction 9-30
EXTRACT PRIMARY ASN AND INSTANCE instruction 10-23
EXTRACT PRIMARY ASN instruction 10-23
EXTRACT PSW instruction 7-218
EXTRACT SECONDARY ASN AND INSTANCE instruction 10-24
EXTRACT SECONDARY ASN instruction 10-24
EXTRACT SIGNIFICANCE DFP instructions 20-38
EXTRACT STACKED REGISTERS instruction 10-25
EXTRACT STACKED STATE instruction 10-26

EXTRACT TRANSACTION NESTING DEPTH
  instruction 7-218
extraction-authority-control bit 5-29

F
  facility indication
    access-exception-fetch/store-indication facility 4-77
    ASN-and-LX-reuse facility 4-76
    CMPSC-enhancement facility 4-77
    compare-and-swap-and-store facility 4-76
    compare-and-swap-and-store facility 2 4-76
    conditional-SSKE facility 4-76
    configuration-topology facility 4-76
    constrained transactional-execution facility 4-77
    CPU-measurement-counter facility 4-77
    CPU-measurement-sampling facility 4-77
    DAT-enhancement facility 4-76
decimal-floating-point facility 4-77
decimal-floating-point high-performance 4-77
decimal-floating-point packed-conversion facility 4-77
decimal-floating-point zoned-conversion facility 4-77
distinct-operands facility 4-77
  enhanced-DAT facility 1 4-76
  enhanced-DAT facility 2 4-77
  enhanced-monitor facility 4-77
  ETF2-enhancement facility 4-76
  ETF3-enhancement facility 4-76
  execute-extensions facility 4-77
  execution-hint facility 4-77
  extended-immediate facility 4-76
  extended-translation facility 2 4-76
  extended-translation facility 3 4-76
  extract-CPU-time facility 4-76
  fast-BCR-serialization facility 4-77
  floating-point-extension facility 4-77
  floating-point-extension facility 4-77
  floating-point-support-enhancement facilities 4-77
  general-instructions-extension facility 4-76
  HFP-multiply-and-add/subtract facility 4-76
  HFP-unnormalized-extension facility 4-76
  high-word facility 4-77
  interlocked-access facility 1 4-77
  interlocked-access facility 2 4-77
  IPTE-range facility 4-76
  load-and-trap facility 4-77
  load-and-zero-rightmost-byte facility 4-77
  load/store-on-condition facility 1 4-77
  local-TLB-clearing facility 4-77
  long-displacement facility 4-76
  long-displacement-facility high-performance 4-76
message-security-assist extension 3 4-77
message-security-assist extension 4 4-77
message-security-assist extension 5 4-77
message-security assist 4-76
miscellaneous-instruction-extensions facility 4-77
move-with-optional-specifications facility 4-76
nonquiescing key-setting facility 4-76
parsing-enhancement facility 4-77
PFPO facility 4-77
population-count facility 4-77
processor-assist facility 4-77
reset-reference-bits-multiple facility 4-77
sense-running-status facility 4-76
set-program-parameters facility 4-77
store-clock-fast facility 4-76
store-CPU-counter-multiple facility 4-78
store-facility-list-extended facility 4-76
store-hypervisor-information facility 4-77
TOD-clock-steering facility 4-76
transactional-execution facility 4-77
vector facility for z/Architecture 4-78
z/architecture active 4-76
z/architecture installed 4-76
z/architecture instructions in ESA/390 mode 4-76
facility indications 4-75
failing-storage address 11-23
assigned storage locations for 3-73
in ESW 16-47, 16-53
as result of channel-control check 16-29, 16-43
as result of channel-data check 16-28, 16-42, 16-43
validity bit for 11-20
validity flag for (in ERW) 16-52
failing-storage-address format
indicator for (in ERW) 16-53
fast-BCR-serialization facility 1-13
facility indication 4-77
FCX-bidirectional-data-transfer facility 1-13
FCX facility 1-13
fetch-only bit 5-57
fetch protection 3-11
bit in segment-table entry 3-43, 3-46
bit in storage key 3-9
override-control bit 3-12
fetch reference 5-121
access exceptions for 6-48
fetching
handling of invalid CBC in storage during 11-8
of ART-table and DAT-table entries 5-117
of instructions 5-116
of PSWs during interruptions 5-127
of storage operands 5-121
Fibre-Channel Extensions 13-6
fibre-channel-extensions facility 1-13
FICON I/O interface
publication referenced xxvii
FIDBR (LOAD FP INTEGER) BFP instruction 19-32
FIDBRA (LOAD FP INTEGER) BFP instruction 19-32
FIDR (LOAD FP INTEGER) HFP instruction 18-15
FIDTR (LOAD FP INTEGER) DFP instruction 20-41
FIEBR (LOAD FP INTEGER) BFP instruction 19-32
FIEBRA (LOAD FP INTEGER) BFP instruction 19-32
field 3-3
field separator (in EDIT) 8-8
field-validity flags (in subchannel logout) 16-49
relation to channel-control check of 16-29
FIER (LOAD FP INTEGER) HFP instruction 18-15
FIFO (first in first out) queuing
example for lock and unlock A-49
fill byte (in EDIT) 8-8
filtering
of program interruptions 5-104
FIND LEFTMOST ONE instruction 7-219
example A-22
FIXBR (LOAD FP INTEGER) BFP instruction 19-32
FIXBRA (LOAD FP INTEGER) BFP instruction 19-32
fixed-length field 3-3
fixed logout
assigned storage locations for 3-74
machine-check 11-25
fixed point
See also binary
divide exception 6-26
overflow exception 6-26
mask in PSW 4-6
See also binary
FIXR (LOAD FP INTEGER) HFP instruction 18-15
FIXTR (LOAD FP INTEGER) DFP instruction 20-41
flags
for IEEE exceptions 9-10
in the transaction diagnostic block 5-96
floating interruption conditions 6-6, 11-23
clearing of 4-60
floating point
See also exponent
binary (BFP) 9-4
binary data format 19-2
conversion
between formats 9-23, 19-5
conversion from binary integer 18-11, 19-19, 20-23
conversion from unsigned binary integer 19-21, 20-24
conversion to binary integer 18-11, 19-22, 20-28
conversion to unsigned binary integer 19-25, 20-31
data
  lengthening format of 18-15, 19-33, 20-44
  shortening format of 18-17, 19-35, 20-45
data class 19-4
decimal (DFP) 9-4
hexadecimal (HFP) 9-3
hexadecimal data formats 18-2
instructions 9-2
numbers 19-2
registers 2-4, 9-8
  clearing of 9-35
  save areas for 3-74
  validity bit for 11-20
shifting
  See normalization
floating-point-control (FPC) register 9-9
  save area for 3-75
  validity bit for 11-21
floating-point extension facility 1-13
floating-point-extension facility
  facility indication 4-77
floating-point-support-enhancement facilities
  facility indication 4-77
floating-point-support-sign-handling facility 1-14
FLOGR (FIND LEFTMOST ONE) instruction 7-219
  example A-22
format
  address 3-3
  binary-floating-point data 19-2
  CCW
    See CCW format control
decimal data 8-1
error
  in DAT-table entry 6-44
  in PSW 6-9
general data 7-3
  in the transaction diagnostic block 5-95
  information 3-2
  instruction 5-3
PSW 4-5
format-0 and format-1 CCWs 15-31
format-2-IDAWS control 15-27
format-1-sibling-descriptor bit 7-156
formats
  hexadecimal-floating-point data 18-2
  forward section header address 5-82
  forward-section validity bit 5-82
FPC
  See floating-point-control (FPC) register
FPC (floating-point-control) register 9-9
FPR-GR-transfer facility 1-14
fraction 18-1
fraction view of floating-point numbers 9-2
free-pool manipulation
  programming example A-50
freeze 7-160
fullword
  See word
function control (I/O) 16-13
function-pending time 17-2
  in extended-measurement word 16-57
functionally-constrained rounding 9-12
functionally-rounded value 9-12
function-pending time
  in measurement block 17-5

G
G (giga) xxvi
  general instructions 7-3
    examples A-7
general-instructions-extension facility 1-14
  facility indication 4-76
general-operand data exception 6-24, 8-4
general register
  save areas 3-74
  general registers 2-4
    validity bit for 11-20
  glue module 5-21
GMT (Greenwich Mean Time) obsolete term for UTC
  4-45
Greenwich Mean Time (GMT) obsolete term for
  Coordinated Universal Time 4-45
guard digit 18-4

H
halfword 3-3
halfword-concurrent storage references 5-124
halt function 15-16
  bit in SCSW for 16-13
  completion of 15-17
  initiated by HALT SUBCHANNEL 14-6
  path management for 15-16
  pending 16-16
  signaling for 15-17
halt signal 17-12
  issued as part of halt function 15-17
HALT SUBCHANNEL instruction 14-6
  See also halt function
effect on SCSW count field 15-19
  function initiated by 15-16
  use of after RESET CHANNEL PATH 14-10
HALVE HFP instructions 18-13
  example A-43
HASCE (home address-space-control element) 3-41
HDR (HALVE) HFP instruction 18-13
  example A-43
HER (HALVE) HFP instruction 18-13
hex
See hexadecimal
hexadecimal (hex) representation 5-7
hexadecimal floating point
conversion
e examples with instructions A-44
instructions
e xamples A-41
hexadecimal floating point (HFP) 9-3
conversion
basic example A-6
hexadecimal-floating-point number
e examples A-5
HFP (hexadecimal floating point) 9-3
HFP data 18-2
conversion of 9-27
HFP exponent
overflow
exception 6-27
underflow
exception 6-27
HFP-multiply-and-add/subtract facility 1-15
facility indication 4-76
HFP significance
exception 6-27
HFP square root
exception 6-27
HFP-unnormalized-extension facility 1-15
facility indication 4-76
HFP-unnormalized-extensions facility 1-15
high-speed data transfer (I/O) 13-15
high-word facility 1-15
facility indication 4-77
home address space 3-20, 5-45
facilities 5-45
home designation-type-control bits 3-42
home private-space-control bit 3-42
home real-space-control bit 3-42
home real-space token origin (HRSTKO) 3-42
home region table
designation (HRTD) 3-42
length (HRTL) 3-42
origin (HROTO) 3-42
home segment table
designation (HSTD) 3-42
length (HSTL) 3-42
origin (HSTO) 3-42
home-space mode 3-37
home space-switch-event-control bit 3-42
home storage-alteration-event-control bit 3-42
home virtual address 3-5
effective address-space-control element for 3-49
HRSD (home real-space designation) 3-42
HRTD (home region-table designation) 3-42
HRTL (home region-table length) 3-42
HRTO (home region-table origin) 3-42
HSCH (HALT SUBCHANNEL) instruction 14-6
HSTD (home segment-table designation) 3-42
HSTL (home segment-table length) 3-42
HSTO (home segment-table origin) 3-42

I
I field of instruction 5-8
I instruction format 5-6
I/O (input/output) 2-7
 basic functions of 15-1
 blocking of data for 15-24
 effect on CPU timer 4-54
 sense data
 See sense data
 support functions of 17-1
I/O addressing 13-5
I/O-command words
CCW 13-7
DCW 13-7
I/O commands
See also commands
publication referenced xxvii
I/O device
See device
I/O-error alert (in subchannel logout) 16-50
I/O instructions 14-2
 deferred condition code for 16-9
 operand access by 14-2
 role of in I/O operations 13-8
I/O interface
ESCON publication referenced xxvii
OEMI publication referenced xxvii
I/O interruption 6-14, 16-1
See also interruption
action for 16-6
mask in the PSW 4-5
masking of 13-12
priority of 16-5
program-controlled interruption
See PCI
I/O-interruption code 6-15
 interruption-identification word in 14-20
stored by TPI 14-20
I/O-interruption condition 13-12, 16-2
alert 16-5
intermediate 16-4
primary 13-10, 16-4
secondary 13-10, 16-5
solicited 16-3
unsolicited 16-3
I/O-interruption-identification word 14-20
assigned storage locations for 3-72
I/O-interruption parameter
assigned storage locations for 3-72
in I/O-interruption code 14-20
in ORB 15-25
in PMCW 15-2
used for IPL 17-17
I/O-interruption request
  clearing of 13-12
  from subchannels 16-6
I/O-interruption subclass 13-12
I/O-interruption subclass code
  See ISC
I/O-interruption subclass mask 6-15, 16-6
  relation to priority 16-5
I/O operations 13-8
  conclusion of
    See conclusion of I/O operations
  initiated indication for 16-12
  termination of
    See conclusion of I/O operations
I/O-system reset 17-13
  as part of subsystem reset 4-60
IAC (INSERT ADDRESS SPACE CONTROL) instruction 10-28
IC (INSERT CHARACTER) instruction 7-219
IC (instruction counter) See instruction address
ICM (INSERT CHARACTERS UNDER MASK) instruction 7-220
  examples A-23
ICMH (INSERT CHARACTERS UNDER MASK) instruction 7-220
ICMY (INSERT CHARACTERS UNDER MASK) instruction 7-220
ICY (INSERT CHARACTER) instruction 7-219
ID
  See CPU identification, sense ID
IDA (indirect-data address) 15-66
  flag in CCW 15-32
IDAW (indirect-data-address word) 15-66
  check (in subchannel logout) 16-48
  invalid address of 16-25
  invalid address specification in 16-25
  invalid address specification of 16-26
idle state for subchannel 16-14
IDTE (INVALIDATE DAT TABLE ENTRY) instruction 10-31
IEDTR (INSERT BIASED EXPONENT) DFP instruction 20-39
IEEE exception conditions
  summary figure 19-10, 24-2
IEEE-exception data exception 6-24, 9-18
IEEE-exception-simulation facility 1-16
IEEE rounding 9-13
IEEE standard 1-26
IEEE trap action and nontrap action 9-18
IEEE-exception data exception 19-10, 24-2
IEEXTR (INSERT BIASED EXPONENT) DFP instruction 20-39
IFCC (interface-control check) 16-29
IIHF (INSERT IMMEDIATE) instruction 7-221
IIHH (INSERT IMMEDIATE) instruction 7-221
IIHL (INSERT IMMEDIATE) instruction 7-221
IIIL (INSERT IMMEDIATE) instruction 7-221
IIIIH (INSERT IMMEDIATE) instruction 7-221
IIIL (INSERT IMMEDIATE) instruction 7-221
ILC (instruction-length code) 6-6
  assigned storage locations for 3-69
  for program interruptions 6-15
IML (initial machine loading) controls 12-3
  immediate operand 5-8
  immediate operation
    SLI flag in CCW for 15-60
    implicit address translation 3-48
    in DFP data 20-5
    incorrect length (subchannel status) 16-24, 16-39
      for immediate operations 15-60
    incorrect-length-indication mode 15-28
    incorrect-length-indication-suppression facility 17-23
      effect on immediate operation 15-60
    incorrect-length-suppression mode 15-28
    incorrect state (signal-processor status) 4-73
    index
      for address generation 5-11
      instructions for branching on 7-39
        into access list 5-55
        into ASN first and second tables 3-27
        into authority table 5-30
        into entry and linkage tables 5-34
        register for 2-4
    indicator
      check-stop 12-3
      CPUs-per-core 12-3
      load 12-3
      manual 12-4
      mode 12-2
      test 12-6
      wait 12-6
    indirect-data address
      See IDA
    indirect-data-address word
      See IDAW
    indirect storage error 11-19
    infinities 9-2, 19-4
      classes of DFP data 20-7
    information format 3-2
    initial-command-response measurement (I/O) 17-9
initial-command-response time (in measurement block) 17-6
initial CPU reset 4-59
  signal-processor order 4-65
initial-machine-loading (IML) controls 12-3
initial program loading
  See IPL
initial-status-interruption control 15-27, 16-12
  relation to Z bit 16-12
  used for IPL 17-17
inoperative (signal-processor status) 4-74
input/output
  See I/O
INSERT ADDRESS SPACE CONTROL instruction 10-28
INSERT BIASED EXPONENT DFP instructions 20-39
INSERT CHARACTER instructions 7-219
INSERT CHARACTERS UNDER MASK instruction 7-220
  examples A-23
INSERT IMMEDIATE instructions 7-221
INSERT PROGRAM MASK instruction 7-221
INSERT PSW KEY instruction 10-29
INSERT STORAGE KEY EXTENDED instruction 10-29
INSERT VIRTUAL STORAGE KEY instruction 10-30
installation 2-1
instruction address
  as a type of address 3-5
  handling by DAT 3-37
  in entry-table entry 5-38
  in the PSW 4-6
  validity bit for 11-20
instruction-fetching-nullification-event mask 4-24
instruction format 5-6
instruction-length code
  preserved by BRANCH AND LINK 5-14, 7-35
  See ILC
instruction-processing damage 11-15
  resulting in processing backup 11-17
  resulting in processing damage 11-18
instructions
  See also instruction lists and page numbers in Appendix B
  backing up of 11-17
  classes of 2-2
  control 10-1
  damage to 11-15, 11-18
  decimal 8-1
    examples A-36
  divisible execution of 5-113
  ending of 5-22
  examples of use A-7
  execution of 5-13
  fetching of 5-116
    access exception for 6-48
    PER event for 4-33
    PER-event mask for 4-24
  floating-point 9-2
    format of 5-3
    general 7-3
    examples A-7
    hexadecimal-floating-point
      examples A-41
I/O
  See I/O Instructions 13-1
interruptible
  See interruptible instructions
  length of 5-7
  list of B-1
  modification by execute-type instruction 7-214
  prefetching of 5-116
  privileged 4-5
    for control 10-1
  See instruction lists and page numbers in Appendix B
  semiprivileged 4-6, 10-2
  sequence of execution of 5-3
  stepping of (rate control) 12-5
    effect on CPU state 4-2
    effect on CPU timer 4-54
  unprivileged 4-5, 7-3
integer
  binary 7-4
    address as 5-11
    conversion from floating point 18-11, 19-22,
      19-25, 20-28, 20-31
    conversion to floating point 18-11, 19-19,
      20-23, 20-24
    examples A-2
  decimal 8-3
  unsigned binary
    conversion to floating point 19-21
integer quotient 19-28
integral boundary 3-3
  octoword 3-3
interface
  ESCON I/O
    publication referenced xxvii
  parallel-I/O
    OEMI publication referenced xxvii
  serial-I/O
    publication referenced xxvii
interface-control check (subchannel status) 16-29
interlocked-access facility 1 1-16
  facility indication 4-77
interlocked-access facility 2 1-16
facility indication 4-77
interlocked-update storage reference 5-121, 5-122
interlocks for virtual storage references 5-113
intermediate interruption condition (I/O) 16-4
intermediate-status bit (I/O) 16-18, 16-36
intermediate values 9-11
interrupt errors 11-6
International Atomic Time (TAI) related to
  Coordinated Universal Time 4-45
interpretive execution
  publication referenced xxvii
interpretive-execution facility 1-29
interrogate TCW
  address of 15-36
interrupt-delay time (in measurement block) 17-6
interrupt key 12-3
  external interruption 6-12
interruptible instructions 5-24
  COMPARE AND FORM CODEWORD 7-120
  COMPARE LOGICAL LONG 7-141
  COMPARE UNTIL SUBSTRING EQUAL 7-152
  MOVE LONG 7-247
  PER event affecting the ending of 4-30
  stopping of 4-2
  TEST BLOCK 10-162
  UPDATE TREE 7-369
interruption 6-2
  See also masks
  action 6-2
    I/O 16-6
    machine-check 11-11
  classes of 6-5
  effect on instruction sequence 5-22
  external
    See external interruption
  I/O
    See I/O interruption
  machine-check
    See machine-check interruption
  masking of 6-5
  pending 6-5
    external 6-10
    machine-check 11-12
  relation to CPU state 4-2
  priority of
    See priority
  program
    See program interruption
  program-controlled (I/O)
    See PCI
  restart 6-54
  string
    See string of interruptions
  supervisor-call 6-54
  interruption code 6-5
  external 6-10
  I/O
    See I/O-interruption code
  machine-check (MCIC) 3-72, 11-14
  program 6-15
  summary of 6-2
  interruption conditions 6-2
    clearing of 4-58
    floating 6-6, 11-23
    I/O
      See I/O-interruption condition
    interruption parameter
      external (assigned storage locations) 3-68
      I/O
        See I/O-interruption parameter
      interruption-response block
        See IRB
    interruption subclass
      See I/O-interruption subclass
  invalid
    access-list entry 5-57
    address 6-19
    bit in ASN-first-table entry 3-28
    bit in ASN-second-table entry 3-29
    bit in linkage-first-table entry 5-37
    bit in linkage-second-table entry 5-37
    bit in linkage-table entry 5-36
    bit in page-table entry 3-48
    bit in region-table entry 3-44
    bit in segment-table entry 3-46
    CBC 11-2
      in registers 11-9
      in storage 11-7
      in storage keys 11-7
      operation code 6-30
      order (signal-processor status) 4-74
      parameter (signal-processor status) 4-73
      translation address 3-58
      translation format
        exception recognition 3-58
  invalid address specification
    in channel-program address 16-25, 16-40
    in IDAW 16-26
    in MIDAW 16-26
    of data in CCW 16-26
    of IDAW 16-25
    of TIC CCW 16-25, 16-40
  invalid CCW field
    command code 16-25
    count 16-25
    data address 16-26
    MIDA flag 16-27
    suspend flag 16-27
invalid format
  of CCW 16-27
  of ORB 16-27
invalid sequence of CCWs 16-27
INVALIDATE DAT TABLE ENTRY instruction 10-31
INVALIDATE PAGE TABLE ENTRY instruction 10-36
  effect of when CPU is stopped 4-2
inverse move
  See MOVE INVERSE instruction, move-inverse facility
IPK (INSERT PSW KEY) instruction 10-29
IPL (initial program loading) 4-61, 17-16
  effect on CPU state 4-3
IPM (INSERT PROGRAM MASK) instruction 7-221
IPTE (INVALIDATE PAGE TABLE ENTRY) instruction 10-36
IPTE-range facility 1-16
  facility indication 4-76
IRB (interruption-response block) 16-6
  See also ECW, ERW, ESW, SCSW storage requirements for 16-13
ISC (I/O-interruption-subclass code) 15-2
  enhanced 14-20
ISKE (INSERT STORAGE KEY EXTENDED) instruction 10-29
isolated state 16-52
IVSK (INSERT VIRTUAL STORAGE KEY) instruction 10-30
key
  key check (in subchannel logout) 16-47
  key-controlled protection 3-11
  exception for 6-32
  key mask
    authorization 5-38
    entry 5-38
    PSW (PKM) 5-29
KIMD (COMPUTE INTERMEDIATE MESSAGE DIGEST) instruction 7-165
KLMD (COMPUTE LAST MESSAGE DIGEST) instruction 7-165
KM (CIPHER MESSAGE) instruction 7-50
KMAC (COMPUTE MESSAGE AUTHENTICATION CODE) instruction 7-178
KMC (CIPHER MESSAGE WITH CHAINING) instruction 7-50
KMCTR (CIPHER MESSAGE WITH COUNTER) instruction 7-90
KMF (CIPHER MESSAGE WITH CIPHER FEEDBACK) instruction 7-75
KMO (CIPHER MESSAGE WITH OUTPUT FEEDBACK) instruction 7-103
KXBR (COMPARE AND SIGNAL) BFP instruction 19-18
KXTR (COMPARE AND SIGNAL) DFP instruction 20-22
L
  L (LOAD) binary instruction 7-221
    example A-23
  L fields of instruction 5-9
  LA (LOAD ADDRESS) instruction 7-223
    examples A-23
  LAA (LOAD AND ADD) instruction 7-225
  LAAG (LOAD AND ADD) instruction 7-225
  LAAL (LOAD AND ADD LOGICAL) instruction 7-225
  LAALG (LOAD AND ADD LOGICAL) instruction 7-225
  LAE (LOAD ADDRESS EXTENDED) instruction 7-223
  LAEy (LOAD ADDRESS EXTENDED) instruction 7-223
  LAM (LOAD ACCESS MULTIPLE) instruction 7-222
  LAMY (LOAD ACCESS MULTIPLE) instruction 7-223
  LAN (LOAD AND AND) instruction 7-226
  LANG (LOAD AND AND) instruction 7-226
  LAO (LOAD AND OR) instruction 7-227
  LAOG (LOAD AND OR) instruction 7-227
  LARL (LOAD ADDRESS RELATIVE LONG) instruction 7-224
  LASP (LOAD ADDRESS SPACE PARAMETERS) instruction 10-39
Last-path-used mask
See LPUM
LAT (LOAD AND TRAP) instruction 7-228
late exception recognition 6-9
LATG (LOAD LOGICAL AND TRAP) instruction 7-228
LATH (LOAD HIGH AND TRAP) instruction 7-233
LAX (LOAD AND EXCLUSIVE OR) instruction 7-226
LAXG (LOAD AND EXCLUSIVE OR) instruction 7-227
LAY (LOAD ADDRESS) instruction 7-223
LB (LOAD BYTE) instruction 7-229
LBH (LOAD BYTE HIGH) instruction 7-229
LBR (LOAD BYTE) binary instruction 7-229
LCCB (LOAD COUNT TO BLOCK BOUNDARY) binary instruction 7-230
LCDBR (LOAD COMPLEMENT) BFP instruction 19-31
LCDFR (LOAD COMPLEMENT) floating-point-support instruction 9-31
LCDR (LOAD COMPLEMENT) HFP instruction 18-14
LCEBR (LOAD COMPLEMENT) BFP instruction 19-31
LCER (LOAD COMPLEMENT) HFP instruction 18-14
LCGFR (LOAD COMPLEMENT) binary instruction 7-230
LCGR (LOAD COMPLEMENT) binary instruction 7-230
LCR (LOAD COMPLEMENT) binary instruction 7-230
LCTL (LOAD CONTROL) instruction 10-49
LCTLG (LOAD CONTROL) instruction 10-49
LCXBR (LOAD COMPLEMENT) BFP instruction 19-31
LCXR (LOAD COMPLEMENT) HFP instruction 18-14
LD (LOAD) floating-point-support instruction 9-31
LDE (LOAD LENGTHENED) HFP instruction 18-15
LDEB (LOAD LENGTHENED) BFP instruction 19-34
LDEBR (LOAD LENGTHENED) BFP instruction 19-33
LDER (LOAD LENGTHENED) HFP instruction 18-15
LDETR (LOAD LENGTHENED) DFP instruction 20-44
LDGR (LOAD FPR FROM GR) floating-point-support instruction 9-34
LDR (LOAD) floating-point-support instruction 9-31
LDBR (LOAD ROUNDED) BFP instruction 19-35
LDBRA (LOAD ROUNDED) BFP instruction 19-35
LDR (LOAD ROUNDED) HFP instruction 18-17
LDR (LOAD ROUNDED) DFP instruction 20-45
left-to-right addressing 3-2
left-units view (LUV) of floating-point numbers 9-2
length field 3-2
instruction 5-7
of BFP data decreasing 19-35
increasing 19-33
of DFP data decreasing 20-45
increasing 20-44
of HFP data decreasing 18-17
increasing 18-15
register-operand 5-7
second operand same as first 5-7
variable (storage operand) 5-9
LER (LOAD) floating-point-support instruction 9-31
LEXBR (LOAD ROUNDED) BFP instruction 19-35
LEXBRA (LOAD ROUNDED) BFP instruction 19-35
LEXR (LOAD ROUNDED) HFP instruction 18-17
LEY (LOAD) floating-point-support instruction 9-31
LFAS (LOAD FPC AND SIGNAL) floating-point-support instruction 9-32
LFH (LOAD HIGH) instruction 7-233
LFPC (LOAD FPC) floating-point-support instruction 9-31
LFT (linkage first table) 5-37
LFTD (linkage-first-table designation) 5-36
LFTL (linkage-first-table length) 5-36
LFTO (linkage-first-table origin) 5-36
LFX (linkage first index)
invalid bit 5-37
translation exception 6-27
LG (LOAD) binary instruction 7-222
LGB (LOAD BYTE) instruction 7-229
LGBR (LOAD BYTE) binary instruction 7-229
LGDR (LOAD GR FROM FPR) floating-point-support instruction 9-34
LG (LOAD) binary instruction 7-222
LGFI (LOAD IMMEDIATE) instruction 7-222
LGFR (LOAD) binary instruction 7-221
LGFRL (LOAD RELATIVE LONG) binary instruction 7-222
LGH (LOAD HALFWORD) instruction 7-231
LGHI (LOAD HALFWORD IMMEDIATE) instruction 7-231
LGHR (LOAD HALFWORD) binary instruction 7-231
LGHRL (LOAD HALFWORD RELATIVE LONG) binary instruction 7-231
LGR (LOAD) binary instruction 7-221
LGRL (LOAD RELATIVE LONG) binary instruction 7-222
LH (LOAD HALFWORD) instruction 7-231
examples A-24
LHH (LOAD HALFWORD HIGH) instruction 7-232
LHI (LOAD HALFWORD IMMEDIATE) instruction 7-231
LHR (LOAD HALFWORD) binary instruction 7-231
LHRL (LOAD HALFWORD RELATIVE LONG) binary instruction 7-231
LHY (LOAD HALFWORD) instruction 7-231
LIFO (last in first out) queuing example for lock and unlock A-48
light
See indicator
limit mode (I/O) 15-3
link information
for BRANCH AND LINK instruction 7-34
for BRANCH AND SAVE AND SET MODE instruction 7-36
for BRANCH AND SAVE instruction 7-35
linkage first table (LFT) 5-37
designation (LFTD) 5-36
length (LFTL) 5-36
origin (LFTO) 5-36
linkage for subroutines 5-14
linkage index (LX) 5-34
linkage second table (LST) 5-37
origin (LSTO) 5-37
linkage stack 5-71, 5-80
associated PER events 5-76
associated trace entries 5-76
branch state entry 10-10
entry address 5-79
entry descriptor 5-80
entry-type code 5-80
handling of information in instructions 5-72
introduction 5-77
next-entry size 5-81
operations 5-77
control 5-79
program-call state entry 10-90
remaining free space 5-80
section 5-77
identification 5-80
state entry 5-82
linkage-stack functions 5-72
linkage table (LT) 5-36
designation (LTD) 5-35
length (LTL) 5-36
origin (LTO) 5-36
list-directed initial-program-load (IPL) function 1-16
list-directed IPL (list-directed initial program loading) 17-19
little endian 7-243, 7-337
LLC (LOAD LOGICAL CHARACTER) instruction 7-234
LLCH (LOAD LOGICAL CHARACTER HIGH) instruction 7-235
LLCR (LOAD LOGICAL CHARACTER) binary instruction 7-234
LLGC (LOAD LOGICAL CHARACTER) instruction 7-234
LLGCR (LOAD LOGICAL CHARACTER) binary instruction 7-234
LLGF (LOAD LOGICAL) instruction 7-233
LLGFR (LOAD LOGICAL) instruction 7-233
LLGFRL (LOAD LOGICAL RELATIVE LONG) binary instruction 7-233
LLGH (LOAD LOGICAL HALFWORD) instruction 7-235
LLGHRL (LOAD LOGICAL RELATIVE LONG) binary instruction 7-235
LLGT (LOAD LOGICAL THIRTY ONE BITS) instruction 7-237
LLGTR (LOAD LOGICAL THIRTY ONE BITS) instruction 7-237
LLH (LOAD LOGICAL HALFWORD) instruction 7-235
LLHH (LOAD LOGICAL HALFWORD HIGH) instruction 7-236
LLHR (LOAD LOGICAL HALFWORD) binary instruction 7-235
LLHRL (LOAD LOGICAL RELATIVE LONG) binary instruction 7-235
LLIHF (LOAD LOGICAL IMMEDIATE) instruction 7-236
LLIHH (LOAD LOGICAL IMMEDIATE) instruction 7-236
LLIHL (LOAD LOGICAL IMMEDIATE) instruction 7-236
LLILF (LOAD LOGICAL IMMEDIATE) instruction 7-236
LLILH (LOAD LOGICAL IMMEDIATE) instruction 7-236
LLILL (LOAD LOGICAL IMMEDIATE) instruction 7-236
LLTG (LOAD AND TRAP) instruction 7-228
LLTGF (LOAD LOGICAL AND TRAP) instruction 7-234
LLTGT (LOAD LOGICAL THIRTY ONE BITS AND TRAP) instruction 7-237
LLZRGF (LOAD LOGICAL AND ZERO RIGHTMOST BYTE) binary instruction 7-234
LM (LOAD MULTIPLE) instruction 7-237
LMD (LOAD MULTIPLE DISJOINT) instruction 7-238
LMG (LOAD MULTIPLE) instruction 7-237
LMH (LOAD MULTIPLE HIGH) instruction 7-238
LMY (LOAD MULTIPLE) instruction 7-237
LNDBR (LOAD NEGATIVE) BFP instruction 19-34
LNDFR (LOAD NEGATIVE) floating-point-support instruction 9-34
LD (LOAD NEGATIVE) HFP instruction 18-16
LNEBR (LOAD NEGATIVE) BFP instruction 19-34
LNER (LOAD NEGATIVE) HFP instruction 18-16
LNGFR (LOAD NEGATIVE) binary instruction 7-239
LNGR (LOAD NEGATIVE) binary instruction 7-239
LNR (LOAD NEGATIVE) binary instruction 7-239
LNXBR (LOAD NEGATIVE) BFP instruction 19-34
LNXR (LOAD NEGATIVE) HFP instruction 18-16
LOAD ACCESS MULTIPLE instructions 7-222
LOAD ADDRESS EXTENDED instruction 7-223
examples A-23
LOAD ADDRESS RELATIVE LONG instruction 7-224
LOAD ADDRESS SPACE PARAMETERS instruction 10-39
LOAD AND ADD instructions 7-225
LOAD AND ADD LOGICAL instructions 7-225
LOAD AND AND instructions 7-226
LOAD AND EXCLUSIVE OR instructions 7-226
LOAD AND OR instructions 7-227
LOAD AND TEST BFP instructions 19-31
LOAD AND TEST bin instruction 7-228
LOAD AND TEST DFP instructions 20-40
LOAD AND TEST HFP instructions 18-13
LOAD AND TRAP binary instructions 7-228
load-and-trap facility 1-16
facility indication 4-77
LOAD AND ZERO RIGHTMOST BYTE binary instructions 7-229
load-and-zero-rightmost-byte facility 1-16
facility indication 4-77
LOAD binary instructions 7-221
element A-23
LOAD BYTE HIGH instruction 7-229
LOAD BYTE instructions 7-229
load-clear key 12-3
load-clear-list-directed key 12-4
LOAD COMPLEMENT BFP instructions 19-31
LOAD COMPLEMENT binary instruction 7-230
LOAD COMPLEMENT floating-point-support instruction 9-31
LOAD COMPLEMENT HFP instructions 18-14
LOAD CONTROL instructions 10-49
LOAD COUNT TO BLOCK BOUNDARY binary instruction 7-230
LOAD floating-point-support instructions 9-31
LOAD FP INTEGER BFP instructions 19-32
LOAD FP INTEGER DFP instructions 20-41
LOAD FP INTEGER HFP instructions 18-15
LOAD FPC AND SIGNAL floating-point-support instruction 9-32
LOAD FPC floating-point-support instruction 9-31
LOAD FPR FROM GR floating-point-support instruction 9-34
LOAD GR FROM FPR floating-point-support instruction 9-34
LOAD HALFWORD binary 7-231
LOAD HALFWORD HIGH IMMEDIATE ON CONDITION binary instruction 7-232
LOAD HALFWORD HIGH instruction 7-232
LOAD HALFWORD IMMEDIATE instruction 7-231
LOAD HALFWORD IMMEDIATE ON CONDITION binary instruction 7-232
LOAD HALFWORD instruction examples A-24
LOAD HALFWORD RELATIVE LONG instructions 7-231
LOAD HIGH AND TRAP instruction 7-233
LOAD HIGH instruction 7-233
LOAD HIGH ON CONDITION instructions 7-239
LOAD IMMEDIATE instruction 7-222
load indicator 12-3
LOAD LENGTHENED BFP instructions 19-33
LOAD LENGTHENED DFP instructions 20-44
LOAD LENGTHENED HFP instructions 18-15
LOAD LOGICAL AND TRAP instruction 7-234
LOAD LOGICAL AND ZERO RIGHTMOST BYTE binary instruction 7-234
LOAD LOGICAL CHARACTER HIGH instruction 7-235
LOAD LOGICAL CHARACTER instructions 7-234
LOAD LOGICAL HALFWORD HIGH instruction 7-236
LOAD LOGICAL HALFWORD instructions 7-235
LOAD LOGICAL HALFWORD RELATIVE LONG instructions 7-235
LOAD LOGICAL IMMEDIATE instructions 7-236
LOAD LOGICAL instructions 7-233
LOAD LOGICAL RELATIVE LONG binary instruction 7-233
LOAD LOGICAL THIRTY ONE BITS AND TRAP instruction 7-237
LOAD LOGICAL THIRTY ONE BITS instructions 7-237
LOAD MULTIPLE DISJOINT instruction 7-237
LOAD MULTIPLE HIGH instruction 7-238
LOAD MULTIPLE instructions 7-237
LOAD NEGATIVE BFP instructions 19-34
LOAD NEGATIVE binary instruction 7-239
LOAD NEGATIVE floating-point-support instruction 9-34
LOAD NEGATIVE HFP instructions 18-16
load-normal key 12-4
LOAD ON CONDITION instructions 7-239
LOAD PAGE-TABLE-ENTRY ADDRESS instruction 10-49
LOAD PAIR DISJOINT instructions 7-241
LOAD PAIR FROM QUADWORD instruction 7-242
LOAD POSITIVE BFP instructions 19-35
LOAD POSITIVE binary instruction 7-242
LOAD POSITIVE floating-point-support instruction 9-34
LOAD POSITIVE HFP instructions 18-16
load state 4-2, 4-3
during CCW-type IPL 4-61
load/store-on-condition facility 1 1-17
facility indication 4-77
load-unit-address controls 12-4
LOAD USING REAL ADDRESS instruction 10-59
load-with-dump key 12-4
LOAD ZERO floating-point-support instructions 9-35
load/store-on-condition facility 2 1-17
loading, initial
See IML, IPL
LOC (LOAD ON CONDITION) instruction 7-239
local-TLB-clearing facility 1-17
facility indication 4-77
location 3-2
not available in configuration 6-19
See also address
LOCFH (LOAD HIGH ON CONDITION) binary instruction 7-239
LOCFHR (LOAD HIGH ON CONDITION) binary instruction 7-239
LOGH (LOAD ON CONDITION) instruction 7-239
LOGH (LOAD HALFWORD HIGH IMMEDIATE ON CONDITION) binary instruction 7-232
LOGHR (LOAD ON CONDITION) instruction 7-239
LOCHHI (LOAD HALFWORD HIGH IMMEDIATE ON CONDITION) binary instruction 7-232
LOCHI (LOAD HALFWORD IMMEDIATE ON CONDITION) binary instruction 7-232
lock A-47
example with FIFO queuing A-49
example with LIFO queuing A-48
lock used by PERFORM LOCKED OPERATION instruction 7-294
LOCR (LOAD ON CONDITION) instruction 7-239
logical
arithmetic (unsigned binary) 7-6
comparison 7-6
connective
AND 7-33, 7-34
EXCLUSIVE OR 7-213, 7-214
OR 7-265, 7-266
data 7-3
logical address 3-5
handling by DAT 3-37
logical-path mask
See LPM
I/O-interruption
See I/O-interruption subclass mask
logical string assist 1-25
logically partitioned (LPAR) mode 1-29, 1-30
logout
fixed
assigned storage locations for 3-74
machine-check 11-25
subchannel (I/O) 16-47
long binary-floating-point number 19-2
long decimal-floating-point number 20-3
long-displacement facility 1-17
facility indication 4-76
long hexadecimal-floating-point number 18-2
long I/O block 16-24, 16-39
loop control 5-14
loop of interruptions
See string of interruptions
low-address protection 3-14
control bit 3-14
exception for 6-33
LPAR (logically partitioned) mode 1-29, 1-30
LPD (LOAD PAIR DISJOINT instructions 7-241
LPDBR (LOAD POSITIVE) BFP instruction 19-35
LPDFR (LOAD POSITIVE) floating-point-support instruction 9-34
LPDG (LOAD PAIR DISJOINT instructions 7-241
LPDR (LOAD POSITIVE) HFP instruction 18-16
LPEBR (LOAD POSITIVE) BFP instruction 19-35
LPER (LOAD POSITIVE) HFP instruction 18-16
LPGR (LOAD POSITIVE) binary instruction 7-242
LPM (logical-path mask) 15-5, 15-28, 15-30
effect on system performance of 15-11
used for IPL 17-17
LPQ (LOAD PAIR FROM QUADWORD) instruction 7-242

X-35
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPR (LOAD POSITIVE) binary instruction</td>
<td>7-242</td>
</tr>
<tr>
<td>LPSW (LOAD PSW) instruction</td>
<td>10-53</td>
</tr>
<tr>
<td>LPSWE (LOAD PSW EXTENDED) instruction</td>
<td>10-53</td>
</tr>
<tr>
<td>LPTEA (LOAD PAGE-TABLE-ENTRY ADDRESS) instruction</td>
<td>10-49</td>
</tr>
<tr>
<td>LPUM (last-path-used mask)</td>
<td>15-6</td>
</tr>
<tr>
<td></td>
<td>in ESW</td>
</tr>
<tr>
<td>LPXBR (LOAD POSITIVE) BFP instruction</td>
<td>19-35</td>
</tr>
<tr>
<td>LPXR (LOAD POSITIVE) HFP instruction</td>
<td>18-16</td>
</tr>
<tr>
<td>LR (LOAD) binary instruction</td>
<td>7-221</td>
</tr>
<tr>
<td>LRA (LOAD REAL ADDRESS) instruction</td>
<td>10-54</td>
</tr>
<tr>
<td>LRAG (LOAD REAL ADDRESS) instruction</td>
<td>10-54</td>
</tr>
<tr>
<td>LRAY (LOAD REAL ADDRESS) instruction</td>
<td>10-54</td>
</tr>
<tr>
<td>LRDR (LOAD ROUNDED) HFP instruction</td>
<td>18-17</td>
</tr>
<tr>
<td>LRER (LOAD ROUNDED) HFP instruction</td>
<td>18-17</td>
</tr>
<tr>
<td>LRL (LOAD RELATIVE LONG) binary instruction</td>
<td>7-222</td>
</tr>
<tr>
<td>LRV (LOAD REVERSED) instruction</td>
<td>7-243</td>
</tr>
<tr>
<td>LRVG (LOAD REVERSED) instruction</td>
<td>7-243</td>
</tr>
<tr>
<td>LRVGR (LOAD REVERSED) instruction</td>
<td>7-243</td>
</tr>
<tr>
<td>LRVH (LOAD REVERSED) instruction</td>
<td>7-243</td>
</tr>
<tr>
<td>LRVRI (LOAD REVERSED) instruction</td>
<td>7-242</td>
</tr>
<tr>
<td>LST (linkage second table)</td>
<td>5-37</td>
</tr>
<tr>
<td>LSTO (linkage-second-table origin)</td>
<td>5-37</td>
</tr>
<tr>
<td>LSX (linkage first index)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>translation exception</td>
</tr>
<tr>
<td></td>
<td>in ESW</td>
</tr>
<tr>
<td></td>
<td>invalid bit</td>
</tr>
<tr>
<td>LT (linkage table)</td>
<td>5-36</td>
</tr>
<tr>
<td>LT (LOAD AND TEST) instruction</td>
<td>7-228</td>
</tr>
<tr>
<td>LTD (linkage-table designation)</td>
<td>5-35</td>
</tr>
<tr>
<td>LTDBR (LOAD AND TEST) BFP instruction</td>
<td>19-31</td>
</tr>
<tr>
<td>LTDTR (LOAD AND TEST) DFP instruction</td>
<td>18-13</td>
</tr>
<tr>
<td>LTG (LOAD AND TEST) instruction</td>
<td>7-228</td>
</tr>
<tr>
<td>LTGF (LOAD AND TEST) binary instruction</td>
<td>7-228</td>
</tr>
<tr>
<td>LTGFR (LOAD AND TEST) binary instruction</td>
<td>7-228</td>
</tr>
<tr>
<td>LTL (linkage-table length)</td>
<td>5-36</td>
</tr>
<tr>
<td>LTO (linkage-table origin)</td>
<td>5-36</td>
</tr>
<tr>
<td>LTR (LOAD AND TEST) binary instruction</td>
<td>7-228</td>
</tr>
<tr>
<td>LTXBR (LOAD AND TEST) BFP instruction</td>
<td>19-31</td>
</tr>
<tr>
<td>LTXR (LOAD AND TEST) HFP instruction</td>
<td>18-14</td>
</tr>
<tr>
<td>LTXTR (LOAD AND TEST) DFP instruction</td>
<td>20-40</td>
</tr>
<tr>
<td>LURA (LOAD USING REAL ADDRESS) instruction</td>
<td>10-59</td>
</tr>
<tr>
<td>LURAG (LOAD USING REAL ADDRESS) instruction</td>
<td>10-59</td>
</tr>
<tr>
<td>LUV (left-units view) of floating-point numbers</td>
<td>9-2</td>
</tr>
<tr>
<td>LX (linkage index)</td>
<td>5-34</td>
</tr>
<tr>
<td></td>
<td>invalid bit</td>
</tr>
<tr>
<td>translation exception</td>
<td>6-28</td>
</tr>
<tr>
<td>LXDB (LOAD LENGTHENED) BFP instruction</td>
<td>19-34</td>
</tr>
<tr>
<td>LXDBR (LOAD LENGTHENED) BFP instruction</td>
<td>19-33</td>
</tr>
<tr>
<td>LXDR (LOAD LENGTHENED) HFP instruction</td>
<td>18-15</td>
</tr>
<tr>
<td>LXDTDR (LOAD LENGTHENED) DFP instruction</td>
<td>20-44</td>
</tr>
<tr>
<td>LXE (LOAD LENGTHENED) HFP instruction</td>
<td>18-15</td>
</tr>
<tr>
<td>LXEB (LOAD LENGTHENED) BFP instruction</td>
<td>19-34</td>
</tr>
<tr>
<td>LXEBR (LOAD LENGTHENED) BFP instruction</td>
<td>19-33</td>
</tr>
<tr>
<td>LXER (LOAD LENGTHENED) HFP instruction</td>
<td>18-15</td>
</tr>
<tr>
<td>LXR (LOAD) floating-point-support instruction</td>
<td>9-31</td>
</tr>
<tr>
<td>LY (LOAD) binary instruction</td>
<td>7-221</td>
</tr>
<tr>
<td>LZDR (LOAD ZERO) floating-point-support instruction</td>
<td>9-35</td>
</tr>
<tr>
<td>LZER (LOAD ZERO) floating-point-support instruction</td>
<td>9-35</td>
</tr>
<tr>
<td>LZRF (LOAD AND ZERO RIGHTMOST BYTE) binary instruction</td>
<td>7-229</td>
</tr>
<tr>
<td>LZRG (LOAD AND ZERO RIGHTMOST BYTE) binary instruction</td>
<td>7-229</td>
</tr>
<tr>
<td>LZXR (LOAD ZERO) floating-point-support instruction</td>
<td>9-35</td>
</tr>
</tbody>
</table>

M

M (mega) xxvi

M (MULTIPLY) binary instruction 7-259, 7-260

element A-28

machine check

See also malfunction

handling of malfunction detected as part of I/O 11-5

interrupt 6-15, 11-10

timeout 11-11

code (MCIC) 3-72, 11-14

floating conditions 11-24

machine check interruption 11-24

mask in the PSW 4-5

subclass masks in control register 11-24

logout 11-25

timeout in the PSW 4-5

machine-check architectural-mode identification 3-70

machine-check extended save area 11-23

machine-type number (in CPU ID) 10-132

MAD (MULTIPLY AND ADD) HFP instruction 18-19

MADB (MULTIPLY AND ADD) BFP instruction 19-38

MADBR (MULTIPLY AND ADD) BFP instruction 19-38

MADR (MULTIPLY AND ADD) BFP instruction 18-19
MAE (MULTIPLY AND ADD) HFP instruction 18-19
MAEB (MULTIPLY AND ADD) BFP instruction 19-38
MAEBR (MULTIPLY AND ADD) BFP instruction 19-38
MAER (MULTIPLY AND ADD) HFP instruction 18-19

main storage 3-2
See also storage
effect of power-on reset on 4-61
See also storage
shared (in multiprocessing) 4-63

malfunction 11-1
at channel subsystem 16-29
at I/O device 16-29
correction of 11-2
effect on manual operation 12-1
from DIAGNOSE instruction 10-23
indication of 11-5
machine-check handling for when detected as part of I/O 11-5

malfunction alert (external interruption) 6-13
when entering check-stop state 11-10

manual indicator 12-4
See also stopped state

manual operation 12-1
controls
address-compare 12-1
alter-and-display 12-2
IML 12-3
load-unit-address 12-4
power 12-4
rate 12-5
TOD-clock 12-6
effect on CPU signaling 4-71

keys
interrupt 12-3
load-clear 12-3
load-clear-list-directed 12-4
load-normal 12-4
load-with-dump 12-4
restart 12-5
start 12-5
stop 12-5
store-status 12-5
system-reset-clear 12-6
system-reset-normal 12-6

masks 6-5
See also I/O interruption, interruption
for IEEE exceptions 9-10
in BRANCH ON CONDITION instruction 7-38
in BRANCH RELATIVE ON CONDITION instruction 7-44
in COMPARE LOGICAL CHARACTERS UNDER MASK instruction 7-140

in INSERT CHARACTERS UNDER MASK instruction 7-220
in PSW 4-5
in STORE CHARACTERS UNDER MASK instruction 7-329
in TEST UNDER MASK instruction 7-343
monitor 6-29
path-management 15-2, 15-28, 15-30
PER-event 4-24
program-interruption 6-16
subclass
See subclass-mask bits
maximum negative number 7-4
MBA (measurement-block address) 15-9
MC (MONITOR CALL) instruction 7-243
MCIC (machine-check-interruption code) 3-72, 11-14
MD (MULTIPLY) HFP instruction 18-18
MDB (MULTIPLY) BFP instruction 19-37
MDBR (MULTIPLY) BFP instruction 19-37
MDE (MULTIPLY) HFP instruction 18-18
MDEB (MULTIPLY) BFP instruction 19-37
MDEBR (MULTIPLY) BFP instruction 19-37
MDER (MULTIPLY) HFP instruction 18-17
MDR (MULTIPLY) HFP instruction 18-17
example A-43
MDTR (MULTIPLY) DFP instruction 20-46
MDTRA (MULTIPLY) DFP instruction 20-47
ME (MULTIPLY) HFP instruction 18-18
measurement
block (I/O)
address 17-7
format 17-7
origin 17-7
device-connect-time 17-10
extended-measurement-word 17-11
measurement-block update (I/O) 17-2
measurement-alert external interruption 6-13
measurement block (I/O) 17-3
data check 16-48
index 15-6
key (MBK)
used as access key 3-11
multiple use of 15-11
program check 16-48
protection check 16-48
update enable 15-3
measurement-block-format control (I/O) 15-8
measurement data (I/O)
accumulated 17-3
effect of CSCH on 14-5
effect of HSCH on 14-7
measurement-mode control (I/O) 15-3
MEE (MULTIPLY) HFP instruction 18-18
MEEB (MULTIPLY) BFP instruction 19-37
MEEBR (MULTIPLY) BFP instruction 19-37
MEER (MULTIPLY) HFP instruction 18-17
MER (MULTIPLY) HFP instruction 18-18
message byte (in EDIT) 8-8
message-security assist 1-17
    facility indication 4-76
message-security-assist extension 1 1-18
message-security-assist extension 2 1-18
message-security-assist extension 3 1-18
    facility indication 4-77
message-security-assist extension 4 1-19
    facility indication 4-77
message-security-assist extension 5 1-20
    facility indication 4-77
MFY (MULTIPLY) binary instruction 7-259
MGHI (MULTIPLY HALFWORD IMMEDIATE) instruction 7-260
MH (MULTIPLY HALFWORD) instruction 7-260
    example A-29
MHI (MULTIPLY HALFWORD IMMEDIATE) instruction 7-260
MHY (MULTIPLY HALFWORD) binary instruction 7-260
MIDA (modified-indirect-data addressing) 15-68
MIDA flag in CCW 15-33
    invalid 16-27
MIDAW (modified-indirect-data-address word)
    invalid address specification of 16-26
MIDAW (modified-indirect-data-address word) 15-68
    check (in subchannel logout) 16-48
MIDAW (modified indirect-data-address word)
    invalid address of 16-25
MIDAW control 15-28
miscellaneous-instruction-extensions facility 1-20
    facility indication 4-77
ML (MULTIPLY LOGICAL) instruction 7-261
MLG (MULTIPLY LOGICAL) instruction 7-261
MLGR (MULTIPLY LOGICAL) instruction 7-261
MLR (MULTIPLY LOGICAL) instruction 7-261
modal instructions 1-5, 7-8
mode
    access-register 3-37
    addressing
        See addressing mode
architectural
    See architectural mode
burst (channel-path operation) 13-3
byte-multiplex mode (channel-path operation) 13-3
home-space 3-37
incorrect-length-indication 15-28
incorrect-length-suppression 15-28
indicator
architectural 12-2
multipath
    See multipath mode
primary-space 3-37
real 3-37
requirements for semiprivileged instructions 5-28
secondary-space 3-37
single-path 15-4, 15-23
translation 3-37
mode-trace-control bit 4-12
model number (in CPU ID) 10-132
modifiable area (in linkage-stack state entry) 5-84
modification control 15-26
modified-CCW-indirect-data-addressing control 15-28
modified-CCW-indirect-data-addressing facility 1-20
MODIFY STACKED STATE instruction 10-59
MODIFY SUBCHANNEL instruction 14-7
MONITOR CALL instruction 7-243
monitor-class number 6-29, 7-243
    assigned storage locations for 3-69
monitor code 6-29, 7-244
    assigned storage locations for 3-72
monitor event 6-29, 7-244
    counting operation 7-244
    program interruption 7-244
monitor-event
    counting operation 5-110
    monitor masks 6-29, 7-243
monitoring
    See also measurement
    channel-subsystem 17-1
    for PER events
    See PER
    with MONITOR CALL 6-29, 7-243
MOVE instructions 7-245
    examples A-21, A-24
move-inverse facility 7-245
MOVE INVERSE instruction 7-245
    example A-25
MOVE LONG EXTENDED instruction 7-250
MOVE LONG instruction 7-246
    examples A-26
MOVE LONG Unicode instruction 7-253
MOVE NUMERICS instruction 7-256
    example A-26
MOVE PAGE instruction 10-60, 10-76
MOVE STRING instruction 7-257
    example A-27
MOVE TO PRIMARY instruction 10-62
MOVE TO SECONDARY instruction 10-62
MOVE WITH DESTINATION KEY instruction 10-64
MOVE WITH KEY instruction 10-65
MOVE WITH OFFSET instruction 7-258
MULTIPLY binary instructions 7-259
examples A-28
MULTIPLY DECIMAL instruction 8-12
element A-39
MULTIPLY DFP instructions 20-46
MULTIPLY HALFWORD IMMEDIATE instruction 7-260
MULTIPLY HALFWORD instruction 7-260
example A-29
MULTIPLY HFP instructions 18-17
example A-43
MULTIPLY LOGICAL instructions 7-261
MULTIPLY SINGLE IMMEDIATE instructions 7-262
MULTIPLY SINGLE instructions 7-261
multiprocessing 4-63
manual operations for 12-6
programming considerations for 8-4, A-45
programming examples A-45
timing-facility interruptions for 4-46
TOD clock for 4-41
multiprogramming examples A-45
multithreading
core 2-3
disablement of 4-59, 4-60
enablement of 4-69
facility description 1-21
operator considerations 12-7
terminology 2-3
thread 2-3
MVC (MOVE) instruction 7-244
examples A-21, A-24
MVCDFK (MOVE WITH DESTINATION KEY) instruction 10-64
MVCIN (MOVE INVERSE) instruction 7-245
example A-25
MVCK (MOVE WITH KEY) instruction 10-65
MVCL (MOVE LONG) instruction 7-246
examples A-26
MVCELE (MOVE LONG EXTENDED) instruction 7-250
MVCLU (MOVE LONG UNICODE) instruction 7-253
MVCOS (MOVE WITH OPTIONAL SPECIFICATIONS) instruction 10-66
MVCPS (MOVE TO PRIMARY) instruction 10-62
MVCS (MOVE TO SECONDARY) instruction 10-62
MVCSK (MOVE WITH SOURCE KEY) instruction 10-69
MVGHI (MOVE) instruction 7-245
MVHHI (MOVE) instruction 7-244
MVHI (MOVE) instruction 7-245
MVI (MOVE) instruction 7-245
example A-25
MVY (MOVE) instruction 7-245
MVN (MOVE NUMERICS) instruction 7-256
example A-26
MVO (MOVE WITH OFFSET) instruction 7-258
  example A-27
MVPG (MOVE PAGE) instruction 10-60, 10-76
MVST (MOVE STRING) instruction 7-257
  example A-27
MVZ (MOVE ZONES) instruction 7-259
  example A-28
MXBR (MULTIPLY) BFP instruction 19-37
MXD (MULTIPLY) HFP instruction 18-18
MXDB (MULTIPLY) BFP instruction 19-37
MXDBR (MULTIPLY) BFP instruction 19-37
MXDR (MULTIPLY) HFP instruction 18-17
MXR (MULTIPLY) HFP instruction 18-17
MXTR (MULTIPLY) DFP instruction 20-46
MXTRA (MULTIPLY) DFP instruction 20-47

N
N (AND) instruction 7-32
N condition (I/O) 16-13
NaN (not-a-number) 9-2, 19-4, 20-7
NC (AND) instruction 7-33
NDNR (AND) binary instruction 7-32
NDXGR (EXCLUSIVE OR) binary instruction 7-212
near-valid CBC 11-2
  in storage 11-6
negative zero
  binary 7-4
  decimal 8-3
  example A-5
nested transaction
  transactional execution 5-91, 5-92
  nesting 5-91, 5-92
  new PSW 4-3
    assigned storage locations for 3-74
    fetched during interruption 6-2
next-entry size (in linkage stack) 5-81
NG (AND) instruction 7-32
NGR (AND) instruction 7-32
NGRK (AND) binary instruction 7-32
NI (AND) instruction 7-32
  example A-8
NIHF (AND IMMEDIATE) instruction 7-33
NIHH (AND IMMEDIATE) instruction 7-33
NIHL (AND IMMEDIATE) instruction 7-33
NILF (AND IMMEDIATE) instruction 7-34
NILH (AND IMMEDIATE) instruction 7-34
NILL (AND IMMEDIATE) instruction 7-34
NIY (AND) instruction 7-32
no-operation
  instruction (BRANCH ON CONDITION) 7-38
  instruction (BRANCH RELATIVE ON CONDITION) 7-44
node (of tree structure) 7-368
nonconstrained transaction
  transactional execution 5-92
  nonconstrained transaction-execution mode
  transactional execution 5-92
  noninterlocked-update storage reference 5-122
  nonnumeric entities
    decimal 20-7
    IEEE 9-2
  nonquiescing key-setting facility
    facility indication 4-76
    NQ control
      in SET STORAGE KEY EXTENDED 10-126
      storage-key accesses 5-118
      1-21
NONTRANSACTION STORE instruction 7-264
nontrap action
  IEEE 9-18
nonvolatile storage 3-2
normal numbers
  class of BFP data 19-4
  class of DFP data 20-7
  normalization
    of HFP numbers 18-2
  not-a-number (NaN) 9-2, 19-4, 20-7
  not operational
    as channel-path state 16-13
    See path-not-operational bit
    as CPU state 4-71
    as TOD-clock state 4-42
  not set (TOD-clock state) 4-42
NR (AND) instruction 7-32
NTSTG (NONTRANSACTION STORE) instruction 7-264
nullification
  exceptions to 5-26
  for exigent machine-check conditions 11-10
  of instruction execution 5-23
  of unit of operation 5-25
numbering
  of addresses (byte locations) 3-2
  of bits 3-3
numbers
  binary 7-4
    examples A-2
  binary-floating-point 19-2
  CPU-model 10-132
    decimal 8-1
      examples A-4
    device 13-6
    hexadecimal 5-7
    hexadecimal-floating-point 18-2
      examples A-5
  machine-type 10-132
numeric bits 8-1
  moving of 7-256
Numeric part of PC number 5-84
NY (AND) instruction 7-32

O
  O (OR) instruction 7-264
  OC (OR) instruction 7-265
octoword 3-3
OEMI (original equipment manufacturers information)
  for I/O interface
    publication referenced xxvii
offset of symbol-translation table 7-155
OG (OR) instruction 7-264
OGR (OR) instruction 7-264
OGRK (OR) binary instruction 7-264
OI (OR) instruction 7-264
  example A-29
    example of problem with A-45
OIHF (OR IMMEDIATE) instruction 7-265
OIHH (OR IMMEDIATE) instruction 7-265
OIHL (OR IMMEDIATE) instruction 7-265
OILF (OR IMMEDIATE) instruction 7-265
OILH (OR IMMEDIATE) instruction 7-266
OILL (OR IMMEDIATE) instruction 7-266
OY (OR) instruction 7-264
old PSW 6-2
  assigned storage locations for 3-73
one's complement binary notation 7-4
  used for SUBTRACT LOGICAL instruction 7-340
  used for SUBTRACT LOGICAL WITH BORROW instruction 7-341
op code
  See operation code
operand 5-3
  access identification 3-70
  access of 5-120
    for I/O instructions 14-2
  address generation for 5-10
  exception 6-29
  immediate 5-8
  length of 5-3
overlaps of
  for decimal instructions 8-3
  for general instructions 7-4
register for 5-7
sequence of references for 5-120
storage 5-9
types of (fetch, store, update) 5-120
used for result 5-3
operating state 4-2
operating
I/O
See I/O operations
  unit of 5-24
operation code (op code) 5-3
  invalid 6-30
operation exception 6-30
operation-request block
  See ORB
operator facilities 2-8, 12-1
  basic 12-1
operator intervening (signal-processor status) 4-74
OR (OR) instruction 7-264
OR IMMEDIATE instructions 7-265
OR instructions 7-264
  example of problem with OR immediate A-45
  examples A-29
ORB (operation-request block) 15-24
  channel-program-type control 15-27
  CSS priority 15-29
  designating a CCW channel program 15-25
  extension control in 15-28, 15-30
  interruption parameter in 15-25
  invalid 16-27
  logical-path mask (LPM) in 15-28, 15-30
orders (I/O) 13-8
orders (signal-processor) 4-64
  conditional emergency signal 4-68
  conditions precluding response to 4-71
  CPU reset 4-65
  emergency signal 4-65
  emergency signal, conditional 4-68
  external call 4-65
  initial CPU reset 4-65
  restart 4-65
  sense 4-65
  set architecture 4-67, 4-70
  set prefix 4-66
  start 4-65
  stop 4-65
  stop and store status 4-65
  store status at address 4-66
  set multithreading 4-69
ORK (OR) binary instruction 7-264
outer transaction 5-92
outermost transaction 5-92
overlap
  binary 7-5
    example A-2
  decimal 6-25
  exponent
    See exponent overflow
  fixed-point 6-26, 7-5
  in CRW 6-26, 7-5
overlaps of
  destructive 7-246, 7-250, 7-254
operand 5-114
   for decimal instructions 8-3
   for general instructions 7-4
operation 5-112
OY (OR) instruction 7-264

P
P (peta) xxvi
PACK ASCII instruction 7-267
PACK instruction 7-266
   example A-29
PACK UNICODE instruction 7-268
packed decimal numbers 8-1
   conversion of to zoned format 7-366
   conversion to from zoned format 7-266
padding byte
   for COMPARE LOGICAL LONG EXTENDED
      instruction 7-144
   for COMPARE LOGICAL LONG instruction 7-141
   for MOVE LONG EXTENDED instruction 7-250
   for MOVE LONG instruction 7-246
page 3-36
page-frame real address (PFRA) 3-48
PAGE IN instruction 10-70
page index (PX) 3-36
page-invalid bit (in page-table entry) 3-48
PAGE OUT instruction 10-71
page protection
   exception for 6-33
page swapping 3-35
page table 3-48
   lookup 3-57
   origin (PTO) 3-46
page-translation exception 6-30
   as an access exception 6-45, 6-51
PALB (PURGE ALB) instruction 10-112
PAM (path-available mask) 15-7
   effect of reconfiguration on 15-11
   effect of resetting on 15-11
   effect on allegiance of 15-12
parallel-I/O channel-to-channel adapter
   publication referenced xxvii
parallel-I/O interface 13-3
   OEMI publication referenced xxvii
parameter
   external-interruption 6-10
      assigned storage locations for 3-68
I/O-interruption
      See I/O-interruption parameter
register for SIGNAL PROCESSOR 4-66, 10-130
   translation 3-37
parity bit 11-2
parsing-enhancement facility 1-21
   facility indication 4-76
partial completion of instruction execution 5-24
PASCE (primary address-space-control element) 3-39
PASN (primary address-space number) 3-21
   in trace entry 4-21
PASTE (primary AST entry) 5-35
PASTEIN (primary-AST-entry instance number) 3-23
PASTEEO (primary-AST-entry origin) 5-35, 5-55
path
   See channel path
   path available for selection 15-13
   path management 13-9
      for clear function 15-14, 15-22
      for halt function 15-16
      for start function and resume function 15-20
   path-management-control word
   See PMCW
path-management masks
   last-path-used mask
      See LPUM
   logical-path mask
      See LPM
   path-available mask
      See PAM
   path-installed mask
      See PIM
   path-not-operational mask
      See PNOM
   path-operational mask
      See POM
path-not-operational bit (N) in SCSW 16-13
path-not-operational condition 15-5
path verification required
   indicator for (in ERW) 16-52
pattern (in EDIT) 8-8
PC-cp (PROGRAM CALL instruction, to current
   primary) 10-91
PC number 10-88
   in linkage-stack state entry 5-84
   in trace entry 4-21
   translation 5-34
PC-ss (PROGRAM CALL instruction, with space
   switching) 10-91
PC-translation-specification exception 6-31
PC-type bit 5-38
PCC (PERFORM CRYPTOGRAPHIC COMPUTATION) instruction 7-269
PCI (program-controlled interruption) 15-64
   as flag in CCW 15-32
   intermediate interruption condition for 16-18
   subchannel status for 16-24
PCKMO (PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION) instruction 10-72
pending channel reports
effect of I/O-system reset on 17-15
pending interruption
See interruption pending
PER (program-interruption recording)
access identification 3-70, 4-29
address 4-29
assigned storage locations for address-space-control element (ASCE) 4-28
ASCE (address-space-control element) identification 4-28
ATMID (addressing-and-translation-mode identification) 4-27
code 4-27
assigned storage locations for events 1-28
extensions 4-23
instruction-fetching event 4-33
masks
bit in the PSW 4-5
PER-event 4-24
priority of indication 4-30
program-interruption condition 6-31
storage-alteration event 4-33
storage-area designation 4-31
ending address 4-25
starting address 4-25
wraparound 4-32
store-using-real-address event 4-34
successful-branching event 4-32
PER zero-address-detection facility 1-22
PER-3 facility 1-21
breaking-event-address recording 4-39
PER instruction-fetching nullification 4-24
PERFORM CRYPTOGRAPHIC COMPUTATION instruction 7-269
PERFORM CRYPTOGRAPHIC KEY MANAGEMENT OPERATION instruction 10-72
PERFORM FLOATING-POINT OPERATION floating-point-support instruction 9-35
PERFORM FRAME MANAGEMENT FUNCTION instruction 10-76
PERFORM LOCKED OPERATION instruction 7-284
example A-51
PERFORM PROCESSOR ASSIST instruction 7-298
PERFORM TIMING FACILITY FUNCTION instruction 10-79
PERFORM TOPOLOGY FUNCTION instruction 10-85
permissible set 9-13
PFD (PREFETCH DATA) instruction 7-310
PFDRL (PREFETCH DATA RELATIVE LONG) instruction 7-310
PFPO (PERFORM FLOATING-POINT OPERATION) floating-point-support instruction 9-35
PFPO facility 1-22
facility indication 4-77
PFRA (page-frame real address) 3-48
PGIN (PAGE IN) instruction 10-70
PGOUT (PAGE OUT) instruction 10-71
piecemeal steps of instruction execution 5-113
PIM (path-installed mask) 15-6
PKA (PACK ASCII) instruction 7-267
PKM (PSW-key mask) 5-29
PKU (PACK UNICODE) instruction 7-268
PLO (PERFORM LOCKED OPERATION) instruction 7-284
example A-51
PMCW (path-management-control word) 15-2
channel-path identifiers (CHPID) 15-8
PNOM (path-not-operational mask) 15-5
effect on POM of indicated in SCSW 16-13
point of damage 11-13
point of interruption 5-24
for machine check 11-13
POM (path-operational mask) 15-7
effect on PNOM of 15-11
POPCNT (POPULATION COUNT) instruction 7-310
population-count facility 1-22
facility indication 4-77
POPULATION COUNT instruction 7-310
postnormalization 18-2
power controls 12-4
power-on reset 4-61
powers of 2
table of G-1
PPA (PERFORM PROCESSOR ASSIST) instruction 7-298
PPNO (PERFORM PSEUDORANDOM NUMBER GENERATION) instruction 7-299
PR (PROGRAM CALL instruction 10-86
PR (PROGRAM RETURN) instruction 10-99
PR-cp (PROGRAM RETURN instruction, to current primary) 10-100
PR-ss (PROGRAM RETURN instruction, with space switching) 10-100
PR/SM (Processor Resource/Systems Manager) 1-29, 1-30
precise intermediate value 9-12
precision (floating-point) 9-2
precision-rounded value 9-12
preferred quantum 20-2
preferred sign codes 8-2
prefetch control 15-27
PREFETCH DATA instruction 7-310
PREFETCH DATA RELATIVE LONG
PREFETCH DATA RELATIVE LONG instruction
7-310
prefetching
access exceptions not recognized for 6-48
channel-control check during 16-29, 16-43
channel-data check during 16-28, 16-42, 16-43
handling of invalid CBC in storage during 11-8
of ART-table and DAT-table entries 5-117
of data for I/O 15-59
of instructions 5-116
of operands 5-121
See CCW prefetch control
prefix 3-18
set by signal-processor order 4-66
store-status save area for 3-74
prefix area 3-18
prefix register 3-18
prenormalization 18-2
primary address space 3-20
primary ASN (PASN) 3-21
in linkage-stack state entry 5-83
primary-AST entry (PASTE) 5-35
origin (PASTEO) 5-35, 5-55
primary ASTEIN (PASTEIN)
in linkage-stack state entry 5-85
primary authority 3-33
exception 6-31
primary CPU 2-3, 4-61, 12-7
primary designation-type-control bits 3-40
primary interruption condition (I/O) 16-4
primary-list bit 5-55
primary private-space-control bit 3-39
primary real-space-control bit 3-40
primary real-space token origin (PRSTKO) 3-41
primary region table
designation (PRTD) 3-39
length (PRTL) 3-41
origin (PRTO) 3-39
primary segment table
designation (PSTD) 3-39
length (PSTL) 3-41
origin (PSTO) 3-39
primary-space access-list designation (PSALD) 5-57
primary-space mode 3-37
primary space-switch-event-control bit 3-40
primary-status bit (I/O) 16-19
primary storage-alteration-event-control bit 3-40
primary subspace-group-control bit 3-39
primary virtual address 3-5
effective address-space-control element for 3-49
priority
of access exceptions 6-51
of ASN-translation exceptions 6-53
of data exceptions 6-16
of external-interruption conditions 6-11
of I/O interruptions 16-5
of interruptions (CPU) 6-55
of PER events 4-30
of program-interruption conditions 6-48
of subspace-replacement exceptions 6-54
of trace exceptions 6-54
private bit 5-57
private-space control
effect on
fetch-protection override 3-13
low-address protection 3-14
use of common regions 3-44
use of common segments 3-46
private-space-control bit 3-39
home 3-42
primary 3-39
secondary 3-41
privileged instructions 4-5
control 10-1
privileged-operation exception 6-32
problem state 4-5
bit in entry-table entry 5-38
bit in the PSW 4-5
compatibility 1-31
processing backup (synchronous machine-check condition) 11-17
processing damage (synchronous machine-check condition) 11-18
processor
See CPU 2-2
processor-assist facility 1-22
facility indication 4-77
processor-availability facility 1-28
Processor Resource/Systems Manager (PR/SM) 1-29, 1-30
program 5-49
channel
See channel program
exceptions 6-15
execution of 5-1
fields of SCHIB modifiable by 15-10
initial loading by CCW-type IPL 17-17
initial loading by list-directed IPL 17-19
initial loading of 4-61, 17-16
interruption 6-15
priority of 6-16, 6-48
PROGRAM CALL instruction 10-86
trace entry for 4-21
type of 5-38
program-call state entry 5-82, 10-90
program check
as subchannel status 16-25, 16-40
measurement-block 16-48
program-controlled interruption (I/O)
   See PCI
program-event recording
   See PER
program events
   See PER events
program interruption
   filtering 5-104
      transaction diagnostic block 3-75, 3-79
program-interruption filtering
   in transactional execution 5-92
program interruption identification
   in the transaction diagnostic block 5-97
program mask
   in the PSW 4-6, 6-16
      inserted by INSERT PROGRAM MASK 7-221
      preserved by BRANCH AND LINK 5-14, 7-35
      set by SET PROGRAM MASK 7-321
      validity bit for 11-20
PROGRAM RETURN instruction 10-99
program-status word
   See PSW
PROGRAM TRANSFER instruction 10-103
   trace entry for 4-21
PROGRAM TRANSFER WITH INSTANCE
   instruction 10-103
programmable field of TOD clock 4-45
protection (storage) 3-10
   access-list-controlled
      See access-list-controlled protection
DAT
   See DAT protection
during tracing 4-23
   fetch
      See fetch protection
key-controlled
      See key-controlled protection
low-address
      See low-address protection
   page
      See page protection
protection check
   as subchannel status 16-28, 16-42
   measurement-block 16-48
protection exception 6-32
   as an access exception 6-45, 6-51
PRSD (primary real-space designation) 3-39
PRSTKO (primary real-space token origin) 3-41
PRTD (primary region-table designation) 3-39
PRTL (primary region-table length) 3-41
PRTOS (primary region-table origin) 3-39
PSALD (primary-space access-list designation) 5-57
pseudo AST entry 3-21
PSMF(PERFORM FRAME MANAGEMENT
   FUNCTION) instruction 10-76
PSTD (primary segment-table designation) 3-39
PSTL (primary segment-table length) 3-41
PSTO (primary segment-table origin) 3-39
PSW (program-status word) 2-3, 4-3
   current 4-3, 5-13
      stored during interruption 6-2
      exceptions associated with 6-9
      format error 6-9
      in linkage-stack state entry 5-83
      in program execution 5-13
      saved 4-58
      store-status save area for 3-74
      validity bits for 11-20
PSW key 4-5
   control bit 5-76
      in entry-table entry 5-77
      in trace entry 4-21
      used as access key 3-11
      validity bit for 11-20
PSW-key mask (PKM) 5-29
   control bit 5-76
      in linkage-stack state entry 5-83
PT (PROGRAM TRANSFER) instruction 10-103
   PT-cp (PROGRAM TRANSFER instruction, to current
      primary) 10-104
PT-ss or PTI-ss (PROGRAM TRANSFER (WITH
      INSTANCE) instruction, with space switching) 10-104
PTF (PERFORM TOPOLOGY FUNCTION)
   instruction 10-85
PTFF (PERFORM TIMING FACILITY FUNCTION)
   instruction 10-79
PTI (PROGRAM TRANSFER WITH INSTANCE)
   instruction 10-103
PTLB (PURGE TLB) instruction 10-112
PTO (page-table origin) 3-46
publications
   other related documents xxvii
PURGE ALB instruction 10-112
PURGE TLB instruction 10-112
PX (page index) 3-36

Q
QADTR (QUANTIZE) DFP instruction 20-48
QAXTR (QUANTIZE) DFP instruction 20-48
QNaN (quiet NaN) 9-2, 19-4, 20-7
quadword 3-3
quadword-concurrent storage references 5-124
QUANTIZE DFP instructions 20-48
quantum 20-2
quantum exception 9-21
nontrap action 9-21
trap action 9-21
queuing
FIFO
example for lock and unlock A-49
LIFO
example for lock and unlock A-48
quiessing 5-131
quiet NaN (QNaN) 9-2, 19-4, 20-7

R
R field of instruction 5-7
radix
   binary 9-4
decimal 9-4
   hexadecimal 9-3
rate control 12-5
RCHP (RESET CHANNEL PATH) instruction 14-9
real address 3-4
real mode 3-37
real space
   token origin (RSTKO) 3-39
real-space-control bit
   home 3-42
   primary 3-40
   secondary 3-41
real-space designation (RSD)
   home 3-42
   primary 3-39
   secondary 3-41
real storage 3-5
receiver check (signal-processor status) 4-74
reconfiguration of I/O system 17-22
recovery
   as class of machine-check condition 11-11
   channel-subsystem 17-24
   system 11-15
      subclass-mask bit for 11-24
reduced-authority state 10-7
redundancy 11-2
reference
   bit in storage key 3-9
   multiple-access 5-123
   recording 3-17
   sequence for storage 5-111
   See also sequence
   single-access 5-123
region 3-36
region first index (RFX) 3-36
region-first-translation exception 6-33
   as an access exception 6-51
region index (RX)
in virtual address 3-36
region-invalid bit (in region-table entry) 3-44
region second index (RSX) 3-36
region-second-translation exception 6-34
   as an access exception 6-51
region table
   origin (RTO) 3-39
region-table designation (RTD) 3-39
   home 3-42
   primary 3-39
   secondary 3-41
region-table entry (RTE) 3-42
region third index (RTX) 3-36
region-third-translation exception 6-34
   as an access exception 6-51
region-translation exception 6-33
register
   access 2-6
   base-address 2-4
   control 2-6
   designation of 5-7
   floating-point 2-4, 9-8
   floating-point-control 9-9
   general 2-4
   index 2-4
   prefix 3-18
   save areas for 3-74, 11-21
   validation of 11-9
   validity bits for 11-20
   vector 2-5
relative branching 5-12
remainder 19-5
   result of DIVIDE TO INTEGER 19-28
remaining free space (in linkage stack) 5-80
remote operating stations 12-1
reporting-source code (RSC) 17-26
reporting-source ID (RSID) 17-27
repressible machine-check conditions 11-11
request-logging-only 16-52
   indicator for (in ERW) 16-52
REROUND DFP instructions 20-51
reset 17-13
   channel-path 17-13
   clear 4-60
   CPU 4-58
   effect on CPU state 4-2
   effect on TOD clock 4-41
   I/O-system 17-13
      as part of subsystem reset 4-60
   initial CPU 4-59
   power on 4-61
   subsystem 4-60
   summary of functions 4-57
   summary of functions performed by manual
   initiation of 4-56
system-reset-clear key 12-6
system-reset-normal key 12-6
RESET CHANNEL PATH instruction 14-9
  function initiated by 15-80
  See channel-path-reset function
RESET REFERENCE BIT EXTENDED instruction 10-112
RESET REFERENCE BIT MULTIPLE instruction 10-113
reset-reference-bits-multiple facility 1-22
  facility indication 4-77
reset signal (I/O) 17-12
  in I/O-system reset 17-14
  issued as part of RCHP 15-81
  in channel-path reset 17-13
resolution
  of clock comparator 4-53
  of CPU timer 4-54
  of TOD clock 4-41
restart
  interruption 6-54
  key 12-5
  signal-processor order 4-65
result operand 5-3
resume function 13-11, 15-20
  initiated by RESUME SUBCHANNEL 14-10
  path management for 15-20
  pending 16-14, 16-36
  See also start function
RESUME PROGRAM instruction 10-113
RESUME SUBCHANNEL instruction 14-10
  channel-program requirements for 14-11
  count of in measurement block 17-4
  function initiated by 15-20
  See resume function
retry
  CPU 11-2
  I/O command
  See command retry
reusable-ASN bit 3-22
RFX (region first index) 3-36
RI instruction format 5-6
RIE instruction format 5-6
right-units view (RUV) of floating-point numbers 9-2
RIL instruction format 5-6
RIS instruction format 5-6
RISBG (ROTATE THEN INSERT SELECTED BITS) instruction 7-314
RISBG N(ROTATE THEN INSERT SELECTED BITS) instruction 7-314
RISBGH (ROTATE THEN INSERT SELECTED BITS HIGH) instruction 7-315
RISBLG (ROTATE THEN INSERT SELECTED BITS LOW) instruction 7-316
RLL (ROTATE LEFT SINGLE LOGICAL) instruction 7-312
RLLG (ROTATE LEFT SINGLE LOGICAL) instruction 7-312
RNSBG (ROTATE THEN AND SELECTED BITS) instruction 7-312
ROTATE LEFT SINGLE LOGICAL instruction 7-312
ROTATE THEN AND SELECTED BITS instruction 7-312
ROTATE THEN EXCLUSIVE OR SELECTED BITS instruction 7-312
example A-30
ROTATE THEN INSERT SELECTED BITS HIGH instruction 7-315
ROTATE THEN INSERT SELECTED BITS instruction 7-314
example A-30
ROTATE THEN INSERT SELECTED BITS LOW instruction 7-316
ROTATE THEN OR SELECTED BITS instruction 7-313
example A-30
rounded intermediate value 9-12
rounding (decimal) 8-12
example A-40
rounding (floating-point)
  IEEE 9-13
rounding action
  summary of 9-17
rounding methods 9-13
RP (RESUME PROGRAM) instruction 10-113
RR instruction format 5-6
RRBE (RESET REFERENCE BIT EXTENDED) instruction 10-112
RRBM (RESET REFERENCE BIT MULTIPLE) instruction 10-113
RRD instruction format 5-6
RRDTR (REROUND) DFP instruction 20-51
RRE instruction format 5-6
RRF instruction format 5-6
RRS instruction format 5-6
RRXTR (REROUND) DFP instruction 20-51
RS instruction format 5-6
RSC (reporting-source code) 17-26
RSCH (RESUME SUBCHANNEL) instruction 14-10
RSI instruction format 5-6
RSID (reporting-source ID) 17-27
RSL instruction format 5-6
RSTKO (real-space token origin) 3-39
RSX (region second index) 3-36
RSY instruction format 5-6
RTE (region-table entry) 3-42
RTO (region-table origin) 3-39
RTX (region third index) 3-36
running (state of TOD clock) 4-41
RUV (right-units view) of floating-point numbers 9-2
RX (region index) 3-36
RX instruction format 5-6
RXE instruction format 5-6
RXF instruction format 5-6
RXSBG (ROTATE THEN EXCLUSIVE OR
SELECTED BITS) instruction 7-312
RXY instruction format 5-6
S
S (SUBTRACT) binary instruction 7-338
S instruction format 5-6
SAC (SET ADDRESS SPACE CONTROL) instruction 10-115
SACF (SET ADDRESS SPACE CONTROL FAST)
instruction 10-116
SAL (SET ADDRESS LIMIT) instruction 14-12
SAM24 (SET ADDRESSING MODE) instruction 7-321
SAM31 (SET ADDRESSING MODE) instruction 7-321
SAM64 (SET ADDRESSING MODE) instruction 7-321
sample count (in ESW) 17-4
SAR (SET ACCESS) instruction 7-321
SASCE (secondary address-space-control element) 3-41
SASN (secondary address-space number) 3-21
in trace entry 4-21
SASTEIN (secondary-AST-entry instance number) 3-23
save areas for registers 3-74, 11-21
saved PSW 4-58
scale factor ($\delta$) 9-12
scaled preferred quantum 20-3
scaled value 9-12
scaling exponent
signed ($\delta$) 9-12
unsigned ($\alpha$) 9-12
SCHIB (subchannel-information block) 15-2
as operand of
MODIFY SUBCHANNEL 14-7
STORE SUBCHANNEL 14-18
Measurement-Block Address (MBA) 15-9
model-dependent area in 15-9
path-management-control word (PMCW) in 15-2
subchannel-status word (SCSW) in 15-9
summary of modifiable fields in 15-10
SCHM (SET CHANNEL MONITOR) instruction 14-13
SCK (SET CLOCK) instruction 10-117
SCKC (SET CLOCK COMPARATOR) instruction 10-118
SCKPF (SET CLOCK PROGRAMMABLE FIELD)
instruction 10-118
SCP-initiated reset 1-28
SCSW (subchannel-status word) 16-7
activity-control field in 16-14, 16-36
CCW address in 16-19
count in 16-31, 16-44
device-status field in 16-24
function-control field in 16-13
in IRB 16-7
in SCHIB 15-9
status-control field in 16-17
subchannel-control field in 16-12, 16-35
subchannel-status field in 16-24, 16-39
SD (SUBTRACT NORMALIZED) HFP instruction 18-24
SDB (SUBTRACT) BFP instruction 19-40
SDBR (SUBTRACT) BFP instruction 19-40
SDR (SUBTRACT NORMALIZED) HFP instruction 18-24
SDTR (SUBTRACT) DFP instruction 20-54
SDTRA (SUBTRACT) DFP instruction 20-54
SE (SUBTRACT NORMALIZED) HFP instruction 18-24
SEARCH STRING instruction 7-317
examples A-31
SEARCH STRING UNICODE instruction 7-319
SEB (SUBTRACT) BFP instruction 19-40
SEBR (SUBTRACT) BFP instruction 19-40
secondary address space 3-20
secondary ASN (SASN) 3-21
control bit 5-77
in linkage-stack state entry 5-83
secondary ASTEIN (SASTEIN)
in linkage-stack state entry 5-84
secondary authority 3-33
exception 6-35
secondary-CCW address validity (in ERW) 16-52
secondary CPU 2-3
secondary designation-type-control bits 3-41
secondary error (in subchannel logout) 16-50
secondary interruption condition (I/O) 16-5
secondary private-space-control bit 3-41
secondary real-space-control bit 3-41
secondary real-space token origin (SRSTKO) 3-41
secondary region table
designation (SRTD) 3-41
length (SRTL) 3-41
origin (SRTO) 3-41
secondary segment table
designation (SSTD) 3-41
length (SSTL) 3-41
origin (SSTO) 3-41
secondary-space-control bit 3-38, 5-29
secondary-space mode 3-37
secondary-status bit (I/O) 16-19
secondary storage-alteration-event-control bit 3-41
secondary subspace-group-control bit 3-41
secondary virtual address 3-5
effective address-space-control element for 3-49
segment 3-36
segment-frame absolute address 3-46
segment index (SX) 3-36
segment-invalid bit (in segment-table entry) 3-46
segment length (STL) 3-39
origin (STO) 3-39
segment-table designation (STD) home 3-42
obtaining of in access-register translation 5-48
primary 3-39
secondary 3-41
segment-translation exception 6-35
as an access exception 6-45, 6-51
self-describing block of I/O data 15-62
semiprivileged instructions 4-6
descriptions of 10-2
program authorization 5-28
summary of 5-32
programs 4-6, 5-28
sense as signal-processor order 4-65
sense-running-status facility facility indication 4-76
sequence conceptual 5-111
instruction-execution 5-3
of CCWs that is invalid 16-27
of storage references 5-111
ART-table and DAT-table entries 5-117
for floating-point data 9-8
instructions 5-116
operands 5-120
storage keys 5-118
sequence code (in subchannel logout) 16-50
field-validity flag 16-49
SER (SUBTRACT NORMALIZED) HFP instruction 18-24
serial-I/O channel-to-channel adapter publication referenced xxvii
serial-I/O interface 13-3
publication referenced xxvii
serialization 5-128
caused by I/O instructions 14-2
channel-program 5-130
CPU 5-128
effects of transactional execution 5-128
in completion of store operations 5-121
quiescing 5-131
specific operand 5-130
server-time-protocol facility 1-22
service-call-logical-processor (SCLP) facility 1-29
service-processor damage 11-17
service processor inoperative (signal-processor status) 4-74
service-signal external interruption 6-13
subclass-mask bit for 6-13
SET ACCESS instruction 7-321
SET ADDRESS LIMIT instruction 14-12
SET ADDRESS SPACE CONTROL FAST instruction 10-116
SET ADDRESS SPACE CONTROL instruction 10-115
SET ADDRESSING MODE instruction 7-321
SET ADDRESSING MODE instructions 7-321
set architecture signal-processor order 4-67, 4-70
SET BFP Rounding Mode floating-point-support instructions 9-47
SET CHANNEL MONITOR instruction 14-13
effect on measurement modes of 17-1
SET CLOCK COMPARATOR instruction 10-118
SET CLOCK instruction 10-117
SET CLOCK PROGRAMMABLE FIELD instruction 10-118
SET CPU TIMER instruction 10-119
SET DFP Rounding Mode (SRNMT) floating-point-support instruction 9-47
SET FPC AND SIGNAL floating-point-support instruction 9-48
SET FPC floating-point-support instruction 9-47
set multithreading signal-processor order 4-69
set prefix (signal-processor order) 4-66
SET PREFIX instruction 10-119
SET PROGRAM MASK instruction 7-321
set-program-parameters facility facility indication 4-77
SET PSW KEY FROM ADDRESS instruction 10-120
SET SECONDARY ASN instruction 10-120
access registers 5-52
SET SECONDARY ASN WITH INSTANCE instruction 10-120
set state (of TOD clock) 4-42
SET STORAGE KEY EXTENDED instruction 10-126
SET SYSTEM MASK instruction 10-129
SFAA (segment-frame absolute address) 3-46
SFASR (SET FPC AND SIGNAL) floating-point-support instruction 9-48
SFPC (SET FPC) floating-point-support instruction 9-47
SG (SUBTRACT) binary instruction 7-338
SGF (SUBTRACT) binary instruction 7-338
SGFR (SUBTRACT) binary instruction 7-338
SGR (SUBTRACT) binary instruction 7-338
SGRK (SUBTRACT) binary instruction 7-338
SH (SUBTRACT HALFWORD) instruction 7-339
shared storage
    See storage sharing
shared TOD clock 4-41
SHHR (SUBTRACT HIGH) instruction 7-339
SHLR (SUBTRACT HIGH) instruction 7-339
SHIFT AND ROUND DECIMAL instruction 8-12
    examples A-39
SHIFT LEFT DOUBLE instruction 7-322
    example A-31
SHIFT LEFT DOUBLE LOGICAL instruction 7-323
SHIFT LEFT SINGLE instruction 7-323
    example A-32
SHIFT RIGHT DOUBLE instruction 7-325
SHIFT RIGHT DOUBLE LOGICAL instruction 7-325
SHIFT RIGHT SINGLE instruction 7-326
SHIFT RIGHT SINGLE LOGICAL instruction 7-327
SHIFT SIGNIFICAND LEFT DFP instructions 20-53
SHIFT SIGNIFICAND RIGHT DFP instructions 20-53
shifting
    floating-point
        See normalization
short binary-floating-point number 19-2
short decimal-floating-point number 20-3
short hexadecimal-floating-point number 18-2
short I/O block 16-24, 16-39
SHY (SUBTRACT HALFWORD) instruction 7-339
SI instruction format 5-6
SID
    See subsystem-identification word
sign bit
    binary 7-4
    floating point 9-2
sign codes (decimal) 8-2
signal (I/O) 17-11
    clear
        See clear signal
    halt
        See halt signal
    reset
        See reset signal
SIGNAL PROCESSOR instruction 10-129
    orders 4-64
    status 4-72
signaling NaN (SNaN) 9-2, 19-4, 20-7
signed binary
    arithmetic 7-5
    comparison 7-6
    integer 7-4
        examples A-2
    signed exponent 9-2
    signed-packed-decimal format 8-1
    used in DFP formatting instructions 20-8
    signed-packed-decimal numbers
        examples A-4
    signed scaling exponent () 9-12
    significance
        loss 18-2
        in HFP addition 18-9
        mask (in PSW) 4-6
        requested in REROUND 20-51
        See also significant digits
    starter (in EDIT) 8-8
significand
    in BFP data 19-3
    in DFP data 20-5
    significant digits 20-5
SIGP
    See SIGNAL PROCESSOR instruction
SIGP (SIGNAL PROCESSOR) instruction 10-129
SIL instruction format 5-6
simulated IEEE-exception data exception 6-24
single-access reference 5-123
single-path mode 15-4, 15-23
SIY instruction format 5-6, 5-7
size notation xxvi
size of address
    controlled by addressing mode 5-10
    in CCW 15-32
skip flag in CCW 15-32
    effect on data transfer of 15-64
SL (SUBTRACT LOGICAL) instruction 7-340
SLA (SHIFT LEFT SINGLE) instruction 7-323
    example A-32
SLAK (SHIFT LEFT SINGLE) instruction 7-323
SLB (SUBTRACT LOGICAL WITH BORROW) instruction 7-341
SLBG (SUBTRACT LOGICAL WITH BORROW) instruction 7-341
SLBGR (SUBTRACT LOGICAL WITH BORROW) instruction 7-341
SLBR (SUBTRACT LOGICAL WITH BORROW) instruction 7-341
SLDA (SHIFT LEFT DOUBLE) instruction 7-322
    example A-31
SLDL (SHIFT LEFT DOUBLE LOGICAL) instruction 7-323
SLDT (SHIFT SIGNIFICAND LEFT) DFP instruction 20-53
SLFI (SUBTRACT LOGICAL IMMEDIATE) instruction 7-340
SLGFI (SUBTRACT LOGICAL IMMEDIATE) instruction 7-340
SLGFR (SUBTRACT LOGICAL) instruction 7-340
SLGR (SUBTRACT LOGICAL) instruction 7-340
SLGRK (SUBTRACT LOGICAL) binary instruction 7-340
SLHHHR (SUBTRACT LOGICAL HIGH) instruction 7-341
SLHHLR (SUBTRACT LOGICAL HIGH) instruction 7-341
SLI (suppress-length-indication) flag in CCW 15-32, 15-39
for immediate operations 15-60
SLL (SHIFT LEFT SINGLE LOGICAL) instruction 7-324
SLLG (SHIFT LEFT SINGLE LOGICAL) instruction 7-324
SLLK (SHIFT LEFT SINGLE LOGICAL) instruction 7-324
SLR (SUBTRACT LOGICAL) instruction 7-339
SLRK (SUBTRACT LOGICAL) binary instruction 7-340
SLXT (SHIFT SIGNIFICAND LEFT) DFP instruction 20-53
SLY (SUBTRACT LOGICAL) instruction 7-340
SNaN (signaling NaN) 9-2, 19-4, 20-7
solicited interruption condition (I/O) 16-3
solid errors 11-6
sorting
extended 1-28
sorting instructions
example A-53
See also COMPARE AND FORM CODEWORD
instruction, UPDATE TREE instruction
source of interruption
identified by interruption code 6-5
SP (SUBTRACT DECIMAL) instruction 8-13
space-switch event 6-35
control bit
in ASTE 3-29
space-switch-event-control bit
home 3-42
primary 3-40
special-operation exception 6-36
special QNaN 9-3, 19-4, 20-7
special quantum-handling operations 20-3
specific-operand serialization 5-130
specification exception 6-38
SPKA (SET PSW KEY FROM ADDRESS) instruction 10-120
SPM (SET PROGRAM MASK) instruction 7-321
SPT (SET CPU TIMER) instruction 10-119
SPX (SET PREFIX) instruction 10-119
SQD (SQUARE ROOT) HFP instruction 18-23
SQDB (SQUARE ROOT) BFP instruction 19-40
SQDBR (SQUARE ROOT) BFP instruction 19-40
SQDR (SQUARE ROOT) HFP instruction 18-23
SQE (SQUARE ROOT) HFP instruction 18-23
SQEB (SQUARE ROOT) BFP instruction 19-40
SQEBR (SQUARE ROOT) BFP instruction 19-40
SQER (SQUARE ROOT) HFP instruction 18-23
SQUARE ROOT BFP instructions 19-40
SQUARE ROOT HFP instructions 18-20
SQXBR (SQUARE ROOT) BFP instruction 19-40
SQXR (SQUARE ROOT) HFP instruction 18-23
SR (SUBTRACT) binary instruction 7-338
SRA (SHIFT RIGHT SINGLE) instruction 7-326
SRAG (SHIFT RIGHT SINGLE) instruction 7-326
SRAK (SHIFT RIGHT SINGLE) instruction 7-326
SRDA (SHIFT RIGHT DOUBLE) instruction 7-325
SRDL (SHIFT RIGHT DOUBLE LOGICAL) instruction 7-325
SRDT (SHIFT SIGNIFICAND RIGHT) DFP instruction 20-53
SRK (SUBTRACT) binary instruction 7-338
SRL (SHIFT RIGHT SINGLE LOGICAL) instruction 7-338
SRLG (SHIFT RIGHT SINGLE LOGICAL) instruction 7-327
SRLK (SHIFT RIGHT SINGLE LOGICAL) instruction 7-327
SRMM (SET BFP Rounding MODE) floating-point-support instruction 9-47
SRNMB (SET BFP Rounding MODE) floating-point-support instruction 9-47
SRNMT (SET DFP Rounding MODE) floating-point-support instruction 9-47
SRP (SHIFT AND ROUND DECIMAL) instruction 8-12
examples A-39
SRSD (secondary real-space designation) 3-41
SRST (SEARCH STRING) instruction 7-317
examples A-31
SRSTKO (secondary real-space token origin) 3-41
SRSTU (SEARCH STRING UNICODE) instruction 7-319
SRTD (secondary region-table designation) 3-41
SRTL (secondary region-table length) 3-41
SRTO (secondary region-table origin) 3-41
SRXT (SHIFT SIGNIFICAND RIGHT) DFP instruction 20-53
SS instruction format 5-6, 5-7
SSAIR (SET SECONDARY ASN WITH INSTANCE) instruction 10-120
SSAR (SET SECONDARY ASN) instruction 10-120
access registers 5-52
SSAR-cp or SSAIR-cp (SET SECONDARY ASN (WITH INSTANCE) instruction, to current primary) 10-121

SSAR-ss or SSAIR-ss (SET SECONDARY ASN (WITH INSTANCE) instruction, with space switching) 10-121

SSASTEO (subspace-AST-entry origin) 5-68

SSASTESN (subspace-AST-entry sequence number) 5-68

SSCH (START SUBCHANNEL) instruction 14-15

SSE instruction format 5-6, 5-7

SSF instruction format 5-7

SSID (subchannel-set identifier) 13-5

SSKE (SET STORAGE KEY EXTENDED) instruction 10-1126

SSM (SET SYSTEM MASK) instruction 10-129

SSM-suppression-control bit 6-36, 10-129

SSTD (secondary segment-table designation) 3-41

SSTL (secondary segment-table length) 3-41

SSTO (secondary segment-table origin) 3-41

ST (STORE) binary instruction 7-327

stack-empty exception 6-42

stack-full exception 6-42

stack-operation exception 6-42

stack-specification exception 6-43

stack-type exception 6-43

stacking process 5-85

stacking PROGRAM CALL 5-73

STAM (STORE ACCESS MULTIPLE) instruction 7-328

STAMY (STORE ACCESS MULTIPLE) instruction 7-328

standalone dump 12-5

standard epoch (for TOD clock) 4-45

STAP (STORE CPU ADDRESS) instruction 10-132

start (CPU)

  function 4-2
  key 12-5
  signal-processor order 4-65

start function (I/O) 13-8, 15-20

bit in SCSW for 16-13

initiated by START SUBCHANNEL 14-15

path management for 15-20

pending 16-15, 16-36

START SUBCHANNEL instruction 14-15

See also start function for I/O

count of in measurement block 17-4

defered condition code for (in SCSW) 16-9

function initiated by 15-20

operation-request block (ORB) used by 15-24

state

CPU

  See CPU state

TOD-clock 4-41

state entry 5-82

status

alert 16-17

device 16-24

  effect of clear function on 15-16

  field-validity flag for (in subchannel logout) 16-49

  with inappropriate bit combination 16-50

  device-status check 16-50

  for SIGNAL PROCESSOR 4-65, 10-130

  initial-status interruption

    See initial-status-interruption control

  intermediate 16-18, 16-36

  primary 16-19

  program

    See PSW resulting from signal-processor orders 4-72

  secondary 16-19

  storing of 4-62

    manual key for 12-5

    subchannel 16-24

status-control field (in SCSW) 16-17

status modifier (device status)

  effect of in command chaining 15-63

status pending 16-19

status-verification facility 17-22

STC (STORE CHARACTER) instruction 7-329

STCH (STORE CHARACTER HIGH) instruction 7-329

STCK (STORE CLOCK) instruction 7-330

STCKC (STORE CLOCK COMPARATOR) instruction 7-331

STCKE (STORE CLOCK EXTENDED) instruction 7-331

STCKF (STORE CLOCK FAST) instruction 7-330

STCM (STORE CHARACTERS UNDER MASK) instruction 7-329

examples A-32

STCMH (STORE CHARACTERS UNDER MASK) instruction 7-329

STCMY (STORE CHARACTERS UNDER MASK) instruction 7-329

STCPS (STORE CHANNEL PATH STATUS) instruction 14-16

STCRW (STORE CHANNEL REPORT WORD) instruction 14-17

STCTG (STORE CONTROL) instruction 10-131

STCTL (STORE CONTROL) instruction 10-131

STCY (STORE CHARACTER) instruction 7-329

STD

See segment-table designation

STD (STORE) floating-point-support instruction 9-48

STDY (STORE) floating-point-support instruction 9-49
STE (STORE) floating-point-support instruction 9-48
STF (STORE) floating-point-support instruction 9-49
STFH (STORE HIGH) instruction 7-335
STFL (STORE FACILITY LIST) instruction 10-134
STFL facility list 3-72
STFL (STORE FACILITY LIST EXTENDED) instruction 7-333
STFPC (STORE FPC) floating-point-support instruction 9-49
STGF (STORE) binary instruction 7-327
STGRL (STORE RELATIVE LONG) instruction 7-328
STG (STORE) binary instruction 7-327
STH (STORE HALFWORD) instruction 7-334
STHH (STORE HALFWORD HIGH) instruction 7-334
STHHRL (STORE HALFWORD RELATIVE LONG) instruction 7-334
STIDP (STORE CPU ID) instruction 10-132
STL (segment-table length) 3-39
STM (STORE MULTIPLE) instruction 7-335
STMG (STORE MULTIPLE) instruction 7-335
STMH (STORE MULTIPLE HIGH) instruction 7-335
STNSM (STORE THEN AND SYSTEM MASK) instruction 10-158
STO (segment-table origin) 3-39
STOC (STORE ON CONDITION) instruction 7-336
STOCFH (STORE HIGH ON CONDITION) binary instruction 7-336
STOCG (STORE ON CONDITION) instruction 7-336
stop
  function 4-2
  key 12-5
  signal-processor order 4-65
stop and store status (signal-processor order) 4-65
stopped (signal-processor status) 4-74
stopped state
  of CPU 4-2
  effect on completion of store operations 5-121
of TOD clock 4-42
storage 3-1, 3-40
  absolute 3-4
  address wraparound
  See wraparound
  addressing 3-2
  See also address
  alteration
    space-control bit 4-25
    alteration manual controls 12-2
    alteration PER event 4-33
    bits for 3-40
    mask for 4-24
    assigned locations in 3-68
    auxiliary 3-2, 3-35
    block 3-4
    testing for usability of 10-161
    buffer (cache) 3-2
    clearing of
      See clearing operation
    concurrency of access for references to 5-124
    configuration of 3-4
    direct-access 3-2
    display 12-2
    error 11-18
      indirect 11-19
    expanded 2-2
    failing address in
      See failing-storage address
    interlocked update 5-121, 5-122
    interlocks for virtual references 5-113
    main 3-2
    noninterlocked update of 5-122
    nonvolatile 3-2
    operand 5-9
      reference to (fetch, store, update) 5-121
      update reference 5-122
      operand consistency 5-123
    examples A-49, A-51
    prefixing for 3-18
    real 3-5
    sequence of references to 5-111
    for floating-point data 9-8
    size
      notation for xxvi
      validation of 11-7
    virtual 3-35
    volatile 3-2
    effect of power-on reset on 4-61
    storage-access code (in subchannel logout) 16-50
    storage-alteration-event bit 4-25
    storage-alteration-event-control bit 3-40
    home 3-42
    primary 3-40
    secondary 3-41
    storage-area designation
      for PER events 4-31
    storage degradation (machine-check condition) 11-19
    storage key 3-9
    error in 11-19
    sequence of references to 5-118
    testing for usability of 10-161
    validation of 11-7
    storage-key function 1-28
    storage-logical-validity bit 11-21
storage protection 3-10
during tracing 4-23
storage-protection-override-control bit 3-12
storage reconfiguration 1-28
storage sharing
by address spaces 3-35
by CPUs and the channel subsystem 3-4
examples A-45
in multiprocessing 4-63
STORE ACCESS MULTIPLE instructions 7-328
STORE binary instructions 7-327
STORE CHANNEL PATH STATUS instruction 14-16
STORE CHANNEL REPORT WORD instruction 14-17
channel-report word (CRW) stored by 17-26
STORE CHARACTER HIGH instruction 7-329, 7-334
STORE CHARACTER instructions 7-329
STORE CHARACTERS UNDER MASK instruction 7-329
examples A-32
STORE CLOCK COMPARATOR instruction 10-131
STORE CLOCK EXTENDED instruction 7-331
store-clock-fast facility 1-23, 4-22
facility indication 4-76
STORE CLOCK FAST instruction 7-330
STORE CLOCK instruction 7-330
STORE CONTROL instruction 10-131
STORE CPU ADDRESS instruction 10-132
store-CPU-counter-multiple facility
facility indication 4-78
STORE CPU ID instruction 10-132
STORE CPU TIMER instruction 10-133
store-facility-list-extended facility 1-23
facility indication 4-76
STORE FACILITY LIST EXTENDED instruction 7-333
STORE FACILITY LIST instruction 10-134
STORE floating-point-support instructions 9-48
STORE FPC floating-point-support instruction 9-49
STORE HALFWORD HIGH instruction 7-334
STORE HALFWORD instructions 7-334
STORE HALFWORD RELATIVE LONG instruction 7-334
STORE HIGH instruction 7-335
STORE HIGH ON CONDITION instructions 7-336
store-hypervisor-information facility
facility indication 4-77
STORE MULTIPLE HIGH instruction 7-335
STORE MULTIPLE instruction
example A-32
STORE MULTIPLE instructions 7-335
STORE ON CONDITION instructions 7-336
STORE PAIR TO QUADWORD instruction 7-337
STORE PREFIX instruction 10-134
STORE REAL ADDRESS instruction 10-134
store reference 5-121
access exceptions for 6-48
STORE RELATIVE LONG instructions 7-328
STORE REVERSED instructions 7-337
store status 4-62
key 12-5
signal-processor order for 4-65
store-status architectural-mode identification 3-70
store status at address (signal-processor order) 4-66
STORE SUBCHANNEL instruction 14-18
STORE SYSTEM INFORMATION instruction 10-135
STORE THEN AND SYSTEM MASK instruction 10-158
STORE THEN OR SYSTEM MASK instruction 10-158
store using real address (PER event) 4-34
store-using-real-address-event mask 4-24
STORE USING REAL ADDRESS instruction 10-159
STOSM (STORE THEN OR SYSTEM MASK) instruction 10-158
STP clock source error (machine-check condition) 11-22
STP sync check (machine-check condition) 11-22
STP-timing-alert condition
See timing alert
STPQ (STORE PAIR TO QUADWORD) instruction 7-337
STPT (STORE CPU TIMER) instruction 10-133
STPX (STORE PREFIX) instruction 10-134
STRAG (STORE REAL ADDRESS) instruction 7-337
streaming-mode control 15-25
string of interruptions 4-3, 6-55
caused by clock comparator 4-54
caused by CPU timer 4-55
STRV (STORE REVERSED) instruction 7-337
STRVG (STORE REVERSED) instruction 7-337
STRVH (STORE REVERSED) instruction 7-337
STSC (STORE SUBCHANNEL) instruction 14-18
STSI (STORE SYSTEM INFORMATION) instruction 10-135
STURA (STORE USING REAL ADDRESS) instruction 10-159
STURG (STORE USING REAL ADDRESS) instruction 10-159
STY (STORE) binary instruction 7-327
SU (SUBTRACT UNNORMALIZED) HFP instruction 18-25
subchannel
active allegiance for 15-13
dedicated allegiance for 15-13
effect of I/O-system reset on 17-15
idle 16-14
working allegiance for 15-12
subchannel-active bit 16-16, 16-36
subchannel addressing 13-5
subchannel control information in SCSW 16-12, 16-35
subchannel enabled bit in PMCW 15-3
subchannel-information block

See SCHIB
subchannel key 15-25, 15-30, 16-9
used as access key 3-11
used for IPL 17-17
subchannel key check (in subchannel logout) 16-47
subchannel logout 16-47
subchannel number 13-5
subchannel operation mode
command mode 13-9
transport mode 13-9
subchannel-set identifier

See SSID
Subchannel sets 13-2
subchannel status 16-24, 16-39
subchannel-status word

See SCSW
subchannels 13-2
subclass-mask bits
I/O-interruption

See I/O-interruption subclass mask
external-interruption 6-11
machine-check 11-24
subnormal numbers
class of DFP data 20-6
subroutine linkage 5-14
subspace-active bit 5-68
subspace-AST-entry origin (SSASTEO) 5-68
subspace-AST-entry sequence number (SSASTESN) 5-68
subspace-group control 3-39
subspace-group-control bit
primary 3-39
secondary 3-41
subspace groups
introduction to 5-17
subspace-replacement
exceptions 6-54
operations 5-71
subsystem-identification word 14-1
subsystem-identification word (SID)
assigned storage locations for 3-72
subsystem-linkage-control bit 5-29, 5-35, 5-36
subsystem reset 4-60
SUBTRACT BFP instructions 19-40
SUBTRACT binary instructions 7-338
SUBTRACT DECIMAL instruction 8-13
SUBTRACT DFP instructions 20-54
SUBTRACT HALFWORD instructions 7-339
SUBTRACT HIGH instruction 7-339
SUBTRACT LOGICAL HIGH instructions 7-341
SUBTRACT LOGICAL IMMEDIATE instructions 7-340
SUBTRACT LOGICAL instructions 7-339
SUBTRACT LOGICAL WITH BORROW instructions 7-341
SUBTRACT NORMALIZED

See SUBTRACT BFP instructions
SUBTRACT NORMALIZED HFP instructions 18-24
SUBTRACT UNNORMALIZED HFP instructions 18-25
successful-branching PER event 4-32
mask for 4-24
SUPERVISOR CALL instruction 7-342
supervisor-call interruption 6-54
supervisor state 4-5
support functions (I/O) 17-1
suppress-length-indication flag in CCW

See SLI
suppress-suspended-interruption control (I/O) 15-27, 16-12
used for IPL 17-17
suppression
exceptions to 5-26
of instruction execution 5-22
of unit of operation 5-25
suppression on protection 3-14
SUR (SUBTRACT UNNORMALIZED) HFP instruction 18-25
suspend control 15-25
suspend-control bit 16-9
used for IPL 17-17
suspend flag in CCW 15-32
invalid 16-27
suspend function 13-11
suspended bit (in SCSW) 16-17, 16-36
suspension of channel-program execution 15-73

effect on DCTI of 15-75
intermediate interruption condition for 16-18
SVC (SUPERVISOR CALL) instruction 7-342
SW (SUBTRACT UNNORMALIZED) HFP instruction 18-25
swapping
by COMPARE (DOUBLE) AND SWAP
instructions 7-127
by EXCLUSIVE OR instruction 7-213
SWR (SUBTRACT UNNORMALIZED) HFP instruction 18-25
SX (segment index) 3-36
SXBR (SUBTRACT) BFP instruction 19-40
SXR (SUBTRACT NORMALIZED) HFP instruction 18-24
SXTR (SUBTRACT) DFP instruction 20-54
SXTRA (SUBTRACT) DFP instruction 20-54
SY (SUBTRACT) binary instruction 7-338
symbol translation use by VTAM 7-160
symbol-translation-option bit 7-155
synchronization checkpoint 11-3
of CPU timer with TOD clock 4-54
of TOD clocks 4-42, 4-47
synchronization control 15-26
synchronous machine-check-interruption conditions 11-17
system manual control of 12-1
organization of 2-1
system check stop 11-10
system damage 11-15
system mask (in PSW) 4-4
validity bit for 11-20
system recovery 11-15
system reset I/O
See I/O-system reset
See reset
system-reset-clear key 12-6
system-reset-normal key 12-6
System/360 and System/370 I/O interface
See parallel-I/O interface

T (tera) xxvi

T (tera) xxvi

table of powers of 2 G-1
table-type bits 3-44, 3-47
in region-table entry 3-44
in segment-table entry 3-47
tables
ASN
See ASN first table, ASN second table
authority
See authority table
DAT
See page table, segment table, region table
table entry
See entry table
linkage
See linkage tables
page
See page table
region
See region table

segment
See segment table
translation 3-42
TABORT (TRANSACTION ABORT) instruction 7-344
TAI (International Atomic Time) related to UTC 4-45
TAM (TEST ADDRESSING MODE) instruction 7-342
TAR (TEST ACCESS) instruction 10-159
target instruction 7-214
target-precision-constrained rounding 9-12
TB (TEST BLOCK) instruction 10-161
TBDR (CONVERT HFP TO BFP) floating-point-support instruction 9-28
TBDER (CONVERT HFP TO BFP) floating-point-support instruction 9-28
TBEGIN (TRANSACTION BEGIN) instruction 7-345
TBEGINC (TRANSACTION BEGIN CONSTRAINED) instruction 7-349
TCDB (TEST DATA CLASS) BFP instruction 19-41
TCEB (TEST DATA CLASS) BFP instruction 19-41
dcw (device-command word) 15-38
TCW (transport-command word) 15-33
contents of 15-33
TCW channel program 13-7
TCW (transport-command word)
chaining 15-63
TCXB (TEST DATA CLASS) BFP instruction 19-41
TDCDT (TEST DATA CLASS) DFP instruction 20-55
TDCET (TEST DATA CLASS) DFP instruction 20-55
TDCXT (TEST DATA CLASS) DFP instruction 20-55
TDGDT (TEST DATA GROUP) DFP instruction 20-56
TDGET (TEST DATA GROUP) DFP instruction 20-56
TDGX (TEST DATA GROUP) DFP instruction 20-56
TEND (TRANSACTION END) instruction 7-351
termination
of I/O operations
See conclusion of I/O operations
of instruction execution 5-23
for exigent machine-check conditions 11-10
of unit of operation 5-25
for exigent machine-check conditions 11-10
termination code (in subchannel logout) 16-50
field-validity flag for 16-49
TEST ACCESS instruction 10-159
TEST ADDRESSING MODE instruction 7-342
TEST AND SET instruction 7-342
TEST BLOCK instruction 10-161
TEST DATA CLASS BFP instructions 19-41
TEST DATA CLASS DFP instructions 20-55
TEST DATA GROUP DFP instructions 20-56
TEST DECIMAL instruction 8-14
test indicator 12-6
TEST PENDING INTERRUPTION instruction 14-19
  interruption code stored by 14-20
TEST PROTECTION instruction 10-163
TEST SUBCHANNEL instruction 14-21
  interruption-response block (IRB) used by 16-6
TEST UNDER MASK HIGH instruction 7-343
TEST UNDER MASK instruction 7-343
  examples A-33
TEST UNDER MASK LOW instruction 7-343
testing for storage-block and storage-key usability 10-161
THDER (CONVERT BFP TO HFP) floating-point-support instruction 9-27
THDR (CONVERT BFP TO HFP) floating-point-support instruction 9-27
thread
  identification (ID) 2-3, 4-63, 4-64, 4-70, 12-3, 12-7
  program-specified maximum 2-3, 4-63, 4-64, 4-69, 4-70, 12-3
  width 4-63, 4-64
  multithreading 2-3
TIC (transfer in channel) 15-77
  invalid sequence of 16-27
TID
  See thread identification
TID width
  See thread identification width
ties 9-13
time-of-day clock
  See TOD clock
timer
  See CPU timer
timing
  channel-subsystem 17-2
timing alert
  external interruption 6-13
timing facilities 4-41
timing-facility bit (in PMCW) 15-4
timing-facility damage 11-15
  for TOD clock 4-42
timing-alert condition
  ETR-timing-alert condition 6-14
  STP-timing-alert condition 6-14
TLB (translation-lookaside buffer) 3-58
  entries 3-59
    attachment of 3-59
    clearing of 3-62
    effect of translation changes on 3-62
    usable state 3-60
TM (TEST UNDER MASK) instruction 7-343
  examples A-33
TMH (TEST UNDER MASK HIGH) instruction 7-343
TMHH (TEST UNDER MASK) instruction 7-343
TML (TEST UNDER MASK LOW) instruction 7-343
TMLH (TEST UNDER MASK) instruction 7-343
TMLL (TEST UNDER MASK) instruction 7-343
TMY (TEST UNDER MASK) instruction 7-343
TOD clock 4-41
  effect of power-on reset on 4-61
  effect on clock-comparator interruption 6-11
  effect on CPU-timer decrementing 4-54
  effect on CPU-timer interruption 6-12
  manual control of 4-42, 12-6
  offset-based steering
    overview 4-49
  steering 4-48
    episodes 4-50
    facility indication 4-76
    hardware based 4-48
      overview 4-49
    offset based 4-48
      overview 4-49
    offset update events 4-49
    registers 4-50
    UTC information block (UIB) 4-51
    unique values of 4-43
    validation of 11-9
    value in trace entry 4-22
TOD-clock-control-override control 4-42
TOD-clock programmable field 4-45
TOD-clock programmable register 4-45
  save areas for 3-75
  validity bit for 11-21
TOD-clock-steering facility 1-23
TOD-clock-sync-control bit 4-42, 4-47
TOD-clock-synchronization facility 4-47
TP (TEST DECIMAL) instruction 8-14
TPI (TEST PENDING INTERRUPTION) instruction 14-19
  interruption code stored by 14-20
TP (TEST DECIMAL) instruction 10-163
TR (TRANSLATE) instruction 7-352
  example A-33
trace 4-10
  entries 4-12
  entry address 4-12
  exceptions 6-54
  table exception 6-43
TRACE instruction 10-166
  trace entry for 4-21
TRACG (TRACE) instruction 10-166
transaction
definition of 5-92
transaction abort code
  in the transaction diagnostic block 5-96
TRANSACTION ABORT instruction 7-344
transaction-abort PSW 5-94
TRANSACTION BEGIN CONSTRAINED instruction 7-349
TRANSACTION BEGIN instruction 7-345, 7-349
processing of 7-346, 7-349
transaction constraint exception 6-43
transaction diagnostic block
  aborted-transaction-instruction-address field 5-96
  breaking-event-address field 5-97
  conflict-token field 5-96
  data-exception-code field 5-97
  exception-access-identification field 5-97
  flags field 5-96
  for a program interruption 3-75, 3-79
  format field 5-95
  program-interruption-identification field 5-97
  transaction-abort-code field 5-96
  transaction-nesting-depth field 5-96
  translation-exception-identification field 5-97
transaction-diagnostic-block address 5-94
transaction diagnostic control
  in control register 2 5-93
transaction diagnostic scope
  in control register 2 5-93
TRANSACTION END instruction 7-351
transaction-end PER event
  mask for 4-24
transaction initiation 5-100
transaction nesting depth 5-94
  in the transaction diagnostic block 5-96
transactional access 5-92
transactional execution
  abort 5-90
  and breaking events 4-40
  and PER events 4-26, 4-37
  commit 5-91
  conflict 5-91
  constrained transaction 5-91
  constrained transaction-execution mode 5-91
  controls 5-93
  effects on CPU serialization 5-128
  nested transaction 5-91, 5-92
  nonconstrained transaction 5-92
  nonconstrained transaction-execution mode 5-92
  outer transaction 5-92
  outermost transaction 5-92
  program-interruption filtering 5-92
  restricted instruction
    tracing 4-23
  transaction
  exception identification 3-70, 3-71
  lookaside buffer
    See TLB
  PC-number 5-34
  specification exception 6-44
  tables for 3-42
  translation exception identification
    in the transaction diagnostic block 5-97
  translation modes 3-37
  translation parameters 3-37
  translation path 3-59
TCCB (transport-command-control block) 15-36
transport-command control block
  See TCCB
transport-command word
See TCW
transport-status block
See TSB
trap action
IEEE 9-18
trap control block 10-168
TRAP instruction 10-167
trap save area 10-169
TRAP2 (TRAP) instruction 10-167
TRAP4 (TRAP) instruction 10-167
TRE (TRANSLATE EXTENDED) instruction 7-359
tree structure for sorting 7-368
trial execution
for editing instructions and TRANSLATE instruction 5-27
for PER 4-27
trimodal addressing 5-10, 7-7
TROO (TRANSLATE ONE TO ONE) instruction 7-361
TROT (TRANSLATE ONE TO TWO) instruction 7-361
TRT (TRANSLATE AND TEST) instruction 7-353
two's complement binary notation 7-4
integer 7-4
examples A-3
TRTO (TRANSLATE TWO TO ONE) instruction 7-361
TRTR (TRANSLATE AND TEST REVERSE) instruction 7-358
TRTT (TRANSLATE TWO TO TWO) instruction 7-361
true zero (HFP number) 18-1
TS (TEST AND SET) instruction 7-342
TSB (transport-status block) 15-47
address of 15-35
contents of 15-49, 15-56
TSCH (TEST SUBCHANNEL) instruction 14-21
two's complement binary notation 7-4
examples A-2
type of PROGRAM CALL 5-38

U
UIB
See UTC information block 4-51
ulp (unit in the last place) 9-7, 9-8, 19-3
underflow
See exponent underflow
unit check (device status)
in establishing dedicated allegiance 15-13
unit of operation 5-24
unlock A-47
two's complement binary notation 7-4
example with FIFO queuing A-50
two's complement binary notation 7-4
example with LIFO queuing A-49
unnormalized floating-point number 18-2

HFP data only 9-4
unordered (comparison to a NaN) 9-24
UNPACK ASCII instruction 7-367
UNPACK instruction 7-366
example A-35
UNPACK UNICODE instruction 7-367
UNPK (UNPACK) instruction 7-366
example A-35
UNPKA (PACK ASCII) instruction 7-367
UNPKU (PACK UNICODE) instruction 7-367
unprivileged instructions 4-5, 7-3
unsigned binary
arithmetic 7-6
integer 7-4
examples A-3
in address generation 5-11
unsigned binary integer
conversion to floating point 19-21
unsigned-packed-decimal format 8-2
used in DFP formatting instructions 20-8
unsigned scaling exponent (α) 9-12
unsolicited interruption condition (I/O) 16-3
unstack-suppression bit 5-80
unstacking process 5-87
update reference 5-122
UPDATE TREE instruction 7-368
example A-53
UPT (UPDATE TREE) instruction 7-368
example A-53
usable ALB entry 5-66
UTC (Coordinated Universal Time) used in TOD epoch 4-45
UTC information block (UIB) 4-51

V
VA (VECTOR ADD) vector instruction 22-3
VAC (VECTOR ADD WITH CARRY) vector instruction 22-4
VACCC (VECTOR ADD WITH CARRY COMPUTE CARRY) vector instruction 22-5
valid ART-table entry 5-66
valid CBC 11-2
valid floating-point-register numbers 9-9
valid region-table, segment-table, or page-table entry 3-59
validation 11-6
of registers 11-9
of storage 11-7
of storage key 11-7
of TOD clock 11-9
validity bit for backward stack-entry address 5-81
validity bit for forward-section-header address 5-82
validity bits
  in machine-check-interruption code 11-19
  in subchannel logout 16-49
variable-length field 3-3
VAVG (VECTOR AVERAGE) vector instruction 22-5
VAVGL (VECTOR AVERAGE LOGICAL) vector instruction 22-6
VCDG (VECTOR FP CONVERT FROM FIXED 64-BIT) vector instruction 24-13
VCDLG (VECTOR FP CONVERT FROM LOGICAL 64-BIT) vector instruction 24-15
VCEQ (VECTOR COMPARE EQUAL) vector instruction 22-7
VCGD (VECTOR FP CONVERT TO FIXED 64-BIT) vector instruction 24-16
VCH (VECTOR COMPARE HIGH) vector instruction 22-8
VCHL (VECTOR COMPARE HIGH LOGICAL) vector instruction 22-9
VCKSM (VECTOR CHECKSUM) vector instruction 22-6
VCLGD (VECTOR FP CONVERT TO LOGICAL 64-BIT) vector instruction 24-18
VCLZ (VECTOR COUNT LEADING ZEROS) vector instruction 22-10
VCTZ (VECTOR COUNT TRAILING ZEROS) vector instruction 22-10
VEC (VECTOR ELEMENT COMPARE) vector instruction 22-7
VECL (VECTOR ELEMENT COMPARE LOGICAL) vector instruction 22-7
vector registers 2-5
  validity bit for 11-20
VECTOR ADD COMPUTE CARRY vector instruction 22-4
VECTOR ADD vector instruction 22-3
VECTOR ADD WITH CARRY COMPUTE CARRY vector instruction 22-5
VECTOR ADD WITH CARRY vector instruction 22-5
VECTOR AND vector instruction 22-5
VECTOR AND WITH COMPLEMENT vector instruction 22-5
VECTOR AVERAGE LOGICAL vector instruction 22-6
VECTOR AVERAGE vector instruction 22-5
VECTOR CHECKSUM vector instruction 22-6
VECTOR COMPARE EQUAL vector instruction 22-7
VECTOR COMPARE HIGH LOGICAL vector instruction 22-9
VECTOR COMPARE HIGH vector instruction 22-8
VECTOR COUNT LEADING ZEROS vector instruction 22-10
VECTOR COUNT TRAILING ZEROS vector instruction 22-10
VECTOR ELEMENT COMPARE LOGICAL vector instruction 22-7
VECTOR ELEMENT COMPARE vector instruction 22-7
VECTOR ELEMENT ROTATE AND INSERT UNDER MASK vector instruction 22-20
VECTOR ELEMENT ROTATE LEFT LOGICAL vector instruction 22-19
VECTOR ELEMENT SHIFT LEFT vector instruction 22-21
VECTOR ELEMENT SHIFT RIGHT ARITHMETIC vector instruction 22-22
VECTOR ELEMENT SHIFT RIGHT LOGICAL vector instruction 22-22
vector exception code (VXC) 6-19
VECTOR EXCLUSIVE OR vector instruction 22-11
vector facility for z/Architecture
  facility indication 4-78
vector facility for z/architecture 1-23
VECTOR FIND ANY ELEMENT EQUAL vector instruction 23-1
VECTOR FIND ELEMENT EQUAL vector instruction 23-3
VECTOR FIND ELEMENT NOT EQUAL vector instruction 23-4
VECTOR FP ADD vector instruction 24-3
VECTOR FP COMPARE AND SIGNAL SCALAR vector instruction 24-8
VECTOR FP COMPARE EQUAL vector instruction 24-9
VECTOR FP COMPARE HIGH OR EQUAL vector instruction 24-12
VECTOR FP COMPARE HIGH vector instruction 24-10
VECTOR FP COMPARE SCALAR vector instruction 24-7
VECTOR FP CONVERT FROM FIXED 64-BIT vector instruction 24-13
VECTOR FP CONVERT FROM LOGICAL 64-BIT vector instruction 24-15
VECTOR FP CONVERT TO FIXED 64-BIT vector instruction 24-16
VECTOR FP CONVERT TO LOGICAL 64-BIT vector instruction 24-18
VECTOR FP DIVIDE vector instruction 24-20
VECTOR FP LOAD LENGTHENED vector instruction 24-24
VECTOR FP LOAD ROUNDED vector instruction 24-25
VECTOR FP MULTIPLY AND ADD vector instruction 24-27
VECTOR FP MULTIPLY AND SUBTRACT vector instruction 24-27
VECTOR FP MULTIPLY vector instruction 24-26
VECTOR FP PERFORM SIGN OPERATION vector instruction 24-29
VECTOR FP SQUARE ROOT vector instruction 24-30
VECTOR FP SUBTRACT vector instruction 24-31
VECTOR FP TEST DATA CLASS IMMEDIATE vector instruction 24-31
VECTOR GALOIS FIELD MULTIPLY SUM AND ACCUMULATE vector instruction 22-11
VECTOR GALOIS FIELD MULTIPLY SUM vector instruction 22-11
VECTOR GATHER ELEMENT vector instruction 21-4
VECTOR GENERATE BYTE MASK vector instruction 21-4
VECTOR GENERATE MASK vector instruction 21-4
VECTOR ISOLATE STRING vector instruction 23-5
VECTOR LOAD AND REPLICATE vector instruction 21-5
VECTOR LOAD COMPLEMENT vector instruction 22-12
VECTOR LOAD ELEMENT IMMEDIATE vector instruction 21-6
VECTOR LOAD ELEMENT vector instruction 21-6
VECTOR LOAD FP INTEGER vector instruction 24-22
VECTOR LOAD GR FROM VR ELEMENT vector instruction 21-7
VECTOR LOAD LOGICAL ELEMENT AND ZERO vector instruction 21-7
VECTOR LOAD MULTIPLE vector instruction 21-8
VECTOR LOAD POSITIVE vector instruction 22-12
VECTOR LOAD TO BLOCK BOUNDARY vector instruction 21-8
VECTOR LOAD vector instruction 21-5
VECTOR LOAD VR ELEMENT FROM GR vector instruction 21-9
VECTOR LOAD VR FROM GRS DISJOINT vector instruction 21-9
VECTOR LOAD WITH LENGTH vector instruction 21-10
VECTOR MAXIMUM LOGICAL vector instruction 22-13
VECTOR MAXIMUM vector instruction 22-13
VECTOR MERGE HIGH vector instruction 21-10
VECTOR MERGE LOW vector instruction 21-10
VECTOR MINIMUM LOGICAL vector instruction 22-13
VECTOR MINIMUM vector instruction 22-13
VECTOR MULTIPLY AND ADD EVEN vector instruction 22-15
VECTOR MULTIPLY AND ADD HIGH vector instruction 22-14
VECTOR MULTIPLY AND ADD LOGICAL EVEN vector instruction 22-15
VECTOR MULTIPLY AND ADD LOGICAL vector instruction 22-15
VECTOR MULTIPLY AND ADD LOGICAL ODD vector instruction 22-16
VECTOR MULTIPLY AND ADD LOW vector instruction 22-14
VECTOR MULTIPLY AND ADD ODD vector instruction 22-16
VECTOR MULTIPLY EVEN vector instruction 22-17
VECTOR MULTIPLY HIGH vector instruction 22-16
VECTOR MULTIPLY LOGICAL EVEN vector instruction 22-18
VECTOR MULTIPLY LOGICAL HIGH vector instruction 22-16
VECTOR MULTIPLY LOGICAL ODD vector instruction 22-18
VECTOR MULTIPLY LOW vector instruction 22-17
VECTOR MULTIPLY ODD vector instruction 22-18
VECTOR NOR vector instruction 22-19
VECTOR OR vector instruction 22-19
VECTOR PACK LOGICAL SATURATE vector instruction 21-12
VECTOR PACK SATURATE vector instruction 21-11
VECTOR PACK vector instruction 21-11
VECTOR PERMUTE DOUBLEWORD IMMEDIATE vector instruction 21-13
VECTOR PERMUTE vector instruction 21-13
VECTOR POPULATION COUNT vector instruction 22-19
VECTOR REPLICATE IMMEDIATE vector instruction 21-14
VECTOR REPPLICATE vector instruction 21-14
VECTOR SCATTER ELEMENT vector instruction 21-15
VECTOR SELECT vector instruction 21-15
VECTOR SHIFT LEFT BY BYTE vector instruction 22-15
VECTOR SHIFT LEFT DOUBLE BY BYTE vector instruction 22-23
VECTOR SHIFT LEFT vector instruction 22-23
VECTOR SHIFT RIGHT ARITHMETIC BY BYTE vector instruction 22-24
VECTOR SHIFT RIGHT ARITHMETIC vector instruction 22-24
VECTOR SHIFT RIGHT LOGICAL BY BYTE vector instruction 22-24
VECTOR SHIFT RIGHT LOGICAL vector instruction 22-24
VECTOR SIGN EXTEND TO DOUBLEWORD vector instruction 21-15
VECTOR STORE ELEMENT vector instruction 21-16
VECTOR STORE MULTIPLE vector instruction 21-17
VECTOR STORE vector instruction 21-16
VECTOR STORE WITH LENGTH vector instruction 21-17
VECTOR STRING RANGE COMPARE vector instruction 23-6
VECTOR SUBTRACT COMPUTE BORROW INDICATION vector instruction 22-25
VECTOR SUBTRACT vector instruction 22-25
VECTOR SUBTRACT WITH BORROW COMPUTE BORROW INDICATION vector instruction 22-26
VECTOR SUBTRACT WITH BORROW INDICATION vector instruction 22-26
VECTOR SUM ACROSS DOUBLEWORD vector instruction 22-27
VECTOR SUM ACROSS QUADWORD vector instruction 22-27
VECTOR SUM ACROSS WORD vector instruction 22-27
VECTOR TEST UNDER MASK vector instruction 22-28
VECTOR UNPACK HIGH vector instruction 21-17
VECTOR UNPACK LOGICAL HIGH vector instruction 21-18
VECTOR UNPACK LOGICAL LOW vector instruction 21-19
VECTOR UNPACK LOW vector instruction 21-18
VERIM (VECTOR ELEMENT ROTATE AND INSERT UNDER MASK) vector instruction 22-20
VERLL (VECTOR ELEMENT ROTATE LEFT LOGICAL) vector instruction 22-20
VERLLV (VECTOR ELEMENT ROTATE LEFT LOGICAL) vector instruction 22-19
version code 10-133
VESL (VECTOR ELEMENT SHIFT LEFT) vector instruction 22-21
VESLV (VECTOR ELEMENT SHIFT LEFT) vector instruction 22-21
VESRA (VECTOR ELEMENT SHIFT RIGHT ARITHMETIC) vector instruction 22-22
VESRAV (VECTOR ELEMENT SHIFT RIGHT ARITHMETIC) vector instruction 22-22
VESRL (VECTOR ELEMENT SHIFT RIGHT LOGICAL) vector instruction 22-22
VESRLV (VECTOR ELEMENT SHIFT RIGHT LOGICAL) vector instruction 22-22
VFA (VECTOR FP ADD) vector instruction 24-3
VFAE (VECTOR FIND ANY ELEMENT EQUAL) vector instruction 23-1
VFCE (VECTOR FP COMPARE EQUAL) vector instruction 24-9
VFCH (VECTOR FP COMPARE HIGH) vector instruction 24-10
VFCH (VECTOR FP COMPARE HIGH OR EQUAL) vector instruction 24-12
VFD (VECTOR FP DIVIDE) vector instruction 24-20
VFEE (VECTOR FIND ELEMENT EQUAL) vector instruction 23-3
VFENE (VECTOR FIND ELEMENT NOT EQUAL) vector instruction 23-4
VFI (VECTOR LOAD FP INTEGER) vector instruction 24-22
VFM (VECTOR FP MULTIPLY) vector instruction 24-26
VFMA (VECTOR FP MULTIPLY AND ADD) vector instruction 24-27
VFMS (VECTOR FP MULTIPLY AND SUBTRACT) vector instruction 24-27
VFPSO (VECTOR FP PERFORM SIGN OPERATION) vector instruction 24-29
VFS (VECTOR FP SUBTRACT) vector instruction 24-31
VFSQ (VECTOR FP SQUARE ROOT) vector instruction 24-30
VFICI (VECTOR FP TEST DATA CLASS IMMEDIATE) vector instruction 24-31
VGBM (VECTOR GENERATE BYTE MASK) vector instruction 21-4
VGEF (VECTOR GATHER ELEMENT) vector instruction 21-4
VGEG (VECTOR GATHER ELEMENT) vector instruction 21-4
VGFM (VECTOR GALOIS FIELD MULTIPLY SUM) vector instruction 22-11
VGFM (VECTOR GALOIS FIELD MULTIPLY SUM AND ACCUMULATE) vector instruction 22-11
VGM (VECTOR GENERATE MASK) vector instruction 21-4
view (of floating-point numbers) 9-2
common-rounding-point 9-13
fraction 9-2
left-units view 9-2
right-units view 9-2
virtual address 3-5
virtual machine
extensions for 1-28
virtual storage 3-35
VISTR (VECTOR ISOLATE STRING) vector instruction 23-5
VL (VECTOR LOAD) vector instruction 21-5
VLBB (VECTOR LOAD TO BLOCK BOUNDARY) vector instruction 21-8
VLC (VECTOR LOAD COMPLEMENT) vector instruction 22-12
VLDE (VECTOR FP LOAD LENGTHENED) vector instruction 24-24
VLEB (VECTOR LOAD ELEMENT) vector instruction 21-6
VLED (VECTOR FP LOAD ROUNDED) vector instruction 24-25
VLEF (VECTOR LOAD ELEMENT) vector instruction 21-6
VLEG (VECTOR LOAD ELEMENT) vector instruction 21-6
VLEH (VECTOR LOAD ELEMENT) vector instruction 21-6
VLEIB (VECTOR LOAD ELEMENT IMMEDIATE) vector instruction 21-6
VLEIF (VECTOR LOAD ELEMENT IMMEDIATE) vector instruction 21-6
VLEIG (VECTOR LOAD ELEMENT IMMEDIATE) vector instruction 21-6
VLEIH (VECTOR LOAD ELEMENT IMMEDIATE) vector instruction 21-6
VLGV (VECTOR LOAD GR FROM VR ELEMENT) vector instruction 21-7
VLL (VECTOR LOAD WITH LENGTH) vector instruction 21-10
VLLEZ (VECTOR LOAD LOGICAL ELEMENT AND ZERO) vector instruction 21-7
VLM (VECTOR LOAD MULTIPLE) vector instruction 21-8
VLP (VECTOR LOAD POSITIVE) vector instruction 22-12
VLR (VECTOR LOAD) vector instruction 21-5
VLEREP (VECTOR LOAD AND REPLICATE) vector instruction 21-5
VLVG (VECTOR LOAD VR ELEMENT FROM GR) vector instruction 21-9
VLVGP (VECTOR LOAD VR FROM GRS DISJOINT) vector instruction 21-9
VM-gdata-space facility 1-28
VMAE (VECTOR MULTIPLY AND ADD EVEN) vector instruction 22-15
VMAH (VECTOR MULTIPLY AND ADD HIGH) vector instruction 22-14
VMAL (VECTOR MULTIPLY AND ADD LOW) vector instruction 22-14
VMALE (VECTOR MULTIPLY AND ADD LOGICAL EVEN) vector instruction 22-15
VMALH (VECTOR MULTIPLY AND ADD LOGICAL HIGH) vector instruction 22-15
VMALO (VECTOR MULTIPLY AND ADD LOGICAL ODD) vector instruction 22-16
VMAO (VECTOR MULTIPLY AND ADD ODD) vector instruction 22-16
VME (VECTOR MULTIPLY EVEN) vector instruction 22-17
VMH (VECTOR MULTIPLY HIGH) vector instruction 22-16
VML (VECTOR MULTIPLY LOW) vector instruction 22-17
VMLE (VECTOR MULTIPLY LOGICAL EVEN) vector instruction 22-18
VMLH (VECTOR MULTIPLY LOGICAL HIGH) vector instruction 22-16
VMLO (VECTOR MULTIPLY LOGICAL ODD) vector instruction 22-18
VMN (VECTOR MINIMUM) vector instruction 22-13
VMNL (VECTOR MINIMUM LOGICAL) vector instruction 22-13
VMO (VECTOR MULTIPLY ODD) vector instruction 22-18
VMRH (VECTOR MERGE HIGH) vector instruction 21-10
VMRL (VECTOR MERGE LOW) vector instruction 21-10
VMX (VECTOR MAXIMUM) vector instruction 22-13
VMXL (VECTOR MAXIMUM LOGICAL) vector instruction 22-13
VN (VECTOR AND) vector instruction 22-5
VNC (VECTOR AND WITH COMPLEMENT) vector instruction 22-5
VNO (VECTOR NOR) vector instruction 22-19
VO (VECTOR OR) vector instruction 22-19
volatile storage 3-2
effect of power-on reset on 4-61
voting digit 9-13
VPDI (VECTOR PERMUTE DOUBLEWORD IMMEDIATE) vector instruction 21-13
VPERM (VECTOR PERMUTE) vector instruction 21-13
VPK (VECTOR PACK) vector instruction 21-11
VPKLS (VECTOR PACK LOGICAL SATURATE) vector instruction 21-12
VPKS (VECTOR PACK SATURATE) vector instruction 21-11
VPOPCT (VECTOR POPULATION COUNT) vector instruction 22-19
VREP (VECTOR REPLICATE) vector instruction 22-19
VREPI (VECTOR REPLICATE IMMEDIATE) vector instruction 21-14
VS (VECTOR SUBTRACT) vector instruction 22-25
VSBCBI (VECTOR SUBTRACT WITH BORROW COMPUTE BORROW INDICATION) vector instruction 22-26
VSBI (VECTOR SUBTRACT WITH BORROW INDICATION) vector instruction 22-26
VSCBI (VECTOR SUBTRACT COMPUTE BORROW INDICATION) vector instruction 22-25
VSCEF (VECTOR SCATTER ELEMENT) vector instruction 21-15
VSCEG (VECTOR SCATTER ELEMENT) vector instruction 21-15
VSEG (VECTOR SIGN EXTEND TO DOUBLEWORD) vector instruction 21-15
VSEL (VECTOR SELECT) vector instruction 21-15
VSL (VECTOR SHIFT LEFT) vector instruction 22-23
VSLB (VECTOR SHIFT LEFT BY BYTE) vector instruction 22-23
VSLDB (VECTOR SHIFT LEFT DOUBLE BY BYTE) vector instruction 22-24
VSRA (VECTOR SHIFT RIGHT ARITHMETIC) vector instruction 22-23
VSRAB (VECTOR SHIFT RIGHT ARITHMETIC BY BYTE) vector instruction 22-24
VSRL (VECTOR SHIFT RIGHT LOGICAL) vector instruction 22-24
VSRLB (VECTOR SHIFT RIGHT LOGICAL) vector instruction 22-24
VST (VECTOR STORE) vector instruction 21-16
VSTEB (VECTOR STORE ELEMENT) vector instruction 21-16
VSTEF (VECTOR STORE ELEMENT) vector instruction 21-16
VSTEG (VECTOR STORE ELEMENT) vector instruction 21-16
VSTEH (VECTOR STORE ELEMENT) vector instruction 21-16
VSTL (VECTOR STORE WITH LENGTH) vector instruction 21-17
VSTM (VECTOR STORE MULTIPLE) vector instruction 21-17
VSTRC (VECTOR STRING RANGE COMPARE) vector instruction 23-6
VSUM (VECTOR SUM ACROSS WORD) vector instruction 22-27
VSUMG (VECTOR SUM ACROSS DOUBLEWORD) vector instruction 22-27
VSUMQ (VECTOR SUM ACROSS QUADWORD) vector instruction 22-27
VTAM use of symbol translation 7-160
VTM (VECTOR TEST UNDER MASK) vector instruction 22-28
VUPH (VECTOR UNPACK HIGH) vector instruction 21-17
VUPL (VECTOR UNPACK LOW) vector instruction 21-18
VUPLH (VECTOR UNPACK LOGICAL) vector instruction 21-18
VUPLL (VECTOR UNPACK LOGICAL LOW) vector instruction 21-19
VX (VECTOR EXCLUSIVE OR) vector instruction 22-11
VXC (vector-exception code) 6-19

W
wait indicator 12-6
wait-state bit
in the PSW 4-5
warning (machine-check condition) 11-16
subclass-mask bit for 11-25
warning-track-interruption facility 1-23
WFC (VECTOR FP COMPARE SCALAR) vector instruction 24-7
WFK (VECTOR FP COMPARE AND SIGNAL SCALAR) vector instruction 24-8
word 3-3
word-concurrent storage references 5-124
working allegiance (I/O) 15-12
wraparound
of instruction addresses 5-10
of PER addresses 4-32
of register numbers
for LOAD MULTIPLE instruction 7-238
for STORE MULTIPLE instruction 7-335
of storage addresses 3-7
controlled by addressing mode 3-7
for MOVE INVERSE instruction 7-245
for MOVE LONG EXTENDED instruction 7-250
for MOVE LONG instruction 7-246
for MOVE LONG UNICODE instruction 7-254
for MOVE WITH OPTIONAL SPECIFICATIONS instruction 10-67
of TOD clock 4-41

X
X (EXCLUSIVE OR) instruction 7-212
X field of instruction 5-11
XA (extended architecture)
See 370-XA architecture
XC (EXCLUSIVE OR) instruction 7-213
examples A-20
XG (EXCLUSIVE OR) instruction 7-212
XGR (EXCLUSIVE OR) instruction 7-212
XI (EXCLUSIVE OR) instruction 7-213
example A-21
XIHF (EXCLUSIVE OR IMMEDIATE) instruction 7-214
XILF (EXCLUSIVE OR IMMEDIATE) instruction 7-214
XIY (EXCLUSIVE OR) instruction 7-213
XR (EXCLUSIVE OR) instruction 7-212
XRK (EXCLUSIVE OR) binary instruction 7-212
XSCH (CANCEL SUBCHANNEL) instruction 14-3  
XY (EXCLUSIVE OR) instruction 7-212

Z
Z bit (zero condition-code bit) 16-12  
as cause of intermediate interruption condition 16-18
z/Architecture architecture  
additions to 1-2, 1-7  
original highlights of 1-2
ZAP (ZERO AND ADD) instruction 8-14  
example A-41
zero  
instruction-length code 6-7  
negative

See negative zero  
normal meaning for byte value xxvii  
setting floating-point register to 9-35  
true (HFP number) 18-1  
zero-address-detection PER event mask for 4-24
ZERO AND ADD instruction 8-14  
example A-41
zero condition code (Z bit in SCSW) 16-12  
zero-padding control 7-155
zone bits 8-1  
moving of 7-259
zoned decimal numbers 8-1  
zoned-decimal numbers  
examples A-4
Communicating Your Comments to IBM

Title: IBM z/Architecture Principles of Operation

Publication No: SA22-7832-10

If you especially like or dislike anything about this book, please use one of the methods listed below to send your comments to IBM. Whichever method you choose, make sure you send your name, address, and telephone number if you would like a reply.

Feel free to comment on specific errors or omissions, accuracy, organization, subject matter, or completeness of this book. However, the comments you send should pertain to only the information in this manual and the way in which the information is presented. To request additional publications, or to ask questions or make comments about the functions of IBM products or systems, you should talk to your IBM representative or to your IBM authorized remarketer.

When you send comments to IBM, you grant IBM a nonexclusive right to use or distribute your comments in any way it believes appropriate without incurring any obligation to you.

If you are mailing a reader's comment form (RCF) from a country other than the United States, you can give the RCF to the local IBM branch office or IBM representative for postage-paid mailing.

- If you prefer to send comments by mail, use the RCF at the back of this book.
- If you prefer to send comments by FAX, use this number:
  - FAX: (International Access Code)+1+845+432-9405
- If you prefer to send comments electronically, use one of these network IDs:
  - Internet e-mail: mhvrdfs@us.ibm.com

Make sure to include the following in your note:

- Title and publication number of this book
- Page number or topic to which your comment applies

Optionally, if you include your telephone number, we will be able to respond to your comments by phone.
Reader's Comments — We'd Like to Hear from You

Title: IBM z/Architecture Principles of Operation
Publication No: SA22-7832-10

You may use this form to communicate your comments about this publication, its organization, or subject matter, with the understanding that IBM may use or distribute whatever information you supply in any way it believes appropriate without incurring any obligation to you. Your comments will be sent to the author's department for whatever review and action, if any, are deemed appropriate.

Note: Copies of IBM publications are not stocked at the location to which this form is addressed. Please direct any requests for copies of publications, or for assistance in using your IBM system, to your IBM representative or to the IBM branch office serving your locality.

Today's date: _______________________________

What is your occupation?

Newsletter number of latest Technical Newsletter (if any) concerning this publication:

How did you use this publication?

[ ] As an introduction [ ] As a text (student)

[ ] As a reference manual [ ] As a text (instructor)

[ ] For another purpose (explain)

Is there anything you especially like or dislike about the organization, presentation, or writing in this manual? Helpful comments include general usefulness of the book; possible additions, deletions, and clarifications; specific errors and omissions.

Page Number: Comment:

Name
Company or Organization
Phone No.

Address
Reader's Comments — We'd Like to Hear from You
SA22-7832-10