

Series/1

GA34-0021-1 File No. S1-01







GA34-0021-1 File No. S1-01

IBM Series/1 Model 5 4955 Processor and Processor Features Description

#### Second Edition (March 1977)

This is a major revision of, and obsoletes GA34-0021-0. Significant changes in this new edition include (1) rearrangement of the chapters to provide a more logical flow of information and (2) removal of certain information (four chapters) that is now included in other publications.

Changes are periodically made to the information herein; any such changes will be reported in subsequent revisions or Technical Newsletters. Before using this publication in connection with the operation of IBM systems, have your IBM representative confirm editions that are applicable and current.

Requests for copies of IBM publications should be made to your IBM representative or the IBM branch office serving your locality.

A form for readers' comments is provided at the back of this publication. If the form has been removed, send your comments to IBM Corporation, Systems Publications, Department 27T, P.O. Box 1328, Boca Raton, Florida 33432. Comments become the property of IBM.

©Copyright International Business Machines Corporation 1976, 1977

ii GA34-0021

# Contents

Preface vii Summary of Publication vii Related Publications viii

Chapter 1. Introduction 1-1 IBM 4955 Processor 1-1 Processor Optional Features/Storage Addition 1-1 Processor Description 1-1 Input/Output Units and Features 1-5 Communications Features 1-5 Sensor Input/Output Options 1-5 Packaging and Power Options 1-5 Other Options 1-5

Chapter 2. Processing Unit Description 2-1 Main Storage 2-1 Addressing Main Storage 2-1 Arithmetic and Logic Unit (ALU) 2-3 Numbering Representation 2-3 Registers 2-4 Per-system Registers 2-4 Per-level Registers 2-5 Indicator Bits 2-5 Even, Negative, and Zero Result Indicators 2-6 Even, Carry, and Overflow Indicators - Condition Code for Input/Output Operations 2-6 Carry and Overflow Indicators - Add and Subtract Operations 2-6 Carry and Overflow Indicators - Shift Operations 2-7 Indicators - Compare Operations 2-7 Indicators - Multiple Word Operands 2-8 Testing Indicators with Conditional Branch and Jump Instructions 2-8 Supervisor State Bit 2-10 In-process Bit 2-10 Trace Bit 2-10 Summary Mask Bit 2-10 Program Execution 2-10 Instruction Formats 2-10 Effective Address Generation 2-12 Processor State Control 2-19 Initial Program Load (IPL) 2-22 Sequential Instruction Execution 2-22 Jumping and Branching 2-23 Level Switching and Interrupts 2-23 Stack Operations 2-23

Chapter 3. Interrupts and Level Switching 3-1 Introduction 3-1 Interrupt Scheme 3-1 Automatic Interrupt Branching 3-2 I/O Interrupts 3-3 Prepare I/O Device for Interrupt 3-3 Present and Accept I/O Interrupt 3-3 Class Interrupts 3-5 Priority of Class Interrupts 3-5 Present and Accept Class Interrupt 3-6 Summary of Class Interrupts 3-9 Recovery from Error Conditions 3-9 Program Check 3-9 Storage Parity Check 3-10 CPU Control Check 3-10 I/O Check 3-10 Soft Exception Trap 3-10 Processor Status Word 3-10 Program Controlled Level Switching 3-12 Selected Level Lower Than Current Level and In-process Flag On 3-13 Selected Level Equal to Current Level and In-process Flag On 3-13 Selected Level Higher Than Current Level and In-process Flag On 3-13 Selected Level Lower Than Current Level and In-process Flag Off 3-14 Selected Level Equal to Current Level and In-process Flag Off 3-14 Selected Level Higher Than Current Level and In-process Flag Off 3-14 Interrupt Masking Facilities 3-15 Summary Mask 3-15 Interrupt Level Mask Register 3-15 Device Mask (I-bit) 3-15 Chapter 4. Input/Output Operations 4-1 Operate I/O Instruction 4-2 Immediate Device Control Block (IDCB) 4-3 Device Control Block (DCB) 4-5 I/O Commands 4-6 DPC Operation 4-8 Cycle Steal 4-10 Start Operation 4-10 Start Cycle Steal Status Operation 4-12 Cycle-Steal Device Options 4-13 Burst Mode 4-13 Chaining 4-13 Programmed Controlled Interrupt (PCI) 4-13 Suppress Exception (SE) 4-14 Cycle-Steal Termination Conditions 4-15 I/O Condition Codes and Status Information 4-15 IO Instruction Condition Codes 4-19 Interrupt Condition Codes 4-19 I/O Status Information 4-20

Chapter 5. Storage Protection 5-1 Storage Protection During Initial Program Load 5-3 Storage Protection in Supervisor State 5-3 Address Space Management 5-3 Active Address Key 5-3 Equate Operand Spaces (EOS) 5-3 Address Space 5-4 Address Key Values After Interrupts 5-5

Chapter 6. Storage Address Relocation Translator Feature6-1Translator Description6-1Storage Mapping6-2Relocation Addressing6-4

 $\square$ 

Storage Protection When Using the Relocation Translator 6-5 I/O Storage Access Using the Relocation Translator 6-5 Compatibility Between the Relocation Translator and the Storage Protection Mechanism 6-5 Characteristics That Are Similar 6-6 Characteristics That Are Dissimilar 6-6 Error Recovery Considerations 6-6 Invalid Storage Address 6-6 Protect Check 6-6 Status of Translator After Power Transitions and Resets 6-6 Instruction Execution Time When Using the Translator 6-7 Chapter 7. Console 7-1 Basic Console 7-2 Keys and Switches 7-2 Indicators 7-2 Programmer Console 7-3 Console Display 7-3 Indicators 7-4 Combination Keys/Indicators 7-5 Keys and Switches 7-7 Displaying Main Storage Locations 7-10 Storing Into Main Storage 7-10 Displaying Registers 7-11 Storing Into Registers 7-11 Chapter 8. Instructions 8-1 Exception Conditions 8-1 Program Check Conditions 8-1 Soft Exception Trap Conditions 8-1 Instruction Termination or Suppression 8-2 Instruction Descriptions 8-2 Add Byte (AB) 8-2 Add Byte Immediate (ABI) 8-3 Add Carry Register (ACY) 8-3 Add Doubleword (AD) 8-4 Register/Storage Format 8-4 Storage/Storage Format 8-4 Add Word (AW) 8-5 Register/Register Format 8-5 Register/Storage Format 8-5 Storage to Register Long Format 8-6 Storage/Storage Format 8-6 Add Word With Carry (AWCY) 8-7 Add Word Immediate (AWI) 8-7 Register Immediate Long Format 8-7 Storage Immediate Format 8-8 Branch Unconditional (B) 8-9 Branch and Link (BAL) 8-10 Branch and Link Short (BALS) 8-10 Branch on Condition (BC) 8-11 Branch on Condition Code (BCC) 8-12 Branch on Not Condition (BNC) 8-13 Branch on Not Condition Code (BNCC) 8-14 Branch on Not Overflow (BNOV) 8-15 Branch on Overflow (BOV) 8-15 Branch Indexed Short (BXS) 8-16 Compare Byte (CB) 8-17 Register/Storage Format 8-17 Storage/Storage Format 8-17 Compare Byte Immediate (CBI) 8-18 Compare Double Word (CD) 8-19 Register/Storage Format 8-19 Storage/Storage Format 8-19 Compare Byte Field Equal and Decrement (CFED) 8-20 Compare Byte Field Equal and Increment (CFEN) 8-20

Compare Byte Field Not Equal and Increment (CFNEN) 8-21 Complement Register (CMR) 8-22 Copy Address Key Register (CPAKR) 8-23 System Register/Storage Format 8-23 System Register/Register Format 8-23 Copy Current Level (CPCL) 8-24 Copy Console Data Buffer (CPCON) 8-24 Copy Interrupt Mask Register (CPIMR) 8-25 Copy In-process Flags (CPIPF) 8-25 Copy Level Block (CPLB) 8-26 Copy Level Status Register (CPLSR) 8-26 Copy Processor Status and Reset (CPPSR) 8-27 Copy Storage Key (CPSK) 8-27 Copy Segmentation Register (CPSR) 8-28 Compare Word (CW) 8-29 Register/Register Format 8-29 Register/Storage Format 8-29 Storage/Storage Format 8-29 Compare Word Immediate (CWI) 8-30 Register Immediate Long Format 8-30 Storage Immediate Format 8-30 Divide Byte (DB) 8-31 Divide Doubleword (DD) 8-32 Diagnose (DIAG) 8-33 Disable (DIS) 8-34 Divide Word (DW) 8-35 Enable (EN) 8-36 Fill Byte Field and Decrement (FFD) 8-37 Fill Byte Field and Increment (FFN) 8-37 Operate I/O (IO) 8-38 Interchange Operand Keys (IOPK) 8-38 Interchange Registers (IR) 8-39 Jump Unconditional (J) 8-39 Jump and Link (JAL) 8-40 Jump on Condition (JC) 8-41 Jump on Count (JCT) 8-42 Jump on Not Condition (JNC) 8-43 Level Exit (LEX) 8-44 Load Multiple and Branch (LMB) 8-44 Multiply Byte (MB) 8-45 Multiply Doubleword (MD) 8-46 Move Address (MVA) 8-47 Storage Address to Register Format 8-47 Storage Immediate Format 8-47 Move Byte (MVB) 8-48 Register/Storage Format 8-48 Storage/Storage Format 8-48 Move Byte Immediate (MVBI) 8-49 Move Byte and Zero (MVBZ) 8-49 Move Doubleword (MVD) 8-50 Register/Storage Format 8-50 Storage/Storage Format 8-50 Move Doubleword and Zero (MVDZ) 8-51 Move Byte Field and Decrement (MVFD) 8-52 Move Byte Field and Increment (MVFN) 8-52 Move Word (MVW) 8-53 Register/Register Format 8-53 Register/Storage Format 8-53 Register to Storage Long Format 8-53 Storage to Register Long Format 8-54 Storage/Storage Format 8-54 Move Word Immediate (MVWI) 8-55 Storage to Register Format 8-55 Storage Immediate Format 8-55 Move Word Short (MVWS) 8-56

Compare Byte Field Not Equal and Decrement (CFNED) 8-21



Register to Storage Format 8-56 Storage to Register Format 8-56 Move Word and Zero (MVWZ) 8-57 Multiply Word (MW) 8-58 No Operation (NOP) 8-59 AND Word Immediate (NWI) 8-59 OR Byte (OB) 8-60 Register/Storage Format 8-60 Storage/Storage Format 8-60 OR Double Word (OD) 8-61 Register/Storage Format 8-61 Storage/Storage Format 8-61 OR Word (OW) 8-62 Register/Register Format 8-62 Register/Storage Format 8-62 Storage to Register Long Format 8-63 Storage/Storage Format 8-63 OR Word Immediate (OWI) 8-64 Register Immediate Format 8-64 Storage Immediate Format 8-64 Pop Byte (PB) 8-65 Pop Doubleword (PD) 8-65 Push Byte (PSB) 8-66 Push Doubleword (PSD) 8-66 Push Word (PSW) 8-67 Pop Word (PW) 8-67 Reset Bits Byte (RBTB) 8-68 Register/Storage Format 8-68 Storage/Storage Format 8-68 Reset Bits Doubleword (RBTD) 8-69 Register/Storage Format 8-69 Storage/Storage Format 8-69 Reset Bits Word (RBTW) 8-70 Register/Register Format 8-70 Register/Storage Format 8-70 Storage to Register Long Format 8-71 Storage/Storage Format 8-71 Reset Bits Word Immediate (RBTWI) 8-72 Register Immediate Long Format 8-72 Storage Immediate Format 8-72 Subtract Byte (SB) 8-73 Subtract Carry Indicator (SCY) 8-73 Subtract Doubleword (SD) 8-74 Register/Storage Format 8-74 Storage/Storage Format 8-74 Set Address Key Register (SEAKR) 8-75 System Register/Storage Format 8-75 System Register/Register Format 8-75 Set Console Data Lights (SECON) 8-76 Set Interrupt Mask Register (SEIMR) 8-76 Set Indicators (SEIND) 8-77 Set Level Block (SELB) 8-78 Set Storage Key (SESK) 8-79 Set Segmentation Register (SESR) 8-80 Scan Byte Field Equal and Decrement (SFED) 8-81 Scan Byte Field Equal and Increment (SFEN) 8-81 Scan Byte Field Not Equal and Decrement (SFNED) 8-82 Scan Byte Field Not Equal and Increment (SFNEN) 8-82 Shift Left Circular (SLC) 8-83 Immediate Count Format 8-83 Count in Register Format 8-83 Shift Left Circular Double (SLCD) 8-84 Count in Register Format 8-85 Shift Left Logical (SLL) 8-86 Immediate Count Format 8-86 Count in Register Format 8-86

Shift Left Logical Double (SLLD) 8-87 Immediate Count Format 8-87 Count in Register Format 8-87 Shift Left and Test (SLT) 8-88 Shift Left and Test Double (SLTD) 8-88 Shift Right Arithmetic (SRA) 8-89 Immediate Count Format 8-89 Count in Register Format 8-89 Shift Right Arithmetic Double (SRAD) 8-90 Immediate Count Format 8-90 Count in Register Format 8-90 Shift Right Logical (SRL) 8-91 Immediate Count Format 8-91 Count in Register Format 8-91 Shift Right Logical Double (SRLD) 8-92 Immediate Count Format 8-92 Count in Register Format 8-92 Store Multiple (STM) 8-93 Stop (STOP) 8-94 Supervisor Call (SVC) 8-94 Subtract Word (SW) 8-95 Register/Register Format 8-95 Register/Storage Format 8-95 Storage to Register Long Format 8-96 Storage/Storage Format 8-96 Subtract Word With Carry (SWCY) 8-97 Subtract Word Immediate (SWI) 8-98 Register Immediate Long Format 8-98 Storage Immediate Format 8-98 Test Bit (TBT) 8-99 Test Bit and Reset (TBTR) 8-99 Test Bit and Set (TBTS) 8-100 Test Bit and Invert (TBTV) 8-100 Test Word Immediate (TWI) 8-101 Register Immediate Long Format 8-101 Storage Immediate Format 8-101 Invert Register (VR) 8-102 Exclusive OR Byte (XB) 8-102 Exclusive OR Doubleword (XD) 8-103 Exclusive OR Word (XW) 8-104 Register/Register Format 8-104 Register/Storage Format 8-104 Storage to Register Long Format 8-105 Exclusive OR Word Immediate (XWI) 8-105 Chapter 9. Floating-Point Feature 9-1 Data Format 9-1 Number Representation 9-1 Floating-Point Numbers 9-1 Binary Integers in Main Storage 9-2 Normalization 9-2 Programming Considerations 9-2 Floating-Point Feature Not Installed 9-2 Floating-Point Registers 9-2 Arithmetic Indicators 9-2 Floating-Point Exceptions 9-2 Level Control 9-3 Instruction Termination or Suppression 9-3 Floating-Point Instructions 9-3 Instruction Formats 9-4 Exception Conditions 9-4 Program Check Conditions 9-4 Soft Exception Trap Conditions 9-5 Instruction Descriptions 9-6 Copy Floating Level Block (CPFLB) 9-6 Floating Add (FA) 9-7



General Description (Short Precision) 9-7 Storage/Register Format 9-7 Register to Register Format 9-7 Floating Add Double (FAD) 9-8 General Description (Double Precision) 9-8 Storage/Register Format 9-8 Register to Register Format 9-8 Floating Compare (FC) 9-9 Floating Compare Double (FCD) 9-9 Floating Divide (FD) 9-10 Storage/Register Format 9-10 Register to Register Format 9-10 Floating Divide Double (FDD) 9-11 Storage/Register Format 9-11 Register to Register Format 9-11 Floating Multiply (FM) 9-12 General Description (Short Precision) 9-12 Storage/Register Format 9-12 Register to Register Format 9-12 Floating Multiply Double (FMD) 9-13 General Description (Double Precision) 9-13 Storage/Register Format 9-13 Register to Register Format 9-13 Floating Move (FMV) 9-14 Storage to Register Format 9-14 Register to Storage Format 9-14 Register to Register Format 9-14 Floating Move and Convert (FMVC) 9-15 Storage to Register Format 9-15 Register to Storage Format 9-15 Floating Move and Convert Double (FMVCD) 9-16 Storage to Register Format 9-16 Register to Storage Format 9-16 Floating Move Double (FMVD) 9-17 Storage to Register Format 9-17 Register to Storage Format 9-17 Register to Register Format 9-17 Floating Subtract (FS) 9-18 General Description (Short Precision) 9-18 Storage/Register Format 9-18 Register to Register Format 9-18 Floating Subtract Double (FSD) 9-19 General Description (Double Precision) 9-19 Storage/Register Format 9-19 Register to Register Format 9-19 Set Floating Level Block (SEFLB) 9-20

Appendix A. Instruction Execution Times A-1 Table 1. Instruction Times – Relocation Translator Not Installed or Disabled A-4 Table 2. Instruction Times – Relocation Translator Enabled A-14

Appendix B. Instruction Formats B-1

Appendix C. Assembler Syntax C-1 Coding Notes C-1 Legend for Machine Instruction Operands C-1

Appendix D. Numbering Systems and Conversion Tables D-1

Binary and Hexadecimal Number Notations D-1 Binary Number Notation D-1 Hexadecimal Number System D-1

Hexadecimal – Decimal Conversion Tables D-2

Appendix E. Character Codes E-1

Appendix F. Carry and Overflow IndicatorsF-1Signed NumbersF-1Unsigned NumbersF-2Carry Indicator SettingF-3Add Operation ExamplesF-3Subtract Operation ExamplesF-4Overflow Indicator SettingF-4ExamplesF-5

Appendix G. Reference InformationG-1Address Key Register (AKR)G-1Condition CodesG-1I/O Instruction Condition CodesG-1Interrupt Condition CodesG-1General RegistersG-1Interrupt Status Byte (ISB)G-1DPC DevicesG-1Cycle Steal DevicesG-2Level Status Register (LSR)G-2Processor Status Word (PSW)G-2

Index X-1

Index of Instructions by Format X-12

Index of Instructions by Name X-15

This publication describes the functional characteristics of the IBM 4955 Processor and the processor optional features. It assumes that the reader understands data processing terminology and is familiar with binary and hexadecimal numbering systems. The publication is intended primarily as a reference manual for experienced programmers who require machine code information to plan, correct, and modify programs written in the assembler language.

# **Summary of Publication**

- Chapter 1. Introduction is an introduction to the system architecture. It contains a general description of the processor, storage, features, and a list of attachable I/O devices.
- Chapter 2. Processing Unit Description contains a description of the processor hardware including registers and indicators.

Main storage data formats and addressing are presented in this chapter.

- A section titled "Program Execution" is included and covers:
- Basic instruction formats
- Effective address generation
- Processor state control
- Initial program load (IPL)
- Jumping and branching
- Level switching and interrupts
- Stack operations
- Chapter 3. Interrupts and Level Switching describes the priority interrupt levels and the interrupt processing for (1) I/O devices, and (2) class interrupts. Related topics are:
  - Program controlled level switching
  - Interrupt masking facilities
  - Recovery from error conditions

- Chapter 4. Input/Output Operations describes the I/O commands and control words that are used to operate the I/O devices. Condition codes and status information relative to the I/O operation are also explained. Specific command and status-word bit structures are contained in the I/O device description books.
- Chapter 5. Storage Protection describes the operation of the storage protection mechanism.
- Chapter 6. Storage Address Relocation Translator Feature describes the optional relocation translator feature including:
  - Relocation addressing
  - Effects on storage protection mechanism
  - Error recovery considerations
- Chapter 7. Console describes the keys, switches, and indicators for the basic console and the optional programmer console. Typical manual operations such as storing into and displaying main storage are presented.
- Chapter 8. Instructions describes the basic instruction set, including indicator settings and possible exception conditions. Individual instruction word formats are included and contain bit combinations for the operation code and function fields. The instructions are arranged in alphabetical sequence based on assembler mnemonics.
- Chapter 9. Floating-Point Feature describes the optional floating-point feature including the floating-point instruction set.
- Appendixes:
  - Instruction execution times
  - Instruction formats
  - Assembler syntax
  - Numbering systems and conversion tables
  - Character codes
  - Carry and overflow indicators
  - Reference information

# **Related Publications**

- IBM Series/1 System Summary, GA34-0035
- IBM Series/1 Installation Manual Physical Planning, GA34-0029
- IBM Series/1 4962 Disk Storage Unit and 4964 Diskette Unit Description, GA34-0024
- IBM Series/1 4973 Line Printer Description, GA34-0044
- IBM Series/1 4974 Printer Description, GA34-0025
- IBM Series/1 4979 Display Station Description, GA34-0026
- IBM Series/1 4982 Sensor Input/Output Unit Description, GA34-0027
- IBM Series/1 Communications Features Description, GA34-0028
- IBM Series/1 Attachment Features Description, GA34-0031
- IBM Series/1 Battery Backup Unit Description, GA34-0032
- IBM Series/1 User's Attachment Manual, GA34-0033

# Chapter 1. Introduction

The IBM 4955 Processor is a compact, general purpose computer and has the following general characteristics:

• Four priority interrupt levels – independent registers and status indicators for each level. Automatic and program controlled level switching.

- Four processor models are available:
  - Model A: 16K bytes basic storage. Additional storage in 16K byte increments up to 64K bytes maximum.
  - Model B: 16K bytes basic storage. Additional storage in 16K byte increments up to 128K bytes maximum.
  - Model C: 32K bytes basic storage. Additional storage in 32K\* byte increments up to 64K bytes maximum.
  - Model D: 32K bytes basic storage. Additional storage in 32K\* byte increments up to 128K bytes maximum.
- FET (field effect transistor) main storage. Read or write time is 300 nanoseconds (660 nanoseconds required between two storage access cycles). Odd parity by byte is maintained throughout storage.
- TTL (transistor-transistor logic) processor technology.
- Microprogram control microcycle time: 220 nanoseconds.
- Instruction set that includes: stacking and linking facilities, multiply and divide, variable field-length byte operations, and a variety of arithmetic and branching instructions.
- Supervisor and problem states.
- Packaged in a 19-inch rack mountable unit full width.
- Basic console standard in processor unit. Programmer console optional.
- Channel capability.
  - Asynchronous, multidropped channel.
  - 256 I/O (input/output) devices can be addressed.
  - Direct program control and cycle steal operations.
  - Maximum burst data rate is 1.8 megabytes per second for storage input cycles, and 1.5 megabytes per second for storage output cycles. When multiple cycle stealing devices are interleaved, the maximum aggregate data rate is 1.65 megabytes per second.

The processor unit contains power and space for additional features and storage. The IBM 4959 Input/Output Expansion Unit is available for additional features.

The processor unit is described in the following sections of this chapter.

#### IBM 4955 Processor

#### **Processor Optional Features/Storage Addition**

- Storage Address Relocation Translator (permits addressing of main storage larger than 64K bytes).
- Storage Addition 16,384 bytes.
  - provides storage in 16K byte increments for all processor models.
  - Model A has a limit of four 16K cards (64K bytes total).
  - Model B has a limit of eight 16K cards (128K bytes total).
  - Models C and D have a limit of one 16K card and it must be installed as the last storage card. That is: any 32K cards would be installed between the 16K card and the processor cards.
- Storage Addition -32,768 bytes.
  - provides storage in 32K byte increments for processor Models C and D.
  - Model C has a limit of two 32K cards (64K bytes total).
  - Model D has a limit of four 32K cards (128K bytes total).
- Programmer Console.
- Floating-Point.

# **Processor Description**

The basic IBM 4955 Processor includes the processor, basic storage, and a basic console. These items are packaged in a unit, called the processor unit. Figure 1-1 shows a block diagram of an IBM 4955 Processor and an IBM 4959 Input/Output Expansion Unit.

<sup>\*</sup>Models C and D may have one 16K byte storage card installed as the last storage card.





The processor is microprogram controlled, utilizing a 220 nanosecond microcycle. Circuit technology is TTL (transistor-transistor logic).

Four priority interrupt levels are implemented in the processor. Each level has an independent set of machine registers. Level switching can occur in two ways: (1) by program control, or (2) automatically upon acceptance of an I/O interrupt request. The interrupt mechanism provides 256 unique entry points for I/O devices.

The processor instruction set contains a variety of instruction types. These include: shift, register to register, register immediate, register to (or from) storage, bit manipulation, multiple register to storage, variable byte field, and storage to storage. Supervisor and problem states are implemented, with appropriate privileged instructions for the supervisor.

A floating-point feature is available that supplements the standard instruction set. The floating-point instructions include single and double precision types for: add, subtract, multiply, divide, compare, and move.



The basic console is intended for dedicated systems that are used in a basically unattended environment. Only minimal controls are provided. A programmer console can be added as a feature; this console provides a variety of indicators and controls for operator-oriented systems.

Main storage technology is FET (field-effect transistor). Basic storage supplied is model dependent. Two storage additions provide additional storage in 16K or 32K byte increments. The maximum total storage is model dependent. Beyond 64K bytes the storage address relocation translator feature is required. This feature increases the addressing capability beyond 64K bytes and allows a maximum total storage of 128K bytes. The read/write access time for main storage is 300 nanoseconds. However, the minimum duration of time between successive storage cycles is 660 nanoseconds. Storage protection is standard. It protects against (1) access (reading and writing) to defined blocks of storage by software or by an I/O operation, and (2) writing in an undesired location within a defined block by software.

I/O devices are attached to the processor through the processor I/O channel. The channel directs the flow of information between the I/O devices, the processor, and main storage. This channel accommodates a maximum of 256 addressable devices.

The channel supports:

- Direct program control operations. Each Operate I/O instruction transfers a byte or word of data between main storage and the device. The operation may or may not terminate in an interrupt.
- Cycle Steal operations. Each Operate I/O instruction initiates multiple data transfers between main storage and the device (65,535 bytes maximum). Cycle steal operations are overlapped with processing operations and always terminate in an interrupt.
- *Interrupt Servicing*. Interrupt requests from the devices, along with cycle steal requests, are presented and polled concurrently with data transfers.

The processor is packaged in a standard 48.3 cm (19 in) rack-mountable unit, called the processor unit. All processor units contain an integral power supply, fans, and the basic console. Refer to the *Series/1 Installation Manual – Physical Planning*, GA34-0029, for environmental characteristics. Four processor models are available. Figure 1-2 shows the IBM 4955 Processor models and the card plugging assignments.

#### **IBM 4955 Processor Models**

| Model                     | A   | B    | С   | D    |
|---------------------------|-----|------|-----|------|
| Storage capacity (bytes)* | 64K | 128K | 64K | 128K |
| I/O feature cards**       | 8   | 3    | 10  | 7    |

- \* The relocation translator feature is required when the total storage exceeds 64K bytes.
- \*\* The floating-point feature can be substituted for one of the I/O feature cards and must be installed adjacent to the processor.





4955 Model A Card Plugging Assignments



4955 Model B Card Plugging Assignments





4955 Model C Card Plugging Assignments



4955 Model D Card Plugging Assignments

The A position for all models is reserved for the I/O cables or (due to voltage limitations) one of the following I/O feature cards:

- Teletypewriter Adapter Feature using TTL voltage levels
- Teletypewriter Adapter Feature using isolated current loop where customer supplies external ±12V power
- Timer Feature
- Customer Direct Program Control Adapter Feature
- 4982 Sensor Input/Output Unit Attachment Feature
- Integrated Digital Input/Output Non-Isolated Feature
- Channel Repower Feature

# Input/Output Units and Features

- IBM 4962 Disk Storage Unit (4 models)
- Requires 4962 Disk Storage Unit Attachment Feature
  IBM 4964 Diskette Unit
  - Requires 4964 Diskette Unit Attachment Feature
- IBM 4979 Display Station
   Requires 4979 Display Station Attachment Feature
- IBM 4973 Line Printer (2 models) - Requires 4973 Printer Attachment Feature
- IBM 4974 Printer
- Requires 4974 Printer Attachment Feature
- Timers Feature (2 timers)
- Teletypewriter Adapter Feature
- Customer Direct Program Control Adapter Feature

The feature cards for attaching the I/O units can be housed in either the processor unit or the I/O expansion unit.

Information about these units and features can be found in separate publications. The order numbers for these publications are listed in the preface of this manual.

# **Communications Features**

- Asynchronous Communications Single Line Control
- Asynchronous Communications 8 Line Control
- Asynchronous Communications 4 Line Adapter
- Binary Synchronous Communications Single Line Control
- Binary Synchronous Communications Single Line Control/High Speed
- Synchronous Data Link Control Single Line Control
- Binary Synchronous Communications 8 Line Control
- Binary Synchronous Communications 4 Line Adapter
- Communications Power Feature
- Communications Indicator Panel

Refer to the publication, *IBM Series/1*, *Communications Features Description*, GA34-0028, for a description of these features.

# Sensor Input/Output Options

- Integrated Digital Input/Output Non-Isolated Feature
- 4982 Sensor Input/Output Unit Attachment Feature

The integrated digital input/output non-isolated feature provides digital sensor I/O and simple attachment for non-IBM equipment. The feature card can be housed in either the processor unit or the I/O expansion unit. Refer to the publication, *IBM Series/1 Attachment Features Description*, GA34-0031, for a description of this feature.

The 4982 sensor input/output attachment unit feature card is housed in either the processor or the I/O expansion unit. Refer to the publication, *IBM Series/1*, 4982 Sensor Input/Output Unit Description, GA34-0027, for a description of the 4982 and associated features.

# Packaging and Power Options

- IBM 4959 Input/Output Expansion Unit
- IBM 4999 Battery Backup Unit
- IBM 4997 Rack Enclosure (1 metre) 2 models
- IBM 4997 Rack Enclosure (1.8 metre) 2 models

The IBM 4959 Input/Output Expansion Unit is available for adding I/O feature cards beyond the capacity of the processor unit. I/O cables (for the I/O channel) are used to attach this unit to the processor. The capacity of the I/O expansion unit is either (1) fourteen I/O feature cards, or (2) thirteen I/O feature cards plus a channel repower card. A channel repower card is required to power each additional I/O expansion unit.

The IBM 4999 Battery Backup Unit permits the processor unit (excluding external devices) to operate from a usersupplied battery when a loss or dip in line power occurs. The battery backup unit is explained in a separate publication. Refer to the preface of this manual for the order number.

# **Other Options**

Additional options such as communications cables, customer access panel, and a channel socket adapter are also available. For a list and description of system units and features, refer to the *IBM Series/1 System Summary*, GA34-0035.

1-6 GA34-0021

.

Figure 2-1 shows the general data flow for the IBM 4955 Processor. The major functional units shown in the data flow are discussed in the following sections.

## Main Storage

Main storage holds data and instructions for applications to be processed on the system. The data and instructions are stored in units of information called a byte. Each byte consists of eight binary data bits. Associated with each byte is a parity bit. Odd parity by byte is maintained throughout storage; even parity causes a machine check error. Formats shown in this manual exclude the parity bit(s) because they are not a part of the data flow manipulated by the instructions.

The bits within a byte are numbered consecutively, left to right, 0 through 7. When a format consists of multiple bytes, the numbering scheme is continued; for example, the bits in the second byte would be numbered 8 through 15. Leftmost bits are sometimes referred to as high-order bits and rightmost bits as low-order bits.

Bytes can be handled separately or grouped together. A *word* is a group of two consecutive bytes, beginning on an even address boundary, and is the basic building block of instructions. A *doubleword* is a group of four consecutive bytes beginning on an even address boundary.

#### Addressing Main Storage

Each byte location in main storage is directly addressable. Byte locations in storage are numbered consecutively, starting with location zero; each number is considered the address of the corresponding byte. Storage addresses are 16-bit unsigned binary numbers. This permits a direct addressing range of 65,536 bytes:

#### Address Range

| 16-bit binary address | Hexadecimal | Decimal |  |  |  |
|-----------------------|-------------|---------|--|--|--|
| 0000 0000 0000 0000   | 0000        | 0       |  |  |  |
| to                    | to          | to      |  |  |  |
| 1111 1111 1111 1111   | FFFF        | 65,535  |  |  |  |

*Note.* Addresses that overflow or underflow the addressing range address wrap modulo 65,536.

When the *Storage Address Relocation Translator Feature* is installed, the 16-bit address is used as a logical address to generate a 24-bit physical address.

#### Instruction and Operand Address Boundaries

As previously stated, all storage addressing is defined by byte location. Instructions can refer to bits, bytes, byte strings, words, or doublewords as data operands. All word and doubleword operand addresses must be on even byte boundaries. All word and doubleword operand addresses point to the most significant (leftmost) byte in the operand. Bit addresses are specified by a byte address and a bit displacement.



#### Processor bus (16 bits)



Legend:

- AKR Address key register
- ALU Arithmetic and logic unit
- CIAR Current instruction address register
- CS Cycle steal
- Ctr Counter
- IAR Instruction address register
- LSR Level status register
- Mask Interrupt level mask register
- Op Operation register
- Proc Processor
- PSW Processor status word
- SAR Storage address register
- SDR Storage data register
- WA Work/shift register
- Y Work/shift register
- Z Console data

Figure 2-1. Data flow for the IBM 4955 Processor

C

To provide maximum addressing range, some instructions refer to a word displacement that is added to the contents of a register. In these cases, the operand is a word and the register must contain an even byte address for valid results. Effective address generation is described in a subsequent section of this chapter.

All instructions must be on an even byte boundary. This implies that the effective address for all branch type instructions must be on an even byte boundary to be valid.

If any of the aforementioned rules are violated, a program check interrupt occurs with *specification check* set in the processor status word (PSW). The instruction is suppressed.

#### Arithmetic and Logic Unit (ALU)

The arithmetic and logic unit (ALU) contains the hardware circuits that perform: addition; subtraction; and logical operations such as AND, OR, and exclusive OR. The ALU performs address arithmetic as well as the operations required to process the instruction operands. Operands may be regarded as signed or unsigned by the programmer. However, the ALU does not distinguish between them. Numbering representation is discussed in a subsequent section of this chapter. For many instructions, indicators are set to reflect the result of the ALU operation. The indicators are discussed in a subsequent section of this chapter.

#### Numbering Representation

Operands may be signed or unsigned depending on how they are used by the programmer. An unsigned number is a binary integer in which all bits contribute to the magnitude. A storage address is an example of an unsigned number. A signed number is one where the high-order bit is used to indicate the sign, and the remaining bits define the magnitude. Signed positive numbers are represented in true binary notation with the sign bit (high-order bit) set to zero. Signed negative numbers are represented in two's complement notation with the sign bit (high-order bit) set to one. The two's complement of a number is obtained by inverting each bit of the number and adding a one to the low-order bit position. Two's complement notation does not include a negative zero. The maximum positive number consists of an all-one integer field with a sign bit of zero; whereas, the maximum negative number (the negative number with the greatest absolute value) consists of an all-zero integer field with a one-bit for the sign.

The following examples show: (1) an unsigned 16-bit number, (2) a signed 16-bit positive number, and (3) a signed 16-bit negative number.

Example of an unsigned 16-bit number:

| 1<br>0    | 1 | 1 | 1 | 1 | 1  | 1 | 1 | 1         | 1 | 1 | 1 | 1 | 1 | 1 | <br>Binary number<br>5 Bit position |
|-----------|---|---|---|---|----|---|---|-----------|---|---|---|---|---|---|-------------------------------------|
| De<br>He: |   |   |   |   | ue |   |   | 535<br>FF | • |   |   |   | - |   | igned number<br>16 bits.)           |

Example of a signed 16-bit positive number:



Hexadecimal value 7FFF number representable in 16 bits.)

When the number is positive, all bits to the left of the most significant bit of the number, including the sign bit, are zero:



Example of a signed 16-bit negative number:



*Note.* This form of representation yields a negative range of one more than the positive range.

When the number is negative, all bits to the left of the most significant bit of the number, including the sign bit, are set to one:



When a signed-number operand must be extended with high-order bits, the expansion is achieved by prefixing a field with each bit set equal to the high-order bit of the operand.

Example of an 8-bit field extended to a 16-bit field:



It must be emphasized that when performing the add and subtract operations, the machine does not regard the number as either signed or unsigned, but performs the designated operation on the values presented. Whether a given add or subtract operation is to be regarded as a signed operation or an unsigned operation is determined by the programmer's view of the values being presented as operands. The carry indicator and the overflow indicator of the LSR are changed on various operations to reflect the result of that operation. This allows the programmer to make result tests for the number representation involved. The carry and overflow indicator settings are explained in a subsequent section.

# Registers

Registers in the processor are provided in two categories:

- 1. Per-system register (the register is provided only once and is used by all priority interrupt levels)
- 2. Per-level register (the register is duplicated for each priority interrupt level)

Information that must be saved when a level is preempted is retained in registers supplied for a specific level. Information that pertains only to the current process is kept in registers common to all levels. The registers in each category are listed in this section. Descriptions for each of the registers appear in subsequent sections. Only registers accessible to the program or the operator (via console operations) are discussed.

Registers supplied on a per-system basis:

- Console address key register
- Console data buffer
- Current-instruction address register (CIAR)
- Mask register (interrupt level)
- Processor status word (PSW)
- Segmentation registers (optional) see Chapter 6, Storage Address Relocation Translator Feature.
- Storage address register (SAR)

Registers supplied on a per-level basis:

- Address key register (AKR)
- Floating-point registers (optional) see Chapter 9, *Floating-Point Feature.*
- General registers (8 per level)
- Instruction address register (IAR)
- Level status register (LSR)

*Note.* For a specific level, the contents of the AKR, IAR, LSR, and the general registers are known as a level status block (LSB). The LSB is a 22 byte entity used by hardware and software for task control and task switching.

#### Per-system Registers

#### **Console Address Key Register**

The Console AKR is not addressable by software. When the programmer console is installed, this register is used for certain console operations. Refer to *Programmer Console* in Chapter 7.

#### **Console Data Buffer**

The console data buffer is a 16-bit register associated with the programmer console feature. Details of how the buffer is used are explained in the programmer console section of Chapter 7. The contents of the console data buffer can be loaded into a specified general register by using the Copy Console Data Buffer (CPCON) instruction (see Chapter 8).

## Current-Instruction Address Register (CIAR)

When the processor enters the stop state, the currentinstruction address register (CIAR) contains the address of the last instruction that was executed. The CIAR is not addressable by software. It may be displayed from the optional programmer console. Refer to *Stop State* in this chapter for methods of entering stop state.

#### Mask Register

The mask register is a 4-bit register used for control of interrupts. Bit 0 controls level 0, bit 1 controls level 1, and so on.

A one bit enables interrupts on a level, while a zero bit disables interrupts. For example if bit 3 is set to a one, interrupts are enabled on level 3.

# Processor Status Word (PSW)

The processor status word (PSW) is a 16-bit register used to (1) record error or exception conditions that may prevent further processing, and (2) hold certain flags that aid in error recovery. Error or exception conditions recorded in the PSW result in a class interrupt. Each bit in the PSW is described in detail in Chapter 3. The PSW can be accessed by using the Copy Processor Status and Reset (CPPSR) instruction (see Chapter 8).

## Storage Address Register (SAR)

The storage address register (SAR) is a 16-bit register that contains the main-storage address for the last attempted processor storage cycle. This register is addressable by the Diagnose instruction and may be altered or displayed from the optional programmer console.

# Per-level Registers

#### Address Key Register (AKR)

The address key register (AKR) is a 16-bit register that contains three address keys and an address-key control bit. This register is associated with the storage protection mechanism. Separate 3-bit fields contain an address key for (1) instruction address space, (2) operand-1 address space, and (3) operand-2 address space. Refer to *Storage Protection* and *Address Space Management* in Chapter 5 for further information.

## **General Registers**

Subsequently referred to simply as registers, the general registers are 16-bit registers available to the program for general purposes. Eight registers are provided for each level. The R and RB fields in the instructions control the selection of these registers.

## Instruction Address Register (IAR)

The instruction address register (IAR) is a 16-bit register that holds the main storage address used to fetch an instruction. After an instruction has been fetched, the IAR is updated to point to the next instruction to be fetched.

Note. These registers are sometimes referred to as IARO, IAR1, IAR2, and IAR3. The numbers represent the priority level associated with the register.

#### Level Status Register (LSR)

The level status register (LSR) is a 16-bit register that holds:

- Indicator bits
  - Set as a result of arithmetic, logical, or I/O operations
- A supervisor state bit
- An in-process bit
- A trace bit
- A summary mask bit

These bits are further discussed in the following sections. Seven other bits in the LSR are not used and are always set to zero.

# **Indicator Bits**

The indicators are located in bits 0-4 of the level status register (LSR). Figure 2-2 shows the indicators and how they are set for arithmetic operations. The indicator bits are changed or not changed depending on the instruction being executed. Some instructions do not affect the indicators, other instructions change all of the indicators, and still other instructions change only specific indicators. Refer to the individual instruction descriptions in Chapter 8 for the indicators changed by each instruction.



Figure 2-2. How indicators are set for signed and unsigned (logical) operations

The indicators are changed in a specialized manner for certain operations. These operations are described briefly. Additional information is provided in subsequent sections for those operations where more detail is required.

- Add, subtract, or logical operations. The even, negative, and zero indicators are *result* indicators. For add and subtract operations, the carry and overflow indicators are changed to provide information for both signed and unsigned number representations.
- Multiply and divide operations. Signed number operands are always assumed for these operations. The carry indicator is used to provide a divide by zero indication for the divide instruction. The overflow indicator defines an unrepresentable product for multiply operations. Refer to the individual instruction descriptions in Chapter 8.
- Priority interrupts and input/output operations. The even, carry and overflow indicators are used to form a three-bit condition code that is set as a binary value.
- Compare operations. The indicators are set in the same manner as a subtract operation.
- Shift operations. The carry and overflow indicators have a special meaning for shift left logical operations.
- Complement operations. The overflow indicator is set if an attempt is made to complement the maximum negative number. This number is not representable.

- Set Indicators (SEIND) and Set Level Block (SELB) instructions. All indicators are changed by the data associated with these instructions.
- Floating-point operations. The optional floating-point instructions set the indicators as described in Chapter 9, Floating-Point Feature.

## Even, Negative, and Zero Result Indicators

The even, negative, and zero indicators are called the result indicators. A positive result is indicated when the zero and negative indicators are both off (set to zero). These indicators are set to reflect the result of the last arithmetic, or logical operation performed. A logical operation in this sense includes data movement instructions. See the individual instruction descriptions in Chapter 8 for the indicators changed for specific instructions.

# Even, Carry, and Overflow Indicators – Condition Code for Input/Output Operations

The even, carry, and overflow indicators contain the I/O condition code: (1) following the execution of an Operate I/O instruction and (2) following an I/O interrupt.

These indicators are used to form a 3-bit binary number that results in a condition code value. For additional information about condition codes, refer to:

- 1. Branch on Condition Code (BCC) and Branch on Not Condition Code (BNCC) instructions in Chapter 8.
- 2. Condition codes in Chapter 4.

# Carry and Overflow Indicators – Add and Subtract Operations

A common set of add and subtract integer operations performs both signed and unsigned arithmetic. Whether a given add or subtract operation is to be regarded as a signed operation or an unsigned operation is determined by the programmer's view of the values being presented as operands. The carry and overflow indicators are set to reflect the result for both cases.

#### **Carry Indicator Setting**

The carry indicator is used to signal overflow of the result when operands are presented as *unsigned* numbers.

#### **Overflow Indicator Setting**

The overflow indicator is used to signal overflow of the result when the operands are presented as *signed* numbers.

*Note.* Appendix F explains the meaning of these indicators for signed and unsigned numbers. The appendix also provides examples for setting the carry indicator and for setting the overflow indicator.

# Carry and Overflow Indicators – Shift Operations

The carry and overflow indicators are changed for shift left logical operations and shift left and test operations. These operations affect the indicators as follows:

- 1. The carry indicator is set to reflect the value of the last bit shifted out of the target register (register where bits are being shifted).
- 2. The overflow indicator is set to one if bit-0 of the target register was changed during the shift. Otherwise it is set to zero.

## Indicators – Compare Operations

A compare operation sets the indicators in the same manner as a subtract operation. The even, negative, and zero indicators reflect the result. The carry and overflow indicators are set as described previously.

Compare instructions provide a test between two operands (without altering either operand) so that conditional branch and jump instructions may be used to control the programming logic flow. The conditions specified in branch and jump instructions are named such that, when the condition of the "subtracted from" operand relative to the other operand is true the jump or branch occurs. Otherwise, the next sequential instruction is executed. This is illustrated in the following example.

• Compare operation example

| nan | Instruction<br>name<br>Compare word |     |      |    |   | A ss<br>mn<br>CW | em |   |    |    |    | <i>Op</i><br>R3, |      |     |    |
|-----|-------------------------------------|-----|------|----|---|------------------|----|---|----|----|----|------------------|------|-----|----|
| OF  | pera                                | tio | n cc | de |   | R1               |    | Γ | R2 |    |    | Fu               | inct | ion |    |
| 0   | 1                                   | 1   | 1    | 0  | 0 | 1                | 1  | 1 | 0  | 0  | 0  | 0                | 1    | 0   | 1  |
| 0   |                                     |     |      | 4  | 5 | ~                | 7  | 8 | ~  | 10 | 11 | _                |      |     | 15 |
|     |                                     |     |      |    |   | R 3              |    |   | R4 |    |    |                  |      |     |    |

In this example, the contents of register 3 are subtracted from register 4:

|               |           |      |      | Decin     | nal        |
|---------------|-----------|------|------|-----------|------------|
|               |           |      |      | Unsig     | ned Signed |
| R4 contents   | 0000 0000 | 0000 | 0010 | 2         | +2         |
| R3 contents   | 1111 1111 | 1111 | 1011 | 65531     | 5          |
| Subtract resu | ılt       |      |      | -65529    | +7         |
| Machine ope   | ration:   |      |      |           |            |
| Minuend       | 0000 0000 | 0000 | 0010 |           |            |
| Subtrahend    | 0000 0000 | 0000 | 0100 | one's con | nplement   |
| Constant      |           |      | 1    | for two's | complement |
| Result        | 0000 0000 | 0000 | 0111 |           |            |

#### Indicator Settings:



If the programmer is comparing *unsigned* numbers, such as storage addresses, he should use the logical conditional tests (refer to Figure 2-3). In this example, assuming unsigned number representation, R4 is logically less than R3 and unequal to R3. Therefore, the following branch instructions would cause a transfer to symbolic location A (assuming register values shown in the example).

| CW   | R3,R4 |
|------|-------|
| BLLT | A     |
| CW   | R3,R4 |
| BNE  | A     |

or

or

The complementary tests (BLGT and BE) would not cause a transfer in this case.

If the programmer is comparing *signed* numbers, he should use the arithmetic conditional tests (refer to Figure 2-3). In the previous compare word example, assuming signed number representation, R4 is greater than R3 and unequal to R3. The following branch instructions would cause a transfer to symbolic location A.

| CW  | R3,R4 |
|-----|-------|
| BGT | A     |
| CW  | R3,R4 |
| BNE | A     |

The complementary tests (BLT and BE) would not cause a transfer.

*Note.* Jump instructions are also available for the logical and arithmetic conditional tests.

It must be emphasized again that the machine does not regard the numbers as either signed or unsigned. The compare word instruction results in a subtract operation being performed on the values presented. The programmer must then choose the correct conditional test (logical or arithmetic) for the number representation involved.

## Indicators – Multiple Word Operands

A programmer may desire to work with numbers that cannot be represented in one word or in a doubleword. It may take three or more words to represent the number.

Certain register to register instructions allow the programmer to add or subtract these multi-word operands and then have the indicators reflect the multi-word result. These instructions are:

Add Carry Register (ACY) Add Word With Carry (AWCY) Subtract Carry Register (SCY) Subtract Word With Carry (SWCY)

The following two examples show how the add instructions are used. A subtract operation would be similar. See Chapter 8 for details of the individual instructions.

Example 1. (Equal length operands)

| R1 | R2 | R3 | Operand 1/<br>Result |  |  |  |
|----|----|----|----------------------|--|--|--|
| R4 | R5 | R6 | Operand 2            |  |  |  |

Program steps:

AW R6,R3 AWCY R5,R2 AWCY R4,R1

#### Explanation:

- Step 1:The contents of R6 are added to the contents of R3.Step 2:The contents of R5 are added to the contents of R2
- plus any carry from the previous operation. Step 3: The contents of R4 are added to the contents of R1 plus any carry from the previous operation.

Example 2. (Unequal length operands)



*Note.* In this example, operand 2 must be an unsigned number or must be positive.

#### **Program Steps:**

| AW   | R6,R3 |
|------|-------|
| AWCY | R5,R2 |
| ACY  | R1    |

#### Explanation:

- Step 1: The contents of R6 are added to the contents of R3.
- Step 2: The contents of R5 are added to the contents of R2 plus any carry from the previous operation.
- Step 3: Any carry from the previous operation is added to the contents of R1.

Note. In both examples the final indicator settings reflect the status of the 3-word result.

- Even Set on if the result low-order bit of R3 is zero.
- Carry Set on if the result cannot be represented as an unsigned 3-word number.
- Overflow Set on if the result cannot be represented as a signed 3-word number.
- Negative Set on if the result high-order bit of R1 is one.
- Zero Set on if all three result registers contain zeros.

# Testing Indicators with Conditional Branch and Jump Instructions

The indicators are tested according to a selected condition when a conditional branch or a conditional jump instruction is executed. The conditions and the indicators tested for each condition are shown in Figure 2-3.

The conditional instructions are:

- Branch on Condition (BC)
- Branch on Not Condition (BNC)
- Jump on Condition (JC)
- Jump on Not Condition (JNC)

The assembler also provides extended mnemonics for the conditions shown in Figure 2-3. Refer to the individual instructions in Chapter 8.

|                              |                    |   | dica<br>stea   |                                       | 5                                      |   |
|------------------------------|--------------------|---|----------------|---------------------------------------|----------------------------------------|---|
| Condition tested by          | Assembler          | 0 | 1              | 2                                     | 3                                      | 4 |
| conditional branch or        | extended           | E | $\overline{C}$ | 0                                     | N                                      | Z |
| jump instruction             | mnemonics          |   | C              |                                       | IV                                     |   |
| Zero or equal                | BE, BZ, JE, JZ     |   |                |                                       |                                        | 1 |
| Not zero or unequal          | BNE, BNZ, JNE, JNZ |   |                |                                       |                                        | 0 |
| Positive and not zero        | BP, JP             |   |                |                                       | 0                                      | 0 |
| Not positive                 | BNP, JNP           |   |                |                                       |                                        | 1 |
|                              |                    |   |                |                                       | 1                                      |   |
| Negative                     | BN, JN             |   |                |                                       | 1                                      |   |
| Not negative                 | BNN, JNN           |   |                |                                       | 0                                      |   |
| Even                         | BEV, JEV           | 1 |                |                                       |                                        |   |
| Not even                     | BNEV, JNEV         | 0 |                |                                       |                                        |   |
| Arithmetically less than     | BLT, JLT           |   |                | 0                                     | $\begin{array}{c} 1\\ 0\end{array}$    |   |
| Arithmetically less than     | BLE, JLE           | + |                | 0                                     | 1                                      |   |
| or equal                     |                    |   |                | 1                                     | 0                                      |   |
|                              |                    |   |                |                                       |                                        | 1 |
| Arithmetically greater than  | BGE, JGE           |   |                | 1                                     | 1                                      |   |
| or equal                     |                    |   |                | 0                                     | 0                                      |   |
| Arithmetically greater than  | BGT, JGT           |   |                | $\begin{vmatrix} 1\\ 0 \end{vmatrix}$ | $\begin{vmatrix} 1 \\ 0 \end{vmatrix}$ | 0 |
|                              |                    |   | 1              | -                                     | 0                                      |   |
| Logically less than or equal | BLLE, JLLE         |   | 1              |                                       |                                        | 1 |
| Logically less than (carry)  | BLLT, JLLT         |   | 1              |                                       |                                        |   |
| Logically greater than       | BLGT, JLGT         |   | 0              |                                       |                                        | 0 |
| Logically greater than or    | BLGE, JLGE         | 1 | 0              |                                       |                                        |   |
| equal (no carry)             |                    |   |                |                                       |                                        |   |

| Legend: | LSR bit |
|---------|---------|
|         | 0       |
|         | 1       |
|         | 2       |
|         | 3       |
|         | 4       |

| bit | Indicator                    |
|-----|------------------------------|
|     | $\mathbf{E} - \mathbf{Even}$ |
|     | C – Carry                    |
|     | 0 – Overflow                 |
|     | N – Negative                 |
|     | Z – Zero                     |

Figure 2-3. Indicators tested by conditional branch and jump instructions

# Supervisor State Bit

LSR bit 8, when set to one, indicates that the processor is in the supervisor state. This state allows privileged instructions to be executed. It is set by any of the following:

- 1. Class interrupt
  - a. Machine check condition
  - b. Program check condition
  - c. Power/thermal warning
  - d. Supervisor Call (SVC) instruction
  - e. Soft exception trap condition
  - f. Trace
  - g. Console interrupt
- 2. I/O interrupt
- 3. Initial program load (IPL)

When LSR bit 8 is set to zero, the processor is in problem state. For a selected priority level, the supervisor can alter the supervisor state bit by using a Set Level Block (SELB) instruction. For additional information, refer to *Processor State Control* in this chapter.

Class interrupts and I/O interrupts are described in Chapter 3. IPL is discussed in a subsequent section of this chapter.

# **In-process Bit**

LSR bit 9, when set to one, indicates that a priority level is currently active or was preempted by a higher priority level before completing its task. Bit 9 is turned off by a Level Exit (LEX) instruction. Bit 9 can also be turned on or off by a Set Level Block (SELB) instruction. The inprocess bit also affects level switching under program control. Refer to *Chapter 3*. *Interrupts and Level Switching*.

# **Trace Bit**

LSR bit 10, when set to one, causes a trace class interrupt at the beginning of each instruction. The bit can be turned on or off with the Set Level Block (SELB) instruction. The trace bit aids in debugging programs. See *Class Interrupts* in Chapter 3.

# Summary Mask Bit

LSR bit 11, when set to zero (disabled), inhibits all priority interrupts on all levels. When this bit is set to one (enabled), normal interrupt processing is allowed. Refer to *Summary Mask* in Chapter 3 for details relating to control of the summary mask.

# Program Execution

# Instruction Formats

The processor instruction formats are designed for efficient use of bit combinations to specify the operation to be performed (operation code) and the operands that participate. Some formats also include (1) an immediate data field or word, (2) an address displacement or address word, and (3) a function field that further modifies the operation code. Various combinations of these fields are used by the individual instructions. Some typical instruction formats are presented in this section. All formats are shown in the section *Instruction Formats* in Appendix B.

## **One Word Instructions**

The basic instruction length is one word (16 bits). The operation code field (bits 0-4) is the only common field for all formats. This field, unless modified by a function field, specifies the operation to be performed. For a format without a function field, bits 5-15 specify the location of operands or data associated with an operand:

#### Example:

| name               | mnemonic | <i>Syntax</i> |
|--------------------|----------|---------------|
| Add Byte Immediate | ABI      | byte,reg      |
| Operation code R   | Imme     | ediate        |

Bits 0-4 Operation code (specifies ABI instruction).

Bits 5-7 General register (0-7).

This register contains data for the second operand.

Bits 8–15 Immediate data for the first operand.

In some cases the operation code is the same for a group of instructions. The format for this group includes a function field. The bit combinations in the function field then determine the specific operation to be performed. Example:

| Instruction<br>name<br>Add Word |     | Assembler<br>mnemonic<br>AW |                     |
|---------------------------------|-----|-----------------------------|---------------------|
| Operation code                  | R1  | R2                          | Function            |
| $0 \ 1 \ 1 \ 1 \ 0$             |     |                             | $0 \ 1 \ 0 \ 0 \ 0$ |
| 0 4                             | 5 7 | 8 10                        | 11 15               |

| Bits 0-4   | Operation code for a group of instructions.                                            |
|------------|----------------------------------------------------------------------------------------|
| Bits 5–7   | General register $(0-7)$ .<br>This register contains data for the first operand.       |
| Bits 8-10  | General register $(0-7)$ .<br>This register contains data for the second operand.      |
| Bits 11–15 | Function field.<br>Modifies the operation code to specify the Add<br>Word instruction. |

*Note.* For other instruction groups, the function'field may vary as to location within the format, and also the number of bits used.

#### **Two Word Instructions**

The first word of this format is identical to the one-word format. The second word (bits 16-31) contains either immediate data, an address, or a displacement. This word is used to (1) provide data for an operand, or (2) provide a main storage address or displacement for effective address generation (see *Effective Address Generation* in this chapter).

Example:

| Instruction<br>name         |     | Assembler<br>mnemonic |    | Syntax              |  |  |  |
|-----------------------------|-----|-----------------------|----|---------------------|--|--|--|
| Branch and Link             |     | BAL                   |    | longaddr,reg        |  |  |  |
| Operation code<br>0 1 1 0 1 | R1  | R2                    | X  | Function<br>0 0 1 1 |  |  |  |
| 0 4                         | 5 7 | 8 10                  | 11 | 12 15               |  |  |  |



Bits 0-4 Operation code.

Bits 5-7 General register (0-7) for the second operand.

Bits 8-10 General register (0-7) for the first operand.

Bit 11 Indirect addressing bit.

Bits 12–15 Function field.

Bits 16-31 A main storage address used for the first operand. Note. In this example, the register designated R1 is associated with the second operand in assembler syntax.

#### Variable Length Instructions

Some instructions use a selectable encoded technique for generating effective addresses. This method is referred to as an address argument technique in subsequent sections. These instruction formats contain a base register (RB) field and an address mode (AM) field. If both operands are using this technique, the format contains an RB and associated AM field for each. These fields are in the first instruction word. The AM field consists of two bits and is referred to in binary notation (AM=00, 01, 10, or 11). If AM is equal to 10 or 11 an additional word is appended to the normal instruction word. For a format that contains two AM fields, two additional words may be appended. See *Effective Address Generation* in this chapter for a description of the appended words and how they are used.

For instructions with a single storage address argument, the RB field consists of two bits. An RB field of two bits with its associated AM field of two bits are referred to as a 4-bit address argument or *addr4* in assembler syntax.

#### Example:

| Instruction<br>name | Syntax    |        |            |    |     |     |   |
|---------------------|-----------|--------|------------|----|-----|-----|---|
| Compare byte        | СВ        |        | addr4, reg |    |     |     |   |
| Operation code      | R         | RB     | AM         | Fu | nct | ion |   |
| 1 1 0 0 0           |           |        |            | 0  | 1   | 0   | 0 |
| 0 4                 | 5 7       | 89     | 10 11      | 12 |     |     | 1 |
| Appe<br>16          | nded word | I, AM= | =10 or 1   | 1  |     |     | 3 |

Bits 0–4 Operation code.

Bits 5-7 General register (0-7) for the second operand.

Bits 8-9 Base register (0-3).

Bits 10-11 Address mode.

Bits 12–15 Function.

Bits 16-31 Appended word for the first operand.

*Note.* The register specified by the RB field is a general register that is used as a base register for effective address generation.

Some instruction formats have two storage address arguments. In this case, the first operand has a 3-bit RB field giving a 5-bit address argument (*addr5* in assembler syntax) and the second operand has a 4-bit address argument.

Example:

| na me        | truction<br>me<br>Id Word |           | menmonic |       |      |      |     |        | <i>Syntax</i><br>addr5,addr4 |                   |  |  |
|--------------|---------------------------|-----------|----------|-------|------|------|-----|--------|------------------------------|-------------------|--|--|
| Opera<br>1 0 | tior<br>1                 | 1 cc<br>0 | ode<br>1 | R     | B1   | RE   | 32  | AM1    | AM2                          | <i>Fun</i><br>0 0 |  |  |
| 0            |                           |           | 4        | 5     | 7    | 8    | 9   | 10 11  | 12 13                        | 14 15             |  |  |
|              |                           | ***       | Ap       | pende | d wo | rd j | for | operan | d 1                          |                   |  |  |
| 16           |                           |           |          |       |      |      |     |        |                              | 31                |  |  |

| Appended word for operand 2 |    |
|-----------------------------|----|
| 32                          | 47 |

Bits 0-4 Operation code.

- Bits 5-7 Base register (0-7) for the first operand.
- Bits 8-9 Base register (0-3) for the second operand.
- Bits 10-11 Address mode for the first operand.
- Bits 12-13 Address mode for the second operand.
- Bits 14–15 Function.
- Bits 16-31 Appended word for the first operand.
- Bits 32-47 Appended word for the second operand.

#### Notes.

- 1. If there is no appended word for the first operand (AM1=00 or 01), the second operand word is appended to the instruction word in bits 16-31.
- 2. Registers specified by the RB fields are general registers.

#### Names of Instruction Formats

Names have been established for several categories of instructions. Each category has the same basic instruction format, therefore, the name is related to the format. In most cases, the name indicates the location of the operands or the type of instruction.

#### Examples:

- Register/Register Instructions. General registers are used by both operands.
- Storage/Storage Instructions. Both operands reside in main storage.
- Register/Storage Instructions. One operand uses a general register. The other operand resides in main storage.
- Register Immediate Instructions. One operand uses a general register. The other operand uses an immediate data field. The immediate data field is the low order byte of a one-word format or the second word of a two-word (long) format.
- Shift Instructions with Immediate Count. This is a shift instruction with the count field contained within the instruction word.
- Storage Immediate Instructions. One operand is in main storage. The other operand uses an immediate data field. The immediate data field is the second word of a two-word format.
- Parametric Instructions. For this instruction format, a parameter field (bits 8–15) is contained within the instruction word.

# Effective Address Generation

For purposes of storage efficiency, certain instructions formulate storage operand addresses in a specialized manner. These instructions have self-contained fields that are used when generating effective addresses. Standard methods for deriving effective addresses are included in this section. Other methods such as bit displacements, are explained in the individual instruction descriptions in Chapter 8.

**Programming note:** For certain instructions, the effective address points to a control block rather than an operand. These instructions are:

- Copy Floating Level Block (CPFLB) (optional floating-point feature)
- Copy Level Block (CPLB)
- Load Multiple and Branch (LMB)
- Pop Byte (PB)
- Pop Doubleword (PD)
- Push Byte (PSB)
- Push Doubleword (PSD)
- Push Word (PSW)
- Pop Word (PW)
- Set Floating Level Block (SEFLB) (optional floating point feature)
- Set Level Status Block (SELB)
- Store Multiple (STM)

**Base Register Word Displacement Short** 



Range 0 to 31 (decimal)

The five-bit unsigned integer (WD) is doubled in magnitude to form a byte displacement then added to the contents of the specified base register to form the effective address. The contents of the base register must be even.

Example:

| Operation code |            | n code RB  |   |   | WD  |      |     |      |    |      |      |      |
|----------------|------------|------------|---|---|-----|------|-----|------|----|------|------|------|
|                |            |            | 0 | 1 |     | 0    | 0   | 1    | 0  | 0    |      |      |
| 0              | 4          |            | 8 | 9 |     | 11   |     |      |    | 15   |      |      |
|                |            |            |   |   |     |      |     |      |    |      | Hex  | Dec  |
| Content        | s of regis | ter 1 (RB) |   |   | 000 | )0 ( | 000 | 0 01 | 10 | 0000 | 0060 | 0096 |
| Word dis       | splaceme   | nt (WD)    |   |   |     |      |     |      |    |      |      |      |
| double         | d          |            |   | - | ł   |      |     |      | 0  | 1000 | 8    | 8    |
| Effective      | e address  |            |   | - | 000 | 00 ( | 000 | ) 01 | 10 | 1000 | 0068 | 0104 |

#### **Base Register Word Displacement**

Instruction format



The eight-bit *signed* integer (WD) is doubled in magnitude to form a byte displacement then added to the contents of the specified base register to form the effective address. The contents of the base register must be even.

The word displacement can be either positive or negative; bit 8 of the instruction word is the sign bit for the displacement value. If this high-order bit of the displacement field is a 0, the displacement is positive with a maximum value of +127 (decimal). If the high-order bit of the displacement field is a 1, the displacement is negative with a maximum value of -128. The negative number is represented in two's complement form.

Example:

| Operation | code |   | RB |   | WD |   |   |   |   |   |   |    |
|-----------|------|---|----|---|----|---|---|---|---|---|---|----|
|           |      | 1 | 1  | 0 | 1  | 1 | 1 | 0 | 1 | 0 | 0 | 1  |
| 0         | 4    | 5 |    | 7 | 8  |   |   |   |   |   |   | 15 |

Note. This example uses a negative word displacement (-17 hex) shown in two's complement. Hex Dec

| _                                 |                      |      | 2    |
|-----------------------------------|----------------------|------|------|
| Contents of register 6 (RB)       | 0000 0000 1000 0110  | 0086 | 0134 |
| Word displacement (WD)<br>doubled |                      |      |      |
| (sign bit is propagated left)     | +1111 1111 1101 0010 | 2E   | - 46 |
| Effective address                 | 0000 0000 0101 1000  | 0058 | 0088 |

#### Four-Bit Address Argument



The Address Mode (AM) has the following significance:

AM=00. The contents of the selected base register form the effective address.

AM=01. The contents of the selected base register form the effective address. After use, the base register contents are incremented by the number of bytes in the operand. For some instructions, the effective address points to a control block rather than an operand. When the effective address points to a control block, the base register contents are incremented by two.

Example:

| Operat | ion code | RB  | AM    |    |
|--------|----------|-----|-------|----|
|        |          | 0 1 | 01    |    |
| 0      | 4        | 89  | 10 11 | 15 |

|                                               |                     | Hex  | Dec  |
|-----------------------------------------------|---------------------|------|------|
| Effective address<br>(contents of register 1) | 0000 0000 1000 0000 | 0080 | 0128 |
| Contents of register 1                        |                     |      |      |
| after instruction execution                   |                     |      |      |
| Byte operand                                  | 0000 0000 1000 0001 | 0081 | 0129 |
| Word operand                                  | 0000 0000 1000 0010 | 0082 | 0130 |
| Double word operand                           | 0000 0000 1000 0100 | 0084 | 0132 |
|                                               |                     |      |      |

Notes.

- 1. For register to storage instructions, if the specified register is the same for both operands, then the register is incremented prior to using it as an operand.
- 2. Certain instructions (storage to storage) have two address arguments. Operand 1 has a 3-bit RB field with its associated AM field. Operand 2 has a 2-bit RB field with its associated AM field. If both RB fields specify the same register and both AM fields are equal to 01, the base register contents are incremented prior to fetching operand 2 and again after fetching operand 2. Assuming the same conditions but with the operand 2 AM field not equal to 01, the base register contents are increments are increments are incremented prior to 2 AM field not equal to 01, the base register contents are incremented prior to 2 address for operand 2.
- 3. If the effective address points to a control block rather than an operand, the base register contents are incremented by two.

С

AM=10. An additional word is appended to the instruction. The word has the following format.

|    | Address or displacement |    |
|----|-------------------------|----|
| 16 |                         | 31 |

- If RB is zero, the appended word contains the effective address.
- If RB is non-zero, the contents of the selected base register and the contents of the appended word (displacement) are added to form the effective address.

Example:

| Operation code  |            | R   | B   | A  | M    |      |     |      |    |    |     |    |   | Ad | ldre | ess |   |   |   |   |   |   |   |    |
|-----------------|------------|-----|-----|----|------|------|-----|------|----|----|-----|----|---|----|------|-----|---|---|---|---|---|---|---|----|
|                 |            | 1   | 1   | 1  | 0    |      |     |      | 0  | 0  | 0_  | 0  | 0 | 0  | 0    | 1   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  |
| 0 4             |            | 8   | 9   | 10 | 0 11 | 12   | ?   | 15   | 16 | 5  |     |    |   |    |      |     |   |   |   |   | _ |   |   | 31 |
|                 |            |     |     |    |      |      |     |      | He | x  | De  | с  |   |    |      |     |   |   |   |   |   |   |   |    |
| Contents of reg | ister 3    |     | 00  | 00 | 100  | 0 0  | 000 | 0000 | 08 | 00 | 204 | 48 |   |    |      |     |   |   |   |   |   |   |   |    |
| Contents of app | pended wor | đ · | +00 | 00 | 000  | 01 0 | 000 | 0000 | 01 | 00 | 02: | 56 |   |    |      |     |   |   |   |   |   |   |   |    |
| Effective addre | <b>SS</b>  |     | 00  | 00 | 100  | 01 0 | 000 | 0000 | 09 | 00 | 23  | 04 |   |    |      |     |   |   |   |   |   |   |   |    |

AM=11. An additional word is appended to the instruction.

• If RB is zero, the appended word has the format:

| Indirect address |  |
|------------------|--|
| <br>             |  |

This address points to a main storage location, on an even byte boundary, that contains the effective address.

# Example:

| Operat | ion code | R | в | A  | М  |       | Γ  |   |   |   |   | In | dire | ect a | ıddı | ess |   |   |   |   |   |    |
|--------|----------|---|---|----|----|-------|----|---|---|---|---|----|------|-------|------|-----|---|---|---|---|---|----|
|        |          | 0 | 0 | 1  | 1  |       | 0  | 0 | 0 | 0 | 0 | 0  | 0    | 0     | 0    | 1   | 0 | 1 | 0 | 0 | 0 | 0  |
| 0      | 4        | 8 | 9 | 10 | 11 | 12 15 | 10 | 5 |   |   |   |    |      |       |      |     |   |   |   |   |   | 31 |

Hex Dec

Contents of appended word 0000 0000 0101 0000 0050 0080

Effective address equals

contents of storage at address 0080 (decimal) 0000 0100 0000 0000 0400 1024

• If **RB** is non-zero, the appended word has the format:

| Disp | lacement 1 | Displacement 2 |    |
|------|------------|----------------|----|
| 16   | 23         | 24             | 31 |

The two displacements are unsigned eight-bit integers. Displacement 2 is added to the contents of the selected base register to generate a main storage address. The contents of this storage location are added to Displacement 1 resulting in the effective address.



Example:

| <b>Operation</b> code                            | RB AM               | Displacement 1 | Displacement 2 |
|--------------------------------------------------|---------------------|----------------|----------------|
|                                                  |                     | 00100101       | 01000010       |
| 0 4                                              | 8 9 10 11 12 15     | 16 23          | 24 3.          |
|                                                  |                     | Hex Dec        |                |
| Contents of register 2                           | 0000 0101 0011 0101 | 0535 1333      |                |
| Displacement 2                                   | + 0100 0010         | 42 66          |                |
| Storage address                                  | 0000 0101 0111 0111 | 0577 1399      |                |
| Contents of storage<br>at address 1399 (decimal) | 0000 0100 0001 0000 | 0410 1040      |                |

 Displacement 1
 +
 0010 0101
 25
 37

 Effective address
 0000 0100 0011 0101
 0435
 1077

Note. This example is invalid for other than a byte operand.

**Programming Note.** This addressing mode (AM=11, RB is non-zero) is useful for the directorized data concept. For the *addr4* or *addr5* assembler syntax, the programmer codes the form *displacement 1 (register, displacement 2)\**. For addr4, the specified register is 1-3. For addr5, the specified register is 1-7. The asterisk denotes indirect addressing.



#### Five-Bit Address Argument



Operation of this mode is identical to the four-bit argument, but provides additional base registers.

#### **Base Register Storage Address**



8

- If RB is zero, the address field contains the effective address.
- If RB is non-zero, the contents of the selected base register and the contents of the address field are added together to form the effective address.

Note. Bit 11, if a one, specifies that the effective addressing is indirect.

#### Example: Indirect address

| Operation code                              | RB                   |      |      |   | A   | ddre | ss  |   |   | • |   |   |    |
|---------------------------------------------|----------------------|------|------|---|-----|------|-----|---|---|---|---|---|----|
|                                             | 1 0 0 1              | 0 0  | 0 0  | 0 | 1 0 | 0    | 0 0 | 0 | 1 | 0 | 0 | 0 | 0  |
| 0 4                                         | 8 10 11 12 15        | 16   |      |   |     |      |     |   |   |   |   |   | 31 |
|                                             |                      | Hex  | Dec  |   |     |      |     |   |   |   |   |   |    |
| Contents of register 4                      | 0000 0001 0000 0000  | 0100 | 0256 |   |     |      |     |   |   |   |   |   |    |
| Address field                               | +0000 0100 0001 0000 | 0410 | 1040 |   |     |      |     |   |   |   |   |   |    |
| Storage address                             | 0000 0101 0001 0000  | 0510 | 1296 |   |     |      |     |   |   |   |   |   |    |
| Effective address<br>Contents of storage at |                      |      |      |   |     |      |     |   |   |   |   |   |    |
| address 1296 (decimal)                      | 0000 0110 0100 0000  | 0640 | 1600 |   |     |      |     |   |   |   |   |   |    |

1

#### Instruction Length Variations for Address Arguments

• One-word instructions that contain a single AM field become two words in length if AM is equal to 10 or 11. The AM appended word follows the instruction word.

#### Example:



• Two-word instructions that contain a single AM field become three words in length if AM is equal to 10 or 11. The AM word is appended to the first instruction word. The *data* or *immediate* field then becomes the third word of the instruction.

#### Example:



• One-word instructions that contain two AM fields (AM1 and AM2) may be one, two, or three words in length depending on the values of AM1 and AM2. The AM1 word is appended first, then the AM2 word is appended.



# **Processor State Control**

The processor is always in one of the following mutually exclusive states:

- Power off
- Stop
- Load
- Wait
- Run when in run state, programs can be executed in either:
  - Supervisor state or
  - Problem state

# Stop State

The stop state is entered when:

- 1. The Stop key on the programmer console is pressed.
- 2. The STOP instruction is executed and (a) the mode switch on the basic console is in the Diagnostic position, and (b) the optional programmer console is installed.
- 3. An address-compare occurs and the rate control on the programmer console is in the Stop on Address position.
- 4. An instruction has completed execution and the rate control on the programmer console is in the Instruction Step position.

5. An error occurs and the error control on the programmer console is in the Stop on Error position.

47

- When the processor stops, the check indicator is on and the appropriate PSW bits are set to one.
- A subsequent depression of any console key turns off the check indicator but does not affect the PSW.
- The next depression of the Start key (assuming no system reset) allows a class interrupt to occur based on the PSW bit of the highest priority.
- 6. The Reset key on the programmer console is pressed.
- 7. Power-on reset occurs.

While the processor is in the stop state: (1) the Stop light on the programmer console is on, (2) the functions provided on the console can be activated, and (3) no interrupt requests can be accepted by the processor.

Note that the check indicator on the programmer console is used solely as an indication of main storage parity when the processor is in stop state (after the first key depression). Refer to Chapter 7 for console information.

Certain error or exception conditions cannot occur during stop state. These are; specification check, privilege violate, invalid function, floating-point exception, stack exception, and CPU control check. These conditions are explained in the PSW section of Chapter 3. If an I/O check condition occurs during stop state, PSW bits 11 and 12 are set to one and the condition is preserved by hardware. The check indicator is not turned on. A subsequent depression of the Start key (assuming no system reset) allows a machine check class interrupt to occur.

If a power/thermal warning condition occurs during stop state, PSW bit 15 is set to one and remains set for the duration of the condition. A subsequent depression of the Start key allows a power/thermal warning class interrupt to occur assuming the condition is still active and no system reset has occurred.

The processor exits the stop state when:

- 1. The Load key on the basic console is pressed.
- 2. The Start key on the programmer console is pressed. When the Start key is pressed, the processor returns to the state that was exited before entering stop state. If the run state is entered, one instruction is executed before interrupts are accepted by the processor. If the stop state was entered because of a reset (poweron reset or reset key), pressing the start key causes program execution to begin on level zero with the instruction in location zero of main storage. If the stop state was entered because of an error, with the Stop on Error switch turned on, a system reset or class interrupt can clear the error condition. For more information about system reset, see State of Processor Following a Reset.

Notes.

- 1. Any manual entry into Stop State is via the programmer console.
- 2. The STOP instruction performs no operation if the programmer console is not installed.

#### Wait State

The processor enters wait state when: (1) a Level Exit (LEX) instruction is executed and no other level is pending, or (2) a Set Level Block (SELB) instruction is executed that sets the current in-process bit off and no level is pending. While the processor is in the wait state, (1) the Wait light on the basic console is on and (2) interrupts can be accepted under control of the system mask register and the summary mask as defined by the LSR of the last active level.

The processor exits the wait state when:

- 1. The Stop key on the programmer console is pressed.
- 2. The Reset key on the programmer console is pressed.
- 3. An I/O interrupt is accepted (the level must be enabled by the summary mask and the mask register).
- 4. A class interrupt occurs. (See *Class Interrupts* in Chapter 3.)

## Load State

The processor enters the load state when initial program load (IPL) begins. This occurs:

- 1. When the Load key on the basic console is pressed.
- 2. After a power-on reset if the Mode switch is in the Auto IPL position.
- 3. When an IPL signal is received from a host system.

While the processor is in load state, the Load light on the basic console is on.

The processor exits the load state and enters the run state upon successful completion of the IPL. See *Initial Program Load (IPL)*.

## **Run State**

The processor enters the run state when not in the stop, wait, or load state. Run state is entered:

- 1. From load state upon successful completion of IPL.
- 2. From wait state when an interrupt is accepted.
- 3. From stop state when the start key is pressed. (See *Stop State.*)

The processor exits run state when entering stop, wait, or load states as previously described.

#### Supervisor State and Problem State

While in run state, instructions can be executed in either supervisor state or problem state. This is determined by bit 8 of the level status register (LSR):

| State      | LSR Bit 8 |
|------------|-----------|
| Supervisor | 1         |
| Problem    | 0         |

Supervisor and problem states are discussed in the following sections.

Supervisor State. The processor enters supervisor state when:

- 1. A class interrupt occurs. This type of interrupt is caused by the following:
  - a. Machine check condition
  - b. Program check condition
  - c. Power/thermal warning
  - d. Supervisor Call (SVC) instruction
  - e. Soft exception trap condition
  - f. Trace bit (LSR bit 10) set to one
  - g. Console Interrupt key on the programmer console
- 2. An I/O interrupt is accepted.
- 3. After initial program load (IPL) has been completed.

Class interrupts and I/O interrupts are discussed in Chapter 3. Initial program load is discussed in a subsequent section of this chapter.

instructions may only be executed in supervisor state: Copy Address Key Register (CPAKR) Copy Console Data Buffer (CPCON) Note 1 Copy Current Level (CPCL) Copy In-Process Flags (CPIPF) Copy Interrupt Mask Register (CPIMR) Copy Instruction Space Key (CPISK) Copy Floating Level Block (CPFLB) Note 2 Copy Level Status Block (CPLB) Copy Operand 1 Key (CPOOK) Copy Operand 2 Key (CPOTK) Copy Processor Status and Reset (CPPSR) Copy Segmentation Register (CPSR) Note 3 Copy Storage Key (CPSK) Diagnose (DIAG) Disable (DIS) Enable (EN) Interchange Operand Keys (IOPK) Level Exit (LEX) Operate I/O (IO) Set Address Key Register (SEAKR) Set Console Data Lights (SECON) Note 4 Set Floating Level Block (SEFLB) Note 2 Set Instruction Space Key (SEISK)

When the processor is in supervisor state, the full

instruction set may be executed. The following privileged

Set Interrupt Mask Register (SEIMR) Set Level Status Block (SELB) Set Operand 1 Key (SEOOK) Set Operand 2 Key (SEOTK) Set Segmentation Register (SESR) Note 3 Set Storage Key (SESK)

#### Notes.

- 1. The resultant data is unpredictable if the programmer console feature is not installed.
- 2. Invalid (soft exception trap) if the floating-point feature is not installed.
- 3. Invalid (program check) if the relocation translator feature is not installed.
- 4. Performs no operation if the programmer console feature is not installed.

Supervisor State overrides the storage protection mechanism. This permits unlimited access to all of main storage regardless of address keys or storage keys (see Chapter 5). When the Storage Address Relocation Translator Feature is installed and enabled, storage protection works differently. Supervisor State can only access the storage defined by the active address keys (see Chapter 6). Address key 0 is implicitly assigned to the supervisor for handling interrupts. **Problem State.** This is a state that does not allow the processor to execute the privileged instructions. The processor enters the problem state when the supervisor state bit (LSR bit 8) is turned off. This can be accomplished with a Set Level Status Block (SELB) instruction. This instruction can change the contents of the registers for a selected priority interrupt level.

While the processor is in problem state, privileged instructions cannot be executed. If a privileged instruction execution is attempted, the instruction is suppressed and a program check class interrupt occurs, with privilege violate (bit 2) set in the processor status word.

## State of Processor Following a Reset

The term *reset* used in the following sections denotes the reset action that occurs during:

- 1. Power-on reset
- 2. Initial program load (IPL) reset
- 3. System reset initiated by pressing the Reset key on the programmer console

The following registers and conditions *are not affected* by a reset and must be initialized by the program or operator before they become valid:

- AKR on levels 1-3
- Console data buffer (programmer console feature)
- General registers
- IAR on levels 1–3
- Storage key registers (storage protection)
- Main storage
- Segmentation registers (relocation translator feature)
- Floating-point registers (floating-point feature)

The following registers and conditions *are affected* by a reset:

- CIAR set to zeros
- IAR on level zero set to zeros
- Mask register set to ones (all levels enabled)
- LSR on level zero
  - Indicators set to zeros
  - Supervisor state (bit 8) set on
  - In-process (bit 9) set on
  - Trace (bit 10) set to zero (disabled)
  - Summary mask (bit 11) set on (enabled)
  - All other bits set to zeros
- AKR on level zero is set to zeros
- PSW set to zeros except as noted
  - Auto-IPL (bit 13) set to zero unless the reset was caused by an Auto-IPL
  - Power/thermal (bit 15) reflects the status of the power/thermal condition
- LSR on levels 1-3 set to zeros
- SAR set to zeros

# Initial Program Load (IPL)

An initial program load function is provided to (1) read an IPL record (set of instructions) from an external storage media, and (2) automatically execute a start-up program. An IPL record is read into storage from a local I/O device or host system. The I/O attachments for the desired IPL sources are prewired at installation time. Two local sources, primary and alternate, can be wired and either can be selected by using the IPL Source switch on the console.

IPL can be started by three methods:

- 1. Manually, by pressing the Load key on the console.
- 2. Automatically, after a power-on condition.
- 3. Automatically, when a signal is received from a host system. The host system can be connected through a communications adapter.

The automatic power-on IPL is selected by a Mode switch on the console. When the Mode switch is in the Auto-IPL position, IPL occurs whenever power turns on (either initially or after a power failure). Auto IPL is useful for unattended systems. A manual IPL can be initiated at any time by pressing the Load key on the console (even when in run state). The Mode switch has no effect on the manual IPL. For Auto-IPL and manual IPL, the local IPL source (primary or alternate) is selected. IPL from a host system can occur at any time and is initiated by the host system. The IPL record is transferred through the hostsystem device; for example, the communications adapter. When an auto-IPL occurs, bit 13 of the PSW is turned on to indicate the condition to the software. When a manual or host-system IPL occurs, this bit is set to zero.

During IPL, the storage protection mechanism is disabled and main storage is loaded starting at location zero. The length of the IPL record depends on the media used by the IPL source. Upon successful completion of an IPL, the processor enters supervisor state and begins execution on priority level zero. The summary mask is enabled and all priority interrupt levels in the mask register are enabled. The level zero AKR is set to all zeros. The first instruction to be executed is at main storage location zero. The IPL source has a pending interrupt request on level zero. The system program must:

- 1. Perform housekeeping; for example, load vector table addresses in the reserved area of storage (see *Automatic Interrupt Branching* in Chapter 3).
- 2. Issue a Level Exit (LEX) instruction. This allows the processor to accept the interrupt from the IPL source. When the interrupt is accepted, a forced branch is taken using the device-address vector table. The vector table entry is determined by the device address of the IPL source and results in a branch to the proper program routine for handling the interrupt. The device address of the IPL source is set into bits 8–15 of register 7 on level zero. Condition code 3, device end, is reported by the IPL source. For additional information, see *I/O Interrupts* in Chapter 3.

A system reset always occurs prior to an IPL. However, if any errors occur during the IPL, the results are unpredictable.

### Sequential Instruction Execution

Normally, the operation of the processor is controlled by instructions taken in sequence. An instruction is fetched from the main storage location specified in the instruction address register (IAR). The instruction address in the IAR is then increased by the number of bytes in the instruction just fetched. The IAR now contains the address of the next sequential instruction. After the current instruction is executed, the same steps are repeated using the updated address in the IAR.

A change from sequential operation can be caused by branching, jumping, interrupts, level switching, or manual intervention.



# Jumping and Branching

The normal sequential execution of instructions is changed when reference is made to a subroutine; when a two-way choice is encountered; or when a segment of coding, such as a loop, is to be repeated. All of these tasks can be accomplished with branching and jumping instructions. Provision is also made for subroutine linkage, permitting not only the introduction of a new instruction address, but also the preservation of the return address and associated information.

The conditional branch and jump instructions are used to test the indicators in the LSR. These indicators are set as the result of I/O operations and most arithmetic or logical operations. Single or multiple indicators are tested as determined by the value in a three-bit field within the instruction. Refer to: (1) *Indicators* and (2) *Testing Indicators with Conditional Branch and Jump Instructions*.

# Jumping

Jump instructions are used to specify a new instruction address relative to the address in the IAR. The new address must be within -256 to +254 of the byte following the jump instruction.

*Note.* The jump instruction contains a word displacement that is converted to a byte displacement when the instruction is executed. However, when using the assembler, the programmer specifies a byte value that is converted to a word displacement by the assembler.

### Branching

Branch instructions are used to specify a new full-width 16-bit address. A 16-bit value, range 0 to 65535, is contained in the second word of the instruction or in a register. The value in the second word can be used as the effective branch address or added to the contents of a base register to form an effective address. (See *Base Register Storage Address* in this chapter.)

# Level Switching and Interrupts

The processor can execute programs on four different interrupt priority levels. These levels, listed in priority sequence, are numbered 0, 1, 2, and 3 with level 0 having highest priority. The processor switches from one level to another in two ways:

- 1. Automatically, when an interrupt request is accepted from an I/O device operating on a higher priority level than the current level.
- 2. Under program control, by using the Set Level Block (SELB) instruction.

Both types of level switching are discussed in detail in Chapter 3. *Class Interrupts* and *Interrupt Masking Facilities* are also discussed in Chapter 3.

# Stack Operations

The processing unit provides two types of stacking facilities. Each facility is briefly described in this section. Additional information appears in subsequent sections. The two types of stacking facilities are:

- Data Stacking. This facility provides an efficient and simple way to handle last-in first-out (LIFO) queues of data items and/or parameters in main storage. The data items or parameters are called stack elements. For a given queue (or stack), each element is one, two, or four bytes wide. Instructions for each element size (byte, word, or doubleword) are provided to:
   a. Push an element into a stack (register to storage).
  - b. Pop an element from a stack (storage to register).
- Linkage stacking. This facility provides an easy method for linking subroutines to a calling program. A word stack is used for saving and restoring the
  - status of general registers and for allocating dynamic work areas. The Store Multiple (STM) instruction stores the contents of the registers into the stack and reserves a designated number of bytes in the stack as a work area. The Load Multiple and Branch (LMB) instruction reloads the registers, releases the stack elements, and causes a branch via register 7 back to the calling program.

*Note.* The Store Multiple instruction *pushes* a block of information into a stack. This block is referred to as a register block. The Load Multiple and Branch instruction *pops* a register block from a stack.

# **Data Stacking Description**

Any contiguous area of main storage can be defined as a stack. Each stack is defined by a stack control block. Figure 2-4 shows a data stack and its associated *stack control block*. Stack control blocks must be aligned on a word boundary.

The words in the stack control block are used as follows:



Figure 2-4. Relationship of stack control block to data stack

 $\mathbf{C}$ 

High Limit Address (HLA). This word contains the address of the first byte beyond the area being used for the stack. All data in the stack has a lower address than the contents of the HLA. Note that the HLA points to the first byte beyond the bottom of an empty stack.

Low Limit Address (LLA). This word designates the lowest storage location that can be used for a stack element. Note that the LLA points to the top of a stack.

**Top Element Address (TEA).** This word points to the stack element that is currently on top of the stack. For empty stacks, the TEA points to the same location as the high limit address (HLA).

### Notes.

- 1. For word, double word, and register block operations, the HLA, LLA, and TEA must all contain an even address to ensure data alignment on a word boundary.
- 2. The HLA and LLA define a contiguous range of addresses. These addresses must not cross the 64K byte boundary that causes storage to wrap.

**Push Operation**. When a new element is pushed into a stack, the address value in the TEA is decremented by the length of the element (one, two, or four bytes) and compared against the LLA. If the TEA is less than the LLA, a stack overflow exists. A soft exception trap interrupt occurs with *stack exception* set in the PSW. The TEA is unchanged. If the stack does not overflow, the TEA is updated and the new element is moved to the top location defined by the TEA.

The following diagram shows how elements are pushed into a stack. Note that each push operation always places an element at a lower address in the stack than the preceding element.



Refer to Chapter 8 for descriptions of the following instructions:

- Push Byte (PSB)
- Push Word (PSW)
- Push Doubleword (PSD)

*Note.* For a push doubleword operation, the TEA points to the high-order word of the doubleword operand.

**Pop Operation.** When an element is popped from a stack, the TEA is compared against the HLA. If it is equal to or greater than the HLA, an underflow condition exists. A soft exception trap interrupt occurs with *stack exception* set in the PSW. If the stack does not underflow, the stack element defined by the TEA is moved to the specified register and the TEA is incremented by the length of the element.

The following diagram shows how elements are popped from a stack.



Refer to Chapter 8 for descriptions of the following instructions:

- Pop Byte (PB)
- Pop Word (PW)
- Pop Doubleword (PD)

*Note.* It is possible to pop data from beyond a stack boundary if (1) the TEA is less than the HLA, and (2) the operand size is greater than HLA minus TEA.

### Data Stacking Example - Allocating Fixed Storage Areas

Many programs require temporary main storage work areas. It is very useful to be able to dynamically assign such workarea storage to a program only when that storage is needed. Conversely, when work-area storage is no longer needed by a program, it is desirable to free that resource so it may be used by other programs. Use of the stacking mechanism can assist in the programming of the dynamic storage management function.

The following is an example of how storage areas could be allocated using the stacking mechanism.

A stack is initialized with addresses that point to fixed areas of storage. Each element in the stack represents the starting address of a block of storage consisting of 512 bytes; e.g., addresses 0200 through 03FF. As storage is needed, the starting address for a block of storage is popped from the stack. When the block of storage is no longer needed, the starting address is pushed back into the stack. The stack control block, stack, and storage areas appear initially as follows:



storage

Notice that each stack element is one word long; addresses of storage areas are the stack elements; the TEA points to the lowest location of the last element because the initialized stack is *full*. Contrast this with an empty stack, in which the TEA points to the same location as the HLA.

Now assume that program A requires a block of storage. Program A (or a storage management function at the request of program A) issues a pop word instruction against the stack control block. The TEA is updated as follows:







HLA = 0B08 ----



 $\square$ 

The word element popped is placed in the register specified by the pop word instruction executed by program A. This is the address of the 512-byte storage area beginning at address 0200.

At this time, assume that program B (operating on a different hardware level than program A) also requires a storage area. It too executes a pop word instruction against the stack. The next element is moved to the register specified and points to the next available storage area and the TEA is updated:







Now, before any further requests occur, program A terminates its need for a work area. Program A then issues a push word instruction against the stack and returns the address of the area it was using for use by other programs:



A similar operation will be performed by program B when it releases its storage to the stack, popping address 0400 into location 0B00. While the addresses are obviously shuffled in the stack (from the values initially established), this presents no problem since each program requires only an area of storage — it is not important where that area is located.

### Linkage Stacking Description

A

As previously described a word-stack mechanism may be used for subroutine linkage. This mechanism saves and restores registers and allocates dynamic work areas.

The letters in the following description correspond to the letters in Figure 2-5.

Stack control block







The Store Multiple (STM) instruction specifies:

Stack control block address

A

В

С

Limit register (RL) number

Number (N) of words to allocate for work areas

When the STM instruction is executed, the allocate value (N), plus the number of registers saved, plus one control word, is the requested block size in words. The block size (converted to bytes) is used to decrement the TEA before an overflow check is made. If no overflow occurs the operation proceeds. The link register (R7) and register 0 through the specified limit register (RL) are saved sequentially in the stack. If register 7 is specified as the limit register, only register 7 is stored in the stack. The dynamic work space is allocated and a pointer to the work area is returned in register RL. If no work area is specified, the returned pointer contains the location of R7 in the stack. The values of RL and N are also saved as an entry in the stack. The TEA is updated to point to the new top of stack location.

When a Load Multiple and Branch (LMB) instruction is executed, the values of RL and N are retrieved from the stack and an underflow check is made. The value of RL controls the reloading of the registers; the values of RL and N are used to restore the stack pointer (TEA) to its former status. The contents of register 7 are then loaded into the instruction address register, returning program control to the calling routine.

### Linkage Stacking Example – Reenterable Subroutine

A subroutine may be used by programs that operate on different interrupt levels. Rather than providing copies of the subroutine, one copy for each program that needs it, the subroutine can be made reenterable. Here, only one copy of the subroutine is provided; the single copy is used by all requesting programs. Two items must be considered in the reenterable subroutine code:

- Saving the register contents of each calling program. The subroutine is then free to use the same registers, restoring their contents to the calling-program's values just prior to returning to the calling program.
- Preserving the applicable variable data (generated by the subroutine) that is related to each call of the subroutine. That is, data associated with one call must not be disturbed when subroutine execution is restarted due to another call from a higher priority program.

The stacking mechanism, by means of the STM and LMB instructions, handles the two items just mentioned. As an example, operation could proceed as follows:

- Program A calls the subroutine by means of a branch and link instruction (return address is in R7).
   BAL SUBRT,7
- 2. The subroutine, in this example, uses registers R3 and R4 during its execution. The subroutine receives (from program A) a parameter list address in R0 and the address of the stack control block in R1. Also, the subroutine requires 20 bytes of work space. Thus, the subroutine executes, upon entry, the following store multiple instruction:

# SUBRT STM 4,(1),20

After execution of the STM, the stack contains the following:

Stack LLA TEA 4 10 n 15 2 R4 N=10 20 bytes **R**7 R0 **R1** R2 **R**3 R4

### HLA -----

\*The last word contains a value that specifies the last register stored (e.g., R4 in this example) and the size of the dynamic work area (in words). R4 (the last register stored in the stack) is automatically loaded, during the STM operation, with the address of the work area to be used by the subroutine to hold its work data.

3. When subroutine processing for this call is completed, the subroutine executes a single load multiple instruction in order to reload the registers and return (via R7) to the calling program:

### LMB(1)

If a second call to the subroutine has occurred prior to execution of the LMB, action similar to that just stated would occur again. However, another stack area would be used. Then, when subroutine execution is completed for the second call, and all higher priority interrupt level processing is completed, a return would be made to the interrupted subroutine for completion of processing for the first call.

Thus, multiple calls to a single subroutine are processed without interfering with the integrity of data associated with any other call to the subroutine.

.

.

# Chapter 3. Interrupts and Level Switching

# Introduction

Efficient operation of a central processor depends on prompt response to I/O device service requests. This is accomplished by an interrupt scheme that stops the current processor operation, branches to a device service routine, handles device service, then returns to continue the interrupted operation. One processor can control many I/O devices; therefore, an interrupt priority is established to handle the more important operations before those of lesser importance. Certain error or exception conditions (such as machine check) also cause interrupts. These are called class interrupts and are processed in a manner similar to I/O interrupts. Both I/O and class interrupts are explained further in the following sections.

Interrupt priority is established by four priority levels of processing. These levels, listed in priority sequence, are numbered 0, 1, 2, and 3 with level 0 having highest priority. Interrupt levels are assigned to I/O devices via program control. This provides flexibility for reassigning device priority as the application changes.

Each of the four priority levels has its own set of registers. These consist of an address key register (AKR), a level status register (LSR), eight general registers (R0–R7), and an instruction address register (IAR). Information pertaining to a level is automatically preserved in these hardware registers when an interrupt occurs.

Processor level switching, under program control, may be accomplished by use of the Set Level Block (SELB) instruction. Details of this method are presented in a separate section of this chapter.

I/O and class interrupts cause automatic branching to a service routine. Fixed locations in main storage are reserved for branch addresses or pointers that are referenced during interrupt processing. This storage allocation is shown in the section Automatic Interrupt Branching in this chapter. Interrupt masking facilities provide additional program control over the four priority levels. System and level masking are controlled by the *Summary Mask* and the *Interrupt Level Mask Register*. Device masking is controlled by the *Device Mask*. Manipulation of the mask bits can enable or disable interrupts on all levels, a specific level, or for a specific device. See *Interrupt Masking Facilities* in this chapter.

### **Interrupt Scheme**

As previously stated, four priority interrupt levels exist. Each I/O device is assigned to a level, dependent on the application. When an interrupt on a given level is accepted, that level remains active until (1) a Level Exit (LEX) instruction is executed, (2) a Set Level Block (SELB) instruction causes a level switch, or (3) a higher priority interrupt is accepted. In the first two cases, the active level at the time is cleared. In the latter case, the processor switches to the higher level, completes execution (including a LEX or SELB instruction), then automatically returns to the interrupted-from level. This automatic return can be delayed by other higher priority interrupts.

If an interrupt request is pending on the currently active level, it will not be accepted until the level is cleared by a LEX or SELB instruction. If no other level of interrupt is pending when a program exits the current level, the processor enters the wait state. In the wait state no processing is performed, but the processor can accept interrupts that are expected to occur. See Figure 3-1.

*Class* interrupts do not change priority levels. They are processed at the currently active level. If the processor is in the wait state when a class interrupt occurs, priority level 0 is used to process the interrupt.



Figure 3-1. Interrupt priority scheme

# Automatic Interrupt Branching

Hardware processing of an interrupt includes automatic branching to a service routine. The processor uses a reserved storage area for branch information. The reserved area begins at main storage address 0000. The total size of the area depends on the number of interrupting devices attached. One word (two bytes) is reserved for each interrupting device and is related to a particular device by the device address. For example: device 00 causes a reference to location 0030, device 01 to location 0032, and so on. The device area begins at address 0030 (Hex); the reserved area is 0000 through 022F (Hex) if 256 devices (maximum number) are attached. These storage locations and contents are shown in Figure 3-2.

| Main storage<br>address (Hex) | Contents of word                |
|-------------------------------|---------------------------------|
| audress (nex)                 | Contents of word                |
| 022E                          | Device FF DDB pointer           |
| á                             | ÷                               |
| 0032                          | Device 01 DDB pointer           |
| 0030                          | Device 00 DDB pointer           |
| 002E                          | Reserved                        |
| 002C                          | Reserved                        |
| 002A                          | Reserved                        |
| 0028                          | Reserved                        |
| 0026                          | Reserved                        |
| 0024                          | Reserved                        |
| 0022                          | Soft exception trap SIA         |
| 0020                          | Soft exception trap LSB pointer |
| 001E                          | Console interrupt SIA           |
| 001C                          | Console interrupt LSB pointer   |
| 001A                          | Trace SIA                       |
| 0018                          | Trace LSB pointer               |
| 0016                          | Power failure SIA               |
| 0014                          | Power failure LSB pointer       |
| 0012                          | SVC SIA                         |
| 0010                          | SVC LSB pointer                 |
| 000E                          | Program check SIA               |
| 000C                          | Program check LSB pointer       |
| 000A                          | Machine check SIA               |
| 0008                          | Machine check LSB pointer       |
| 0006                          | Reserved                        |
| 0004                          | Reserved                        |
| 0002                          | Restart instruction word 2      |
| 0000                          | Restart instruction word 1      |

Figure 3-2. Reserved storage locations

The reserved storage locations are described as follows:

| Storage Location<br>(Hex) | Contents                                                                                                                                                                                                                                                      |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000-0003                 | Restart instruction. Following IPL a forced branch is made to location 0000.                                                                                                                                                                                  |
| 0004-0005                 | Reserved.                                                                                                                                                                                                                                                     |
| 0006-0007                 | Reserved.                                                                                                                                                                                                                                                     |
| 0008–0023                 | Addresses used for class interrupts. The Level<br>Status Block (LSB) pointer is the first address<br>of an area where a level status block will be<br>stored. The Start Instruction Address (SIA)<br>points to the first instruction of a service<br>routine. |
| 0024-002F                 | Reserved.                                                                                                                                                                                                                                                     |
| 0030–022F                 | Addresses used for I/O interrupts. The Device Data Block (DDB) pointer is the address of the first word of a device data block. This word is used to obtain the start instruction address for the service routine. See $I/O$ Interrupts in this chapter.      |

*Note.* The area reserved for I/O devices varies in size depending on the number of devices. The device address determines the fixed location to be accessed. For example: Interrupts for device 01 always vector to main storage address 0032.

A device address is established by installing the appropriate connectors on the I/O feature card for the device.

# **I/O Interrupts**

# Prepare I/O Device for Interrupt

I/O device interrupt parameters are established via program control. The Operate I/O (IO) instruction initiates the device operation and in conjunction with the "Prepare" I/O command tells the device:

- 1. If the device can interrupt.
- 2. What priority level to use for interrupts. See Chapter 8 *Instructions* and Chapter 4 *Input/Output Operations* for details of the Operate I/O instruction.

Execution of the Prepare command transfers a word to the addressed device that controls its interrupt parameters. This word has the format:

| Zero | Level    | Ι  |
|------|----------|----|
| 0    | 10 11 14 | 15 |

Bits Contents

0-10 Set to zeros.

11-14 Level. A four-bit encoded field that assigns an interrupt priority level to the device (see note).
Example: 0000 - level 0, 0001 - level 1, 0010 - level 2, 0011 - level 3.

15 Device mask or I-bit. This bit sets the interrupt mask in the device. When set to one, the device can interrupt. When set to zero, the device cannot request an interrupt.

*Note.* The 4955 Processor does not recognize priority levels other than zero through three; therefore, bits 11 and 12 must always be set to zero or the interrupt is lost.

An interrupting device is always able to accept and execute a Prepare command, even if it is presently busy or has an interrupt request pending from a previous command. This allows the software to change the device mask and interrupt level at any time. Any pending interrupt request is then serviced on the new interrupt level.

# Present and Accept I/O Interrupt

The I/O device presents an interrupt request on its assigned priority level. This request is applied to the interrupt algorithm for acceptance determination.

For an I/O interrupt to be serviced, the following conditions must exist:

- 1. The summary mask must be on (enabled).
- 2. The mask bit (Interrupt Level Mask Register) for the interrupting level must be on (enabled).
- 3. For I/O interrupts the device must have its Device Mask bit on (enabled).
- 4. The interrupt request must be the highest priority of the outstanding requests and higher than the current level of the processor.
- 5. The processor must not be in the stop state.

Supervisor state is entered upon acceptance of all priority interrupts.

Following acceptance, the device sends an interrupt ID word and a condition code to the processor. The condition code is placed in the even, carry, and overflow indicators for the interrupted-to level. The ID word is placed into register 7 of the interrupted-to level. The interrupt ID word consists of an interrupt information byte (bits 0-7) and the device address (bits 8-15). See Chapter 4 for condition codes and interrupt information byte (IIB) details. Hardware causes the following events to occur after the processor receives the interrupt ID word and the condition code (Figure 3-3):



Figure 3-3. Example of I/O interrupt with automatic branching

- C
- The processor hardware switches from the registers and status of the interrupted-from level to those of the interrupted-to level.
- The interrupt ID word is placed in register 7 of the interrupted-to level.
- The condition code is placed in LSR positions 0–2.
- Supervisor state is entered (LSR bit 8 is set to one).
- The processor executes an automatic branch.
  - The device address is used by hardware to fetch the DDB pointer from reserved storage.
  - The DDB pointer is placed in register 1 of the interrupted-to level.
  - The DDB pointer is used by hardware to fetch the start instruction pointer.
  - The Start Instruction Address (SIA) is loaded into the IAR of the interrupted-to level.
- Execution begins on the new level.

# **Class Interrupts**

System error or exception conditions can cause seven types of class interrupts:

- 1. Machine check, caused by a hardware error.
- 2. Program check, caused by a programming error.
- 3. Power/thermal warning, caused by a power or thermal irregularity.
- 4. Supervisor call, caused by execution of an SVC instruction.
- 5. Soft exception trap, caused by software.
- 6. Trace, caused by instruction execution (trace enabled in the current LSR).
- 7. Console, caused by a console interrupt when the optional programmer console is installed.

Machine check, program check, soft exception trap, and power/thermal warning are defined by bits in the processor status word. Software can refer to the processor status word for a specific condition and any related status information. See *Processor Status Word* in this chapter.

Class interrupts do not cause a change in priority level. The interrupt is serviced on the level that is active when the condition occurs. If the processor is in the wait state, the interrupt is serviced on priority level zero. Independent routines are used to handle each type of class interrupt regardless of priority level.

All class interrupts cause the processor to enter supervisor state. Refer to a subsequent section, *Present and Accept Class Interrupt*, for details of the hardware processing.

### Programming Notes.

- 1. Two class interrupts (power/thermal warning and console) can be disabled by the summary mask.
- 2. If the optional programmer console is installed and Check Restart is selected, machine check, power/ thermal warning, and program check interrupts do not occur. If Stop on Error is selected, a stop occurs before a machine check, power/thermal warning, or program check interrupt is serviced. See *Programmer Console Feature* in Chapter 7.

# **Priority of Class Interrupts**

Although class interrupts are serviced on the current priority level, they are serviced according to an exception condition priority.

The following table lists the exception conditions in priority sequence with zero being the highest priority. Two exception conditions of the same priority, such as protect check and specification check, may be reported to the PSW simultaneously. The table also shows the associated class interrupt vector for the exception conditions.

| Priority | Exception Condition                            | Class Interrupt<br>Routine |
|----------|------------------------------------------------|----------------------------|
| 0        | CPU control check<br>I/O check                 | Machine check              |
| 1        | Invalid function (Note 1)                      |                            |
| 2        | Privilege violate                              |                            |
| 3        | Invalid function (Note 2)                      |                            |
| 4        | Protect check<br>Specification check           | Program check              |
| 5        | Invalid storage address<br>Specification check |                            |
| 6        | Storage parity                                 | Machine check              |
| 7        | Power warning<br>Thermal warning               | Power/thermal<br>warning   |
| 8        | Supervisor call                                | Supervisor call            |
| 9        | Invalid function (Note 3)                      |                            |
| 10       | Floating-point exception                       | Soft exception<br>trap     |
| 11       | Stack exception                                | uup                        |
| 12       | Trace                                          | Trace                      |
| 13       | Console                                        | Console                    |

Note 1. Caused by an illegal operation code or function combination.

*Note 2.* A Copy Segmentation Register (CPSR) or Set Segmentation Register (SESR) instruction is attempted and the translator feature is not installed.

Note 3. A floating-point instruction is attempted and the floating-point feature is not installed.

# Present and Accept Class Interrupt

When a class interrupt occurs, it is serviced on the currently active level or on level zero (if in the wait state). Hardware processing of the interrupt causes the following:

- Register contents are saved
- Supervisor state is entered (LSR bit 8 is set to one)
- Trace is reset (LSR bit 10 is set to zero)
- Summary mask is disabled (LSR bit 11 is set to zero)
- The address key register is set to pre-determined values dependent on the type of class interrupt
- An automatic branch is taken to a service routine

Each type of class interrupt has an associated LSB pointer and SIA in the reserved area of main storage (see Figure 2.2). Beference is made to the reserved area to:

3-2). Reference is made to the reserved area to:

- 1. Store current level IAR, AKR, registers, and LSR into a level status block (LSB) in main storage.
- 2. Automatically branch to a service routine by using the start instruction address (SIA).

### Notes.

- 1. Priority level zero is forced active when a class interrupt occurs in the wait state. The level zero LSB is stored into main storage. The in-process flag (LSR bit 9) is zero in the stored LSB.
- 2. Address key values are set in anticipation of the address spaces required by the interrupt service routine. See *Address Space Management* in Chapter 5.

Contents of the level status block are as follows:

| Main s | torage |
|--------|--------|
|--------|--------|

| address (LSB) |                              |
|---------------|------------------------------|
| pointer)      | Instruction address register |
|               | Address key register         |
|               | Level status register        |
|               | Register 0                   |
|               | Register 1                   |
|               | Register 2                   |
|               | Register 3                   |
|               | Register 4                   |
|               | Register 5                   |
|               | Register 6                   |
| +14 (Hex)     | Register 7                   |
|               | 0 15                         |

The instruction address (contents of IAR) stored in the LSB depends on the type of class interrupt and is shown in the following chart.

| Type of Class<br>Interrupt                                   | Contents of IAR<br>(Stored in LSB)                                             |
|--------------------------------------------------------------|--------------------------------------------------------------------------------|
| Program check<br>Soft exception trap                         | Address of instruction that caused the interrupt.                              |
| Supervisor call<br>Trace<br>Console<br>Power/thermal warning | Address of the next instruction.                                               |
| Machine check (with<br>Sequence indicator<br>off)            | Address of instruction that caused the interrupt.                              |
| Machine check (with<br>Sequence indicator<br>on)             | Address of instruction<br>that was being executed<br>at the time of the error. |

### **Machine Check**

A machine check interrupt is caused by a hardware malfunction and is considered a system-wide incident. The three types are:

- 1. Storage parity check (PSW bit 08)
- 2. CPU control check (PSW bit 10)
- 3. I/O check (PSW bit 11)

A level status block is stored, starting at the location in main storage designated by the machine check LSB pointer (contents of storage locations hex 0008 and 0009). The contents of the storage address register (SAR) are loaded into register seven. The last active processor address key is placed into the OP1K address key of the AKR; then, OP2K, EOS bit and ISK are set to zero. The machine check SIA (contents of storage locations hex 000A and 000B) is then loaded into the IAR, becoming the address of the next instruction to be fetched. *Note.* When the error condition occurs:

- 1. The IAR contains the true address of the first word of the instruction; it is not incremented if the error occurs in the second or third word of a long instruction.
- 2. For a storage parity check, the last active processor key defines the address space corresponding to the storage address loaded into R7. For a CPU control check or an I/O check, this key and R7 provide no useful information.

### **Program Check**

A program check interrupt is caused by a programming error. The types are:

- 1. Specification check (PSW bit 00).
- 2. Invalid storage address (PSW bit 01).
- 3. Privilege violate (PSW bit 02).
- 4. Protect check (PSW bit 03).
- 5. Invalid function (PSW bit 04).

A level status block is stored, starting at the location in main storage designated by the program check LSB pointer (contents of storage locations hex 000C and 000D). The contents of the storage address register (SAR) are loaded into register seven. The last active processor address key is placed into the OP1K address key of the AKR; then, OP2K, EOS bit, and ISK are set to zero. The program check SIA (contents of storage locations hex 000E and 000F) is then loaded into the IAR, becoming the address of the next instruction to be fetched.

### Note.

- 1. A program check interrupt condition on one priority level does not affect software on other levels.
- 2. For a specification check, an invalid storage address, and a protect check, the last active processor key defines the address space corresponding to the storage address loaded into R7. For privilege violate, this key and R7 provide no useful information.

# Power/Thermal Warning (PSW Bit 15)

A power/thermal warning class interrupt is initiated by:

- 1. A power warning signal that is generated when the power line decreases to about 85% of its rated value.
- 2. A thermal warning that occurs if the temperature limits inside the closure are exceeded.

In both cases, the instruction address that is stored in the LSB points to the next instruction to be executed.

A level status block is stored, starting at the location in main storage designated by the power failure LSB pointer (contents of storage locations hex 0014 and 0015). The EOS bit and all address keys in the AKR are set to zero. The power failure SIA (contents of storage locations hex 0016 and 0017) is then loaded into the IAR, becoming the address of the next instruction to be fetched.

A power/thermal warning interrupt can occur when the system is running or in the wait state, assuming (1) the summary mask is enabled and (2) the programmer console is not set to Check Restart. These interrupts are not taken by the processor if either of the two conditions are not met.

If the optional battery backup unit is installed and a power warning occurs, PSW bit 15 remains on as long as power is supplied by the battery. If a thermal warning occurs, the processor will power down regardless of the battery backup unit. The minimum time before the processor powers down is 20 milliseconds. The IBM 4999 Battery Backup Unit is explained in a separate publication; *IBM Series/1 Battery Backup Unit Description*, GA34-0032.

Power/thermal warning interrupts are not taken by the processor until the first instruction is executed following a power-on reset, an IPL, or exit from stop state.

*Note.* If the processor is in the wait state when the power/thermal condition occurs:

- 1. The interrupt is serviced on priority level 0. The level 0 LSB is stored into main storage. Additional power/ thermal interrupts, along with priority interrupts, are disabled at this time because the summary mask is set to zero by the class interrupt.
- 2. The instruction address stored in the LSB is unpredictable.

### Supervisor Call

A supervisor call class interrupt is initiated by executing an SVC instruction. The SVC instruction is described in Chapter 8. A level status block is stored, starting at the main storage location designated by the supervisor call LSB pointer (contents of storage locations hex 0010 and 0011). The OP2K address key is placed into the OP1K address key in the AKR; then, OP2K, EOS bit, and ISK are set to zero. The supervisor call SIA (contents of storage locations 0012 and 0013) is then loaded into the IAR, becoming the address of the next instruction to be fetched.

# Soft Exception Trap

A soft exception trap interrupt is caused by software. The types are:

- 1. Invalid function (PSW bit 4)
- 2. Floating-point exception (PSW bit 5)
- 3. Stack exception (PSW bit 6)

These exception conditions may be handled by software; therefore, they do not constitute an error condition.

A level status block is stored, starting at the location in main storage designated by the soft-exception-trap LSB pointer (contents of storage locations hex 0020 and 0021). The contents of the storage address register (SAR) are loaded into register seven. The OP2K address key is placed into the OP1K address key in the AKR; then, OP2K, EOS bit, and ISK are set to zero. The soft-exception-trap SIA (contents of storage locations hex 0022 and 0023) is then loaded into the IAR, becoming the address of the next instruction to be fetched.

Note. The contents of R7 are unpredictable.

# Trace

The trace class interrupt provides an instruction trace facility for software debugging. Instruction tracing may occur on any priority level, and is enabled by the trace bit (LSR bit 10). The tracing occurs when bit 10 of the current LSR is set to one. When trace is enabled, a trace class interrupt occurs at the beginning of each instruction. A level status block is stored, starting at the location in main storage designated by the trace LSB pointer (contents of storage locations hex 0018 and 0019). The ISK address key is placed into the OP1K address key in the AKR; then, OP2K, EOS bit, and ISK are set to zero. The trace SIA (contents of storage locations hex 001A and 001B) is then loaded into the IAR, becoming the address of the next instruction to be fetched.

Note. After the LSB is stored, and before the next instruction is fetched, supervisor state is set on (LSR bit 8), trace is turned off (LSR bit 10), and the summary mask is disabled (LSR bit 11).

Programming Note. When trace is enabled, a trace class interrupt occurs prior to executing each instruction. Hardware processing of the interrupt provides an automatic branch to the programmer's trace routine. To prevent retracing the same instruction, the program should exit the trace routine by using the Set Level Block (SELB) instruction with the inhibit trace (IT) bit set to one. The inhibit trace bit prevents a trace interrupt from occurring for the duration of one instruction (see SELB instruction in Chapter 8). A double trace of an instruction can also occur when the instruction is interrupted and must be reexecuted. For example: a class interrupt occurs during execution of a variable field length instruction. Under this condition, exit from the class interrupt routine should be via a SELB instruction with the inhibit trace bit set to one. The occurrence of any class interrupt or priority interrupt causes the trace bit (LSR bit 10) to be set to zero. This action permits tracing only problem state code. If the programmer desires to trace supervisor code, he must make provisions within the service routine to enable the trace bit. The following three conditions inhibit a trace class

# interrupt:

- 1. A Set Level Block (SELB) instruction sets the trace bit on and the in-process bit on in the LSR of a selected level lower than the current level; then, when the selected level becomes active, the first instruction executed is not preceded by a trace interrupt.
- 2. The programmer console is in diagnose mode and a stop instruction is encountered while tracing; then, when the Start Key is depressed, a trace interrupt does not occur prior to executing the first instruction.
- 3. When a level is exited by either a LEX or a SELB instruction and processing is to continue on a pending level, one instruction is executed on the pending level prior to sampling for a trace interrupt.

# Console

A console interrupt function is provided when the optional programmer console is installed. To recognize the interrupt, the processor must have the summary mask enabled and be in the run state or wait state. A level status block is stored, starting at the main storage location designated by the console interrupt LSB pointer (contents of storage locations hex 001C and 001D). The EOS bit and all address keys are set to zero. The console interrupt SIA (contents of storage locations hex 001E and 001F) is then loaded into the IAR, becoming the address of the next instruction to be fetched.

# Notes.

- 1. If the processor is in the wait state when a console interrupt occurs, the interrupt is serviced on priority level 0.
- 2. If the summary mask is disabled, the console interrupt is ignored since it is not buffered.



# Summary of Class Interrupts

The following chart is a summary of class interrupt processing. Each class interrupt is fully explained in separate sections of this chapter.

| Error or<br>exception<br>condition | Store<br>LSB   | Set<br>R7 | <br> | Set<br>AK |      |     | Branch<br>to<br>service<br>routine |
|------------------------------------|----------------|-----------|------|-----------|------|-----|------------------------------------|
| Class Interrupt                    | LSB<br>Pointer | Reg<br>7  | EOS  | OP1K      | OP2K | ISK | SIA<br>Pointer                     |
| Machine check                      | 0008-0009      | SAR       | 0    | *         | 0    | 0   | 000A-000B                          |
| Program check                      | 000C-000D      | SAR       | 0    | *         | 0    | 0   | 000E-000F                          |
| Power/thermal<br>warning           | 0014-0015      |           | 0    | 0         | 0    | 0   | 0016-0017                          |
| SVC                                | 0010-0011      |           | 0    | **        | 0    | 0   | 0012-0013                          |
| Soft exception<br>trap             | 0020-0021      | SAR       | 0    | **        | 0    | 0   | 0022-0023                          |
| Ттасе                              | 0018-0019      |           | 0    | ***       | 0    | 0   | 001A-001B                          |
| Console                            | 001C-001D      |           | 0    | 0         | 0    | 0   | 001E-001F                          |

\*Last active processor address key

**\*\*OP2K** at time of interrupt

\*\*\*ISK at time of interrupt

### **Recovery from Error Conditions**

Error recovery procedures, initiated by software, depend on several factors:

- 1. Application involved.
- 2. Type of error.
- 3. Number of recommended retries.

The error class interrupt provides an automatic branch to a service routine. This routine can interrogate the PSW for specific error and status information. The routine can then initiate corrective action or retry the failing instruction(s). If an error occurs during a priority interrupt sequence, the priority level switch is completed before the error class interrupt is processed. This facilitates automatic register retention. A reset is generated by machine check class interrupts caused by an I/O check or a CPU control check. No reset is generated by program check or power/thermal warning class interrupts. Error conditions along with error recovery information are presented in the following sections.

### **Program** Check

A program check is caused by a programming error and initiates a program check class interrupt. Error retry depends on the application. All necessary parameters are made available for locating and, if required, correcting the invalid condition. There is no change to operands or priority level during a program check class interrupt. The stored LSB reflects conditions at the time the interrupt occurred and contains:

- The contents of all general registers.
- Status information (AKR and LSR contents).
- The address of the failing instruction (IAR contents).

The contents of the storage address register (SAR) are loaded into R7, but has meaning only for specification check, invalid storage address, and protect check. The programmer must reference the PSW to determine the type of program check.

# Storage Parity Check

A storage parity error initiates a machine check class interrupt. The error may occur when accessing a storage location that has not been validated since power on. Any retry procedure should include refreshing data in the failing location. Two unsuccessful retries are considered a permanent failure and the storage location should not be used.

# **CPU** Control Check

A CPU control check occurs if hardware detects a malfunction of the processor controls. It is a machine-wide error and initiates a machine check class interrupt. A reset is generated to the channel, the I/O attachment features, and all attached I/O devices. The processor, sensor-based output points, and timer values are not reset. The generated reset should clear the error condition, but validity of any previous execution is not guaranteed. No retry is recommended. An IPL should be initiated.

# I/O Check

An I/O check condition occurs if a hardware error is detected that may prevent further communication with I/O devices. A machine check class interrupt is initiated and a reset is generated to the I/O attachment features, the channel, and all I/O devices. Error recovery from an I/O check depends on the sequence indicator setting (PSW bit 12).

Sequence Indicator Set to Zero. The error occurred during an Operate I/O instruction. The address of the failing instruction (IAR contents) is available in the stored LSB. Retry should be attempted twice. After two unsuccessful retries, use of the device should be discontinued.

Sequence Indicator Set to One. The error occurred during an interrupt or cycle steal operation. The instruction address (IAR contents) stored in the LSB is not related to the error. The sequence of events leading to the I/O check is lost, along with all pending interrupt requests within the devices. Retry is not recommended.

### Soft Exception Trap

A soft exception trap interrupt is the result of an exception condition that software may choose to handle dynamically. All necessary parameters are available to locate and correct the condition. The address of the instruction (IAR contents) causing the exception is preserved in the level status block in main storage. The processor is not reset. The programmer must reference the PSW to determine the soft-exception type.

### **Processor Status Word**

The processor status word (PSW) is used to record error or exception conditions in the system that may prevent further processing. It also contains certain status flags related to error recovery. Error or exception conditions recorded in the PSW cause four of the possible seven class interrupts to occur. These are machine check, program check, soft exception trap, and power/thermal warning. See *Class Interrupts* in this chapter.

The Copy Processor Status and Reset (CPPSR) instruction can be used to examine the PSW. This instruction stores the contents of the PSW into a specified location in main storage.

The PSW is contained in a 16-bit register with the following bit representation:

|     |                          | Class               |             |
|-----|--------------------------|---------------------|-------------|
| Bit | Condition                | Interrupt           | Remarks     |
| 00  | Specification check      | Program check       |             |
| 01  | Invalid storage address  | Program check       |             |
| 02  | Privilege violate        | Program check       |             |
| 03  | Protect check            | Program check       |             |
| 04  | Invalid function         | Program check or    |             |
|     |                          | Soft exception trap |             |
| 05  | Floating-point exception | Soft exception trap |             |
| 06  | Stack exception          | Soft exception trap |             |
| 07  | Not used                 |                     | always zero |
| 08  | Storage parity check     | Machine check       |             |
| 09  | Not used                 |                     | always zero |
| 10  | CPU control check        | Machine check       |             |
| 11  | I/O check                | Machine check       |             |
| 12  | Sequence indicator       | None                | Status flag |
| 13  | Auto-IPL                 | None                | Status flag |
| 14  | Translator enabled       | None                | Status flag |
| 15  | Power/thermal warning    | Power/thermal       | Note 1      |

*Note 1.* The power/thermal warning class interrupt is controlled by the summary mask.

**Bit 00 Specification Check.** Set to one if the storage address violates the boundary requirements of the specified data type.

Bit 01 Invalid Storage Address. Set to one when an attempt is made to access a storage address outside the storage size of the system. This can occur on an instruction fetch, an operand fetch, or an operand store.

**Bit 02 Privilege Violate.** Set to one when a privileged instruction is attempted in the problem state (supervisor state bit in the level status register is not on).

Bit 03 Protect Check. In the problem state, this bit is set to one when (1) an instruction is fetched from a storage area not assigned to the current operation, (2) the instruction attempts to access a main storage operand in a storage area not assigned to the current operation, or (3) the instruction attempts to change a main storage operand in violation of the read-only control.

**Bit 04 Invalid Function.** Set to one by one of the following conditions:

1. Attempted execution of an illegal operation code or function combination. These are:

| Op code | Function                                       |
|---------|------------------------------------------------|
| 00111   | All                                            |
| 01000   | 0001, 0010, 0011, 0101, 0110, 0111             |
| 01011   | 0001, 1001 (When relocation translator feature |
|         | is not installed)                              |
| 01011   | 0101, 0111                                     |
| 01100   | 111                                            |
| 01110   | 11000, 11010, 11011, 11100, 11110, 11111       |
| 01111   | 1X1XX, 01XXX, 1X011, 10001                     |
| 11011   | All                                            |
| 10110   | All                                            |
| 11101   | 1100, 1101, 1110, 1111                         |
|         |                                                |

*Note.* The preceding illegal conditions cause a *program check* class interrupt to occur.

2. The processor attempts to execute an instruction associated with an uninstalled feature. These are:

| Op code | Function                                                                                              |
|---------|-------------------------------------------------------------------------------------------------------|
| 00100   | All (Floating-point feature not installed)                                                            |
| 01011   | 0011, 1011 (If the floating-point feature is not installed and the processor is in supervisor state). |

Note. The preceding condition causes a soft-exception-trap class interrupt to occur.

**Bit 05 Floating-Point Exception.** Set to one when an exception condition is detected by the optional floating-point processor. The arithmetic indicators (carry, even, and overflow) define the specific condition.

**Bit 06 Stack Exception.** Set to one when an attempt has been made to pop an operand from an empty main storage stack or push an operand into a full main storage stack. A stack exception also occurs when the stack cannot contain the number of words to be stored by a Store Multiple (STM) instruction.

**Bit 08 Storage Parity.** Set to one when a parity error has been detected on data being read out of storage by the processor. This error may occur when accessing a storage location that has not been validated since power on.

**Bit 10 CPU Control Check.** A control check will occur if no levels are active but execution is continuing. This is a machine-wide error. (See I/O check note.)

Bit 11 I/O Check. Set to one when a hardware error has occurred on the I/O interface that may prevent further communication with any I/O device. PSW bit 12 (sequence indicator) is a zero if the error occurred during an Operate I/O instruction and is set to one if the error occurred during a non-DPC transfer. The sequence indicator bit is not an error in itself but reflects the last interface sequence at any time. An I/O check cannot be caused by a software error. (See note.)

Note. The machine check class interrupt initiated by a CPU control check or I/O check causes a reset. The I/O channel and all devices in the system are reset as if a Halt I/O (channel directed command) had been executed. The processor, sensor-based output points, and timer values are not reset.

**Bit 12 Sequence Indicator.** This bit reflects the last I/O interface sequence to occur. See "I/O Check" described above.

Bit 13 Auto IPL. Set to one by hardware when an automatic IPL occurs.

Set to zero by:

- A power on reset when Auto IPL mode is not selected.
- Pressing the Load key.
- An IPL initiated by a host system.

Refer to Initial Program Load (IPL) in Chapter 2.

**Bit 14 Translator Enabled.** When the Storage Address Relocation Translator Feature is installed this bit is set to one or zero as follows:

- 1. Set to one (enabled)
  - An Enable (EN) instruction is executed with bit 12 of the instruction word set to zero and bit 14 set to one.
- 2. Set to zero (disabled)
  - A Disable (DIS) instruction is executed with bit 14 of the instruction word set to one.
  - An Enable (EN) instruction is executed with bit 12 of the instruction word set to one.
  - A processor reset (power-on reset, check restart, IPL, or system reset key).

**Bit 15 Power Warning and Thermal Warning.** Set to one when these conditions occur (see *Power/Thermal Warning* class interrupt in this chapter). The power/thermal class interrupt is controlled by the summary mask.

# **Program Controlled Level Switching**

Level switching under program control may be accomplished by using the Set Level Block (SELB) instruction. This instruction is covered in detail in Chapter 8, *Instructions*, and in general it will:

- Specify the location of a level status block (LSB) at an effective address in main storage.
- Specify a selected priority level associated with the main storage LSB.
- Load the main storage LSB into the hardware LSB for the selected level.

*Note.* The hardware LSB consists of the following hardware registers for the selected level:

- 1. Instruction address register
- 2. Address key register
- 3. Level status register
- 4. Eight general registers (0-7)

The system programmer should become thoroughly familiar with other effects on the processor caused by execution of the SELB instruction. These effects are determined by three factors:

- 1. The current execution level.
- 2. The selected level specified in the SELB instruction.
- 3. The state of the *in-process flag* (Bit 9 of the LSR) contained in the main storage LSB.

*Note.* Interrupt masking, provided by the summary mask and the interrupt level mask register, does not apply to program controlled level switching.

The main storage LSB and the location of the in-process flag bit are shown in the following diagram:

Main storage effective

| effective   | TAD        | <br>  |
|-------------|------------|-------|
| address     | IAR        | <br>  |
|             | AKR        | <br>  |
|             | LSR        | <br>* |
|             | Register 0 |       |
|             | Register 1 |       |
|             | Register 2 |       |
|             | Register 3 | <br>  |
|             | Register 4 | <br>  |
|             | Register 5 |       |
|             | Register 6 |       |
| EA+14 (Hex) | Register 7 |       |

\*In-process flag (bit 9) 0 = off 1 = on

Execution of the SELB instruction may result in level switching or a change in the pending status of a level as described in the following sections.

# Selected Level Lower Than Current Level and In-process Flag On

These conditions cause the selected level to be pending. The main storage LSB is loaded into the hardware LSB for the selected level. Execution of a LEX instruction on the current level causes the selected level to become active providing no higher priority interrupts are being requested.



# Selected Level Equal to Current Level and In-process Flag On

These conditions cause the selected level to become the current level. The main storage LSB is loaded into the hardware LSB for the selected level.



# Selected Level Higher Than Current Level and In-process Flag On

These conditions cause the selected level to become the current level. The main storage LSB is loaded into the hardware LSB for the selected level. This is a level switch to the higher (selected) level and causes the lower level to be pending.



# Selected Level Lower Than Current Level and In-process Flag Off

These conditions cause the selected level to be not pending. The main storage LSB is loaded into the hardware LSB for the selected level.



# Selected Level Equal to Current Level and In-process Flag Off

These conditions cause an exit from the selected (current) level. This exit is identical to executing a LEX instruction with the exception that the main storage LSB is loaded into the hardware LSB for the selected level. Refer to the *LEX Instruction* in Chapter 8.



# Selected Level Higher Than Current Level and In-process Flag Off

The main storage LSB is loaded into the hardware LSB for the higher (selected) level.



# **Interrupt Masking Facilities**

Three levels of priority interrupt masking are provided to the programmer for control of the interrupt processing. These consist of:

- 1. Summary Mask (LSR bit 11)
- 2. Interrupt Level Mask Register
- 3. Device Mask (I-bit)

Each masking facility has specific control as explained in the following sections.

# Summary Mask

The summary mask provides a masking facility for priority interrupts and certain class interrupts. The state of the summary mask (enabled or disabled) is controlled by bit 11 in the level status register (LSR) of the active priority level. When bit 11 is set to zero, the summary mask is disabled and prevents (1) all priority interrupts regardless of priority level, and (2) power/thermal and console class interrupts. All other class interrupts are not masked. When bit 11 is set to one, the mask is enabled and the interrupts are allowed.

The summary mask is disabled and enabled as follows:

- Disabled (Set to Zero)
  - 1. When a Supervisor Call (SVC) instruction is executed, the summary mask for the active level is disabled.
  - 2. Execution of a Disable (DIS) instruction, with bit 15 of the instruction equal to one, causes the summary mask for the active level to be disabled.
  - 3. All class interrupts disable the active level summary mask.
  - 4. The summary mask for a selected level is disabled by executing a Set Level Block (SELB) instruction with bit 11 of the LSR to be loaded equal to zero.
  - 5. The summary mask bits for priority levels 1-3 are set to zero by a system reset, power-on reset, or IPL.
- Enabled (Set to One)
  - 1. Execution of an Enable (EN) instruction, with bit 15 of the instruction equal to one, causes the active level summary mask to be enabled.
  - 2. The summary mask for a selected level is enabled by executing a Set Level Block (SELB) instruction with bit 11 of the LSR to be loaded equal to one.
  - 3. The level zero summary mask is enabled by a system reset, power-on reset, or IPL.
  - 4. The summary mask for the interrupted-to level is enabled by a priority interrupt.

*Note.* If the processor is in the wait state, the summary mask is enabled or disabled as defined by bit 11 in the LSR of the last active priority level.

# Interrupt Level Mask Register

The interrupt level mask register is a 4-bit register used for control of interrupts on specific priority levels. Each level is controlled by a separate bit of the mask register as shown below:

Interrupt Level Mask Register

| Bit position   | 0 | 1 | 2 | 3 |  |
|----------------|---|---|---|---|--|
|                |   |   |   |   |  |
| Priority level | 0 | 1 | 2 | 3 |  |

With a bit position set to one, the corresponding priority level is enabled and permits interrupts. With a bit position set to zero, the corresponding priority level is disabled. The Set Interrupt Mask Register (SEIMR) instruction is used to control bit settings in the interrupt level mask register. The Copy Interrupt Mask Register (CPIMR) instruction may be used to interrogate the register.

Note. All levels are enabled (Set to one) by a system reset, power-on reset, or IPL.

# Device Mask (I-bit)

Each interrupting device contains a one-bit mask called the device mask or interrupt bit (I-bit). Interrupts by the device are permitted when its device mask is enabled (set to one). With the device mask bit disabled (set to zero), that device cannot cause an interrupt. The device mask is controlled by a *Prepare* command in conjunction with an Operate I/O instruction. See Chapter 8, *Instructions*, and Chapter 4, *Input/Output Operations*.

C

•

~ \*

# Chapter 4. Input/Output Operations

Input/output (I/O) operations involve the use of input/output devices. These devices are attached to the processor and main storage via the I/O channel with the channel directing the flow of information. The I/O channel can accommodate a maximum of 256 addressable devices. The general data flow is shown in Figure 4-1.



Figure 4-1. Block diagram of Series/1 Model 5 system

The channel supports three basic types of operations:

- Direct Program Control (DPC) Operations An immediate data transfer is made between main storage and the device for each Operate I/O instruction. The data may consist of one byte or one word. The operation may or may not terminate with an interrupt.
- Cycle Steal Operations An Operate I/O instruction can initiate cycle-stealing data transfers of up to 65,535 bytes between main storage and the device. Cycle steal operations are overlapped with processing operations. Word or byte transfers, DCB chaining, burst mode, and program controlled interrupt can be supported. All cycle stealing operations terminate with an interrupt.
- Interrupt Servicing Four preemptive priority interrupt levels are available to facilitate device service. The device interrupt level is assignable by the program. In addition, the device interrupt capability may be masked under program control. Interrupt requests, along with cycle steal requests, are presented and polled concurrently with DPC and cycle-steal data transfers.

The cliannel provides comprehensive error checking including time-outs, sequence checking, and parity checking. Error, exception, and status reporting are facilitated by (1) recording condition codes in the processor during execution of Operate I/O instructions, and (2) recording condition codes and an Interrupt Information Byte (IIB) in the processor during interrupt acceptance. Additional status words may be used by the device as necessary to describe its status (see I/O Condition Codes and Status Information in this chapter).

# **Operate I/O Instruction**

The Operate I/O instruction initiates all I/O operations from the processor. It is a privileged instruction and is independent of specific I/O parameters. The generated effective address points to an immediate device control block (IDCB) in main storage. The IDCB consists of two words that contain an I/O command, a device address, and an immediate data field. For DPC operations, the immediate data field is used as a device data word. For cycle steal operations, the immediate data field points to a device control block (DCB) that provides additional information needed for the operation. For more details of the *Operate* I/O Instruction refer to Chapter 8.

Operate I/O Instruction Address R21 0 0  $0 \ 1 \ 1 \ 0 \ 1$ 0 0 0 \* 1 Effective address **IDCB** Command Device address Immediate data field 0 7 8 15 16 31 Cycle steal operations DĊB

\*Indirect addressing bit

# Immediate Device Control Block (IDCB)

The location in storage specified by the Operate I/O instruction contains the first word of the IDCB. The IDCB contains an I/O command that describes the specific nature of the I/O operation. This command is used by the channel for execution of the operation. The IDCB must always be on a word address boundary and has the following format:



### Command field (bits 0-7)

- Bit 0 Channel directed. If this bit is equal to one, the I/O command is directed to the channel rather than to a specific device. The Halt I/O command is the only valid channel directed command. Any other command with bit 0 set to one causes a command reject exception condition.
- Bit 1Read/Write. If this bit is equal to one, the data<br/>contained in the immediate field is transferred to the<br/>addressed I/O device. If this bit is equal to zero, the<br/>immediate field contains the data received from the<br/>I/O device at the conclusion of the IO instruction.Bits 2-3Function. This field specifies the general type of
- Bits 2-3 Function. This field specifies the general type of I/O operation to be performed (see Figure 4-2).
  Bits 4-7 Modifier. This field contains four bits for further
- specification of a function, if required (see Figure 4-2).

### Device address field (bits 8–15)

This byte contains the I/O device address. The address range is 00 through FF (hex).

### Immediate data field (bits 16-31)

This field contains a device data word for DPC operations. It contains the address of a device control block for cycle steal operations.

Figure 4-2 shows the relationship of the IDCB and the Operate I/O instruction. It also contains a chart of the various I/O commands. The Start command and the Start Cycle Steal Status command are used to initiate cycle steal operations. The remaining commands are used for DPC operations only.



\*Indirect addressing bit.

\*\*Modifier XXXX is device dependent. Other modifiers are system defined.

\*\*\*To avoid future code obsolescence, this command format must not be used.

Figure 4-2. IDCB and I/O commands

# Device Control Block (DCB)

This section describes the device control block that is used for a cycle steal operation. The actual cycle steal operation is explained in a later section of this chapter. The DCB is an eight-word control block residing in the supervisor area of main storage. It contains the specific parameters of a cycle steal operation. The device fetches the DCB using the cycle steal mechanism. The format of the DCB is shown in Figure 4-3.



\*Device option bits

Figure 4-3. Device control block

### The DCB words have the following meanings:

Control word

- Bit 0\* Chaining flag. If this bit is equal to one, a DCB chaining operation is indicated.
- Bit 1\* Programmed controlled interrupt (PCI). If this bit is equal to one, the device presents a programmed controlled interrupt (PCI) at the completion of the DCB fetch.
- Bit 2 Input flag. The setting of this bit tells the device the direction of data transfer.
  0 = Output (main storage to device)
  1 = Input (device to main storage)
  For bidirectional data transfers under one DCB operation, this bit must be set to one. For control operations involving no data transfer, this bit must be set to zero.
- Bit 3 *Reserved.* This bit must be set to zero to avoid future code obsolescence.
- Bit 4\* Suppress exception (SE). If this bit is equal to one, the device is allowed to suppress the reporting of certain exception conditions. The device can then take alternative action depending on the condition.
- Bits 5-7 Cycle steal address key. This key is presented by the device during data transfers. It is used to ascertain storage access authorization (see Chapter 5, Storage Protection).
- Bits 8-15 *Modifier.* These are device dependent bits with one exception. When a device uses burst mode, it is specified in bit 15. These bits may be used for functions that are unique to a particular device.

\*Chaining, PCI, and SE are device options that are available on a device feature basis. Any bit not used by the device should be set to zero although it is not checked by the device.

Refer to the Cycle-Steal Device Options section of this chapter.

### **Device Parameter Words 1–2**

These parameter words are device-dependent control words and are implemented as required. Refer to the individual device publications for definition.

### **Device Parameter Word 3**

When PCI is specified, the high-order byte (bits 0-7) of this word is used for a DCB identifier. The device places the identifier in the interrupt information byte when the PCI is processed. The low-order byte (bits 8-15) is always device dependent. The high-order byte is device dependent when PCI is not specified.

### **Device Parameter Word 4**

If suppress exception (SE) is used by a device, this word specifies a 16-bit main storage address called the *status address*. This address points to a *residual status block* that is stored by the device following completion of the DCB operation.

If suppress exception is not used by a device, a residual status block is not stored. In this case, parameter word 4 is device dependent. Refer to *Cycle-Steal Device Options* in this chapter.

### **Device Parameter Word 5**

If the DCB chaining bit (bit 0 of the control word) is equal to one, this word specifies a 16-bit main storage address of the next DCB in the chain. If chaining is not indicated, this parameter word is device dependent.

### Count

The count word contains a 16-bit unsigned integer representing the number of data bytes to be transferred for the current DCB. Count is specified in bytes with a range of 0 through 65,535. The count specification must be even for word-only devices.

### **Data Address**

This word contains the starting main storage address for the data transfer.

# Programming Considerations When Using the DCB

- 1. Only those words required for the cycle stealing operation are fetched by the device and they may be fetched in any order. Contents of the words must be specified correctly; if not, the device records a *DCB specification check* in the interrupt status byte and terminates the cycle steal operation with an exception interrupt.
- 2. The DCB address (in the IDCB), the chain address, and the status address must be even (word boundary). If the DCB address is odd, the device records a *command reject* condition code and terminates the cycle steal operation. An odd chain address or status address results in a *DCB specification* check.

*Note.* Condition code and status recording are explained in detail in a separate section of this chapter.

# **I/O** Commands

This section describes each I/O command and shows the related IDCB. The command field (bits 0-7) of the IDCB contains the binary value of the command. An <u>X</u> in this field means the value is device dependent.

# Read



| Immediate data field |          |
|----------------------|----------|
| E                    | ata word |
| 16                   | 31       |

This command transfers a word or byte from the addressed device to the data word of the IDCB. If a single byte is transferred, it is placed in bits 24-31 of the data word with bits 16-23 set to zeros. Correct parity is always maintained and checked for both bytes on the I/O channel. The individual devices may use either the 0X or 1X type of read command. The two commands operate the same in the channel.

# Read ID

| ID | СВ | (im | me    | diat | e de  | evic | e co | onti                 | olt | oloc | k)  |     |   |   |    |
|----|----|-----|-------|------|-------|------|------|----------------------|-----|------|-----|-----|---|---|----|
| Co | mm | ian | d fie | ld   |       |      |      | Device address field |     |      |     |     |   |   |    |
| 0  | 0  | 1   | 0     | 0    | 0     | 0    | 0    | X                    | х   | Х    | Х   | Х   | Х | Х | Х  |
| Q  |    |     |       |      |       |      | 7    | 8                    |     |      |     |     |   |   | 15 |
|    |    |     | 20    | 5    |       |      |      | -                    |     |      | 00- | -FF | , |   |    |
| Im | me | dia | te di | ata. | field | d    |      |                      |     | •    |     |     |   |   |    |
|    |    |     |       |      |       | D    | ata  | wo                   | rđ  |      |     |     |   |   |    |
| 16 |    |     |       |      |       |      |      |                      |     |      |     |     |   |   | 31 |

This command transfers an identification (ID) word from the device to the data word of the IDCB. The device identification word contains physical information about the device and may be used to determine the devices that are attached to the system. This word is not related to the interrupt ID word associated with interrupt processing. The device ID word format is:

|   |               |      | 1  |    |     |
|---|---------------|------|----|----|-----|
|   | Assigned code |      | c  | CS | D   |
| 0 |               | 12 1 | 13 | 14 | 1.5 |

| One                | que identification code for the device<br>o – not a controller device or the device does not<br>ort delayed command reject<br>e – controller device or any device that reports<br>ayed command reject |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| One<br>Bit 15 Zere | o – not a cycle steal device<br>e – cycle steal device<br>o – IBM device<br>e – OEM device                                                                                                            |

Note. A controller may control more than one I/O device and is not directly addressable, but is not transparent to software. That is, the controller may cause busy or exception conditions as opposed to those caused by an attached I/O device.



### **Read Status**



This command transfers a device status word from the device to the data word of the IDCB. Contents of the status word are device dependent.

### Write



This command transfers a word or byte to the addressed device from the data word of the IDCB. The individual device may use either format of the command. If a single byte is to be transferred, it must be placed in bits 24-31 of the data word and bits 16-23 must be set to zero. A byte oriented device may ignore bits 16-23 (including the parity bit) on the I/O channel but these bits should be zeros to avoid future code obsolescence.

*Note.* Both bytes of the IDCB data word are fetched by the channel and placed on the I/O data bus (in good parity) even if not required by the device.

### Prepare

|    |       |      |     |       |       |   |   | Device address field<br>XXXXXXXXXX |   |   |     |     |   |   |            |
|----|-------|------|-----|-------|-------|---|---|------------------------------------|---|---|-----|-----|---|---|------------|
| 0  | 1     | 1    | 0   | 0     | 0     | 0 | 0 | Х                                  | Х | х | Х   | х   | Х | Х | Х          |
| o_ |       |      |     |       |       |   | ] | 8                                  |   |   |     |     |   |   | <i>1</i> . |
|    |       |      | 6   | 0     |       |   |   |                                    |   |   | 00- | -FF | , |   |            |
|    | med   | liat | e d | ata . | field | d |   |                                    |   |   |     |     |   |   |            |
| Im | Zeros |      |     |       |       |   |   |                                    |   |   | Le  |     |   |   |            |

This command transfers a word (to the addressed device) that controls the device interrupt parameters. The word is transferred from the immediate data field of the IDCB in the format shown. A priority interrupt level is assigned to the device by the *level* field. The I-bit (device mask) controls the device interrupt capability. If the I-bit equals 1, the device is allowed to interrupt. If the I-bit equals 0, the device cannot interrupt. See *Prepare I/O Device for Interrupt* in Chapter 3.

Note. The IBM 4955 Processor does not recognize a priority level other than 0-3. Lost interrupts result if a device is prepared for a level other than 0-3.

### Control



This command initiates a control action in the addressed device. A word, or byte, transfer from the data word of the IDCB to the addressed device may or may not occur, depending on device requirements. If a single byte is to be transferred it must be placed in bits 24-31 of the data word and bits 16-23 must be set to zero.

*Note.* Both bytes of the IDCB data word are fetched by the channel and placed on the I/O data bus (in good parity) even if not required by the device.

# **Device Reset**

| IDCB (in | ımedia  | te d | evic | e c | onti                 | oll | oloc | k)  |     |   |   |    |
|----------|---------|------|------|-----|----------------------|-----|------|-----|-----|---|---|----|
| Comman   | d field |      |      |     | Device address field |     |      |     |     |   |   |    |
| 0 1 1    | 0 1     | 1    | 1    | 1   | x                    | Х   | Х    | х   | х   | х | х | X  |
| 0        |         |      |      | 7   | 8                    |     |      |     |     |   |   | 15 |
|          | 6F      |      |      |     |                      |     |      | 00- | -FF |   |   |    |
| Immedia  | te data | fiel | d    |     |                      |     |      |     |     |   |   |    |
|          |         |      | Z    | ero | s                    |     |      |     |     |   |   |    |
| 16       |         |      |      |     |                      |     | _    |     |     |   |   | 31 |

This command resets the addressed device. A pending interrupt from this device (or a busy condition) is cleared. The device mask (I-bit) is not changed. There is no change to the assigned priority level for the device. The residual address (device status) and output sensor points are not affected. Parity checking of the IDCB data word is not performed.

### Start



This command initiates a cycle steal operation for the addressed device. The second word of the IDCB is transferred to the device. It contains a 16-bit logical storage address of a device control block (DCB) to be used by the device. See *Cycle Steal* in this chapter.

# Start Cycle Steal Status



This command initiates a cycle steal operation for the addressed device. Its purpose is to collect status information from the addressed device. The second word of the IDCB is transferred to the device and contains a 16-bit logical address of a device control block (DCB). See *Start Cycle Steal Status Operation* in this chapter.

# Halt I/O



This is a *channel* directed command that causes a halt of all I/O activity on the I/O channel and resets all devices. No data is associated with this command. All pending device interrupts are cleared. Device priority-interruptlevel assignments and device masks (I-bits) are unchanged. The residual address (device status) and output sensor points are not affected.

### Notes.

- 1. The channel is always able to accept and execute this command.
- 2. Halt I/O is the only valid channel directed command.

# **DPC Operation**

A DPC operation causes an immediate transfer of data or control information to or from an I/O device. An Operate I/O instruction must be executed for each data transfer and causes the following events to occur (refer to Figure 4-4).

- 1. The Operate I/O instruction points to an IDCB in main storage.
- 2. The I/O channel uses the IDCB to select the addressed device and to determine the operation to perform.
- 3. The I/O channel sends data to the device from main storage, or from the device to main storage.
- 4. The device sends an IO instruction condition code to the level status register (LSR) in the processor. D

### Notes.

- 1. The DPC operation may end with a priority interrupt if the device has this capability. Refer to *I/O Inter-rupts* in Chapter 3.
- 2. There are two types of condition codes: the first is an I/O instruction condition code and is available immediately after completion of an Operate I/O instruction; the second is an interrupt condition code and is presented upon acceptance of a priority interrupt. The code significance is different for the two cases. Refer to I/O Condition Codes and Status Information in this chapter.



Bit 2 overflow indicator

Figure 4-4. Direct program control I/O operation

# **Cycle Steal**

The cycle steal mechanism allows data service to or from an I/O device while the processor is processing instructions. This overlapped operation allows multiple data transfers to be started by one Operate I/O instruction. The processor executes the Operate I/O instruction, then continues processing instructions while the I/O device steals main storage data cycles when needed. The channel resolves contention among multiple devices requesting cycle steal transfers. The operation always ends with a priority interrupt from the device.

The cycle steal operation includes certain capabilities that are provided on a device feature basis:

- 1. Burst mode
- 2. DCB chaining
- 3. Programmed controlled interrupt (PCI)
- 4. Suppress exception (SE)
- 5. Storage addresses and data transfers by byte or word

See the *Cycle-Steal Device Options* section of this chapter for details of these facilities.

All cycle steal operations terminate with a priority interrupt, providing, the device has executed a successful *Prepare* command, with the device mask (I-bit) enabled. If the device mask is disabled, the interrupt presentation is blocked and the device remains busy until (1) the condition is cleared by a reset, or (2) the proper Prepare command is executed.

All cycle steal operations are started by an Operate I/O instruction that points to an IDCB. The immediate data field of the IDCB contains the address of a device control block (DCB). The DCB is fetched by the device using a cycle-steal address key of zero. Within the DCB are specific parameters of the cycle steal operation. See *Device Control Block* in this chapter.

There are two types of cycle steal commands:

- Start
- Start Cycle Steal Status

# Start Operation

A cycle steal operation begins after successful execution of the *Start* command. The IDCB, pointed to by an Operate I/O instruction, has the format:

| Co | mn | nan | d fi | eld |   |   |   | Device address field |   |   |   |   |   |   |    |
|----|----|-----|------|-----|---|---|---|----------------------|---|---|---|---|---|---|----|
| 0  | 1  | 1   | 1    | Х   | х | х | х | x                    | х | х | х | х | х | х | Х  |
| ō  |    |     |      |     |   |   | 7 | 8                    |   |   |   |   |   |   | 15 |



The command modifier (X) is device dependent. The DCB address always specifies a word boundary and is the starting storage address of the DCB. This address is used by the device to fetch the DCB, using the cycle steal mechanism.

A cycle steal operation is presented in the following chart. Use Figure 4-5 in conjunction with this chart. Condition codes used in the chart are fully explained in the section I/O Condition Codes and Status Information in this chapter.

*Note.* An I/O device must be properly prepared (using a *Prepare* command), before it is allowed to interrupt.

Cycle steal major steps Remarks

| eyere srear major sreps              |                                                                                                                                                                                                                                |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Start cycle steal                    | <ol> <li>Execute IO instruction.</li> <li>IDCB contains <i>Start</i> command and points to a DCB. The DCB address is sent to the device.</li> <li>Device presents condition code 7 (bits 0-2 in the LSR).</li> </ol>           |
| Device fetches DCB                   | <ol> <li>Device uses cycle steal mechanism to<br/>fetch DCB.</li> <li>Cycle steal address key of zero is used.</li> </ol>                                                                                                      |
| Data transfer                        | <ol> <li>Data is transferred to or from the device<br/>in word or byte format. D</li> <li>Transfer continues until count in DCB<br/>is exhausted.</li> <li>DCB specifies cycle steal address key for<br/>data area.</li> </ol> |
| Termination (no<br>error condition)  | <ol> <li>Device presents interrupt request.</li> <li>Channel polls I/O attachment feature<br/>and accepts request.</li> <li>Device sends interrupt ID word and<br/>interrupt condition code 3 (device end).</li> </ol>         |
| Termination<br>(Exception condition) | <ol> <li>Device presents interrupt request.</li> <li>Channel polls I/O attachment feature<br/>and accepts request.</li> <li>Device sends interrupt ID word and<br/>interrupt condition code 2 (exception).</li> </ol>          |

*Note.* Other events that might occur during the cycle steal operation are:

| Chaining                     | <ol> <li>Device completes the current DCB opera-<br/>tion but does not present an interrupt<br/>request.</li> <li>Device fetches next DCB in the chain.</li> </ol>        |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Program controlled interrupt | <ol> <li>Device fetches DCB (PCI bit = 1).</li> <li>Device initiates an interrupt and sends<br/>an interrupt ID word and interrupt<br/>condition code 1 (PCI).</li> </ol> |
| Suppress Exception           | <ol> <li>Device completes current operation.</li> <li>Device stores status at the main storage<br/>location defined by DCB parameter</li> </ol>                           |

word 4.





# Start Cycle Steal Status Operation

The purpose of this operation is to obtain data from the device if the previous cycle steal operation terminates due to an error or exception condition. The operation is initiated by a *Start Cycle Steal Status* command. The IDCB format is:



This command uses a special DCB format with some words and fields set to zeros (see Figure 4-6).

| Word | DCB (device control block)         |  |  |  |  |  |  |  |  |  |  |
|------|------------------------------------|--|--|--|--|--|--|--|--|--|--|
| 0    | Control word                       |  |  |  |  |  |  |  |  |  |  |
| 0    | 0 0 1 0 0 Addr key 0 0 0 0 0 0 0 0 |  |  |  |  |  |  |  |  |  |  |
| 1    | Not used (zeros)                   |  |  |  |  |  |  |  |  |  |  |
| 2    | Not used (zeros)                   |  |  |  |  |  |  |  |  |  |  |
| 3    | Not used (zeros)                   |  |  |  |  |  |  |  |  |  |  |
| 4    | Not used (zeros)                   |  |  |  |  |  |  |  |  |  |  |
| 5    | Not used (zeros)                   |  |  |  |  |  |  |  |  |  |  |
| 6    | Byte count                         |  |  |  |  |  |  |  |  |  |  |
| 7    | Data address                       |  |  |  |  |  |  |  |  |  |  |
|      | 0 15                               |  |  |  |  |  |  |  |  |  |  |
|      |                                    |  |  |  |  |  |  |  |  |  |  |

Figure 4-6. DCB for start cycle steal status operation

#### Programming Note.

Concerning the DCB for the start cycle steal status operation:

- 1. Bits designated as zero are not checked by hardware (see Figure 4-6).
- 2. The count is specified in bytes.
- 3. The maximum count is device dependent.
- 4. The validity of a count value less than the maximum value is device dependent.
- 5. If the maximum count is exceeded, or a count value is specified that indicates the partial storing of a word length parameter, the device records a *DCB specifica-tion check* in the ISB and terminates the operation.
- 6. An odd data address also results in a *DCB specification check*.

Data is transferred to main storage starting at the data address specified in the DCB. This data consists of residual parameters and device dependent status information and has the following formats:



**Residual Address.** This word contains the main storage address of the last attempted cycle steal transfer associated with a *Start* command. It may be a data address, a DCB address, or a residual-status-block address. It is updated to the current cycle-steal storage address upon execution of cycle steal transfers. For word transfers, the residual address points to the high-order byte of the word. If an error occurs during a start cycle steal status operation, this address (as contained within the device) is not altered. Device reset, Halt I/O, machine check, and system reset have no effect on the residual address in the device. It is cleared by a power-on reset. Following a power-on reset the residual address is:

- 0000 (Hex) for a byte-oriented device.
- 0001 (Hex) for a word-oriented device.

**Device Cycle-Steal-Status Word 1.** This word contains the residual byte count of the previous cycle steal operation associated with a start command. The byte count is initialized by the count field of a DCB associated with a *Start* command, and is updated as each byte of data is successfully transferred via a cycle steal operation. It is not updated by cycle-steal transfers into the residual status block. The residual byte count is not altered if an error occurs during a start cycle steal status operation. It is reset by (1) power-on reset, (2) system reset, (3) device reset, (4) Halt I/O, and (5) machine check condition.

Note. The contents of the device cycle-steal-status word 1 are device dependent if the device does not: (1) implement suppress exception (SE), or (2) store a residual byte count as part of its cycle-steal status.

**Device Dependent Status Words.** The number and contents of these words are specified by the individual device. Three conditions can cause bits to be set in the device dependent status words (refer to individual device publications).

- 1. Execution of an I/O command that causes an exception interrupt.
- 2. Asynchronous conditions in the device that indicate an error, exception, or a state condition.
- 3. As defined by the individual device.

The bits are reset as follows:

- 1. For the first condition listed above, the bits are reset by the acceptance of the next I/O command (except Start Cycle Steal Status) following the exception interrupt. These bits are also reset by a power-on reset, system reset, or execution of a Halt I/O command.
- 2. For the second condition, the bits are reset on a device dependent basis.
- 3. For the third condition, the bits are reset as defined by the individual device.

# **Cycle-Steal Device Options**

The I/O channel supports operations such as burst mode and chaining when required by individual devices. Bits in the DCB control word are used to activate these operations. Refer to the individual device publications for the device options used. The following sections explain the operations.

# **Burst** Mode

Burst mode, when used by a device, is specified in bit 15 of the DCB control word. If bit 15 is equal to one, the transfer of data takes place in burst mode. This mode dedicates the I/O channel to the device until the last data transfer for the DCB is completed. Cycle steal interleave, by other devices, is prevented. Burst mode also prevents any priority interrupt request from being accepted by the processor.

The maximum burst rate for the 4955 channel is:

- 1.8 megabytes per second for storage input cycles.
- 1.5 megabytes per second for storage output cycles.

# Chaining

The purpose of chaining is to allow the programmer to sequence an I/O device through a set of operations by using a chain of DCBs. Bit 0 of the DCB control word (when set to one) indicates a chaining operation. This means that the chained DCB, fetched by the device, is interpreted as a new operation (or function) to be performed. The DCB may be equal to, but not a continuation of, the operation specified by the previous DCB.

When the current DCB indicates a chaining operation, device parameter word 5 of the DCB must contain a main storage address that points to the next DCB in the chain. The device completes the current operation but does not present an interrupt request (excluding PCI) to the processor. Instead, the device fetches the next DCB in the chain and continues operation.

*Note.* The chaining operation has no effect on programmed controlled interrupt (PCI). These interrupts, when specified in the DCB, still occur at the completion of the DCB fetch operation.

# **Programmed Controlled Interrupt (PCI)**

Bit 1 of the DCB control word (when set to one) tells the device to present a PCI to the processor at the completion of the DCB fetch prior to data transfer.

When the PCI is serviced, a DCB identifier byte is returned to the processor in the interrupt information byte (IIB). Refer to DCB device parameter word 3 in this chapter. Two conditions should be noted by the programmer:

- 1. Chaining and data transfers associated with the DCB may commence even if the PCI is pending.
- 2. If the PCI is pending when the device encounters the next interrupt causing condition, the PCI condition is discarded by the device and replaced with the new interrupt condition.

# Suppress Exception (SE)

When a device uses this option it is allowed to suppress the reporting of certain exception conditions that would normally cause an exception interrupt. The device is then allowed to take alternative action depending on the condition. The suppressed exception conditions are reported to the programmer as status information upon completion of the operation. Refer to a subsequent section, *Suppression of Exceptions*, for details of the various actions a device might take.

The suppress exception option also provides for automatic logging of status information (including suppressed exceptions) into main storage. When the SE bit for a DCB is set to one, the device always stores a residual status block into main storage after successful completion of the data transfer for the DCB. Device parameter word 4 of the DCB must be used to specify the starting main storage address for the residual status block. Note that a residual status block is stored even if there are no exception conditions to be suppressed.

The following section shows the residual status block that is stored.

#### **Residual Status Block**

The residual status block is stored into main storage at the location pointed to by the status address (DCB word 4). The device uses an address key for this operation that corresponds to the DCB address space. The size of a residual status block is fixed for each device with a limit of 8 words total. The format is:





- Word  $\theta$  Contains the residual byte count associated with the DCB.
- Word 1 EOC is the End of Chain bit and is set to one for all conditions that would terminate a chaining operation. NE is the No Exception bit and is set to one when the operation is completed and no exceptions are reported. The Status Flags are device dependent flags that indicate suppressed exception conditions.

Any additional words are device dependent as to number and content. Refer to the individual device publications for the additional status information and, also, the bit significance of the status flags.

#### Suppression of Exceptions

An exception condition can be suppressed by a device only when it occurs during a data transfer operation. It cannot be suppressed if it occurs during (1) a DCB fetch, (2) storing of a residual status block, or (3) a cycle steal status operation. A second requirement of a suppressible exception is that the device be capable of continuing operation in a normal and predictable manner after occurrence of the exception. If these conditions are not met, the exception condition causes an exception interrupt. When a suppressible exception is encountered, the device initiates one of a possible three types of action depending on the device and the exception condition. Note that the number of action types used by a device and the suppressible exceptions for each type are a device specification. Refer to the individual device publication. The three action types are:

- 1. Suppress Exception and Continue. The exception condition occurs but data transfer is allowed to proceed. At the completion of the data transfer (defined by the DCB) a residual status block is stored with word one set as follows:
  - A status flag for this exception is set to one.
  - If the DCB specifies chaining, then the EOC bit is set to zero. Otherwise, it is set to one.
  - The NE bit is set to zero.

The device may then continue with the next DCB if chaining is specified.

- 2. Suppress Exception and Terminate Data Transfer. Upon detecting the exception condition, the device terminates the data transfer for this DCB. It then stores a residual status block containing:
  - A status flag for the exception condition.
  - EOC bit set to zero, if chaining. Otherwise, set to one.
  - NE bit set to zero.

The device may then continue with the next DCB if chaining is specified.

**Programming** Note. For some devices, the most common exception condition of this type is incorrect length record (ILR). For example, the data transfer is completed prior to the count reaching zero.

In certain communications devices a short ILR is considered normal operation. When a short ILR occurs in this type device, the residual byte count is sufficient to indicate the condition; therefore, the NE bit may be set to indicate no exception. 3. Suppress Exception and Terminate Chain. Upon detecting this exception condition, the device terminates the data transfer for this DCB. It ignores any commands specifying further chaining.

The device stores a residual status block containing:

- A status flag for the exception condition
- EOC bit set to one
- NE bit set to zero.

The device then presents a device end interrupt. Refer to *Interrupt Condition Codes* in a subsequent section of this chapter.

**Programming Note.** In certain communication devices a change-of-direction character is considered normal operation. When a change-of-direction character occurs in this type device, the EOC bit is sufficient to indicate the condition; therefore, the NE bit may be set to indicate no exception.

**Priority of Suppress Exception Actions.** Multiple exceptions that are suppressible can occur during an operation. They are noted in the residual status block by setting multiple status flags. The type of action taken by a device depends on the exception/action combination with highest priority. The priority sequence is type 3, type 2, and type 1 with type 3 having the highest priority.

# **Cycle-Steal Termination Conditions**

The following chart shows the action that occurs at the end of a DCB operation depending on the function specified and the exception conditions encountered:

| CHN | SE | Suppressible<br>exception | Non-Suppressible<br>exception | No<br>exception |
|-----|----|---------------------------|-------------------------------|-----------------|
| 0   | 0  | I(XCT)                    | I(XCT)                        | I(DE)           |
| 0   | 1  | I(PDE)                    | I(XCT)                        | I(DE)           |
| 1   | 0  | I(XCT)                    | I(XCT)                        | CC              |
| 1   | 1  | *I(PDE)/CC                | I(XCT)                        | I(DE)           |

CC - DCB chaining

CHN - Chaining flag (bit 0 of the DCB control word)

I(DE) – Device end interrupt

I(PDE) – Permissive device end interrupt (see device end interrupt) I(XCT) – Exception interrupt

SE – Suppress exception (bit 4 of the DCB control word)

\*Dependent on the specific exception condition in the individual device.

#### I/O Condition Codes and Status Information

Each time an Operate I/O instruction is issued, the device, controller, or channel immediately reports to the processor one of seven condition codes pertaining to execution of the I/O command. These codes are called *IO instruction* condition codes. Three bits are used to encode a condition code value (range 0 through 7). The bits are recorded in the even, carry, and overflow positions of the LSR and may be interrogated by specific instructions such as *Branch on Condition Code* and *Branch on Not Condition Code*. (See BCC and BNCC in Chapter 8.)

For interrupting devices, condition codes are also reported during a priority interrupt. These codes are called *Interrupt* condition codes and pertain to operations that continue beyond execution of the Operate I/O instruction (such as cycle stealing of data). The interrupt condition codes are recorded in the LSR and interrogated in the same manner as the I/O instruction codes. Along with the interrupt condition code, the device also transfers an interrupt ID word to the processor. Bits 0 through 7 of the interrupt ID word contain status information related to the interrupt processing and are called the interrupt information byte (see *Interrupt ID Word* in this chapter).

Figure 4-7 presents an overall view of condition code reporting along with status information. Details of the condition codes and status information are discussed in the following sections. Note that there are two unique sets of condition codes (IO instruction and interrupt) and that most status information is device dependent.



Figure 4-7. Condition codes, status words, and status bytes received from a device (Part 1)



Figure 4-7. Condition codes, status words, and status bytes received from a device (Part 2)



Figure 4-7. Condition codes, status words, and status bytes received from a device (Part 3)

# **IO Instruction Condition Codes**

These codes are reported during execution of an Operate I/O instruction.

| Condition | LSR p | osition | 1     |            |                       |
|-----------|-------|---------|-------|------------|-----------------------|
| code (CC) |       |         | Over- | Reported   |                       |
| value     | Even  | Carry   | flow  | by         | Meaning               |
| 0         | 0     | 0       | 0     | channel    | Device not attached   |
| 1         | 0     | 0       | 1     | device     | Busy                  |
| 2         | 0     | 1       | 0     | device     | Busy after reset      |
| 3         | 0     | 1       | 1     | chan/dev   | Command reject        |
| 4         | 1     | 0       | 0     | device     | Intervention required |
| 5         | 1     | 0       | 1     | chan/dev   | Interface data check  |
| 6         | 1     | 1       | 0     | controller | Controller busy       |
| 7         | 1     | 1       | 1     | chan/dev   | Satisfactory          |

- CC=0 Device not attached. Reported by the channel when the addressed device is not attached to the system.
- CC=1 Busy. Reported by the device when it is unable to execute a command because it is in the busy state. The device enters the busy state upon acceptance of a command that requires an interrupt for termination. It exits the busy state when the processor accepts the interrupt. Certain devices also enter the busy state when an external event occurs that results in an interrupt. When this condition code is reported, a subsequent priority interrupt from the addressed device always occurs.
- CC=2 Busy after reset. Reported by the device when it is unable to execute a command because of a reset and the device has not had sufficient time to return to the quiescent state. No interrupt occurs to indicate termination of this condition.
- CC=3 Command reject. Reported by the device or the channel when:
  - 1. A command is issued (in the IDCB) that is outside the device command set.
  - 2. The device is in an improper state to execute the command.
  - 3. The IDCB contains an incorrect parameter. For example: an odd byte DCB address, or an incorrect function/modifier combination.

When a cycle-steal device reports command reject, it does not fetch the DCB.

- CC=4 Intervention required. Reported by the device when it is unable to execute a command due to a condition requiring manual intervention to correct.
- CC=5 Interface data check. Reported by the device or the channel when a parity error is detected on the I/O data bus during a data transfer.
- CC=6 Controller busy. This condition is reported by a device controller, not the addressed device, when the controller is busy. It is reported only by controllers that have two or more devices attached (each device having a unique address). When this condition code is reported, a subsequent controller-end interrupt always occurs.
- CC=7 Satisfactory. Reported by the device or the channel when it accepts the command.

These condition codes are mutually exclusive and have a priority sequence. That is; beginning with CC=7, each successive condition code through CC=0 takes precedence over the previous code. For example, if a device cannot accept a command because it is busy, it reports CC=1, irrespective of error conditions encountered.

*Note.* The only exception is CC=6 (controller busy). This condition code may have a variable priority depending on the particular controller.

#### Interrupt Condition Codes

These condition codes are reported by the device or controller during priority interrupt acceptance.

| Condition | LSR p | position | !     |            |                    |
|-----------|-------|----------|-------|------------|--------------------|
| code (CC) |       |          | Over- | Reported   |                    |
| value     | Even  | Carry    | flow  | by         | Meaning            |
| 0         | 0     | 0        | 0     | controller | Controller end     |
| 1         | 0     | 0        | 1     | device     | Program controlled |
|           |       |          |       |            | interrupt (PCI)    |
| 2         | 0     | 1        | 0     | device     | Exception          |
| 3         | 0     | 1        | 1     | device     | Device end         |
| 4         | 1     | 0        | 0     | device     | Attention          |
| 5         | 1     | 0        | 1     | device     | Attention and PCI  |
| 6         | 1     | 1        | 0     | device     | Attention and      |
|           |       |          |       |            | exception          |
| 7         | 1     | 1        | 1     | device     | Attention and      |
|           |       |          |       |            | device end         |

- CC=0 Controller end. Reported by a controller when controller busy (IO instruction condition code) has been previously reported one or more times. It signifies that the controller is now free to accept I/O commands for devices under its control. The device address reported with controller end is always the lowest address (numerical value) of the group of devices serviced by the controller. The interrupt information byte, in the interrupt ID word, is set to zero.
- CC=1 Program controlled interrupt. Reported when the interrupt indicates that a DCB with the PCI bit set to one has been transferred by cycle steal to the device and no error or exception condition has occurred. The device places a DCB identifier into the interrupt information byte.
- CC=2 Exception. Reported when an error or exception condition is associated with the interrupt. The condition is described in the interrupt status byte (ISB) or in device dependent status words.
- CC=3 Device end. Reported when no error, exception, or attention condition has occurred during the I/O operation, and the interrupt is not the result of a PCI. For example: an operation has terminated normally.

Note. If the device has come to a normal end while using suppress exception (SE bit set to one) and an exception was suppressed since the last *Start* command, then bit zero of the interrupt status byte is set to one. This condition is called *permissive device end* (PDE) and indicates that errors or exceptions have been suppressed. Related status information is contained in the residual status block.

- CC=4 Attention. Reported when the interrupt was caused by an external event rather than execution of an Operate I/O instruction. Additional status information is not provided unless the event requires further definition; for example, code bits for a keyboard function.
- CC=5 Attention and PCI. Reported when attention and PCI are both present. In this case, the interrupt information byte contains the DCB identifier, and the attention must be singular in meaning.

 $\square$ 

- CC=6 Attention and exception. Reported when attention and exception are both present.
- CC=7 Attention and device end. Reported when attention and device end are both present. For this condition code, device end could also mean permissive device end. Refer to interrupt condition code 3.

The interrupt condition codes are mutually exclusive with each other but have no priority sequence.

# **I/O Status Information**

Some form of status information is transferred from the device to the processor as a result of:

- A read status operation (see *Read Status* command in this chapter).
- A start cycle steal status operation (see *Start Cycle Steal Status Operation* in this chapter).
- Storing a residual status block (see *Cycle-Steal Device Options* in this chapter).
- A priority interrupt.

The interrupt status information is detailed in the following two sections (*Interrupt ID Word* and *Interrupt Status Byte*).

#### Interrupt ID Word

Acceptance of an I/O interrupt causes the device to present an interrupt ID word to the processor. Presentation of the interrupt ID word is explained in Chapter 3 (see I/O Interrupts). This word has the following format:



- Bits 0-7 Interrupt information byte (IIB). For interrupt condition codes 2 and 6, the IIB has a special format and is called an interrupt status byte (ISB). Refer to interrupt status byte in this section. For most other interrupt condition codes, implementation of the IIB is device dependent. Exceptions are:
  - 1. CC=0. The IIB is set to zero.
  - 2. CC=3 or 7. Bit zero may be set to one if suppress exception is in effect.
- Bits 8-15 Device address. This byte contains the address of the interrupting device.

#### Interrupt Status Byte (ISB)

The ISB is a special format of the interrupt information byte (IIB) and contains detailed information on the nature of the interrupt. The ISB is reported only for error or exception conditions (interrupt condition codes 2 or 6). The ISB bits are normally set as a result of:

- 1. Status errors that occur during a DPC operation that cannot be indicated via a condition code.
- 2. Status errors that occur during a cycle steal operation.

The ISB is never reported as zero unless the condition code presentation of 2 or 6 is singular in meaning for devices that do not cycle steal. After the processor has accepted the interrupt request, the device resets the ISB.

Bits 0-7 of the two special formats are explained in the following sections.

ISB (devices that do not cycle steal):

- Bit 0 Device dependent status available. This bit set to one signifies that additional status information is available from the device. The information content and method of reading is described in the individual device publications.
- Bit 1 Delayed Command reject. This bit is set to one if the device cannot execute the command (specified in the IDCB) due to an incorrect parameter in the IDCB, or it cannot execute the command due to its present state. For example: (1) the IDCB specifies an incorrect function/modifier combination, or (2) the device is temporarily not ready. The operation in progress is terminated. Command reject is set in the ISB only if the device cannot report IO instruction condition codes for the condition.
- Bits 2-7 Device dependent. These bits, if used, are described in the individual device publications.

#### ISB (cycle stealing device):

Bit 0 Device dependent status available. This bit, when set to one, signifies that: (1) additional status information is available from the device, or (2) the device is in an improper state to execute a function specified by a DCB.

The operation is terminated. The content and method of reading the additional status information is described in the individual device publications.

Note. When bit 0 of the ISB is equal to one and bits 2-7 are zeros, the contents of the residual-address word (cycle steal status) are defined by the device.

Bit 1

Delayed command reject. This bit is set to one if the device cannot execute the command due to one of the following conditions:

- 1. The IDCB contains an incorrect parameter. Examples are (a) an odd-byte DCB address, or (b) an incorrect function/modifier combination.
- 2. The present state of the device, such as a *not* ready condition, prevents execution of an I/O command specified in the IDCB.

Delayed command reject is set in the ISB only if the device cannot report IO instruction condition codes for the condition. The operation is terminated. The DCB is not fetched.

Bit 2 Incorrect length record. This bit is set to one when the device encounters a mismatch between byte count and actual record length after beginning execution of the DCB. For example: the byte count is reduced to zero (with chaining flag off) and no end of record encountered. Incorrect length record is not reported when the SE bit in the control word is set to one. Reporting of incorrect length record is a device dependent feature and may be implemented regardless of the suppress exception feature. The operation is terminated.

- Bit 3 DCB specification check. This bit is set to one when the device cannot execute a command due to an incorrect parameter specification in the DCB. Examples are (1) an odd-byte DCB chaining or status address, (2) the byte count is odd for a word-only device, (3) an odd-byte data address for a word-only device, (4) an invalid command or invalid bit settings in the control word, or (5) an incorrect count. The operation is terminated.
  - Bit 4 Storage data check. This error condition applies to cycle steal output operations only. If the bit is set to one, it indicates that the main storage location accessed during the current output cycle contained bad parity. Parity in main storage is not corrected. The device terminates the operation. The bad parity data is not transferred to the I/O data bus. No machine check condition occurs.
  - Bit 5 *Invalid storage address.* When set to one, this bit indicates one of the following conditions:
    - 1. During a cycle steal operation, the device has presented a main storage address that is outside the storage size of the system.
    - 2. A cycle stealing device has attempted to access storage through a segmentation register and the valid bit in the segmentation register is set to zero. Note that the relocation translator feature must be installed and enabled before this condition can occur.

Invalid storage address can occur on a data transfer or on a DCB fetch operation. In either case, the cycle steal operation is terminated.

Bit 6 *Protect check.* When set to one, this bit indicates that the I/O device attempted to access a main storage location and presented an incorrect address key.

Bit 7 Interface data check. This bit set to one indicates that a parity error has been detected on the I/O data bus during a cycle steal data transfer. The condition may be detected by the channel or the I/O device. In either case, the operation is terminated.

. .

·

. .

O

j.

.

The storage protection mechanism is provided as a basic part of the IBM 4955 Processor. This chapter describes the operation of the storage protection mechanism when the Storage Address Relocation Translator Feature is not installed or is disabled and, therefore, applies only to the first 64K bytes of storage. When the relocation translator feature is installed and enabled, the storage protection mechanism, as described in this chapter, is disabled and all storage protection is controlled by the relocation translator. See Chapter 6, *Storage Address Relocation Translator Feature.* 

The state of the storage protection mechanism is controlled by the Enable (EN) and the Disable (DIS) instructions described in Chapter 8. When enabled, it protects against: (1) access (reading and writing) to defined blocks of storage by software or by an I/O operation, and (2) writing in an undesired location within a defined block by software.

Storage is divided into blocks of 2048 bytes (Figure 5-1). Thirty-two storage key registers are installed; one for each block of storage up to the maximum storage size of 64K bytes. Each block has an associated 8-bit storage key register containing a three-bit storage key and a read-only bit. The storage key and the read-only bit are set into a storage key register by the Set Storage Key (SESK) instruction. The Copy Storage Key (CPSK) instruction can be used to read out the storage key register. Both instructions are described in Chapter 8. The SESK instruction can specify a main storage block greater than the amount of storage installed on the system without causing a program check (if the installed storage is less than 64K bytes).

The processor determines storage-access authorization by comparing a storage key against an address key. Each priority level has an associated address key register (AKR). This register contains three address-key fields for: (1) operand 1, (2) operand 2, and (3) instruction space (Figure 5-1). Each address-key field is three bits long. The address key used for a particular storage access is determined by the type of operand being accessed and is called the active address key. Proper access is determined by comparing the active address key against the storage key. If writing into storage is involved, the access is further controlled by the read-only bit associated with the storage block. See the Address Space Management section of this chapter for more details on the active address key and the AKR. The address keys in the AKR are assigned by the supervisor using the appropriate system register instructions: (1) Set Address Key Register (SEAKR), (2) Set Instruction Space Key (SEISK), (3) Set Operand 1 Key (SEOOK), and (4) Set Operand 2 Key (SEOTK). They can be read by the Copy Level Block (CPLB) instruction or the appropriate system register instructions: (1) Copy Address Key Register (CPAKR), (2) Copy Instruction Space Key (CPISK), (3) Copy Operand 1 Key (CPOOK), and (4) Copy Operand 2 Key (CPOTK).



• For a main storage access, the storage key A must match the active address key B except as noted below:

-Supervisor state. Access to any area of storage, regardless of address keys or storage keys.

-Storage key of 7. Unprotected - any address key can be used.

• The read-only control is ignored by an I/O cycle-steal access or when in supervisor state.

\*The information is shown in the storage key register as it appears to the programmer.

Figure 5-1. Storage protection mechanism

When the storage protection mechanism is enabled, one or more of the following conditions must be true to authorize an attempt to access storage:

- 1. The machine is in supervisor state.
- 2. The storage key of the addressed block must be set to seven. If attempting to write into storage, the read-only bit must be set to zero.
- 3. The storage key of the addressed block must equal the active address key. If attempting to write into storage, the read-only bit must be set to zero.

If none of the three conditions is true:

- The storage access is prevented.
- The contents of main storage are not changed.
- A program check interrupt occurs with *protect check* set in the processor status word.

#### Programming Notes.

- 1. A storage key of seven allows access to any storage location within the block regardless of the active address key. However, the read-only control cannot be violated.
- 2. An active address key of zero is not a master key. The storage protection mechanism (if enabled) should be disabled prior to dumping the contents of storage to an I/O device.

For certain hardware functions that involve the access of main storage, the storage protection mechanism is suppressed. In the following cases, no storage protection checking is performed until the hardware function is completed:

- 1. During initial program load (see *Storage Protection during Initial Program Load* in this chapter).
- 2. While the system is in the stop state and a main storage access is being performed from the programmer console (optional feature).
- 3. While level status blocks are being stored by the hardware during class interrupts.

For I/O devices, one of the following conditions must be true to authorize an attempt to access storage:

- 1. The storage key of the addressed block must be set to seven.
- 2. The storage key of the addressed block must equal the active I/O cycle-steal address key.

Note that the read-only bit is ignored during cycle-steal access to main storage. The I/O cycle-steal address key is specified in the device control block (DCB). The DCB is used to control the cycle steal operation as explained in Chapter 4, *Input/Output Operations*.

Storage Protection During Initial Program Load

During initial program load (IPL), the storage protection mechanism is disabled. IPL is preceded by a hardware reset and no instructions are executed until the IPL terminates. At the successful completion of IPL, the processor enters supervisor state on priority level zero with all address keys in the address key register set to zero.

# Storage Protection in Supervisor State

Supervisor state overrides the storage protection mechanism. The supervisor has unlimited access to all of main storage. Any of the following events cause the processor to enter supervisor state:

- 1. A priority interrupt.
- 2. A class interrupt.
- 3. A successful IPL and a subsequent I/O interrupt.

*Note.* Occurrence of these events results in specific values being set in the address keys in the affected address key register. These address-key values are described in the section *Address Space Management* in this chapter.

When the processor exits supervisor state, via a Set Level Block (SELB) instruction, storage protection functions are resumed. The processor is now in the problem state and makes reference to the current address-key register for the active address key. Note. Storage protection in supervisor state is changed when the relocation translator feature is installed and enabled. This change is described in Chapter 6, Storage Address Relocation Translator Feature.

## Address Space Management

#### Active Address Key

At any point in time, one of four address keys may be used to access storage. The key in use is called the active address key and may be either the ISK, OP1K, OP2K, or the cycle-steal address key. The address key in use (active) depends on the type of operation being performed at a specific instant in time. When the storage protection mechanism is enabled, the active address key is used to determine storage access authorization. When the relocation translator feature is installed and enabled, the active address key defines storage access through a particular block of segmentation registers. See Chapter 6, Storage Address Relocation Translator Feature.

Each priority level in the processor has an associated address key register (AKR). Each register contains three address keys and an *equate operand spaces* (EOS) bit.

Address Key Register (AKR)

| x  | 0  | 0 | 0 | 0 | x  | x      | x | 0 | x | x      | x               | 0  | x  | x  | x  |
|----|----|---|---|---|----|--------|---|---|---|--------|-----------------|----|----|----|----|
| 0  | 1  |   |   | 4 | 5  |        | 7 | 8 | 9 |        | $\overline{11}$ | 12 | 13 |    | 15 |
| ł  |    |   |   |   | -  | $\sim$ | ~ |   | - | $\sim$ | -               |    | -  |    | -  |
| ΕĊ | )S |   |   |   | OI | 91 K   |   |   | 0 | P2K    | ζ.              |    |    | IS | K  |

- EOS Equate operand spaces. This bit when set to one causes all data operands to use the OP2K address key. See Equate Operand Spaces section in this chapter.
- OP1K Operand 1 key. These bits contain the binary-coded operand 1 address key with bit 7 as the low-order bit.
- OP2K Operand 2 key. These bits contain the binary-coded operand 2 address key with bit 11 as the low-order bit.
- ISK Instruction space key. These bits contain the binary-coded instruction-space address key with bit 15 as the low-order bit.

# Equate Operand Spaces (EOS)

The equate operand spaces bit (bit 0) in the address key register provides a control to modify the active address key definition for data operands. When the EOS bit is set to one (enabled), all processor data fetches occur within a single address space. The processor uses the OP2K address key for storage access. The OP1K is unchanged but is ignored. When the EOS bit is set to zero (disabled), the OP1K address key functions in a normal manner.

Equate operand spaces (EOS) may be enabled by (1) an Enable (EN) instruction, (2) a Set Level Block (SELB) instruction, or (3) a Set Address Key Register (SEAKR) instruction. EOS may be disabled by (1) a Disable (DIS) instruction, (2) a Set Level Block (SELB) instruction, or (3) a Set Address Key Register (SEAKR) instruction. These instructions are described in Chapter 8.

# Address Space

An address key defines a particular address space where:

- The address space is a range of logically contiguous storage.
- The address space is accessible by the effective address without intervention by a resource management function. That is, the address space is not greater than 64K bytes.

All instruction fetches occur within the address space defined by the instruction space key (ISK). For *storage to storage* instructions, all reads and writes concerning data operand 1 occur in the address space defined by the operand 1 key (OP1K). All reads and writes concerning data operand 2 occur in the address space defined by the operand 2 key (OP2K).

#### Examples:

ISK = OP1K = OP2K. For instruction processing, all storage accesses occur within the same address space.

ISK  $\neq$  OP1K, OP1K = OP2K. Instruction fetches occur in the ISK address space. Data access occurs in the OP2K address space.

ISK  $\neq$  OP1K  $\neq$  OP2K (Refer to Figure 5-2). The instruction fetch occurs in the ISK address space. The sourcedata operand access (storage to storage operations) occurs in the OP1K address space. All other data operand accesses occur in the OP2K address space.



Notes.

1. OP1K is only used for the source operand in Storage to Storage operations.

2. OP2K is used for storage data access in all other operations (excluding Branch/Jump).

Figure 5-2. Data movement in address spaces when ISK  $\neq$  OP1K  $\neq$  OP2K

I/O operations that access main storage also use an address key. Cycle steal operations (read or write) use the cycle-steal address key specified within the device control block. An address key of zero is used when the device fetches the device control block. DPC operations that write data to storage use the OP2K address key. The cycle steal and DPC operations are explained in Chapter 4, *Input/Output Operations*.

Other defined usage of the address key register:

- 1. All indirect access for branching uses the ISK.
- 2. Effective address generation (access of indirect storage address) occurs in the address space of the particular data operand.
- 3. Storage access via the console is defined by the ISK. Stop on Address is based on the ISK when the translator feature is installed and enabled.
- 4. System reset and IPL set all address keys and the EOS bit to zero.

#### Address Key Values After Interrupts

When priority or class interrupts occur, certain values are set into the address keys of the affected AKR. These values anticipate the address spaces that the programmer might need for interrupt processing. The following chart shows the resulting AKR for each type of interrupt.

| Resulting AKR values |                              |                                                                                                                                                    |                                                                                                                                                                                                                                                        |  |  |  |  |  |
|----------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| EOS                  | OP1K                         | OP2K                                                                                                                                               | ISK                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 0                    | 0                            | 0                                                                                                                                                  | 0                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 0                    | Note 1                       | 0                                                                                                                                                  | 0                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 0                    | Note 2                       | 0                                                                                                                                                  | 0                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 0                    | Note 2                       | 0                                                                                                                                                  | 0                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 0                    | Note 1                       | 0                                                                                                                                                  | 0                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 0                    | Note 3                       | 0                                                                                                                                                  | 0                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 0                    | 0                            | 0                                                                                                                                                  | 0                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 0                    | 0                            | 0                                                                                                                                                  | 0                                                                                                                                                                                                                                                      |  |  |  |  |  |
|                      | EOS<br>0<br>0<br>0<br>0<br>0 | EOS         OP1K           0         0           0         Note 1           0         Note 2           0         Note 1           0         Note 3 | EOS         OP1K         OP2K           0         0         0           0         Note 1         0           0         Note 2         0           0         Note 2         0           0         Note 1         0           0         Note 3         0 |  |  |  |  |  |

#### Note.

1. OP1K is set to the preceding key contained in OP2K

2. OP1K is set to the last active processor address key.

3. OP1K is set to the preceding key contained in the ISK.

All interrupt service routines are presumed to reside in address space zero; therefore, the ISK and OP2K are set to zero when an interrupt occurs. Necessary information for processing a specific interrupt may reside in an address space other than zero. The address key related to the particular interrupt is placed in OP1K. The OP1K is set in anticipation of a storage to storage move of information from the interrupting address space to address space zero.

*Note.* Class interrupts cause a hardware controlled storing of a level status block. This operation uses address key zero.

5-6 GA34-0021

à

.

# Chapter 6. Storage Address Relocation Translator Feature

The Storage Address Relocation Translator Feature is an optional feature for the IBM 4955 Processor Model B or D.

The relocation translator feature permits addressing of main storage locations beyond 64K bytes. The first 64K bytes can be directly addressed when the translator is disabled. Therefore, the feature is required when main storage is larger than 64K bytes. The reason for this requirement is that addresses, without this feature, are 16 bits long and provide an addressing capability of:

HexadecimalDecimal00000totoFFFF65,535

Addresses generated in relocation mode are 24 bits long. The 24-bit address provides an addressing *capability* of:

 Hexadecimal
 Decimal

 000000
 0

 to
 to

 FFFFFF
 16,777,215

# Segmentation registers

This addressing range should not be confused with main storage size, which is a maximum of 128K bytes for the IBM 4955 Processor Model B or D.

Besides address generation, storage protection also functions differently in relocation mode. When the translator feature is installed and enabled, the storage protection mechanism as described in Chapter 5 is disabled and all storage protection is under control of the translator. Refer to *Storage Protection when Using the Relocation Translator* in this chapter.

#### **Translator Description**

The translator feature provides 8 stacks of 16-bit segmentation registers. The stacks are numbered 0 through 7 to correspond to the 8 possible values of the address keys. Each stack consists of 32 registers (0 through 31):



Thus, 256 segmentation registers are provided in the relocation translator. Note that only one translator can be installed in the IBM 4955 Processor Model B or D.

The eight stacks of segmentation registers are under supervisory program control. Four privileged instructions are provided:

- Set Segmentation Register (SESR). This instruction loads one segmentation register.
- Copy Segmentation Register (CPSR). This instruction allows the supervisor to inspect the contents of a segmentation register.
- Enable (EN). This instruction enables the relocation translator. Until the translator is enabled, 16-bit addressing is in effect for the low-order 64K bytes of storage. Any storage above 64K bytes is not accessible to the programs until the translator is enabled.
- Disable (DIS). This instruction disables the relocation translator.

Refer to Chapter 8 for descriptions of the preceding instructions.

#### Storage Mapping

Mapping of main storage is achieved through the segmentation registers. Each segmentation register controls 2Kbyte segments of storage. The SESR instruction is used to load each segmentation register with a unique physical segment address. This segment address is the physical address of a 2K-byte segment of storage. Note however, that more than one segmentation register can be loaded with the same segment address. For example; stack 0, register 15 (associated with the supervisor address key of 0) can be loaded with the same number as stack 3, register 6. This arrangement allows the supervisor (for example) to address control blocks within a problem program even though the address key for the supervisor is different than the key for the problem program. Once loaded, each stack of segmentation registers contains a complete map of 64K bytes scattered in 2K-byte physical segments. A separate stack of segmentation registers is provided for each address-key value and allows fast task switching without the need for saving or restoring the storage map.

The following is an example of storage mapping for 128K bytes.

| 2K bi<br>numl |            |                           |                          |   |   | ini |   | egm | ieni |     |     |      |   |   |   | oad<br>ESR |                  |   |    |
|---------------|------------|---------------------------|--------------------------|---|---|-----|---|-----|------|-----|-----|------|---|---|---|------------|------------------|---|----|
| 1 st<br>64K   | 2nd<br>64K | First address<br>in block | Last address<br>in block | 0 |   |     |   | Se  | gm   | ent | ađa | lres | 5 |   |   | 12         | 2¦13             |   | 15 |
| 0             | 32         | 0000                      | 07FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 0 | 0 | 0 | 0          | IX               | X | 0  |
| 1             | 33         | 0800                      | 0FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 0 | 0 | 0 | 1          | ١X               | х | 0  |
| 2             | 34         | 1000                      | 17FF                     | 0 | 0 | 0   | þ | 0   | 0    | 0   | *   | 0    | 0 | 0 | 1 | 0          | 1 <sub>X</sub>   | х | 0  |
| 3             | 35         | 1800                      | 1FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 0 | 0 | 1 | 1          | X                | х | 0  |
| 4             | 36         | 2000                      | 27FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 0 | 1 | 0 | 0          | 1 <sub>X</sub>   | x | 0  |
| 5             | 37         | 2800                      | 2FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 0 | 1 | 0 | 1          | ١X               | х | 0  |
| 6             | 38         | 3000                      | 37FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 0 | 1 | 1 | 0          | ١x               | х | 0  |
| 7             | 39         | 3800                      | 3FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 0 | 1 | 1 | 1          | IX               | х | 0  |
| 8             | 40         | 4000                      | 47FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 1 | 0 | 0 | 0          | ١x               | х | 0  |
| 9             | 41         | 4800                      | 4FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 1 | 0 | 0 | 1          | IX               | Х | 0  |
| 10            | 42         | 5000                      | 57FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 1 | 0 | 1 | 0          | IX               | х | 0  |
| 11            | 43         | 5800                      | 5FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 1 | 0 | 1 | 1          | X                | х | 0  |
| 12            | 44         | 6000                      | 67FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 1 | 1 | 0 | 0          | iX               | х | 0  |
| 13            | 45         | 6800                      | 6FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 1 | 1 | 0 | 1          | jX               | х | 0  |
| 14            | 46         | 7000                      | 77FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 1 | 1 | 1 | 0          | İΧ               | Х | 0  |
| 15            | 47         | 7800                      | 7FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 0    | 1 | 1 | 1 | 1          | X                | х | 0  |
| 16            | 48         | 8000                      | 87FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 0 | 0 | 0 | 0          | jX               | х | 0  |
| 17            | 49         | 8800                      | 8FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 0 | 0 | 0 | 1          | İX               | х | 0  |
| 18            | 50         | 9000                      | 97FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 0 | 0 | 1 | 0          | IX               | Х | 0  |
| 19            | 51         | 9800                      | 9FFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 0 | 0 | 1 | 1          | ١X               | Х | 0  |
| 20            | 52         | A000                      | A7FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 0 | 1 | 0 | 0          | X                | х | 0  |
| 21            | 53         | A800                      | AFFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 0 | 1 | 0 | 1          | IX               | Х | 0  |
| 22            | 54         | B000                      | B7FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 0 | 1 | 1 | 0          | IX               | Х | 0  |
| 23            | 55         | <b>B800</b>               | BFFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 0 | 1 | 1 | 1          | Ιx               | Х | 0  |
| 24            | 56         | C000                      | C7FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 1 | 0 | 0 | 0          | Ιx               | х | 0  |
| 25            | 57         | C800                      | CFFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 1 | 0 | 0 | 1          | Ιx               | Х | 0  |
| 26            | 58         | D000                      | D7FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 1 | 0 | 1 | 0          | ١x               | х | 0  |
| 27            | 59         | D800                      | DFFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 1 | 0 | 1 | 1          | $ _{\mathbf{X}}$ |   | 0  |
| 28            | 60         | E000                      | E7FF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 1 | 1 | 0 | 0          | $ _{\mathbf{X}}$ |   |    |
| 29            | 61         | E800                      | EFFF                     | 0 | 0 | 0   | 0 | 0   | 0    | 0   | *   | 1    | 1 | 1 | 0 | 1          | I <sub>X</sub>   | х | 0  |
| 30            | 62         | F000                      | F7FF                     | Ō | 0 | 0   | 0 | 0   | Õ    | Õ   | *   | 1    | 1 | 1 | 1 | 0          | IX               | x | Õ  |
| 31            | 63         | F800                      | FFFF                     | Ŏ | Õ | 0   | 0 | Ő   | Õ    | 0   | *   | 1    | 1 | 1 | 1 | 1          | X                |   |    |

\*This bit is 0 for 1st 64K and 1 for 2nd 64K

Example of storage mapping for 128K bytes

.

#### **Relocation Addressing**

This section describes how the relocation translator generates a 24-bit address to address any byte in storage. Figure 6-1 shows an example of address translation. The letters in the following steps correspond to the letters on the figure.

А

The active address key from the address key register selects a segmentation register stack. The address key pertains to the instruction being executed on the current priority level.

B The five high-order bits (0 through 4) of the 16-bit address (generated for the instruction being executed) select a segmentation register within the stack selected in step A. These bits define the logical segment. **C** The 24-bit address is generated. The 13 high-order bits (0 through 12) are from the segmentation register; these bits specify the physical address of a 2K-byte segment of storage.

The 11 low-order bits (bits 13 through 23) of the 24-bit address are the 11 low-order bits (5 through 15) of the 16-bit logical address (generated for the instruction being executed); these bits specify the byte address within the 2K-byte segment.





# Storage Protection When Using the Relocation Translator

When the translator is installed but disabled, by a Disable (DIS) instruction with parameter field bit 14 set, only the first 64K bytes of storage can be addressed. Operation of the storage protection mechanism is exactly as described in Chapter 5. When the translator is installed and enabled by an Enable (EN) instruction (with parameter field bit 14 set to one and bit 12 set to zero) the storage protection mechanism described in Chapter 5 is disabled.

When the translator is enabled, the storage protection mechanism by itself no longer protects against inadvertent writing or instruction access of main storage. This function is undertaken by the translator. To this end, the storage key registers are ignored by the hardware. As previously described, the address keys are used to select stacks of segmentation registers. There are eight such stacks in the translator with 32 segmentation registers in each stack. Address key 0 is implicitly assigned to the supervisor for handling interrupts. Address key 0 is also used for (1) cycle steal DCB fetching, and (2) storing of the residual status block. Chapter 5 describes the method of setting and reading the address keys. Because each stack of segmentation registers has access to storage only within its assigned region, protection is provided against writing into storage or fetching instructions from another region.

The translator also provides no-access and read-only protection within the regions controlled by each stack of segmentation registers. This allows storage protection of shared segments of storage. Bits 13 and 14 of the segmentation registers are used for this purpose:

Bit 13 (Valid Bit). When set to one, this bit specifies that the contents of the segmentation register are valid; the segmentation register can be used to perform the translation. When bit 13 is a zero, the segmentation register cannot be used for translation (no access). If translation is attempted, a program check interrupt occurs with *invalid storage address* (ISA) set in the program status word. This is called a *logical ISA*.

**Bit 14 (Read-Only Bit).** When set to a one, this bit specifies that the block is read only. If an attempt is made to write into storage using a segmentation register with the read-only bit set to one, a program check interrupt occurs with *protect check* set in the program status word. Storage is not changed. Bit 14 is ignored by a cycle steal access, or when in supervisor state.

# I/O Storage Access Using the Relocation Translator

All storage access requests from I/O devices are translated by the same mechanism that handles storage requests from the processor. The device control block (DCB) must reside in the supervisor's address space. Therefore; all I/O devices must use address key 0 to gain access to the DCB and to store the residual status block. The address key of the process requiring a cycle steal operation resides in the DCB. The I/O device presents this address key along with a 16 bit logical address to the translator. This allows the I/O device to directly address the storage space for a particular process. The address key allows I/O storage protection to be established between address spaces assuming the supervisor ensures the integrity of the DCBs.

# Compatibility Between the Relocation Translator and the Storage Protection Mechanism

The storage protection mechanism (as described in Chapter 5) has similar characteristics to those of the relocation translator; also, there are certain characteristics that are dissimilar. The programmer should be familiar with these characteristics in order to write code that migrates from a system using the storage protection mechanism to one using the relocation translator.

The two sets of characteristics are listed below and require the following definitions:

- Storage protect system the storage protection mechanism is enabled. The relocation translator (if installed) is disabled.
- Translator system the storage protection mechanism is disabled. The relocation translator is enabled.

# Characteristics That Are Similar

- 1. The *active address key* defines the storage that may be addressed at any point in time.
- 2. For a storage protect system, the storage key registers define access control to a 2K-byte block of storage. For a translator system, the segmentation registers define access control to a 2K-byte block of storage.
- 3. Within the storage defined by an address key, a read-only area may be designated. The read-only areas are defined for 2K-byte blocks.
- 4. No protect check occurs when accessing storage in supervisor state.
- 5. I/O cycle-steal access to main storage is unaffected by the read-only bit.
- 6. The storage protection mechanism or the relocation translator may be either enabled or disabled using the Enable (EN) or Disable (DIS) instructions.
- For a storage protect system, a storage key of 7 defines a common area accessible by any address key. A translator system can reproduce this function by mapping the same logical address in all address spaces into a unique physical address.

# Characteristics That Are Dissimilar

- 1. In a storage protect system, supervisor state allows access to all of main storage, irrespective of address keys or storage keys. In a translator system, supervisor state may only access the storage defined by the active address key.
- 2. In a storage protect system, the total storage defined by address keys is less than or equal to 64K-bytes. In a translator system, the total storage defined by address keys is less than or equal to 512K-bytes at an instant in time.
- 3. In a translator system, the address space defined by an address key starts at logical address zero. In a storage protect system, the address space defined by an address key starts on various 2K-byte block boundaries.
- 4. The instructions used to load and store storage key registers are different from the instructions used to load and store segmentation registers.
- 5. In a translator system, an I/O device should not receive protect checks. In a storage protect system, it is possible for an I/O device to receive protect checks.
- 6. Due to the address mapping capability of a translator system, certain mappings from logical to physical address space are difficult to emulate in a storage protect system. For example: a common area exclusive to only two address keys.
- 7. In a translator system, PSW bit 14 provides status information on whether the translator is enabled or disabled. There is no status bit to provide this information concerning the storage protection mechanism.

#### **Error Recovery Considerations**

#### Invalid Storage Address

If a program check interrupt with *invalid storage address* (ISA) set in the program status word occurs when the relocation translator is enabled, it has two possible meanings:

- 1. Mapping occurred into a real storage address, but that segment of storage is not installed on the machine. This error is called a physical ISA.
- 2. Bit 13 (valid bit) of the segmentation register was not set when mapping was attempted. This signifies that the contents of the segmentation register are invalid. This error is called a logical ISA.

The specific nature of the ISA can be resolved as follows:

- 1. Store the segmentation register following the program check interrupt.
- Test the segmentation register for the presence of bit 13.
- 3. If bit 13 is a one, the supervisor's concept of the actual storage installed on the machine is incorrect.

#### **Protect** Check

When the translator is enabled, a program check interrupt with *protect check* set in the PSW is caused by an attempt to write into storage using a segmentation register with bit 14 (read-only) set to one.

When the translator is disabled, protect check in the **PSW** can be set by the storage protection mechanism (if it is enabled). Refer to Chapter 5 for additional information about the storage protection mechanism.

To resolve the cause of the protect check error, the supervisor must determine if the translator is enabled.

# Status of Translator After Power Transitions and Resets

The translator is enabled only by the Enable (EN) instruction. The translator is disabled by the following:

- 1. Disable (DIS) instruction
- 2. Power on reset
- 3. Check restart
- 4. Initial program load (IPL)

5. System reset key (Programmer Console Feature)

Notes.

- 1. A machine check does not disable the translator.
- 2. The segmentation registers are not reset when the translator is disabled.

# Instruction Execution Time When Using the Translator

The translator, when enabled, adds 220 nanoseconds to each reference to main storage. When the translator is disabled, storage references proceed at normal speed (660 nanoseconds). Table 2 in Appendix A provides instruction execution times when the translator is enabled.

.

ι,

. .

6-8 GA34-0021

and approximately a second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the

 And A. Statistical and the second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical sec statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statistical second statis

# Chapter 7. Console

There are two configurations of consoles available for the IBM 4955 Processor. The Basic Console is standard, and remains with the processor. The Programmer Console is an optional feature that is added to the basic console when the option is selected.



7-2 GA34-0021

The basic console is primarily intended for those systems that are totally dedicated to a particular application, where operator intervention is not needed during the execution of the application.

The programmer console is aimed at operator oriented systems where various programs are entered and executed during the day. This type of environment requires a more versatile console arrangement for program and machine problem determination, and for manual alteration of data and programs in storage.

# **Basic Console**

Each IBM 4955 Processor comes equipped with the standard Basic Console. The Basic Console provides the following capabilities:

- Power On/Off switch for the processor card file
- IPL source switch to select a primary or alternate IPL device
- Load key for IPL (initial program load)
- Mode switch to select: Diagnostic mode, Auto IPL, or Normal mode
- Load, Wait, Run, and Power On indicators.

#### Keys and Switches

A Power On/Off When this switch is placed in the On position, power is applied to the processor unit. After all power levels are up, the Power On indicator is turned on. When this switch is placed in the Off position, power is removed from the processor card file and the Power On indicator is turned off. **IPL** Source .B This switch selects the I/O device to be used for program loading. In the Primary position, the device that was pre-wired as the primary IPL device is selected. In the Alternate position, the device that was prewired as the alternate IPL device is selected. Load Pressing this key causes a system reset, then С the initial program load (IPL) sequence is started. The Load indicator is turned on and remains on until the IPL sequence is completed. When the IPL is completed. instruction execution begins at location zero on level zero.

D Mode

This switch has the following positions:

- Auto IPL In this position, an IPL is initiated after a successful power-on sequence. Bit 13 of the PSW is set to indicate to the software that an automatic IPL was performed. In this mode STOP instructions are treated as no-ops.
- Normal This position is for attended operation. In this mode STOP instructions are treated as no-ops.
- Diagnostic This position has no function without the Programmer Console. This position places the processor in diagnostic mode if the Programmer Console is attached. When the processor is in diagnostic mode, STOP instructions cause the processor to enter stop state.

# Indicators

| E | Power On | On when the proper power levels are available to the system.                                                       |
|---|----------|--------------------------------------------------------------------------------------------------------------------|
| F | Load     | On when the machine is performing an initial program load (IPL).                                                   |
| G | Wait     | On when an instruction that exits the active level has been executed and no other priority interrupts are pending. |
| Н | Run      | On when the machine is executing instructions                                                                      |



# Programmer Console

The Programmer Console is an optional feature that can be ordered with the IBM 4955 Processor or may be field installed at a later date. The Programmer Console provides the following capabilities:

- Start and stop the processor.
- Display or alter any storage location.
- System reset.
- Select any of the four interrupt levels for display or alter purposes.
- Display or alter the storage address register (SAR), instruction address register (IAR), console address key register (AKR), console data buffer, or any general purpose register.
- Display but not alter the level status register (LSR), current instruction address register (CIAR), op register, level address key register (AKR), or processor status word (PSW).
- Stop-on-address.
- Stop-on-error.
- Instruction step.
- Check restart.
- Request a console interrupt.
- Check indicator, on when a machine check or program check class interrupt has occurred.

The Programmer Console is touch sensitive with an audio tone generator providing an audio response tone whenever a key depression has been accepted and serviced by the processor.

# Console Display

#### Run or Wait State

When the processor is in run or wait state, the console data buffer is displayed in the data display indicators. An exception to this is when a Set Console Data Lights instruction writes a message to the data lights. This instruction does not change the buffer. When the Data Buffer key is pressed, the console data buffer is again displayed in the indicators.

When the console data buffer is being displayed, it can be changed by entering new data using the data entry keys. No depression of the Store key or Data Buffer key is required.

#### Stop State

When the processor enters stop state, the IAR is displayed in the data display indicators. Any system resource that has a corresponding select key on the console can be displayed. For example, the console data buffer can be displayed by pressing the Data Buffer key.



#### **Power-On Reset**

After a power-on reset, the data display indicators are set on and the level indicators are set off.

#### **Indicators**

Α

#### Data Display

- When the processor is in run state, the console data buffer is displayed in the data display indicators.
- The Set Console Data Lights (SECON) instruction can write a message to the data display.
- When the processor enters stop state, the IAR is displayed unless another system resource is selected.
- To display the contents of the console data buffer after a system resource has been displayed, press the Data Buffer key. C

Check

Β.

On when a machine check or program check class interrupt has occured. The check indicator is turned off by:

- Clearing the check condition
  - Reset key
  - Load key
  - Executing a Copy Processor Status and Reset (CPPSR) instruction. This instruction resets bits 0-12 of the PSW.
- Pressing any console key while in the stop state. Note that the check condition is not cleared unless the Reset key or the Load key is pressed.

While in the stop state, the check indicator is used to indicate main storage parity errors during display operations. Refer to *Displaying Main Storage Locations* in this chapter.



# $\cap$

# **Combination Keys/Indicators**

There are nine combination key/indicators:

- Level 0, 1, 2, and 3
- Stop
- Stop On Address
- Instruct Step
- Check Restart
- Stop On Error
- A Level 0–3

The current active level is always displayed by one of the level indicators. When in the stop state, pressing any of the level keys causes that level to be selected and the associated indicator is turned on.

Stop

This indicator is on when the processor is in the stop state. Stop state is entered in the following ways:

- By pressing the Stop key.
  - In run state the current instruction is completed.
  - In wait state, stop state is entered directly.
  - In the stop state, the contents of the IAR upon entering stop state are restored to the IAR and displayed in the lights. The level that was active upon entering stop state is reselected (becomes active).
- By execution of the Stop instruction (diagnostic mode only).
- When an address compare occurs in stop-on-address mode.
- When an error occurs in stop-onerror mode.
- By pressing the Reset key.
- When a power-on reset occurs.
- By selecting the Instruction Step mode while in run state.

The Stop On Address key and the Instruct Step key are mutually exclusive. When one is pressed, the other is reset if it was on.



This key places the processor in stop on address mode. Pressing the Stop On Address key a second time resets stop on address mode and turns off the indicator.



Pressing the Instruct Step key places the processor in instruction step mode and turns the Instruction Step indicator on. The Stop On Address indicator is turned off if it was on.

If the processor is in run or wait states, pressing this key causes the processor to enter stop state. Pressing the Instruction Step key a second time resets instruction step mode, the processor remains in stop state.

To operate in instruction step mode:

- Key the desired starting address and store into the IAR.
- Press the Instruct Step key.
- Press the Start key. The instruction located at the selected address is executed, the processor returns to stop state. The IAR is updated to the next instruction address, this address is displayed in the data display indicators.
- Each subsequent depression of the Start key causes one instruction to be executed and the IAR is updated to the next instruction address.

*Note.* Priority and class interrupts are not inhibited during execution of the instruction.



#### Stop On Address Mode

Processor must be in stop state to set the compare address.

- 1. If the Storage Address Relocation Feature is not installed go to step 2, otherwise:
  - a. Press AKR key (selects console AKR when all level lights are off).
  - b. Key in the Address Key (ISK bits of AKR).
  - c. Press Store key.
- 2. Press Stop On Address Key.
- 3. Key in selected address.
- 4. Press Store Key. The selected address and address key are placed in the stop on address buffer.
- 5. Press Start Key. Execution begins at current IAR address on the current level.

When the selected address is loaded into the IAR, the processor enters stop state. To exit stop state press the Start key; execution begins at the next sequential address.



The Check Restart key and the Stop On Error key are mutually exclusive. When one is pressed the other is reset if it was on.

E Check Restart

Pressing this key places the processor in check restart mode. While in this mode, a program check, a machine check, or a power/thermal warning class interrupt causes the processor to be reset and execution to restart at address zero on level zero.

*Note.* The power/thermal warning class interrupt is controlled by the summary mask.

F Stop On Error

Pressing this key places the processor in stop on error mode. Any program check, machine check, or power/thermal warning causes the processor to enter stop state. To determine the cause of the error, display the PSW. To restart the processor, press the Reset key then the Start key. Pressing only the Start key, allows the processor to proceed with the class interrupt as if stop mode had not occurred. Note that the check indicator may have been turned off while in stop state. After the class interrupt routine is completed, control may be returned to the instruction that caused the error and an attempt to reexecute the instruction may be made. Note that some instructions are not reexecutable because operand registers or storage locations were changed before the instruction was terminated (because of the initial error). In these cases, the operator must be familiar with the program because manual restoration of affected locations must be made before restart is attempted.

*Note.* The power/thermal warning class interrupt is controlled by the summary mask.

# Keys and Switches

A Reset

This key initiates a system reset that performs the following functions:

- IAR on level zero set to zeros.
- AKR on level zero set to zeros.
- Console AKR set to zero.
- Interrupt mask set to all levels enabled.
- LSR on level zero indicators set to zero, summary mask enabled, supervisor state and in-process flag turned on, trace disabled.
- LSRs for levels 1-3 set to zeros.
- PSW set to zero.
- SAR set to zeros.
- CIAR set to zeros.

After the system reset is completed, the processor is placed in the stop state with stop indicator on.

The following resources are not affected by system reset:

- General registers (all levels)
- IARs (levels 1–3)
- AKRs (levels 1-3)
- Storage key stack
- Main storage
- Console data buffer
- Segmentation registers (relocation translator features)
- Floating-point registers (floating-point feature)
- Stop on Address buffer.

|   | 1           |                                                                                                                                                                                                                                                                                                                                                                            |
|---|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| В | Store       | This key is effective only when the<br>processor is in stop state. Pressing this<br>key causes the last data entry to be<br>stored in the last selected resource.                                                                                                                                                                                                          |
| С | Data Buffer | Pressing this key causes the console data<br>buffer to be selected. The contents of the<br>console data buffer are displayed in the<br>data display indicators.                                                                                                                                                                                                            |
| D | Console     |                                                                                                                                                                                                                                                                                                                                                                            |
|   | Interrupt   | The effect of this key depends on the state<br>of the processor. If the processor is in the<br>stop or load states, this key has no effect.<br>If the processor is in the run or wait state<br>and the summary mask is enabled prior to<br>the key action, a console class interrupt<br>occurs. The audio response tone is gener-<br>ated when the interrupt is processed. |
| E | Start       | Effective in stop state only. Stop state is<br>exited and the processor resumes execution<br>at the address in the IAR on the current<br>level. If stop state was entered from system<br>reset, execution begins at address zero,<br>level zero. If stop state was entered from<br>wait state, the processor returns to wait<br>state.                                     |

Note. The Reset and Console Interrupt keys have an indication (+++) on the face of the keys. This signifies that additional pressure must be used to activate these keys. This is to minimize the possibility of the operator inadvertently activating these functions.



| F   | PSW          | Pressing this key selects the processor<br>status word. The contents of the PSW are<br>displayed in the data display indicators.<br>Data cannot be stored into the PSW from<br>the console.                                                                                                                                                                  |
|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| G   | Op Reg       | Data cannot be stored into the Op register<br>from the console. Pressing this key selects<br>the Op register and displays the contents<br>in the data display indicators.                                                                                                                                                                                    |
| H   | CIAR         | Pressing this key after entering stop state<br>causes the address of the instruction just<br>executed to be displayed. Data cannot be<br>stored into the CIAR from the console.                                                                                                                                                                              |
| ; L | SAR          | Pressing this key while in stop state dis-<br>plays the contents of the storage address<br>register. An address can be stored into the<br>SAR to address main storage for display<br>or store operations. Bit 15 of the SAR<br>cannot be set from the console.                                                                                               |
| K   | Main Storage | Pressing this key selects main storage as the<br>facility to be accessed by the console. When<br>this key is pressed, the contents of the<br>main storage location addressed by the<br>SAR is displayed in the data display indi-<br>cators. Procedures for displaying and<br>storing main storage are provided in sub-<br>sequent sections of this chapter. |

#### Level Dependent Keys

The following keys select registers that are duplicated in hardware for each of the four interrupt levels:

- LSR
- AKR
- IAR
- General purpose registers 0-7

Pressing any of these keys, once a level has been selected, causes the contents of that register to be displayed in the data display indicators.

The level status register (LSR) is displayable only; data cannot be stored into this register.

To display an AKR for a given level, press the AKR key; the console AKR is displayed in the data display indicators, and the level indicators are reset. Press the desired Level key; the contents of the AKR for that level are now displayed. The *level AKRs* are displayable only. The console AKR is used for console operations only, and data can be stored into or displayed from this register.

Bit 15 of the IARs cannot be changed from the console.

Pressing the Store key after selecting an LSR or AKR results in no action taken and no audio tone response.





# Data Entry Keys

The sixteen data entry keys are used to enter data into a selected resource such as main storage or a general register. When data is entered it is shifted through the indicators as shown in the following example.



# Example: Data to be entered: F3A8



- Indicator on

O- Indicator off

# **Displaying Main Storage Locations**

- Machine must be in stop state.
- If the Storage Address Relocation Translator Feature is installed and enabled, start at step 1, otherwise start at step 4.
- 1. Press the AKR key. A The contents of the console AKR are displayed in the data display indicators.
- 2. Key in one hex character (new address key). This character is displayed in bits 12-15 of the data display indicators. Bit 12 is ignored when the address key is stored (the key is stored in bits 13-15).
- 3. Press the Store key B to Store the new address key into the AKR.
- 4. Press the SAR key. C The contents of the SAR are displayed in the data display indicators.
- 5. Key in the selected address (four hex characters). This address is displayed in the data display indicators.
- 6. Press the Store key. **B** The address that is displayed is stored into the SAR.
- 7. Press the Main Storage key. D The contents of the addressed storage location are displayed in the data display indicators. To display sequential main storage locations, continue pressing the Main Storage key. The storage address is incremented by +2 each time the Main Storage key is pressed, and the addressed location is displayed.



### Notes.

- 1. The use of the procedure at step 1 through 3, assumes a thorough knowledge of the relocation translator feature and the storage mapping assigned by the program.
- 2. If an invalid storage address or a protect check condition occurs:
  - a. The program check is suppressed.
  - b. No PSW bit is set.
  - c. The check indicator is not turned on.
  - d. The storage access is suppressed.
  - e. The data display indicators are set to a value of 0003 with no other visual indication of the error.

# Storing Into Main Storage

- Machine must be in stop state.
- If the Storage Address Relocation Translator Feature is installed and enabled, start at step 1, otherwise start at step 4.
- 1. Press the AKR key. A The contents of the console AKR are displayed in the data display indicators.
- 2. Key in one hex character (new address key). This character is displayed in bits 12-15 of the data display indicators. Bit 12 is ignored when the address key is stored (the key is in bits 13-15).
- 3. Press the Store key B to store the new address key into the AKR.
- 4. Press the SAR key. C The current contents of the SAR are displayed in the data display indicators.
- 5. Key in the selected address (four hex characters). The address is displayed in the data display indicators.
- 6. Press the Store key. **B** The address displayed in the data display indicators is stored into the SAR.
- Press the Main Storage Key.
   The contents of the addressed storage location are displayed in the data display indicators.
- 8. Key in the data that is to be stored into main storage. This data is displayed in the data display indicators.
- 9. Press the store key. B The data that is displayed is stored at the selected storage location. Each subsequent pressing of the Store key causes the SAR to be incremented by +2, and the data stored at the location is displayed.

*Note.* The use of the procedure at step 1 through 3, assumes a thorough knowledge of the relocation translator feature and the storage mapping assigned by the program.

# **Displaying Registers**

- Processor must be in Stop State.
- 1. Select the proper level by pressing the appropriate Level key.

The contents of any register associated with the selected level can now be displayed by pressing the register key.

Press the desired register key. The contents of that register are displayed in the data display indicators.

To display the same register on each level, select the register, then press each level key. Each level selection causes the selected register for that level to be displayed in the data display indicators.

# Storing Into Registers

- Processor must be in stop state.
- 1. Select the proper level by pressing the appropriate Level key.
- Ptess the key for the register where data is to be stored. The contents of that register are displayed in the data display indicators. B
- 3. Key in the data that is to be stored. This data is displayed in the data display indicators.
- 4. Press the Store key. C The data that is displayed is stored into the selected register.

To store into the corresponding register on another level, select the level and proceed with step 3; or, if the same data is to be stored, select the level and press the Store key.



7-12 GA34-0021

The instructions (excluding floating-point instructions) for the IBM 4955 Processor are described in this chapter. Floating-point instructions are described in Chapter 9. A complete listing of instruction formats is contained in Appendix B. Instruction timings are contained in Appendix A. Indicator settings are listed for each instruction. For additional indicator information, refer to *Indicators* in Chapter 2.

## **Exception Conditions**

Exception conditions that might occur during instruction execution are shown in abbreviated form with each instruction description. Refer to the following sections for a detailed description of these conditions.

## **Program Check Conditions**

### Invalid Function

(1) An illegal operation code or function combination is encountered during instruction execution, or (2) while in supervisor state, the processor attempts to execute a Copy Segmentation Register (CPSR) or Set Segmentation Register (SESR) instruction and the optional relocation translator feature is not installed.

A program check class interrupt occurs with *invalid* function (bit 4) set in the PSW.

## **Invalid Storage Address**

**Instruction Word or Operand.** One or more words of the instruction or the effective address is outside the installed storage size of the system. The instruction is suppressed unless otherwise noted in the individual instruction description.

A program check class interrupt occurs with *invalid* storage address (bit 1) set in the PSW.

### **Privilege Violate**

**Privileged Instruction**. A privileged instruction is encountered while in problem state. The instruction is suppressed.

A program check class interrupt occurs with *privilege* violate (bit 2) set in the PSW.

### Protect Check

Instruction Fetch or Operand Access. In the problem state, an instruction is fetched or data is accessed from a storage area not assigned to the current operation.

**Operand Store**. In the problem state, the instruction attempts to change an operand in a storage area assigned as read-only.

The instruction is suppressed unless otherwise noted in the individual instruction description. A program check class interrupt occurs with *protect check* (bit 3) set in the **PSW**.

### Specification Check

**Operand Address.** The generated effective address has violated an even-byte boundary requirement.

Indirect Address. When using addressing mode (AM=11), the indirect address is not on an even-byte boundary.

The instruction is suppressed unless otherwise noted in the individual instruction description. A program check class interrupt occurs with *specification check* (bit 0) set in the PSW.

*Note.* A specification check can also occur during a Supervisor Call (SVC) instruction if the SVC LSB pointer or the SVC SIA pointer violates an even-byte boundary requirement.

## Soft Exception Trap Conditions

### **Invalid Function**

(1) A floating-point instruction (operation code 00100) is attempted and the floating-point feature is not installed, or (2) a Set Floating Level Block (SEFLB) or Copy Floating Level Block (CPFLB) instruction is attempted while in supervisor state, and the floating-point feature is not installed.

The instruction is suppressed. A soft-exception-trap class interrupt occurs with *invalid function* (bit 4) set in the **PSW**.

## Stack Exception

(1) The stack is full and a Push instruction or a Store Multiple (STM) instruction is attempted, (2) the stack is empty and a Pop instruction or a Load Multiple and Branch (LMB) instruction is attempted, or (3) the stack cannot contain the number of words to be stored by a Store Multiple instruction.

The instruction is suppressed. A soft-exception-trap class interrupt occurs with *stack exception* (bit 6) set in the **PSW**.

*Note.* When the AM field is equal to 01, the register specified by the RB field is incremented before the class interrupt occurs.

## Instruction Termination or Suppression

Exception conditions that occur during instruction processing might cause the instruction to be terminated or suppressed. When an instruction is terminated, partial execution has taken place and may have caused a change to registers, indicators, or main storage. When an instruction is suppressed, there has been no execution, therefore, no changes. Refer to *Exception Conditions* in the previous section.

## **Instruction Descriptions**

The following descriptions are in alphabetical sequence based on assembler mnemonics. However, extended mnemonics are listed under the appropriate machine instruction. For example: branching, jumping, and address key register instructions. Add Byte (AB)



| Operat | tior | ı Co | ode  |      | R   |      | RI  | 3 | AM   | X    | Fu | nct | ion |
|--------|------|------|------|------|-----|------|-----|---|------|------|----|-----|-----|
| 1 1    | 0    | 0    | 0    |      |     |      |     |   |      |      | 1  | 1   | 0   |
| 0      |      |      | 4    | 5    |     | 7    | 8   | 9 | 10 1 | 1 12 | 13 |     | 1.  |
|        |      |      |      |      |     |      |     |   |      | ł    |    |     |     |
|        |      |      |      |      |     |      |     |   |      |      |    |     |     |
|        | 1 :  | = re | sult | to s | tor | age  | )   |   |      |      |    |     |     |
|        |      |      |      |      |     | -    | > - |   |      |      |    |     |     |
|        | 0 -  | = re | suu  | to r | egi | sier | )   |   |      |      |    |     |     |

Address/DisplacementDisplacement 1Displacement 216232431

An add operation is performed between the least significant byte of the register specified by the R field and the location specified by the effective address in main storage. (See *Effective Address Generation* in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand and high-order byte of the register are unchanged.

### Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the byte. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one byte; i.e., if the sum is less than  $-2^7$  or greater than  $+2^7-1$ .

If an overflow occurs, the result contains the correct loworder eight bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check.** Even byte boundary violation (indirect address).

## Add Byte Immediate (ABI)

## ABI byte,reg

| OF | oera | tior | 1 co | de | 1 | R | <u> </u> | Immediate |    |
|----|------|------|------|----|---|---|----------|-----------|----|
| 0  | 0    | 0    | 0    | 0  |   |   |          |           |    |
| 0  |      |      |      | 4  | 5 | 7 | 8        |           | 15 |

The immediate field is expanded to 16 bits by sign propagation to the eight high-order bits. The field is then added to the contents of the register specified by the R field. The result is placed in the register specified by the R field.

## Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

## **Program Check Conditions**

Protect Check. Instruction fetch.

## Add Carry Register (ACY)

reg

ACY

| Op | bera | tior | 1 00 | de |    |   |   |   | R2 |    | Fu | nct | ion |    |
|----|------|------|------|----|----|---|---|---|----|----|----|-----|-----|----|
| 0  | 1    | 1    | 1    | 0  | .0 | 0 | 0 |   |    | 0  | 1  | 1   | 0   | 0  |
| 0  |      |      |      | 4  | 5  |   | 7 | 8 | 10 | 11 |    |     |     | 15 |

The value of the carry indicator on entry is added to the contents of the register specified by the R2 field, and the result is placed in the register specified by the R2 field. Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

*Programming Note.* This instruction can be used when adding multiple word operands. See *Indicators – Multiple Word Operands* in Chapter 2.

## Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even. Unchanged.

Negative. Changed to reflect the result.

**Zero.** If on at entry, changed to reflect the result. If off at entry, it remains off.

## **Program Check Conditions**

Protect Check. Instruction fetch.

## Add Doubleword (AD)

## **Register/Storage Format**

AD reg,addr4 addr4,reg



An add operation is performed between the register pair specified by the R field (R and R+1) and the doubleword in main storage specified by the effective address. (See *Effective Address Generation* in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged.

If the R field equals 7, register 7 and register 0 are used.

### Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the doubleword. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in the doubleword; i.e., if the sum is less than  $-2^{31}$  or greater than  $+2^{31}-1$ .

If an overflow occurs, the result contains the correct low-order 32 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. If the doubleword location specified by the effective address crosses a read-only protection boundary, partial data may be stored into the non read-only protected area. The status of the indicators is unpredictable.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

## Storage/Storage Format

AD addr5,addr4



The address arguments generate the effective addresses of two operands in main storage. (See *Effective Address Generation* in Chapter 2.) Doubleword operand 1 is added to doubleword operand 2. The result replaces operand 2. Operand 1 is unchanged.

### Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the doubleword. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in the doubleword; i.e., if the sum is less than  $-2^{31}$  or greater than  $+2^{31}-1$ .

If an overflow occurs, the result contains the correct low-order 32 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If RB1 and RB2 specify the same register and AM1=01, the register is incremented before the program check interrupt occurs.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand store, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

## Add Word (AW)

| Regist | er/Register Format |
|--------|--------------------|
| AW     | reg,reg            |

| 0 | Operation code |   |   |   |   | R1 |   | Γ | R2 |    |    | Fu | nct | ion |    |
|---|----------------|---|---|---|---|----|---|---|----|----|----|----|-----|-----|----|
| 0 | 1              | 1 | 1 | 0 |   |    |   |   |    |    | 0  | 1  | 0   | 0   | 0  |
| 0 |                |   |   | 4 | 5 |    | 7 | 8 | 1  | 10 | 11 |    |     |     | 15 |

The contents of the register specified by the R1 field are added to the contents of the register specified by the R2 field. The result is placed in the register specified by the R2 field. The contents of the register specified by the R1 field remain unchanged if R1 and R2 do not specify the same register.

### Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Protect Check. Instruction fetch.

### **Register/Storage Format**

AW reg,addr4 addr4,reg

| Opera<br>1 1                                    | tion<br>0 | 0 Co | ode<br>1 |   | R |   | RI | 3 | AM | 1  | X  | Fu<br>1 | nct<br>1 | ion<br>0 |
|-------------------------------------------------|-----------|------|----------|---|---|---|----|---|----|----|----|---------|----------|----------|
| 0                                               |           |      | 4        | 5 |   | 7 | 8  | 9 | 10 | 11 | 12 | 13      |          | 15       |
| 1 = result to storage<br>0 = result to register |           |      |          |   |   |   |    |   |    |    |    |         |          |          |

| Address/       | Displacement                  |
|----------------|-------------------------------|
| Displacement 1 | Displacement 2                |
| 16             | $\frac{1}{24} = \frac{1}{31}$ |

An add operation is performed between the register specified by the R field and the location specified by the effective address in main storage. (See *Effective Address Generation* in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged.

#### Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

## Storage to Register Long Format

AW longaddr,reg



The contents of the main storage location specified by an effective address are added to the contents of the register specified by the R1 field. The result is placed in the register specified by the R1 field.

The effective main storage address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field. If the R2 field equals zero, no register contributes to the address generation.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0 (direct address). The result from step 1 is the effective address.

Bit 11=1 (indirect address). The result from step 1 is the address of the main storage location that contains the effective address.

## Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## Storage/Storage Format

AW addr5,addr4



The address arguments generate the effective addresses of two operands in main storage. (See *Effective Address Generation* in Chapter 2.) Word operand 1 is added to word operand 2. The result replaces operand 2. Operand 1 is unchanged.

## Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

t,

## Add Word With Carry (AWCY)

AWCY reg,reg

| Op  | Operation code |   |   |   |   | R1 | _ |   | R2 |    | Fu | ncti | ion | ٦  |
|-----|----------------|---|---|---|---|----|---|---|----|----|----|------|-----|----|
| • 0 | 1              | 1 | 1 | 0 |   |    |   |   |    | 0  | 1  | 0    | 0   | 1  |
| 0   |                |   |   | 4 | 5 | 7  | 7 | 8 | 10 | 11 |    |      |     | 15 |

This instruction adds three terms together:

(R1) the contents of the register specified by the R1 field.
(R2) the contents of the register specified by the R2 field.
C the value of the carry indicator at entry.

The contents of the register specified by the R1 field are unchanged if R1 and R2 do not specify the same register. The final result replaces the contents of the register specified by the R2 field.

**Programming** Note. This instruction can be used when adding multiple word operands. See *Indicators – Multiple* Word Operands in Chapter 2.

## Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even. Unchanged.

**Zero.** If on at entry, set to reflect the result. If off at entry, remains off.

Negative. Changed to reflect the result.

## **Program Check Conditions**

Protect Check. Instruction fetch.

## Add Word Immediate (AWI)

# Register Immediate Long FormatAWIword,reg[,reg]

| Op | Operation code |   |   |   |   | R1 |    |     | R2 |    |         | Fu | nct | ion |    |
|----|----------------|---|---|---|---|----|----|-----|----|----|---------|----|-----|-----|----|
| 0  | 1              | 1 | 1 | 1 |   |    |    |     |    |    | 0       | 0  | 0   | 0   | 1  |
| 0  |                |   |   | 4 | 5 |    | 7  | 8   |    | 10 | 11      |    |     |     | 15 |
|    |                |   |   |   |   | Im | me | dia | te |    | <u></u> |    |     |     |    |
| 16 |                |   |   |   |   |    |    |     |    |    |         |    |     |     | 21 |

The immediate field is added to the contents of the register specified by the R1 field. The result is placed in the register specified by the R2 field. The contents of the register specified by the R1 field are unchanged if R1 and R2 do not specify the same register.

## Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word.

Protect Check. Instruction fetch.

# Storage Immediate Format

## AWI word,addr4

Format without appended word for effective addressing (AM = 00 or 01)

| O | Operation code |   |   |   |   |    |     | I   | RB | AM    | ŀ  | un | ctio | n  |
|---|----------------|---|---|---|---|----|-----|-----|----|-------|----|----|------|----|
| 0 | 1              | 0 | 0 | 0 | 0 | 0  | 0   |     |    |       | 1  | 0  | 0    | 1  |
| 0 |                |   |   | 4 | 5 |    | 7   | 8   | 9  | 10 11 | 12 | ?  |      | 15 |
|   |                |   |   |   |   |    |     |     |    |       |    |    |      |    |
|   |                |   |   |   |   | In | ıme | dia | te |       |    |    |      |    |
|   |                |   |   |   |   |    |     |     |    |       |    |    |      |    |
|   |                |   |   |   |   |    |     |     |    |       |    |    |      |    |

Format with appended word for effective addressing (AM = 10 or 11)

| Op | oera                          | tio | n co | de |   |    |     | F   | RB | AM    | ŀ  | Tune | ctio | n  |  |
|----|-------------------------------|-----|------|----|---|----|-----|-----|----|-------|----|------|------|----|--|
| 0  | 1                             | 0   | 0    | 0  | 0 | 0  | 0   |     |    |       | 1  | 0    | 0    | 1  |  |
| 0  |                               |     |      | 4  | 5 |    | 7   | 8   | 9  | 10 11 | 12 | ?    |      | 15 |  |
|    |                               |     |      |    |   |    |     |     |    |       |    |      |      |    |  |
|    | Address/Displacement          |     |      |    |   |    |     |     |    |       |    |      |      |    |  |
| Γ- | Displacement 1 Displacement 2 |     |      |    |   |    |     |     |    |       |    |      |      |    |  |
| 16 |                               |     |      |    |   |    | 23  | 24  | !  |       |    |      |      | 31 |  |
|    |                               |     |      |    |   |    |     |     |    |       |    |      |      |    |  |
|    |                               |     |      |    |   | Im | ime | dia | te |       |    |      |      |    |  |
|    |                               |     |      |    |   |    |     |     |    |       |    |      |      |    |  |
| 32 | 2                             |     |      |    |   |    |     |     |    |       |    |      |      | 47 |  |

The immediate field is added to the contents of the location specified by the effective address. (See *Effective Address Generation* in Chapter 2.) The result replaces the contents of the storage location specified by the effective address.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

The immediate operand is unchanged.

### Indicators

**Carry**. Turned on if a carry is detected out of the highorder bit position of the word. If no carry is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the sum cannot be represented in one word; i.e., if the sum is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

۲

If an overflow occurs, the result contains the correct low-order 16 bits of the sum; the carry indicator contains the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

B

## Branch Unconditional (B)

B longaddr Extended Assembler Mnemonic BX vcon Branch External



An effective branch address is generated and loaded into the instruction address register, becoming the next instruction to be fetched.

31

The effective branch address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form a main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0. The result from step 1 is a direct address and is loaded into the instruction address register. Bit 11=1. The result from step 1 is an indirect address. The contents of the main storage location specified by the result are loaded into the instruction address register.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

### Indicators

16

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or effective branch address.

Protect Check. Instruction fetch.

# BAL BALS

## Branch and Link (BAL)

BAL longaddr,reg

Extended Assembler Mnemonic

BALX vcon, reg Branch and Link External



The updated value of the instruction address register (the address of the next sequential instruction) is stored into the register specified by the R1 field. An effective branch address is then generated and loaded into the instruction address register, becoming the next instruction to be fetched.

The effective branch address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form a main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0. The result from step 1 is a direct address and is loaded into the instruction address register. Bit 11=1. The result from step 1 is an indirect address. The contents of the main storage location specified by the result are loaded into the instruction address register.

*Programming Note.* If R1 and R2 specify the same register the initial contents are used in effective address computation and subsequently overwritten by the return data.

## Indicators

No indicators are changed.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or effective branch address. No branch is taken, but the contents of the register specified by the R1 field are still changed. The instruction is terminated.

Protect Check. Instruction fetch.

**Specification Check.** Even byte boundary violation (indirect address or branch address). The instruction is terminated. No branch is taken but the contents of the R1 register are changed.

## Branch and Link Short (BALS)

BALS (reg.jdisp)\* (reg)\* addr\*

| 0p | per | a | tior | 1 00 | ode | Γ | R |   | Γ | Word displacement |    |
|----|-----|---|------|------|-----|---|---|---|---|-------------------|----|
| 1  | 1   |   | 1    | 1    | 1   |   |   |   |   |                   |    |
| 0  |     |   |      |      | 4   | 5 |   | 7 | 8 |                   | 15 |

The updated contents of the instruction address register (the location of the next sequential instruction) are stored in register 7.

Bit 8 of the word displacement field is propagated left by 7 bit positions and a zero is appended at the low order end, resulting in a 16-bit word. (Word displacement is converted to a byte displacement.) This value is added to the contents of the register specified by R to form an effective address. The contents of the storage location specified by the effective address are stored into the instruction address register, and become the address of the next instruction to be fetched.

**Programming Note.** If the implied register (R7) is used as a base register, the initial contents of R7 are used in effective address computation and subsequently overwritten by the return data.

## Indicators

No indicators are changed.

## **Program Check Conditions**

Invalid Storage Address. Effective address. The instruction is terminated. Branching does not occur but storing of the updated instruction address into R7 does occur.

## Protect Check. Instruction fetch.

Specification Check. Even byte boundary violation (effective address). The instruction is terminated. Branching does not occur but storing of the updated instruction address into R7 does occur.

## Branch on Condition (BC)

| Mnemonic<br>BC | <i>Operand</i><br>syntax<br>cond,longaddr | <i>Instruction name</i><br>Branch on Condition      | Condition<br>field<br>bits (see A)<br>Any value<br>listed below |
|----------------|-------------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------|
| Extended       | Operand                                   |                                                     | Condition<br>field                                              |
| Mnemonic       | syntax                                    | Instruction name                                    | bits (see A)                                                    |
| BE             | longaddr                                  | Branch on Equal                                     | 000                                                             |
| BOFF           | longaddr                                  | Branch if Off                                       | 000                                                             |
| BZ             | longaddr                                  | Branch on Zero                                      | 000                                                             |
| BP             | longaddr                                  | Branch on Positive                                  | 001                                                             |
| BMIX           | longaddr                                  | Branch if Mixed                                     | 001                                                             |
| BN             | longaddr                                  | Branch if Negative                                  | 010                                                             |
| BON            | longaddr                                  | Branch if On                                        | 010                                                             |
| BEV            | longaddr                                  | Branch on Even                                      | 011                                                             |
| BLT            | longaddr                                  | Branch on Arith-<br>metically Less Than             | 100                                                             |
| BLE            | longaddr                                  | Branch on Arith-<br>metically Less<br>Than or Equal | 101                                                             |
| BLLE           | longaddr                                  | Branch on Logically<br>Less Than or Equal           | 110                                                             |
| BCY            | longaddr                                  | Branch on Carry                                     | 111                                                             |
| BLLT           | longaddr                                  | Branch on Logically<br>Less Than                    | 111                                                             |





This instruction tests the condition of the various indicators (LSR bits 0-4). If the condition tested is met, the effective branch address is loaded into the instruction address register and becomes the next address to be fetched.

If the condition tested is not met, the next sequential instruction is fetched.

The effective branch address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form a main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0. The result from step 1 is a direct address and is loaded into the instruction address register. Bit 11=1. The result from step 1 is an indirect address. The contents of the main storage location specified by the result are loaded into the instruction address register.

### Indicators

All indicators are unchanged.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or effective address.

Protect Check. Instruction fetch.

# BCC

## **Branch on Condition Code (BCC)**

BCC cond,longaddr

Extended mnemonic

BNER longaddr Branch on Not Error (CC field = 111)



The value of the CC field is compared to the even, carry, and overflow indicators. These indicators hold the I/O condition code: (1) following an I/O instruction or (2) following an I/O interrupt.

| CC bit | Indicator |
|--------|-----------|
| 5      | Even      |
| 6      | Carry     |
| 7      | Overflow  |

If the conditions match, an effective branch address is generated and loaded into the instruction address register, becoming the next instruction to be fetched.

If the conditions do not match the next sequential instruction is fetched.

The effective branch address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form a main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0. The result from step 1 is a direct address and is loaded into the instruction address register. Bit 11=1. The result from step 1 is an indirect address. The contents of the main storage location specified by the result are loaded into the instruction address register.

### Indicators

No indicators are changed.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or effective address.

Protect Check. Instruction fetch.

**Specification Check**. Even byte boundary violation (indirect address or branch address).

## I/O Condition Codes

The I/O condition codes are summarized in the following tables. Refer to Chapter 4 for a detailed description of each condition code value. Also refer to the specific I/O device descriptions because some devices do not report all condition codes.

## Condition Codes Reported After I/O Instruction.

| Condi-<br>tion<br>code | Indicators<br>Even | Carry | Overflow | Meaning               |
|------------------------|--------------------|-------|----------|-----------------------|
| 0                      | 0                  | 0     | 0        | Device not attached   |
| 1                      | 0                  | 0     | 1        | Busy                  |
| 2                      | 0                  | 1     | 0        | Busy after reset      |
| 3                      | 0                  | 1     | 1        | Command reject        |
| 4                      | 1                  | 0     | 0        | Intervention required |
| 5                      | 1                  | 0     | 1        | Interface data check  |
| 6                      | 1                  | 1     | 0        | Controller busy       |
| 7                      | 1                  | 1     | 1        | Satisfactory          |

## Condition Codes Reported During an I/O Interrupt.

| Condi-<br>tion<br>code | Indicators<br>Even | Carry | Overflow | Meaning                         |
|------------------------|--------------------|-------|----------|---------------------------------|
| 0                      | 0                  | 0     | 0        | Controller end                  |
| 1                      | 0                  | 0     | 1        | PCI (program control interrupt) |
| 2                      | 0                  | 1     | 0        | Exception                       |
| 3                      | 0                  | 1     | 1        | Device end                      |
| 4                      | 1                  | 0     | 0        | Attention                       |
| 5                      | 1                  | 0     | 1        | Attention and PCI               |
| 6                      | 1                  | 1 ·   | 0        | Attention and exception         |
| 7                      | 1                  | 1     | 1        | Attention and device end        |

## Branch on Not Condition (BNC)

| Mnemonic<br>BNC | <i>Operand</i><br>syntax<br>cond,longaddr | <i>Instruction name</i><br>Branch on Not               | Condition<br>field<br>bits (see A)<br>Any value |
|-----------------|-------------------------------------------|--------------------------------------------------------|-------------------------------------------------|
|                 |                                           | Condition                                              | listed below                                    |
| Extended        | Operand                                   |                                                        | Condition<br>field                              |
| Mnemonic        | syntax                                    | Instruction name                                       | bits (see A)                                    |
| BNE             | longaddr                                  | Branch on Not Equal                                    | 000                                             |
| BNZ             | longaddr                                  | Branch on Not Zero                                     | 000                                             |
| BNOFF           | longaddr                                  | Branch if Not OFF                                      | 000                                             |
| BNP             | longaddr                                  | Branch on Not Positive                                 | 001                                             |
| BNMIX           | longaddr                                  | Branch on Not Mixed                                    | 001                                             |
| BNN             | longaddr                                  | Branch on Not<br>Negative                              | 010                                             |
| BNON            | longaddr                                  | Branch if Not On                                       | 010                                             |
| BNEV            | longaddr                                  | Branch on Not Even                                     | 011                                             |
| BGE             | longaddr                                  | Branch on Arith-<br>metically Greater<br>Than or Equal | 100                                             |
| BGT             | longaddr                                  | Branch on Arith-<br>metically Greater<br>Than          | 101                                             |
| BLGT            | longaddr                                  | Branch on Logically<br>Greater Than                    | 110                                             |
| BLGE            | longaddr                                  | Branch on Logically<br>Greater Than or Equal           | 111                                             |
| BNCY            | longaddr                                  | Branch on No Carry                                     | 111                                             |



This instruction tests the various indicators (LSR bits 0-4). If the condition tested is met, the effective branch address is loaded into the instruction address register and becomes the next address to be fetched.

If the condition tested is not met, the next sequential instruction is fetched.

The effective branch address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form a main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0. The result from step 1 is a direct address and is loaded into the instruction address register. Bit 11=1. The result from step 1 is an indirect address. The contents of the main storage location specified by the result are loaded into the instruction address register.

## Indicators

All indicators are unchanged.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or effective address.

Protect Check. Instruction fetch.

# BNCC

## Branch on Not Condition Code (BNCC)

BNCC cond,longaddr

Extended mnemonic

BER longaddr Branch on Error (CC Field=111)



The value of the CC field is compared to the even, carry,

and overflow indicators. These indicators hold the I/O conditions code: (1) following and I/O instruction or (2) following an I/O interrupt.

| Indicator |
|-----------|
| Even      |
| Carry     |
| Overflow  |
|           |

If the conditions do not match, an effective branch address is generated and loaded into the instruction address register, becoming the next instruction to be fetched.

If the conditions match, the next sequential instruction is fetched.

The effective branch address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0. The result from step 1 is a direct address and is loaded into the instruction address register. Bit 11=1. The result from step 1 is an indirect address. The contents of the main storage location specified by the result are loaded into the instruction address register.

## Indicators

No indicators are changed.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or effective address.

Protect Check. Instruction fetch.

**Specification Check**. Even byte boundary violation (indirect address or branch address).

## I/O Condition Codes

The I/O condition codes are summarized in the following tables. Refer to Chapter 4 for a detailed description of each condition code value. Also refer to the specific I/O device descriptions because some devices do not report all condition codes.

## Condition Codes Reported After I/O Instruction.

Condition Indicators code Carry Overflow Meaning Even Device not attached 0 0 0 0 1 0 0 1 Busy 2 0 0 Busy after reset 1 3 0 1 1 Command reject 4 1 0 0 Intervention required 5 0 1 Interface data check 1 0 1 Controller busy 6 1 1 1 Satisfactory 7 1

## Condition Codes Reported During an I/O Interrupt.

| Condi<br>tion<br>Code | Indicators<br>Even | Carry | Overflow | Meaning                            |
|-----------------------|--------------------|-------|----------|------------------------------------|
| 0                     | 0                  | 0     | 0        | Controller end                     |
| 1                     | 0                  | 0     | 1        | PCI (program controlled interrupt) |
| 2                     | 0                  | 1     | 0        | Exception                          |
| 3                     | 0                  | 1     | 1        | Device end                         |
| 4                     | 1                  | 0     | 0        | Attention                          |
| 5                     | 1                  | 0     | 1        | Attention and PCI                  |
| 6                     | 1                  | 1     | 0        | Attention and Exception            |
| 7                     | 1                  | 1     | 1        | Attention and device end           |

8-14

Branch on Not Overflow (BNOV)



#### **BNOV** longaddr



The overflow indicator is tested. If the indicator is off. the effective branch address is loaded into the instruction address register and becomes the next address to be fetched.

If the overflow indicator is on, the next sequential instruction is fetched.

The effective branch address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form a main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0. The result from step 1 is a direct address and is loaded into the instruction address register. Bit 11=1. The result from step 1 is an indirect address. The contents of the main storage location specified by the result are loaded into the instruction address register.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

## Indicators

All indicators are unchanged.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or effective address.

**Protect Check**. Instruction fetch.

Specification Check. Even byte boundary violation (indirect address or branch address).

## Branch on Overflow (BOV)

BOV longaddr





The overflow indicator is tested. If the indicator is on, the effective branch address is loaded into the instruction address register and becomes the next address to be fetched.

If the overflow indicator is off, the next sequential instruction is fetched.

The effective branch address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form a main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0. The result from step 1 is a direct address and is loaded into the instruction address register. Bit 11=1. The result from step 1 is an indirect address. The contents of the main storage location specified by the result are loaded into the instruction address register.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

## Indicators

All indicators are unchanged.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or effective address.

Protect Check. Instruction fetch.

## Branch Indexed Short (BXS)

BXS (reg<sup>1-7</sup>,jdisp) (reg<sup>1-7</sup>) addr

| 0 | pera | itio | n co | ode | R   |   | Word displacement |    |
|---|------|------|------|-----|-----|---|-------------------|----|
| 0 | 1    | 0    | 1    | 0   |     |   |                   |    |
| 0 |      |      |      | 4   | 5   | 7 | 8                 | 15 |
|   |      |      |      |     | 1 - | 7 |                   |    |

Bit 8 of the word displacement field is propagated left seven bit positions and a zero is appended at the low order end, resulting in a 16-bit word. (Word displacement is converted to a byte displacement.) This value is added to the contents of the register specified by the R field, and the result is stored into the instruction address register, becoming the address of the next instruction to be fetched.

*Note.* The hardware format of this instruction is identical to the format used for the Jump Unconditional (J) and No Operation (NOP) instructions.

## Indicators

No indicators are changed.

**Program Check Conditions** 

Invalid Storage Address. Effective address.

Protect Check. Instruction fetch.

Specification Check. Even byte boundary violation (branch address).

## Compare Byte (CB)

Register/Storage FormatCBaddr4,reg



The contents of the location specified by the effective address in main storage are subtracted from the least significant byte of the register specified by the R field. (*Effective Address Generation* is explained in Chapter 2.)

Neither operand is changed.

Bit 12 of the instruction is not used and must be set to zero to avoid future code obsolescence.

## Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the byte. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one byte; i.e., if the difference is less than  $-2^7$  or greater than  $+2^7-1$ .

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check**. Even byte boundary violation (indirect address).

## Storage/Storage Format

CB addr5,addr4



The address arguments generate the effective addresses of the two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) Byte operand 1 is subtracted from byte operand 2. Neither operand is changed.

## Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the byte. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one byte; i.e., if the difference is less than  $-2^7$  or greater than  $+2^7-1$ .

Even, Negative, and Zero. Changed to reflect the result.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch or operand access. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Specification Check.** Even byte boundary violation (indirect address).

## Compare Byte Immediate (CBI)

CBI byte,reg

| 0 | Operation code |   |   |   | I | 2 | Immediate |    |
|---|----------------|---|---|---|---|---|-----------|----|
| 1 | 1              | 1 | 1 | 0 |   |   |           |    |
| 0 |                |   |   | 4 | 5 | 7 | 8         | 15 |

The immediate field is extended to 16 bits by sign propagation to the eight high-order bit positions. The result is subtracted from the contents of the register specified by the R field. Neither operand is changed.

## Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less the  $-2^{15}$  or greater than  $+2^{15}-1$ .

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Protect Check. Instruction fetch.

## Compare Doubleword (CD)

# Register/Storage Format

CD addr4,reg



The contents of the doubleword in main storage specified by the effective address are subtracted from the contents of the register pair specified by the R field and R+1.

(*Effective Address Generation* is explained in Chapter 2.) Neither operand is changed.

Bit 12 of the instruction is not used and must be set to zero to avoid future code obsolescence.

If the R field equals 7, register 7 and register 0 are used.

## Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the doubleword. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in the doubleword; i.e., if the difference is less than  $-2^{31}$  or greater than  $+2^{31}-1$ .

Even, Negative, and Zero. Changed to reflect the result.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

## Storage/Storage Format

CD addr5,addr4

| <i>Operation code</i><br>1 0 0 1 0                                                   | RB1 | RB2     | AM1   | AM2    | <i>Fun</i><br>1 1 |  |  |  |
|--------------------------------------------------------------------------------------|-----|---------|-------|--------|-------------------|--|--|--|
| 0 4                                                                                  | 5 7 | 89      | 10 11 | 12 13  | 14 15             |  |  |  |
| $\frac{Address/Displacement}{16} = \frac{Address/Displacement}{2324} = \frac{1}{31}$ |     |         |       |        |                   |  |  |  |
| Displacen                                                                            |     | Displac |       | icemen | $\frac{1}{t^2}$   |  |  |  |

The address arguments generate the effective addresses of two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) Doubleword operand 1 is subtracted from doubleword operand 2. Neither operand is changed.

## Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the operand. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one doubleword; i.e., if the difference is less than  $-2^{31}$  or greater than  $+2^{31}-1$ .

Even, Negative, and Zero. Changed to reflect the result.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch or operand access. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

# CFED CFEN

## Compare Byte Field Equal and Decrement (CFED)

Compare Byte Field Equal and Increment (CFEN)

CFED (reg),(reg) CFEN (reg),(reg)



This instruction compares two fields in main storage on a byte for byte basis. Register 7 contains the number of bytes to be compared. This number is decremented after each byte is compared. The register specified by R1 contains the address of operand 1. The register specified by R2 contains the address of operand 2. Operand 1 is subtracted from operand 2, but neither operand is changed. After each byte is compared, the addresses in R1 and R2 are incremented or decremented (determined by bit 13 of the instruction). The operation terminates when either:

- 1. An equal condition is detected, or
- 2. The number of bytes specified in register 7 has been compared.

When an equality occurs, the addresses in the registers point to the next operands to be compared, but the count in R7 is not updated.

Bit 11 of the instruction is not used and must be set to zero to avoid future code obsolescence.

See Scan Byte Field Equal and Decrement (SFED) and Scan Byte Field Equal and Increment (SFEN) for other versions of this machine instruction.

## Notes.

- 1. If the specified count in R7 is zero, the instruction performs no operation (No-op).
- 2. Variable field length instructions can be interrupted. When this occurs and the interrupted level resumes operation, the processor treats the uncompleted instruction as a new instruction with the remaining byte count specified in register 7.

## Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the byte. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one byte; i.e., if the difference is less than  $-2^7$  or greater than  $+2^7-1$ .

Even, Negative, and Zero. Changed to reflect the result.

## **Program Check Conditions**

Invalid Storage Address. Operand. The instruction is terminated.

**Protect Check**. Instruction fetch or operand access. The instruction is terminated.

Compare Byte Field Not Equal and Decrement (CFNED)

# Compare Byte Field Not Equal and Increment (CFNEN)

CFNED (reg),(reg) CFNEN (reg),(reg)



This instruction compares two fields in main storage on a byte for byte basis. Register 7 contains the number of bytes to be compared. This number is decremented after each byte is compared. The register specified by R1 contains the address of operand 1. The register specified by R2 contains the address of operand 2. Operand 1 is subtracted from operand 2, but neither operand is changed. After each byte is compared, the addresses in R1 and R2 are incremented or decremented (determined by bit 13 of the instruction). The operation terminates when either:

- 1. An unequal condition is detected, or
- 2. The number of bytes specified in register 7 has been compared.

When an inequality occurs, the addresses in the registers point to the next operands to be compared, but the count in R7 is not updated.

Bit 11 is not used and must be set to zero to avoid future code obsolescence.

See Scan Byte Field Not Equal and Decrement (SFNED) and Scan Byte Field Not Equal and Increment (SFNEN) for other versions of this machine instruction.

### Notes.

- 1. If the specified count in R7 is zero, the instruction performs no operation (no-op).
- 2. Variable field length instructions can be interrupted. When this occurs and the interrupted level resumes operation, the processor treats the uncompleted instruction as a new instruction with the remaining byte count specified in register 7.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the byte. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one byte; i.e., if the difference is less than  $-2^7$  or greater than  $+2^7-1$ .

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Invalid Storage Address. Operand. The instruction is terminated.

**Protect Check.** Instruction fetch or operand access. The instruction is terminated.

## Complement Register (CMR)

CMR reg[,reg]

| 0 | pera | itio | n co | ode | R | 1 | R2 |    | Function |   |   | n |    |
|---|------|------|------|-----|---|---|----|----|----------|---|---|---|----|
| 0 | 1    | 1    | 1    | 0   |   |   |    |    | 0        | 0 | 1 | 1 | 0  |
| 0 |      |      |      | 4   | 5 | 7 | 8  | 10 | 11       |   |   |   | 15 |

The contents of the register specified by the R1 field are converted to the two's complement. The result is placed in the register specified by the R2 field. The contents of the register specified by the R1 field are unchanged if R1 and R2 do not specify the same register.

### Indicators

**Carry**. Reset. Then turned on if the number to be complemented is zero.

**Overflow**. Reset. Then turned on if the number to be complemented is the maximum negative number representable.

Even, Negative, and Zero. Unchanged.

### **Program Check Conditions**

Protect Check. Instruction fetch.

## Copy Address Key Register (CPAKR)

## System Register/Storage Format

| Mnemonic<br>CPAKR    | <i>Syntax</i><br>addr4 | <i>Instruction name</i><br>Copy Address Key<br>Register | K field<br>011 |  |
|----------------------|------------------------|---------------------------------------------------------|----------------|--|
| Extended<br>Mnemonic | Syntax                 | Instruction name                                        | K field        |  |
| CPISK                | addr4                  | Copy Instruction Space<br>Key                           | 000            |  |
| CPOOK<br>CPOTK       | addr4<br>addr4         | Copy Operand 1 Key<br>Copy Operand 2 Key                | 010<br>001     |  |
|                      |                        |                                                         |                |  |

| 0 | pera | itio | n co | ode | Γ | ĸ |   | R | B | AM    | F  | unc | tio | n  |
|---|------|------|------|-----|---|---|---|---|---|-------|----|-----|-----|----|
| 0 | 1    | 0    | 1    | 1   |   |   |   |   |   |       | 1  | 0   | 1   | 0  |
| 0 |      |      |      | 4   | 5 |   | 7 | 8 | 9 | 10 11 | 12 | ?   |     | 15 |

| Address/       | Displacement   |
|----------------|----------------|
| Displacement 1 | Displacement 2 |
| 16 2           | 3 24 31        |

The contents of the address key register (AKR) field, specified by the K field, are stored into the word location specified by the effective address. The contents of the AKR are unchanged. (*Effective Address Generation* is explained in Chapter 2.) The K field can specify: (1) a field within the AKR, or (2) the entire AKR.

| K field | Address key register<br>field name | Bits  |
|---------|------------------------------------|-------|
| 000     | Instruction space key              | 13-15 |
| 001     | Operand 2 key                      | 9-11  |
| 010     | Operand 1 key                      | 5-7   |
| 011     | Address key register               | 0-15  |
| 100     | Unused                             |       |
| 101     | Unused                             |       |
| 110     | Unused                             |       |
| 111     | Unused                             |       |
|         |                                    |       |

Unused K-field values should not be used to avoid future program obsolescence.

If the K field specifies a specific field within the AKR, the specified field is stored in bits 13-15 of the word location in main storage. Bits 0-12 of the word in main storage are set to zero. If the K field specifies the entire AKR, the entire AKR is stored in the word location in main storage.

## Indicators

All indicators are unchanged.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

## System Register/Register Format

| Mnemonic | Syntax | Instruction name              | K field |
|----------|--------|-------------------------------|---------|
| CPAKR    | reg    | Copy Address Key<br>Register  | 011     |
| Extended |        |                               |         |
| Mnemonic | Syntax | Instruction name              | K field |
| CPISK    | reg    | Copy Instruction Space<br>Key | 000     |
| CPOOK    | reg    | Copy Operand 2 Key            | 001     |
| CPOTK    | reg    | Copy Operand 1 Key            | 010     |

| 01 | pera | itio | n co | ode | K |   | R |    | F    | unc | tio | n |    |   |
|----|------|------|------|-----|---|---|---|----|------|-----|-----|---|----|---|
| 0  | 1    | 1    | 1    | 1   |   |   |   |    | 1    | 1   | 0   | 1 | 0  |   |
| 0  |      |      |      | 4   | 5 | 7 | 8 | 10 | 0 11 | l   |     |   | 15 | - |

The contents of the address key register (AKR) field, specified by the K field, are loaded into the register specified by the R field. The contents of the AKR are unchanged. The K field can specify: (1) a field within the AKR, or (2) the entire AKR.

| Address key register  |                                                                                                                             |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------|
| field name            | Bits                                                                                                                        |
| Instruction space key | 13-15                                                                                                                       |
| Operand 2 key         | 9-11                                                                                                                        |
| Operand 1 key         | 5-7                                                                                                                         |
| Address key register  | 0-15                                                                                                                        |
| Unused                |                                                                                                                             |
| Unused                |                                                                                                                             |
| Unused                |                                                                                                                             |
| Unused                |                                                                                                                             |
|                       | field name<br>Instruction space key<br>Operand 2 key<br>Operand 1 key<br>Address key register<br>Unused<br>Unused<br>Unused |

Unused K-field values should not be used to avoid future program obsolescence.

If the K field specifies a specific field within the AKR, the specified field is loaded into bits 13-15 of the register in the R field. Bits 0-12 of the register are set to zero. If the K field specifies the entire AKR, the entire AKR is loaded into the register.

## Indicators

All indicators are unchanged.

## **Program Check Conditions**

Privilege Violate. Privileged instruction.

# CPCL<sup>®</sup> CPCON

## Copy Current Level (CPCL) CPCL reg

| i | 0 | pera | ıtið | n co | ode |   |   |   | Γ | R2 | Τ  | F  | unc | tion | n |    |
|---|---|------|------|------|-----|---|---|---|---|----|----|----|-----|------|---|----|
| Ì | 0 | 1    | 1    | 1    | 1   | 0 | 0 | 0 |   |    |    | 1  | 1   | 0    | 0 | 1  |
|   | 0 |      |      |      | 4   | 5 |   | 7 | 8 |    | 10 | 11 |     |      |   | 15 |

The register specified by the R2 field is loaded as follows:

- Bits 0 through 13 are set to zero.
- Bits 14 and 15 are set to the binary-encoded current level. For example if the current level is three, bits 14 and 15 are set to 11.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

## Indicators

All indicators are unchanged.

## **Program Check Conditions**

Privilege Violate. Privileged instruction.

## Copy Console Data Buffer (CPCON) CPCON reg

| 0 | pera | itio | n co | ode | Γ |   |   | R2 |    | F  | unc | tion | n |    |
|---|------|------|------|-----|---|---|---|----|----|----|-----|------|---|----|
| 0 | 1    | 1    | 1    | 1   | 0 | 0 | 0 |    |    | 1  | 1   | 0    | 0 | 0  |
| 0 |      |      |      | 4   | 5 |   | 7 | 8  | 10 | 11 | !   |      |   | 15 |

The contents of the console data buffer are loaded into the register specified by the R2 field. The contents of the buffer are unchanged.

If the programmer console is not installed, the data loaded into the specified register is undefined.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

## Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Privilege Violate. Privileged instruction.

Copy Interrupt Mask Register (CPIMR) **CPIMR** addr4

| 0 | pera | tio | n co | ode |   |   |   | R | B | AM    | Fi | inc | tio | n  |
|---|------|-----|------|-----|---|---|---|---|---|-------|----|-----|-----|----|
| 0 | 1    | 0   | 1    | 1   | 0 | 0 | 0 |   | _ |       | 1  | 0   | 0   | 0  |
| 0 |      |     |      | 4   | 5 |   | 7 | 8 | 9 | 10 11 | 12 |     |     | 15 |
|   |      |     |      |     |   |   |   |   |   |       |    |     |     |    |

|    | Address/I      | Displacement   | ٦ |
|----|----------------|----------------|---|
|    | Displacement 1 | Displacement 2 | 1 |
| 16 | 23             | 24 31          | ! |

The contents of the interrupt mask register are stored at the word location in main storage specified by the effective address. (See Effective Address Generation in Chapter 2.) The interrupt mask register is unchanged.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

The mask is represented in a bit significant manner as follows:

Mask bit Interrupt level 0 0 1 1 2 2

3 Bits 4-15 are set to zero.

A mask bit set to "1" indicates that the level is enabled. A mask bit set to "0" indicates that the level is disabled.

## Indicators

3

All indicators are unchanged.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

Specification Check. Even byte boundary violation (indirect address or operand address).

#### Copy In-process Flags (CPIPF) **CPIPF** addr4

| 0p   | bera | itio | n co | ode  |    |      |             | R    | В    | AM              | $F_{1}$ | unc | tior | 1  |
|------|------|------|------|------|----|------|-------------|------|------|-----------------|---------|-----|------|----|
| 0    | 1    | 0    | 1    | 1    | 0  | 0    | 0           |      |      | }               | 1       | 1   | 0    | 1  |
| 0    |      |      |      | 4    | 5  |      | 7           | 8    | 9    | 10 11           | 12      |     |      | 15 |
|      |      |      |      |      |    |      |             |      |      |                 |         |     |      |    |
|      |      |      |      |      |    |      |             |      |      |                 |         |     |      |    |
|      |      |      |      |      |    |      |             |      |      |                 |         |     |      |    |
|      |      |      |      |      | Ad | Idre | <u>ss/1</u> | Dist | olac | ement           |         |     |      |    |
|      |      |      |      |      |    |      | ss/1        | Disp | olac | ement<br>Displa |         |     |      |    |
| <br> |      | Di   | spla | icer | Ad |      | ·           |      |      | ement<br>Displa | cen     | nen | t 2  |    |

The in-process flags for each level are stored at the word location in main storage specified by the effective address. (Effective Address Generation is explained in Chapter 2.)

The in-process flags are not changed. The flags are stored in a bit significant manner with bit zero representing level zero, and so on. Bits 4-15 are set to zero.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

This instruction permits the supervisor on the current level to inspect the in-process flags of the other levels. The in-process flag, bit 9 of the level status register, is on when a level is active or pending (previously interrupted by a higher level).

### Indicators

All indicators are unchanged.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

# CPLB CPLSR

## Copy Level Block (CPLB)

CPLB reg,addr4

| Oper | atio | n co | ode  |   | R |       | R        | B    | AM              | Fı  | ınc | tior | n  |
|------|------|------|------|---|---|-------|----------|------|-----------------|-----|-----|------|----|
| 0 1  | 0    | 1    | 1    |   |   |       |          |      |                 | 1   | 1_  | 1    | 0  |
| 0    |      |      | 4    | 5 |   | 7     | 8        | 9    | 10 11           | 12  |     |      | 15 |
|      |      |      |      |   |   |       |          |      |                 |     |     |      |    |
|      |      |      |      |   |   |       |          |      |                 |     |     |      |    |
|      |      |      |      | _ |   |       | <u>.</u> | 3.55 |                 |     |     |      |    |
|      |      |      |      | _ |   | ess/1 | Disp     | lac  | ement           |     |     |      |    |
|      |      | spla | acer | _ |   | ess/1 |          | lac  | ement<br>Displa | cen | nen | t 2  |    |

This instruction stores a level status block (LSB) into 11 words of main storage beginning with the location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The contents of the LSB and the R field register are not changed.

The register specified by the R field contains the binary encoded level of the LSB to be stored. The binary encoded level is placed in bits 14 and 15 of the register. Bits 0-13 are unused and must be zero.

Using this one instruction, the supervisor can copy the information contained in the hardware registers assigned to a program operating on any level. Most instructions are restricted to the registers associated with the current level. After executing a CPLB instruction, the supervisor can:

- 1. Use the information just stored; for example, the contents of the general registers or the protect key in the LSR.
- 2. Assign the level to another task by executing a Set Level Block (SELB) instruction that points to a different level status block.

In the second case, the supervisor can restart the preempted program at a later time by executing another SELB instruction that points to the previously stored level status block.

*Programming Note.* If the AM field equals 01, the contents of the register specified by the RB field are incremented by 2.

## Indicators

All indicators are unchanged.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or the 11 word main storage area. The instruction is terminated. If the main storage area being accessed is partially outside the installed storage size, a partial data transfer occurs.

Privilege Violate. Privileged instruction.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## Level Status Block Format

| EA           | IAR        |
|--------------|------------|
|              | AKR        |
|              | LSR        |
|              | Register 0 |
|              | Register 1 |
|              | Register 2 |
|              | Register 3 |
|              | Register 4 |
|              | Register 5 |
|              | Register 6 |
| EA+20        | Register 7 |
| (+14 hex)    |            |
| EA=effective | address    |

### Format of Register Specified by R in CPLB Instruction

|   |   |   |   |   |   |   |   |   |             |      |   |   |    | Le | evel |
|---|---|---|---|---|---|---|---|---|-------------|------|---|---|----|----|------|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0    | 0 | 0 | 0  |    |      |
| 0 |   |   |   |   |   |   |   |   |             |      |   |   | 13 | 14 | 15   |
|   |   |   |   |   |   |   |   |   | $L\epsilon$ | evel | 0 |   |    | 0  | 0    |
|   |   |   |   |   |   |   |   |   | Le          | evel | 1 |   |    | 0  | 1    |
|   |   |   |   |   |   |   |   |   | Le          | evel | 2 |   |    | 1  | 0    |
|   |   |   |   |   |   |   |   |   | Le          | evel | 3 |   |    | 1  | 1    |

## Copy Level Status Register (CPLSR) CPLSR reg

| 0 | pera | tio | n co | ode |   |   |   | R2 |    | F  | unc | tio | n |    |
|---|------|-----|------|-----|---|---|---|----|----|----|-----|-----|---|----|
| 0 | 1    | 1   | 1    | 0   | 0 | 0 | 0 |    |    | 0  | 1   | 1   | 1 | 0  |
| 0 |      |     |      | 4   | 5 |   | 7 | 8  | 10 | 11 |     |     |   | 15 |

The level status register is loaded into the register specified by the R2 field. The level status register is unchanged. Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

## Indicators

All indicators are unchanged.

## **Program Check Conditions**

Protect Check. Instruction fetch.

Copy Processor Status and Reset (CPPSR) CPPSR addr4



The contents of the processor status word (PSW) are stored at the word location in main storage specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

This instruction resets bits 0 through 12 of the PSW. Bits 13 through 15 are unchanged.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

## Indicators

All indicators are unchanged.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

### Program Status Word (PSW) Format

| PSW bit | Meaning                  |
|---------|--------------------------|
| 0       | Specification check      |
| 1       | Invalid storage address  |
| 2       | Privilege violate        |
| 3       | Protect check            |
| 4       | Invalid function         |
| 5       | Floating point exception |
| 6       | Stack exception          |
| 7       | Not used                 |
| 8       | Storage parity check     |
| 9       | Not used                 |
| 10      | CPU control check        |
| 11      | I/O check                |
| 12      | Sequence indicator       |
| 13      | Auto-IPL                 |
| 14      | Translator enabled       |
| 15      | Power/thermal warning    |

## Copy Storage Key (CPSK)

Refer to Chapter 5 for a description of the storage protection mechanism.

CPSK reg,addr4

| O | pera | itio | n co | ode |   | R |   | R | B | AM | 1  | F  | unc | tior | 1  |
|---|------|------|------|-----|---|---|---|---|---|----|----|----|-----|------|----|
| 0 | 1    | 0    | 1    | 1   |   |   |   |   |   |    |    | 1  | 1   | 0    | 0  |
| 0 |      |      |      | 4   | 5 |   | 7 | 8 | 9 | 10 | 11 | 12 | ?   |      | 15 |

|    | Address/L      | Displacement   | 1 |
|----|----------------|----------------|---|
|    | Displacement 1 | Displacement 2 | נ |
| 16 |                | 24 31          |   |

This instruction stores the contents of a storage key register at the byte location in main storage specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

The register specified by the R field contains the main storage block number for the storage key register to be stored. (A storage key register is associated with every 2048 bytes of storage.) The block number is binary encoded in bits 0-4 of the register. Bits 5-15 are not used and must be zero to avoid future code obsolescence.

The format of the register specified by the R field is:



The format of the byte at the storage location is:

|   |     |      |      | Key    |   | R |  |
|---|-----|------|------|--------|---|---|--|
| 0 | 0   | 0    | 0    |        |   |   |  |
| 0 |     |      | 3    | 4      | 6 | 7 |  |
|   |     |      |      |        |   |   |  |
|   | 1 : | = re | nd i | onlv — |   |   |  |

Bits 4-7, the storage key and read only bit, are the data from the storage key register for the selected main storage block. Bits 0-3 must be zero to avoid future code obsolescence.

The contents of the storage key register are unchanged.

### Indicators

No indicators are changed.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

**Specification Check**. Even byte boundary violation (indirect address).

# **CPSR**

## Copy Segmentation Register (CPSR)

This instruction is invalid if the Storage Address Relocation Translator Feature is not installed. Chapter 6 describes the relocation translator feature.

CPSR reg,addr4

|   | 0µ<br>0 | pera<br>1 | itio<br>0 | n co<br>1 | ode<br>1 |   | R    |      | R   | B         | AM    | F1 | unc<br>0 | tior<br>0 | 1        |
|---|---------|-----------|-----------|-----------|----------|---|------|------|-----|-----------|-------|----|----------|-----------|----------|
| ľ | 0       |           |           |           | 4        | 5 |      | 7    | 8   | 9         | 10 11 | 12 | ?        |           | 15       |
|   |         |           |           |           |          |   |      |      |     |           |       |    |          |           |          |
| ſ |         |           |           |           |          | A | ddre | ess/ | Dis | -<br>Dlac | emer  |    |          |           | <u>-</u> |

This instruction stores the contents of a segmentation register into the doubleword location in main storage specified by the effective address. *(Effective Address Generation* is explained in Chapter 2.)

The register specified by the R field contains the number of the segmentation register to be stored (0-255). This number is composed of three bits from the address key (values 0-7) and the five high-order bits of the logical storage address (values 0-31). Bits 8 through 15 of the register are not used and must be set to zero to avoid future code obsolescence.

The format of the register specified by the R field is:



The format of the segmentation register stored at the effective address is:



Bits 0 through 12 contain the high-order 13 bits of the physical address used by the translator to select a 2K block of storage.

Bit 13, if a one, signifies that the contents of the segmentation register is valid, and translation can be performed. If an attempt is made to use a segmentation register in which bit 13 is a zero, a program check interrupt occurs, with *invalid storage address* set in the PSW.

Bit 14, if a one, signifies that the block is read only. If an attempt is made to write into the block when bit 14 of the associated segmentation register is a one and while in problem state, a program check interrupt occurs, with *protect check* set in the PSW. The contents of main storage are not changed. When in supervisor state or on a cycle steal access, bit 14 is ignored.

Bits 15 through 31 are not used and must be set to zero to avoid future code obsolescence.

The contents of the segmentation register are unchanged.

### Indicators

No indicators are changed.

**Program Check Conditions** 

Invalid Function. Translator not installed.

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

## Compare Word (CW)

| and the second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second se |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 27 E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| i and a second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |

*Register/Register Format* CW reg,reg

| 0 | perc | itio | n co | ođe | R | 1 | R | 22 | F  | unc | tio | n |    |
|---|------|------|------|-----|---|---|---|----|----|-----|-----|---|----|
| 0 | 1    | 1    | 1    | 0   |   |   |   |    | 0  | 0   | 1   | 0 | 1  |
| 0 |      |      |      | 4   | 5 | 7 | 8 | 10 | 11 |     |     |   | 15 |

The contents of the register specified by the R1 field are subtracted from the contents of the register specified by the R2 field. The contents of both registers are unchanged.

## Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Protect Check. Instruction fetch.

## **Register/Storage Format**

CW addr4,reg

| 0 | p | era | tio | n co | ode |   | R |   | R | B | AM    | F  | unc | tion | n  |
|---|---|-----|-----|------|-----|---|---|---|---|---|-------|----|-----|------|----|
| 1 |   | 1   | 0   | 0    | 1   |   |   |   |   |   |       | 0  | 1   | 0    | 0  |
| 0 |   |     |     |      | 4   | 5 |   | 7 | 8 | 9 | 10 11 | 12 |     |      | 15 |

| Address/                      | Displacement                |
|-------------------------------|-----------------------------|
| Displacement 1                | Displacement 2              |
| $\frac{1}{16} = \frac{1}{23}$ | $\frac{1}{24} \frac{1}{31}$ |

The contents of the word in main storage specified by the effective address are subtracted from the contents of the register specified by the R field. (*Effective Address Generation* is explained in Chapter 2.)

Both operands are unchanged.

### Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

#### Storage/Storage Format

CW addr5,addr4

| 0 | pera | tio | n co | de | RB | 1 | RI | 32 | AM1   | AM2   | F  | un |
|---|------|-----|------|----|----|---|----|----|-------|-------|----|----|
| 1 | 0    | 0   | 0    | 1  |    |   |    |    |       |       | 1  | 1  |
| 0 |      |     |      | 4  | 5  | 7 | 8  | 9  | 10 11 | 12 13 | 14 | 15 |



|    |                | lisplacement   |
|----|----------------|----------------|
|    | Displacement 1 | Displacement 2 |
| 32 | 39             | $40^{$         |

The address arguments generate the effective addresses of two operands in main storage. (See *Effective Address Generation* in Chapter 2.) Word operand 1 is subtracted from word operand 2. Neither operand is changed.

### Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow**. Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch or operand access. The instruction is terminated. If AM1 equals 01, RB1 may be incremented.

## **Compare Word Immediate (CWI)**

Register Immediate Long FormatCWIword,reg



The immediate field is subtracted from the contents of the register specified by the R1 field. The contents of the register specified by the R1 field are unchanged.

Bits 8–10 are not used and must be set to zero to avoid future code obsolescence.

## Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word.

Protect Check. Instruction fetch.

## Storage Immediate Format

CWI word,addr4

Format without appended word for effective

| au | are  | SSIN | g (4 | -1M | = U | 0 01 | : 01 | ) |   |       |    |     |     |    |
|----|------|------|------|-----|-----|------|------|---|---|-------|----|-----|-----|----|
| 0  | pera | itio | n co | ode |     |      |      | R | B | AM    | F  | unc | tio | n  |
| 0  | 1    | 0    | 0    | 0   | 0   | 0    | 0    |   |   |       | 1  | 1   | 1   | 1  |
| 0  |      |      |      | 4   | 5   |      | 7    | 8 | 9 | 10 11 | 12 |     |     | 15 |



Format with appended word for effective addressing (AM = 10 or 11)

| au | uic  | 22111 | 5 (4 | 7111 | - 1, | 0.01 | 11 | , |   |       |    |     |      |    |
|----|------|-------|------|------|------|------|----|---|---|-------|----|-----|------|----|
| 0  | pera | itio  | n co | ode  |      |      |    | R | B | AM    | F  | unc | tion | 1  |
| 0  | 1    | 0     | 0    | 0    | 0    | 0    | 0  |   |   |       | 1  | 1   | 1    | 1  |
| 0  |      |       |      | 4    | 5    |      | 7  | 8 | 9 | 10 11 | 12 |     |      | 15 |



|    | Immediate |  |
|----|-----------|--|
|    |           |  |
| 32 | 47        |  |

The immediate word is subtracted from the contents of the location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

Bits 5-7 are not used and must be set to zero to avoid future code obsolescence. Both operands are unchanged.

#### Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow**. Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

 $\sim$ 

 $( \ )$ 

DB addr4,reg

| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | 0ŗ | pera | itio | n co | ode |                  | R   |      | R       | B   | AM         | F     | unc | tion | 1  |
|-------------------------------------------------------|----|------|------|------|-----|------------------|-----|------|---------|-----|------------|-------|-----|------|----|
| Address/Displacement                                  | 1  | 1    | 1    | 0    | 1   |                  |     |      |         |     |            | 0     | 0   | 1    | 0  |
|                                                       | 0  |      |      |      | 4   | 5                |     | 7    | 8       | 9   | 10 11      | 12    |     |      | 15 |
|                                                       |    |      |      |      |     |                  |     |      |         |     |            |       |     |      |    |
|                                                       |    |      |      |      |     |                  |     |      |         |     |            |       |     |      |    |
|                                                       |    |      | —    | — ·  |     |                  |     |      | <u></u> |     | - <u> </u> |       |     |      |    |
| Displacement 1 Displacement 2                         |    |      |      |      |     | $\underline{A}a$ | are | 55/1 | Dist    | nac | - <u> </u> |       |     |      |    |
|                                                       | _  |      |      |      |     |                  | ٤ 1 |      |         |     | Diamla     | ~ ~ ~ |     | 4 3  |    |

A divide operation is performed between the word dividend contained in the register specified by the R field and the byte divisor at the location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The 1-word quotient replaces the contents of the specified register while the 1-word remainder is placed in the register specified by R+1. If the R field specifies register 7, the remainder is placed in register 0.



#### Indicators

**Overflow**. Cleared, then turned on if division by zero is attempted, or if the quotient cannot be represented in one word. If overflow occurs, the remaining indicators and the contents of the specified register are undefined.

**Carry**. Cleared, then turned on (together with the overflow indicator) if the overflow was caused by an attempt to divide by zero.

Even, Negative, and Zero. Changed to reflect the result.

### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. If the AM field equals 01, the contents of the register specified by the RB field are incremented.

Protect Check. Instruction fetch or operand access.

**Specification Check**. Even byte boundary violation (indirect address).

## Divide Doubleword (DD)

DD addr4,reg

| 01 | pera | tio | n c c    | ode  |      | R   |     | R   | B    | AM     | F   | unc | tio        | n  |
|----|------|-----|----------|------|------|-----|-----|-----|------|--------|-----|-----|------------|----|
| Ц  | 1    | 1   | <u> </u> | 1    |      |     |     |     |      |        | 11  | 0   | 1          | 0  |
| .0 |      |     |          | 4    | 5    |     | 7   | 8   | 9    | 10 11  | 12  | ?   |            | 15 |
|    |      |     |          |      |      |     |     |     |      |        |     |     |            |    |
|    |      |     |          |      |      |     |     |     |      |        |     |     |            |    |
|    |      | _   | _        |      |      |     |     |     |      |        | _   |     |            |    |
| 1  |      |     |          |      | Ad   | dre | ss/ | Dis | plac | ement  |     |     |            | !  |
|    |      | Di  | spla     | icen | nent | 1   |     |     |      | Displa | cen | nen | <u>t 2</u> |    |
| 16 |      |     |          |      |      |     | 23  | 24  | !    |        |     |     |            | 31 |

A divide operation is performed between the doubleword dividend contained in the registers, specified by the R field and R+1, and the word divisor at the location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The doubleword quotient replaces the contents of the specified registers (least significant word is in R+1). The one-word remainder is placed in the register specified by R+2.

The R field wraps from 7 to 0; e.g., if R specifies register 6, registers 6, 7, and 0 are used.



*Programming Note.* If the AM field equals 01, the contents of the register specified by the RB field are incremented by 2.

## Indicators

**Overflow**. Cleared, then turned on if division by zero is attempted, or if the quotient cannot be represented in a doubleword. If overflow occurs, the remaining indicators and the contents of the specified registers are undefined.

**Carry**. Cleared, then turned on (together with the overflow indicator) if the overflow was caused by an attempt to divide by zero.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

## Diagnose (DIAG)

DIAG ubyte



The Diagnose instruction is used for controlling or testing various hardware functions in a machine dependent manner. The parameter field has the following general significance:



Bits 10 and 11 are not used and should be set to zero to avoid future code obsolescence.

- If the C bit (bit 13) is set to one, the number 0005 is loaded into Register 0 of the current interrupt level. Software uses this number to determine that the processor is a 4955.
- If the C bit is set to zero, the function bits have the following meanings:

Bits 8

9

- 0 0 Diagnostic word storage error recovery
- 0 1 Diagnostic byte storage error recovery
- 1 0 Main storage to/from local storage
- 1 1 Enable/disable channel request lines

Diagnostic storage error recovery – This function allows the inhibiting of storage parity generation and checking when using the processor SAR and SDR. The cycle steal storage data register and storage address register can be selected but parity cannot be inhibited. Other bits in the parameter field are as follows:

| Bits | Significance      |
|------|-------------------|
| 12=0 | Load from storage |

- 12=1 Store storage
- 14=0 Inhibit parity check/generation
- 14=1 Enable parity check/generation
- 15=0 Select processor SDR/SAR
- 15=1 Select cycle steal SDR/SAR (ignore bit 14)

The storage address for this storage cycle is contained in R7 while the data register is R0.

## Notes.

- 1. Functions selected by the parameter field apply only to the storage cycle initiated by the execution of this instruction.
- 2. Bit 9 provides the option of single byte manipulation when using the processor SAR and SDR. Diagnostic byte operations are not supported when using the cycle steal SAR and SDR; therefore, bit 9 is ignored when bit 15 is set to one.
- If bit 9 is on (byte operation) and bit 12 is off (load storage operation), the register that is loaded has bits 0-7 set to zeros.

Main storage to/from local storage – This function permits the transfer of data between main storage and local storage by directly addressing local storage. Two additional words are appended to the Diagnose instruction when this function is specified.

The bits in the two additional words are defined as follows:

- Bits Significance
- 16-25 Unused
- 26-31 Local storage address
- 32-47 Data to be transferred
- Bit 12 of the parameter field specifies the direction of transfer.
- 12=0 Load immediate data to local storage
- 12=1 Store local storage to immediate data

*Programming Note.* This function can change AKRs, IARs, and LSRs in local storage. The current level AKR and LSR in local storage are not continuously updated. Use of this instruction to load or store the current level AKR or LSR is not recommended.

*Enable/disable I/O channel request lines* – This function inhibits and logically isolates the interrupt and cycle steal request lines between the channel and the device. Bit 14 of the parameter field is used as follows:

- 14=0 Disable channel request lines
- 14=1 Enable channel request lines

## Indicators

No indicators are directly changed by this instruction; however, LSRs may be changed by the main storage to local storage function.

## **Program Check Conditions**

Privilege Violate. Privileged instruction.

## Disable (DIS)

DIS ubyte

| O | pera | tio | n co | ode | Fu | nct | ion | Parameter |    |
|---|------|-----|------|-----|----|-----|-----|-----------|----|
| 0 | 1    | 1   | 0    | 0   | 0  | 1   | 1   |           |    |
| 0 |      |     |      | 4   | 5  |     | 7   | 8         | 15 |

The facilities designated by one bits in the parameter field are disabled. The bits in the parameter field have the following significance:

| Bit | Facility                                       |
|-----|------------------------------------------------|
| 8   | Not used                                       |
| 9   | Not used                                       |
| 10  | Not used                                       |
| 11  | Not used                                       |
| 12  | Storage protect*                               |
| 13  | Equate operand spaces (AKR bit 0 set to zero)* |
| 14  | Translator (PSW bit 14 set to zero)**          |
| 15  | Summary mask (LSR bit 11 set to zero)          |
|     |                                                |

\* See Chapters 5 and 6.

\*\* See Chapter 6.

Note. Bits not used must be set to zero to avoid future code obsolescence.

If parameter bit 14 is set to one and the relocation translator feature is not installed, no action occurs regarding this bit. If parameter bit 14 is set to one and the relocation translator feature is installed and enabled (bit 14 of the PSW is on), the translator is disabled (bit 14 of the PSW is turned off).

## Indicators

No indicators are changed.

### **Program Check Conditions**

Privilege Violate. Privileged instruction.

## Divide Word (DW)

DW addr4,reg



A divide operation is performed between the word dividend contained in the register specified by the R field and the word divisor at the location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The one word quotient replaces the contents of the specified register. The one word remainder is placed in the register specified by R+1.

The R field wraps from 7 to 0; that is, if R specifies register 7, registers 7 and 0 are used.



## Indicators

**Overflow**. Cleared, then turned on if division by zero is attempted, or if the quotient cannot be represented in one word. If overflow occurs, the remaining indicators and the contents of the specified registers are undefined.

**Carry**. Cleared, then turned on (together with the overflow indicator) if the overflow was caused by an attempt to divide by zero.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

#### Enable (EN)

EN ubyte

| O | Operation code |   |   |   |   | inci | tion |   | Parameter |    |
|---|----------------|---|---|---|---|------|------|---|-----------|----|
| 0 | 1              | 1 | 0 | 0 | 0 | 1    | 0    |   |           |    |
| 0 |                |   |   | 4 | 5 |      | 7    | 8 |           | 15 |

The facilities designated by one bits in the parameter field are enabled.

The bits in the parameter field have the following significance:

| Bit | Facility |
|-----|----------|
|-----|----------|

- 8 Not used
- 9 Not used
- 10 Not used
- 11 Not used
- 12 Storage protect\*
- 13 Equate operand spaces (AKR bit 0 set to one)\*
- 14 Translator (PSW bit 14 set to one)\*\*
- 15 Summary mask (LSR bit 11 set to one)
- \* See Chapters 5 and 6.

\*\* See Chapter 6.

Note. Bits not used must be set to zero to avoid future code obsolescence.

If bit 12 is equal to 1:

- Bit 14 is not checked.
- Storage protection mechanism is enabled.
- Relocation translator (if installed and enabled) is disabled.

If bit 14 is equal to 1:

- No action occurs if the Storage Address Relocation Translator Feature is not installed.
- If the relocation translator feature is installed, it is enabled.
- The storage protection mechanism (if enabled) is disabled.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Privilege Violate. Privileged instruction.

# Fill Byte Field and Decrement (FFD)

Fill Byte Field and Increment (FFN) FFD reg,(reg)

FFN reg,(reg)



This instruction fills all bytes of a field in main storage with the same bit configuration in each byte. Register 7 contains the number of bytes to be filled (field length). If a field length of zero is specified, the instruction is a no-op. The register specified by R1 contains, in bits 8-15, the byte used to fill the field. The register specified by R2 contains the starting address of the field in main storage.

After each byte in the field is filled:

- 1. The address in R2 is either incremented or decremented, determined by bit 13 of the instruction. This permits filling the field in either direction.
- 2. The length count in R7 is decremented.

The operation ends when the specified field length has been filled (contents of R7 equal zero). At this time, the address in R2 has been updated and points to the byte adjacent to the end of the field.

Bits 11 and 15 of the instruction are not used and must be set to zero to avoid future code obsolescence.

See Move Byte Field and Decrement (MVFD) and Move Byte Field and Increment (MVFN) for other versions of this machine instruction.

*Note.* Variable field length instructions can be interrupted. When this occurs and the interrupted level resumes operation, the processor treats the uncompleted instruction as a new instruction with the remaining byte count specified in register 7.

#### Indicators

Carry. Unchanged.

Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect that result of the last byte moved.

#### **Program Check Conditions**

Invalid Storage Address. Operand. The instruction is terminated.

**Protect Check**. Instruction fetch, operand access, or operand store. The instruction is terminated.

# IO IOPK

# Operate I/O (IO)

Refer to Chapter 4 for a detailed description concerning the operation of this instruction.

#### IO longaddr



An effective main storage address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field. If the R2 field equals zero, no register contributes to the address generation.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0 (direct address). The result from step 1 is the effective address.

Bit 11=1 (indirect address). The result from step 1 is the address of the main storage location that contains the effective address.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

The effective address specifies the location of a twoword control block, called the immediate device control block (IDCB). The IDCB contains the command, device address, and a one-word immediate data field:

| Command field      |    | Device addr | ess field |
|--------------------|----|-------------|-----------|
| 0                  | 7  | 8           | 15        |
| Immediate data fie | ld |             |           |
| 16                 |    |             | 31        |

The immediate data field serves two purposes:

- 1. For direct program control (DPC) operations, it holds the data transferred to or from the I/O device.
- 2. For cycle steal operations, it holds the address of the device control block (DCB).

Refer to Chapter 4 for additional information.

Indicators

Even, Carry, and Overflow. Changed to reflect the condition code. See Branch on Condition Code (BCC) or Branch on Not Condition Code (BNCC) instructions.

Negative and Zero. These indicators are not changed.

Program Check Conditions

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

# Interchange Operand Keys (IOPK) IOPK

| 0 | pera | tio | n co | ode | Fu | Function |   |   |   |   |   |    |              |    |
|---|------|-----|------|-----|----|----------|---|---|---|---|---|----|--------------|----|
| 0 | 1    | 1   | 0    | 0   | 1  | 1        | 0 | 0 | 0 | 0 | 0 | 0. | $\theta = 0$ | 0  |
| 0 |      |     |      | 4   | 5  |          | 7 | 8 |   |   |   |    |              | 15 |

The contents of the operand 1 key (OP1K) are interchanged with the contents of the operand 2 key (OP2K) in the address key register. Bits 8-15 of the instruction are not used and must be set to zero to avoid future code obsolescence.

Indicators

All indicators are unchanged.

#### **Program Check Conditions**

Privilege Violate. Privileged instruction.

# Interchange Registers (IR)

| · • |
|-----|
| 187 |
|     |
|     |
|     |

# reg,reg

IR

| O | Operation code |   |   | [ | R1 |  |   | R2 | Function |    |   |   |   |    |
|---|----------------|---|---|---|----|--|---|----|----------|----|---|---|---|----|
| 0 | 1              | 1 | 1 | 0 |    |  |   |    |          | 0  | 0 | 1 | 1 | 1  |
| 0 |                |   |   | 4 | 5  |  | 7 | 8  | 10       | 11 |   |   |   | 15 |

The contents of the register specified by the R1 and R2 fields are interchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand moved from R1 to R2.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

# Jump Unconditional (J)

jdisp

J





Bit 8 of the word displacement field is propagated left seven bit positions and a zero is appended at the low order end, resulting in a 16-bit word. (Word displacement is converted to a byte displacement.) This value is added to the instruction address register. The new value in the IAR becomes the address of the next instruction to be fetched.

*Note.* The hardware format of this instruction is identical to the format used for the Branch Indexed Short (BXS) instruction.

#### Indicators

No indicators are changed.

**Program Check Conditions** 

Invalid Storage Address. Effective address.

Protect Check. Instruction fetch.

**Specification Check**. Even byte boundary violation (branch address).

# JAL

## Jump and Link (JAL)

JAL jdisp,reg jaddr,reg

| Operation code |           |   |   | R |  |   | Word displacement |    |  |  |
|----------------|-----------|---|---|---|--|---|-------------------|----|--|--|
| 1              | $0 \in 0$ | 1 | 1 |   |  |   |                   |    |  |  |
| 0              |           |   | 4 | 5 |  | 7 | 8                 | 15 |  |  |

The updated value of the instruction address register (the location of the next sequential instruction) is stored into the register specified by the R field. Bit 8 of the word displacement field is propagated left by seven bit positions and a zero is appended at the low order end, resulting in a 16-bit word. (The word displacement is converted to a byte displacement.) This value is added to the updated contents of the instruction address register, and the result is stored in the instruction address register, becoming the address of the next instruction to be fetched.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Effective address. The instruction is terminated. Branching does not occur, but the storing of the updated instruction address into the register specified by the R field still occurs.

# Jump on Condition (JC)

| Mnemonic | Operand<br>syntax        | Instruction name                                  | Condition<br>field<br>bits (see A) |
|----------|--------------------------|---------------------------------------------------|------------------------------------|
| JC       | cond,jdisp<br>cond,jaddr | Jump on Condition                                 | Any value<br>listed below          |
| Extended | Operand                  |                                                   | Condition<br>field                 |
| Mnemonic | syntax                   | Instruction name                                  | bits (see A)                       |
| JE       | jdisp<br>jaddr           | Jump on Equal                                     | 000                                |
| JOFF     | jdisp<br>jaddr           | Jump if Off                                       | 000                                |
| JZ       | jdisp<br>jaddr           | Jump on Zero                                      | 000                                |
| JMIX     | jdisp<br>jaddr           | Jump if Mixed                                     | 001                                |
| JP       | jdisp<br>jaddr           | Jump on Positive                                  | 001                                |
| JON      | jdisp<br>jaddr           | Jump if On                                        | 010                                |
| JN       | jdisp<br>jaddr           | Jump on Negative                                  | 010                                |
| JEV      | jdisp<br>jaddr           | Jump on Even                                      | 011                                |
| JLT      | jdisp<br>jaddr           | Jump on Arith-<br>metically Less Than             | 100                                |
| JLE      | jdisp<br>jaddr           | Jump on Arith-<br>metically Less Than<br>or Equal | 101                                |
| JLLE     | jdisp<br>jaddr           | Jump on Logically<br>Less Than or Equal           | 110                                |
| JCY      | jdisp<br>jaddr           | Jump on Carry                                     | 111                                |
| JLLT     | jdisp<br>jaddr           | Jump on Logically<br>Less Than                    | 111                                |

| Operation | code | Cond  | Word displacement |
|-----------|------|-------|-------------------|
| 0 0 0     | 1 0  |       |                   |
| 0         | 4    | 5 A 7 | 8 15              |

This instruction tests the condition of the various indicators set by a previously executed instruction (for example: an arithmetic, compare, test bit, or test word type of instruction).

If the condition tested is met, bit 8 of the word displacement field is propagated left by seven bit positions and a zero is appended at the low-order end resulting in a 16-bit word. (Word displacement is converted to a byte displacement.) This value is added to the updated value of the instruction address register, becoming the address of the next instruction to be fetched. If the condition tested is not met, the next sequential instruction is fetched.

For additional information about the indicator settings for the various conditions, see Chapter 2.

#### Indicators

No indicators are changed.

**Program Check Conditions** 

Invalid Storage Address. Effective address.

# Jump on Count (JCT)

JCT jdisp,reg jaddr,reg

| Op | Operation code |   |   |   | Γ | R |   |   | Word displacement |  |  |
|----|----------------|---|---|---|---|---|---|---|-------------------|--|--|
| 1  | 0              | 1 | 1 | 1 |   |   |   |   |                   |  |  |
| 0  |                |   |   | 4 | 5 |   | 7 | 8 | 15                |  |  |

This instruction tests the contents of the register specified by the R field.

If the register contents are not zero, the contents are decremented by one. If the register contents are still not zero, the word displacement is converted to a byte displacement and added to the contents of the updated instruction address register (IAR). This value indicates the location of the next instruction to be fetched.

If the register contents are zero when initially tested, no decrementing occurs. In this case, or when the register contents are zero after decrementing, the next sequential instruction is fetched. *Note.* When the register contents are not zero, the word displacement is converted to a byte displacement as follows. Bit 8 of the word displacement field is propagated left by seven bit positions, and a zero is appended at the low-order end. This results in a 16-bit word that has been doubled in magnitude.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Effective address. The jump does not occur, but the contents of the register specified by the R field are still decremented by one.



# Jump on Not Condition (JNC)

| Mnemonic | Operand<br>syntax        | Instruction name                                      | Condition<br>field<br>bits (see A) |
|----------|--------------------------|-------------------------------------------------------|------------------------------------|
| JNC      | cond.jdisp<br>cond.jaddr | Jump on Not Condi-<br>tion                            | Any value<br>listed below          |
| Extended | Operand                  |                                                       | Condition<br>field                 |
| Mnemonic | syntax                   | Instruction name                                      | bits (see A)                       |
| JNE      | jdisp<br>jaddr           | Jump on Not Equal                                     | 000                                |
| JNOFF    | jdisp<br>jaddr           | Jump if Not Off                                       | 000                                |
| JNZ      | jdisp<br>jaddr           | Jump on Not Zero                                      | 000                                |
| JNMIX    | jdisp<br>jaddr           | Jump on Not Mixed                                     | 001                                |
| JNP      | jdisp<br>jaddr           | Jump on Not Positive                                  | 001                                |
| JNON .   | jdisp<br>jaddr           | Jump if Not On                                        | 010                                |
| JNN      | jdisp<br>jaddr           | Jump on Not Negative                                  | 010                                |
| JNEV     | jdisp<br>jaddr           | Jump on Not Even                                      | 011                                |
| JGE      | jdisp<br>jaddr           | Jump on Arith-<br>methically Greater<br>Than or Equal | 100                                |
| JGT      | jdisp<br>jaddr           | Jump on Arith-<br>metically Greater<br>Than           | 101                                |
| JLGT     | jdisp<br>jaddr           | Jump on Logically<br>Greater Than                     | 110                                |
| JLGE     | jdisp<br>jaddr           | Jump on Logically<br>Greater Than or Equal            | 111                                |
| JNCY     | jdisp<br>jaddr           | Jump on No Carry                                      | 111                                |



This instruction tests the condition of the various indicators set by a previously executed instruction (for example: an arithmetic, compare, test bit, or test word type of instruction.)

If the condition tested is met, bit 8 of the word displacement field is propagated left by seven bit positions and a zero is appended at the low-order end resulting in a 16-bit word. (Word displacement is converted to a byte displacement.) This value is added to the updated value of the instruction address register, becoming the address of the next instruction to be fetched.

If the condition tested is not met, the next sequential instruction is fetched.

For additional information about the indicator settings for the various conditions, see Chapter 2.

#### Indicators

No indicators are changed.

**Program Check Conditions** 

Invalid Storage Address. Effective address.

# LEX LMB

# Level Exit (LEX)

LEX [ubyte]

| Operation code |  |   |  | Fu | ncti | ion |   | Parameter |    |
|----------------|--|---|--|----|------|-----|---|-----------|----|
|                |  | 1 |  |    | 0    | 0   | 1 |           |    |
| 0              |  |   |  | 4  | 5    |     | 7 | 8         | 1. |

When this instruction is executed, the processor exits the current level. The in-process flag (LSR bit 9) for the current level is turned off. Next the instruction tests for (1) pending levels or outstanding priority interrupt requests, and (2) the condition of the summary mask (LSR bit 11) for the level to be exited:

- If pending levels or outstanding requests exist and the summary mask is enabled:
  - A branch is executed to the address contained in the IAR of the highest pending or requesting level.
  - This level then becomes the current level and processing resumes.
- If pending levels or outstanding requests exist and the summary mask is disabled:
  - The priority interrupts are not allowed.
  - The highest pending level becomes the current level and processing resumes.
  - If no levels are pending, the processor goes to the wait state.
- If no levels are pending and no interrupt requests are outstanding, the processor goes to the wait state.

For additional information on level switching, refer to Chapter 3.

*Programming Note.* When a level is exited by a LEX instruction and processing is to continue on a pending level, one instruction is executed on the pending level prior to sampling for a trace class interrupt.

## Indicators

No indicators are changed.

## **Program Check Conditions**

Privilege Violate. Privileged instruction.

# Load Multiple and Branch (LMB)

Refer to *Stack Operations* in Chapter 2 for a detailed description concerning the operation of this instruction. The LMB instruction is used in conjunction with the Store Multiple (STM) instruction described later in this chapter.

LMB addr4

| Op       | era | tion | co  | de  |      |      |      | ŀ    | RB | AM      | Τ    | Fu | nct | ion |
|----------|-----|------|-----|-----|------|------|------|------|----|---------|------|----|-----|-----|
| 0        | 1   | 0    | 0   | 0   | 0    | 0    | 0    |      |    |         | 1    | 0  | 1   | 0   |
| 0        |     |      |     | 4   | 5    |      | 7    | 8    | 9  | 10 11   | 12   |    |     | 15  |
| <u> </u> |     | _    |     |     |      |      |      |      |    |         |      |    |     |     |
| <br>     |     |      |     | Ac  | ldre | ess/ | Dist | olac | em |         |      | _  | _   |     |
| [        | Dis | pla  | cen | nen | t 1  |      |      | Γ.   | Di | splacer | nent | 2  | _   | i   |
|          |     |      | _   | -   |      | _    |      | 24   | _  |         |      | _  | _   |     |

The contents of the registers for the current level are loaded from the stack defined by the *stack control block* pointed to by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The registers to be loaded are defined by the stack entry previously stored by a Store Multiple (STM) instruction. The next instruction is fetched from the storage address contained in register 7.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

Programming Note. If the AM field equals 01 the contents of the register specified by the RB field are incremented by 2.

## Indicators ·

No indicators are changed.

#### **Program Check Conditions**

**Invalid Storage Address.** Instruction word or stack control block. The instruction is terminated.

**Protect Check.** Instruction fetch or operand access. The instruction is terminated. A partial data transfer occurs if the area of the stack being accessed crosses a protection boundary.

#### Specification Check.

- 1. Even byte boundary violation (indirect address, stack control block, or stack element).
- 2. Address in R7 is odd.

## Soft Exception Trap Condition

Stack Exception. Stack is empty. If the AM field equals 01, the contents of the register specified by the RB field are incremented. The instruction is terminated.

MB addr4,reg

| Operation | code   | R         | RB      | AM       |     | Fu  | nct | ion |
|-----------|--------|-----------|---------|----------|-----|-----|-----|-----|
| 1 1 1     | 0 1    |           |         |          | 0   | 0   | 0   | 1   |
| 0         | 4      | 5 7       | 89      | 10 11    | 12  | 1   |     | 15  |
|           |        |           |         |          |     |     |     |     |
|           | <br>Ac | ldress/Di | splacem | ent – -  |     |     | -   |     |
|           |        |           |         |          |     | _   |     |     |
| Displa    | cemen  | t 1       |         | isplacen | nen | t 2 |     |     |

A multiply operation is performed between the word multiplier contained in the register specified by the R field and the byte multiplicand at the location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The word product replaces the contents of the register.



Indicators

Carry. Reset.

**Overflow.** Cleared, then turned on if the result cannot be represented in 16 bits. If overflow occurs, the contents of the specified register are undefined.

Even, Negative, and Zero. Set to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand. If the AM field equals 01, the contents of the register specified by the RB field are incremented.

Protect Check. Instruction fetch or operand access.

**Specification Check**. Even byte boundary violation (indirect address).

# Multiply Doubleword (MD)

MD addr4,reg



A multiply operation is performed between the doubleword multiplier contained in the registers specified by the R field and R+1 and the word multiplicand at the location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The doubleword product replaces the contents of the registers with the least significant word in R+1.

The R field wraps from 7 to 0; that is, if R specifies register 7, registers 7 and 0 are used.



*Programming Note.* If AM=01, the register specified by the RB field is incremented by 2.

## Indicators

8-46

Carry. Reset.

**Overflow**. Cleared, then turned on if the result cannot be represented in 32 bits. If overflow occurs, the contents of the specified registers are undefined.

Even, Negative, and Zero. Set to reflect the result.

## **Program Check Conditions**

GA34-0021

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

# Move Address (MVA)

Storage Address to Register Format MVA addr4,reg





The effective address is loaded into the register specified by the R field. (*Effective Address Generation* is explained in Chapter 2.)

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand loaded into the register specified by the R field.

#### **Program Check Conditions**

Invalid Storage Address. Second Instruction word.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address).

#### Storage Immediate Format

MVA raddr,addr4

Format without appended word for effective addressing (AM = 00 or 01)

| Op | peration code |   |    |   |   |   |   | F | RB | A  | М  | F  | unc | tio | n  |
|----|---------------|---|----|---|---|---|---|---|----|----|----|----|-----|-----|----|
| 0  | 1             | 0 | _0 | 0 | 0 | 0 | 0 |   |    |    |    | 0  | 0   | 0   | 0  |
| Q  |               |   |    | 4 | 5 |   | 7 | 8 | 9  | 10 | 11 | 12 |     |     | 15 |



Format with appended word for effective addressing (AM = 10 or 11)

| Op | erat | tion | co | de |   |   |   | F | RB | A  | Μ  | Fi | unc | tior | 1  |
|----|------|------|----|----|---|---|---|---|----|----|----|----|-----|------|----|
| 0  | 1    | 0    | 0  | 0  | 0 | 0 | 0 |   |    |    |    | 0  | 0   | 0    | 0  |
| 0  |      |      |    | 4  | 5 |   | 7 | 8 | 9  | 10 | 11 | 12 |     |      | 15 |

|           | Address/D | Displacement   |
|-----------|-----------|----------------|
| Displacem | ent 1     | Displacement 2 |
| 16        | 23        | 24 31          |
| •••••     |           |                |

|    | Immediate |    |
|----|-----------|----|
|    |           |    |
| 32 |           | 47 |

The operand in the immediate field replaces the contents of the location specified by the effective address.

(Effective Address Generation is explained in Chapter 2.) Bits 5-7 of the instruction are not used and must be

set to zero to avoid future code obsolescence. The immediate operand is not changed.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed, but the indicators are set as described.

## Move Byte (MVB)

**Register/Storage Format** 

MVB reg,addr4 addr4,reg



A byte is moved between the least significant byte of the register specified by the R field and the location specified by the effective address in main storage. (*Effective Address Generation* is explained in Chapter 2.) Bit 12 of the instruction specifies the direction of the move:

Bit 12=0. The byte is moved from storage to register. The high-order bit of the byte (sign) is propagated to the eight high order bits of the register. This permits the Compare Byte Immediate (CBI) instruction to be used for byte compare operations. The operand in storage is unchanged.

Bit 12=1. The byte is moved from register to storage. The contents of the register specified by the R field are not changed.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand moved.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check.** Even byte boundary violation (indirect address).

Storage/Storage Format MVB addr5,addr4

| Operation code |     | RB2             | AM1   | AM2    | <i>Fun</i><br>0 0 |
|----------------|-----|-----------------|-------|--------|-------------------|
| 0 4            | 5 7 | 89              | 10 11 | 12 13  | 14 15             |
| Displaceme     |     | Displac<br>3 24 |       | acemen |                   |
| Displaceme     | -   | Displace        |       | cement | 2 47              |

The address arguments generate the effective addresses of two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) A byte is moved from operand 1 to operand 2. Operand 1 is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the byte moved.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check.** Even byte boundary violation (indirect address).

# Move Byte Immediate (MVBI)

MVBI byte,reg

| Op | era | tion | co | de | <u> </u> | R | Τ | Immediate |
|----|-----|------|----|----|----------|---|---|-----------|
| 0  | 0   | 0    | 0  | 1  |          |   |   |           |
| 0  |     |      |    | 4  | 5        | 7 | 8 | 15        |

The register specified by the R field is loaded with the immediate operand.

The immediate field of the instruction forms the operand to be loaded. The immediate field is expanded to a sixteen bit operand by propagating the sign bit value through the high order bit positions; this operand is loaded into the register specified by the R field.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand loaded into the register.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

#### Move Byte and Zero (MVBZ)

MVBZ addr4,reg

| 0Į       | oera | tior | 1 CO | de  |      | R    |            | F                                     | RB  | AN       | И  |     |   |   |    |
|----------|------|------|------|-----|------|------|------------|---------------------------------------|-----|----------|----|-----|---|---|----|
| 1        | 1    | 0    | 0    | 0   |      |      |            |                                       |     |          |    | 0   | 1 | 0 | 1  |
| 0        |      |      |      | 4   | 5    |      | 7          | 8                                     | 9   | 10.      | 11 | 12  |   |   | 15 |
|          |      |      |      |     |      |      |            |                                       |     |          |    |     |   |   |    |
|          |      |      |      |     |      |      |            |                                       |     |          |    |     |   |   |    |
| Γ-       |      | -    |      | Ad  | ldre | ss/l | Disp       | lac                                   | eme | ent      | _  | -   |   | - | ר־ |
|          | Di   | spla | cen  | nen | t 1  |      | . <u> </u> | 1 -                                   | Di  | splace   | em | ent | 2 |   |    |
| <u>ہ</u> |      |      |      | _   | -    |      |            | ـــــــــــــــــــــــــــــــــــــ | _   | <u> </u> |    |     |   |   | 31 |

The byte specified by the effective address is loaded into the least significant byte of the register specified by the R field. (*Effective Address Generation* is explained in Chapter 2.) The high order bit of the byte (sign) is propagated to the eight high order bits within the register.

The byte specified by the effective address is then set to zeros.

Bit 12 of the instruction is not used and must be set to zero to avoid future code obsolescence.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand loaded into the register.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. The register is loaded but the main storage location is unchanged. The status of the even, negative, and zero indicators is unpredictable.

**Specification Check.** Even byte boundary violation (indirect address).

#### Move Doubleword (MVD)

#### **Register/Storage Format**

MVD addr4,reg reg,addr4



A doubleword is moved between the contents of the register pair specified by the R field (R and R+1) and the doubleword location specified by the effective address in main storage. (*Effective Address Generation* is explained in Chapter 2.) The source operand is unchanged.

The R field wraps from 7 to 0; that is, if R specifies register 7, registers 7 and 0 are used.

Bit 12 of the instruction specifies the direction of the move:

Bit 12=0. The doubleword is moved from storage to the register pair.

*Bit 12=1.* The doubleword is moved from the register pair to storage.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand moved.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. If the doubleword location specified by the effective address crosses a read-only protection boundary, partial data may be stored into the non read-only protected area. The status of the even, negative, and zero indicators is unpredictable.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

Storage/Storage Format MVD addr5,addr4



The address arguments generate the effective addresses of two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) A doubleword is moved from operand 1 to operand 2. Operand 1 is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the doubleword moved.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

# **MVDZ**

# Move Doubleword and Zero (MVDZ)

MVDZ addr4,reg



The doubleword specified by the effective address is loaded into the register pair specified by the R field (R and R+1). (*Effective Address Generation* is explained in Chapter 2.) The R field wraps from 7 to 0; that is, if R specifies register 7, registers 7 and 0 are used.

The doubleword specified by the effective address is then set to zeros.

Bit 12 of the instruction is not used and must be set to zero to avoid future code obsolescence.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand loaded into the register pair.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. If the doubleword location specified by the effective address crosses a read-only protection boundary, partial data may be stored into the non read-only protected area. The status of the even, negative, and zero indicators is unpredictable.

# MVFD MVFN

# Move Byte Field and Decrement (MVFD)

Move Byte Field and Increment (MVFN) MVFD (reg),(reg)

MVFN (reg),(reg)



This instruction moves a specified number of bytes (one byte at a time) from one storage location to another. Register 7 contains the number of bytes to be moved (field length). If a field length of zero is specified, the instruction is a no-op. The register specified by R1 contains the address of operand 1; the register specified by R2 contains the address of operand 2. Operand 1 is moved to operand 2.

- After each byte is moved:
- The addresses in R1 and R2 are either incremented or decremented, determined by bit 13 of the instruction. This allows the field to be moved in either direction.
- 2. The length count in R7 is decremented.

The operation ends when the specified field length has been filled (contents of R7 equal zero). At this time, the addresses in R1 and R2 have been updated and point to the next operands.

Bits 11 and 15 of the instructions are not used and must be set to zero to avoid future code obsolescence.

See Fill Byte Field and Decrement (FFD) and Fill Byte Field and Increment (FFN) for other versions of this machine instruction.

*Note.* Variable field length instructions can be interrupted. When this occurs and the interrupted level resumes operation, the processor treats the uncompleted instruction as a new instruction with the remaining count specified in register 7.

## Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result of the last byte moved.

#### **Program Check Conditions**

Invalid Storage Address. Operand. The instruction is terminated.

**Protect Check.** Instruction fetch, operand access, or operand store. The instruction is terminated.



# Move Word (MVW)

M R

Register/Register Format MVW reg,reg

| Op | Operation code |   |   |   | Γ | R1 | Fu | Function |    |   |   |   |    |
|----|----------------|---|---|---|---|----|----|----------|----|---|---|---|----|
| 0  | 1              | 1 | 1 | 0 |   |    |    |          | 0  | 0 | 1 | 0 | 0  |
| 0  |                |   |   | 4 | 5 | 7  | 8  | 10       | 11 |   |   |   | 15 |

The contents of the register specified by the R1 field replace the contents of the register specified by the R2 field. The contents of the register specified by the R1 field are unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

# **Register/Storage Format**

MVW reg,addr4 addr4,reg





A word is moved between the contents of the register specified by the R field and the location specified by the effective address in main storage. (*Effective Address Generation* is explained in Chapter 2.) The source operand is unchanged.

## Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand moved.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

# Register to Storage Long Format

MVW reg,longaddr





The contents of the register specified by the R1 field are stored into the main storage location specified by an effective address. This effective address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field. If the R2 field equals zero, no register contributes to the address generation.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0 (direct address). The result from step 1 is the effective address.

Bit 11=1 (indirect address). The result from step 1 is the address of the main storage location that contains the effective address.

#### Indicators

Carry and Overflow. Unchanged.

**Even**, Negative, and Zero. Changed to reflect the result stored from the register specified by the R1 field.

#### Program Check Conditions

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

# Storage to Register Long Format

MVW longaddr,reg



The register specified by the R1 field is loaded with the contents of the main storage location specified by an effective address. This effective address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field. If the R2 field equals zero, no register contributes to the address generation.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0 (direct address). The result from step 1 is the effective address.

Bit 11=1 (indirect address). The result from step 1 is the address of the main storage location that contains the effective address.

## Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result loaded into the register specified by the R1 field.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

Storage/Storage FormatMVWaddr5,addr4



The address arguments generate the effective addresses of two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) A word is moved from operand 1 to operand 2. Operand 1 is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the word moved.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

# Move Word Immediate (MVWI)

Storage to Register Format MVWI word,reg

# Operation codeRRBAMFunction0100010004578910111215Address/DisplacementDisplacement 1

The effective address value is loaded into the register specified by the R field. (*Effective Address Generation* is explained in Chapter 2.) This value is equal to the value of word as specified by the programmer.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand loaded into the register specified by the R field.

#### **Program Check Conditions**

Invalid Storage Address. Second instruction word.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address).

# Storage Immediate Format

MVWI word,addr4

Format without appended word for effective addressing (AM = 00 or 01)

| Op | peration code<br>1 0 0 ( |   |   |   |   |   |   | F | RB | AM    | Function |   |   |    |  |
|----|--------------------------|---|---|---|---|---|---|---|----|-------|----------|---|---|----|--|
| 0  | 1                        | 0 | 0 | 0 | 0 | 0 | 0 |   |    |       | 0        | 0 | 0 | 0  |  |
| 0  |                          |   |   | 4 | 5 |   | 7 | 8 | 9  | 10 11 | 12       |   |   | 15 |  |



Format with appended word for effective addressing (AM = 10 or 11)

| Op | Operation code |   |   |   |   |   |   | F | RB | A  | М  | F  | unc | tio | n  |
|----|----------------|---|---|---|---|---|---|---|----|----|----|----|-----|-----|----|
| 0  | 1              | 0 | 0 | 0 | 0 | 0 | 0 |   |    |    |    | 0  | 0   | 0   | 0  |
| 0  |                |   |   | 4 | 5 |   | 7 | 8 | 9  | 10 | 11 | 12 |     |     | 15 |

| Address/Displacement |          |  |  |  |  |  |  |  |  |  |  |
|----------------------|----------|--|--|--|--|--|--|--|--|--|--|
| Displace             | ement 2  |  |  |  |  |  |  |  |  |  |  |
| 23 24                | 31       |  |  |  |  |  |  |  |  |  |  |
|                      | Displace |  |  |  |  |  |  |  |  |  |  |

|    | Immediate | ٦ |
|----|-----------|---|
|    |           | L |
| 32 | 4         | 7 |

The operand in the immediate field replaces the contents of the location specified by the effective address.

(Effective Address Generation is explained in Chapter 2.) Bits 5-7 of the instruction are not used and must be

set to zero to avoid future code obsolescence. The immediate operand is not changed.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

# Move Word Short (MVWS)

Register to Storage FormatMVWSreg,shortaddr



The contents of the register specified by R1 are stored into the main storage location specified by the effective address. The contents of the register are unchanged.

The effective address is generated as follows:

- 1. The five bit unsigned integer (word displacement) is doubled in magnitude (converted to a byte displacement).
- 2. The result from step 1 is added to the contents of the base register (RB) to form a main storage address.
- 3. Instruction bit 10 is tested for direct or indirect addressing:

Bit 10=0 (direct address). The result from step 2 is the effective address.

Bit 10=1 (indirect address). The result from step 2 is the address of the main storage location that contains the effective address.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand stored into main storage.

#### **Program Check Conditions**

Invalid Storage Address. Operand.

**Protect Check.** Instruction fetch, operand access, or operand store.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

# Storage to Register Format MVWS shortaddr,reg



The contents of the main storage location specified by the effective address are loaded into the register specified by the R1 field. The contents of the main storage location remain unchanged.

The effective address is generated as follows:

- 1. The five bit unsigned integer (word displacement) is doubled in magnitude (converted to a byte displacement).
- 2. The result from step 1 is added to the contents of the base register (RB) to form a main storage address.
- 3. Instruction bit 10 is tested for direct or indirect addressing:

Bit 10=0 (direct address). The result from step 2 is the effective address.

Bit 10=1 (indirect address). The result from step 2 is the address of the main storage location that contains the effective address.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the operand loaded into the register specified by the R1 field.

#### **Program Check Conditions**

Invalid Storage Address. Operand.

Protect Check. Instruction fetch or operand access.

# **MVWZ**

# Move Word and Zero (MVWZ)

MVWZ addr4,reg

| Op | era |   | R |   |   | RB | AM | F | Function |       |      |   |   |    |
|----|-----|---|---|---|---|----|----|---|----------|-------|------|---|---|----|
| 1  | 1   | 0 | 0 | 1 | 1 |    |    | } |          |       | 0    | 1 | 0 | 1  |
| 0  |     |   |   | 4 | 5 |    | 7  | 8 | 9        | 10 1. | 1 12 |   |   | 15 |

| Address        | /Displacement  |    |
|----------------|----------------|----|
| Displacement 1 | Displacement 2 |    |
| $16^{$         | 23 24          | 31 |

The word specified by the effective address is loaded into the register specified by the R field. (*Effective Address Generation* is explained in Chapter 2.)

The word specified by the effective address is then set to zeros.

Bit 12 of the instruction is not used and must be set to zero to avoid future code obsolescence.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result of the operand loaded.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. The register is loaded but the main storage location is unchanged. The status of the even, negative, and zero indicators is unpredictable.

# MŴ

# Multiply Word (MW)

MW addr4,reg



A multiply operation is performed between the word multiplier contained in the register specified by the R field and the word multiplicand at the location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The word product replaces the contents of the register.



#### Indicators

Carry. Unchanged.

**Overflow.** Cleared, then turned on if the result cannot be represented in 16 bits. If overflow occurs, the contents of the specified register are undefined.

Even, Negative, and Zero. Set to Reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

# No Operation (NOP) NOP

| Op | pera | tior | 1 co | de |   |   |   |   |   |   |   |   |   |   |    |
|----|------|------|------|----|---|---|---|---|---|---|---|---|---|---|----|
| 0  | 1    | 0    | 1    | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  |
| 0  |      |      |      | 4  | 5 |   | 7 | 8 |   |   |   |   |   |   | 15 |

The hardware format of this instruction is identical to the format used for the Branch Indexed Short (BXS) and Jump Unconditional (J) instructions. When bits 5-15 are all zeros, the instruction performs no operation.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

# AND Word Immediate (NWI)

| NWI | word,reg[ | ,reg] |
|-----|-----------|-------|
|-----|-----------|-------|

| Op | era | tior | 1 00 | ode |   | R1 R2 |   |  |    |    | Function |   |   |    |  |  |  |
|----|-----|------|------|-----|---|-------|---|--|----|----|----------|---|---|----|--|--|--|
| 0  | 1   | 1    | 1    | 1   |   |       |   |  |    | 0  | 0        | 0 | 0 | 0  |  |  |  |
| 0  |     |      |      | 4   | 5 | 7     | 8 |  | 10 | 11 |          |   |   | 15 |  |  |  |

|    | Immediate |    |
|----|-----------|----|
| 16 |           | 31 |

The immediate field is ANDed bit by bit with the contents of the register specified by the R1 field. The result is placed in the register specified by the R2 field. The contents of the register specified by R1 are unchanged unless R1 and R2 specify the same register.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word.

# OR Byte (OB)

#### **Register/Storage Format**

OB reg,addr4

addr4,reg



A logical OR operation is performed between the least significant byte of the register specified by the R field and the location specified by the effective address in main storage. (Effective Address Generation is explained in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged. Also, when going from storage to register, bits 0 through 7 of the register are unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

Specification Check. Even byte boundary violation (indirect address).

#### Storage/Storage Format OB addr5,addr4



The address arguments generate the effective addresses of two operands in main storage. (Effective Address Generation is explained in Chapter 2.) A one byte logical OR operation is performed between operand 1 and operand 2. The result replaces operand 2.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

Protect Check. Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

Specification Check. Even byte boundary violation (indirect address).

# **OR** Doubleword (OD)

#### **Register/Storage Format**

OD

addr4,reg reg,addr4



 Address/Displacement

 Displacement 1
 Displacement 2

 16
 23 24
 31

A logical OR operation is performed between the contents of the register pair specified by the R field (R and R+1) and the doubleword in main storage specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged.

If the R field equals 7, register 7 and register 0 are used.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the results of the OR operation.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. If the doubleword location specified by the effective address crosses a read-only protection boundary, partial data may be stored into the non read-only protected area. The status of the even, negative, and zero indicators is unpredictable.

**Specification Check.** Even byte boundary violation (indirect address or direct address).

## Storage/Storage Format

OD addr5,addr4

| Op                                                          | era | tion | co  | de  |   | RB1         | R         | B2  | AMI   | AM2    | Fun   |  |  |  |
|-------------------------------------------------------------|-----|------|-----|-----|---|-------------|-----------|-----|-------|--------|-------|--|--|--|
| 1                                                           | 0   | 0    | 1   | 0   |   |             |           | i   |       |        | 0 1   |  |  |  |
| 0                                                           |     |      |     | 4   | 5 | 7           | 8         | 9   | 10 11 | 12 13  | 14 15 |  |  |  |
| Address/Displacement<br>Displacement 1<br>16<br>23 24<br>31 |     |      |     |     |   |             |           |     |       |        |       |  |  |  |
|                                                             | Dis | pla  | cen | nen |   | ddress/<br> | Dis<br>40 | · · |       | cement | 2 47  |  |  |  |

The address arguments generate the effective addresses of two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) A doubleword logical OR operation is performed between operand 1 and operand 2. The result replaces operand 2. Operand 1 is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result of the OR operation.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

# OR Word (OW)

#### **Register/Register Format**

OW reg,reg

| 1 | Op | era | tior | 1 00 | de |   | R1 |   | R2 | Function |   |   |   |    |  |
|---|----|-----|------|------|----|---|----|---|----|----------|---|---|---|----|--|
|   | 0  | 1   | 1    | 1    | 0  |   |    |   |    | 0        | 0 | 0 | 0 | 1  |  |
| 1 | 0  |     |      |      | 4  | 5 | 7  | 8 | 10 | 11       |   |   |   | 15 |  |

The contents of the register specified by the R1 field are ORed bit by bit with the contents of the register specified by the R2 field. The result is placed in the register specified by the R2 field. The contents of the register specified by the R1 field remain unchanged unless R1 and R2 specify the same register.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

**Register/Storage Format** 



| Op<br>1 | eran<br>1 | tion<br>0 | <i>Co</i><br>0 | de<br>1 |                | २ | RI    | B . | AM         | X    | Funct<br>0 0 | tion<br>1 |
|---------|-----------|-----------|----------------|---------|----------------|---|-------|-----|------------|------|--------------|-----------|
| 0       |           |           |                | 4       | 5              | 7 | 8     | 9   | 10 11      | 12   | 13           | 15        |
|         |           |           |                |         | to st<br>to re | - | · > - |     |            |      |              |           |
|         | Dis       | spla      | cen            |         | dress          |   |       |     | entsplacem | nent | 2            |           |

A logical OR operation is performed between the contents of the register specified by the R field and the location specified by the effective address in main storage. (See *Effective Address Generation* in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

**Even**, Negative, and Zero. Changed to reflect the result of the OR operation.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

## Storage to Register Long Format OW

longaddr.reg



A logical OR operation is performed between the contents of the main storage location specified by an effective address and the contents of the register specified by the R1 field. The result is placed in the register specified by the R1 field.

The effective main storage address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field. If the R2 field equals zero, no register contributes to the address generation.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0 (direct address). The result from step 1 is the effective address.

Bit 11=1 (indirect address). The result from step 1 is the address of the main storage location that contains the effective address.

## Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result loaded into the register specified by the R1 field.

## **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

Specification Check. Even byte boundary violation (indirect address or operand address).

# Storage/Storage Format

OW addr5.addr4



The address arguments generate the effective addresses of two operands in main storage. (See Effective Address Generation in Chapter 2.) A one word logical OR operation is performed between operand 1 and operand 2. The result replaces operand 2. Operand 1 is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

Protect Check. Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.



# OR Word Immediate (OWI)

## Register Immediate Format

OWI word,reg[,reg]



The immediate field is ORed bit by bit with the contents of the register specified by the R1 field. The result is placed in the register specified by the R2 field. The contents of the register specified by R1 are unchanged unless R1 and R2 specify the same register.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch.

# Storage Immediate Format

OWI word,addr4

Format without appended word for effective addressing (AM = 00 or 01)

| 0Į | pera | tio | n cc | ode |   |   |   | F | RB | A  | Μ  | F  | un | ctio | n  |
|----|------|-----|------|-----|---|---|---|---|----|----|----|----|----|------|----|
| 0  | 1    | 0   | 0    | 0   | 0 | 0 | 0 |   |    |    |    | 1  | 1  | 0    | 0  |
| 0  |      |     |      | 4   | 5 |   | 7 | 8 | 9  | 10 | 11 | 12 |    |      | 15 |



Format with appended word for effective addressing (AM = 10 or 11)

| 0 | p | era | tio | n co | de |   |   |   | 1 | <i>RB</i> | AM    | F  | une | ctio | n  |
|---|---|-----|-----|------|----|---|---|---|---|-----------|-------|----|-----|------|----|
| 0 |   | 1   | 0   | 0    | 0  | 0 | 0 | 0 |   | _         |       | 1  | 1   | 0    | 0  |
| 0 |   |     |     |      | 4  | 5 |   | 7 | 8 | 9         | 10 11 | 12 |     |      | 15 |



|    | Immediate |    |
|----|-----------|----|
|    |           |    |
| 32 |           | 47 |

A logical OR operation is performed between the immediate field and the contents of the main storage location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The result replaces the contents of the storage location.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence. The immediate operand is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result of the OR operation.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

# Pop Byte (PB)

Refer to *Stack Operations* in Chapter 2 for additional information about the operation of this instruction and the associated stack control block.

PB addr4,reg

| Γ | Operation code |   |   |   |   | - <i>R</i> |  |   | I | RB | A  | М  |    | Fu | ncti | ion |
|---|----------------|---|---|---|---|------------|--|---|---|----|----|----|----|----|------|-----|
|   | 1              | 1 | 1 | 0 | 1 |            |  |   |   |    |    |    | 0  | 0  | 1    | 1   |
|   | 0              |   |   |   | 4 | 5          |  | 7 | 8 | 9  | 10 | 11 | 12 |    |      | 15  |

| Address/Dis    | placement      | 1      |
|----------------|----------------|--------|
| Displacement 1 | Displacement 2 | 1<br>J |
| 16 23          | 3 24 31        |        |

The top element of a byte stack is popped from the stack and loaded into the least significant byte of the register specified by the R field. The stack is defined by the stack control block pointed to by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

*Programming Note.* If AM equals 01, the register specified by the RB field is incremented by two.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word, stack control block, or operand.

**Protect Check.** Instruction fetch, operand access, or stack control block.

**Specification Check.** Even byte boundary violation (indirect address or stack control block).

#### Soft Exception Trap Condition

Stack Exception. Stack is empty. If AM equals 01, the contents of the register specified by the RB field are incremented.

#### Pop Doubleword (PD)

Refer to *Stack Operations* in Chapter 2 for additional information about the operation of this instruction and the associated stack control block.

PD addr4,reg



The top element of a doubleword stack is popped from the stack and loaded into the register pair specified by the R field (R and R+1). The stack is defined by the stack control block pointed to by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

If the R field equals 7, registers 7 and 0 are used.

*Programming Note.* If AM equals 01, the register specified by the RB field is incremented by two.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word, stack control block, or operand.

**Protect Check.** Instruction fetch, operand access, or stack control block. The instruction is terminated. For operand access, partial data is transferred to the register pair if the doubleword being addressed crosses a protection boundary.

**Specification Check.** Even byte boundary violation (indirect address, stack control block, or stack element).

#### Soft Exception Trap Condition

Stack Exception. Stack is empty. If the AM field equals 01, the contents of the register specified by the RB field are incremented.

# Push Byte (PSB)

Refer to *Stack Operations* in Chapter 2 for additional information about the operation of this instruction and the associated stack control block.

#### PSB reg,addr4





The least significant byte of the register specified by the R field is pushed into the stack. The stack is defined by the stack control block pointed to by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

*Programming Note.* If AM equals 01, the register specified by the RB field is incremented by two.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word, stack control block, or operand.

**Protect Check**. Instruction fetch, operand access, or operand store.

**Specification Check**. Even byte boundary violation (indirect address or stack control block).

#### Soft Exception Trap Condition

Stack Exception. Stack is full. If AM equals 01, the contents of the register specified by the RB field are incremented.

#### Push Doubleword (PSD)

Refer to *Stack Operations* in Chapter 2 for additional information about the operation of this instruction and the associated stack control block.

PSD reg,addr4

| Operation code |   |   |   |   |   | R |   |   | RB | AM    | F  | unc | inction |    |
|----------------|---|---|---|---|---|---|---|---|----|-------|----|-----|---------|----|
| 1              | 1 | 1 | 0 | 1 | 1 |   |   |   |    |       | 1  | 0   | 0       | 0  |
| 0              |   |   |   | 4 | 5 |   | 7 | 8 | 9  | 10 11 | 12 |     |         | 15 |

| Address/Disp   | lacement       | ר־ |
|----------------|----------------|----|
| Displacement 1 | Displacement 2 | -  |
| 16 $-23$       | 24             | 31 |

The doubleword operand contained in the register pair specified by the R field (R and R+1) is pushed into the stack. The stack is defined by the stack control block pointed to by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

If the R field equals 7, registers 7 and 0 are used.

*Programming Note.* If AM equals 01, the register specified by the RB field is incremented by two.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word, stack control block, or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. The instruction is terminated. For operand store (read-only violation), partial data is transferred to the non-read-only area of main storage if the doubleword being stored crosses a protection boundary.

**Specification Check.** Even byte boundary violation (indirect address, stack control block, or stack element).

#### **Soft Exception Trap Condition**

Stack Exception. Stack is full. If the AM field equals 01, the contents of the register specified by the RB field are incremented.

# Push Word (PSW)

Refer to *Stack Operations* in Chapter 2 for additional information about the operation of this instruction and the associated stack control block.

PSW reg,addr4



The word operand contained in the register specified by the R field is pushed into the stack. The stack is defined by the stack control block pointed to by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

*Programming Note.* If AM equals 01, the register specified by the RB field is incremented by two.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word, stack control block, or operand.

**Protect Check**. Instruction fetch, operand access, or operand store.

**Specification Check.** Even byte boundary violation (indirect address, stack control block, or stack element).

#### Soft Exception Trap Condition

**Stack Exception**. Stack is full. If the AM field equals 01, the contents of the register specified by the RB field are incremented.

## Pop Word (PW)

Refer to *Stack Operations* in Chapter 2 for additional information about the operation of this instruction and the associated stack control block.

PW addr4,reg

| Op | Operation code |   |   |    |     | R        |          |      | 28  | AM           | Function |            |   |    |
|----|----------------|---|---|----|-----|----------|----------|------|-----|--------------|----------|------------|---|----|
| 1  | 1              | 1 | 0 | 1  |     |          |          |      |     |              | 0        | 1          | 1 | 1  |
| 0  |                |   |   | 4  | 5   |          | 7        | 8    | 9   | 10 11        | 12       |            |   | 15 |
|    |                |   |   |    |     |          |          |      |     |              |          |            |   |    |
|    |                |   |   |    |     |          |          |      |     |              |          |            |   |    |
|    |                |   |   |    |     |          |          | _    |     |              |          |            |   |    |
|    |                |   |   | Ad | dre | <br>ss/L | <br>Disp | lace | eme |              |          | <b>_</b> . |   |    |
|    | Dis            |   | _ |    | -   | ss/L     | Disp     |      |     | nt<br>placen |          | <br>       |   |    |

The top element of a word stack is popped from the stack and loaded into the register specified by the R field. The stack is defined by the stack control block pointed to by the effective address (*Effective Address Generation* is explained in Chapter 2.)

*Programming Note.* If AM equals 01, the register specified by the RB field is incremented by two.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word, stack control block, or operand.

**Protect Check.** Instruction fetch, operand access, or stack control block.

**Specification Check.** Even byte boundary violation (indirect address, stack control block, or stack element).

#### Soft Exception Trap Condition

Stack Exception. Stack is empty. If the AM field equals 01, the contents of the register specified by the RB field are incremented.

## Reset Bits Byte (RBTB)

## **Register/Storage Format**

RBTB addr4,reg reg,addr4



This instruction operates either:

- 1. Storage to register (instruction bit 12 equals 0) or
- 2. Register to storage (instruction bit 12 equals 1).

Storage to Register. The specified bits are reset in the least significant byte of the register specified by the R1 field. The bit positions turned off correspond to the bit positions containing one-bits in the main storage byte location specified by the effective address. The remaining bits in the low-order byte of the register are unchanged. Also, bits 0-7 of the register and the storage operand are unchanged.

**Register to Storage**. The specified bits are reset in the main storage byte location specified by the effective address. The bits turned off correspond to the bit positions containing one-bits in the least significant byte of the register specified by the R field. The remaining bits in the storage location are unchanged. The register operand is unchanged.

Note. Effective Address Generation is explained in Chapter 2.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check.** Even byte boundary violation (indirect address).

Storage/Storage Format RBTB addr5.addr4



The address arguments generate the effective addresses of two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) The bit positions containing one-bits in byte operand 1 determine the bit positions turned off in byte operand 2. The remaining bits in operand 2 are unchanged. The result replaces operand 2. Operand 1 is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check.** Even byte boundary violation (indirect address).

# Reset Bits Doubleword (RBTD)

# Register/Storage Format RBTD addr4,reg reg,addr4



This instruction operates either:

- 1. Storage to register (instruction bit 12 equals 0) or
- 2. Register to storage (instruction bit 12 equals 1)

**Storage to Register**. The specified bits are reset in the register pair specified by the R field (R and R+1). The bit positions turned off correspond to the bit positions containing one-bits in the doubleword main storage location specified by the effective address. The remaining bits in the register pair are unchanged. The storage operand is unchanged.

**Register to Storage**. The specified bits are reset in the doubleword main storage location specified by the effective address. The bit positions turned off correspond to the bit positions containing one-bits in the register pair specified by the R field (R and R+1). The remaining bits in the storage operand are unchanged. The register operand is unchanged. If the R field equals 7, registers 7 and 0 are used.

Note. Effective Address Generation is explained in Chapter 2.

## Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. If the doubleword location specified by the effective address crosses a read-only protection boundary, partial data may be stored into the non read-only protected area. The status of the even, negative, and zero indicators is unpredictable.

**Specification Check**. Even byte boundary violation (indirect address or operand address).

# Storage/Storage Format

RBTD addr5,addr4

| Ope<br>1 | ratio<br>0 ( | ) 1  | ode<br>0 |   | RB1           | RI         | 32 | AM1   | AM2    | <i>Fun</i><br>1 0 |
|----------|--------------|------|----------|---|---------------|------------|----|-------|--------|-------------------|
| 0        |              |      | 4        | 5 | 7             | 8          | 9  | 10 11 | 12 13  | 14 15             |
|          | Displ        | acer | nen      |   | idress/<br>23 | Disp<br>24 |    |       | cement |                   |
|          | Displ        | acen | nen      |   | ddress/       | Disp<br>40 |    |       | cement | $\frac{2}{47}$    |

The address arguments generate the effective addresses of two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) The bit positions containing one-bits in doubleword operand 1 determine the bit positions turned off in doubleword operand 2. The remaining bits in operand 2 are unchanged. The result replaces operand 2. Operand 1 is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

Instructions 8-69

# Reset Bits Word (RBTW)

**Register/Register Format** 

RBTW reg,reg

| OF | bera | tio | 1 00 | ode | RI R2 |   |   |    |    | Function |   |   |    |  |  |
|----|------|-----|------|-----|-------|---|---|----|----|----------|---|---|----|--|--|
| 0  | 1    | 1   | 1    | 0   |       |   |   |    | 0  | Ö        | 0 | 0 | 0  |  |  |
| 0  |      |     |      | 4   | 5     | 7 | 8 | 10 | 11 |          |   |   | 15 |  |  |

The bit positions containing one-bits in the register specified by the R1 field determine the bit positions turned off in the register specified by the R2 field. The remaining bits in the register specified by the R2 field are unchanged. The contents of the register specified by the R1 field are unchanged unless R1 and R2 specify the same register.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

Register/Storage Format RBTW addr4,reg

reg,addr4



This instruction operates either:

- 1. Storage to register (instruction bit 12 equals 0) or
- 2. Register to storage (instruction bit 12 equals 1)

Storage to Register. The specified bits are reset in the register specified by the R field. The bit positions turned off correspond to the bit positions containing one-bits in the main storage word location specified by the effective address. The remaining bits in the register are unchanged. The storage operand is unchanged.

**Register to Storage.** The specified bits are reset in the main storage word location specified by the effective address. The bit positions turned off correspond to the bit positions containing one-bits in the register specified by the R field. The remaining bits in the storage operand are unchanged. The register operand is unchanged.

Note. Effective Address Generation is explained in Chapter 2.

Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

# Storage to Register Long Format RBTW longaddr,reg



The bit positions containing one-bits in the main storage word location specified by the effective address determine the bit positions turned off in the register specified by the R1 field. The remaining bits in the register specified by the R1 field are unchanged. The storage operand is unchanged.

The effective address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field to form a main storage address. If the R2 field equals zero, no register contributes to the address generation. The contents of R2 are not changed.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0 (direct address). The result from step 1 is the effective address.

Bit 11=1 (indirect address). The result from step 1 is the address of the main storage location that contains the effective address.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

# Storage/Storage Format

RBTW addr5,addr4

| $\begin{bmatrix} O_l \\ 1 \end{bmatrix}$ | pera<br>0 | tion<br>0 | 1 cc<br>0 | ode<br>1 |   | RB.         | 1           | RI | 32   | AM1             | AM2    | $\begin{bmatrix} F\iota \\ 1 \end{bmatrix}$ | in<br>0     |
|------------------------------------------|-----------|-----------|-----------|----------|---|-------------|-------------|----|------|-----------------|--------|---------------------------------------------|-------------|
| 0                                        |           |           |           | 4        | 5 |             | 7           | 8  | 9    | 10 11           | 12 13  | 14                                          | 15          |
|                                          |           | spla      | icer      | nen      | _ | ddre<br>— – | 2322        | Ţ_ |      | ement<br>Displa | cement | 2                                           | <br> <br>31 |
|                                          |           | ispl      | ace       | mer      | _ | ddre        | 2ss/1<br>39 |    | olac | ement<br>Displa | cement | 2                                           | <br><br>47  |

The address arguments generate the effective addresses of two operands in main storage. (*Effective Address Generation* is explained in Chapter 2.) The bit positions containing one-bits in word operand 1 determine the bit positions turned off in word operand 2. The remaining bits in operand 2 are unchanged. The result replaces operand 2. Operand 1 is unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

### RBTWI

#### **Reset Bits Word Immediate (RBTWI)**

#### **Register Immediate Long Format**

RBTWI word,reg[,reg]



The bit positions containing one-bits in the immediate field determine the bit positions to be reset. These bit positions are reset in the operand from the contents of the register specified by the R1 field. The result is placed in the register specified by the R2 field.

#### Example:

| Contents of immediate field | 0000 0000 0000 1111 |
|-----------------------------|---------------------|
| Contents of R1 register     | 0101 0101 0101 0101 |
| Result in R2 register       | 0101 0101 0101 0000 |

The contents of the register specified by the R1 field are unchanged unless R1 and R2 specify the same register.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word.

Protect Check. Instruction fetch.

#### Storage Immediate Format RBTWI word,addr4

Format without appended word for effective addressing (AM = 00 or 01)

| Op | era | tior | i co | de |   |   |   | K | <i>B</i> | AM    | F  | 'unc | ctio | n  |
|----|-----|------|------|----|---|---|---|---|----------|-------|----|------|------|----|
| 0  | 1   | 0    | 0    | 0  | 0 | 0 | 0 |   |          |       | 1  | 1    | 0    | 1  |
| 0  |     |      |      | 4  | 5 |   | 7 | 8 | 9        | 10 11 | 12 |      |      | 15 |



Format with appended word for effective addressing (AM = 10 or 11)

|    |     |      |      |    |   | ` |   |   |   | -    |      |     |     |    |
|----|-----|------|------|----|---|---|---|---|---|------|------|-----|-----|----|
| Op | era | tion | ı co | de |   |   |   | F | B | AM   | F    | unc | tio | n  |
| 0  | 1   | 0    | 0    | 0  | 0 | 0 | 0 |   |   |      | 1    | 1   | 0   | 1  |
| 0  |     |      |      | 4  | 5 |   | 7 | 8 | 9 | 10 1 | 1 12 |     |     | 15 |

|    | Address/       | Displacement   |    |
|----|----------------|----------------|----|
| Γ_ | Displacement 1 | Displacement 2 |    |
| 16 | 23             | 24             | 31 |

|    | Immediate |    |
|----|-----------|----|
| 32 |           | 47 |

The bit positions containing one-bits in the immediate field determine the bit positions turned off in the main storage location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The immediate operand is unchanged.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

#### Subtract Byte (SB)

SB reg,addr4 addr4,reg



| Address/L                                    | Displacement                                                |
|----------------------------------------------|-------------------------------------------------------------|
| Displacement 1                               | Displacement 2                                              |
| $\frac{1}{16} = \frac{1}{23} = \frac{1}{23}$ | $\frac{1}{24} = \frac{1}{24} = \frac{1}{31} = \frac{1}{31}$ |

A subtract operation is performed between the least significant byte of the register specified by the R field and the location specified by the effective address in main storage. (See *Effective Address Generation* in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand and high-order byte of the register are unchanged.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the byte. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one byte; i.e., if the difference is less than  $-2^7$  or greater than  $+2^7-1$ .

If an overflow occurs, the result contains the correct low-order eight bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check.** Even byte boundary violation (indirect address).

#### Subtract Carry Indicator (SCY)

reg

SCY

| Operation code |   |   |   |   | Γ |   |   |   | R2 | 1  | Fun | ctic | n |    |
|----------------|---|---|---|---|---|---|---|---|----|----|-----|------|---|----|
| 0              | 1 | 1 | 1 | 0 | 0 | 0 | 0 |   |    | 0  | 0   | 0    | 1 | 0  |
| 0              |   |   |   | 4 | 5 |   | 7 | 8 | 10 | 11 |     |      |   | 15 |

The value of the carry indicator on entry is subtracted from the contents of the register specified by the R2 field. The result is placed in the register specified by the R2 field. Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

Programming Note. This instruction can be used when subtracting multiple word operands. See Indicators-Multiple Word Operands in Chapter 2.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct low-order 16 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even. Unchanged.

Negative. Changed to reflect the result.

**Zero.** If on at entry, changed to reflect the result. If off at entry, it remains off.

#### **Program Check Conditions**

SD

#### Subtract Doubleword (SD)

#### **Register/Storage Format**

reg,addr4 addr4,reg



A subtract operation is performed between the register pair specified by the R field (R and R+1) and the doubleword in main storage specified by the effective address. (See *Effective Address Generation* in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged.

If the R field equals 7, register 7 and register 0 are used.

#### Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the doubleword. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in the doubleword; i.e., if the difference is less than  $-2^{31}$  or greater than  $+2^{31}-1$ .

If an overflow occurs, the result contains the correct low-order 32 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. If the doubleword location specified by the effective address crosses a read-only protection boundary, partial data may be stored into the non read-only protected area. The status of the even, negative, and zero indicators is unpredictable.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### Storage/Storage Format

SD addr5.addr4



The address arguments generate the effective addresses of two operands in main storage. (See *Effective Address Generation* in Chapter 2.) Doubleword operand 1 is subtracted from doubleword operand 2. The result replaces operand 2. Operand 1 is unchanged.

#### Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the doubleword. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in the doubleword; i.e., if the difference is less than  $-2^{31}$  or greater than  $+2^{31}-1$ .

If an overflow occurs, the result contains the correct low-order 32 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

#### Set Address Key Register (SEAKR)

#### System Register/Storage Format

| Mnemonic             | Syntax | Instruction name          | K field |
|----------------------|--------|---------------------------|---------|
| SEAKR                | addr4  | Set Address Key Register  | 011     |
| Extended<br>Mnemonic | Syntax | Instruction name          | K field |
| SEISK                | addr4  | Set Instruction Space Key | 000     |
| SEOOK                | addr4  | Set Operand 1 Key         | 010     |
| SEOTK                | addr4  | Set Operand 2 Key         | 001     |

| 0 | pera | itio | n | code | T | K | 1 | RB | AM    | 1  | -<br>Tun | ctic | n  |
|---|------|------|---|------|---|---|---|----|-------|----|----------|------|----|
| 0 | 1    | 0    | 1 | 1    |   |   |   |    |       | 0  | 0        | 1    | 0  |
| 0 |      |      |   | 4    | 5 | 7 | 8 | 9  | 10 11 | 12 | ?        |      | 15 |

Address/Displacement 2 Displacement 1 Displacement 2 16 23 24 31

The address key register (AKR) field, specified by the K field, is loaded from the word location in main storage specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The K field can specify: (1) a field within the AKR, or (2) the entire AKR.

| K field | Address key register field name | Bits  |
|---------|---------------------------------|-------|
| 000     | Instruction space key           | 13-15 |
| 001     | Operand 2 key                   | 9–11  |
| 010     | Operand 1 key                   | 5-7   |
| 011     | Address key register            | 0-15  |
| 100     | Unused                          |       |
| 101     | Unused                          |       |
| 110     | Unused                          |       |
| 111     | Unused                          |       |
|         |                                 |       |

Unused K-field values should not be used to avoid future program obsolescence.

If the K field specifies a specific field within the AKR, bits 13-15 from the word location in main storage are loaded into the AKR field. If the K field specifies the entire AKR, bits 0-15 from the word location in main storage are loaded into the AKR.

The contents of the word in main storage are unchanged.

#### Indicators

All indicators are unchanged.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

**Specification Check.** Even byte boundary violation (indirect address).

#### System Register/Register Format

| Mnemonic             | Syntax | Instruction name          | K Field |
|----------------------|--------|---------------------------|---------|
| SEAKR                | reg    | Set Address Key Register  | 011     |
| Extended<br>Mnemonic | Syntax | Instruction name          | K Field |
| SEISK                | reg    | Set Instruction Space Key | 000     |
| SEOOK                | reg    | Set Operand 1 Key         | 010     |
| SEOTK                | reg    | Set Operand 2 Key         | 001     |
|                      |        |                           |         |

| Operation code |   |   |   |   | Γ | K R |   |    | Function |   |   |   |    |  |
|----------------|---|---|---|---|---|-----|---|----|----------|---|---|---|----|--|
| 0              | 1 | 1 | 1 | 1 |   |     |   |    | 1        | 0 | 0 | 1 | 0  |  |
| 0              |   |   |   | 4 | 5 | 7   | 8 | 10 | 11       | ! |   |   | 15 |  |

The address key register (AKR) field, specified by the K field, is loaded from the register specified by the R field. The contents of the register are unchanged. The K field can specify: (1) a field within the AKR, or (2) the entire AKR.

| K field | Address key register field name | Bits  |
|---------|---------------------------------|-------|
| 000     | Instruction space key           | 13-15 |
| 001     | Operand 2 key                   | 9-11  |
| 010     | Operand 1 key                   | 5-7   |
| 011     | Address key register            | 0-15  |
| 100     | Unused                          |       |
| 101     | Unused                          |       |
| 110     | Unused                          |       |
| 111     | Unused                          |       |

Unused K-field values should not be used to avoid future program obsolescence.

If the K field specifies a specific field within the AKR, bits 13-15 from the register specified by the R field are loaded into the AKR field. If the K field specifies the entire AKR, bits 0-15 from the specified register are loaded in the AKR.

#### Indicators

All indicators are unchanged.

#### **Program Check Condition**

Privilege Violate. Privileged instruction.

## SECON SEIMR

#### Set Console Data Lights (SECON)

SECON reg

| 0į | oera | itio | 7 | code | <u> </u> | · |   | Г | R2 |   | Fun | ctic | n |    |
|----|------|------|---|------|----------|---|---|---|----|---|-----|------|---|----|
| 0  | 1    | 1    | 1 | 1    | 0        | 0 | 0 |   |    | 1 | 0   | 0    | 0 | 0  |
| 0  |      |      |   | 4    | 5        |   | 7 | 8 | 10 | 1 | 1   |      |   | 15 |

The contents of the register specified by R2 are stored in the console data lights. The contents of the register are unchanged.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

If the Programmer console is not installed, the instruction performs no operation.

#### Indicators

All indicators are unchanged.

#### **Program Check Conditions**

Privilege Violate. Privileged instruction.

#### Set Interrupt Mask Register (SEIMR) SEIMR addr4

| Operation code |   |   |   | - |   |   | 1 | RB | AM | 1    | Function |   |   |    |
|----------------|---|---|---|---|---|---|---|----|----|------|----------|---|---|----|
| 0              | 1 | 0 | 1 | 1 | 0 | 0 | 0 |    |    |      | 0        | 0 | 0 | 0  |
| 0              |   |   |   | 4 | 5 |   | 7 | 8  | 9  | 10 1 | 1 12     | 2 |   | 15 |

| <u> </u> | Address/Displacement        | -!            |
|----------|-----------------------------|---------------|
|          | Displacement 1 Displacement | $\frac{1}{2}$ |
| 16       | 23 24                       | 31            |

Bits 0-3 of the word location in main storage specified by the effective address are loaded into the interrupt mask register. (*Effective Address Generation* is explained in Chapter 2.) Bits 4-15 of the word in main storage are not used. The contents of main storage are unchanged.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

The mask is represented in a bit significant manner as follows:

| Mask bit | Interrupt level |
|----------|-----------------|
| 0        | 0               |
| 1        | 1               |
| 2        | 2               |
| 3        | 3               |

A mask bit set to "1" indicates that the level is enabled. A mask bit set to "0" indicates that the level is disabled.

#### Indicators

All indicators are unchanged.

Program Check Conditions

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

### SEIND

#### Set Indicators (SEIND) reg

SEIND

| Γ | Operation code |   |   |   |   | 1 |   |   |   | R2 |    |    | Function |   |   |    |  |
|---|----------------|---|---|---|---|---|---|---|---|----|----|----|----------|---|---|----|--|
|   | )              | 1 | 1 | 1 | 0 | 0 | 0 | 0 |   |    |    | 0  | 1        | 1 | 1 | 1  |  |
| - | )              |   |   |   | 4 | 5 |   | 7 | 8 | į  | 10 | 11 |          |   |   | 15 |  |

Bits 0 through 4 of the register specified by the R2 field are loaded into bits 0 through 4 of the current level status register (indicators). Bits 5 through 15 of the register specified by R2 are ignored. Bits 5 through 15 of the level status register are unchanged.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

The following table shows the indicator bits of the level status register (LSR):

LSR bit Indicator 0 Even 1 Carry 2 Overflow Negative 3 4 Zero

Indicators Changed as specified by the R2 register.

**Program Check Conditions** 

#### Set Level Block (SELB)

Execution of the SELB instruction can cause the processor to change levels. Also, the processor may exit supervisor state. For additional information concerning the processor action when executing this instruction, refer to *Program Controlled Level Switching* in Chapter 3.

| eg,addr4 |
|----------|
|          |

| 0 | Operation code |   |   |   | Γ | R |   |   | RB AM |    | M  | Function |   |   |    |
|---|----------------|---|---|---|---|---|---|---|-------|----|----|----------|---|---|----|
| 0 | 1              | 0 | 1 | 1 |   |   |   |   |       | ]  |    | 0        | 1 | 1 | 0  |
| 0 |                |   |   | 4 | 5 |   | 7 | 8 | 9     | 10 | 11 | 12       |   |   | 15 |

This instruction loads a level status block (LSB), from 11 words of main storage, into the LSB for a selected level. The beginning location for the main storage LSB is specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) The contents of the storage locations are not changed.

The selected level is specified (binary encoded) in bits 14-15 of the R field register. Bits 1-13 of the register are not used and must be zero to avoid future code obsolescence.

#### Inhibit Trace (IT) Bit

Bit 0 of the register specified by the R field is the inhibit trace (IT) interrupt bit. If bit 0 is a one and the trace bit (bit 10) in the LSR of the target LSB is a one, then both the Set Level Block instruction and the instruction pointed to by the IAR in the target LSB are executed before trace interrupts are allowed. See *Programming Note 1*.

If bit 0 is zero and the trace bit in the LSR of the target LSB is a one, the Set Level Block instruction is executed and then trace interrupts are allowed.

The target LSB is defined by either (1) the effective address, if the in-process bit is set to one in the LSR of the main storage LSB and the specified R field level is higher than or equal to the current level, or (2) the currently active LSB when condition 1 is not met.

#### Level Status Block Format

| EA        | IAR        |
|-----------|------------|
|           | AKR        |
|           | LSR        |
|           | Register 0 |
|           | Register 1 |
|           | Register 2 |
|           | Register 3 |
|           | Register 4 |
|           | Register 5 |
|           | Register 6 |
| EA+20     | Register 7 |
| (+14 hex) |            |

EA=effective address

#### Format of Register Specified by R in Instruction

| IT | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0   | 0 | 0 | 0 | 0  | X         | X   |
|----|---|---|---|---|---|---|---|----|-----|---|---|---|----|-----------|-----|
| 0  | 1 |   |   |   |   |   |   |    |     |   |   |   | 13 | 14<br>*** | 15  |
|    |   |   |   |   |   |   |   | _  |     |   |   |   |    |           | *** |
|    |   |   |   |   |   |   |   | Le | vel | 0 |   |   |    | 0         | 0   |
|    |   |   |   |   |   |   |   | Le | vel | 1 |   |   |    | 0         | 1   |
|    |   |   |   |   |   |   |   | Le | vel | 2 |   |   |    | 1         | 0   |
|    |   |   |   |   |   |   |   | Le | vel | 3 |   |   |    | 1         | 1   |

#### Programming Notes.

- 1. The Set Level Block instruction with the IT bit equal to one should be used to return from the trace interrupt routine and from a class interrupt routine when the instruction causing the interrupt is to be reexecuted. This is necessary to prevent a double trace of the instruction.
- 2. If the Set Level Block instruction sets the current level in-process bit to zero and the current level trace bit to one, no trace interrupt occurs as the level is exited.
- 3. The registers, AKR, and LSR for the current level are not changed if the specified R field level is other than the current level.
- 4. If the AM field equals 01, the contents of the register specified by the RB field are incremented by 2.

#### Indicators

All indicators are unchanged if the specified level is other than the current level.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or level status block.

Privilege Violate. Privileged instruction.

**Specification Check.** Even byte boundary violation (indirect address or level status block address).

#### Set Storage Key (SESK)

Refer to Chapter 5 for a description of the storage protection mechanism:

SESK reg,addr4

| 0 | pe  | ra | tio | n | code | Γ | R |   | I | RB | A  | M  | F  | lun | ctic | m  |   |
|---|-----|----|-----|---|------|---|---|---|---|----|----|----|----|-----|------|----|---|
| 0 | _ 1 | L  | 0   | 1 | _1   |   |   |   |   |    |    |    | 0  | 1   | 0    | 0  |   |
| 0 |     |    |     |   | 4    | 5 |   | 7 | 8 | 9  | 10 | 11 | 12 |     |      | 1. | 5 |

|         | Address/Displ | acement      | <u> </u> |
|---------|---------------|--------------|----------|
| Displac | cement 1      | Displacement | t 2      |
| 16      | 2324          |              | 31       |

This instruction loads a storage key register with the contents of the byte location in main storage specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

The register specified by the R field contains the main storage block number for the storage key register to be loaded. (A storage key register is associated with every 2048 bytes of storage.) The block number is binary encoded in bits 0-4 of the register. Bits 5-15 are not used and must be zero to avoid future code obsolescence.

The format of the register specified by the R field is:



The format of the byte at the storage location is:



Bits 4-7 are the storage key and read-only bit for the selected storage block. Bits 0-3 are not used and must be zero to avoid future code obsolescence.

The contents of the storage location are unchanged.

#### Indicators

No indicators are changed.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

**Specification Check.** Even byte boundary violation (indirect address).

### SESR

#### Set Segmentation Register (SESR)

This instruction is invalid if the Storage Address Relocation Translator Feature is not installed. Chapter 6 describes the relocation translator feature and relocation addressing.

Refer to *Storage Mapping* in Chapter 6 for an example of loading segmentation registers.

SESR reg,addr4

|   |    | pera | itio | n c<br>1 | ode |   | R |      | ŀ  | RB   | AM              | $\begin{bmatrix} F \\ 0 \end{bmatrix}$ | un  | ctic | <i>n</i> |
|---|----|------|------|----------|-----|---|---|------|----|------|-----------------|----------------------------------------|-----|------|----------|
| 1 | 0  | 1    |      | 1        | 4   | 5 |   | 7    | 8  | 9    | 10 11           | Ľ                                      |     | 0    | 15       |
|   |    |      |      |          |     |   |   |      |    |      |                 |                                        |     |      |          |
| ſ |    |      | Di   | spla     |     |   |   | ss/L |    | lace | ement<br>Displa | cen                                    | nen | t 2  | <br>1    |
|   | 16 | _    |      | <u> </u> |     | - |   | 23   | 24 |      |                 |                                        |     |      | 31       |

This instruction loads a segmentation register with the contents of the doubleword location in main storage specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.)

The general register specified by the R field must contain, in bits 0-7, the number of the segmentation register to be loaded (0-255). This number is composed of:

- Three bits that correspond to an address-key value (0-7). These bits select a particular stack of segmentation registers.
- Five bits that correspond to the five high-order bits of a logical storage address. These bits provide a number (0-31) that selects a segmentation register within a stack.

Note that relocation addressing selects the identical segmentation register when the same logical storage address and address key combination are used by the program.

Bits 8-15 of the R field register are not used and must be set to zero to avoid future code obsolescence.

The format of the register specified by the R field is:



The format of the doubleword to be loaded into the segmentation register is:



0 0 0 0 0 0 0 0 0 0

Bits 0 through 12 contain the high-order 13 bits of the physical address used by the translator to select a 2K block of storage.

Bit 13, if a one, signifies that the contents of the segmentation register are valid, and translation can be performed. If an attempt is made to use a segmentation register with bit 13 set to zero, a program check interrupt occurs, with invalid storage address set in the PSW.

Bit 14, if a one, signifies that the block is read only. If an attempt is made to write into the block when bit 14 of the associated segmentation register is a one and while in problem state, a program check interrupt occurs, with protect check set in the PSW. When in supervisor state or on a cycle steal access, bit 14 is ignored. The contents of main storage are not changed.

Bits 15 through 31 are not used and must be set to zero to avoid future code obsolescence.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Function. Translator not installed.

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.



Scan Byte Field Equal and Decrement (SFED)

Scan Byte Field Equal and Increment (SFEN) SFED reg,(reg)

SFEN reg,(reg)



This instruction compares a field in main storage against a single byte contained in a register. This comparison is made one byte at a time. Register 7 contains the number of bytes to be compared. This number is decremented after each byte is compared.

The register specified by R1 contains, in bits 8-15, the single byte of operand 1. The register specified by R2 contains the starting address of operand 2. Operand 1 is subtracted from operand 2, but neither operand is changed.

After each byte is compared, the address in R2 is incremented or decremented (determined by bit 13 of the instruction). The operation terminates when either:

- 1. An equal condition is detected, or
- 2. The number of bytes specified in register 7 has been compared.

When an equality occurs, the address in the register specified by R2 points to the next operand to be compared, but the count in R7 is not updated.

Bit 11 of the instruction is not used and must be set to zero to avoid future code obsolescence.

See Compare Byte Field Equal and Decrement (CFED) and Compare Byte Field Equal and Increment (CFEN) for other versions of this machine instruction.

#### Notes.

- 1. Variable field length instructions can be interrupted. When this occurs and the interrupted level resumes operation, the processor treats the uncompleted instruction as a new instruction with the remaining byte count specified in register 7.
- 2. If the specified count in R7 is zero, the instruction performs no operation (no-op).

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the byte. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one byte; i.e., if the difference is less than  $-2^7$  or greater than  $+2^7-1$ .

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

**Invalid Storage Address.** Operand. The instruction is terminated.

**Protect Check.** Instruction fetch. The instruction is terminated.

### SFNED SFNEN

#### Scan Byte Field Not Equal and Decrement (SFNED)

#### Scan Byte Field Not Equal and Increment (SFNEN) SFNED reg,(reg)

SFNEN reg,(reg)



This instruction compares a field in main storage against a single byte contained in a register. This comparison is made one byte at a time. Register 7 contains the number of bytes to be compared. This number is decremented after each byte is compared.

The register specified by R1 contains, in bits 8-15, the single byte of operand 1. The register specified by R2 contains the starting address of operand 2. Operand 1 is subtracted from operand 2, but neither operand is changed. After each byte is compared, the address in R2 is incremented or decremented (determined by bit 13 of the instruction). The operation terminates when either:

- 1. An unequal condition is detected, or
- 2. The number of bytes specified in register 7 has been compared.

When an inequality occurs, the address in the register specified by R2 points to the next operand to be compared, but the count in R7 is not updated.

Bit 11 of the instruction is not used and must be set to zero to avoid future code obsolescence.

See Compare Byte Field Not Equal and Decrement (CFNED) and Compare Byte Field Not Equal and Increment (CFNEN) for other versions of this machine instruction.

#### Notes.

- 1. Variable field length instructions can be interrupted. When this occurs and the interrupted level resumes operation, the processor treats the uncompleted instruction as a new instruction with the remaining byte count specified in register 7.
- 2. If the specified count in R7 is zero, the instruction performs no operation (no-op).

#### Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the byte. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one byte; i.e., if the difference is less than  $-2^7$  or greater than  $+2^7-1$ .

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Operand. The instruction is terminated.

**Protect Check.** Instruction fetch. The instruction is terminated.

#### Shift Left Circular (SLC)

 $\bigcirc$ 

Immediate Count Format SLC cnt16,reg

| 0 | pera | tio | n co | ode |   | R | Count |    | Fun | ction |
|---|------|-----|------|-----|---|---|-------|----|-----|-------|
| 0 | 0    | 1   | 1    | 0   |   |   |       |    | 0 0 | 0     |
| 0 |      |     |      | 4   | 5 | 7 | 8     | 12 | 13  | 15    |

The bits in the register specified by the R field are shifted left by the number of bit positions specified in the count field. The bits shifted out of the high-order bit (bit 0) re-enter at the low-order bit (bit 15). A count of zero causes no shifting to take place.

Although the register to be shifted contains only 16 bits, shift count values of 0-31 may be specified. Shift counts greater than 16 lengthen the execution time and provide an effective shift of modulo 16.

#### Indicators

Carry and Overflow. Unchanged.

**Even, Negative, and Zero.** Changed to reflect the final contents of the register.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

Example:









#### Count in Register Format

SLC reg,reg

| [o] | pera | itio | n co | ode | RI |   | R2 | ?  | F  | unc | tion | n |    |
|-----|------|------|------|-----|----|---|----|----|----|-----|------|---|----|
| 0   | 1    | 1    | 1    | 0   |    |   |    |    | 1  | 0   | 0    | 0 | 0  |
| 0   |      |      |      | 4   | 5  | 7 | 8  | 10 | 11 | 1   |      |   | 15 |

The bits in the register specified by the R1 field are shifted left by the number of bits specified by the shift count. This count is obtained from bits 8 through 15 of the register specified by the R2 field.

The contents of the register specified by the R2 field are unchanged unless the R1 and R2 fields specify the same register. In this case, the register contents are shifted as specified.

Although the register to be shifted contains only 16 bits, shift count values of 0-255 may be specified. Shift counts greater than 16 lengthen the execution time and provide an effective shift of modulo 16.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the register specified by the R1 field.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

Example:



### **SLCD**

#### Shift Left Circular Double (SLCD)

Immediate Count Format

SLCD cnt31,reg

| 0 | pera | tio | n co | ode |   | R | Count | t  | Fu | nci | tion |
|---|------|-----|------|-----|---|---|-------|----|----|-----|------|
| 0 | 0    | 1   | 1    | 0   |   |   | l     |    | 1  | 0   | 0    |
| 0 |      |     |      | 4   | 5 | 7 | 8     | 12 | 13 |     | 15   |

The bits in the register pair specified by the R field and R+1 are shifted left by the number of bit positions specified in the count field.

Within the register pair, the register specified by the R field contains the high-order word (bits 0-15); the register specified by R+1 contains the low-order word (bits 16-31). The bits shifted out of the high-order bit (bit 0) re-enter at the low-order bit (bit 31).

If the count is zero, no shifting occurs. If the R field equals 7, registers 7 and 0 are used for the register pair.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the two registers.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

Example:





#### **Count in Register Format**

SLCD reg,reg

| O | pera | tio | n co | ode |   | R1 | Γ | R2 |    | F  | unc | tion | 1 |    |
|---|------|-----|------|-----|---|----|---|----|----|----|-----|------|---|----|
| 0 | 1    | 1   | 1    | 0   |   |    |   |    |    | 1  | 0   | 1    | 0 | 0  |
| 0 |      |     |      | 4   | 5 | 7  | 8 |    | 10 | 11 |     |      |   | 15 |

The bits in the register pair specified by the R1 field and R1+1 are shifted left by the number of bits specified by the shift count. This count is obtained from bits 8 through 15 of the register specified by the R2 field.

Within the register pair, the register specified by the R1 field contains the high-order word (bits 0-15); the register specified by R1+1 contains the low-order word (bits 16-31). The bits shifted out of the high-order bit (bit 0) re-enter at the low-order bit (bit 31).

If the count is zero, no shifting occurs. If the R1 field equals 7, registers 7 and 0 are used for the register pair.

The contents of the register specified by the R2 field are unchanged unless the R1 (or R1+1) and R2 fields specify the same register. In this case, the register contents are shifted as specified.

Although the registers to be shifted represent 32 bits, shift count values of 0-255 may be specified. Shift count values greater than 32 lengthen the execution time and provide an effective shift of modulo 32.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the two registers.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

Example:











Instructions 8-85

#### Shift Left Logical (SLL)

Immediate Count Format

SLL cnt16,reg

| 0 | pera | itio | n co | ode |   | R |   | Count |    | Fı | inci | tion |
|---|------|------|------|-----|---|---|---|-------|----|----|------|------|
| 0 | 0    | 1    | 1    | 0   | ĺ |   |   |       |    | 0  | 0    | 1    |
| 0 |      |      |      | 4   | 5 |   | 7 | 8     | 12 | 13 | •    | 15   |

The bits in the register specified by the R field are shifted left by the number of bit positions specified in the count field. The vacated low-order bit positions of the register are set to zero. A count of zero causes no shifting to take place.

Although the register to be shifted contains only 16 bits, shift count values of 0-31 may be specified. Shift counts greater than 17 lengthen the execution time of the shift instruction and provide an effective shift of 17.

#### Indicators

**Carry.** Set to reflect the last bit shifted out of bit 0. If the count is zero, the carry indicator is reset.

**Overflow.** First reset, then set to a one if the most significant bit in the register (bit 0) has changed during the operation.

Even, Carry, and Overflow. Changed to reflect the final contents of the register.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

### **Count in Register Format**

SLL reg,reg

| 0 | per | itio | n co | ođe | I | R1 | T | R2 |    | F  | 'unc | tio | n |    |
|---|-----|------|------|-----|---|----|---|----|----|----|------|-----|---|----|
| 0 | 1   | 1    | 1    | 0   |   |    |   |    |    | 1  | 0    | 0   | 0 | 1  |
| 0 |     |      |      | 4   | 5 | 7  | 8 |    | 10 | 11 | !    |     |   | 15 |

The bits in the register specified by the R1 field are shifted left by the number of bits specified by the shift count. This count is obtained from bits 8 through 15 of the register specified by the R2 field. The vacated low-order bits of the register specified by the R1 field are set to zero.

The contents of the register specified by the R2 field are unchanged unless the R1 and R2 fields specify the same register. In this case, the register contents are shifted as specified.

Although the register shifted contains only 16 bits, shift count values of 0-255 may be specified. Shift counts greater than 17 lengthen the execution time of the shift instruction and provide an effective shift of 17.

#### Indicators

**Carry.** Set to reflect the last bit shifted out of bit 0. If the count is zero, the carry indicator is reset.

**Overflow.** First reset, then set to a one if the most significant bit in the register (bit 0) has changed during the operation.

Even, Negative, and Zero. Changed to reflect the final contents of the register specified by the R1 field.

#### **Program Check Conditions**

#### Shift Left Logical Double (SLLD)

# $\mathbf{O}$

Immediate Count Format

| SLLD | cnt31,reg |
|------|-----------|
|      |           |

| [o] | pera | itio | n co | ode |   | R | Co | unt |    | Fu | nct | ion |
|-----|------|------|------|-----|---|---|----|-----|----|----|-----|-----|
| 0   | 0    | 1    | 1    | 0   |   |   |    |     |    | 1  | 0   | 1   |
| 0   |      |      |      | 4   | 5 | 7 | 8  |     | 12 | 13 |     | 15  |

The bits in the register pair specified by the R field and R+1 are shifted left by the number of bit positions specified in the count field. The vacated low-order bits of the register pair are set to zero.

Within the register pair, the register specified by the R field contains the high-order word (bits 0-15); the register specified by R+1 contains the low-order word (bits 16-31).

If the shift count is zero, no shifting occurs. If the R field equals 7, registers 7 and 0 are used for the register pair.

#### Indicators

Carry. Set to reflect the last bit shifted out of bit 0.

**Overflow.** First reset, then set to a one if the most significant bit in the register pair (bit 0) has changed during the operation.

Even, Negative, and Zero. Changed to reflect the final contents of the two registers.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

### Count in Register Format

SLLD reg,reg

| 0 | pera | itio | n co | ode |   | R1 | 1 | R2 | F  | unc | tio | n |    |
|---|------|------|------|-----|---|----|---|----|----|-----|-----|---|----|
| 0 | 1    | 1    | 1    | 0   |   |    |   |    | 1  | 0   | 1   | 0 | 1  |
| 0 |      |      |      | 4   | 5 | 7  | 8 | 10 | 11 |     |     |   | 15 |

The bits in the register pair specified by the R1 field and R1+1 are shifted left by the number of bit positions specified by the shift count. This count is obtained from bits 8 through 15 of the register specified by the R2 field. The vacated low-order bit positions of the register pair are set to zero.

Within the register pair, the register specified by the R1 field contains the high-order word (bits 0-15); the register specified by R1+1 contains the low-order word (bits 16-31).

If the shift count is zero, no shifting occurs. If the R1 field equals 7, registers 7 and 0 are used for the register pair.

The contents of the register specified by the R2 field are unchanged unless the R1 (or R1+1) and R2 fields specify the same register. In this case, the register contents are shifted as specified.

Although the registers to be shifted represent 32 bits, shift count values of 0-255 may be specified. Shift counts greater than 33 lengthen the execution time of the shift instruction and provide an effective shift of 33.

#### Indicators

Carry. Set to reflect the last bit shifted out of bit 0.

**Overflow.** First reset, then set to a one if the most significant bit in the register pair (bit 0) has changed during the operation.

Even, Negative, and Zero. Changed to reflect the final contents of the two registers.

**Program Check Conditions** 

# SLT SLTD

Shift Left and Test (SLT)

SLT reg,reg

| 0 | per | atio | n co | ode |   | R1 |   | R2 | F  | unc | tion | n |   |   |
|---|-----|------|------|-----|---|----|---|----|----|-----|------|---|---|---|
| 0 | 1   | 1    | 1    | 0   |   |    |   |    | 1  | 1   | 0    | 0 | 1 |   |
| 0 |     |      |      | 4   | 5 | 7  | 8 | 10 | 11 | !   |      |   | 1 | 5 |

The bits in the register specified by the R1 field are shifted left. The vacated low-order bit positions of the register are set to zero.

Shifting continues until either one of the following occurs:

- 1. The number of bits specified by the shift count have been shifted. This count is obtained from bits 8 through 15 of the register specified by the R2 field. No shifting occurs if the shift count is zero.
- 2. A one-bit is shifted from the high-order bit (bit 0) to the carry indicator. In this case, the remaining shift count is loaded into bits 8 through 15 of the register specified by the R2 field.

Bits 0 through 7 of the register specified by the R2 field are unchanged; these bits must be set to zero to avoid future code obsolescence.

If the R1 and R2 fields specify the same register, the bits in the register are shifted as specified and, when shifting is complete, the remaining shift count replaces the shifted result.

Although the register to be shifted contains only 16 bits, shift count values of 0-255 may be specified.

#### Indicators

**Carry.** Set to reflect the last bit shifted out of bit 0 of the R1 register. If the count is zero, the carry indicator is reset.

**Overflow.** First reset, then set to a one if the most significant bit (bit 0) in the register specified by the R1 field has changed during the operation.

**Even**, Negative, and Zero. Changed to reflect the final contents of the register specified by the R2 field.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

#### Shift Left and Test Double (SLTD)

SLTD reg,reg

| OĮ | pera | itio | n co | ode | R | 1 | R | 22 | F  | unc | tio | n |    |
|----|------|------|------|-----|---|---|---|----|----|-----|-----|---|----|
| 0  | 1    | 1    | 1    | 0   |   |   |   |    | 1  | 1   | 1   | 0 | 1  |
| 0  |      |      |      | 4   | 5 | 7 | 8 | 10 | 11 |     |     |   | 15 |

The bits in the register pair specified by the R1 field and R1+1 are shifted left. The vacated low-order bit positions of the register pair are set to zero.

Shifting continues until either one of the following occurs:

- The number of bits specified by the shift count have been shifted. This count is obtained from bits 8 through 15 of the register specified by the R2 field. No shifting occurs if the shift count is zero.
- 2. A one-bit is shifted from the high-order bit to the carry indicator. In this case, the remaining shift count is loaded into bits 8 through 15 of the register specified by the R2 field.

Bits 0 through 7 of the register specified by the R2 field are unchanged; these bits must be set to zero to avoid future code obsolescence.

Within the register pair, the register specified by the R1 field contains the high-order word (bits 0-15); the register specified by R1+1 contains the low-order word (bits 16-31). If the R1 field equals 7, registers 7 and 0 are used for the register pair.

If the R1 (or R1+1) and R2 fields specify the same register, the bits in the register are shifted as specified and, when shifting is complete, the remaining shift count replaces the shifted result.

Although the registers to be shifted contain only 32 bits, shift count values of 0-255 may be specified.

#### Indicators

Carry. Set to reflect the last bit shifted out of bit 0 of the R1 register. If the count is zero, the carry indicator is reset.

**Overflow.** First reset, then set to a one if the most significant bit (bit 0) in the register specified by the R1 field has changed during the operation.

Even, Negative, and Zero. Changed to reflect the final contents of the register specified by the R2 field.

**Program Check Conditions** 

#### Shift Right Arithmetic (SRA)

Immediate Count Format SRA cnt16,reg

| $\overline{O_l}$ | Operation code |   |   |   | <u> </u> | R |   | Count |    | Fu | nci | tion |
|------------------|----------------|---|---|---|----------|---|---|-------|----|----|-----|------|
| 0                | 0              | 1 | 1 | 0 |          |   |   |       |    | 0  | 1   | 1    |
| 0                |                |   |   | 4 | 5        |   | 7 | 8     | 12 | 13 |     | 15   |

The bits in the register specified by the R field are shifted right by the number of bit positions specified in the count field. The value of the sign (the high-order bit) is entered into the vacated high-order bit positions of the register specified by the R field. If the shift count is zero, no shifting takes place.

Although the register to be shifted contains only 16 bits, shift count values of 0-31 may be specified. Shift counts greater than 16 lengthen the execution time of the shift instruction and provide an effective shift of 16.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the register.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

#### Count in Register Format

SRA reg,reg

| O1 | bera | Operation code |   |   |   | R1 |   | R2 | F  | unc | tio | n |    |
|----|------|----------------|---|---|---|----|---|----|----|-----|-----|---|----|
| 0  | 1    | 1              | 1 | 0 |   |    |   |    | 1  | 0   | 0   | 1 | 1  |
| 0  |      |                |   | 4 | 5 | 7  | 8 | 10 | 11 | !   |     |   | 15 |

The bits in the register specified by the R1 field are shifted right by the number of bit positions specified by the shift count. This count is obtained from bits 8 through 15 of the register specified by the R2 field. The value of the sign (the high-order bit) is entered into the vacated high-order bit positions of the register specified by the R1 field. If the shift count is zero, no shifting takes place.

The contents of the register specified by the R2 field are unchanged unless the R1 and R2 fields specify the same register. In this case, the register contents are shifted as specified.

Although the register to be shifted is 16 bits, shift count values of 0-255 may be specified. Shift counts greater than 16 lengthen the execution time of the shift instruction and provide an effective shift of 16.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the register specified by the R1 field.

#### **Program Check Conditions**

Shift Right Arithmetic Double (SRAD)

Immediate Count Format

SRAD cnt31,reg

| 0 | pera | itio | n co | ode |   | R | Count |    | Fı | inci | tion |
|---|------|------|------|-----|---|---|-------|----|----|------|------|
| 0 | 0    | 1    | 1    | 0   |   |   |       |    | 1  | 1    | 1    |
| 0 |      |      |      | 4   | 5 | 7 | 8     | 12 | 13 | 2    | 15   |

The bits in the register pair specified by the R field and R+1 are shifted right by the number of bit positions specified in the count field. The value of the sign (the high-order bit) is entered into the vacated high-order bit positions of the register pair.

Within the register pair, the register specified by the R field contains the high-order word (bits 0-15); the register specified by R+1 contains the low-order word (bits 16-31).

If the shift count is zero, no shifting occurs. If the R field equals 7, registers 7 and 0 are used for the register pair.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the register pair.

**Program Check Conditions** 

Protect Check. Instruction fetch.

#### Count in Register Format SRAD reg,reg

| $[o_i]$ | pera | tio | n co | ode | R | 1 | L I | R2 |   | F  | unc | tio | 1 |    |
|---------|------|-----|------|-----|---|---|-----|----|---|----|-----|-----|---|----|
| 0       | 1    | 1   | 1    | 0   | ł |   |     |    |   | 1  | 0   | 1   | 1 | 1  |
| 0       |      |     |      | 4   | 5 | 7 | 8   | 1  | 0 | 11 |     |     |   | 15 |

The bits in the register pair specified by the R1 field and R1+1 are shifted right by the number of bit positions specified by the shift count. This count is obtained from bits 8 through 15 of the register specified by the R2 field. The value of the sign (the high-order bit) is entered into the vacated high-order bit positions of the register pair.

Within the register pair, the register specified by the R1 field contains the high-order word (bits 0-15); the register specified by R1+1 contains the low-order word (bits 16-31).

If the shift count is zero, no shifting occurs. If the R field equals 7, registers 7 and 0 are used for the register pair.

The contents of the register specified by the R2 field are unchanged unless the R1 (or R1+1) and R2 fields specify the same register. In this case, the register contents are shifted as specified.

Although the registers to be shifted represent 32 bits, shift count values of 0-255 may be specified. Shift counts greater than 32 lengthen the execution time of the shift instruction and provide an effective shift of 32.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the register pair.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

8-90 GA34-0021

#### Shift Right Logical (SRL)

#### Immediate Count Format SRL cnt16,reg

| 0 | pera | itio | n co | ode |   | R | Count | Fund  | ction |
|---|------|------|------|-----|---|---|-------|-------|-------|
| 0 | 0    | 1    | 1    | 0   |   |   |       | 0 1   | 0     |
| 0 |      |      |      | 4   | 5 | 7 | 8     | 12 13 | 15    |

The bits in the register specified by the R field are shifted right by the number of bit positions specified in the count field. The vacated high-order bit positions of the register are set to zero. A count of zero causes no shifting to take place.

Although the register to be shifted contains only 16 bits, shift count values of 0-31 may be specified. Shift counts greater than 16 lengthen the execution time of the shift instruction and provide an effective shift of 16.

#### Indicators

Carry and Overflow. Unchanged.

**Even**, Negative, and Zero. Changed to reflect the final contents of the register.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

#### Count in Register Format

SRL reg,reg

| O | peration code |   |   |   |   | R1 | 1 | R2 | F  | unc | tio | 1 |    |
|---|---------------|---|---|---|---|----|---|----|----|-----|-----|---|----|
| 0 | 1             | 1 | 1 | 0 |   |    |   |    | 1  | 0   | 0   | 1 | 0  |
| 0 |               |   |   | 4 | 5 | 7  | 8 | 10 | 11 |     |     |   | 15 |

The bits in the register specified by the R1 field are shifted right by the number of bit positions specified by the shift count. This count is obtained from bits 8 through 15 of the register specified by the R2 field. The vacated highorder bit positions of the register specified by the R1 field are set to zero. A count of zero causes no shifting to take place.

The contents of the register specified by the R2 field are unchanged unless the R1 and R2 fields specify the same register. In this case, the register contents are shifted as specified.

Although the register to be shifted contains only 16 bits, shift count values of 0-255 may be specified. Shift counts greater than 16 lengthen the execution time of the shift instruction and provide an effective shift of 16.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the register specified by the R1 field.

#### **Program Check Conditions**

#### Shift Right Logical Double (SRLD)

Immediate Count Format

SRLD cnt31,reg

| 0  | Operation code |   |   |   | Γ | R | 10 | Count |    | Fu | inc | tion |
|----|----------------|---|---|---|---|---|----|-------|----|----|-----|------|
| 0  | 0              | 1 | 1 | 0 |   |   |    |       |    | 1  | 1   | 0    |
| ·0 |                |   |   | 4 | 5 | 7 | 8  |       | 12 | 13 | ,   | 15   |

The bits in the register pair specified by the R field and R+1 are shifted right by the number of bit positions specified in the count field. The vacated high-order bits of the register pair are set to zero.

Within the register pair, the register specified by the R field contains the high-order word (bits 0-15); the register specified by R+1 contains the low-order word (bit 16-31).

If the shift count is zero, no shifting occurs. If the R field equals 7, registers 7 and 0 are used for the register pair.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the final contents of the register.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

#### Count in Register Format SRLD reg,reg

| ſ | Operation code |   |   |  |   |   |   | R1 |   | Γ | R2 |    | F  | unc | tio | n |    |
|---|----------------|---|---|--|---|---|---|----|---|---|----|----|----|-----|-----|---|----|
|   | 0              | 1 | 1 |  | 1 | 0 |   |    |   |   |    |    | 1  | 0   | 1   | 1 | 0  |
| • | 0              |   |   |  |   | 4 | 5 |    | 7 | 8 |    | 10 | 11 |     |     |   | 15 |

The bits in the register pair specified by the R1 field and R1+1 are shifted right by the number of bit positions specified by the shift count. This count is obtained from bits 8 through 15 of the register specified by the R2 field. The vacated high-order bits of the register pair are set to zero.

Within the register pair, the register specified by the R1 field contains the high-order word (bits 0-15); the register specified by R1+1 contains the low-order word (bits 16-31).

If the shift count is zero, no shifting occurs. If the R1 field equals 7, registers 7 and 0 are used for the register pair.

The contents of the register specified by the R2 field are unchanged unless the R1 (or R1+1) and R2 fields specify the same register. In this case, the register contents are shifted as specified.

Although the registers to be shifted represent 32 bits, shift count values of 0-255 may be specified. Shift counts greater than 32 lengthen the execution time of the shift instruction and provide an effective shift of 32.

#### Indicators

Carry and Overflow. Unchanged.

**Even, Negative, and Zero.** Changed to reflect the final contents of the register pair.

#### **Program Check Conditions**



#### Store Multiple (STM)

Refer to *Stack Operations* in Chapter 2 for additional information about the operation of this instruction. The STM instruction is used in conjunction with the Load Multiple and Branch (LMB) instruction described previously in this chapter.

STM reg,addr4[,abcnt]

Format without appended word for effective addressing  $(\Delta M = 0.0 \text{ or } 0.1)$ 

| au      | ure            | ssm | g (2 | 1141 | - 0 | 0.01 | 01 | ) |   |       |    |     |      |    |
|---------|----------------|-----|------|------|-----|------|----|---|---|-------|----|-----|------|----|
| $[O_l]$ | Operation code |     |      |      |     |      |    | R | B | AM    | F  | unc | tion | n  |
| 0       | 1              | 0   | 0    | 0    | 0   | 0    | 0  |   |   |       | 1  | 0   | 0    | 0  |
| 0       |                |     |      | 4    | 5   |      | 7  | 8 | 9 | 10 11 | 12 | 2   |      | 15 |



Format with appended word for effective

| addressing | (AM = 1) | 0 or 11 | ) |
|------------|----------|---------|---|
|            |          |         |   |

| 0Į | oera | tio | n co | ode |   |   |   | R | B | AM    | F  | unc | tior | 1  |
|----|------|-----|------|-----|---|---|---|---|---|-------|----|-----|------|----|
| 0  | 1    | 0   | 0    | 0   | 0 | 0 | 0 |   |   |       | 1  | 0   | 0    | 0  |
| 0  |      |     |      | 4   | 5 |   | 7 | 8 | 9 | 10 11 | 12 | ?   |      | 15 |



| RL |       | N |
|----|-------|---|
|    |       |   |
| 32 | 34 35 | 4 |

The STM instruction stores the contents of a specified number of registers for the current level into a stack. This stack is defined by the stack control block pointed to by the effective address. (Effective Address Generation is explained in Chapter 2.)

The RL field specifies the last register to be stored. Register 7 is stored first, then registers 0 through the register specified by RL. If RL specifies register 7, only register 7 is stored.

The N field specifies the number of words to be allocated in the stack as a dynamic work area. A value of zero is valid.

The new top element address of the stack (incremented by two) is loaded into the last register stored; that is, the register specified by RL. This address points to the low storage end of the dynamic work area (or the last register stored if N=0).

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

*Programming Note.* If the AM field equals 01, the contents of the register specified by the RB field are incremented by 2.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or stack control block.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. A partial data transfer occurs if the area of the stack being accessed crosses a protection boundary.

**Specification Check.** Even byte boundary violation (indirect address, stack control block, or stack element).

#### Soft Exception Trap Condition

#### Stack Exception.

- 1. Stack is full.
- 2. Stack cannot contain the number of words to be stored; that is:
  - a. Number of words specified by the N field, plus
  - b. The number of registers to be moved, plus
  - c. One control word.

If the AM field equals 01, the contents of the register specified by the RB field are incremented.

### STOP SVC

### Stop (STOP)

STOP [ubyte]

| Operation code |  |  |  | $F\iota$ | inct | tion | Parameter |   |    |
|----------------|--|--|--|----------|------|------|-----------|---|----|
|                |  |  |  | 0        |      |      |           |   |    |
| 0              |  |  |  | 4        | 5    |      | 7         | 8 | 15 |

The parameter field is ignored by the hardware, and may be used for software flags or indicators.

This instruction is executed only when the Programmer Console is installed and the Mode switch is in the Diagnostic position. Otherwise this instruction performs no operation (no-op). The processor enters the stop state following execution of this instruction. The indicators are unchanged.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

#### Supervisor Call (SVC)

Execution of this instruction causes a *class interrupt*. Additional information appears in Chapter 3.

SVC ubyte

| Operation code |   |   |   |   | Fu | nct | ion | Parameter |    |
|----------------|---|---|---|---|----|-----|-----|-----------|----|
| 0              | 1 | 1 | 0 | 0 | 0  | 0   | 0   |           |    |
| 0              |   |   |   | 4 | 5  |     | 7   | 8         | 15 |

The instruction address register is incremented by two: the current level status block (LSB) is stored, using an address key of zero, starting at the main storage location specified by the contents of the SVC LSB pointer that resides in main storage location 0010 hexadecimal. The instruction also causes the following events:

- The summary mask (LSR bit 11) is disabled.
- Supervisor state (LSR bit 8) is turned on.
- Trace (LSR bit 10) is turned off.
- Equate operand spaces (AKR bit 0) is turned off.
- Operand 2 key contents are loaded into the operand 1 key.
- Then the operand 2 key and the instruction space key are set to zero.

The parameter field (bits 8-15) is under control of the Programming System. This field is loaded into the low-order byte of register 1. The high-order byte of register 1 is set to zero.

Subsequently, the contents of main storage location 0012 hexadecimal (SVC start instruction address) are loaded into the instruction address register, becoming the address of the next instruction to be fetched.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

**Specification Check.** LSB pointer or SIA pointer. The instruction is terminated.

Subtract Word (SW)

Register/Register Format SW reg,reg

| 0 | Operation code |   |   |   | Γ | R1 | Γ | R2 | F    | Function |   |   |    |  |
|---|----------------|---|---|---|---|----|---|----|------|----------|---|---|----|--|
| 0 | 1              | 1 | 1 | 0 |   |    |   |    | 0    | 1        | 0 | 1 | 0  |  |
| 0 |                |   |   | 4 | 5 | 7  | 8 | 1  | 0 11 | !        |   |   | 15 |  |

The contents of the register specified by the R1 field are subtracted from the contents of the register specified by the R2 field. The result is placed in the register specified by the R2 field. The contents of the register specified by the R1 field remain unchanged unless R1 and R2 specify the same register.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the register. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct loworder 16 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

**Register/Storage Format** 

reg,addr4 addr4,reg

SW



| Γ  | _ | Address/L      | Displacement                          |
|----|---|----------------|---------------------------------------|
| Ľ  | _ | Displacement 1 | Displacement 2                        |
| 16 | i | 23             | $\frac{1}{24}$ $       \overline{31}$ |

A subtract operation is performed between the register specified by the R field and the location specified by the effective address in main storage. (See *Effective Address Generation* in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged.

#### Indicators

**Carry**. Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct loworder 16 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

#### Storage to Register Long Format SW longaddr.reg



The contents of the main storage word location specified by an effective address are subtracted from the contents of the register specified by the R1 field. The result is placed in the register specified by the R1 field.

The effective main storage address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field. If the R2 field equals zero, no register contributes to the address generation.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0 (direct address). The result from step 1 is the effective address.

Bit 11=1 (indirect address). The result from step 1 is the address of the main storage location that contains the effective address.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct loworder 16 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

### Storage/Storage Format

SW addr5,addr4



The address arguments generate the effective addresses of two operands in main storage. (See *Effective Address Generation* in Chapter 2.) Word operand 1 is subtracted from word operand 2. The result replaces operand 2.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct loworder 16 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

**Invalid Storage Address.** Instruction word or operand. The instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

**Protect Check.** Instruction fetch, operand access, or operand store. For instruction fetch or operand access, the instruction is terminated. If AM1 equals 01 and the operand 2 effective address is invalid, RB1 is incremented.

For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

#### Subtract Word With Carry (SWCY)

SWCY reg,reg

|   |      |      |      |     |   |    |   | •  |    |    | _   |     |   |    |
|---|------|------|------|-----|---|----|---|----|----|----|-----|-----|---|----|
| 0 | pera | itio | n co | ode |   | R1 |   | R2 |    | F  | unc | tio | n |    |
| 0 | 1    | 1    | 1    | 0   |   |    |   |    |    | 0  | 1   | 0   | 1 | 1  |
| 0 |      |      |      | 4   | 5 | 7  | 8 |    | 10 | 11 |     |     |   | 15 |

If the carry indicator is on at entry (denoting a borrow), a positive one is subtracted from the contents of the register specified by the R2 field. Then the contents of R1 are subtracted from the intermediate result. If the carry indicator is off at entry, the contents of R1 are subtracted from the contents of the register specified by R2. The contents of the register specified by the R1 field are unchanged unless R1 and R2 specify the same register. The final result replaces the contents of the register specified by the R2 field.

Programming Note. This instruction can be used when subtracting multiple word operands. See Indicators – Multiple Word Operands in Chapter 2.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct loworder 16 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even. Unchanged.

Zero. If on at entry, set to reflect the result. If off at entry, remains off.

Negative. Changed to reflect the result.

**Program Check Conditions** 

#### Subtract Word Immediate (SWI)

# Register Immediate Long FormatSWIword,reg[,reg]



The immediate field is subtracted from the contents of the register specified by the R1 field. The result is placed in the register specified by the R2 field. The contents of the register specified by the R1 field are unchanged unless R1 and R2 specify the same register.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct loworder 16 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word.

Protect Check. Instruction fetch.

#### Storage Immediate Format SWI word,addr4

Format without appended word for effective addressing (AM = 00 or 01)

| Оре       | era  | tior | n co | de   |     |      |      | R          | B    | AM       | Ft  | unc | tior | 1  |
|-----------|------|------|------|------|-----|------|------|------------|------|----------|-----|-----|------|----|
| 0         | 1    | 0    | 0    | 0    | 0   | 0    | 0    |            |      |          | 1   | 1   | 1    | 0  |
| 0         |      |      |      | 4    | 5   | _    | 7    | 8          | 9    | 10 11    | 12  |     |      | 1. |
|           |      |      |      | ,    |     | In   | ime  | diat       | e    |          |     |     |      |    |
|           |      |      |      |      |     |      |      |            |      |          |     |     |      |    |
| 16        |      |      |      |      | -   |      |      |            |      |          |     |     |      | 3. |
|           |      |      |      |      | •   |      | ·    |            | or   | effectiv | e   |     |      |    |
| add       | Ires | ssin | g (A | ١M   | = 1 | 0 01 | r 11 | .)         |      |          |     | _   |      |    |
| Op        | era  | tio  | n co | de   |     |      |      | <i>R</i> . | B    | AM       | F   | unc | tior | 1  |
| 0         | 1    | 0    | 0    | 0    | 0   | 0    | 0    |            |      |          | 1   | 1   | 1    | 0  |
| 0         |      |      | 2    | 4    | 5   |      | 7    | 8          | 9    | 10 11    | 12  |     |      | 1. |
|           | _    |      |      |      | Ad  | dre  | ss/L | Dispi      | lace | ement    |     |     |      |    |
|           |      | Di   | spla | icei | nen | it 1 |      | Ι-         | _    | Displa   | cer | nen | t 2  |    |
| 16        |      | •    |      |      |     |      | 23   | 3 24       |      |          |     |     |      | 3  |
| · · · · · |      |      |      |      |     | In   | ime  | diat       | P    |          |     |     |      |    |
|           |      |      |      |      |     | 111  |      |            | ·    |          |     |     |      |    |
| 32        |      |      |      |      |     |      |      |            |      |          |     |     |      | 4  |

The immediate field is subtracted from the contents of the main storage location specified by the effective address. (See *Effective Address Generation* in Chapter 2.) The result replaces the contents of the storage location specified by the effective address.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

The immediate operand is unchanged.

#### Indicators

**Carry.** Turned on by the detection of a borrow beyond the high-order bit position of the word. If no borrow is detected, the carry indicator is reset.

**Overflow.** Cleared, then turned on if the difference cannot be represented in one word; i.e., if the difference is less than  $-2^{15}$  or greater than  $+2^{15}-1$ .

If an overflow occurs, the result contains the correct loworder 16 bits of the difference; the carry indicator contains the complement of the high-order (sign) bit.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

#### Test Bit (TBT)

TBT (reg, bitdisp)

| 0 | peri | atio | n co | ode | Γ | R | _ | Fu | in | Bit di | splacement |
|---|------|------|------|-----|---|---|---|----|----|--------|------------|
| 0 | 1    | 0    | 0    | 1   |   |   |   | 0  | 0  |        |            |
| 0 |      |      |      | 4   | 5 |   | 7 | 8  | 9  | 10     | 1:         |

The bit displacement is added to the byte address contained in the register specified by the R field to form an effective bit address. The bit displacement field is an unsigned sixbit binary integer. The bit at the effective bit address is tested, and the zero and negative indicators are set to reflect the result.

#### Indicators

Zero and Negative. First reset, then set as follows:

| Value of   | Indicators |          |  |  |  |  |  |
|------------|------------|----------|--|--|--|--|--|
| tested bit | Zero       | Negative |  |  |  |  |  |
| 0          | 1          | 0        |  |  |  |  |  |
| 1          | 0          | 1        |  |  |  |  |  |

Even, Carry, and Overflow. Unchanged.

#### **Program Check Conditions**

Invalid Storage Address. Operand.

Protect Check. Instruction fetch or operand access.

#### Test Bit and Reset (TBTR)

TBTR (reg,bitdisp)

| 0 | Operation code |   |   |   |   | R |   | $F\iota$ | in | Bit | displacement |
|---|----------------|---|---|---|---|---|---|----------|----|-----|--------------|
| 0 | 1              | 0 | 0 | 1 |   |   |   | 1        | 0  |     | [            |
| 0 |                |   |   | 4 | 5 |   | 7 | 8        | 9  | 10  | 15           |

The bit displacement is added to the byte address contained in the register specified by the R field to form an effective bit address. The bit displacement field is an unsigned sixbit integer.

The bit at the effective address is tested, and the zero and negative indicators are set to reflect the result.

Following the preceding test, the addressed bit is *unconditionally set to zero*.

#### Indicators

Zero and Negative. First reset, then set as follows:

| Value of   | Indicators |          |  |  |  |  |
|------------|------------|----------|--|--|--|--|
| tested bit | Zero       | Negative |  |  |  |  |
| 0          | 1          | 0        |  |  |  |  |
| 1          | 0          | 1        |  |  |  |  |

Even, Carry, and Overflow. Unchanged.

#### **Program Check Conditions**

Invalid Storage Address. Operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

## TBTS TBTV

#### Test Bit and Set (TBTS)

TBTS (reg,bitdisp)

| 0 | Operation code |   |   |   |   | R |   |   | in | Bit displace | lisplacement |
|---|----------------|---|---|---|---|---|---|---|----|--------------|--------------|
| 0 | 1              | 0 | 0 | 1 |   |   |   | 0 | 1  |              |              |
| 0 |                |   |   | 4 | 5 |   | 7 | 8 | 9  | 10           | 1:           |

The bit displacement is added to the byte address contained in the register specified by the R field to form an effective bit address. The bit displacement field is an unsigned sixbit binary integer.

The bit at the effective address is tested, and the zero and negative indicators are set to reflect the result.

Following the preceding test, the addressed bit is *unconditionally set to one*.

#### Indicators

Zero and Negative. First reset, then set as follows:

| Value of   | Indicators |          |  |  |  |  |  |
|------------|------------|----------|--|--|--|--|--|
| tested bit | Zero       | Negative |  |  |  |  |  |
| 0          | 1          | 0        |  |  |  |  |  |
| 1          | 0          | 1        |  |  |  |  |  |

Even, Carry, and Overflow. Unchanged.

#### **Program Check Conditions**

Invalid Storage Address. Operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

### Test Bit and Invert (TBTV)

TBTV (reg,bitdisp)

| $O_l$ | Operation code |   |   |   | R | Ft | ın | Bit d | lisplace | nent |    |
|-------|----------------|---|---|---|---|----|----|-------|----------|------|----|
| 0     | 1              | 0 | 0 | 1 |   |    | 1. | 1     |          |      |    |
| 0     |                |   |   | 4 | 5 | 7  | 8  | 9     | 10       |      | 15 |

The bit displacement is added to the byte address contained in the register specified by the R field to form an effective bit address. The bit displacement field is an unsigned sixbit binary integer.

The bit at the effective address is tested, and the zero and negative indicators are set to reflect the result.

Following the preceding test, the addressed bit is *unconditionally inverted*.

#### Indicators

Zero and Negative. First reset, then set as follows:

| Value of   | Indicators |          |  |  |  |  |
|------------|------------|----------|--|--|--|--|
| tested bit | Zero       | Negative |  |  |  |  |
| 0          | 1          | 0        |  |  |  |  |
| 1          | 0          | 1        |  |  |  |  |

Even, Carry, and Overflow. Unchanged.

Program Check Conditions

Invalid Storage Address. Operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

#### Test Word Immediate (TWI)

# )

#### Register Immediate Long Format TWI word,reg



The contents of the register specified by the R1 field are tested against the mask contained in the immediate word of the instruction. The contents of the register specified by the R1 field are not changed.

Mask bits set to one select the bits to be tested in the register.

#### Example:

| Mask          | 0000 0000 0101 1100 |
|---------------|---------------------|
| Register      | 0000 0000 0011 0101 |
| Selected bits | 0 1 01              |

The selected bits are tested for the following: (1) all bits zero, (2) all bits ones, or (3) a combination of one and zero bits (mixed). The zero and negative indicators are set to reflect the result as shown under *Indicators*.

Instruction bits 8 through 10 are not used and must be set to zero to avoid future code obsolescence.

#### Indicators

Zero and Negative. Reset, then set as follows:

|               | Indica | ators        |
|---------------|--------|--------------|
| Selected bits | Zero   | Negative     |
| All zeros*    | 1      | 0            |
| All ones      | 0      | 1            |
| Mixed         | 0      | 0 (positive) |

\*Also applies when the mask bits are all zeros.

Even, Carry, and Overflow. Unchanged.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch.

#### Storage Immediate Format

TWI word,addr4

Format without appended word for effective addressing ( $\Delta M = 0.0 \text{ or } 0.1$ )

| Operation code 0 1 0 0 0 |   |   |   |   |   |   |    | R  | B | AM    | Fı | inc | tio | n  |
|--------------------------|---|---|---|---|---|---|----|----|---|-------|----|-----|-----|----|
| 0                        | 1 | 0 | 0 | 0 | 0 | 0 | 0  |    |   |       | 1  | 0   | 1   | 1  |
| 0                        |   |   |   | 4 | 5 |   | 7  | 8  | 9 | 10 11 | 12 |     |     | 15 |
|                          |   |   |   |   |   |   | Ма | sk |   |       |    |     |     |    |
| 16                       |   |   |   |   |   |   |    |    |   |       |    |     |     | 31 |

Format with appended word for effective

| ad             | dre | ssin | ıg ( <i>1</i> | ٩M   | = 10 | ) 01 | : 11 | )    |      |          |       |      |    |
|----------------|-----|------|---------------|------|------|------|------|------|------|----------|-------|------|----|
| Operation code |     |      |               |      |      |      | RB   |      | AM   | Function |       |      |    |
| 0              | 1   | 0    | 0             | 0    | 0    | 0    | 0    |      |      |          | 1 0   | 1    | 1  |
| 0              |     |      |               | 4    | 5    |      | 7    | 8    | 9    | 10 11    | 12    |      | 15 |
|                |     |      |               |      | Ad   | idre | ess/ | Dis  | plac | ement    |       |      |    |
|                |     | D    | ispl          | acer | nen  | t 1  |      | T-   |      | Displa   | cemer | nt 2 | _  |
| 16             |     |      |               |      |      |      | 23   | 3 24 | 1    |          |       |      | 31 |
|                |     |      |               |      |      |      | M    | ask  |      |          |       |      |    |
| 32             |     |      |               |      |      |      |      |      |      |          |       |      | 47 |

The contents of the storage location specified by the effective address are tested against the mask in the immediate word of the instruction. (*Effective Address Generation* is explained in Chapter 2.) Both operands remain unchanged.

Mask bits set to one select the bits to be tested in the storage operand.

#### Example:

| Mask            | 0000 0000 0000 | 1110 |
|-----------------|----------------|------|
| Storage operand | 0000 0000 0101 | 1110 |
| Selected bits   |                | 111  |

The selected bits are tested for the following: (1) all bits zeros, (2) all bits ones, or (3) a combination of one and zero bits (mixed). The zero and negative indicators are set to reflect the result as shown under *Indicators*.

Bits 5-7 of the instruction are not used and must be set to zero to avoid future code obsolescence.

#### Indicators

Zero and Negative. Reset, then set as follows:

|               | Indice | ators        |
|---------------|--------|--------------|
| Selected bits | Zero   | Negative     |
| All zeros*    | 1      | 0            |
| All ones      | 0      | 1            |
| Mixed         | 0      | 0 (positive) |

\*Also applies when the mask bits are all zeros.

Even, Carry, and Overflow. Unchanged.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

#### Invert Register (VR)

VR reg[,reg]

| 0 | pera | atio. | n co | ode |   | RI |   |   | R2 |    | F  | unc | tio | n |    |
|---|------|-------|------|-----|---|----|---|---|----|----|----|-----|-----|---|----|
| 0 | 1    | 1     | 1    | 0   |   |    |   |   |    |    | 0  | 1   | 1   | 0 | 1  |
| 0 |      |       |      | 4   | 5 |    | 7 | 8 |    | 10 | 11 |     |     |   | 15 |

The contents of the register specified by the R1 field are one's complemented. The result is placed in the register specified by the R2 field. The contents of the register specified by the R1 field are unchanged.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

#### Exclusive OR Byte (XB)

XB reg,addr4 addr4,reg



|    |                | Displaceme | nt       | !    |
|----|----------------|------------|----------|------|
|    | Displacement 1 | Dis        | placemer | 11 2 |
| 16 |                | 24         |          | 31   |

A logical exclusive OR operation is performed between the least significant byte of the register specified by the R field and the main storage location specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged. Also, when going from storage to register, bits 0-7 of the register are unchanged.

#### Example of Exclusive OR Byte:

| Register contents | 0000 1010 1100 0011 |
|-------------------|---------------------|
| Storage operand   | 0110 0101           |
| Result            | 1010 0110           |

Rule: Either but not both bits.

#### Indicators

Carry and Overflow. Unchanged.

**Even, Negative, and Zero.** Changed to reflect the result of the exclusive OR operation.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

**Specification Check.** Even byte boundary violation (indirect address).

#### Exclusive OR Doubleword (XD)

XD

reg,addr4 addr4,reg





A logical exclusive OR operation is performed between the contents of the register pair specified by the R field (R and R+1) and the doubleword in main storage specified by the effective address. (*Effective Address Generation* is explained in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged.

If the R field equals 7, registers 7 and 0 are used as the register pair.

#### Example of Exclusive OR Doubleword:

| Register pair contents | 0000 0000 1010 1100 0000 0000 1110 1111 |
|------------------------|-----------------------------------------|
| Storage operand        | 0000 0000 1101 0011 0000 0000 1101 0000 |
| Result                 | 0000 0000 0111 1111 0000 0000 0011 1111 |

Rule: Either but not both bits.

#### Indicators

Carry and Overflow. Unchanged.

**Even**, Negative, and Zero. Changed to reflect the result of the exclusive OR operation.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. If the doubleword location specified by the effective address crosses a read-only protection boundary, partial data may be stored into the non read-only protected area. The status of the even, negative, and zero indicators is unpredictable.

#### Exclusive OR Word (XW)

#### **Register/Register Format**

XW reg,reg

| Operation code |   |   |   | R | 1 | R2 | F | Function |      |   |   |   |    |   |
|----------------|---|---|---|---|---|----|---|----------|------|---|---|---|----|---|
| 0              | 1 | 1 | 1 | 0 |   |    |   |          | 0    | 0 | 0 | 1 | 1  |   |
| 0              |   |   |   | 4 | 5 | 7  | 8 | 10       | 0 11 |   |   |   | 15 | 5 |

The contents of the register specified by the R1 field are *exclusive ORed* bit by bit with the contents of the register specified by the R2 field. The result is placed in the register specified by the R2 field. The contents of the register specified by R1 are unchanged unless R1 and R2 specify the same register.

#### Example of Exclusive OR Word:

 Register contents (R1)
 1111 0000 1010 0000

 Register contents (R2)
 0011 1111 0111 1111

 Result
 1100 1111 1101 1111

Rule: Either but not both bits.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result of the exclusive OR operation.

#### **Program Check Conditions**

Protect Check. Instruction fetch.

Register/Storage Format

XW reg,addr4 addr4,reg



A logical exclusive OR operation is performed between the contents of the register specified by the R field and the main storage location specified by the effective address. (Effective Address Generation is explained in Chapter 2.) Bit 12 of the instruction specifies the destination of the result. The source operand is unchanged.

Example of Exclusive OR Word:

| Register contents (R) | 1111 0000 1010 0000 |
|-----------------------|---------------------|
| Storage operand       | 0011 1111 0111 1111 |
| Result                | 1100 1111 1101 1111 |

Rule: Either but not both bits.

#### Indicators

Carry and Overflow. Unchanged.

**Even, Negative, and Zero**. Changed to reflect the result of the exclusive OR operation.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store. For operand store (read-only violation), the instruction is terminated. Main storage is not changed but the indicators are set as described.

XW longaddr,reg



A logical exclusive OR operation is performed between the contents of the register specified by the R1 field and the contents of the main storage word location specified by the effective address. The result is placed in the register specified by the R1 field.

The effective main storage address is generated as follows:

- 1. The address field is added to the contents of the register specified by the R2 field. If the R2 field equals zero, no register contributes to the address generation.
- 2. Instruction bit 11 is tested for direct or indirect addressing:

Bit 11=0 (direct address). The result from step 1 is the effective address.

Bit 11=1 (indirect address). The result from step 1 is the address of the main storage location that contains the effective address.

#### Example of Exclusive OR Word:

| Register contents (R1) | 1111 0000 1010 0000 |
|------------------------|---------------------|
| Storage operand        | 0011 1111 0111 1111 |
| Result                 | 1100 1111 1101 1111 |

*Rule:* Either but not both bits.

#### Indicators

Carry and Overflow. Unchanged.

**Even, Negative, and Zero.** Changed to reflect the result loaded into the register specified by the R1 field.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### Exclusive OR Word Immediate (XWI)

XWI word,reg[,reg]

| Operation code |   |   |   |   | R1 |    |    | R2  |    | F  |    |   |   |   |    |
|----------------|---|---|---|---|----|----|----|-----|----|----|----|---|---|---|----|
| 0              | 1 | 1 | 1 | 1 |    |    |    |     |    |    | 0  | 0 | 1 | 0 | 1  |
| 0              |   |   |   | 4 | 5  |    | 7  | 8   |    | 10 | 11 |   |   |   | 15 |
|                |   |   |   |   |    |    |    |     |    |    |    |   |   |   |    |
|                |   | _ | _ |   |    |    |    |     |    |    |    |   | _ |   |    |
|                |   |   |   |   |    | Im | me | dia | te |    |    |   |   |   |    |
| L              |   |   |   |   |    |    |    |     |    |    |    |   |   |   |    |
| 16             |   |   |   |   |    |    |    |     |    |    |    |   |   |   | 31 |

The immediate field is *exclusive ORcd* bit by bit with the contents of the register specified by the R1 field. The result is placed in the register specified by the R2 field. The contents of the register specified by R1 are unchanged unless R1 and R2 specify the same register.

Example of Exclusive OR Word:

 Register contents (R1)
 1111 0000 1010 0000

 Immediate operand
 0011 1111 0111 1111

 Result
 1100 1111 1101 1111

Rule: Either but not both bits.

#### Indicators

Carry and Overflow. Unchanged.

Even, Negative, and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word.

¢ -

### Chapter 9. Floating-Point Feature

The floating-point feature includes (1) all floating-point instructions and (2) four 64-bit floating-point registers for each of the four priority interrupt levels in the processor. The floating-point instruction set performs calculations on operands with a wide range of magnitude. Results of these calculations are scaled to preserve precision. The floatingpoint registers are provided to avoid unnecessary storing and loading operations for results and operands.

A floating-point number consists of a signed exponent and a signed fraction. The quantity expressed by this number is the product of the fraction and the number 16 raised to the power of the exponent. The exponent is expressed in excess 64 binary notation; the fraction is expressed as a hexadecimal number having a radix point to the left of the high-order hexadecimal digit.

#### Data Format

Two fixed-length formats (short and long) may be used for floating-point data.

| Short Floating-Point Number-used for single precision |                |   |   |          |   |                                                    |  |  |  |  |
|-------------------------------------------------------|----------------|---|---|----------|---|----------------------------------------------------|--|--|--|--|
| S                                                     | Characteristic |   |   | Fraction | 3 | $\left\{ \begin{array}{c} \\ \end{array} \right\}$ |  |  |  |  |
| 0                                                     | 1              | 7 | 8 |          |   | 31                                                 |  |  |  |  |

Long Floating-Point Number-used for double precision

| S | Characteristic |   |   | Fraction | ))  |    |
|---|----------------|---|---|----------|-----|----|
|   |                |   |   |          | ( ( |    |
| 0 | 1              | 7 | 8 |          |     | 63 |

Both formats may be used in main storage and in the floating-point registers. The first bit in either format is the sign bit (S). The subsequent seven bit positions are occupied by the characteristic. The fraction field may have either six or 14 hexadecimal digits.

The entire set of floating-point instructions is available for both short and long operands. When single precision (short format) is specified, all operands and results are 32bit floating-point words. With two exceptions, the rightmost 32-bits of the floating-point registers do not participate in single precision operations and are unchanged by the operations. The two exceptions are (1) the product in multiply operations (it is a 64-bit floating-point word and occupies a full register), and (2) a storage to register move (the loworder 32 bits are set to zero). When double precision (long format) is specified, all operands and results are 64-bit floating-point words. Although final results in short precision have six fraction digits, intermediate results in add and subtract operations may extend to seven fraction digits. The low-order digit of a seven digit fraction is called the guard digit and serves to increase the precision of the final result. Intermediate results in long precision may extend to 15 fraction digits with the 15th digit being the guard digit.

#### Number Representation

#### Floating-Point Numbers

The fraction of a floating-point number is expressed in hexadecimal digits. The radix point of the fraction is assumed to be immediately to the left of the high-order fraction digit. To provide the proper magnitude for the floating-point number, the fraction is considered to be multiplied by a power of 16. The characteristic portion, bits 1-7 of both floating-point formats, indicates this power. The bits within the characteristic field can represent numbers from 0 through 127. To accommodate large and small magnitudes, the characteristic is formed by adding 64 to the actual exponent. The range of the exponent is thus -64 through +63. This technique produces a characteristic in excess 64 notation.

Both positive and negative quantities have a true fraction, the difference in sign being indicated by the sign bit. The number is positive or negative accordingly as the sign bit is zero or one.

A floating-point number with zero characteristic, zero fraction, and plus sign is called a true zero. A true zero may arise as the result of an arithmetic operation because of the particular magnitude of the operands. A result is forced to be true zero when an exponent underflow occurs or when a result fraction is zero.

#### **Conversion Example**

Convert the decimal number 149.25 to a short-precision floating-point operand.

- The number is decomposed into a decimal integer and a decimal fraction. 149.25 = 149 plus 0.25
- 2. The decimal integer is converted to its hexadecimal representation.

$$149_{10} = 95_{16}$$

3. The decimal fraction is converted to its hexadecimal representation.

 $0.25_{10} = 0.4_{16}$ 

- 4. Combine the integral and fractional parts and express as a fraction times a power of 16 (exponent).
   95.4<sub>16</sub> = (0.954 x 10<sup>2</sup>)<sub>16</sub>
- 5. The characteristic is developed from the exponent and converted to binary.

base + exponent = characteristic 64 + 2 = 66 = 1000010

6. The fraction is converted to binary and grouped hexadecimally.

.954, 6 = .1001 0101 0100

- 7. The characteristic and the fraction are stored in short precision format. The sign position contains the sign of the fraction.
  - S
     Char
     Fraction

     0
     1000010
     1001 0101 0100 0000 0000 0000

## **Binary Integers in Main Storage**

Signed binary integers occupy storage in one of two fixed length formats:

- 1. One word format (16 bits)
- 2. Doubleword format (32 bits)

Both formats may be used in main storage and are automatically converted to single or double precision floatingpoint numbers during *floating move and convert* operations that move data from storage to a floating-point register. Negative signed binary integers are in main storage in two's complement form. They are converted to contain a true fraction. An integer may be moved from main storage to a floating-point register, without conversion, by using the *floating move* instruction. In this case, the integer is assumed to be a floating-point number.

Floating move and convert operations that move data from a floating-point register to storage accomplish the reverse process; the floating-point number in the register is automatically converted to an integer. This integer result is then placed in main storage. The *floating move* and *floating* move and convert operations are fully explained in the section *Floating-Point Instructions* in this chapter.

## Normalization

A quantity can be represented with the greatest precision by a floating-point number of given fraction length when that number is normalized. A normalized floating-point number has a nonzero high-order hexadecimal fraction digit. If one or more high-order fraction digits are zero, the number is said to be unnormalized. The process of normalization consists of shifting the fraction left until the high-order hexadecimal digit is nonzero and reducing the characteristic by the number of hexadecimal digits shifted. Normalization takes place (1) after the multiply operations, and (2) after the add or subtract operations if an actual subtraction has taken place; for example, +A+(-B), +A-(+B), or -A-(-B). Normalization does not take place following a true addition or division; therefore, unnormalized operands can produce an unnormalized result. Floating-point numbers in main storage are assumed to be normalized.

## **Programming Considerations**

## Floating-Point Feature Not Installed

An attempt to execute a floating-point instruction when the feature is not installed results in a soft-exception-trap interrupt with *invalid function* set in the PSW. An exception to this rule exists when attempting to execute a floatingpoint privileged instruction while in problem state. In this case, a program check interrupt occurs, with *privilege violate* set in the PSW.

## Floating-Point Registers

Four floating-point registers are provided for each of the four priority interrupt levels associated with the processor. Floating-point register selection is determined by the register (R) field of the instruction. The R field in the instruction format consists of two bits and may be labeled R, R1, and R2 as required by the individual instruction.

| R field value | Floating-point register selected |
|---------------|----------------------------------|
| 00            | Register 0                       |
| 01            | Register 1                       |
| 10            | Register 2                       |
| 11            | Register 3                       |

*Note.* The floating-point registers are not affected by Reset and must be initialized by the programmer.

## Arithmetic Indicators

The processor indicators (carry, overflow, zero, negative, and even) are set or reset at the end of each floating-point instruction. Details of indicator settings are contained in the individual instruction descriptions in this chapter.

## Floating-Point Exceptions

Floating-point underflow, overflow, and divide check are considered exception conditions. When these conditions are recognized, a soft-exception-trap class interrupt occurs with floating-point exception (bit 5) set in the PSW. Note that the soft-exception-trap interrupt does not occur during floating-point compare operations. The overflow, carry and even indicators are set as follows:

**Overflow Indicator.** Set to one by an overflow, underflow, or divide check.

**Carry Indicator.** Set to one by a divide check.

Even Indicator. Set to one by an underflow.

#### **Floating-Point Overflow**

- Add operations An exponent overflow occurs when a carry from the high-order position of the intermediatesum fraction causes the characteristic of the sum to exceed 127. The operation is completed by making the characteristic equal to 127. The result fraction is changed to the largest possible value.
- Subtract and compare operations An exponent overflow occurs when a borrow from the high-order position of the intermediate-sum fraction causes the characteristic of the sum to exceed 127. The operation is completed by making the characteristic equal to 127. The result fraction bits are all changed to one.
- Divide operations An exponent overflow occurs when the final-quotient characteristic exceeds 127. The operation is completed by forcing the characteristic to 127 and the result fraction to all ones.
- Multiply operations An exponent overflow occurs when the characteristic of the normalized product exceeds 127 and the fraction is not zero. The operation is completed by forcing the characteristic to 127 and the result fraction to all ones.

#### **Floating-Point Underflow**

- Add operations An exponent underflow occurs when the characteristic of the normalized sum is less than zero and the fraction is not zero. The result sign, characteristic, and fraction are forced to zero.
- Subtract and compare operations An exponent underflow occurs when the characteristic of the normalized sum is less than zero and the fraction is not zero. The result sign, characteristic, and fraction are forced to zero.
- Divide operations An exponent underflow occurs when the characteristic of the normalized quotient is less than zero and the fraction is not zero. The result sign, characteristic, and fraction are forced to zero.
- Multiply operations An exponent underflow occurs when the characteristic of the normalized product is less than zero and the fraction is not zero. The result sign, characteristic, and fraction are forced to zero.

#### **Divide Check**

• Divide operations – A divide check occurs when division by zero is attempted. The dividend is not changed.

## Level Control

Floating-point instructions are executed in a normal instruction stream on the active priority level in the processor. This level is sampled by the floating-point operation at the beginning of each floating-point instruction. Only program check and machine check class interrupts can occur during execution of floating-point instructions.

## Instruction Termination or Suppression

Exception conditions that occur during instruction processing might cause the instruction to be terminated or suppressed. When an instruction is terminated, partial execution has taken place and may have caused a change to registers, indicators, or main storage. When an instruction is suppressed, there has been no execution, therefore, no changes. Refer to *Exception Conditions* in this chapter.

## **Floating-Point Instructions**

The floating-point instruction set provides a variety of instructions that deal with single or double precision float-ing-point data. The main categories are:

- Arithmetic instructions (add, subtract, multiply, divide, and compare)
- Data movement instructions (with or without conversion of binary integers)

Two privileged instructions are also provided for interrogation of the floating-point registers. They are (1) Copy Floating Level Block (CPFLB) and (2) Set Floating Level Block (SEFLB).

All floating-point instructions use the floating-point registers. One group of instructions (storage/floating-point register) specifies a register for one operand, and an effective main storage address for the other operand. Another group (floating-point register to floating-point register) specifies registers for both operands.

## Instruction Formats

Arithmetic and data movement instructions use the following two formats:

#### Storage/Floating-point Register



Op code field. Specifies floating-point operation.

R field. Specifies a floating-point register.

*Function field.* Designates function to be performed (add, subtract, multiply, divide, move, move and convert). *RB and AM fields.* Designate the effective address argument.

(See *Effective Address Generation* in Chapter 2.) *P field*. Designates precision of floating-point data.

0 =Single precision

1 =Double precision

Second word (Bits 16-31). Address mode appended word for an AM field equal to 10 or 11.

#### Floating-point Register to Floating-point Register



Op code field. Specifies floating-point operation.

R1 and R2 fields. Specify floating-point registers.

Bits 10-11. Designate the function modifier. These bits are not used and must be set to zero to avoid future code obsolescence.

*Function field.* Designates function to be performed (add, subtract, multiply, divide, move, compare).

*Note.* To avoid future code obsolescence, function field bit combinations equal to 110 and 111 must not be used.

P field. Designates precision of floating-point data.

0 = single precision

1 = double precision

Another instruction format is used for the two privileged instructions (Copy Floating Level Block and Set Floating Level Block). The three-bit R field associated with this format specifies a processor general register (0-7). See the individual instructions for the complete format.

*Note.* The instruction formats are also shown in Appendix B of this manual.

## **Exception Conditions**

Exception conditions that might occur during instruction execution are shown in abbreviated form with each instruction description. Refer to the following sections for a detailed description of these conditions.

## **Program Check Conditions**

#### **Invalid Storage Address**

**Instruction Word or Operand.** One or more words of the instruction or the effective address is outside the installed storage size of the system. The register to register instructions are suppressed. The storage/register instructions are terminated.

A program check class interrupt occurs with *invalid* storage address (bit 1) set in the PSW.

#### **Privilege Violate**

**Privileged Instruction.** A privileged instruction is encountered while in problem state. The instruction is suppressed.

A program check class interrupt occurs with *privileged* violate (bit 2) set in the PSW.

#### **Protect Check**

Instruction Fetch or Operand Access. In the problem state, an instruction is fetched or data is accessed from a storage area not assigned to the current operation.

**Operand Store.** In the problem state, the instruction attempts to change an operand in a storage area assigned as read-only.

The register to register instructions are suppressed. The storage/register instructions are terminated. A program check class interrupt occurs with *protect check* (bit 3) set in the PSW.

#### **Specification Check**

**Operand Address.** The generated effective address has violated an even-byte boundary requirement.

Indirect Address. When using addressing mode (AM=11), the indirect address is not on an even-byte boundary.

The register to register instructions are suppressed. The storage/register instructions are terminated. A program check class interrupt occurs with *Specification check* (bit 0) set in the PSW.

#### Soft Exception Trap Condition

#### **Floating-Point Exception**

A floating-point underflow, overflow, or divide check has occurred. The instruction completes execution. A softexception-trap class interrupt occurs with *floating-point exception* (bit 5) set in the PSW.

#### **Invalid Function**

An attempt is made to execute a floating-point instruction when (1) the feature is not installed, or (2) the feature is installed but cannot be selected. The register to register instructions are suppressed. The storage/register instructions are terminated. A soft exception trap class interrupt occurs with *invalid function* (bit 4) set in the PSW.

*Note.* The resulting class interrupt causes the contents of the storage address register (SAR) to be loaded into general register seven. SAR contains either (1) the calculated effective address of data operand 2, or (2) the address of the attempted instruction for register to register operations.

## **CPFLB**

## **Instruction Descriptions**

The following descriptions are in alphabetical sequence based on assembler mnemonics. Indicator settings are listed for each instruction. For additional indicator information, refer to *Arithmetic Indicators* in this chapter and to *Indicators* in Chapter 2.

Instruction timings are contained in Appendix A of this manual.

## Copy Floating Level Block (CPFLB) CPFLB reg,addr4

| Opera | Operation code |   |   |   | R |   | RI | 3 | AM   |    |    | Fur | ıcti | on |
|-------|----------------|---|---|---|---|---|----|---|------|----|----|-----|------|----|
| 0 1   | 0              | 1 | 1 |   |   |   |    |   |      |    | 1  | 0   | 1    | 1  |
| 0     |                |   | 4 | 5 |   | 7 | 8  | 9 | 10 1 | 11 | 12 |     |      | 15 |
| U     |                |   | - | 5 |   |   | 0  | , | 101  |    | 12 |     |      |    |



The contents of the floating-point registers (floating level block) for the level specified by the R field register are stored into main storage locations beginning at the specified effective address (EA). All registers remain unchanged. After execution of this instruction, the floating level block appears in main storage as follows:

| EA            | Contents of floating-point register 0 |    |
|---------------|---------------------------------------|----|
|               | Contents of floating-point register 1 |    |
|               | Contents of floating-point register 2 |    |
| EA + 24 (Hex) | Contents of floating-point register 3 |    |
|               | 0                                     | 63 |

The general register specified by the R field has the format:

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | Level |
|---|---|---|---|---|---|---|---|---|---|---|---|---|----|-------|
| 0 |   |   |   |   |   |   |   |   |   |   |   |   | 13 | 14 15 |

Bits 0-7, 12 and 13 are not used and must be zero to avoid future code obsolescence. Bits 8-11 must be zero in order to select the floating-point feature. Bits 14 and 15 hold the binary-encoded level of the floating level block associated with this operation. For example: 00 for level 0, 01 for level 1, 10 for level 2, and 11 for level 3.

*Programming Note.* If AM=01, the register specified by the RB field is incremented by two.

#### Indicators.

No indicators are changed.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## Floating Add (FA)

#### General Description (Short Precision)

Addition of two floating-point numbers is based on characteristic comparison and fraction addition. The characteristics of the two operands are compared, and the fraction accompanying the smaller characteristic is shifted right, with its characteristic increased by one for each hexadecimal digit shifted, until the two characteristics are equal.

When an operand is shifted right during alignment, the leftmost hexadecimal digit of the field shifted out is retained as a guard digit. The operand that is not shifted is considered to be extended with a low-order zero. Both operands are considered to be extended with low-order zeros when no alignment shift occurs. The 28-bit fractions are then added algebraically to form an intermediate sum.

The intermediate-sum fraction consists of seven hexadecimal digits and a possible carry. If a carry is present, the sum is shifted right one digit position, to make room for the carry, and the characteristic is increased by one.

If the operand signs are unlike (resulting in a subtraction) and the fraction is not zero, normalization takes place. The intermediate sum is shifted left as necessary to form a normalized number. Vacated low-order digit positions are filled with zeros, and the characteristic is reduced by the number of hexadecimal digits shifted. The intermediatesum fraction is subsequently truncated to the proper result fraction length of six hexadecimal digits.

#### Storage/Register Format

FA addr4,freg

| Op | pera | tio | n co | ode |   | F | 2    | R | В | AM    | Fι | inci | ion | P  |
|----|------|-----|------|-----|---|---|------|---|---|-------|----|------|-----|----|
| 0  | 0    | 1   | 0    | 0   | 0 |   | R RB |   |   |       | 0  | 0    | 0   | 0  |
| 0  |      |     |      | 4   | 5 | 6 | 7    | 8 | 9 | 10 11 | 12 | ?    | 14  | 15 |

| Address/Disp                  | lacement                      |
|-------------------------------|-------------------------------|
| Displacement 1                | Displacement 2                |
| $\frac{1}{16}$ $\frac{1}{23}$ | $\frac{1}{24}$ $\frac{1}{31}$ |

The 32-bit main storage operand specified by the effective address is algebraically added to the 32-bit operand in the floating-point register specified by the R field. The result is placed back into the floating-point register specified by the R field. The main storage operand is unchanged. The loworder 32 bits of the specified floating-point register are unchanged.

The sign of the sum is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

#### **Register to Register Format**

FA freg,freg

| OF | pera | tio | n co | de |   | R | 1 | R | 2 |    |    | Fu | inci | ion | P  |
|----|------|-----|------|----|---|---|---|---|---|----|----|----|------|-----|----|
| 0  | 0    | 1   | 0    | 0  | 1 |   |   |   |   | 0  | 0  | 0  | 0    | 0   | 0  |
| 0  |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | ?    | 14  | 15 |

The two 32-bit operands contained in the floating-point registers specified by the R1 and R2 fields are added algebraically. The result is placed back into the floating-point register specified by the R2 field. The R1 register is unchanged when not equal to R2. The low-order 32 bits of the R2 register are unchanged.

The sign of the sum is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

**Program Check Condition** 

Protect Check. Instruction fetch.

#### **Soft Exception Trap Condition**

Floating-Point Exception. Overflow or underflow.

## Floating Add Double (FAD)

#### General Description (Double Precision)

Addition of two floating-point numbers is based on characteristic comparison and fraction addition. The characteristics of the two operands are compared and the fraction accompanying the smaller characteristic is shifted right, with its characteristic increased by one for each hexadecimal digit shifted, until the two characteristics are equal. The fractions are then added algebraically to form an intermediate sum.

When an operand is shifted right during alignment, the last hexadecimal digit shifted out of the 64-bit register is preserved as a guard digit with 15 digits participating in the arithmetic.

The long intermediate-sum fraction consists of 15 hexadecimal digits and a possible carry. If a carry is present, the sum is shifted right one digit position, and the characteristic is increased by one.

If the operand signs are unlike (resulting in a subtraction) and the fraction is not zero, normalization takes place. The intermediate sum including the guard digit is shifted left as necessary to form a normalized number. Vacated low-order digit positions are filled with zeros, and the characteristic is reduced by the number of hexadecimal digits shifted.

#### Storage/Register Format

FAD addr4,freg

| Operatio     | on co | ode | 1 | R    |      | RI   | в | AM            | Func | tion | Р  |
|--------------|-------|-----|---|------|------|------|---|---------------|------|------|----|
| 0 0 1        | 0     | 0   | 0 |      |      |      |   |               | 0 0  | 0    | 1  |
| 0            |       | 4   | 5 | 6    | 7    | 8    | 9 | 10 11         | 1 12 | 14   | 15 |
|              |       |     |   |      |      |      |   |               |      |      |    |
|              |       |     |   |      |      |      |   |               |      |      |    |
|              |       |     |   |      |      |      |   |               |      |      |    |
|              |       |     |   | _    |      |      |   |               |      |      | -  |
|              |       |     | _ | ss/l | Disp | lace |   |               |      |      | -  |
| <br><br>Disp |       |     | _ | ss/l | Disp |      |   | nt<br>splacer |      |      | -  |

The 64-bit main storage operand specified by the effective address is algebraically added to the 64-bit operand in the floating-point register specified by the R field. The result is placed back into the floating-point register specified by the R field. The main storage operand is unchanged.

The sign of the sum is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

Register to Register FormatFADfreg,freg

| ſ | 0ţ | oera | tio | n co | de |   | R | 1 | R | 2 |    |      | Fı | inci | tion | Ρ  |
|---|----|------|-----|------|----|---|---|---|---|---|----|------|----|------|------|----|
|   | 0  | 0    | 1   | 0    | 0  | 1 | ł |   | { |   | 0  | 0    | 0  | 0    | 0    | 1  |
|   | 0  |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | ) 11 | 12 | ?    | 14   | 15 |

The two 64-bit operands contained in the floating-point registers specified by the R1 and R2 fields are added algebraically. The result is palced back into the floating-point register specified by the R2 field. The R1 register is unchanged when not equal to R2.

The sign of the sum is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

#### Indicators

**Overflow**. Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

**Program Check Condition** 

Protect Check. Instruction fetch.

Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

## Floating Compare (FC)

FC freg,freg

| OF | oera | tior | n co | de |   | R | 1 | R | 2 |    |      | $F\iota$ | inct | ion | P  |
|----|------|------|------|----|---|---|---|---|---|----|------|----------|------|-----|----|
| 0  | 0    | 1    | 0    | 0  | 1 |   |   |   |   | 0  | 0    | 1        | 0    | 1   | 0  |
| 0  |      |      |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | ) 11 | 12       | ?    | 14  | 15 |

The 32-bit operand contained in the floating-point register specified by the R1 field is algebraically subtracted from the 32-bit operand contained in the floating-point register specified by the R2 field. Contents of both floating-point registers remain unchanged. See *Floating Subtract* for details of the subtract operation.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Condition**

Protect Check. Instruction fetch.

#### Floating Compare Double (FCD)

FCD freg,freg

| O | bera | tio | n cc | de |   | R | 1 | R | 2 |    |      | Fu | nct | ion | P  |
|---|------|-----|------|----|---|---|---|---|---|----|------|----|-----|-----|----|
| 0 | 0    | 1   | 0    | 0  | 1 |   |   |   |   | 0  | 0    | 1  | 0   | 1   | 1  |
| 0 |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | ) 11 | 12 | ?   | 14  | 15 |

The 64-bit operand contained in the floating-point register specified by the R1 field is algebraically subtracted from the 64-bit operand contained in the floating-point register specified by the R2 field. Contents of both floating-point registers remain unchanged. See *Floating Subtract Double* for details of the subtract operation.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

**Program Check Condition** 

Protect Check. Instruction fetch.

#### Floating Divide (FD)

#### Storage/Register Format

FD addr4,freg



The 32-bit dividend contained in the floating-point register specified by the R field is divided by the 32-bit divisor at the main storage location specified by the effective address. The 32-bit quotient is placed back in the floating-point register specified by the R field. The low-order 32 bits of the specified floating-point register are unchanged. No remainder is preserved. The main storage operand is unchanged.

The floating-point division is based on characteristic subtraction and fraction division. The operands are assumed to be normalized. The difference between the dividend and divisor characteristics plus 64 is used as the characteristic of the intermediate quotient.

The sign of the quotient is determined by the rules of algebra unless the quotient is made a true zero; in this case, the sign is made plus.

All dividend and divisor fraction digits participate in forming the fraction of the quotient. The quotient fraction will be a 24-bit normalized result if the dividend and the divisor are normalized.

#### Indicators

**Overflow.** Turned on by divide check, exponent overflow, or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

**Carry.** Turned on by divide check. Otherwise, the indicator is reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow, underflow, or divide check.

#### **Register to Register Format**

FD freg,freg

| 0µ | oera | tio | n co | de |   | R | 1 | R | 2 |    |      | Fu | inci | ion | P  | l |
|----|------|-----|------|----|---|---|---|---|---|----|------|----|------|-----|----|---|
| 0  | 0    | 1   | 0    | 0  | 1 |   |   |   |   | 0  | 0    | 0  | 1    | 1   | 0  |   |
| 0  |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | ) 11 | 12 | ?    | 14  | 15 |   |

The 32-bit dividend contained in the floating-point register specified by the R2 field is divided by the 32-bit divisor contained in the floating-point register specified by the R1 field. The 32-bit quotient is placed back in the floatingpoint register specified by the R2 field. No remainder is preserved. The low-order 32 bits of the R2 register are unchanged. The R1 register is unchanged when not equal to R2.

The floating-point division is based on characteristic subtraction and fraction division. The operands are assumed to be normalized. The difference between the dividend and divisor characteristics plus 64 is used as the characteristic of the intermediate quotient.

The sign of the quotient is determined by the rules of algebra unless the quotient is made a true zero; in this case, the sign is made plus.

All dividend and divisor fraction digits participate in forming the fraction of the quotient. The quotient fraction will be a 24-bit normalized result if the dividend and divisor are normalized.

#### Indicators

**Overflow.** Turned on by divide check, exponent overflow, or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

**Carry.** Turned on by divide check. Otherwise, the indicator is reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Condition**

Protect Check. Instruction fetch.

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow, underflow, or divide check.

## Floating Divide Double (FDD)

## Storage/Register Format FDD

addr4,freg

| $O_l$ | pera | tio | n cc | ode |   | R |   | R | В | AN | 1  | Fu  | nct | ion | P  |
|-------|------|-----|------|-----|---|---|---|---|---|----|----|-----|-----|-----|----|
| 0     | 0    | 1   | 0    | 0   | 0 |   |   |   |   | AN |    | 0   | 1   | 1   | 1  |
| 0     |      |     |      | 4   | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12  |     | 14  | 15 |
| v     |      |     |      | -1  | 5 | Ū | , | 0 |   | 10 |    | 1 * |     | 14  |    |



The 64-bit dividend contained in the floating-point register specified by the R field is divided by the 64-bit divisor at the main storage location specified by the effective address. The 64-bit quotient is placed back in the floating-point register specified by the R field. No remainder is preserved. The main storage operand is unchanged.

Floating-point division is based on characteristic subtraction and fraction division. The operands are assumed to be normalized. The difference between the dividend and divisor characteristics plus 64 is used as the characteristic of the intermediate quotient.

All dividend and divisor fraction digits participate in forming the fraction of the quotient. The quotient fraction will be a 56-bit normalized result if the dividend and divisor are normalized.

The sign of the quotient is determined by the rules of algebra unless the quotient is made a true zero; in this case, the sign is made plus.

#### Indicators

**Overflow.** Turned on by divide check, exponent overflow, or exponent underflow. Otherwise, the indicator is reset.

Even. Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Turned on by divide check. Otherwise, the indicator is reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

Specification Check. Even byte boundary violation (indirect address or operand address).

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow, underflow, or divide check.

## **Register to Register Format**

FDD freg,freg

| Or | oera | tio | n co | de |   | R | 1 | R | ? |    |    | Fu | nct | ion | P  |
|----|------|-----|------|----|---|---|---|---|---|----|----|----|-----|-----|----|
| 0  | 0    | 1   | 0    | 0  | 1 |   |   |   |   | 0  | 0  | 0  | 1   | 1   | 1  |
| 0  |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 2   | 14  | 15 |

The 64-bit dividend contained in the floating-point register specified by the R2 field is divided by the 64-bit divisor contained in the floating-point register specified by the R1 field. The 64-bit quotient is placed back in the floatingpoint register specified by the R2 field. No remainder is preserved. The R1 register is unchanged when not equal to R2.

Floating-point division is based on characteristic subtraction and fraction division. The operands are assumed to be normalized. The difference between the dividend and divisor characteristics plus 64 is used as the characteristic of the intermediate quotient.

All dividend and divisor fraction digits participate in forming the fraction of the quotient. The quotient fraction will be a 56-bit normalized result if the dividend and divisor are normalized.

The sign of the quotient is determined by the rules of algebra unless the quotient is made a true zero; in this case, the sign is made plus.

#### Indicators

**Overflow.** Turned on by divide check, exponent overflow, or exponent underflow. Otherwise, the indicator is reset.

Even. Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Turned on by divide check. Otherwise, the indicator is reset.

Negative and Zero. Changed to reflect the result.

**Program Check Condition** 

Protect Check. Instruction fetch.

Soft Exception Trap Condition

Floating-Point Exception. Overflow, underflow, or divide check.

## Floating Multiply (FM)

## General Description (Short Precision)

Multiplication of two floating-point numbers is based on exponent addition and fraction multiplication. The operands are assumed to be normalized. The sum of the characteristics of the operands less 64 is used as the characteristic of the intermediate product. When the result is normalized without requiring any postnormalization, the intermediateproduct fraction is the result fraction, and the intermediateproduct characteristic becomes the final-product characteristic. When the intermediate-product fraction has one leading zero digit, it is shifted left one digit position and the intermediate-product characteristic is reduced by one.

The multiplier and multiplicand have six-digit fractions. The product fraction has 14 digits. The two low-order fraction digits are always zero, unless overflow occurs.

## Storage/Register Format

FM addr4,freg

|          | P<br>0 | ion<br>0 | nct<br>1 | Fur<br>0 | И   | A    | В  | R    |     | R     |            | ode<br>0 | n cc<br>0 | tioi<br>1 | era<br>0 |    |
|----------|--------|----------|----------|----------|-----|------|----|------|-----|-------|------------|----------|-----------|-----------|----------|----|
| 15       | 1      | 14       |          | 12       | 11  | 10   | 9  | 8    | 7   | 6     | 5          | 4        |           |           | 0        | 0  |
|          |        |          |          |          |     |      |    |      |     |       |            |          |           |           |          |    |
| <u>۲</u> |        |          | -        |          |     | ent  | em | olac | Dis | ess/  | ddre       | Ad       |           |           |          |    |
|          | _      |          | 2        | nent     | cen | spla |    | 1_   |     |       | <u>t 1</u> | nen      | acer      | spl       | Di       | Ε. |
|          |        |          | 2        | nent     | cen |      | Di |      |     | 255/1 |            | _        | acer      | spl       | Di       |    |

The 32-bit main storage operand specified by the effective address and the 32-bit operand contained in the floatingpoint register specified by the R field are multiplied. The normalized result is placed back into the floating-point register specified by the R field. The main storage operand is unchanged.

The sign of the product is determined by the rules of algebra unless all digits of the product fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

When either or both operand fractions are zero, the result is made a true zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

# Register to Register FormatFMfreg,freg

| $\left[ O \right]$ | pera | tio | n co | ode |   | R | 1 | R | 2 | Γ  |      | Fu | nci | ion | P  |
|--------------------|------|-----|------|-----|---|---|---|---|---|----|------|----|-----|-----|----|
| 0                  | 0    | 1   | 0    | 0   | 1 |   |   |   |   | 0  | 0    | 0  | 1   | 0   | 0  |
| 0                  |      |     |      | 4   | 5 | 6 | 7 | 8 | 9 | 10 | ) 11 | 12 | ?   | 14  | 15 |

The two 32-bit operands contained in the floating-point registers specified by the R1 and R2 fields are multiplied and the normalized result is placed back into the floating-point register specified by the R2 field. The R1 register is unchanged when not equal to R2.

The sign of the product is determined by the rules of algebra unless all digits of the product fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

When either or both operand fractions are zero, the result is made a true zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

#### Program Check Condition

Protect Check. Instruction fetch.

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

## Floating Multiply Double (FMD)

#### General Description (Double Precision)

Multiplication of two floating-point numbers is based on exponent addition and fraction multiplication. The operands are assumed to be normalized. The sum of the characteristics of the operands less 64 is used as the characteristic of the intermediate product. When the result is normalized without requiring any postnormalization, the intermediateproduct fraction is the result fraction, and the intermediateproduct characteristic becomes the final-product characteristic. When the intermediate-product fraction has one leading zero digit, it is shifted left one digit position and the intermediate-product characteristic is reduced by one. The multiplier and multiplicand fractions have 14 digits and the result-product fraction is truncated to 14 digits.

## Storage/Register Format

FMD addr4.freg

|           | 1          |               |       |
|-----------|------------|---------------|-------|
|           |            | 0 1           | 0 1   |
| 5789      | 10 11      | 12            | 14 1. |
| , , , , , |            |               |       |
|           |            |               |       |
|           |            |               |       |
| Displacem | ent –      |               |       |
|           |            |               |       |
| D D       | splacer    | nent 2        |       |
|           | /Displacem | /Displacement |       |

The 64-bit main storage operand specified by the effective address and the 64-bit operand contained in the floatingpoint register specified by the R field are multiplied. The normalized result is placed back into the floating-point register specified by the R field. The main storage operand is unchanged.

The sign of the product is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

When either or both operand fractions are zero, the result is made a true zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

Even. Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

Specification Check. Even byte boundary violation (indirect address or operand address).

#### **Soft Exception Trap Condition**

Floating-Point Exception. Overflow or underflow.

#### **Register to Register Format** FMD

freg,freg

| 0p | oera | tio | n co | de |   | R | 1 | R | 2 |    |    | Fu   | nct | ion | P  |
|----|------|-----|------|----|---|---|---|---|---|----|----|------|-----|-----|----|
| 0  | 0    | 1   | 0    | 0  | 1 |   |   |   |   | 0  | 0  | 0    | 1   | 0   | 1  |
| 0  |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 1 12 | !   | 14  | 15 |

The two 64-bit operands contained in the floating-point registers specified by the R1 and R2 fields are multiplied. The normalized result is placed back into the floating-point register specified by the R2 field. The R1 register is unchanged when not equal to R2.

The sign of the product is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

When either or both operand fractions are zero, the result is made a true zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

Even. Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Condition**

Protect Check. Instruction fetch.

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

#### Floating Move (FMV)

## Storage to Register Format

FMV addr4,freg

| $\overline{O_p}$ | era | tio | n co | de |   | R |   | R | B | AM    | Fu | nct | ion | P  |
|------------------|-----|-----|------|----|---|---|---|---|---|-------|----|-----|-----|----|
| 0                | 0   | 1   | 0    | 0  | 0 |   |   |   |   | AM    | 1  | 0   | 1   | 0  |
| 0                |     |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 11 | 12 |     | 14  | 15 |
| U                |     |     |      | 4  | 5 | 0 |   | 0 | y | 10 11 | 12 |     | 14  |    |



The 32-bit floating-point number in the main storage location specified by the effective address is loaded into the floating-point register specified by (1) the R field and (2) the current interrupt level. The main storage operand is unchanged. The low order 32 bits of the 64-bit register are set to zeros.

Indicators

Carry. Reset.

Overflow. Reset.

Even. Reset.

Negative and Zero. Changed to reflect the result loaded into the register.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### **Register to Storage Format**

FMV freg,addr4

| Ōŗ  | oera | tior | 1 co | de  |      | R    | _    | R   | B   | AM      | Fu   | icti | ion | Ρ  |
|-----|------|------|------|-----|------|------|------|-----|-----|---------|------|------|-----|----|
| 0   | 0    | 1    | 0    | 0   | 0    |      |      |     |     |         | 1    | 1    | 1   | 0  |
| 0   |      |      |      | 4   | 5    | 6    | 7    | 8   | 9   | 10 11   | 12   |      | 14  | 15 |
|     |      |      |      |     |      |      |      |     |     |         |      |      |     |    |
| -   |      |      |      |     |      |      |      |     |     |         |      |      |     | -1 |
| 1   |      |      | _    | Ad  | ldre | ss/L | Disp | lac | eme | nt      |      |      |     |    |
| L . |      |      |      |     |      |      |      |     |     |         |      |      |     |    |
|     | Di   | spla | cen  | nen | t 1  |      |      |     | Di  | splacen | nent | 2    |     |    |

The 32-bit floating-point number contained in the highorder 32 bits of the floating-point register specified by the R field is stored in the main storage location specified by, the effective address. The register specified by the R field is unchanged.

#### Indicators

Carry. Reset.

Overflow. Reset.

Even. Reset.

Negative and Zero. Changed to reflect the stored result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch, operand access, or operand store.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### **Register to Register Format**

FMV freg,freg

| OF | pera | tior | 1 co | de |   | R | 1 | R | 2 |    |    | Fu   | nct | ion | P  |
|----|------|------|------|----|---|---|---|---|---|----|----|------|-----|-----|----|
| 0  | 0    | 1    | 0    | 0  | 1 |   |   |   |   | 0  | 0  | 1    | 0   | 0   | 0  |
| 0  |      |      |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 1 12 | 2   | 14  | 15 |

The 32-bit operand contained in the floating-point register specified by the R1 field is moved to the floating-point register specified by the R2 field. The low-order 32 bits of the R2 register are set to zeros. The floating-point register specified by R1 is unchanged when not equal to R2. Bit 13 of the instruction, along with bits 10 and 11, must be set to zero to avoid future code obsolescence.

#### Indicators

Carry. Reset.

Overflow. Reset.

Even. Reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Condition**

Protect Check. Instruction fetch.

## Floating Move and Convert (FMVC)

## Storage to Register Format FMVC addr4,freg



The 16-bit signed binary integer in the main storage location specified by the effective address is converted to a 32-bit floating-point number with low-order zeros inserted; then loaded into the floating-point register specified by (1) the R field and (2) the current interrupt level. The low-order 32 bits of the register are set to zero. The 64-bit register is normalized with zeros inserted at the low-order positions during normalization. The main storage operand is unchanged.

#### Indicators

Carry. Reset.

Overflow. Reset.

Even. Reset.

Negative and Zero. Changed to reflect the result loaded into the register.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## Register to Storage Format

FMVC freg,addr4

| $O_{I}$        | oera | tio  | n cc | ode  |       | R    |      | R    | B   | AM     | Fu   | nct | ion | P          |
|----------------|------|------|------|------|-------|------|------|------|-----|--------|------|-----|-----|------------|
| 0              | 0    | 1    | 0    | 0    | 0     |      |      |      |     |        | 1    | 1   | 0   | 0          |
| 0              |      |      |      | 4    | 5     | 6    | 7    | 8    | 9   | 10 11  | 12   | ?   | 14  | 15         |
|                |      |      |      |      |       |      |      |      |     |        |      |     |     |            |
|                | _    | _    |      |      |       |      |      |      |     |        |      |     |     |            |
| Г <sup>-</sup> |      |      |      | Ad   | dre   | ss/L | Disp | lace | me  | nt –   |      | _   | _   | <u>ר</u> – |
|                | Dis  | spla | cen  | nent | E 1 - |      | -    | -    | Dis | placen | nent | 2   |     |            |
| 16             |      |      | ·    |      |       | -    | 23   | 24   |     |        |      |     |     | 31         |

The 32-bit floating-point number contained in the highorder 32 bits of the floating-point register specified by the R field is converted to a signed 16-bit binary integer and stored at the main storage location specified by the effective address. For proper conversion to occur, the floating-point number must be normalized. Any fraction remaining after conversion is truncated. The register specified by the R field is unchanged.

If the characteristic of the floating-point number is negative, the integer stored is zero.

#### Indicators

Carry. Reset.

**Overflow.** Turned on if the converted number is larger than  $+2^{15}-1$  or less than  $-2^{15}$ . In this case, the largest possible value is stored ( $-2^{15}$  if negative overflow or  $2^{15}-1$  if positive overflow). Otherwise, the indicator is reset.

Even. Reset.

Negative and Zero. Changed to reflect the stored integer.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch, operand access, or operand store.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## **FMVCD**

## Floating Move and Convert Double (FMVCD)

Storage to Register Format FMVCD addr4,freg

| le     | R          | RB                            | AM                                   | Funct                                 | ion P                                                     |
|--------|------------|-------------------------------|--------------------------------------|---------------------------------------|-----------------------------------------------------------|
| 0 0    | n          |                               |                                      | 1 0                                   | 0 1                                                       |
| 4 5    | 67         | 89                            | 10 11                                | 12                                    | 14 15                                                     |
|        |            |                               |                                      |                                       |                                                           |
|        |            |                               |                                      |                                       |                                                           |
| Addr   | ess/Dis    | nlacem                        |                                      |                                       |                                                           |
|        |            |                               |                                      | ===                                   |                                                           |
| ient i |            |                               | ispiacei                             | ment 2                                |                                                           |
|        | 0 0<br>4 5 | 0 0<br>4 5 6 7<br>Address/Dis | 0 0 4 5 6 7 8 9<br>Address/Displacem | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 1 1 0<br>4 5 6 7 8 9 10 11 12<br>Address/Displacement |

The 32-bit signed binary integer in the main storage location specified by the effective address is converted to a 64-bit floating-point number with low-order zeros inserted; then loaded into the floating-point register specified by (1) the R field and (2) the current interrupt level. The 64-bit register is normalized with zeros inserted at the low-order positions during normalization. The main storage operand is unchanged.

#### Indicators

Carry. Reset.

Overflow. Reset.

Even. Reset.

Negative and Zero. Changed to reflect the result loaded into the register.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## **Register to Storage Format** FMVCD freg,addr4

| Ор | era | tior | n ca | ode |              | R    |     | R           | B           | AM             | Fu  | nct     | ion | P  |
|----|-----|------|------|-----|--------------|------|-----|-------------|-------------|----------------|-----|---------|-----|----|
| 0  | 0   | 1    | 0    | 0   | 0            |      |     |             |             |                | 1   | 1       | 0   | 1  |
| 0  |     |      |      | 4   | 5            | 6    | 7   | 8           | 9           | 10 11          | 12  |         | 14  | 15 |
|    |     |      |      |     |              |      |     |             |             |                |     |         |     |    |
|    |     |      |      |     |              |      |     |             |             |                |     |         |     |    |
|    |     |      |      |     |              |      |     |             |             |                |     |         |     |    |
|    |     |      |      |     | dar          | 2001 | nie | <u>plac</u> | em          | ent –          |     | _       | _   |    |
|    |     |      | _    |     |              |      | Dis |             |             |                | ·   | <br>. 7 | _   |    |
|    | D   | ispl | acei |     | ddre<br>it 1 |      | • — |             | <b>T</b> Di | ent<br>splacer | nen | <br>t 2 |     |    |

The 64-bit floating-point number contained in the floatingpoint register specified by the R field is converted to a signed 32-bit binary integer and stored at the main storage location specified by the effective address. For proper conversion to occur, the floating-point number must be normalized. Any fraction remaining after conversion is truncated. The register specified by the R field remains unchanged.

If the characteristic of the floating-point number is negative, the integer stored is zero.

#### Indicators

Carry. Reset.

**Overflow.** Turned on if the converted number is larger than  $+2^{31}-1$  or less than  $-2^{31}$ . In this case, the largest possible value is stored  $(-2^{31})$  if negative overflow or  $2^{31}-1$  if positive overflow). Otherwise, the indicator is reset.

Even. Reset.

Negative and Zero. Changed to reflect the stored integer.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

**Protect Check.** Instruction fetch, operand access, or operand store.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## Floating Move Double (FMVD)

# Storage to Register FormatFMVDaddr4,freg

| OF | Operation code |   |   |   |   | R |   | R | B | AM    | Fu | nc t | ion | P  |
|----|----------------|---|---|---|---|---|---|---|---|-------|----|------|-----|----|
| 0  | 0              | 1 | 0 | 0 | 0 |   |   |   |   |       | 1  | 0    | 1   | 1  |
| 0  |                |   |   | 4 | 5 | 6 | 7 | 8 | 9 | 10 11 | 12 | ?    | 14  | 15 |

| Address/Disp   | placement                                                   |
|----------------|-------------------------------------------------------------|
| Displacement 1 | Displacement 2                                              |
| 16 $23$        | $\frac{1}{24} = \frac{1}{24} = \frac{1}{24} = \frac{1}{31}$ |

The 64-bit floating-point number in the main storage location specified by the effective address is loaded into the floating-point register specified by (1) the R field and (2)the current interrupt level. The main storage operand is unchanged.

#### Indicators

Carry. Reset.

Overflow. Reset.

Even. Reset.

Negative and Zero. Changed to reflect the result loaded into the register.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## Register to Storage Format

FMVD freg,addr4

| OF | oera | tio | n co | de |   | R |   | R | B | AM    | Fu | nct | ion | P  |
|----|------|-----|------|----|---|---|---|---|---|-------|----|-----|-----|----|
| 0  | 0    | 1   | 0    | 0  | 0 |   |   | 1 |   |       | 1  | 1   | 1   | 1  |
| 0  |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 11 | 12 | ?   | 14  | 15 |

| Address/Disp   | lacement                      |
|----------------|-------------------------------|
| Displacement 1 | Displacement 2                |
| 16 23          | $\frac{1}{24}$ $\frac{1}{31}$ |

The 64-bit floating-point number contained in the register specified by the R field is stored in the main storage location specified by the effective address. The register specified by the R field remains unchanged.

#### Indicators

Carry. Reset.

Overflow. Reset.

Even. Reset.

Negative and Zero. Changed to reflect the stored result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch, operand access, or operand store.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## Register to Register Format

FMVD freg,freg

| $O_{I}$ | pera | tio | n co | de |   | R | 1 | R | 2 | <u> </u> |    | Fu | nct | ion | P  |
|---------|------|-----|------|----|---|---|---|---|---|----------|----|----|-----|-----|----|
| 0       | 0    | 1   | 0    | 0  | 1 |   |   | [ |   | 0        | 0  | 1  | 0   | 0   | 1  |
| 0       |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10       | 11 | 12 | ?   | 14  | 15 |

The 64-bit operand contained in the floating-point register specified by the R1 field is moved to the floating-point register specified by the R2 field. The floating-point register specified by the R1 field is unchanged. Bit 13 of the instruction, along with bits 10 and 11, must be set to zero to avoid future code obsolescence.

#### Indicators

Carry. Reset.

Overflow. Reset.

Even. Reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Condition**

Protect Check. Instruction fetch.

## Floating Subtract (FS)

#### General Description (Short Precision)

Subtraction of two floating-point numbers is based on characteristic comparison and fraction subtraction. The characteristics of the two operands are compared, and the fraction accompanying the smaller characteristic is shifted right, with its characteristic increased by one for each hexadecimal digit shifted, until the two characteristics are equal.

When an operand is shifted right during alignment, the leftmost hexadecimal digit of the field shifted out is retained as a guard digit. The operand that is not shifted is considered to be extended with a low-order zero. Both operands are considered to be extended with low-order zeros when no alignment shift occurs. The 28-bit fractions are then subtracted algebraically to form an intermediate sum.

The intermediate-sum fraction consists of seven hexadecimal digits and a possible borrow. If a borrow is present, the sum is shifted right one digit position, and the characteristic is increased by one.

If a true subtraction is performed and the fraction is not zero, normalization takes place. The intermediate sum is shifted left as necessary to form a normalized number. Vacated low-order digit positions are filled with zeros and the characteristic is reduced by the number of hexadecimal digits shifted. The intermediate-sum fraction is subsequently truncated to the proper result-fraction length of six hexadecimal digits.

#### Storage/Register Format

#### FS addr4,freg

| $ O_l $ | oera | tio | n co | ode |   | R     |      | R    | В          | AM             | Fu   | nct | ion | Ρ        |
|---------|------|-----|------|-----|---|-------|------|------|------------|----------------|------|-----|-----|----------|
| 0       | 0    | 1   | 0    | 0   | 0 |       |      |      |            |                | 0    | 0   | 1   | 0        |
| 0       |      |     |      |     | 5 | 6     | 7    | 8    | 9          | 10 1.          | 1 12 |     | 14  | 15       |
|         |      |     |      |     |   |       |      |      |            |                |      |     |     |          |
|         |      |     |      |     |   |       |      |      |            |                |      |     |     |          |
|         |      |     |      |     |   |       |      |      | - <u>-</u> | <u> </u>       |      |     |     | -1       |
|         |      |     |      |     |   | ess/I | Disp | olac | -          |                |      |     |     | · 1<br>1 |
|         | Di   | spl | acer |     |   | ess/I | Disp |      | -          | ent<br>splaces | — –  |     |     | · 1<br>1 |

The 32-bit main storage operand specified by the effective address is algebraically subtracted from the 32-bit operand contained in the floating-point register specified by the R field. The result is placed back in the floating-point register specified by the R field. The low-order 32 bits of the specified floating-point register are unchanged. The main storage operand is unchanged.

The sign of the sum is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

#### Indicators

9-18 GA34-0021

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

#### **Register to Register Format**

FS freg,freg

| $O_{l}$ | bera | tio | n co | ode | [ | R | 1 | R | 2 |    |      | Fu | nct | ion | P  |
|---------|------|-----|------|-----|---|---|---|---|---|----|------|----|-----|-----|----|
| 0       | 0    | 1   | 0    | 0   | 1 |   |   |   |   | 0  | 0    | 0  | 0   | 1   | 0  |
| 0       |      |     | _    | 4   | 5 | 6 | 7 | 8 | 9 | 10 | ) 11 | 12 | ?   | 14  | 15 |

The 32-bit operand contained in the floating-point register specified by the R1 field is algebraically subtracted from the 32-bit operand contained in the floating-point register specified by the R2 field. The result is placed back in the floating-point register specified by the R2 field. The low-order 32 bits of the R2 register are unchanged. The R1 register is unchanged when not equal to R2.

The sign of the sum is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

**Program Check Condition** 

Protect Check. Instruction fetch.

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

## Floating Subtract Double (FSD)

#### General Description (Double Precision)

Subtraction of two floating-point numbers is based on characteristic comparison and fraction subtraction. The characteristics of the two operands are compared and the fraction accompanying the smaller characteristic is shifted right, with its characteristic increased by one for each hexadecimal digit shifted, until the two characteristics are equal.

When an operand is shifted right during alignment, the last hexadecimal digit shifted out of the 64-bit register is preserved as a guard digit with 15 digits participating in the arithmetic. The fractions are then subtracted algebraically to form an intermediate sum.

The long intermediate-sum fraction consists of 15 hexadecimal digits and a possible borrow. If a borrow is present, the sum is shifted right one digit position, and the characteristic is increased by one.

If a true subtraction is performed and the fraction is not zero, normalization takes place. The intermediate sum including the guard digit is shifted left as necessary to form a normalized number. Vacated low-order digit positions are filled with zeros, and the characteristic is reduced by the number of hexadecimal digits shifted.

#### Storage/Register Format

FSD addr4, freg

| 01 | oera | tio | n cc | de |   | R |   | R | B | AM | r  | Fu | nct | ion | P   | l |
|----|------|-----|------|----|---|---|---|---|---|----|----|----|-----|-----|-----|---|
| 0  | 0    | 1   | 0    | 0  | 0 |   |   | Í |   |    |    | 0  | 0   | 1   | 1   |   |
| 0  |      |     |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | ?   | 14  | 115 | 5 |



The 64-bit main storage operand specified by the effective address is algebraically subtracted from the 64-bit operand contained in the floating-point register specified by the R field and the result is placed back in the floating-point register specified by the R field. The main storage operand is unchanged.

The sign of the sum is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

**Program Check Conditions** 

Invalid Storage Address. Instruction word or operand.

Protect Check. Instruction fetch or operand access.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

#### Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

#### **Register to Register Format**

FSD freg,freg

| Op | era | tior | 1 со | de |   | R | 1 | R | 2 |    |    | Fu | nct | ion | P  |
|----|-----|------|------|----|---|---|---|---|---|----|----|----|-----|-----|----|
| 0  | 0   | 1    | 0    | 0  | 1 |   |   |   |   | 0  | 0  | 0  | 0   | 1   | 1  |
| 0  |     |      |      | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | ?   | 14  | 15 |

The 64-bit operand contained in the floating-point register specified by the R1 field is algebraically subtracted from the 64-bit operand contained in the floating-point register specified by the R2 field. The result is placed back in the floating-point register specified by the R2 field. The R1 register is unchanged when not equal to R2.

The sign of the sum is determined by the rules of algebra unless all digits of the intermediate-sum fraction are zero; in this case, the sign is made plus and the result characteristic is forced to zero.

#### Indicators

**Overflow.** Turned on by an exponent overflow or exponent underflow. Otherwise, the indicator is reset.

**Even.** Turned on by an exponent underflow. Otherwise, the indicator is reset.

Carry. Reset.

Negative and Zero. Changed to reflect the result.

**Program Check Condition** 

Protect Check. Instruction fetch.

Soft Exception Trap Condition

Floating-Point Exception. Overflow or underflow.

## SEFLB

## Set Floating Level Block (SEFLB)

SEFLB reg,addr4

| Op | pera                        | tio  | n co | ode |   | R    |       | R | B  | AM             | F   | une   | ctio | n  |
|----|-----------------------------|------|------|-----|---|------|-------|---|----|----------------|-----|-------|------|----|
| 0  | 1                           | 0    | 1    | 1   |   |      |       |   |    |                | 0   | 0     | 1    | 1  |
| 0  | $\frac{0}{0}$ $\frac{1}{4}$ |      |      |     | 5 |      | 7     | 8 | 9  | 10 11          | 12  | ?     |      | 15 |
|    | Di                          | spla | icei | Ac  |   | ss/D | `<br> |   | Di | ent<br>splacen | nen | t - 2 |      |    |

A floating level block in main storage is loaded into the floating-point registers for the level specified by the R field register. The generated effective address (EA) specifies the beginning address of the floating level block. The contents of main storage and the R field register remain unchanged. The floating level block appears in main storage as follows:

| EA            | Loaded into floating-point register 0 |    |
|---------------|---------------------------------------|----|
|               | Loaded into floating-point register 1 |    |
|               | Loaded into floating-point register 2 |    |
| EA + 24 (Hex) | Loaded into floating-point register 3 |    |
|               | 0                                     | 63 |

The general register specified by the R field has the format:

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | Level |  |
|---|---|---|---|---|---|---|---|---|---|---|---|---|----|-------|--|
| 0 |   |   |   |   |   |   |   |   |   |   |   |   | 13 | 14 15 |  |

Bits 0-7, 12 and 13 are not used and must be zero to avoid future code obsolescence. Bits 8-11 must be zero in order to select the floating-point feature. Bits 14 and 15 hold the binary-encoded level of the floating level block associated with this operation. For example: 00 for level 0, 01 for level 1, 10 for level 2, and 11 for level 3.

*Programming Note.* If AM=01, the register specified by the RB field is incremented by two.

#### Indicators

No indicators are changed.

#### **Program Check Conditions**

Invalid Storage Address. Instruction word or operand.

Privilege Violate. Privileged instruction.

**Specification Check.** Even byte boundary violation (indirect address or operand address).

## Appendix A. Instruction Execution Times

This appendix contains two tables:

Table 1:Instruction execution times when the Storage<br/>Address Relocation Translator feature is not<br/>installed or is disabled.

Table 2:Instruction execution times when the Storage<br/>Address Relocation Translator feature is<br/>enabled.

The instructions in each table are in alphabetical sequence based on assembler mnemonics. Figure A-1 is used with Table 1. Figure A-2 is used with Table 2.

Key to symbols for tables in this appendix:

| ,      |                                                                                            |
|--------|--------------------------------------------------------------------------------------------|
| Symbol | Meaning                                                                                    |
| Α      | Additional time for the bit number tested (see TBTV note).                                 |
| AM1    | Additional time for operand 1 addressing mode (see Figure A-1 or A-2).                     |
| AM2    | Additional time for operand 2 addressing mode (see Figure A-1 or A-2).                     |
| BT     | Bit number of tested bit (see TBTV note).                                                  |
| CL     | Current level.                                                                             |
| СТ     | The count value at the beginning of instruction execution.                                 |
| D      | Additional time for the Disable instruction (see EN note).                                 |
| Е      | Additional time for the Enable instruction (see EN note).                                  |
| IP     | In-process flag.                                                                           |
| K      | The bit number of the left most one bit (see SLTD note 2).                                 |
| RL     | Limit register (LMB and STM instructions).                                                 |
| RS     | Additional addressing-mode time for register/storage instructions (see Figure A-1 or A-2). |
| SL     | Selected level.                                                                            |
| Х      | Additional time for addressing mode when AM = 01<br>(see Figure A-1 or A-2).               |
| Y      | Additional time for addressing mode when AM = 01<br>(see Figure A-1 or A-2).               |
| *      | Indirect address.                                                                          |

#### Use this figure with Table 1.

Instructions that use addressing mode (AM) for effective address generation require additional time that must be added to the base time for execution.

• RS-the additional time for register/storage instructions

| AM      | Time (RS) |
|---------|-----------|
| 00      | 220       |
| 01      | 440       |
| 10 RB=0 | 880       |
| 10 RB≠0 | ľ100      |
| 11 RB=0 | 1540      |
| 11 RB≠0 | 2420      |

• AM1, AM2, X, Y-the additional time for storage/storage instructions

| AM      | Time (AM1) | Time (AM2) | X   | Y   |
|---------|------------|------------|-----|-----|
| 00      | 220        | 220        | 0   | 0   |
| 01      | 440        | 440        | 220 | 440 |
| 10 RB=0 | 880        | 880        | 0   | 0   |
| 10 RB≠0 | 1100       | 1100       | 0   | 0   |
| 11 RB=0 | 1540       | 1540       | 0   | 0   |
| 11 RB≠0 | 2420       | 2420       | 0   | 0   |

#### Example:

For an instruction time equal to 5720+(AM1+Y)+AM2 if AM1=01 and AM2=11 (RB $\neq$ 0) then total instruction time is 5720+(440+440)+2420=9020

• Assembler syntax for address modes

| Assembler Syntax               |                                     | Address Modes |
|--------------------------------|-------------------------------------|---------------|
| addr4                          | addr5                               | (see Note 1)  |
| (reg <sup>0-3</sup> )          | (reg)                               | 00            |
| $(reg^{0-3})+$                 | (reg)+                              | 01            |
| addr                           | addr                                | 10 RB=0       |
| (reg <sup>1-3</sup> , waddr)   | (reg <sup>1-7</sup> , waddr)        | 10 RB≠0       |
| addr*                          | addr*                               | 11 RB=0       |
| $disp1(reg^{1-3}, disp2)*$     | disp1 (reg <sup>1-7</sup> , disp2)* | )             |
| disp(reg <sup>1-3</sup> )*     | $disp(reg^{1-7})*$                  |               |
| $(reg^{1-3})^*$                | $(reg^{1-7})^*$                     | > 11 RB≠0     |
| (reg <sup>1 - 3</sup> , disp)* | (reg <sup>1-7</sup> , disp)*        | ,             |

Note 1. Register/storage instructions use assembler syntax addr4 for address mode (AM).

Storage/storage instructions use assembler syntax:

- (1) *addr5* for address mode for operand 1 (AM1), and (2) *addr4* for address mode for operand 2 (AM2).
- Figure A-1. Additional instruction times for addressing mode when the relocation translator is not installed or is disabled.

#### Use this figure with Table 2.

Instructions that use addressing mode (AM) for effective address generation require additional time that must be added to the base time for execution.

• RS-the additional time for register/storage instructions

| AM      | Time (RS) |
|---------|-----------|
| 00      | 440       |
| 01      | 660       |
| 10 RB=0 | 1320      |
| 10 RB≠0 | 1540      |
| 11 RB=0 | 2200      |
| 11 RB≠0 | 3080      |

• AM1, AM2, X, Y-the additional time for storage/storage instructions

| AM      | Time (AM1) | Time (AM2) | X   | Y   |
|---------|------------|------------|-----|-----|
| 00      | 440        | 440        | 0   | 0   |
| 01      | 660        | 660        | 220 | 440 |
| 10 RB=0 | 1320       | 1320       | 0   | 0   |
| 10 RB≠0 | 1540       | 1540       | 0   | 0   |
| 11 RB=0 | 2200       | 2200       | 0   | 0   |
| 11 RB≠0 | 3080       | 3080       | 0   | 0   |

#### Example:

For an instruction time equal to 6820+(AM1+Y)+AM2 if AM1=01and AM2=11 ( $RB\neq0$ ) then total instruction time is 6820+(660+440)+3080=11000

• Assembler syntax for address modes

| Assembler Syntax                   |                                     | Address Modes |  |  |
|------------------------------------|-------------------------------------|---------------|--|--|
| addr4                              | addr5                               | (see Note 1)  |  |  |
| (reg <sup>0-3</sup> )              | (reg)                               | 00            |  |  |
| (reg <sup>0-3</sup> )+             | (reg)+                              | 01            |  |  |
| addr                               | addr                                | 10 RB=0       |  |  |
| (reg <sup>1-3</sup> , waddr)       | (reg <sup>1-7</sup> , waddr)        | 10 RB≠0       |  |  |
| addr*                              | addr*                               | 11 RB=0       |  |  |
| disp1(reg <sup>1-3</sup> , disp2)* | disp1 (reg <sup>1-7</sup> , disp2)* | 1             |  |  |
| disp(reg <sup>1-3</sup> )*         | disp(reg <sup>1-7</sup> )*          | 11 88.0       |  |  |
| $(reg^{1-3})^*$                    | (reg <sup>1-7</sup> )*              | > 11 RB≠0     |  |  |
| (reg1 - 3, disp)*                  | (reg <sup>1-7</sup> , disp)*        |               |  |  |

Note 1. Register/storage instructions use assembler syntax addr4 for address mode (AM).

Storage/storage instructions use assembler syntax:

(1) *addr5* for address mode for operand 1 (AM1), and (2) *addr4* for address mode for operand 2 (AM2).

Figure A-2. Additional instruction times for addressing mode when the relocation translator is enabled.

# Table 1. Instruction Times-RelocationTranslator Not Installed or Disabled

| Iransiato | or Not Instaned of Disable                        | u                      | Execution times                 |
|-----------|---------------------------------------------------|------------------------|---------------------------------|
| Mnemonic  | Instruction name                                  | Syntax                 | Execution time<br>(nanoseconds) |
| AB        | Add Byte                                          | reg,addr4              | 2420+RS                         |
| AD        | Auu byte                                          | addr4,reg              | 1540+RS                         |
| ABI       | Add Byte Immediate                                | byte,reg               | 1100                            |
| ACY       | Add Carry Register                                | reg                    | 1540                            |
| AD        | Add Double Word                                   | reg,addr4              | 4180+RS                         |
|           |                                                   | addr4,reg              | 3300+RS                         |
|           |                                                   | addr5,addr4            | 5720+(AM1+Y)+AM2                |
| AW        | Add Word                                          | reg,reg                | 1100<br>2420 JBS                |
|           |                                                   | reg,addr4<br>addr4,reg | 2420+RS<br>1540+RS              |
|           |                                                   | addr5,addr4            | 3080+(AM1+Y)+AM2                |
|           |                                                   |                        | $R = 0 \qquad R \neq 0$         |
|           |                                                   | longaddr,reg           | 2420 2420                       |
|           |                                                   | longaddr*,reg          | 2860 3080                       |
| AWCY      | Add Word With Carry                               | reg,reg                | 1540                            |
| AWI       | Add Word Immediate                                | word,reg[,reg]         | 1980                            |
|           |                                                   | word,addr4             | 3740+RS                         |
| В         | Branch Unconditional                              | longaddr               | 1760                            |
|           |                                                   | longaddr*              | 2420                            |
| BAL       | Branch and Link                                   | longaddr,reg           | 1980                            |
|           |                                                   | longaddr*,reg          | 2640                            |
| BALS      | Branch and Link Short                             | (reg,jdisp)*           | 2200<br>2200                    |
|           |                                                   | (reg)*<br>addr*        | 2200                            |
| BALX      | Branch and Link External                          |                        | See BAL                         |
| DILDI     | Druhen und Emit External                          |                        | Branch                          |
|           |                                                   |                        | Not taken Taken                 |
| BC        | Branch on Condition                               | cond,longaddr          | 1540 1760                       |
|           |                                                   | cond,longaddr*         | 1540 2420                       |
|           |                                                   |                        | Branch                          |
|           |                                                   |                        | Not taken Taken                 |
| BCC       | Branch on Condition Code                          | cond,longaddr          | 1540 1760                       |
|           |                                                   | cond,longaddr*         | 1540 2420                       |
| BCY       | Branch on Carry                                   |                        | See BC                          |
| BE        | Branch on Equal                                   |                        | See BC                          |
| BER       | Branch on Error                                   |                        | See BNCC                        |
| BEV       | Branch on Even                                    |                        | See BC                          |
| BGE       | Branch on Arithmetically<br>Greater Than or Equal |                        | See BNC                         |
| BGT       | Branch on Arithmetically<br>Greater Than          |                        | See BNC                         |
| BLE       | Greater Than<br>Branch on Arithmetically          |                        | See BC                          |
|           | Less Than or Equal                                |                        |                                 |
| BLGE      | Branch on Logically                               |                        | See BNC                         |
|           | Greater Than or Equal                             |                        |                                 |
| BLGT      | Branch on Logically                               |                        | See BNC                         |
|           | Greater Than                                      |                        | 9 DG                            |
| BLLE      | Branch on Logically<br>Less Than or Equal         |                        | See BC                          |
| BLLT      | Branch on Logically                               |                        | See BC                          |
| DELI      | Less Than                                         |                        | 300 DC                          |
| BLT       | Branch on Arithmetically                          |                        | See BC                          |
|           | Less Than                                         |                        |                                 |
|           |                                                   |                        |                                 |

Table 1 (Part 1 of 10)

4

|          |                                                                |                                 | Execution time             |                |
|----------|----------------------------------------------------------------|---------------------------------|----------------------------|----------------|
| Mnemonic | Instruction name                                               | Syntax                          | (nanoseconds)              |                |
| BMIX     | Branch if Mixed                                                |                                 | See BC                     |                |
| BN       | Branch on Negative                                             |                                 | See BC                     |                |
|          |                                                                |                                 | Branch<br>Not taken Taken  |                |
| BNC      | Branch on Not Condition                                        | cond,longaddr<br>cond,longaddr* | 1540 1760<br>1540 2420     |                |
|          |                                                                |                                 | Branch<br>Not taken Taken  |                |
| BNCC     | Branch on Not Condition<br>Code                                | cond,longaddr<br>cond,longaddr* | 1540176015402420           |                |
| BNCY     | Branch on No Carry                                             |                                 | See BNC                    |                |
| BNE      | Branch on Not Equal                                            |                                 | See BNC                    |                |
| BNER     | Branch if Not Error                                            |                                 | See BCC                    |                |
| BNEV     | Branch on Not Even                                             |                                 | See BNC                    |                |
| BNMIX    | Branch if Not Mixed                                            |                                 | See BNC                    |                |
| BNN      | Branch on Not Negative                                         |                                 | See BNC                    |                |
| BNOFF    | Branch if Not Off                                              |                                 | See BNC                    |                |
| BNON     | Branch if Not On                                               |                                 | See BNC                    |                |
|          |                                                                |                                 | Branch                     |                |
|          |                                                                |                                 | Not taken Taken            |                |
| BNOV     | Branch on Not Overflow                                         | longaddr                        | 1540 1760                  |                |
| DMD      | Description Net Destriction                                    | longaddr*                       | 1540 2420                  |                |
| BNP      | Branch on Not Positive                                         |                                 | See BNC                    |                |
| BNZ      | Branch on Not Zero                                             |                                 | See BNC                    |                |
| BOFF     | Branch if Off                                                  |                                 | See BC                     |                |
| BON      | Branch if ON                                                   |                                 | See BC                     |                |
|          |                                                                |                                 | Branch<br>Not taken Taken  |                |
| BOV      | Branch on Overflow                                             | longaddr                        | 1540 1760                  |                |
|          |                                                                | longaddr*                       | 1540 2420                  |                |
| BP       | Branch on Positive                                             |                                 | See BC                     |                |
| BX       | Branch External                                                | vcon                            | See B                      |                |
| BXS      | Branch Indexed Short                                           | $(reg^{1-7}, jdisp)$            | 1320                       |                |
|          |                                                                | (reg <sup>1-7</sup> )<br>addr   | 1320<br>1320               |                |
| BZ       | Branch on Zero                                                 | auui                            |                            |                |
| CB       |                                                                | added rag                       | See BC                     |                |
| CB       | Compare Byte                                                   | addr4,reg<br>addr5,addr4        | 1540+RS<br>2200+AM1+AM2    |                |
| CBI      | Compare Byte Immediate                                         | byte,reg                        | 1100                       |                |
| CD       | Compare Double Word                                            | addr4,reg<br>addr5,addr4        | 3080+RS<br>4620+AM1+AM2    |                |
| CFED     | Compare Byte Field Equal and Decrement                         | (reg),(reg)                     | 1540+(3080 x CT)           | See CFNEN note |
| CFEN     | Compare Byte Field Equal and Increment                         | (reg),(reg)                     | 1540+(3080 x CT)           | See CFNEN note |
| CFNED    | Compare Byte Field Not<br>Equal and Decrement                  | (reg),(reg)                     | 1540+(3080 x CT)           | See CFNEN note |
| CFNEN    | Compare Byte Field Not<br>Equal and Increment                  | (reg),(reg)                     | 1540+(3080 x CT)           | See note       |
|          | <i>Note.</i> For CFED, CFEN, CFN is terminated by a comparison |                                 | act 880 if the instruction |                |

Table 1 (Part 2 of 10)

C

|          |                        |                |          |          |        |                          | Execution time         |                |
|----------|------------------------|----------------|----------|----------|--------|--------------------------|------------------------|----------------|
| Mnemonic | Instruct               | ion nar        | ne       |          |        | Syntax                   | (nanoseconds)          |                |
| CMR      | Comple                 | ment F         | legister |          |        | reg[,reg]                | 1320                   |                |
| CPAKR    | Copy A                 | ddress         |          |          |        | addr4                    | 3080+RS                |                |
|          | Key Reg                | gister         |          |          |        | reg                      | 1760                   |                |
| CPCL     | Copy C                 |                |          |          |        | reg                      | 1540                   |                |
| CPCON    | Copy Co                |                |          |          |        | reg                      | 1540                   |                |
| CPFLB    | Copy Fl                | loating        | Level    | Block    |        | reg,addr4                | 18260+RS               |                |
| CPIMR    | Copy In<br>Register    | -              | t Mask   |          |        | addr4                    | 2640+RS                |                |
| CPIPF    | Copy Ir                | n-proce        | ss Flag  | s        |        | addr4                    | 2640+RS                |                |
| CPISK    | Copy In                |                | on       |          |        | addr4                    | 3080+RS                |                |
|          | Space K                |                |          |          |        | reg                      | 1760                   |                |
| CPLB     | Copy Le                | evel Blo       | ock      |          |        | reg,addr4                |                        | SL=CL<br>SL≠CL |
| CPLSR    | Copy Le                | evel Sta       | atus Re  | gister   |        | reg                      | 1100                   |                |
| CPOOK    | Copy O                 | perand         | 1 Key    |          |        | addr4                    | 3080+RS                |                |
|          |                        |                |          |          |        | reg                      | 1760                   |                |
| CPOTK    | Copy O                 | perand         | 2 Key    |          |        | addr4                    | 3080+RS<br>1760        |                |
| CODED    | Come De                |                |          |          |        | reg                      |                        |                |
| CPPSR    | Copy Pr<br>and Res     |                | r Statu  | s        |        | addr4                    | 2640+RS                |                |
| CPSK     | Copy St                |                |          |          |        | reg,addr4                | 3740+RS                |                |
| CPSR     | Copy Se<br>Register    |                | ation    |          |        | reg,addr4                | 3520+RS                |                |
| CW       | Compar                 | e Word         | l        |          |        | reg,reg                  | 1100                   |                |
|          |                        |                |          |          |        | addr4,reg<br>addr5,addr4 | 1540+RS<br>2200+(AM1+X | )+AM2          |
| CWI      | Compar                 | o Word         | Immo     | diata    |        | word,reg                 | 1980                   | JTANIZ         |
| CWI      | Compar                 | e word         | IIIIIIe  | ulate    |        | word,addr4               | 3080+RS                |                |
| DB       | Divide H               | Byte           |          |          |        | addr4,reg                | 24220+RS               |                |
|          |                        | •              |          |          |        |                          | 28380+RS               |                |
|          |                        |                |          |          |        |                          | 32780+RS               |                |
|          |                        |                |          |          |        |                          | 3520+RS                |                |
| DD       | Divide I               | <b>\</b> auhla | Word     |          |        | addr4,reg                | 5500+RS                |                |
| DD       | Divide I               | Jouble         | wora     |          |        | add14,reg                | 41800+RS<br>49940+RS   |                |
|          |                        |                |          |          |        |                          | 58960+RS               |                |
|          |                        | •              |          |          |        |                          | 2420+RS                |                |
|          |                        |                |          |          |        |                          | 5060+RS                |                |
| DIAG     | Diagnos                | e              |          |          |        | ubyte                    | See chart              |                |
|          |                        |                |          |          |        |                          | Time                   |                |
|          | If instru              |                |          |          |        |                          | 1760                   |                |
|          | If instru<br>bits as f |                |          | s off, c | heck   | other                    |                        |                |
|          | 8                      | 9              | 12       | 14       | 15     |                          |                        |                |
|          | 0                      | x              | 0        | 0        | 0      |                          | 3520                   |                |
|          | 0                      | X              | Ő        | 0        | 1      |                          | 5060                   |                |
|          | 0                      | х              | 0        | 1        | 0      |                          | 3300                   |                |
|          | 0                      | Х              | 0        | 1        | 1      |                          | 4840                   |                |
|          | 0                      | X              | 1        | 0        | 0      |                          | 3300<br>4620           |                |
|          | 0<br>0                 | X<br>X         | 1<br>1   | 0<br>1   | 1<br>0 |                          | 4620<br>3080           |                |
|          | 0                      | X              | 1        | 1        | 1      |                          | 4400                   |                |
|          | 1                      | 0              | 0        | X        | Х      |                          | 3300                   |                |
|          | 1                      | 0              | 1        | X        | X      |                          | 3740                   |                |
|          | 1                      | 1              | X        | X        | X      |                          | 2200                   |                |
|          | Note. Y                | s can b        | e eithe  | r U or 1 | ι.     |                          |                        |                |
|          |                        |                |          |          |        |                          |                        |                |

Minimum Average Maximum Divide by zero Overflow Minimum Average Maximum Divide by zero Overflow

Table 1 (Part 3 of 10)

| Mnemon | ic Instruc        | tion na | me       |         | S           | yntax            | Execution time<br>(nanoseconds)                        |                                                             |
|--------|-------------------|---------|----------|---------|-------------|------------------|--------------------------------------------------------|-------------------------------------------------------------|
| DIS    | Disable           |         |          |         |             | byte             | 1760+D                                                 | See EN note                                                 |
| DW     | Divide            |         |          |         |             | ddr4,reg         | 22220+RS<br>26400+RS<br>31900+RS<br>2420+RS<br>4400+RS | Minimum<br>Average<br>Maximum<br>Divide by zero<br>Overflow |
| EN     | Enable            |         |          |         | u           | byte             | 1760+E                                                 | See note                                                    |
|        | Note.             | For the | DIS at   | nd EN   |             | ions, the values | of D and                                               |                                                             |
|        | E are b           | ased or | ı instru | ction-v | vord bit    | s 12–15.         |                                                        |                                                             |
|        | 12                | 13      | 14       | 15      | D           | Ε                |                                                        |                                                             |
|        | 0                 | 0       | 0        | 0       | 0           | 0                |                                                        |                                                             |
|        | 0                 | 0       | 0        | 1       | 220         | 0                |                                                        |                                                             |
|        | 0<br>0            | 0<br>0  | 1<br>1   | 0<br>1  | 220<br>440  | 220<br>220       |                                                        |                                                             |
|        | 0                 | 1       | 0        | 0       | 440         | 220              |                                                        |                                                             |
|        | 0                 | 1       | 0        | 1       | 660         | 220              |                                                        |                                                             |
|        | 0                 | 1       | 1        | 0       | 660         | 440              |                                                        |                                                             |
|        | 0                 | 1       | 1        | 1       | 880         | 440              |                                                        |                                                             |
|        | 1                 | 0<br>0  | 0<br>0   | 0<br>1  | 220<br>440  | 0<br>0           |                                                        |                                                             |
|        | 1                 | 0       | 1        | 0       | 440         | 0                |                                                        |                                                             |
|        | 1                 | 0       | 1        | 1       | 660         | 0                |                                                        |                                                             |
|        | 1                 | 1       | 0        | 0       | 660         | 220              |                                                        |                                                             |
|        | 1                 | 1       | 0        | 1       | 880         | 220              |                                                        |                                                             |
|        | 1                 | 1<br>1  | 1<br>1   | 0<br>1  | 880<br>1100 | 220<br>220       |                                                        |                                                             |
| FA     | Floatin           |         | 1        | 1       |             | ddr4,freg        | 10120+RS<br>25740+RS                                   | Minimum<br>Maximum                                          |
|        |                   |         |          |         | fi          | reg,freg         | 8360<br>23980                                          | Minimum<br>Maximum                                          |
| FAD    | Floatin           | g Add   | Double   | •       | а           | ddr4,freg        | 11440+RS<br>49060+RS                                   | Minimum<br>Maximum                                          |
|        |                   |         |          |         | f           | reg,freg         | 8580<br>47080                                          | Minimum<br>Maximum                                          |
| FC     | Floatin           | g Com   | pare     |         | f           | reg,freg         | 7700<br>22660                                          | Minimum<br>Maximum                                          |
| FCD    | Floatin           | g Com   | pare Do  | ouble   | f           | reg,freg         | 7920<br>42680                                          | Minimum<br>Maximum                                          |
| FD     | Floatin           | g Divid | le       |         | a           | ddr4,freg        | 28160+RS<br>34540+RS                                   | Minimum<br>Maximum                                          |
|        |                   |         |          |         | f           | reg,freg         | 26180<br>31240                                         | Minimum<br>Maximum                                          |
| FDD    | Floatin           | g Divid | le Doul  | ble     |             | ddr4,freg        | 53240+RS<br>66660+RS                                   | Minimum<br>Maximum                                          |
|        |                   |         |          |         | f           | reg,freg         | 50160<br>62260                                         | Minimum<br>Maximum                                          |
| FFD    | Fill By<br>Decrem |         | l and    |         | r           | eg,(reg)         | 1540+(1980 x CT)                                       |                                                             |
| FFN    | Fill By<br>Increm |         | l and    |         | r           | eg,(reg)         | 1540+(1980 x CT)                                       |                                                             |
| FM     | Floatin           | g Multi | iply     |         |             | ddr4,freg        | 19360+RS<br>22220+RS                                   | Minimum<br>Maximum                                          |
|        |                   | _       |          |         |             | reg,freg         | 16500<br>19140                                         | Minimum<br>Maximum                                          |
| FMD    | Floatin<br>Double | -       | iply     |         |             | ddr4,freg        | 23760+RS<br>30140+RS<br>20240                          | Minimum<br>Maximum<br>Minimum                               |
| h      |                   |         |          |         | t           | reg,freg         | 20240<br>26400                                         | Minimum<br>Maximum                                          |

C

| Mnemo       Syntax       (nanoseconds)         FWV       Floating Move       adds4 freg       6400         FMVC       Floating Move and       addr4 freg       1210+R       Minimum         16940+RS       1210+R       Minimum         16940+RS       1210+R       Minimum         17380+RS       1120+R       Minimum         Convert       addr4 freg       1210+R       Minimum         Convert Double       freg,addr4       1220+R       Minimum         Convert Double       freg,addr4       30800+RS       Minimum         Somo       1220-R       Minimum       30800-RS       Minimum         Somo       Freg,addr4       30800+RS       Minimum       30800-RS       Minimum         FMVD       Floating Move Double       freg,addr4       8360+RS       Minimum       30800-RS       Minimum         SFN       Floating Subtract       addr4 freg       1240+RS       Maximum       Minimum         SFN       Floating Subtract Double       addr4 freg       3060+RS       Minimum       Minimum         SFN       Floating Subtract Double       addr4 freg       1240+RS       Minimum       Minimum         SFN       Floating Subtract Double                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |                                |                          | Execution to | ime          |          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------|--------------------------|--------------|--------------|----------|
| Fregring<br>fregring4400<br>fregringFMVCFloating Move and<br>Convertaddr4,freg<br>addr412100+RS<br>16940+RSMinimum<br>Minimum<br>17380+RSFMVCDFloating Move and<br>Convert Doubleaddr4,freg<br>addr412100+RS<br>1200+RSMinimum<br>Minimum<br>17380+RSFMVDFloating Move Double<br>Convert Doubleaddr4,freg<br>addr412100+RS<br>1200+RSMinimum<br>Minimum<br>30800+RSFMVDFloating Move Double<br>meg.freg<br>freg.freg<br>freg.fregaddr4,freg<br>25300<br>Freg.freg<br>25007480+RS<br>Maximum<br>30800+RSMinimum<br>Maximum<br>30800+RSFMVDFloating Subtractaddr4,freg<br>meg.freg1440+RS<br>3630Minimum<br>Maximum<br>23980Minimum<br>Maximum<br>23980FSFloating Subtract Double<br>addr4,fregaddr4,freg<br>1440+RS<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>23980Minimum<br>Maximum<br>Maximum<br>1200FSDFloating Subtract Double<br>addr4,fregaddr4,freg<br>11440+RS<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>1210FSDFloating Subtract Double<br>addr4,fregaddr4,freg<br>11440+RS<br>Maximum<br>1210Minimum<br>Maximum<br>1230FSDFloating Subtract Double<br>addr4,fregaddr4,freg<br>11440+RS<br>Maximum<br>1230Maximum<br>Maximum<br>1230FGDOperate I/Ô<br>longaddtmaximum<br>1240See note<br>1320JOPJump on Condition<br>jaddrjadgr<br>jaddr<br>12001320JCTJump on Condition<br>jaddr,reg13201980JCTJump on Carry<br>Less Tha                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Mnemonic | Instruction name               | Syntax                   | (nanosecond  | ls)          |          |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | FMV      | Floating Move                  | addr4,freg               | 6380+RS      |              |          |
| FNVC     Floating Move and<br>Convert     addr4, freg     12100+RS     Minimum       Freg.addr4     8360+RS     Minimum       FNVCD     Floating Move and<br>Convert Double     addr4, freg     12100+RS     Minimum       FNVCD     Floating Move and<br>Convert Double     addr4, freg     12100+RS     Minimum       FWVD     Floating Move Double     addr4, freg     7800+RS     Minimum       FRVD     Floating Move Double     addr4, freg     7800+RS     Minimum       FRVD     Floating Move Double     addr4, freg     7800+RS     Minimum       FRVD     Floating Move Double     addr4, freg     7800+RS     Minimum       FRS     Floating Subtract     addr4, freg     1440+RS     Maximum       Freg.afreg     8360     Minimum     4000     See note       Freg.freg     850     Maximum     4000     See note       Ingaddr     4400     4400     See note     See note       Ingaddr     1320     Jum     Jum     Jum     Jum       JAL     Jump on Condition     jdisp.reg     1320     Jum       JAL     Jump on Condition     jdisp.reg     1320     Jum       JAL     Jump on Condition     jdisp.reg     1320     Jum       JAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |                                | <b>•</b>                 |              |              |          |
| $\begin{array}{c c c c c } \mbox{Convert} & 169 \mbox{Fielder} & 169 \mbox{Fielder} & 173 \mbox{Fielder} & 173 \mbox{Fielder} & 173 \mbox{Fielder} & 173 \mbox{Fielder} & 173 \mbox{Fielder} & 112 \mbox{Convert} Duble & 121 \mbox{Fielder} & 112 \mbox{Convert} Duble & 122 \mbox{Fielder} & 112 \mbox{Convert} Duble & 122 \mbox{Fielder} & 112 \mbox{Convert} Duble & 122 \mbox{Fielder} & 112 \mbox{Convert} Duble & 122 \mbox{Fielder} & 112 \mbox{Convert} & 120 \mbox{Fielder} & 112 \mbox{Convert} & 100 \mbox{Fielder} & 1140 \mbox{Fielder} & 123 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 123 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1140 \mbox{Fielder} & 1100 F$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |                                | freg,addr4               | 6380+RS      |              |          |
| FMVCD<br>Floating Move and<br>Convert Doubleaddr4,freg<br>pation 11220+RS<br>Freg.addr41210+RS<br>2100+RS<br>S0800+RS<br>Maximum<br>MaximumFMVD<br>Floating Move Double<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FMVC     |                                | addr4,freg               |              |              |          |
| FNVCD:       Floating Move and<br>Convert Double       addr4, freg<br>reg.addr4       1210+RS<br>28160+RS       Minimum<br>Maximum         FWVD:       Floating Move Double       addr4, freg<br>reg.addr4       7480+RS       Minimum<br>30800+RS         FWVD:       Floating Move Double       addr4, freg<br>reg.addr4       8360+RS       Minimum<br>25740+RS       Minimum<br>25740+RS       Minimum<br>25740+RS       Minimum<br>25740+RS       Minimum<br>25740+RS       Minimum<br>261020+RS       Minimum<br>27000         FSD:       Floating Subtract       addr4, freg<br>addr4, freg       11440+RS       Minimum<br>27000       Maximum         FSD:       Floating Subtract Double       addr4, freg<br>addr4, freg       1440+RS       Maximum         FSD:       Floating Subtract Double       addr4, freg<br>addr4, freg       1440+RS       Maximum         FSD:       Floating Subtract Double       addr4, freg<br>addr4, freg       1440+RS       Maximum         FRG       Reg.freg       880       Se note       Maximum         Freg.freg       880       Se note       Se note       Se note         IOP       Interchange Operand Keys       1760       Se note       Se note         JOP       Interchange Registers       reg.freg       1320       Se note         JAL       Jump on Conditional       jdisp.reg       <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |                                | freg,addr4               |              |              |          |
| $\begin{array}{cccc} \mbox{Convert Double} & treg_addr4 & 11220+R8 & Maximum Mximum                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | FMVCD    | Floating Move and              | addr4.freg               |              |              |          |
| FMVDFloating Move Double<br>reg.freg<br>freg.addr43600+RSMaximum<br>5500FSFloating Subtractaddr4,freg<br>reg.addr43500+RSMinimum<br>Maximum<br>25740+RSMinimum<br>Maximum<br>MaximumFSFloating Subtract Double<br>addr4,fregaddr4,freg<br>49060+RSMinimum<br>23980Minimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>49060+RSFSDFloating Subtract Doubleaddr4,freg<br>1440+RS1440+RS<br>49060+RSMinimum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>49060+RSFSDFloating Subtract Double<br>160addr4,freg<br>19001440+RS<br>49060+RSMinimum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>49060+RSFSDFloating Subtract Double<br>160addr4,freg<br>19001440+RS<br>49060+RSMinimum<br>Maximum<br>49060+RSMaximum<br>Maximum<br>49060+RSFSDFloating Subtract Double<br>100longaddr<br>16004400See note<br>1002See note<br>1002IOPKInterchange Operand Keys<br>jaddrreg.reg<br>13201320JALJump unconditional<br>jaddr,regjaddr880JCJump on Count<br>1940jadgr,reg<br>jaddr,reg1320JCTJump on CurtySee JCJCTJump on CartySee JCJCTJump on Arithmetically<br>Creater Than or EqualSee JC- <t< td=""><td></td><td>2</td><td></td><td></td><td></td><td></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          | 2                              |                          |              |              |          |
| FMVDFloating Move Doubleaddr4, freg<br>reg.,adr47480+RS<br>5500<br>freg.,adr4Maximum<br>2570+RSMinimum<br>Maximum<br>2370+RSMinimum<br>Maximum<br>Maximum<br>23980Minimum<br>Maximum<br>Maximum<br>23980Minimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>A7080Minimum<br>Maximum<br>Maximum<br>RMinimum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>RMinimum<br>49060+RSMinimum<br>Maximum<br>Maximum<br>RFDFloating Subtract Doubleaddr4, freg<br>teg.freg880-Minimum<br>49060+RSMaximum<br>Maximum<br>RIOPOperate I/Olongaddr44004400See note<br>100See note<br>100See note<br>100IOPKInterchange Operand Keysreg.freg<br>jaddr1320JALJump and Linkjdisp<br>jaddr, reg1320JCCJump on Countjdisp, reg<br>jaddr, reg154017601980JCYJump on Countjdisp, reg<br>jaddr, reg154017601980JCYJump on Arithmetically<br>Less Than or EqualSee JCJCEJump on Arithmetically<br>Than or EqualSee JC <td></td> <td></td> <td>freg,addr4</td> <td>11220+RS</td> <td></td> <td>Minimum</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |                                | freg,addr4               | 11220+RS     |              | Minimum  |
| $\begin{array}{c c c c c } & \operatorname{Feq. freg.} & \operatorname{S500} \\ & \operatorname{Feq. ddr4} & \operatorname{8360+RS} & & \operatorname{Maximum} \\ & \operatorname{25740+RS} & \operatorname{Maximum} \\ & \operatorname{25740+RS} & \operatorname{Maximum} \\ & \operatorname{Maximum} \\ & \operatorname{Rainmum} \\ & Rainm$ |          |                                |                          | 30800+RS     |              | Maximum  |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | FMVD     | Floating Move Double           | addr4,freg               | 7480+RS      |              |          |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |                                |                          |              |              |          |
| FSDFloating Subtract Double<br>reg.freg $3300$ Maximum<br>Maximum<br>Maximum<br>$49060+RS$ Maximum<br>Maximum<br>Maximum<br>$47080$ Maximum<br>Maximum<br>$47080$ FSDFloating Subtract Double<br>reg.freg $addr4,freg$<br>$4000+RS$ $11440+RS$<br>$49060+RS$ Minimum<br>Maximum<br>Maximum<br>$7000+RS$ Minimum<br>Maximum<br>Maximum<br>$7000+RS$ Minimum<br>Maximum<br>Maximum<br>$7000+RS$ Minimum<br>Maximum<br>Maximum<br>$7000-RS$ IOOperate I/Olongaddr40004400See note<br>See noteNote. Channel and device times mus be added (typically<br>IRInterchange Registers<br>jaddr1760See noteIRInterchange Registers<br>jaddrreg.reg1320See noteJALJump and Linkjdisp.reg1320Seejaddr,reg1320SeeSeeSeeJCJump on Conditioncond,jdisp.reg1320SeeJCJump on Countjdisp.reg154017601980JCYJump on CarrySee JCSeeSeeSeeJCJump on CarrySeeSeeSeeSeeJCJump on Arithmetically<br>Creater Than or EqualSeeSeeSeeSeeJLGEJump on Logically Greater<br>Than or EqualSeeSeeSeeSeeSeeJLTJump on Logically Less<br>Than or EqualSeeSeeSeeSeeSeeSeeJLLTJump on Logically Less<br>Than or EqualSeeSeeSeeSeeSeeSee<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |                                | freg,addr4               | 8360+RS      |              |          |
| FSDFloating Subtract Double<br>addr4,fregaddr4,freg<br>addr4,freg11440+RS<br>49060+RSMaximum<br>Maximum<br>49060Mainimum<br>49060Feg.freg8580<br>47080Maximum<br>R = 0R ≠ 0Maximum<br>Maximum<br>Maximum<br>R = 0R ≠ 0IOOperate I/O<br>0longaddr<br>longaddr44004400See noteIOOperate I/O<br>0longaddr<br>longaddr44004400See noteIOOperate I/O<br>0longaddr<br>longaddr48405060See noteIOInterchange Operand Keysreg,reg1320IJJump Unconditional<br>jdisp.reg1320IIJALJump and Link<br>jaddr, reg1320IIJALJump and Linkjdisp,reg1320IJCCJump on Condition<br>igaddr,reg11001320IJCTJump on Conditioncond jaddr15401760JCTJump on CarrySee JCI1980JCYJump on EqualSee JCI1980JGTJump on Arithmetically<br>Creater Than or EqualSee JNCIJLGEJump on Logically Greater<br>Than or EqualSee JNCIIJLGTJump on Logically GreaterSee JNCIIJLTJump on Logically Less<br>Than or EqualSee JCIIJLTJump on Logically Less<br>Than or EqualSee JCIIJLTJump on Logically Greater<br>ThanSee JCII <t< td=""><td>FS</td><td>Floating Subtract</td><td>addr4,freg</td><td></td><td></td><td></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | FS       | Floating Subtract              | addr4,freg               |              |              |          |
| FSD         Floating Subtract Double         addr4,freg         11440+RS<br>49060+RS         Minimum<br>49060+RS         Maximum<br>Maximum<br>47080         Maximum<br>47080         Maximum<br>47080         Minimum<br>Maximum<br>47080         Minimum<br>Maximum<br>47080         Minimum<br>Maximum<br>47080         Minimum<br>47080         Minimum<br>Maximum<br>47080         Minimum<br>47080         Minimum<br>Maximum<br>47080         Minimum<br>Maximum<br>Maximum<br>Maximum<br>47080         Minimum<br>47080         Minimum<br>47080         Minimum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maximum<br>Maxim<br>Maximum<br>Maxim<br>Maximum<br>Maxim<br>Maximum<br>Maxim<br>Maximum<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Maxim<br>Ma                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |                                | freg,freg                | 8360         |              | Minimum  |
| free,free49060+RS<br>8580Maximum<br>Maximum<br>47080IOOperate I/Olongaddr44004400See note<br>See noteIOOperate I/Olongaddr*48405060See noteIOOperate I/Olongaddr*48405060See noteIOOperate I/Oiongaddr*1760.See noteSee noteIOInterchange Operand Keys1760.See noteSee noteIRInterchange Operand Keys1760.See noteSee noteJJump Unconditionaljdisp.reg1320See notejaddr,reg1320See noteSee noteSee noteJALJump and Linkjdisp.reg1320See notejaddr,reg1320See noteSee noteSee noteJCJump on Conditioncond.jdisp11001320CTJump on Countjdisp.reg15401760JCYJump on CarrySee JCSee JCJEVJump on EqualSee JNCSee JNCJEVJump on Arithmetically<br>Less Than or EqualSee JNCJCGJump on Arithmetically Greater<br>Than or EqualSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCJLLTJump on Logically Less<br>Than or EqualSee JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |                                |                          | 23980        |              | Maximum  |
| freg.freg\$\$580<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>47080Minimum<br>4800See inter<br>1800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800Minimum<br>4800 </td <td>FSD</td> <td>Floating Subtract Double</td> <td>addr4,freg</td> <td>11440+RS</td> <td></td> <td>Minimum</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | FSD      | Floating Subtract Double       | addr4,freg               | 11440+RS     |              | Minimum  |
| IOOperate I/Olongaddr<br>longaddr47080<br>$R \neq 0$ Maximum<br>$R = 0$<br>$R \neq 0$ IOOperate I/Olongaddr<br>longaddr44004400See noteNote. Channel and device times must be added (typically 1760).Note. Channel and device times must be added (typically 1760).See noteIOPKInterchange Operand Keys1760See noteSee noteIRInterchange Operand Keys1760See noteJJump Unconditional<br>jaddrjdisp880SeeJALJump and Linkjdisp,reg<br>jaddr,reg1320SeeJCJump on Conditioncond,jaiddr11001320JCJump on Conditioncond,jaiddr11001320JCTJump on Count<br>jaddr,reg154017601980JCYJump on CarrySee JCSeeJSEJEVJump on EvenSeeSeeJSEJGEJump on Arithmetically<br>Less Than or EqualSeeSeeSeeJLEJunp on Arithmetically Greater<br>ThanSeeSeeSeeJLGTJunn on Logically Greater<br>Than or EqualSeeSeeSeeJLEJunn on Logically Greater<br>ThanSeeSeeSeeJLLTJunp on Logically Less<br>Than or EqualSeeSeeSeeJLLTJunp on Logically LessSeeSeeSee                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |                                |                          | 49060+RS     |              | Maximum  |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |                                | freg,freg                |              |              |          |
| IOOperate I/Olongaddr<br>longaddr*44004400<br>4400See note<br>See noteNore. Channel and device times must be added (typically<br>IR1760,1760,IOPKInterchange Operand Keys1760,IRInterchange Registersreg,reg1320JJump Unconditional<br>jaddrjdisp880JALJump and Linkjdisp,reg1320JALJump on Conditioncond,jdisp11001320JCJump on Conditioncond,jdisp11001320JCJump on Countjdisp,reg154017601980JCYJump on Countjdisp,reg154017601980JCYJump on EqualSee JCSee JC19801980JCYJump on EqualSee JCSee JC1980JGEJump on Arithmetically<br>Greater Than or EqualSee JNCSee JNCJGEJump on Arithmetically<br>Less Than or EqualSee JNCSee JNCJLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |                                |                          | 47080        |              | Maximum  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |                                |                          | R = 0        | <i>R ≠ 0</i> |          |
| Note. Channel and device times must be added (typically 1760).IOPKInterchange Operand Keys1760IRInterchange Registersreg.reg1320JJump Unconditionaljdisp880JALJump and Linkjdisp.reg1320jaddr,reg1320JumpJALJump on Conditioncond.jdisp1320JUmp on Conditioncond.jdisp11001320JCJump on Conditioncond.jdisp11001320JCJump on Conditioncond.jdisp154017601980JCTJump on Countjdisp.reg154017601980JCYJump on CarrySee JCSee JC19801980JEVJump on EqualSee JCSee JC19801980JGTJump on Arithmetically<br>Creater Than or EqualSee JNCSee JNCSee JNCJLEJump on Arithmetically<br>Less Than or EqualSee JNCSee JNCSee JNCJLGFJump on Logically Greater<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically Greater<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically Ices<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically Ices<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically Greater<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically Ices<br>Than or EqualSee JNCSee JNC<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Ю        | Operate I/O                    |                          | 4400         | 4400         | See note |
| IOPKInterchange Operand Keys1760IRInterchange Registersreg,reg1320JJump Unconditionaljdisp880jaddr880jaddr880JALJump and Linkjdisp,reg1320JALJump and Linkjdisp,reg1320JCJump on Conditioncond,jdisp11001320JCJump on Conditioncond,jdisp,reg154017601980JCJump on Conditioncond,jaddr11001320CT=0CT>1JCTJump on Countjdisp,reg154017601980JCYJump on CarrySee JC154017601980JCYJump on EqualSee JC154017601980JCYJump on EvenSee JC154017601980JGEJump on Arithmetically<br>Greater Than or EqualSee JCSee JC1760JGEJump on Arithmetically<br>Less Than or EqualSee JC17601980JLEJump on Logically Greater<br>ThanSee JNC17601980JLGTJump on Logically Greater<br>Than or EqualSee JNC17601980JLLTJump on Logically Less<br>Than or EqualSee JC17601760JLLTJump on LogicallySee JC17601980JLLTJump on LogicallySee JC17601980JLLTJump on LogicallySee JC17601760                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                                | longaddr*                | 4840         | 5060         | See note |
| IR<br>IInterchange Registers<br>Jump Unconditional<br>jdisp<br>jaddrreg,reg<br>jdisp<br>jaddr1320JALJump and Link<br>jdisp,reg<br>jdisp,reg<br>LCP13201320JALJump and Linkjdisp,reg<br>jdidr,reg1320JCJump on Conditioncond,jdisp<br>cond,jaddr11001320JCJump on Conditioncond,jdisp<br>reg<br>jaddr,reg11001320JCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JC154017601980JCYJump on EqualSee JCSee JC1980JGTJump on Arithmetically<br>Greater Than or EqualSee JCSee JCJLEJump on Arithmetically<br>Creater Than or EqualSee JNCSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Greater<br>Than or EqualSee JNCSee JNC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          | Note. Channel and device times | must be added (typically | y 1760).     |              |          |
| JJump Unconditional<br>jaddrjdisp<br>jaddr880JALJump and Linkjdisp,reg<br>jaddr,reg1320JALJump and Linkjdisp,reg<br>jaddr,reg1320JCJump on Conditioncond,jdisp<br>cond,jaddr11001320JCJump on Conditioncond,jdisp<br>cond,jaddr11001320JCTJump on Countjdisp,reg<br>jaddr,reg140017601980JCYJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JCSee JCSee JCSee JCJEJump on EqualSee JCSee JNCSee JNCSee JNCJCTJump on Arithmetically<br>Greater Than or EqualSee JNCSee JNCSee JNCJLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically LessSee JNCSee JNCSee JNCJLLTJump on Logically LessSee JNCSee JNCSee JNC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | IOPK     | Interchange Operand Keys       |                          | 1760         |              |          |
| JALJump and Linkjaddr<br>jdisp,reg<br>jaddr,reg880JALJump and Linkjdisp,reg<br>jaddr,reg1320JUmp<br>Not takenTakenTakenJCJump on Conditioncond,jdisp<br>cond,jaddr11001320JCJump on Conditioncond,jdisp<br>cond,jaddr11001320JCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JCIS4017601980JCYJump on EqualSee JCIS4017601980JEVJump on EqualSee JCIS4017601980JGTJump on Arithmetically<br>Greater Than or EqualSee JNCIS40IS40JLEJump on Arithmetically<br>Less Than or EqualSee JNCIS40IS40JLGTJump on Logically Greater<br>Than or EqualSee JNCIS40IS40JLLEJump on Logically Greater<br>Than or EqualSee JNCIS40IS40JLLTJump on Logically Less<br>Than or EqualSee JNCIS40IS40JLLTJump on Logically Less<br>Than or EqualSee JNCIS40IS40JLLTJump on Logically Less<br>Than or EqualSee JCIS40IS40JLLTJump on Logically Less<br>Than or EqualSee JCIS40IS40JLLTJump on Logically Less<br>Than or EqualSee JCIS40IS40JLLTJump on LogicallyIS40See JCIS40JLLTJump on LogicallyIS40<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | IR       | Interchange Registers          | reg,reg                  | 1320         |              |          |
| JALJump and Linkjdisp,reg<br>jaddr,reg1320<br>1320<br>Jump<br>Not takenJade<br>TakenJCJump on Conditioncond,jdisp<br>cond,jaddr11001320<br>CT=0CT=1CT>1JCJump on Conditioncond,jaddr11001320<br>CT=0CT=1CT>1JCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JC154017601980JEJump on EqualSee JCSee JC1980JEVJump on EvenSee JCSee JCSee JCJGEJump on Arithmetically<br>Greater Than or EqualSee JNCSee JNCJLEJump on Arithmetically<br>Less Than or EqualSee JNCSee JNCJLGTJump on Logically Greater<br>ThanSee JNCSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | J        | Jump Unconditional             |                          |              |              |          |
| JCJump on Conditioncond,jdisp<br>cond,jaddr1320<br>Jump<br>Not takenTakenJCJump on Conditioncond,jdisp<br>cond,jaddr11001320<br>1320<br>CT=0CT> IJCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JC154017601980JCYJump on EqualSee JC19801980JCYJump on EqualSee JC1980JCYJump on EqualSee JC1980JCYJump on Arithmetically<br>Greater Than or EqualSee JNC1980JLEJump on Arithmetically<br>Creater ThanSee JNC1980JLGEJump on Logically Greater<br>Than or EqualSee JNC1980JLLEJump on Logically Greater<br>Than or EqualSee JNC1980JLLEJump on Logically Less<br>Than or EqualSee JNC1980JLLEJump on Logically Less<br>Than or EqualSee JC1980JLLTJump on Logically Less<br>Than or EqualSee JC1980JLLTJump on Logically Less<br>Than or EqualSee JC1980                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          | T                              | -                        |              |              |          |
| JCJump on Conditioncond,jdisp<br>cond,jaddr11001320<br>1320<br>$CT=0$ $CT > 1$ JCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JC154017601980JEJump on EqualSee JCSee JCSee JCSee JCJEVJump on EvenSee JCSee JCSee JCSee JCJGEJump on Arithmetically<br>Greater Than or EqualSee JNCSee JNCSee JNCJLEJump on Arithmetically<br>Less Than or EqualSee JNCSee JNCSee JNCJLGEJump on Logically Greater<br>ThanSee JNCSee JNCSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JNCSee JNCSee JNC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | JAL      | Jump and Link                  |                          |              |              |          |
| JCJump on Conditioncond,jdisp<br>cond,jaddr11001320<br>1320JCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JC17601980JCYJump on EqualSee JC17601980JEVJump on EvenSee JC17601980JGEJump on Arithmetically<br>Greater Than or EqualSee JNC11JLEJump on Arithmetically<br>Less Than or EqualSee JNC11JLGEJump on Logically Greater<br>ThanSee JNC11JLEJump on Logically Greater<br>Than or EqualSee JNC11JLEJump on Logically Greater<br>Than or EqualSee JNC11JLLTJump on Logically Less<br>Than or EqualSee JC11JLLTJump on Logically Less<br>Than or EqualSee JC11JLLTJump on Logically Less<br>Than or EqualSee JC11JLTJump on LogicallySee JC11JLTJump on LogicallySee JC11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                                |                          | •            | Taken        |          |
| cond jaddr11001320 $CT=0$ $CT=1$ $CT>1$ JCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JC17601980JCYJump on EqualSee JCJEJump on EvenSee JCJEVJump on EvenSee JCSee JCJEJGEJump on Arithmetically<br>Greater Than or EqualSee JNCSee JNCJLEJump on Arithmetically<br>Less Than or EqualSee JCSee JNCJLGEJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCSee JNCJLLTJump on Logically Less<br>Than or EqualSee JCSee JNC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | IC       | Jump on Condition              | cond idisn               |              |              |          |
| JCTJump on Countjdisp,reg<br>jaddr,reg $CT=0$ $CT=1$ $CT>1$ JCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySee JC17601980JEJump on EqualSee JCImportImportJEVJump on EvenSee JCImportImportJGEJump on Arithmetically<br>Greater Than or EqualSee JNCImportJGTJump on Arithmetically<br>Greater ThanSee JNCImportJLEJump on Arithmetically<br>Greater ThanSee JNCImportJLGEJump on Logically Greater<br>Than or EqualSee JNCImportJLEJump on Logically Greater<br>Than or EqualSee JNCImportJLLEJump on Logically Less<br>Than or EqualSee JCImportJLLTJump on LogicallySee JCImport                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          | tump on contacton              | ~ .                      |              |              |          |
| JCTJump on Countjdisp,reg<br>jaddr,reg154017601980JCYJump on CarrySeeJCJEJump on EqualSeeJCJEVJump on EvenSeeJCJGEJump on Arithmetically<br>Greater Than or EqualSeeJCJGTJump on Arithmetically<br>Greater ThanSeeJCJLEJump on Arithmetically<br>Greater ThanSeeJCJGTJump on Arithmetically<br>Greater ThanSeeJCJLEJump on Arithmetically<br>Greater ThanSeeJCJLEJump on Logically Greater<br>Than or EqualSeeJNCJLLEJump on Logically Less<br>Than or EqualSeeJCJLLTJump on LogicallySeeJC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |                                |                          |              |              | CT > 1   |
| jaddr,reg154017601980JCYJump on CarrySee JCJEJump on EqualSee JCJEVJump on EvenSee JCJGEJump on Arithmetically<br>Greater Than or EqualSee JNCJGTJump on Arithmetically<br>Greater ThanSee JNCJLEJump on Arithmetically<br>Greater Than or EqualSee JNCJLEJump on Arithmetically<br>Greater ThanSee JNCJLEJump on Logically Greater<br>Than or EqualSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Less<br>Than or EqualSee JCJLLTJump on Logically Less<br>Than or EqualSee JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ICT      | Jump on Count                  | idien reg                |              |              |          |
| JCYJump on CarrySee JCJEJump on EqualSee JCJEVJump on EvenSee JCJGEJump on Arithmetically<br>Greater Than or EqualSee JNCJGTJump on Arithmetically<br>Greater ThanSee JNCJLEJump on Arithmetically<br>Greater Than or EqualSee JNCJLEJump on Arithmetically<br>Greater ThanSee JNCJLEJump on Arithmetically<br>Greater Than or EqualSee JNCJLEJump on Logically Greater<br>Than or EqualSee JNCJLGEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Less<br>Than or EqualSee JCJLLTJump on Logically Less<br>Than or EqualSee JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 301      | Jump on Count                  |                          |              |              |          |
| JEJump on EqualSee JCJEVJump on EvenSee JCJGEJump on Arithmetically<br>Greater Than or EqualSee JNCJGTJump on Arithmetically<br>Greater ThanSee JNCJLEJump on Arithmetically<br>Greater Than or EqualSee JCJLEJump on Arithmetically Greater<br>Than or EqualSee JNCJLGEJump on Logically Greater<br>Than or EqualSee JNCJLGEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Less<br>Than or EqualSee JCJLLEJump on Logically Less<br>Than or EqualSee JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | JCY      | Jump on Carry                  | j                        |              | 1.00         | 1.00     |
| JEVJump on EvenSee JCJGEJump on Arithmetically<br>Greater Than or EqualSee JNCJGTJump on Arithmetically<br>Greater ThanSee JNCJLEJump on Arithmetically<br>Less Than or EqualSee JCJLGEJump on Logically Greater<br>Than or EqualSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Less<br>Than or EqualSee JCJLLEJump on Logically Less<br>Than or EqualSee JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |                                |                          |              |              |          |
| JGEJump on Arithmetically<br>Greater Than or EqualSee JNCJGTJump on Arithmetically<br>Greater ThanSee JNCJLEJump on Arithmetically<br>Less Than or EqualSee JCJLGEJump on Logically Greater<br>Than or EqualSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Less<br>Than or EqualSee JCJLLEJump on Logically Less<br>Than or EqualSee JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |                                |                          |              |              |          |
| Greater Than or EqualJGTJump on Arithmetically<br>Greater ThanSee JNCJLEJump on Arithmetically<br>Less Than or EqualSee JCJLGEJump on Logically Greater<br>Than or EqualSee JNCJLGTJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Greater<br>ThanSee JNCJLLEJump on Logically Greater<br>Than or EqualSee JNCJLLEJump on Logically Less<br>Than or EqualSee JCJLLTJump on Logically Less<br>Than or EqualSee JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          | • ,                            |                          |              |              |          |
| Greater Than       Greater Than         JLE       Jump on Arithmetically<br>Less Than or Equal       See JC         JLGE       Jump on Logically Greater<br>Than or Equal       See JNC         JLGT       Jump on Logically Greater<br>Than       See JNC         JLLE       Jump on Logically Less<br>Than or Equal       See JC         JLLE       Jump on Logically Less<br>Than or Equal       See JC         JLLT       Jump on Logically       See JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | JGE      |                                |                          | See JNC      |              |          |
| Less Than or Equal     See JNC       JLGE     Jump on Logically Greater     See JNC       Than or Equal     See JNC       JLGT     Jump on Logically Greater     See JNC       JLLE     Jump on Logically Less     See JC       Than or Equal     See JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | JGT      | Jump on Arithmetically         |                          | See JNC      |              |          |
| Than or Equal       JLGT     Jump on Logically Greater     See JNC       Than     Than       JLLE     Jump on Logically Less     See JC       Than or Equal     See JC       JLLT     Jump on Logically                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | JLE      | -                              |                          | See JC       |              |          |
| Than     See JC       JLLE     Jump on Logically Less     See JC       Than or Equal     See JC       JLLT     Jump on Logically     See JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | JLGE     | Jump on Logically Greater      |                          | See JNC      |              |          |
| Than or Equal<br>JLLT Jump on Logically See JC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | JLGT     |                                |                          | See JNC      |              |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | JLLE     |                                |                          | See JC       |              |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | JLLT     |                                |                          | See JC       |              |          |

Table 1 (Part 5 of 10)

| Mnemonic | Instruction name                    | Syntax                                | Execution time<br>(nanoseconds)    |                               |
|----------|-------------------------------------|---------------------------------------|------------------------------------|-------------------------------|
| JLT      | Jump on Arithmetically<br>Less Than |                                       | See JC                             |                               |
| JMIX     | Jump if Mixed                       |                                       | See JC                             |                               |
| JN       | Jump on Negative                    |                                       | See JC                             |                               |
|          | Camp on regarde                     |                                       | Jump                               |                               |
|          |                                     |                                       | Not taken Taken                    |                               |
| JNC      | Jump on Not Condition               | cond,jdisp<br>cond,jaddr              | 1100132011001320                   |                               |
| JNCY     | Jump on No Carry                    |                                       | See JNC                            |                               |
| JNE      | Jump on Not Equal                   |                                       | See JNC                            |                               |
| JNEV     | Jump on Not Even                    |                                       | See JNC                            |                               |
| JNMIX    | Jump if Not Mixed                   |                                       | See JNC                            |                               |
| JNN      | Jump on Not Negative                |                                       | See J NC                           |                               |
| JNOFF    | Jump if Not Off                     |                                       | See JNC                            |                               |
| JNON     | Jump if Not On                      |                                       | See JNC                            |                               |
| JNP      | Jump on Not Positive                |                                       | See JNC                            |                               |
| JNZ      | Jump on Not Zero                    |                                       | See JNC                            |                               |
| JOFF     | Jump if Off                         |                                       | See JC                             |                               |
| JON      | Jump if On                          |                                       | See JC                             |                               |
| JP       | Jump on Positive                    |                                       | See JC                             |                               |
| JZ       | Jump on Zero                        |                                       | See JC                             |                               |
| LEX      | Level Exit                          | [ubyte]                               | 2860                               |                               |
| LMB      | Load Multiple and Branch            | addr4                                 | 7700+RS RL=7<br>8580+(660xRL)+RS R | L <b>#</b> 7                  |
| MB       | Multiply Byte                       | addr4,reg                             | 10340+RS<br>16940+RS<br>23320+RS   | Minimum<br>Average<br>Maximun |
| MD       | Multiply Doubleword                 | addr4,reg                             | 10780+RS<br>26400+RS<br>41800+RS   | Minimum<br>Average<br>Maximum |
| MVA      | Move Address                        | addr4,reg<br>addr,addr4               | 2200+RS<br>3520+RS                 |                               |
| MVB      | Move Byte                           | reg,addr4<br>addr4,reg<br>addr5,addr4 | 2200+RS<br>1760+RS<br>2860+AM1+AM2 |                               |
| MVBI     | Move Byte Immediate                 | by te, reg                            | 880                                |                               |
| MVBZ     | Move Byte and Zero                  | addr4,reg                             | 2640+RS                            |                               |
| MVD      | Move Doubleword                     | reg,addr4<br>addr4,reg<br>addr5,addr4 | 3300+RS<br>2420+RS<br>4620+AM1+AM2 |                               |
| MVDZ     | Move Doubleword and Zero            | addr4,reg                             | 3740+RS                            |                               |
| MVFD     | Move Byte Field and<br>Decrement    | (reg),(reg)                           | 1540+(2200 x CT)                   |                               |
| MVFN     | Move Byte Field and<br>Increment    | (reg),(reg)                           | 1540+(2200 x CT)                   |                               |
| MVW      | Move Word                           | reg,reg                               | 1100                               |                               |
|          |                                     | reg,addr4<br>addr4,reg                | 2200+RS<br>1540+RS                 |                               |
|          |                                     | addr5,addr4                           | 2860+(AM1+X)+AM2                   |                               |
|          |                                     |                                       | $R = 0 \qquad R \neq 0$            |                               |
|          |                                     | reg,longaddr                          | 2640 2640                          |                               |
|          |                                     | reg,longaddr*                         | 3080 3300                          |                               |
|          |                                     | longaddr,reg                          | 2420 2420                          |                               |
|          |                                     | longaddr*,reg                         | 2860 3080                          |                               |

Table 1 (Part 6 of 10)

|          |                          |                                        | Execution time                  |     |
|----------|--------------------------|----------------------------------------|---------------------------------|-----|
| Mnemonic | Instruction name         | Syntax                                 | (nanoseconds)                   |     |
| MVWI     | Move Word Immediate      | word,reg<br>word,addr4                 | 2200<br>3520+RS                 |     |
| MVWS     | Move Word Short          | reg,shortaddr                          | 2640                            |     |
|          |                          | reg,shortaddr*                         | 3520                            |     |
|          |                          | shortaddr, reg                         | 2420                            |     |
|          |                          | shortaddr*,reg                         | 3080                            |     |
| MVWZ     | Move Word and Zero       | addr4,reg                              | 2420+RS                         |     |
| MW       | Multiply Word            | addr4,reg                              | 9460+RS Minin                   |     |
|          |                          |                                        | 16060+RS Aver:<br>22440+RS Maxi | -   |
| NOP      | No Operation             |                                        | 880                             | mum |
| NWI      | And Word Immediate       | word,reg[,reg]                         | 1980                            |     |
| OB       | OR Byte                  | reg,addr4                              | 2420+RS                         |     |
| OB       | OK by a                  | addr4,reg                              | 1540+RS                         |     |
|          |                          | addr5,addr4                            | 3080+AM1+AM2                    |     |
| OD       | OR Doubleword            | reg,addr4                              | 4180+RS                         |     |
|          |                          | addr4, reg                             | 3300+RS                         |     |
|          |                          | addr5,addr4                            | 5500+AM1+AM2                    |     |
| OW       | OR Word                  | reg,reg                                | 1100                            |     |
|          |                          | reg,addr4<br>addr4,reg                 | 2420+RS<br>1540+RS              |     |
|          |                          | addr5,addr4                            | 3080+(AM1+X)+AM2                |     |
|          |                          | ······································ | $R = 0 \qquad R \neq 0$         |     |
|          |                          | longaddr,reg                           | 2420 2420                       |     |
|          |                          | longaddr*,reg                          | 2860 3080                       |     |
| OWI      | OR Word Immediate        | word,reg[,reg]                         | 1980                            |     |
|          |                          | word,addr4                             | 3520+RS                         |     |
| PB       | Pop Byte                 | addr4,reg                              | 5720+RS                         |     |
| PD       | Pop Doubleword           | addr4,reg                              | 5940+RS                         |     |
| PSB      | Push Byte                | reg,addr4                              | 5500+RS                         |     |
| PSD      | Push Doubleword          | reg,addr4                              | 5940+RS                         |     |
| PSW      | Push Word                | reg,addr4                              | 5060+RS                         |     |
| PW       | Pop Word                 | addr4,reg                              | 5280+RS                         |     |
| RBTB     | Reset Bits Byte          | reg,addr4                              | 2420+RS                         |     |
|          |                          | addr4,reg                              | 1540+RS                         |     |
| DDTD     | Deset Dite Devilier at   | addr5,addr4                            | 3080+AM1+AM2                    |     |
| RBTD     | Reset Bits Doubleword    | reg,addr4<br>addr4,reg                 | 4180+RS<br>3300+RS              |     |
|          |                          | addr5,addr4                            | 5500+AM1+AM2                    |     |
| RBTW     | Reset Bits Word          | reg,reg                                | 1100                            |     |
|          |                          | reg,addr4                              | 2420+RS                         |     |
|          |                          | addr4,reg                              | 1540+RS                         |     |
|          |                          | addr5,addr4                            | 3080+(AM1+X)+AM2                |     |
|          |                          |                                        | $R = 0 \qquad R \neq 0$         |     |
|          |                          | longaddr,reg<br>longaddr*,reg          | 2420 2420                       |     |
| DRTWI    | Reset Bits Word          |                                        | 2860 3080                       |     |
| RBTWI    | Immediate                | word,reg[,reg]<br>word,addr4           | 1980<br>3520+RS                 |     |
| SB       | Subtract Byte            | reg,addr4                              | 2420+RS                         |     |
|          |                          | addr4,reg                              | 1540+RS                         |     |
| SCY      | Subtract Carry Indicator | reg                                    | 1540                            |     |
| SD       | Subtract Doubleword      | reg,addr4                              | 4180+RS                         |     |
|          |                          | addr4, reg                             | 3300+RS                         |     |
|          |                          | addr5,addr4                            | 5720+(AM1+Y)+AM2                |     |
|          |                          |                                        |                                 |     |

Table 1 (Part 7 of 10)

U

ور ندر

|          |                                                          |                          | Execution time                                                                                                                                   |                          |
|----------|----------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| Mnemonic | Instruction name                                         | Syntax                   | (nanoseconds)                                                                                                                                    |                          |
| SEAKR    | Set Address Key                                          | addr4                    | 2420+RS                                                                                                                                          |                          |
|          | Register                                                 | reg                      | 2200                                                                                                                                             |                          |
| SECON    | Set Console Data Lights                                  | reg                      | 1540                                                                                                                                             |                          |
| SEFLB    | Set Floating Level Block                                 | reg,addr4                | 14740+RS                                                                                                                                         |                          |
| SEIMR    | Set Interrupt Mask<br>Register                           | addr4                    | 2420+RS                                                                                                                                          |                          |
| SEIND    | Set Indicators                                           | reg                      | 2420                                                                                                                                             |                          |
| SEISK    | Set instruction<br>Space Key                             | addr4<br>reg             | 2420+RS<br>2200                                                                                                                                  |                          |
| SELB     | Set Level Block                                          | reg,addr4                | 11220 IP off and SL <<br>12320 IP off and SL=C<br>10780 IP off and SL ><br>11220 IP on and SL <<br>11440 IP on and SL=C<br>12100 IP on and SL >C | EL<br>CL<br>CL<br>L      |
|          | Note. IP = in process flag; SI                           | L = selected level; CL = | = current level                                                                                                                                  |                          |
| SEOOK    | Set Operand 1 Key                                        | addr4<br>reg             | 2420+RS<br>2200                                                                                                                                  |                          |
| SEOTK    | Set Operand 2 Key                                        | addr4<br>reg             | 2420+RS<br>2200                                                                                                                                  |                          |
| SESK     | Set Storage Key                                          | reg,addr4                | 3960+RS                                                                                                                                          |                          |
| SESR     | Set Segmentation<br>Register                             | reg,addr4                | 2860+RS                                                                                                                                          |                          |
| SFED     | Scan Byte Field Equal<br>and Decrement                   | reg,(reg)                | 1540+(2680 x CT)                                                                                                                                 | See SFNEN note           |
| SFEN     | Scan Byte Field Equal<br>and Increment                   | reg,(reg)                | 1540+(2680 x CT)                                                                                                                                 | See SFNEN note           |
| SFNED    | Scan Byte Field Not<br>Equal and Decrement               | reg,(reg)                | 1540+(2680 x CT)                                                                                                                                 | See SFNEN note           |
| SFNEN    | Scan Byte Field Not<br>Equal and Increment               | reg,(reg)                | 1540+(2680 x CT)                                                                                                                                 | See note                 |
|          | Note. For SFED, SFEN, SFI instruction is terminated by a |                          |                                                                                                                                                  |                          |
| SLC      | Shift Left Circular                                      | cnt16,reg                | 1980                                                                                                                                             | Zero count               |
|          |                                                          |                          | 1980+110 x (CT+1)                                                                                                                                | Odd count                |
|          |                                                          | TOO TOO                  | 1980+110 x (CT)<br>1760                                                                                                                          | Even count<br>Zero count |
|          |                                                          | reg,reg                  | 1760+110 x (CT+1)                                                                                                                                | Odd count                |
|          |                                                          |                          | 1760+110 x (CT)                                                                                                                                  | Even count               |
| SLCD     | Shift Left Circular                                      | cnt31,reg                | 2640                                                                                                                                             | Zero count               |
|          | Double                                                   |                          | 2640+110 x (CT+1)                                                                                                                                | Odd count                |
|          |                                                          | <b>100 100</b>           | 2640+110 x (CT)<br>2200                                                                                                                          | Even count               |
|          |                                                          | reg,reg                  | 2200<br>2200+110 x (CT+1)                                                                                                                        | Zero count<br>Odd count  |
|          |                                                          |                          | 2200+110 x (CT)                                                                                                                                  | Even count               |
| SLL      | Shift Left Logical                                       | cnt16,reg                | 2200                                                                                                                                             | Zero count               |
|          |                                                          |                          | 2200+110 x (CT+1)                                                                                                                                | Odd count                |
|          |                                                          |                          | 2200+110 x (CT)<br>1980                                                                                                                          | Even count               |
|          |                                                          | reg,reg                  | 1980<br>1980+110 x (CT+1)                                                                                                                        | Zero count<br>Odd count  |
|          |                                                          |                          | 1980+110 x (CT)                                                                                                                                  | Even count               |
| SLLD     | Shift Left Logical                                       | cnt31,reg                | 2860                                                                                                                                             | Zero count               |
|          | Double                                                   | -                        | 2860+110 x (CT+1)                                                                                                                                | Odd count                |
|          |                                                          |                          | 2860+110 x (CT)                                                                                                                                  | Even count               |
|          |                                                          | reg,reg                  | 2420<br>$2420\pm110 \times (CT\pm1)$                                                                                                             | Zero count               |
|          |                                                          |                          | 2420+110 x (CT+1)<br>2420+110 x (CT)                                                                                                             | Odd count<br>Even count  |
|          |                                                          |                          | (01)                                                                                                                                             |                          |

Table 1 (Part 8 of 10)

|              |                                         |                                                                              | Execution time                                                  |                                                             |
|--------------|-----------------------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------|
| Mnemonic     | Instruction name                        | Syntax                                                                       | (nanoseconds)                                                   |                                                             |
| SLT          | Shift Left and Test                     | reg,reg                                                                      | 2860+660 x CT<br>3960+660 x K<br>2640                           | See SLTD note (1)<br>See SLTD note (2)<br>See SLTD note (3) |
| SLTD         | Shift Left and Test<br>Double           | reg,reg                                                                      | 3080+660 x CT<br>4180+660 x K<br>2860                           | See note (1)<br>See note (2)<br>See note (3)                |
|              | Notes.                                  |                                                                              |                                                                 |                                                             |
|              | the carry indicator                     |                                                                              |                                                                 |                                                             |
|              |                                         | into the carry indicator befor<br>. K = bit number of leftmost<br>1 is zero. |                                                                 |                                                             |
| SRA          | Shift Right Arithmetic                  | cnt16,reg                                                                    | 1980<br>1980+110 x (CT+1)<br>1980+110 x (CT)                    | Zero count<br>Odd count                                     |
|              |                                         | reg,reg                                                                      | 1980+110 x (CT)<br>1760<br>1760+110 x (CT+1)<br>1760+110 x (CT) | Even count<br>Zero count<br>Odd count<br>Even count         |
| SRAD         | Shift Right Arithmetic<br>Double        | cnt31,reg                                                                    | 2640<br>2640+110 x (CT+1)<br>2640+110 x (CT)                    | Zero count<br>Odd count<br>Even count                       |
|              |                                         | reg,reg                                                                      | 2200<br>2200+110 x (CT+1)<br>2200+110 x (CT)                    | Zero count<br>Odd count<br>Even count                       |
| SRL          | Shift Right Logical                     | cnt16,reg                                                                    | 1980<br>1980+110 x (CT+1)<br>1980+110 x (CT)                    | Zero count<br>Odd count<br>Even count                       |
|              |                                         | reg,reg                                                                      | 1760<br>1760+110 x (CT+1)<br>1760+110 x (CT)                    | Zero count<br>Odd count<br>Even count                       |
| SRLD         | Shift Right Logical<br>Double           | cnt31,reg                                                                    | 2640<br>2640+110 x (CT+1)<br>2640+110 x (CT)                    | Zero count<br>Odd count<br>Even count                       |
|              |                                         | reg,reg                                                                      | 2200<br>2200+110 x (CT+1)<br>2200+110 x (CT)                    | Zero count<br>Odd count<br>Even count                       |
| STM          | Store Multiple                          | reg,addr4[,abcnt]                                                            | 9900+RS RL=7<br>10780+(880xRL)+RS F                             | RL≠7                                                        |
| STOP         | Stop                                    | [ubyte]                                                                      | 1540                                                            |                                                             |
| SVC          | Supervisor Call                         | ubyte                                                                        | 14300                                                           |                                                             |
| SW           | Subtract Word                           | reg,reg<br>reg,addr4<br>addr4,reg<br>addr5,addr4                             | 1100<br>2420+RS<br>1540+RS<br>3080+(AM1+Y)+AM2                  |                                                             |
|              |                                         |                                                                              | $R = 0 \qquad R \neq 0$                                         |                                                             |
|              |                                         | longaddr,reg<br>longaddr*,reg                                                | 2420242028603080                                                |                                                             |
| SWCY         | Subtract Word With Carry                |                                                                              | 1540                                                            |                                                             |
| SWI          | Subtract Word Immediate                 | word,reg[,reg]                                                               | 3520+RS<br>1980                                                 |                                                             |
| TBT          | Test Bit                                | (reg, bit disp)                                                              | 4400+A                                                          | See TBTV note                                               |
| TBTR         | Test Bit and Reset                      | (reg, bitdisp)                                                               | 5060+A                                                          | See TBTV note                                               |
| TBTS<br>TBTV | Test Bit and Set<br>Test Bit and Invert | (reg,bitdisp)<br>(reg,bitdisp)                                               | 5060+A<br>5060+A                                                | See TBTV note<br>See note                                   |

<u>\_</u>

Table 1 (Part 9 of 10)

| Mnemonic | Instruction name<br>Note. For TBT, TBTR, TBTS, a<br>A = 0 if BT is zero.<br>$A = 110 \times BT$ if BT is even.<br>$A = 110 \times (BT+1)$ if BT is odd. |                                                 | Execution time<br>(nanoseconds)                  |                                                                            |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------|
| TWI      | BT = bit number of tested bit (r<br>Test Word Immediate                                                                                                 | ange 0-7).<br>word,reg<br>word,addr4            | 2420<br>2640<br>3080+RS<br>3300+RS               | All bits = $0$<br>All bits $\neq 0$<br>All bits = $0$<br>Any bits $\neq 0$ |
| VR<br>XB | Invert Register<br>Exclusive OR Byte                                                                                                                    | reg[,reg]<br>reg,addr4<br>addr4,reg             | 1320<br>2420+RS<br>1540+RS                       |                                                                            |
| XD       | Exclusive OR Doubleword                                                                                                                                 | reg,addr4<br>addr4,reg                          | 4180+RS<br>3300+RS                               |                                                                            |
| XW       | Exclusive OR Word                                                                                                                                       | reg,reg<br>reg,addr4<br>addr4,reg               | 1100<br>2420+RS<br>1540+RS<br>$R = 0$ $R \neq 0$ |                                                                            |
| XWI      | Exclusive OR Word<br>Immediate                                                                                                                          | longaddr,reg<br>longaddr*,reg<br>word,reg[,reg] | 2420 2420<br>2860 3080<br>1980                   |                                                                            |

Table 1 (Part 10 of 10)

ſ

## Table 2. Instruction Times – Relocation Translator Enabled

|          |                                                   |                        | Execution time            |
|----------|---------------------------------------------------|------------------------|---------------------------|
| Mnemonic | Instruction name                                  | Syntax                 | (nanoseconds)             |
| AB       | Add Byte                                          | reg,addr4              | 2860+RS                   |
|          |                                                   | addr4,reg              | 1760+RS                   |
| ABI      | Add Byte Immediate                                | byte,reg               | 1320                      |
| ACY      | Add Carry Register                                | reg                    | 1760                      |
| AD       | Add Double Word                                   | reg,addr4              | 5060+RS                   |
|          |                                                   | addr4, reg             | 3740+RS                   |
|          |                                                   | addr5,addr4            | 6820+(AM1+Y)+AM2          |
| AW       | Add Word                                          | reg,reg                | 1320                      |
|          |                                                   | reg,addr4<br>addr4,reg | 2860+RS<br>1760+RS        |
|          |                                                   | addr5,addr4            | 3520+(AM1+Y)+AM2          |
|          |                                                   |                        | $R = 0 \qquad R \neq 0$   |
|          |                                                   | longaddr,reg           | 3080 3080                 |
|          |                                                   | longaddr*,reg          | 3740 3960                 |
| AWCY     | Add Word With Carry                               | reg,reg                | 1760                      |
| AWI      | Add Word Immediate                                | word,reg[,reg]         | 2420                      |
|          |                                                   | word,addr4             | 4400+RS                   |
| В        | Branch Unconditional                              | longaddr               | 2200                      |
|          |                                                   | longaddr*              | 3080                      |
| BAL      | Branch and Link                                   | longaddr,reg           | 2420                      |
|          |                                                   | longaddr*,reg          | 3300                      |
| BALS     | Branch and Link Short                             | (reg,jdisp)*           | 2640                      |
|          |                                                   | (reg)*<br>addr*        | 2640<br>2640              |
| BALX     | Branch and Link External                          | auui                   | See BAL                   |
| DADA     | Dianon and Link External                          |                        | Branch                    |
|          |                                                   |                        | Branch<br>Not taken Taken |
| BC       | Branch on Condition                               | cond,longaddr          | 1980 2200                 |
|          |                                                   | cond,longaddr*         | 1980 3080                 |
|          |                                                   |                        | Branch                    |
|          |                                                   |                        | Not taken Taken           |
| BCC      | Branch on Condition Code                          | cond,longaddr          | 1980 2200                 |
|          |                                                   | cond,longaddr*         | 1980 3080                 |
| BCY      | Branch on Carry                                   |                        | See BC                    |
| BE       | Branch on Equal                                   |                        | See BC                    |
| BER      | Branch on Error                                   |                        | See BNCC                  |
| BEV      | Branch on Even                                    |                        | See BC                    |
| BGE      | Branch on Arithmetically<br>Greater Than or Equal |                        | See BNC                   |
| BGT      | Branch on Arithmetically<br>Greater Than          |                        | See BNC                   |
| BLE      | Branch on Arithmetically                          |                        | See BC                    |
| DEE      | Less Than or Equal                                |                        | bee be                    |
| BLGE     | Branch on Logically                               |                        | See BNC                   |
|          | Greater Than or Equal                             |                        |                           |
| BLGT     | Branch on Logically                               |                        | See BNC                   |
|          | Greater Than                                      |                        |                           |
| BLLE     | Branch on Logically                               |                        | See BC                    |
| DI 1 5   | Less Than or Equal                                |                        |                           |
| BLLT     | Branch on Logically<br>Less Than                  |                        | See BC                    |
|          | Lood High                                         |                        |                           |

Table 2 (Part 1 of 10)

A-14 GA34-0021

U

| Mnemonic<br>BLT | Instruction name<br>Branch on Arithmetically  | Syntax                                               | (nanoseconds)<br>See BC   |              |
|-----------------|-----------------------------------------------|------------------------------------------------------|---------------------------|--------------|
| DMIN            | Less Than<br>Branch if Mixed                  |                                                      | See BC                    |              |
| BMIX<br>BN      | Branch on Negative                            |                                                      | See BC                    |              |
| DIN             | Dialicit on Regative                          |                                                      | Branch                    |              |
|                 |                                               |                                                      | Branch<br>Not taken Taken |              |
| BNC             | Branch on Not Condition                       | cond,longaddr                                        | 1980 2200                 |              |
|                 |                                               | cond,longaddr*                                       | 1980 3080                 |              |
|                 |                                               |                                                      | Branch                    |              |
|                 |                                               |                                                      | Not taken Taken           |              |
| BNCC            | Branch on Not Condition                       | cond,longaddr                                        | 1980 2200                 |              |
|                 | Code                                          | cond,longaddr*                                       | 1980 <b>3080</b>          |              |
| BNCY            | Branch on No Carry                            |                                                      | See BNC                   |              |
| BNE             | Branch on Not Equal                           |                                                      | See BNC                   |              |
| BNER            | Branch if Not Error                           |                                                      | See BCC                   |              |
| BNEV            | Branch on Not Even                            |                                                      | See BNC                   |              |
| BNMIX           | Branch if Not Mixed                           |                                                      | See BNC                   |              |
| BNN             | Branch on Not Negative                        |                                                      | See BNC                   |              |
| BNOFF           | Branch if Not Off<br>Branch if Not On         |                                                      | See BNC<br>See BNC        | ,            |
| BNON            | Branch II Not On                              |                                                      |                           |              |
|                 |                                               |                                                      | Branch<br>Not taken Taken |              |
| BNOV            | Branch on Not Overflow                        | longaddr                                             | 1980 2200                 |              |
| DIVOV           | blanch on Not Overnow                         | longaddr*                                            | 1980 3080                 |              |
| BNP             | Branch on Not Positive                        | C C                                                  | See BNC                   |              |
| BNZ             | Branch on Not Zero                            |                                                      | See BNC                   |              |
| BOFF            | Branch if Off                                 |                                                      | See BC                    |              |
| BON             | Branch if ON                                  |                                                      | See BC                    |              |
|                 |                                               |                                                      | Branch                    |              |
|                 |                                               |                                                      | Not taken Taken           |              |
| BOV             | Branch on Overflow                            | longaddr                                             | 1980 2200                 |              |
|                 |                                               | longaddr*                                            | 1980 3080                 |              |
| BP              | Branch on Positive                            |                                                      | See BC                    |              |
| BX              | Branch External                               | vcon                                                 | See B                     |              |
| BXS             | Branch Indexed Short                          | (reg <sup>1-7</sup> ,jdisp)<br>(reg <sup>1-7</sup> ) | 1540                      |              |
|                 |                                               | (reg )<br>addr                                       | 1540<br>1540              |              |
| BZ              | Branch on Zero                                | addi                                                 | See BC                    |              |
| CB              | Compare Byte                                  | addr4,reg                                            | 1760+RS                   |              |
|                 |                                               | addr5,addr4                                          | 2420+AM1+AM2              |              |
| CBI             | Compare Byte Immediate                        | byte,reg                                             | 1320                      |              |
| CD              | Compare Double Word                           | addr4,reg                                            | 3520+RS                   |              |
|                 |                                               | addr5,addr4                                          | 5280+AM1+AM2              |              |
| CFED            | Compare Byte Field Equal and Decrement        | (reg),(reg)                                          | 1760+(3520 x CT)          | See CFNEN no |
| CFEN            | Compare Byte Field Equal and Increment        | (reg),(reg)                                          | 1760+(3520 x CT)          | See CFNEN no |
| CFNED           | Compare Byte Field Not<br>Equal and Decrement | (reg),(reg)                                          | 1760+(3520 x CT)          | See CFNEN no |
| CFNEN           | Compare Byte Field Not<br>Equal and Increment | (reg),(reg)                                          | 1760+(3520 x CT)          | See note     |

is terminated by a comparison condition.



|          |                                                    |                        | Execution time                   |                            |
|----------|----------------------------------------------------|------------------------|----------------------------------|----------------------------|
| Mnemonic | Instruction name                                   | Syntax                 | (nanoseconds)                    |                            |
| CMR      | Complement Register                                | reg[,reg]              | 1540                             |                            |
| CPAKR    | Copy Address Key Register                          | addr4<br>reg           | 3300+RS<br>1980                  |                            |
| CPCL     | Copy Current Level                                 | reg                    | 1760                             |                            |
| CPCON    | Copy Console Data Buffer                           | reg                    | 1760                             |                            |
| CPFLB    | Copy Floating Level Block                          | reg,addr4              | 21780+RS                         |                            |
| CPIMR    | Copy Interrupt Mask<br>Register                    | addr4                  | 2860+RS                          |                            |
| CPIPF    | Copy In-process Flags                              | addr4                  | 2860+RS                          |                            |
| CPISK    | Copy Instruction Space Key                         | addr4                  | 3300+RS                          |                            |
|          |                                                    | reg                    | 1980                             |                            |
| CPLB     | Copy Level Block                                   | reg,addr4              | 15620+RS SL=CL<br>14960+RS SL≠CL |                            |
| CPLSR    | Copy Level Status Register                         | reg                    | 1320                             |                            |
| CPOOK    | Copy Operand 1 Key                                 | addr4                  | 3300+RS                          |                            |
|          | ,                                                  | reg                    | 1980                             |                            |
| CPOTK    | Copy Operand 2 Key                                 | addr4                  | 3300+RS                          |                            |
|          |                                                    | reg                    | 1980                             |                            |
| CPPSR    | Copy Processor Status<br>and Reset                 | addr4                  | 2860+RS                          |                            |
| CPSK     | Copy Storage Key                                   | reg,addr4              | 4180+RS                          |                            |
| CPSR     | Copy Segmentation<br>Register                      | reg,addr4              | 3960+RS                          |                            |
| CW       | Compare Word                                       | reg,reg                | 1320                             |                            |
|          |                                                    | addr4, reg             | 1760+RS                          |                            |
|          |                                                    | addr5,addr4            | 2420+(AM1+X)+AM2                 |                            |
| CWI      | Compare Word Immediate                             | word,reg<br>word,addr4 | 2420<br>3520+RS                  |                            |
| DB       | Divide Byte                                        | addr4,reg              | 24440+RS                         | Minimum                    |
|          |                                                    |                        | 28600+RS                         | Average                    |
|          |                                                    |                        | 33000+RS                         | Maximum                    |
|          |                                                    |                        | 3740+RS<br>5720+RS               | Divide by zero<br>Overflow |
| DD       | Divide Double Word                                 | addr4,reg              | 42020+RS                         | Minimum                    |
| DD       | Divide Double word                                 | auu14,10g              | 42020+RS<br>50160+RS             | Average                    |
|          |                                                    |                        | 59180+RS                         | Maximum                    |
|          |                                                    |                        | 2640+RS                          | Divide by zero             |
|          |                                                    |                        | 5280+RS                          | Overflow                   |
| DIAG     | Diagnose                                           | ubyte                  | See chart                        |                            |
|          |                                                    |                        | Time                             |                            |
|          | If instruction bit 13 is on:                       |                        | 1980                             |                            |
|          | If instruction bit 13 is off, check                | k other                |                                  |                            |
|          | bits as follows:                                   |                        |                                  |                            |
|          |                                                    | 5                      |                                  |                            |
|          | 0 X 0 0 0                                          |                        | 5280                             |                            |
|          |                                                    |                        | 550Q                             |                            |
|          | 0 X 0 1 0<br>0 X 0 1 1                             |                        | 3740<br>5060                     |                            |
|          | 0 X 1 0 0                                          |                        | 3740                             |                            |
|          | 0 X 1 0 1                                          |                        | 4840                             |                            |
|          | 0 X 1 1 0                                          |                        | 3520                             |                            |
|          | 0 X 1 1 1                                          |                        | 4620                             |                            |
|          |                                                    |                        | 3960                             |                            |
|          |                                                    |                        | 4400                             |                            |
|          | 1  1  X  X  X <i>Note.</i> X can be either 0 or 1. | 2                      | 2420                             |                            |
|          |                                                    |                        |                                  |                            |

Table 2 (Part 3 of 10)

| Mnemonic | Instruction              | n name                |        |            | Syntax            | Execution time<br>(nanoseconds)                        |                                                             |
|----------|--------------------------|-----------------------|--------|------------|-------------------|--------------------------------------------------------|-------------------------------------------------------------|
| DIS      | Disable                  |                       |        |            | ubyte             | 1760+D                                                 | See EN note                                                 |
| DW       | Divide Wo                | Divide Word addr4,reg |        |            | addr4,reg         | 22440+RS<br>26620+RS<br>32120+RS<br>2640+RS<br>4620+RS | Minimum<br>Average<br>Maximum<br>Divide by zero<br>Overflow |
| EN       | Enable                   |                       |        |            | ubyte             | 1760+E                                                 | See note                                                    |
|          | Note. For                | the DIS a             | nd EN  | instruc    | tions, the values | of D and                                               |                                                             |
|          | E are base               | d on instru           | ction- | word bi    | ts 12–15.         |                                                        |                                                             |
|          | 12                       | 13 14                 | 15     | D          | E                 |                                                        |                                                             |
|          | -                        | 0 0                   | 0      | 0          | 0                 |                                                        |                                                             |
|          |                          | 0 0<br>0 1            | 1<br>0 | 220<br>220 | 0<br>220          |                                                        |                                                             |
|          |                          | 0 1                   | 1      | 440        | 220               |                                                        |                                                             |
|          |                          | 1 0                   | 0      | 440        | 220               |                                                        |                                                             |
|          |                          | 1 0                   | 1      | 660        | 220               |                                                        |                                                             |
|          |                          | 1 1 1                 | 0<br>1 | 660<br>880 | 440<br>440        |                                                        |                                                             |
|          |                          | 0 0                   | 0      | 220        | 0                 |                                                        |                                                             |
|          |                          | 0 0                   | 1      | 440        | 0                 |                                                        |                                                             |
|          |                          | 0 1                   | 0      | 440        | 0                 |                                                        |                                                             |
|          |                          | 0 1<br>1 0            | 1<br>0 | 660<br>660 | 0<br>220          |                                                        |                                                             |
|          |                          | 1 0                   | 1      | 880        | 220               |                                                        |                                                             |
|          | 1                        | 1 1                   | 0      | 880        | 220               |                                                        |                                                             |
|          |                          | 1 1                   | 1      | 1100       | 220               |                                                        |                                                             |
| FA       | Floating A               | Add                   |        |            | addr4,freg        | 10780+RS                                               | Minimum                                                     |
|          |                          |                       |        |            | freg,freg         | 26400+RS<br>8580                                       | Maximum<br>Minimum                                          |
|          |                          |                       |        |            | 1105,1105         | 24200                                                  | Maximum                                                     |
| FAD      | Floating A               | dd Doubl              | e      |            | addr4,freg        | 12540+RS                                               | Minimum                                                     |
|          |                          |                       |        |            | <b>c c</b>        | 50160+RS                                               | Maximum                                                     |
|          |                          |                       |        |            | freg,freg         | 8800<br>47300                                          | Minimum<br>Maximum                                          |
| FC       | Floating C               | Compare               |        |            | freg,freg         | 7920                                                   | Minimum                                                     |
|          |                          |                       |        |            |                   | 22880                                                  | Maximum                                                     |
| FCD      | Floating C               | Compare D             | ouble  |            | freg,freg         | 8140                                                   | Minimum                                                     |
|          |                          |                       |        |            |                   | 42900                                                  | Maximum                                                     |
| FD       | Floating D               | Divide                |        | ;          | addr4,freg        | 28820+RS<br>35200+RS                                   | Minimum<br>Maximum                                          |
|          |                          |                       |        |            | freg,freg         | 26180                                                  | Maximum<br>Minimum                                          |
|          |                          |                       |        |            |                   | 31460                                                  | Maximum                                                     |
| FDD      | Floating D               | vivide Dou            | ble    | ;          | addr4,freg        | 54180+RS                                               | Minimum                                                     |
|          |                          |                       |        |            | 6                 | 67760+RS                                               | Maximum                                                     |
|          |                          |                       |        |            | freg,freg         | 50380<br>62480                                         | Minimum<br>Maximum                                          |
| FFD      | Fill Byte F              | Field and             |        |            | reg,(reg)         | 1760+(2200 x CT)                                       |                                                             |
|          | Decrement                |                       |        |            | 01(8)             | (==00 A OI)                                            |                                                             |
| FFN      | Fill Byte F<br>Increment |                       |        | :          | reg,(reg)         | 1760+(2200 x CT)                                       |                                                             |
| FM       | Floating M               | fultiply              |        | ;          | addr4,freg        | 20020+RS                                               | Minimum                                                     |
|          |                          |                       |        |            |                   | 22880+RS                                               | Maximum                                                     |
|          |                          |                       |        |            | freg,freg         | 16720                                                  | Minimum<br>Maximum                                          |
| FMD      | Floating M               | fultiply D            | whia   |            | addrd free        | 19360<br>24860+RS                                      | Minimum                                                     |
|          | r toatilig M             | iunipiy D             | JUDIC  | :          | addr4,freg        | 24860+RS<br>31240+RS                                   | Minimum<br>Maximum                                          |
|          |                          |                       |        |            | freg,freg         | 20460                                                  | Minimum                                                     |
|          |                          |                       |        |            |                   | 26460                                                  | Maximum                                                     |



ſ

|          |                                                 |                          | Execution t          | ime          |                    |
|----------|-------------------------------------------------|--------------------------|----------------------|--------------|--------------------|
| Mnemonic | Instruction name                                | Syntax                   | (nanosecond          |              |                    |
| FMV      | Floating Move                                   | addr4,freg               | 7040+RS              |              |                    |
|          | -                                               | freg,freg                | 4620                 |              |                    |
|          |                                                 | freg,addr4               | 7040+RS              |              |                    |
| FMVC     | Floating Move and Convert                       | addr4,freg               | 12540+RS<br>17380+RS |              | Minimum<br>Maximum |
|          |                                                 | freg,addr4               | 8800+RS<br>17820+RS  |              | Minimum<br>Maximum |
| FMVCD    | Floating Move and<br>Convert Double             | addr4,freg               | 12760+RS<br>28820+RS |              | Minimum<br>Maximum |
|          |                                                 | freg,addr4               | 11880+RS<br>31460+RS |              | Minimum<br>Maximum |
| FMVD     | Floating Move Double                            | addr4,freg               | 8580+RS              |              |                    |
|          | e e e                                           | freg,freg                | 5720                 |              |                    |
|          |                                                 | freg,addr4               | 9460+RS              |              |                    |
| FS       | Floating Subtract                               | addr4,freg               | 10780+RS<br>26400+RS |              | Minimum<br>Maximum |
|          |                                                 | freg,freg                | 8580<br>24200        |              | Minimum<br>Maximum |
| FSD      | Floating Subtract Double                        | addr4,freg               | 12540+RS<br>50160+RS |              | Minimum<br>Maximum |
|          |                                                 | freg,freg                | 8800<br>47300        |              | Minimum<br>Maximum |
|          |                                                 |                          | R = 0                | R ≠ 0        |                    |
| Ю        | Operate I/O                                     | longaddr                 | 5280                 | 5280         | See note           |
| 10       | Operate 1/O                                     | longaddr*                | 5940                 | 6160         | See note           |
|          | Note. Channel and device times                  | must be added (typicall  | y 1760).             |              |                    |
| IOPK     | Interchange Operand Keys                        |                          | 1980                 |              |                    |
| IR       | Interchange Registers                           | reg,reg                  | 1540                 |              |                    |
| J        | Jump Unconditional                              | jdisp                    | 1100                 |              |                    |
|          |                                                 | jaddr                    | 1100                 |              |                    |
| JAL      | Jump and Link                                   | jdisp,reg<br>jaddr,reg   | 1540<br>1540         |              |                    |
|          |                                                 |                          | Jump<br>Not taken    | Taken        |                    |
| JC       | Jump on Condition                               | cond,jdisp<br>cond,jaddr | 1320<br>1320         | 1540<br>1540 |                    |
|          |                                                 | Contagatati              | CT = 0               | CT = 1       | CT > 1             |
| ICT      | Inma on Count                                   | idian aca                |                      |              | 2200               |
| JCT      | Jump on Count                                   | jdisp,reg<br>jaddr,reg   | 1760<br>1760         | 1980<br>1980 | 2200<br>2200       |
| JCY      | Jump on Carry                                   |                          | See JC               |              |                    |
| JE       | Jump on Equal                                   |                          | See JC               |              |                    |
| JEV      | Jump on Even                                    |                          | See JC               |              |                    |
| JGE      | Jump on Arithmetically<br>Greater Than or Equal |                          | See JNC              |              |                    |
| JGT      | Jump on Arithmetically<br>Greater Than          |                          | See JNC              |              |                    |
| JLE      | Jump on Arithmetically<br>Less Than or Equal    |                          | See JC               |              |                    |
| JLGE     | Jump on Logically Greater<br>Than or Equal      |                          | See JNC              |              |                    |
| JLGT     | Jump on Logically Greater<br>Than               |                          | See JNC              |              |                    |
| JLLE     | Jump on Logically Less<br>Than or Equal         |                          | See JC               |              |                    |
|          |                                                 |                          |                      |              |                    |

Table 2 (Part 5 of 10)

A-18 GA34-0021

| Mnemonic | Instruction name                    | Syntax                                | Execution time<br>(nanoseconds)    |                               |
|----------|-------------------------------------|---------------------------------------|------------------------------------|-------------------------------|
| JLLT     | Jump on Logically<br>Less Than      | •                                     | See JC                             |                               |
| JLT      | Jump on Arithmetically<br>Less Than |                                       | See JC                             |                               |
| JMIX     | Jump if Mixed                       |                                       | See JC                             |                               |
| JN       | Jump on Negative                    |                                       | See JC                             |                               |
|          |                                     |                                       | Jump<br>Not taken Taken            |                               |
| JNC      | Jump on Not Condition               | cond,jdisp<br>cond,jaddr              | 1320 1540<br>1320 1540             |                               |
| JNCY     | Jump on No Carry                    |                                       | See JNC                            |                               |
| JNE      | Jump on Not Equal                   |                                       | See JNC                            |                               |
| JNEV     | Jump on Not Even                    |                                       | See JNC                            |                               |
| JNMIX    | Jump if Not Mixed                   |                                       | See JNC                            |                               |
| JNN      | Jump on Not Negative                |                                       | See JNC                            |                               |
| JNOFF    | Jump if Not Off                     |                                       | See JNC                            |                               |
| JNON     | Jump if Not On                      |                                       | See JNC                            |                               |
| JNP      | Jump on Not Positive                |                                       | See JNC                            |                               |
| JNZ      | Jump on Not Zero                    |                                       | See JNC                            |                               |
| JOFF     | Jump if Off                         |                                       | See JC                             |                               |
| JON      | Jump if On                          |                                       | See JC                             |                               |
| JP       | Jump on Positive                    |                                       | See JC                             |                               |
| JZ       | Jump on Zero                        |                                       | See JC                             | -                             |
| LEX      | Level Exit                          | [ubyte]                               | 3080                               |                               |
| LMB      | Load Multiple and Branch            | addr4                                 | 8800+RS RL=7<br>9900+(880 x RL)+RS | RL≠7                          |
| МВ       | Multiply Byte                       | addr4,reg                             | 10560+RS<br>17160+RS<br>23540+RS   | Minimum<br>Average<br>Maximum |
| MD       | Multiply Doubleword                 | addr4,reg                             | 11000+RS<br>26620+RS<br>42020+RS   | Minimum<br>Average<br>Maximum |
| MVA      | Move Address                        | addr4,reg<br>addr,addr4               | 2200+RS<br>3960+RS                 |                               |
| MVB      | Move Byte                           | reg,addr4<br>addr4,reg<br>addr5,addr4 | 2640+RS<br>1980+RS<br>3300+AM1+AM2 |                               |
| MVBI     | Move Byte Immediate                 | byte,reg                              | 1100                               |                               |
| MVBZ     | Move Byte and Zero                  | addr4,reg                             | 3080+RS                            |                               |
| MVD      | Move Doubleword                     | reg,addr4<br>addr4,reg<br>addr5,addr4 | 3960+RS<br>2860<br>5500+AM1+AM2    |                               |
| MVDZ     | Move Doubleword and<br>Zero         | addr4,reg                             | 4620+RS                            |                               |
| MVFD     | Move Byte Field and<br>Decrement    | (reg),(reg)                           | 1760+(2640 x CT)                   |                               |
| MVFN     | Move Byte Field and<br>Increment    | (reg),(reg)                           | 1760+(2640 x CT)                   |                               |

Table 2 (Part 6 of 10)

C

|          |                       |                               | Execution time          |                    |
|----------|-----------------------|-------------------------------|-------------------------|--------------------|
| Mnemonic | Instruction name      | Syntax                        | (nanoseconds)           |                    |
| MVW      | Move Word             | reg,reg                       | 1320                    |                    |
|          |                       | reg,addr4                     | 2640+RS                 |                    |
|          |                       | addr4,reg                     | 1760+RS                 |                    |
|          |                       | addr5,addr4                   | 3300+(AM1+X)+AM2        |                    |
|          |                       |                               | $R=0 \qquad R\neq 0$    |                    |
|          |                       | reg,longaddr                  | 3300 3300               |                    |
|          |                       | reg,longaddr*                 | <b>3960 4180</b>        |                    |
|          |                       | longaddr,reg<br>longaddr*,reg | 3080 3080<br>3740 3960  |                    |
| MVWI     | Move Word Immediate   | word,reg                      | 2200                    |                    |
|          | Move word miniounte   | word,addr4                    | 3960+RS                 |                    |
| MVWS     | Move Word Short       | reg,shortaddr                 | 3080                    |                    |
|          |                       | reg,shortaddr*                | 4180                    |                    |
|          |                       | shortaddr, reg                | 2860                    |                    |
|          |                       | shortaddr*,reg                | 3740                    |                    |
| MVWZ     | Move Word and Zero    | addr4,reg                     | 2860+RS                 |                    |
| MW       | Multiply Word         | addr4,reg                     | 9680+RS                 | Minimum            |
|          |                       |                               | 16280+RS<br>22660+RS    | Average<br>Maximum |
| NOP      | No Operation          |                               | 1100                    | Maximum            |
| NWI      | And Word Immediate    | word,reg[,reg]                | 2420                    |                    |
| OB       | OR Byte               | reg,addr4                     | 2420<br>2860+RS         |                    |
| 0b       | OK Byte               | addr4,reg                     | 1760+RS                 |                    |
|          |                       | addr5,addr4                   | 3520+AM1+AM2            |                    |
| OD       | OR Doubleword         | reg,addr4                     | 5060+RS                 |                    |
|          |                       | addr4,reg                     | 3740+RS                 |                    |
|          |                       | addr5,addr4                   | 6600+AM1+AM2            |                    |
| OW       | OR Word               | reg,reg                       | 1320<br>2860+RS         |                    |
|          |                       | reg,addr4<br>addr4,reg        | 1760+RS                 |                    |
|          |                       | addr5,addr4                   | 3520+(AM1+X)+AM2        |                    |
|          |                       |                               | $R=0 \qquad R\neq 0$    |                    |
|          |                       | longaddr,reg                  | 3080 3080               |                    |
|          |                       | longaddr*,reg                 | 3740 3960               |                    |
| OWI      | OR Word Immediate     | word,reg[,reg]                | 2420                    |                    |
|          |                       | word,addr4                    | 4180+RS                 |                    |
| PB       | Pop Byte              | addr4,reg                     | 6600+RS                 |                    |
| PD       | Pop Doubleword        | addr4,reg                     | 7040+RS                 |                    |
| PSB      | Push Byte             | reg,addr4                     | 6380 <b>+RS</b>         |                    |
| PSD      | Push Doubleword       | reg,addr4                     | 7040+RS                 |                    |
| PSW      | Push Word             | reg,addr4                     | 5960+RS                 |                    |
| PW       | Pop Word              | addr4,reg                     | 6160 <b>+RS</b>         |                    |
| RBTB     | Reset Bits Byte       | reg,addr4                     | 2860+RS                 |                    |
|          |                       | addr4,reg<br>addr5,addr4      | 1760+RS<br>3520+AM1+AM2 |                    |
| RBTD     | Reset Bits Doubleword | reg,addr4                     | 5060+RS                 |                    |
| RDID     | Reset Dits Doubleword | addr4,reg                     | 3740+RS                 |                    |
|          |                       | addr5,addr4                   | 6600+AM1+AM2            |                    |
| RBTW     | Reset Bits Word       | reg,reg                       | 1320                    |                    |
|          |                       | reg,addr4                     | 2860+RS                 |                    |
|          |                       | addr4, reg                    | 1760+RS                 |                    |
|          |                       | addr5,addr4                   | 3520+(AM1+X)+AM2        |                    |
|          |                       |                               | $R = 0 \qquad R \neq 0$ |                    |
|          |                       | longaddr,reg<br>longaddr*,reg | 3080 3080<br>3740 3960  |                    |
|          |                       | iongaudi",ieg                 | 3740 3960               |                    |

Table 2 (Part 7 of 10)

A-20 GA34-0021

|               | ,                                          |                          |                                                |                          |
|---------------|--------------------------------------------|--------------------------|------------------------------------------------|--------------------------|
| Mnemonic      | Instruction name                           | Syntax                   | Execution time<br>(nanoseconds)                |                          |
| RBTWI         | Reset Bits Word                            | word, reg[, reg]         | 2420                                           |                          |
|               | Immediate                                  | word,addr4               | 4180+RS                                        |                          |
| SB            | Subtract Byte                              | reg,addr4                | 2860+RS                                        |                          |
|               |                                            | addr4,reg                | 1760+RS                                        |                          |
| SCY           | Subtract Carry Indicator                   | reg                      | 1760                                           |                          |
| SD            | Subtract Doubleword                        | reg,addr4<br>addr4,reg   | 5060+RS<br>3740+RS                             |                          |
|               |                                            | addr5,addr4              | 6820+(AM1+Y)+AM2                               |                          |
| SEAKR         | Set Address Key Register                   | addr4                    | 2640+RS                                        |                          |
|               | -                                          | reg                      | 2420                                           |                          |
| SECON         | Set Console Data Lights                    | reg                      | 1760                                           |                          |
| SEFLB         | Set Floating Level Block                   | reg,addr4                | 18480+RS                                       |                          |
| SEIMR         | Set Interrupt Mask Register                | addr4                    | 2640+RS                                        |                          |
| SEIND         | Set Indicators                             | reg                      | 2640                                           |                          |
| SEISK         | Set Instruction Space Key                  | addr4                    | 2640+RS<br>2420                                |                          |
| SELB          | Set Level Block                            | reg<br>reg,addr4         | 13640 IP off and SL $<$                        | CI                       |
| SELD          | Set Level Diock                            | ieg,auui+                | 14740 IP off and SL=C                          |                          |
|               |                                            |                          | 13200 IP off and SL $>$                        |                          |
|               |                                            |                          | 13640 IP on and SL <                           |                          |
|               |                                            |                          | 13860 IP on and SL=Cl<br>14520 IP on and SL >0 |                          |
|               | Note. IP = in process flag; SL =           | = selected level: CI = c |                                                |                          |
| SEOOK         | Set Operand 1 Key                          | addr4                    | 2640+RS                                        |                          |
| BLOOK         | Set Operand T Key                          | reg                      | 2420                                           |                          |
| SEOTK         | Set Operand 2 Key                          | addr4                    | 2640+RS                                        |                          |
|               |                                            | reg                      | 2420                                           |                          |
| SESK          | Set Storage Key                            | reg,addr4                | 4400+RS                                        |                          |
| SESR          | Set Segmentation Register                  | reg,addr4                | 3080+RS                                        | _                        |
| SFED          | Scan Byte Field Equal<br>and Decrement     | reg,(reg)                | 1760+(3080 x CT)                               | See SFNEN note           |
| SFEN          | Scan Byte Field Equal and Increment        | reg,(reg)                | 1760+(3080 x CT)                               | See SFNEN note           |
| <b>S</b> FNED | Scan Byte Field Not<br>Equal and Decrement | reg,(reg)                | 1760+(3080 x CT)                               | See SFNEN note           |
| SFNEN         | Scan Byte Field Not<br>Equal and Increment | reg,(reg)                | 1760+(3080 x CT)                               | See note                 |
|               | Note. For SFED, SFEN, SFNI                 | ED, and SFNEN, subtr     | act 880 if the                                 |                          |
|               | instruction is terminated by a c           | comparison condition.    |                                                |                          |
| SLC           | Shift Left Circular                        | cnt16,reg                | 2200                                           | Zero count               |
|               |                                            |                          | 2200+110 x (CT+1)                              | Odd count                |
|               |                                            | reg,reg                  | 2200+110 x (CT)<br>1980                        | Even count<br>Zero count |
|               |                                            | 105,205                  | 1980+110 x (CT+1)                              | Odd count                |
|               |                                            |                          | 1980+110 x (CT)                                | Even count               |
| SLCD          | Shift Left Circular                        | cnt31,reg                | 2860                                           | Zero count               |
|               | Double                                     |                          | 2860+110 x (CT+1)<br>2860+110 x (CT)           | Odd count<br>Even count  |
|               |                                            | reg,reg                  | 2420                                           | Zero count               |
|               |                                            |                          | 2420+110 x (CT+1)                              | Odd count                |
| ar -          |                                            |                          | 2420+110 x (CT)                                | Even count               |
| SLL           | Shift Left Logical                         | cnt16,reg                | 2420<br>$2420\pm110 \times (CT\pm1)$           | Zero count               |
|               |                                            |                          | 2420+110 x (CT+1)<br>2420+110 x (CT)           | Odd count<br>Even count  |
|               |                                            | reg,reg                  | 2200                                           | Zero count               |
|               |                                            |                          | 2200+110 x (CT+1)                              | Odd count                |
|               |                                            |                          | 2200+110 x (CT)                                | Even count               |

Table 2 (Part 8 of 10)

| Mnemonic | Instruction name           | Syntax    | Execution time<br>(nanoseconds)              |                                                             |
|----------|----------------------------|-----------|----------------------------------------------|-------------------------------------------------------------|
| SLLD     | Shift Left Logical Double  | cnt31,reg | 3080<br>3080+110 x (CT+1)<br>3080+110 x (CT) | Zero count<br>Odd count<br>Even count                       |
|          |                            | reg,reg   | 2640<br>2640+110 x (CT+1)<br>2640+110 x (CT) | Zero count<br>Odd count<br>Even count                       |
| SLT      | Shift Left and Test        | reg,reg   | 3080+660 x CT<br>4180+660 x K<br>2860        | See SLTD note (1)<br>See SLTD note (2)<br>See SLTD note (3) |
| SLTD     | Shift Left and Test Double | reg,reg   | 3300+660 x CT<br>4400+660 x K<br>3080        | See note (1)<br>See note (2)<br>See note (3)                |

٠

#### Notes.

(1) The shift count goes to zero before a shifted bit is set into the carry indicator.

(2) A shifted bit is set into the carry indicator before the shift count goes to zero. K = bit number of leftmost one bit.

(3) The initial operand is zero.

| SRA  | Shift Right Arithmetic     | cnt16,reg         | 2200<br>2200+110 x (CT+1) | Zero count<br>Odd count |
|------|----------------------------|-------------------|---------------------------|-------------------------|
|      |                            |                   | 2200+110 x (CT)           | Even count              |
|      |                            | reg,reg           | 1980                      | Zero count              |
|      |                            | <b>-</b>          | 1980+110 x (CT+1)         | Odd count               |
|      |                            |                   | 1980+110 x (CT)           | Even count              |
| SRAD | Shift Right Arithmetic     | cnt31,reg         | 2860                      | Zero count              |
|      | Double                     | -                 | 2860+110 x (CT+1)         | Odd count               |
|      |                            |                   | 2860+110 x (CT)           | Even count              |
|      |                            | reg,reg           | 2420                      | Zero count              |
|      |                            |                   | 2420+110 x (CT+1)         | Odd count               |
|      |                            |                   | 2420+110 x (CT)           | Even count              |
| SRL  | Shift Right Logical        | cnt16,reg         | 2200                      | Zero count              |
|      |                            |                   | 2200+110 x (CT+1)         | Odd count               |
|      |                            |                   | 2200+110 x (CT)           | Even count              |
|      |                            | reg,reg           | 1980                      | Zero count              |
|      |                            |                   | 1980+110 x (CT+1)         | Odd count               |
|      |                            |                   | 1980+110 x (CT)           | Even count              |
| SRLD | Shift Right Logical Double | cnt31,reg         | 2860                      | Zero count              |
|      |                            |                   | 2860+110 x (CT+1)         | Odd count               |
|      |                            |                   | 2860+110 x (CT)           | Even count              |
|      |                            | reg,reg           | 2420                      | Zero count              |
|      |                            |                   | 2420+110 x (CT+1)         | Odd count               |
|      |                            |                   | 2420+110 x (CT)           | Even count              |
| STM  | Store Multiple             | reg,addr4[,abcnt] | 11220+RS RL=7             |                         |
|      |                            |                   | 12320+(1100 x RL)+RS      | 5 RL <b></b> 7          |
| STOP | Stop                       | [ubyte]           | 1760                      |                         |
| SVC  | Supervisor Call            | ubyte             | 17380                     |                         |
| SW   | Subtract Word              | reg,reg           | 1320                      |                         |
|      |                            | reg,addr4         | 2860+RS                   |                         |
|      |                            | addr4, reg        | 1760+ <b>RS</b>           |                         |
|      |                            | addr5,addr4       | 3520+(AM1+Y)+AM2          |                         |
|      |                            |                   | $R=0 \qquad R\neq 0$      |                         |
|      |                            | longaddr,reg      | 3080 3080                 |                         |
|      |                            | longaddr*,reg     | 3740 3960                 |                         |
| SWCY | Subtract Word With Carry   | reg,reg           | 1760                      |                         |
| SWI  | Subtract Word Immediate    | word,addr4        | 4180+RS                   |                         |
|      |                            | word,reg[,reg]    | 2420                      |                         |
|      |                            |                   |                           |                         |

Table 2 (Part 9 of 10)

| Mnemonic | Instruction name                                                                                                                      | Syntax         | Execution i<br>(nanosecon |                  |                              |
|----------|---------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------|------------------|------------------------------|
| TBT      | Test Bit                                                                                                                              | (reg,bitdisp)  | 4840+A                    |                  | See TBTV note                |
| TBTR     | Test Bit and Reset                                                                                                                    | (reg,bitdisp)  | 5720+A                    |                  | See TBTV note                |
| TBTS     | Test Bit and Set                                                                                                                      | (reg,bitdisp)  | 5720+A                    |                  | See TBTV note                |
| TBTV     | Test Bit and Invert                                                                                                                   | (reg,bitdisp)  | 5720+A                    |                  | See note                     |
|          | Note. For TBT, TBTR, TBTS,                                                                                                            | and TBTV:      |                           |                  |                              |
|          | A = 0 if BT is zero.<br>A = $110 \times BT$ if BT is even.<br>A = $110 \times (BT+1)$ if BT is odd<br>BT = bit number of tested bit ( |                |                           |                  |                              |
| TWI      | Test Word Immediate                                                                                                                   | word,reg       | <b>286</b> 0              |                  | All bits = 0                 |
|          |                                                                                                                                       |                | 3080                      |                  | All bits $\neq 0$            |
|          |                                                                                                                                       | word,addr4     | 3520+RS<br>3740+RS        |                  | All bits = 0<br>Any bits ≠ 0 |
| VR       | Invert Register                                                                                                                       | reg[,reg]      | 1540                      |                  | Airy onts 7 0                |
| XB       | Exclusive OR Byte                                                                                                                     | reg.addr4      | 2860+RS                   |                  |                              |
|          |                                                                                                                                       | addr4,reg      | 1760+RS                   |                  |                              |
| XD       | Exclusive OR Doubleword                                                                                                               | reg,addr4      | 5060+RS                   |                  |                              |
|          |                                                                                                                                       | addr4,reg      | 3740+RS                   |                  |                              |
| XW       | Exclusive OR Word                                                                                                                     | reg,reg        | 1320                      |                  |                              |
|          |                                                                                                                                       | reg,addr4      | 2860+RS                   |                  |                              |
|          |                                                                                                                                       | addr4,reg      | 1760+RS                   |                  |                              |
|          |                                                                                                                                       |                | R = 0                     | R <del>4</del> 0 |                              |
|          |                                                                                                                                       | longaddr,reg   | 3080                      | 3080             |                              |
|          | <b></b>                                                                                                                               | longaddr*,reg  | 3740                      | 3960             |                              |
| XWI      | Exclusive OR Word<br>Immediate                                                                                                        | word,reg[,reg] | 2420                      |                  |                              |

Table 2 (Part 10 of 10)

. .

A-24 GA34-0021

# **Oxxx** Appendix B. Instruction Formats

The following instruction formats are shown in ascending sequence based on operation code. Bits zero through four of the first instruction word comprise the operation code field. Bit combinations are shown for each operation code along with the hexadecimal representation.

Some instructions contain a function field that modifies the operation code to form individual instructions within a group. Each chart shows the function field bit combinations in hexadecimal and in ascending sequence. The assembler mnemonic, assembler syntax, and instruction name are listed for the individual instructions. The asterisk shown with the assembler syntax indicates indirect addressing.

Refer to Chapter 2, *Effective Address Generation*, for a description of the Address Mode (AM) appended words.







cond,jdisp cond,jaddr

Jump on Condition Jump on Condition

Extended mnemonics: JCY, JE, JEV, JLE, JLLE, JLLT, JLT, JMIX, JN, JOFF, JON, JP, JZ





cond,jdisp cond,jaddr

Jump on Not Condition

Jump on Not Condition

Extended mnemonics: JGE, JGT, JLGE, JLGT, JNCY, JNE, JNEV, JNMIX, JNN, JNP, JNZ

| Operation co<br>0 0 1 0 | de<br>0 0 | R    | RB | AM    | Fun     | Р             | \$                               |
|-------------------------|-----------|------|----|-------|---------|---------------|----------------------------------|
|                         | 4 5       |      | 89 | 10 11 | 12      | 14 15         |                                  |
| 2                       |           | 0-3  |    | X     | ~       | $\tilde{D-F}$ | AM appended word                 |
|                         |           |      |    |       |         |               |                                  |
| 2 0-3 X                 | 0         | FA   |    |       | addr4,  | freg          | Floating Add                     |
|                         | 1         | FAD  |    |       | addr4,  | freg          | Floating Add Double              |
|                         | 2         | FS   |    |       | addr4,  | freg          | Floating Subtract                |
|                         | 3         | FSD  |    |       | addr4,  | freg          | Floating Subtract Double         |
|                         | 4         | FM   |    |       | addr4,  | freg          | Floating Multiply                |
| Ì                       | 5         | FMD  |    |       | addr4,  | freg          | Floating Multiply Double         |
|                         | 6         | FD   |    |       | addr4,  | freg          | Floating Divide                  |
|                         | 7         | FDD  |    |       | addr4,  | freg          | Floating Divide Double           |
|                         | 8         | FMVC | 2  |       | addr4,  | freg          | Floating Move and Convert        |
|                         | 9         | FMVC | CD |       | addr4,  | freg          | Floating Move and Convert Double |
|                         | A         | FMVC | 2  |       | freg,ac | ldr4          | Floating Move and Convert        |
|                         | в         | FMVC | D  |       | freg,ac | idr4          | Floating Move and Convert Double |
|                         | c         | FMV  |    |       | addr4,  | freg          | Floating Move                    |
|                         | D         | FMVI | )  |       | addr4,  | freg          | Floating Move Double             |
|                         | Е         | FMV  |    |       | freg,ad | ldr4          | Floating Move                    |
|                         | F         | FMVI | )  |       | freg,ac | ldr4          | Floating Move Double             |

| O        | pera | tio | n co | de     |   | R      | ! | R      | 2 |        |    | Func   |        | P  |
|----------|------|-----|------|--------|---|--------|---|--------|---|--------|----|--------|--------|----|
| 0        | 0    | 1   | 0    | 0      | 1 |        | j |        |   | 0      | 0  | 1      | :      |    |
| 0        |      |     |      | 4      | 5 | 6      | 7 | 8      | 9 | 10     | 11 | 12     | 14     | 15 |
| $\smile$ |      | ~   | -    | $\sim$ | - | $\sim$ | - | $\sim$ | - | $\sim$ | -  | $\sim$ | $\sim$ | -  |
|          |      | 2   |      |        | 4 | - 7    |   |        |   | X      |    |        | 0-F    | 7  |

| 2 | 4-7 X | 0 | FA                 | freg,freg |
|---|-------|---|--------------------|-----------|
| L |       | 1 | FAD                |           |
|   |       | I | ГАD                | freg,freg |
|   |       | 2 | FS                 | freg,freg |
|   |       | 3 | FSD                | freg,freg |
|   |       | 4 | FM                 | freg,freg |
|   |       | 5 | FMD                | freg,freg |
|   |       | 6 | FD                 | freg,freg |
|   |       | 7 | FDD                | freg,freg |
|   |       | 8 | FMV                | freg,freg |
|   |       | 9 | FMVD               | freg,freg |
|   |       | Α | FC                 | freg,freg |
|   |       | В | FCD                | freg,freg |
|   |       | С | (must not be used) |           |
|   |       | D | (must not be used) |           |
|   |       | E | (must not be used) |           |
|   |       | F | (must not be used) |           |

Floating Add Floating Add Double Floating Subtract Floating Subtract Double Floating Multiply Floating Multiply Double Floating Divide Floating Divide Double Floating Move Floating Move Double Floating Compare Floating Compare Double **Executes FMV Executes FMVD** Indicators are reset Indicators are reset

2.5

# 2xxx 3xxx

| Operation cod<br>0 0 1 0 | de<br>1 | R1 R2    | 0 I D Fun         |                                        |
|--------------------------|---------|----------|-------------------|----------------------------------------|
| 0                        | 4 3     | 5 7 8    | 10 11 12 13 14 15 |                                        |
| 2                        |         | 8-F      |                   |                                        |
|                          |         |          |                   |                                        |
| 2 8-F X                  | 0       | MVFD     | (reg),(reg)       | Move Byte Field and Decrement          |
|                          | 1       | (unused) |                   |                                        |
|                          | 2       | CFNED    | (reg),(reg)       | Compare Byte Field Not Equal and Decre |
|                          | 3       | CFED     | (reg),(reg)       | Compare Byte Field Equal and Decremen  |
|                          | 4       | MVFN     | (reg),(reg)       | Move Byte Field and Increment          |
|                          | 5       | (unused) |                   |                                        |
|                          | 6       | CFNEN    | (reg),(reg)       | Compare Byte Field Not Equal and Incre |
|                          | 7       | CFEN     | (reg),(reg)       | Compare Byte Field Equal and Increment |
|                          | 8       | FFD      | reg,(reg)         | Fill Byte Field and Decrement          |
|                          | 9       | (unused) |                   |                                        |
|                          | A       | SFNED    | reg,(reg)         | Scan Byte Field Not Equal and Decremer |
|                          | В       | SFED     | reg,(reg)         | Scan Byte Field Equal and Decrement    |
|                          | C       | FFN      | reg.(reg)         | Fill Byte Field and Increment          |
|                          | D       | (unused) |                   |                                        |
|                          | E       | SFNEN    | reg,(reg)         | Scan Byte Field Not Equal and Incremen |
|                          | F       | SFEN     | reg,(reg)         | Scan Byte Field Equal and Increment    |

**b.**..

C

| Operation code0011 | R Count | Function  |                               |
|--------------------|---------|-----------|-------------------------------|
| 0 4 5              | 7 8     | 12 13 15  |                               |
| 3 0                | -7 X    | 0-F       |                               |
|                    |         |           |                               |
| 3 0-7 X 0,8        | SLC     | cnt16,reg | Shift Left Circular           |
| 1,9                | SLL     | cnt16,reg | Shift Left Logical            |
| 2,A                | SRL     | cnt16,reg | Shift Right Logical           |
| 3,В                | SRA     | cnt16,reg | Shift Right Arithmetic        |
| 4,C                | SLCD    | cnt31,reg | Shift Left Circular Double    |
| 5,D                | SLLD    | cnt31,reg | Shift Left Logical Double     |
| 6,E                | SRLD    | cnt31,reg | Shift Right Logical Double    |
| 7,F                | SRAD    | cnt31,reg | Shift Right Arithmetic Double |

3xxx 4xxx





Illegal operation code (program check condition)



AM appended word

Note 1. Use format without immediate field.

4xxx 5xxx

| Operation code | R Fun   | Bit displacement |
|----------------|---------|------------------|
| 0 1 0 0 1      |         |                  |
| ) 4            | 5 7 8 9 | 10 15            |
| 4              | 8-F     | 0-F X            |
| 4 8-F 0-3      | х твт   | (reg,bitdisp)    |
| 4-7            | TBTS    | (reg,bitdisp)    |
|                |         | / <b>.</b>       |
| 8-B            | TBTR    | (reg, bitdisp)   |

| $O_l$    | oera | itio   | n co | ode    |    | R  |   | Word displac | ement  |
|----------|------|--------|------|--------|----|----|---|--------------|--------|
| 0        | 1    | 0      | 1    | 0      |    |    |   |              |        |
| 0        |      |        |      | 4      | 5  |    | 7 | 8            | 15     |
| $\smile$ | -    | $\sim$ | -    | $\sim$ |    |    | ~ | $\sim$       | $\sim$ |
|          |      | 5      |      |        | 0- | -7 |   | X            | X      |



| No Operation                | l |
|-----------------------------|---|
| jdisp                       |   |
| jaddr                       |   |
| (reg <sup>1-7</sup> ,jdisp) |   |
| (reg <sup>1-7</sup> )       |   |
| addr                        |   |

Jump Unconditional Jump Unconditional Branch Indexed Short Branch Indexed Short

| • 4 | × 34 |     | ۰. |  |
|-----|------|-----|----|--|
|     |      | £.  | 9  |  |
|     |      | ć., |    |  |

| 1.                    | peration<br>1 0 |       | .             |    | K       | RB  | AM    | Function  |          | <u> </u>                           |
|-----------------------|-----------------|-------|---------------|----|---------|-----|-------|-----------|----------|------------------------------------|
| 0                     | 1 0             |       | $\frac{1}{4}$ | 5  | 7       | 89  | 10 11 | 12        | 15 16    |                                    |
| U                     |                 |       | -             | 5  | ,       | 0 9 | 10 11 | 14        |          |                                    |
|                       |                 |       |               |    |         |     |       |           | AM       | <b>1</b> appended word             |
| 1 1                   | peratio         | n cod | te            |    | R       | RB  | AM    | Function  |          |                                    |
| 0                     | 1 0             |       | 1             |    |         | L   |       | l         | <u>`</u> |                                    |
| $\overset{o}{\smile}$ | $\sim$          |       | 4             | 5  | 7       | 89  | 10 11 | 12        | 15 16    | 31                                 |
|                       | 5               |       |               | 8- | -F      |     | x     | -F        | Al       | M appended word                    |
|                       |                 |       |               |    |         |     |       |           |          |                                    |
| 5                     | 8-F             | x     | 0             | Ţ  | SEIMF   | ર   |       | addr4     | ,        | Set Interrupt Mask Register        |
|                       |                 |       | 1             |    | SESR    |     |       | reg,addr4 |          | Set Segmentation Register          |
|                       |                 | İ     | 2             |    | SEAK    | R   |       | addr4     |          | Set Address Key Register (Note 2)  |
|                       |                 |       | 3             |    | SEFLB   |     |       | reg,addr4 |          | Set Floating Level Block           |
|                       |                 | 1     | 4             |    | SESK    |     |       | reg,addr4 |          | Set Storage Key                    |
|                       |                 |       | 5             |    | (invali | d)  |       |           |          | •                                  |
|                       |                 |       | 6             |    | SELB    |     |       | reg,addr4 |          | Set Level Status Block             |
|                       |                 |       | 7             |    | (invali | d)  |       |           | (e       |                                    |
|                       |                 |       | 8             |    | CPIMI   | R   |       | addr4     |          | Copy Interrupt Mask Register       |
|                       |                 |       | 9             |    | CPSR    |     |       | reg,addr4 |          | Copy Segmentation Register         |
|                       |                 |       | A             |    | CPAK    | R   |       | addr4     |          | Copy Address Key Register (Note 3) |
|                       |                 |       | B             |    | CPFL    | В   |       | reg,addr4 |          | Copy Floating Level Block          |
|                       |                 |       | С             |    | CPSK    |     |       | reg,addr4 |          | Copy Storage Key                   |
|                       |                 |       | D             |    | CPIPF   | 7 . |       | addr4     |          | Copy In-Process Flags              |
|                       |                 |       | E             |    | CPLB    |     |       | reg,addr4 |          | Copy Level Block                   |
|                       |                 |       | F             |    | CPPSI   | ર   |       | addr4     |          | Copy Processor Status and Reset    |

Note 2. Use format with K field.

Extended mnemonics: SEISK, SEOTK, SEOOK Note 3. Use format with K field. Extended mnemonics: CPISK, CPOTK, CPOOK

B-8 GA34-0021

|                                                                                    | Function Parameter | ,       |                         |
|------------------------------------------------------------------------------------|--------------------|---------|-------------------------|
| $\begin{array}{c} 0  1  1  0  0 \\ \hline 0 \qquad \qquad 4 \\ \hline \end{array}$ |                    | 15      |                         |
| 6                                                                                  | 0-7 X              | x       |                         |
| 6 0 X                                                                              | x svc              | ubyte   | Supervisor Call         |
|                                                                                    |                    | [ubyte] | Level Exit              |
| 2                                                                                  | EN                 | ubyte   | Enable                  |
| 3                                                                                  | DIS                | ubyte   | Disable                 |
| 4                                                                                  | STOP               | [ubyte] | Stop                    |
| 5                                                                                  | DIAG               | ubyte   | Diagnose                |
| 6                                                                                  | ЮРК                |         | Interchange Operand Key |
| 7                                                                                  | (invalid)          |         |                         |



Note 4. Extended mnemonics: BCY, BE, BEV, BLE, BLLE, BLLT, BLT, BMIX, BN, BOFF, BON, BP, BZ Note 5. Extended mnemonics: BGE, BGT, BLGE, BLGT, BNCY,

BNE, BNEV, BNMIX, BNN, BNOFF, BNON, BNP, BNZ

Note 6. Extended mnemonic: BX

Note 7. Extended mnemonic: BALX

Note 8. Extended mnemonic: BNER

Note 9. Extended mnemonic: BER

| R1, condition, or condition code<br>0=Direct address, 1=Indirect address |                                                      |           |                |                              |  |  |  |  |  |  |
|--------------------------------------------------------------------------|------------------------------------------------------|-----------|----------------|------------------------------|--|--|--|--|--|--|
| -                                                                        | Operation code R2 Function Address                   |           |                |                              |  |  |  |  |  |  |
|                                                                          | 1                                                    | 1         |                | 7                            |  |  |  |  |  |  |
| 0                                                                        | 4 5                                                  | 7 8 10 11 | 12 15 16       | 31                           |  |  |  |  |  |  |
| 6                                                                        | 6 	 8-F 	 1, 	 3, 	 5, 	 7, 	 9, 	 B, 	 D, 	 F 	 0-F |           |                |                              |  |  |  |  |  |  |
| ſ                                                                        |                                                      |           |                |                              |  |  |  |  |  |  |
| 6 8–F                                                                    | 0                                                    | BC        | cond,longaddr* | Branch on Condition          |  |  |  |  |  |  |
|                                                                          | 1                                                    | BNC       | cond,longaddr* | Branch on Not Condition      |  |  |  |  |  |  |
|                                                                          | 2 B                                                  |           | longaddr*      | Branch Unconditional         |  |  |  |  |  |  |
|                                                                          | 3                                                    | BAL       | longaddr*,reg  | Branch and Link              |  |  |  |  |  |  |
|                                                                          | 4                                                    | BCC       | cond,longaddr* | Branch on Condition Code     |  |  |  |  |  |  |
|                                                                          | 5                                                    | BNCC      | cond,longaddr* | Branch on Not Condition Code |  |  |  |  |  |  |
|                                                                          | 6                                                    | BOV       | longaddr*      | Branch on Overflow           |  |  |  |  |  |  |
|                                                                          | 7                                                    | BNOV      | longaddr*      | Branch on Not Overflow       |  |  |  |  |  |  |
|                                                                          | 8                                                    | MVW       | longaddr*,reg  | Move Word                    |  |  |  |  |  |  |
|                                                                          | 9                                                    | OW        | longaddr*,reg  | OR Word                      |  |  |  |  |  |  |
|                                                                          | A                                                    | RBTW      | longaddr*,reg  | Reset Bits Word              |  |  |  |  |  |  |
|                                                                          | В                                                    | XW        | longaddr*,reg  | Exclusive OR Word            |  |  |  |  |  |  |
|                                                                          | C                                                    | Ю         | longaddr*      | Operate I/O                  |  |  |  |  |  |  |
|                                                                          | D                                                    | MVW       | reg,longaddr*  | Move Word                    |  |  |  |  |  |  |
|                                                                          | E                                                    | AW        | longaddr*,reg  | Add Word                     |  |  |  |  |  |  |
|                                                                          | F                                                    | SW        | longaddr*,reg  | Subtract Word                |  |  |  |  |  |  |

**P** 

| Operation co |   | R1                     | R2          | Function                  | 1    |
|--------------|---|------------------------|-------------|---------------------------|------|
| 0 1 1 1      | 0 |                        | 112         | 1 4.1011011               |      |
| 0            | 4 | 5 7                    | 8 10        | 11 1.                     | 5    |
| 7            |   | $0-7$ $\overline{0}$ , | 2, 4, 6, 8, | $\frac{1}{A,C,E} = 0 - F$ |      |
| Ţ.           |   |                        |             |                           |      |
| 7 0-7        | 0 | RBTW                   | 1           | reg,reg                   | Res  |
|              | 1 | OW                     |             | reg,reg                   | OR   |
|              | 2 | SCY                    |             | reg                       | Sub  |
|              | 3 | XW                     |             | reg,reg                   | Exc  |
|              | 4 | MVW                    |             | reg,reg                   | Mov  |
|              | 5 | CW                     |             | reg,reg                   | Cor  |
|              | 6 | CMR                    |             | reg[,reg]                 | Cor  |
|              | 7 | IR                     |             | reg,reg                   | Inte |
|              | 8 | AW                     |             | reg,reg                   | Add  |
|              | 9 | AWCY                   | č           | reg,reg                   | Add  |
|              | Α | SW                     |             | reg,reg                   | Sub  |
|              | В | SWCY                   | •           | reg,reg                   | Sub  |
|              | С | ACY                    |             | reg                       | Add  |
|              | D | VR                     |             | reg[,reg]                 | Inv  |
|              | Ε | CPLSI                  | R           | reg                       | Cor  |
|              | F | SEINI                  | D           | reg                       | Set  |

set Bits Word R Word btract Carry Indicator clusive OR Word ove Word mpare Word mplement Register terchange Registers id Word ld Word With Carry btract Word btract Word With Carry ld Carry Register vert Register py Level Status Register t Indicators

B-12 GA34-0021

| Operation co<br>0 1 1 1 | ode<br>0 | R1 R2       | Function                            |                               |
|-------------------------|----------|-------------|-------------------------------------|-------------------------------|
| م                       | 4 5      | 781         | 10 11 15                            |                               |
| 7                       |          | 0-7         | $\underbrace{1}_{9, B, D, F} 0 - F$ |                               |
|                         |          | 1, 3, 5, 7, | 9, B, D, F                          |                               |
| Г                       |          |             | ]                                   |                               |
| 7 0-7                   | 0        | SLC         | *07 *07                             | Shift Left Circular           |
|                         |          |             | reg,reg                             |                               |
|                         | 1        | SLL         | reg,reg                             | Shift Left Logical            |
|                         | 2        | SRL         | reg,reg                             | Shift Right Logical           |
|                         | 3        | SRA         | reg,reg                             | Shift Right Arithmetic        |
|                         | 4        | SLCD        | reg,reg                             | Shift Left Circular Double    |
|                         | 5        | SLLD        | reg,reg                             | Shift Left Logical Double     |
|                         | 6        | SRLD        | reg,reg                             | Shift Right Logical Double    |
|                         | 7        | SRAD        | reg,reg                             | Shift Right Arithmetic Double |
|                         | 8        | (invalid)   |                                     |                               |
|                         | 9        | SLT         | reg,reg                             | Shift Left and Test           |
|                         | A        | (invalid)   |                                     |                               |
|                         | в        | (invalid)   |                                     |                               |
|                         | С        | (invalid)   |                                     |                               |
|                         | D        | SLTD        | regreg                              | Shift Left and Test Double    |
|                         | Е        | (invalid)   |                                     |                               |
|                         | F        | (invalid)   |                                     |                               |

## 7xxx



7xxx 8xxx



Extended mnemonics: SEISK, SEOTK, SEOOK Note 11. Use format with K field. Extended mnemonics: CPISK, CPOTK, CPOOK



#### 8xxx 9xxx



Axxx Bxxx











Illegal operation code (Program check condition)

47

#### Bxxx Cxxx



| 0=Storage | to register; | 1=Register | to storage |
|-----------|--------------|------------|------------|



| C | 0-7 X | 0  | MVB  | addr4,reg | Move Byte          |
|---|-------|----|------|-----------|--------------------|
|   |       | 1  | OB   | addr4,reg | OR Byte            |
|   |       | 2  | RBTB | addr4,reg | Reset Bits Byte    |
|   |       | 3  | ХВ   | addr4,reg | Exclusive OR Byte  |
|   |       | 4  | СВ   | addr4,reg | Compare Byte       |
|   |       | 5  | MVBZ | addr4,reg | Move Byte and Zero |
|   |       | 6  | AB   | addr4,reg | Add Byte           |
|   |       | 7  | SB   | addr4,reg | Subtract Byte      |
|   |       | 8  | MVB  | reg,addr4 | Move Byte          |
|   |       | 9  | OB   | reg,addr4 | OR Byte            |
|   |       | A  | RBTB | reg,addr4 | Reset Bits Byte    |
|   |       | В  | ХВ   | reg,addr4 | Exclusive OR Byte  |
|   |       | Е  | AB   | reg,addr4 | Add Byte           |
|   |       | F. | SB   | reg,addr4 | Subtract Byte      |
|   |       |    |      |           |                    |

#### Cxxx

|                              |   |                 | 0=Storage to                       | register; 1=Register to storage |
|------------------------------|---|-----------------|------------------------------------|---------------------------------|
| Operation co<br>1 1 0 0<br>0 | 1 | R RB<br>5 7 8 9 | AM Function<br>X 10 11 12 13 15 16 | <u>ک</u> ے<br>ا                 |
| ° č                          |   | $8-F$ $\lambda$ | 0-B, E, F AM                       | appended word                   |
| <u> </u>                     |   |                 |                                    |                                 |
| C 8-F X                      | 0 | MVW             | addr4,reg                          | Move Word                       |
|                              | 1 | OW              | addr4,reg                          | OR Word                         |
|                              | 2 | RBTW            | addr4,reg                          | Reset Bits Word                 |
|                              | 3 | XW              | addr4,reg                          | Exclusive OR Word               |
|                              | 4 | CW              | addr4,reg                          | Compare Word                    |
|                              | 5 | MVWZ            | addr4,reg                          | Move Word and Zero              |
|                              | 6 | AW              | addr4,reg                          | Add Word                        |
|                              | 7 | SW              | addr4,reg                          | Subtract Word                   |
|                              | 8 | MVW             | reg,addr4                          | Move Word                       |
|                              | 9 | OW              | reg,addr4                          | OR Word                         |
|                              | Α | RBTW            | reg,addr4                          | Reset Bits Word                 |
|                              | В | XW              | reg,addr4                          | Exclusive OR Word               |
|                              | Е | AW              | reg,addr4                          | Add Word                        |
|                              | F | SW              | reg,addr4                          | Subtract Word                   |

jeto,

0=Storage to register: 1=Registe

## Dxxx





D 8-F X X

Illegal operation code (Program check condition)



X MVWS shortaddr\*,reg Move Word Short

E 0

Instruction Formats B-21

#### Exxx Fxxx

| Operation co                                          |   | R      | RB  | AM              | Function  |       | 757                 |   |
|-------------------------------------------------------|---|--------|-----|-----------------|-----------|-------|---------------------|---|
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | 1 | 5 7    | 89  | 10 11           | 12        | 15 16 |                     |   |
| E                                                     | - | 8-F    | Ű   | $\widetilde{X}$ | 0-F       |       | pended word         |   |
| E 8-F X                                               | 0 | PSB    |     |                 | reg,addr4 |       | Push Byte           |   |
|                                                       | 1 | МВ     |     |                 | addr4,reg |       | Multiply Byte       |   |
|                                                       | 2 | DB     |     |                 | addr4,reg |       | Divide Byte         |   |
|                                                       | 3 | РВ     |     | ۱.              | addr4,reg |       | Pop Byte            |   |
|                                                       | 4 | PSW    |     |                 | reg,addr4 |       | Push Word           |   |
|                                                       | 5 | MW     |     |                 | addr4,reg |       | Multiply Word       |   |
|                                                       | 6 | DW     |     |                 | addr4,reg |       | Divide Word         |   |
|                                                       | 7 | PW     |     |                 | addr4,reg |       | Pop Word            |   |
|                                                       | 8 | PSD    |     |                 | reg,addr4 |       | Push Double Word    |   |
|                                                       | 9 | MD     |     |                 | addr4,reg |       | Multiply Double Wor | d |
|                                                       | Α | DD     |     |                 | addr4,reg |       | Divide Double Word  |   |
|                                                       | В | PD     |     |                 | addr4,reg |       | Pop Doubleword      |   |
|                                                       | С | (inval | id) |                 |           |       |                     |   |
|                                                       | D | (inval | id) |                 |           |       |                     |   |
|                                                       | Е | (inval | id) |                 |           |       |                     |   |
|                                                       | F | (inval | id) |                 |           |       |                     |   |



Compare Byte Immediate



| F 8-F X X | BALS | (reg,jdisp)* | Branch and Link Short |
|-----------|------|--------------|-----------------------|
|           | BALS | (reg)*       | Branch and Link Short |
|           | BALS | addr*        | Branch and Link Short |

# Appendix C. Assembler Syntax

| Coding           |                                                        |                                                                                                                                                                                                                                                                                       |       | (reg <sup>1-3</sup> ,waddr)                     | The effective address is the con-                                                                                                                                                                 |
|------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1. Data<br>to ri |                                                        | nodifies a field, is always from left                                                                                                                                                                                                                                                 |       | 1-2                                             | tents of the register reg <sup>1-3</sup> , added to the value of waddr. (AM=10)                                                                                                                   |
| -                | sters used in effe<br>ys in parenthese                 | ective address calculations are s.                                                                                                                                                                                                                                                    |       | disp1(reg <sup>1-3</sup> ,disp                  | 2)*The effective address is calculated<br>as follows: The contents of the<br>register reg <sup>1-3</sup> are added to the                                                                         |
| cates<br>the c   | s indirect address<br>contents of the a                | tion followed by an asterisk indi-<br>sing. Here, the effective address is<br>addressed storage location.                                                                                                                                                                             |       |                                                 | value of the displacement disp2<br>to form an address. The contents<br>of that storage location are added                                                                                         |
|                  |                                                        | ndicates that, after use, the contents by the number of bytes addressed.                                                                                                                                                                                                              |       |                                                 | to the value of disp1 to form the effective address. (AM=11)                                                                                                                                      |
|                  | indicates address                                      |                                                                                                                                                                                                                                                                                       |       | disp(reg <sup>1-3</sup> )*                      | The effective address is the<br>contents of storage at the address<br>defined by the contents of                                                                                                  |
|                  | · .                                                    | nstruction Operands                                                                                                                                                                                                                                                                   |       |                                                 | reg <sup><math>1-3</math></sup> , added to the value of disp. (AM=11)                                                                                                                             |
| abcnt            | of a work stora<br>Multiple (STM)                      | lue or expression representing the size<br>age area to be allocated by the Store<br>) instruction. The value you code must<br>nber in the range 0–16382.                                                                                                                              |       | (reg <sup>1-3</sup> )*                          | The effective address is the con-<br>tents of storage at the address<br>defined by the contents of reg <sup>1-3</sup> .<br>(AM=11)                                                                |
| addr             |                                                        | ue. Code an absolute or relocatable he range 0–65535.                                                                                                                                                                                                                                 |       | (reg <sup>1-3</sup> ,disp)*                     | (AM-11)<br>The contents of $reg^{1-3}$ are added<br>to disp, forming an address. The                                                                                                              |
| addr4            | An address valu<br>ing forms:<br>(reg <sup>0-3</sup> ) | ue that you code in one of the follow-<br>The effective address is the con-                                                                                                                                                                                                           |       |                                                 | contents of storage at that<br>address form the effective address.<br>(AM=11)                                                                                                                     |
|                  |                                                        | tents of the register reg <sup>0-3</sup> .<br>(AM=00)                                                                                                                                                                                                                                 |       | even or odd. For                                | ressing, the effective address can be<br>r word or doubleword addressing, the                                                                                                                     |
|                  | $(reg^{0-3}) +$                                        | The effective address is the contents of the register reg <sup>0-3</sup> . After an instruction uses it, the                                                                                                                                                                          | addr5 | effective address<br>An address value<br>forms: | must be even.<br>that you code in one of the following                                                                                                                                            |
|                  |                                                        | contents of the register are in-<br>creased by the number of bytes<br>addressed by the instruction.                                                                                                                                                                                   |       | (reg)                                           | The effective address is the contents of the register reg. $(AM=00)$                                                                                                                              |
|                  | addr                                                   | (AM=01)<br>The effective address is the value                                                                                                                                                                                                                                         |       | (reg) +                                         | The effective address is the con-<br>tents of the register reg. After an                                                                                                                          |
|                  | auui                                                   | of addr, unless the instruction<br>and addr are within the range of                                                                                                                                                                                                                   |       |                                                 | instruction uses it, the contents<br>of the register are increased by<br>the number of bytes addressed by                                                                                         |
|                  |                                                        | the same USING statement. If<br>they are, the assembler computes<br>the effective address as a displace-<br>ment (-32768 to +32767 or 0<br>to 65535) from the base register,<br>which must be reg <sup>1-3</sup> . (AM=10)                                                            |       | addr                                            | the instruction. (AM=01)<br>The effective address is the value<br>of addr, unless the instruction<br>and addr are within the domain<br>and range of the same USING<br>statement. If they are, the |
|                  | addr*                                                  | The effective address is the con-<br>tents of storage at the address<br>defined by addr, unless the instruc-<br>tion and addr are within the<br>domain and range of the same<br>USING statement. If they are,<br>the assembler computes the effec-<br>tive address as the contents of |       |                                                 | assembler computes the effective<br>address as a displacement (-32768<br>to +32767 or 0 to 65535) from<br>the base register, which must be<br>$reg^{1-7}$ . (AM=10)                               |
|                  |                                                        | storage at the address defined by<br>a displacement $(0-255)$ from the<br>base register, which must be<br>reg <sup>1-3</sup> . (AM=11)                                                                                                                                                |       |                                                 |                                                                                                                                                                                                   |

|         | addr*                                                               | The effective address is the con-<br>tents of storage at the address<br>defined by addr, unless the instruc-                                                                                                                                                                                                        | jdisp              |                                                                                            | m the byte following a jump<br>an absolute value or expression<br>o +254.                                                                                                                                                                                                      |
|---------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                                                                     | tion and addr are within the domain and range of the same                                                                                                                                                                                                                                                           | longaddr           | An address value th ing forms:                                                             | at you code in one of the follow-                                                                                                                                                                                                                                              |
|         |                                                                     | USING statement. If they are,<br>the assembler computes the<br>effective address as the contents<br>of storage at the address defined<br>by a displacement $(0-255)$ from<br>the base register, which must be<br>reg <sup>1-7</sup> . (AM=11)                                                                       |                    | addr                                                                                       | The effective address is the value<br>of addr, unless the instruction<br>and addr are within the domain<br>and range of the same USING<br>statement. If they are, the<br>assembler computes the effective<br>address as a displacement (-32768                                 |
|         | (reg <sup>1-7</sup> ,waddr)                                         | The effective address is the con-<br>tents of reg <sup><math>1-7</math></sup> , added to the value<br>of waddr. (AM=10)                                                                                                                                                                                             |                    |                                                                                            | to +32767 or 0 to 65535) from the base register, which must be $reg^{1-7}$ .                                                                                                                                                                                                   |
|         | disp1(reg <sup>1-7</sup> ,disp2) <sup>,</sup>                       | <sup>a</sup> The effective address is calculated<br>as follows: The contents of the<br>register reg <sup>1-7</sup> are added to the<br>value of the displacement disp2<br>to form an address. The contents<br>of that storage location are added<br>to the value of disp1 to form the<br>effective address. (AM=11) |                    | addr*                                                                                      | The effective address is the<br>contents of storage at the address<br>defined by addr, unless the instruc-<br>tion and addr are within the<br>domain and range of the same<br>USING statement. If they are,<br>the assembler computes the<br>effective address as the contents |
|         | disp(reg <sup>1-7</sup> )*                                          | The effective address is the con-<br>tents of storage at the address<br>defined by the contents of $reg^{1-7}$ ,<br>added to the value of disp.<br>(AM=11)                                                                                                                                                          |                    |                                                                                            | of storage at the address defined<br>by a displacement (-32768 to<br>+32767 or 0 to 65535) from the<br>base register, which must be<br>reg <sup>1-7</sup> .                                                                                                                    |
| ·       | (reg <sup>1-7</sup> )*                                              | The effective address is the con-<br>tents of storage at the address<br>defined by the contents of $reg^{1-7}$ .                                                                                                                                                                                                    |                    | (reg <sup>1-7</sup> ,waddr)                                                                | The effective address is the con-<br>tents of $reg^{1-7}$ , added to the value<br>of waddr.                                                                                                                                                                                    |
|         | (reg <sup>1-7</sup> ,disp)*                                         | (AM=11)<br>The contents of reg <sup>1-7</sup> are added<br>to disp, forming an address. The<br>contents of storage at that address                                                                                                                                                                                  |                    | (reg <sup>1-7</sup> ,waddr)*                                                               | The contents of the reg <sup>1-7</sup> , plus<br>waddr, form an address. The<br>contents of storage at that loca-<br>tion form the effective address.                                                                                                                          |
|         |                                                                     | form the effective address.<br>(AM=11)                                                                                                                                                                                                                                                                              |                    | (reg <sup>1-7</sup> )                                                                      | The effective address is the contents of the register $reg^{1-7}$ .                                                                                                                                                                                                            |
|         |                                                                     | , the effective address can be even<br>or doubleword addressing, the<br>ust be even.                                                                                                                                                                                                                                |                    | (reg <sup>1-7</sup> )*                                                                     | The effective address is the con-<br>tents of storage at the address<br>defined by the contents of $reg^{1-7}$ .                                                                                                                                                               |
| bitdisp | A displacement into<br>value or expression                          | b a bit field. Code an absolute in the range $0-63$ .                                                                                                                                                                                                                                                               | raddr              | An address value. C<br>the range $0-65535$                                                 | Code a relocatable expression in                                                                                                                                                                                                                                               |
| byte    | A byte value. Code<br>in the range -128 to                          | e an absolute value or expression<br>o +127 or 0 to 255.                                                                                                                                                                                                                                                            | reg                | register symbol (R0                                                                        | register. Code either a predefined<br>(-R7) or a symbol that is equated<br>the number $(0, 1, 2, 3, 4, 5, 6, 6, 7)$                                                                                                                                                            |
| cnt16   |                                                                     | register) shift count. Code an pression in the range $0-16$ .                                                                                                                                                                                                                                                       |                    | Symbols are equate                                                                         | ter number (0, 1, 2, 3, 4, 5, 6, or 7).<br>d with EQUR statements, which<br>astruction using the register symbol.                                                                                                                                                              |
| cnt31   |                                                                     | ster pair) shift count. Code an $(p_1, p_2) = (p_2, p_3)$                                                                                                                                                                                                                                                           | reg <sup>0-3</sup> | A general-purpose r                                                                        | register. Code either a predefined<br>(-R3) or a symbol that is equated                                                                                                                                                                                                        |
| cond    | A condition code va<br>expression in the ra                         | alue. Code an absolute value or $nge 0-7$ .                                                                                                                                                                                                                                                                         |                    | to the desired regist                                                                      | ter number (0, 1, 2, or 3).<br>d with EQUR statements, which                                                                                                                                                                                                                   |
| disp    | -                                                                   | lacement. Code an absolute in the range $0-255$ .                                                                                                                                                                                                                                                                   | reg <sup>1-3</sup> | must precede the in                                                                        | estruction using the register symbol.                                                                                                                                                                                                                                          |
| freg    | floating register syn<br>is equated to the de<br>3). Symbols are eq | gister. Code either a predefined<br>nbol (FR0–FR3) or a symbol that<br>esired register number (0, 1, 2, or<br>uated with EQUR statements,<br>a the instruction using the register                                                                                                                                   |                    | register symbol (R1<br>to the desired regist<br>are equated with E<br>cede the instruction | (-R3) or a symbol that is equated<br>ter number (1, 2, or 3). Symbols<br>QUR statements, which must pre-<br>n using the register symbol.                                                                                                                                       |
| jaddr   | symbol.<br>The address of an i                                      | e the instruction using the register<br>nstruction that is within –256 to<br>byte following a jump instruction.<br>expression.                                                                                                                                                                                      | reg <sup>1-7</sup> | register symbol (R1<br>to the desired regist<br>Symbols are equate                         | register. Code either a predefined $1-R7$ ) or a symbol that is equated ter number $(1, 2, 3, 4, 5, 6, \text{ or } 7)$ .<br>ed with EQUR statements, which astructions using the register                                                                                      |

~~~

| shortaddr | An address value th ing forms:                  | at you code in one of the follow-                                                                                                                                                                                                          |
|-----------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | (reg <sup>0-3</sup> ,wdisp)                     | The effective address is the value of wdisp added to the contents of $reg^{0-3}$ .                                                                                                                                                         |
|           | (reg <sup>0-3</sup> ,wdisp) *                   | The effective address is the con-<br>tents of storage at the address<br>defined by the value of wdisp<br>added to the contents of reg $^{0-3}$ .                                                                                           |
|           | (reg <sup>0-3</sup> )<br>(reg <sup>0-3</sup> )* | The effective address is the contents of $(reg^{0-3})$ .                                                                                                                                                                                   |
|           | (reg <sup>0-3</sup> )*                          | The effective address is the con-<br>tents of storage at the address<br>defined by the contents of $reg^{0-3}$ .                                                                                                                           |
|           | addr                                            | To use this form, the instruction<br>and addr must be in the domain<br>and range of the same USING<br>statement. The assembler com-<br>putes a displacement $(0-62)$ and<br>register combination that refers<br>to the requested location. |
|           | addr*                                           | Same as addr, except the assembler<br>computes the effective address as<br>the contents of storage at the<br>address defined by a displacement<br>(0-62) and register combination.                                                         |
|           | <i>Note</i> . For addr and reg <sup>0-3</sup> . | d addr*, the base register must be                                                                                                                                                                                                         |
| ubyte     | •••                                             | value or mask. Code an absolute in the range $0-255$ .                                                                                                                                                                                     |
| vcon      | An ordinary symbol<br>the current source        | ol that is defined externally from program.                                                                                                                                                                                                |
| waddr     |                                                 | s value. Code an absolute or<br>ion in the range -32768 to<br>535.                                                                                                                                                                         |
| wdisp     |                                                 | ess displacement. Code an absolute in the range $0-62$ .                                                                                                                                                                                   |
| word      |                                                 | le an absolute value or expression<br>8 to +32767 or 0 to 65535.                                                                                                                                                                           |

C

#### Appendix D. Numbering Systems and Conversion Tables

#### Binary and Hexadecimal Number Notations

#### **Binary Number Notation**

A binary number system, such as is used in Series/1 uses a base of two. The concept of using a base of two can be compared with the base of ten (decimal) number system.

| Binary number |
|---------------|
| = 0           |
| = 1           |
| = 10          |
| = 11          |
| = 100         |
| = 101         |
| = 110         |
| = 111         |
| = 1000        |
| = 1001        |
|               |





As shown above, the decimal number system allows counting to ten in each position from units to tens to hundreds to thousands, etc. The binary system allows counting to two in each position. Register displays in the Series/1 are in binary form: a bit light on is a 1; a bit light off is a 0.

Example of a binary number:



#### Hexadecimal Number System

It has been noted that binary numbers require about three times as many positions as decimal numbers to express the equivalent number. This is not much of a problem to the computer; however, in talking and writing or in communicating with the computer, these binary numbers are bulky. A long string of 1's and 0's cannot be effectively transmitted from one individual to another. Some shorthand method is necessary.

The hexadecimal number system fills this need. Because of the simple relationship of hexadecimal to binary, numbers can be converted from one system to another by inspection. The base or radix of the hexadecimal system is 16. This means there are 16 symbols: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, and F. The letters A, B, C, D, E, and F represent the 10-base system values of 10, 11, 12, 13, 14, and 15, respectively.

Four binary positions are equivalent to one hexadecimal position. The following table shows the comparable values of the three number systems.

| Decimal | Binary | Hexadecimal |
|---------|--------|-------------|
| 0       | 0000   | 0           |
| 1       | 0001   | 1           |
| 2       | 0010   | 2           |
| 3       | 0011   | 3           |
| 4       | 0100   | 4           |
| 5       | 0101   | 5           |
| 6       | 0110   | 6           |
| 7       | 0111   | 7           |
| 8       | 1000   | 8           |
| 9       | 1001   | 9           |
| 10      | 1010   | Α           |
| 11      | 1011   | В           |
| 12      | 1100   | С           |
| 13      | 1101   | D           |
| 14      | 1110   | Ε           |
| 15      | 1111   | F           |

At this point, all 16 symbols have been used, and a carry to the next higher position of the number is necessary. For example:

| Decimal | Binary    | Hexadecimal |
|---------|-----------|-------------|
| 16      | 0001 0000 | 10          |
| 17      | 0001 0001 | 11          |
| 18      | 0001 0010 | 12          |
| 19      | 0001 0011 | 13          |
| 20      | 0001 0100 | 14          |
| 21      | 0001 0101 | 15          |
|         |           |             |

-and so on-

Remember that as far as the internal circuitry of the computer is concerned, it understands only binary. But an operator can look at a series of lights on the computer console showing binary 1's and 0's, for example: 0001 1110 0001 0011, and say that the lights represent the hexadecimal value 1E13, which is easier to state than the string of 1's and 0's.

Hexadecimal-Decimal Conversion Tables

The table in this appendix provides for direct conversion of decimal and hexadecimal number in these ranges:

HexadecimalDecimal000 to FFF0000 to 4095

For numbers outside the range of the table, add the following values to the tables figures:

| Hexadecimal | Decimal |
|-------------|---------|
| 1000        | 4096    |
| 2000        | 8192    |
| 3000        | 12288   |
| 4000        | 16384   |
| 5000        | 20480   |
| 6000        | 24576   |
| 7000        | 28672   |
| 8000        | 32768   |
|             |         |



|                          | - 0                          | 1                                    | 2                            | 3                                    | 4                                    | 5                                    | 6                                    | 7                                    | 8                                    | 9                                    | A                                    | В                            | С                                    | D                                    | E                                    | F                                    |
|--------------------------|------------------------------|--------------------------------------|------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|
| 20 <u>/</u>              | 0512                         | 0513                                 | 0514                         | 0515                                 | 0516                                 | 0517                                 | 0518                                 | 0519                                 | 0520                                 | 0521                                 | 0522                                 | 0523                         | 0524                                 | 0525                                 | 0526                                 | 0527                                 |
| 21_                      | 0528                         | 0529                                 | 0530                         | 0531                                 | 0532                                 | 0533                                 | 0534                                 | 0535                                 | 0536                                 | 0537                                 | 0538                                 | 0539                         | 0540                                 | 0541                                 | 0542                                 | 0543                                 |
| 22_                      | 0544                         | 0545                                 | 0546                         | 0547                                 | 0548                                 | 0549                                 | 0550                                 | 0551                                 | 0552                                 | 0553                                 | 0554                                 | 0555                         | 0556                                 | 0557                                 | 0558                                 | 0559                                 |
| 23_                      | 0560                         | 0561                                 | 0562                         | 0563                                 | 0564                                 | 0565                                 | 0566                                 | 0567                                 | 0568                                 | 0569                                 | 0570                                 | 0571                         | 0572                                 | 0573                                 | 0574                                 | 0575                                 |
| 24_                      | 0576                         | 0577                                 | 0578                         | 0579                                 | 0580                                 | 0581                                 | 0582                                 | 0583                                 | 0584                                 | 0585                                 | 0586                                 | 0587                         | 0588                                 | 0589                                 | 0590                                 | 0591                                 |
| 25_                      | 0592                         | 0593                                 | 0594                         | 0595                                 | 0596                                 | 0597                                 | 0598                                 | 0599                                 | 0600                                 | 0601                                 | 0602                                 | 0603                         | 0604                                 | 0605                                 | 0606                                 | 0607                                 |
| 26_<br>27_<br>28_        | 0608<br>0624<br>0640         | 0609<br>0625                         | 0610<br>0626                 | 0611<br>0627                         | 0612<br>0628                         | 0613<br>0629                         | 0614<br>0630                         | 0615<br>0631                         | 0616<br>0632                         | 0617<br>0633                         | 0618<br>0634                         | 0619<br>0635                 | 0620<br>0636                         | 0621<br>0637                         | 0622<br>0638                         | 0 <b>623</b><br>0639                 |
| 28_<br>29_<br>2A_<br>2B_ | 0656<br>0672<br>0688         | 0641<br>0657<br>0673<br>0689         | 0642<br>0658<br>0674<br>0690 | 0643<br>0659<br>0675<br>0691         | 0644<br>0660<br>0676<br>0692         | 0645<br>0661<br>0677<br>0693         | 0646<br>0662<br>0678<br>0694         | 0647<br>0663<br>0679<br>0695         | 0648<br>0664<br>0680<br>0696         | 0649<br>0665<br>0681<br>0697         | 0650<br>0666<br>0682<br>0698         | 0651<br>0667<br>0683<br>0699 | 0652<br>0668<br>0684<br>0700         | 0653<br>0669<br>0685<br>0701         | 0654<br>0670<br>0686<br>0702         | 0655<br>0671<br>0687<br>0703         |
| 2C_                      | 0704                         | 0705                                 | 0706                         | 0707                                 | 0708                                 | 0709                                 | 0710                                 | 0711                                 | 0712                                 | 0713                                 | 0714                                 | 0715                         | 0716                                 | 0717                                 | 0718                                 | 0719                                 |
| 2D_                      | 0720                         | 0721                                 | 0722                         | 0723                                 | 0724                                 | 0725                                 | 0726                                 | 0727                                 | 0728                                 | 0729                                 | 0730                                 | 0731                         | 0732                                 | 0733                                 | 0734                                 | 0735                                 |
| 2E_                      | 0736                         | 0737                                 | 0738                         | 0739                                 | 0740                                 | 0741                                 | 0742                                 | 0743                                 | 0744                                 | 0745                                 | 0746                                 | 0747                         | 0748                                 | 0749                                 | 0750                                 | 0751                                 |
| 2F_                      | 0752                         | 0753                                 | 0754                         | 0755                                 | 0756                                 | 0757                                 | 0758                                 | 0759                                 | 0760                                 | 0761                                 | 0762                                 | 0763                         | 0764                                 | 0765                                 | 0766                                 | 0767                                 |
| 30_                      | 0768                         | 0769                                 | 0770                         | 0771                                 | 0772                                 | 0773                                 | 0774                                 | 0775                                 | 0776                                 | 0777                                 | 0778                                 | 0779                         | 0780                                 | 0781                                 | 0782                                 | 0783                                 |
| 31_                      | 0784                         | 0785                                 | 0786                         | 0787                                 | 0788                                 | 0789                                 | 0790                                 | 0791                                 | 0792                                 | 0793                                 | 0794                                 | 0795                         | 0796                                 | 0797                                 | 0798                                 | 0799                                 |
| 32_                      | 0800                         | 0801                                 | 0802                         | 0803                                 | 0804                                 | 0805                                 | 0806                                 | 0807                                 | 0808                                 | 0809                                 | 0810                                 | 0811                         | 0812                                 | 0813                                 | 0814                                 | 0815                                 |
| 33_                      | 0816                         | 0817                                 | 0818                         | 0819                                 | 0820                                 | 0821                                 | 0822                                 | 0823                                 | 0824                                 | 0825                                 | 0826                                 | 0827                         | 0828                                 | 0829                                 | 0830                                 | 0831                                 |
| 34_                      | 0832                         | 0833                                 | 0834                         | 0835                                 | 0836                                 | 0837                                 | 0838                                 | 0839                                 | 0840                                 | 0841                                 | 0842                                 | 0843                         | 0844                                 | 0845                                 | 0846                                 | 0847                                 |
| 35_                      | 0848                         | 0849                                 | 0850                         | 0851                                 | 0852                                 | 0853                                 | 0854                                 | 0855                                 | 0856                                 | 0857                                 | 0858                                 | 0859                         | 0860                                 | 0861                                 | 0862                                 | 0863                                 |
| 36_                      | 0864                         | 0865                                 | 0866                         | 0867                                 | 0868                                 | 0869                                 | 0870                                 | 0871                                 | 0872                                 | 0873                                 | 0874                                 | 0875                         | 0876                                 | 0877                                 | 0878                                 | 0879                                 |
| 37_                      | 0880                         | 0881                                 | 0882                         | 0883                                 | 0884                                 | 0885                                 | 0886                                 | 0887                                 | 0888                                 | 0889                                 | 0890                                 | 0891                         | 0892                                 | 0893                                 | 0894                                 | 0895                                 |
| 38_                      | 0896                         | 0897                                 | 0898                         | 0899                                 | 0900                                 | 0901                                 | 0902                                 | 0903                                 | 0904                                 | 0905                                 | 0906                                 | 0907                         | 0908                                 | 0909                                 | 0910                                 | 0911                                 |
| 39_                      | 0912                         | 0913                                 | 0914                         | 0915                                 | 0916                                 | 0917                                 | 0918                                 | 0919                                 | 0920                                 | 0921                                 | 0922                                 | 0923                         | 0924                                 | 0925                                 | 0926                                 | 0927                                 |
| 3A_                      | 0928                         | 0929                                 | 0930                         | 0931                                 | 0932                                 | 0933                                 | 0934                                 | 0935                                 | 0936                                 | 0937                                 | 0938                                 | 0939                         | 0940                                 | 0941                                 | 0942                                 | 0943                                 |
| 3B_                      | 0944                         | 0945                                 | 0946                         | 0947                                 | 0948                                 | 0949                                 | 0950                                 | 0951                                 | 0952                                 | 0953                                 | 0954                                 | 0955                         | 0956                                 | 0957                                 | 0958                                 | 0959                                 |
| 3C_                      | 0960                         | 0961                                 | 0962                         | 0963                                 | 0964                                 | 0965                                 | 0966                                 | 0967                                 | 0968                                 | 0969                                 | 0970                                 | 0971                         | 0972                                 | 0973                                 | 0974                                 | 0975                                 |
| 3D_                      | 0976                         | 0977                                 | 0978                         | 0979                                 | 0980                                 | 0981                                 | 0982                                 | 0983                                 | 0984                                 | 0985                                 | 0986                                 | 0987                         | 0988                                 | 0989                                 | 0990                                 | 0991                                 |
| 3E_                      | 0992                         | 0993                                 | 0994                         | 0995                                 | 0996                                 | 0997                                 | 0998                                 | 0999                                 | 1000                                 | 1001                                 | 1002                                 | 1003                         | 1004                                 | 1005                                 | 1006                                 | 1007                                 |
| 3F_                      | 1008                         | 1009                                 | 1010                         | 1011                                 | 1012                                 | 1013                                 | 1014                                 | 1015                                 | 1016                                 | 1017                                 | 1018                                 | 1019                         | 1020                                 | 1021                                 | 1022                                 | 1023                                 |
|                          | 0                            | 1                                    | 2                            | 3                                    | 4                                    | 5                                    | 6                                    | 7                                    | 8                                    | 9                                    | A                                    | В                            | С                                    | D                                    | E                                    | F                                    |
| 40_                      | 1024                         | 1025                                 | 1026                         | 1027                                 | 1028                                 | 1029                                 | 1030                                 | 1031                                 | 1032                                 | 1033                                 | 1034                                 | 1035                         | 1036                                 | 1037                                 | 1038                                 | 1039                                 |
| 41_                      | 1040                         | 1041                                 | 1042                         | 1043                                 | 1044                                 | 1045                                 | 1046                                 | 1047                                 | 1048                                 | 1049                                 | 1050                                 | 1051                         | 1052                                 | 1053                                 | 1054                                 | 1055                                 |
| 42_                      | 1056                         | 1057                                 | 1058                         | 1059                                 | 1060                                 | 1061                                 | 1062                                 | 1063                                 | 1064                                 | 1065                                 | 1066                                 | 1067                         | 1068                                 | 1069                                 | 1070                                 | 1071                                 |
| 43_                      | 1072                         | 1073                                 | 1074                         | 1075                                 | 1076                                 | 1077                                 | 1078                                 | 1079                                 | 1080                                 | 1081                                 | 1082                                 | 1083                         | 1084                                 | 1085                                 | 1086                                 | 1087                                 |
| 44_                      | 1088                         | 1089                                 | 1090                         | 1091                                 | 1092                                 | 1093                                 | 1094                                 | 1095                                 | 1096                                 | 1097                                 | 1098                                 | 1099                         | 1100                                 | 1101                                 | 1102                                 | 1103                                 |
| 45_                      | 1104                         | 1105                                 | 1106                         | 1107                                 | 1108                                 | 1109                                 | 1110                                 | 1111                                 | 1112                                 | 1113                                 | 1114                                 | 1115                         | 1116                                 | 1117                                 | 1118                                 | 1119                                 |
| 46_                      | 1120                         | 1121                                 | 1122                         | 1123                                 | 1124                                 | 1125                                 | 1126                                 | 1127                                 | 1128                                 | 1129                                 | 1130                                 | 1131                         | 1132                                 | 1133                                 | 1134                                 | 1135                                 |
| 47_                      | 1136                         | 1137                                 | 1138                         | 1139                                 | 1140                                 | 1141                                 | 1142                                 | 1143                                 | 1144                                 | 1145                                 | 1146                                 | 1147                         | 1148                                 | 1149                                 | 1150                                 | 1151                                 |
| 48_<br>49_<br>4A_<br>4B_ | 1152<br>1168<br>1184<br>1200 | 1153<br>1169<br>1185<br>1201         | 1154<br>1170<br>1186<br>1202 | 1155<br>1171<br>1187<br>1203         | 1156<br>1172<br>1188<br>1204         | 1157<br>1173<br>1189<br>1205         | 1158<br>1174<br>1190<br>1206         | 1140<br>1159<br>1175<br>1191<br>1207 | 1160<br>1176<br>1192<br>1208         | 1140<br>1161<br>1177<br>1193<br>1209 | 1162<br>1178<br>1194<br>1210         | 1163<br>1179<br>1195<br>1211 | 1140<br>1164<br>1180<br>1196<br>1212 | 1145<br>1165<br>1181<br>1197<br>1213 | 1166<br>1182<br>1198<br>1214         | 1167<br>1183<br>1199<br>1215         |
| 4C_<br>4D_<br>4E_<br>4F_ | 1216<br>1232<br>1248<br>1264 | 1201<br>1217<br>1233<br>1249<br>1265 | 1218<br>1234<br>1250<br>1266 | 1203<br>1219<br>1235<br>1251<br>1267 | 1204<br>1220<br>1236<br>1252<br>1268 | 1203<br>1221<br>1237<br>1253<br>1269 | 1200<br>1222<br>1238<br>1254<br>1270 | 1207<br>1223<br>1239<br>1255<br>1271 | 1208<br>1224<br>1240<br>1256<br>1272 | 1203<br>1225<br>1241<br>1257<br>1273 | 1210<br>1226<br>1242<br>1258<br>1274 | 1227<br>1243<br>1259<br>1275 | 1212<br>1228<br>1244<br>1260<br>1276 | 1213<br>1229<br>1245<br>1261<br>1277 | 1214<br>1230<br>1246<br>1262<br>1278 | 1213<br>1231<br>1247<br>1263<br>1279 |
| 50_                      | 1280                         | 1281                                 | 1282                         | 1283                                 | 1284                                 | 1285                                 | 1286                                 | 1287                                 | 1288                                 | 1289                                 | 1290                                 | 1291                         | 1292                                 | 1293                                 | 1294                                 | 1295                                 |
| 51_                      | 1296                         | 1297                                 | 1298                         | 1299                                 | 1300                                 | 1301                                 | 1302                                 | 1303                                 | 1304                                 | 1305                                 | 1306                                 | 1307                         | 1308                                 | 1309                                 | 1310                                 | 1311                                 |
| 52_                      | 1312                         | 1313                                 | 1314                         | 1315                                 | 1316                                 | 1317                                 | 1318                                 | 1319                                 | 1320                                 | 1321                                 | 1322                                 | 1323                         | 1324                                 | 1325                                 | 1326                                 | 1327                                 |
| 53_                      | 1328                         | 1329                                 | 1330                         | 1331                                 | 1332                                 | 1333                                 | 1334                                 | 1335                                 | 1336                                 | 1337                                 | 1338                                 | 1339                         | 1340                                 | 1341                                 | 1342                                 | 1343                                 |
| 54_<br>55_<br>56_<br>57_ | 1344<br>1360<br>1376<br>1392 | 1345<br>1361<br>1377<br>1393         | 1346<br>1362<br>1378<br>1394 | 1347<br>1363<br>1379<br>1395         | 1348<br>1364<br>1380<br>1396         | 1349<br>1365<br>1381<br>1397         | 1350<br>1366<br>1382<br>1398         | 1353<br>1351<br>1367<br>1383<br>1399 | 1352<br>1368<br>1384<br>1400         | 1353<br>1369<br>1385<br>1401         | 1354<br>1370<br>1386<br>1402         | 1355<br>1371<br>1387<br>1403 | 1356<br>1372<br>1388<br>1404         | 1357<br>1373<br>1389<br>1405         | 1358<br>1374<br>1390<br>1406         | 1359<br>1375<br>1391<br>1407         |
| 58_                      | 1408                         | 1409                                 | 1410                         | 1411                                 | 1412                                 | 1413                                 | 1414                                 | 1415                                 | 1416                                 | 1417                                 | 1418                                 | 1419                         | 1420                                 | 1421                                 | 1422                                 | 1423                                 |
| 59_                      | 1424                         | 1425                                 | 1426                         | 1427                                 | 1428                                 | 1429                                 | 1430                                 | 1431                                 | 1432                                 | 1433                                 | 1434                                 | 1435                         | 1436                                 | 1437                                 | 1438                                 | 1439                                 |
| 5A_                      | 1440                         | 1441                                 | 1442                         | 1443                                 | 1444                                 | 1445                                 | 1446                                 | 1447                                 | 1448                                 | 1449                                 | 1450                                 | 1451                         | 1452                                 | 1453                                 | 1454                                 | 1455                                 |
| 5B_                      | 1456                         | 1457                                 | 1458                         | 1459                                 | 1460                                 | 1461                                 | 1462                                 | 1463                                 | 1464                                 | 1465                                 | 1466                                 | 1467                         | 1468                                 | 1469                                 | 1470                                 | 1471                                 |
| 5C_<br>5D_               | 1472<br>1488                 | 1473<br>1489                         | 1474<br>1490                 | 1475<br>1491                         | 1476<br>1492                         | 1401<br>1477<br>1493                 | 1478<br>1494                         | 1479<br>1495                         | 1480<br>1496                         | 1481<br>1497                         | 1482<br>1498                         | 1483<br>1499                 | 1484<br>1500                         | 1485<br>1501                         | 1486<br>1502                         | 1487<br>1503                         |

ſ

٠

|                                                                                                                                                                                            |                                                                                                                                                                                                              | <u> </u>                                                                                                                                                                                                                             |                                                                                                                                                                                                                              |                                                                                                                                                                                              |                                                                                                                                                                                                              | ~                                                                                                                                                                                                                    |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                       |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                       | n                                                                                                                                                                                                            |                                                                                                                                                                                                              |                                                                                                                                                                                                                              | F                                                                                                                                                                                                                    |                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                            | -0                                                                                                                                                                                                           | 1                                                                                                                                                                                                                                    | 2                                                                                                                                                                                                                            | 3                                                                                                                                                                                            | 4                                                                                                                                                                                                            | 5                                                                                                                                                                                                                    | 6                                                                                                                                                                                                            | 7                                                                                                                                                                                                                                                    | 8                                                                                                                                                                                                                     | 9                                                                                                                                                                                                            | A                                                                                                                                                                                                                                                                     | B                                                                                                                                                                                                            | C                                                                                                                                                                                                            | D                                                                                                                                                                                                                            | E<br>1550                                                                                                                                                                                                            | F                                                                                                                                                                                                                    |
| 60 <u>▼</u><br>61_                                                                                                                                                                         | 1536<br>1552                                                                                                                                                                                                 | 1537<br>1553                                                                                                                                                                                                                         | 1538<br>1554                                                                                                                                                                                                                 | 1539<br>1555                                                                                                                                                                                 | 1540<br>1556                                                                                                                                                                                                 | 1541<br>1557                                                                                                                                                                                                         | 1542<br>1558                                                                                                                                                                                                 | 1543<br>1559                                                                                                                                                                                                                                         | 1544<br>1560                                                                                                                                                                                                          | 1545<br>1561                                                                                                                                                                                                 | 1546<br>1562                                                                                                                                                                                                                                                          | 1547<br>1563                                                                                                                                                                                                 | 1548<br>1564                                                                                                                                                                                                 | 1549<br>1565                                                                                                                                                                                                                 | 1566                                                                                                                                                                                                                 | 1551<br>1567                                                                                                                                                                                                         |
| 62                                                                                                                                                                                         | 1568                                                                                                                                                                                                         | 1569                                                                                                                                                                                                                                 | 1570                                                                                                                                                                                                                         | 1571                                                                                                                                                                                         | 1572                                                                                                                                                                                                         | 1573                                                                                                                                                                                                                 | 1574                                                                                                                                                                                                         | 1575                                                                                                                                                                                                                                                 | 1576                                                                                                                                                                                                                  | 1577                                                                                                                                                                                                         | 1578                                                                                                                                                                                                                                                                  | 1579                                                                                                                                                                                                         | 1580                                                                                                                                                                                                         | 1581                                                                                                                                                                                                                         | 1582                                                                                                                                                                                                                 | 1583                                                                                                                                                                                                                 |
| 63_<br>64_                                                                                                                                                                                 | 1584<br>1600                                                                                                                                                                                                 | 1585<br>1601                                                                                                                                                                                                                         | 1586<br>1602                                                                                                                                                                                                                 | 1587<br>1603                                                                                                                                                                                 | 1588<br>1604                                                                                                                                                                                                 | 1589<br>1605                                                                                                                                                                                                         | 1590<br>1606                                                                                                                                                                                                 | 1591<br>1607                                                                                                                                                                                                                                         | 1592<br>1608                                                                                                                                                                                                          | 1593<br>1609                                                                                                                                                                                                 | 1594<br>1610                                                                                                                                                                                                                                                          | 1595<br>1611                                                                                                                                                                                                 | 1596<br>1612                                                                                                                                                                                                 | 1597<br>1613                                                                                                                                                                                                                 | 1598<br>1614                                                                                                                                                                                                         | 1599<br>1615                                                                                                                                                                                                         |
| 65_                                                                                                                                                                                        | 1616                                                                                                                                                                                                         | 1617                                                                                                                                                                                                                                 | 1618                                                                                                                                                                                                                         | 1619                                                                                                                                                                                         | 1620                                                                                                                                                                                                         | 1621                                                                                                                                                                                                                 | 1622                                                                                                                                                                                                         | 1623                                                                                                                                                                                                                                                 | 1624                                                                                                                                                                                                                  | 1625                                                                                                                                                                                                         | 1626                                                                                                                                                                                                                                                                  | 1627                                                                                                                                                                                                         | 1628                                                                                                                                                                                                         | 1629                                                                                                                                                                                                                         | 1630                                                                                                                                                                                                                 | 1631                                                                                                                                                                                                                 |
| 66_                                                                                                                                                                                        | 1632                                                                                                                                                                                                         | 1633                                                                                                                                                                                                                                 | 1634                                                                                                                                                                                                                         | 1635                                                                                                                                                                                         | 1636                                                                                                                                                                                                         | 1637<br>1653                                                                                                                                                                                                         | 1638<br>1654                                                                                                                                                                                                 | 1639                                                                                                                                                                                                                                                 | 1640                                                                                                                                                                                                                  | 1641                                                                                                                                                                                                         | 1642                                                                                                                                                                                                                                                                  | 1643                                                                                                                                                                                                         | 1644<br>1660                                                                                                                                                                                                 | 1645<br>1661                                                                                                                                                                                                                 | 1646<br>1662                                                                                                                                                                                                         | 1647                                                                                                                                                                                                                 |
| 67_<br>68_                                                                                                                                                                                 | 1648<br>1664                                                                                                                                                                                                 | 1649<br>1665                                                                                                                                                                                                                         | 1650<br>1666                                                                                                                                                                                                                 | 1651<br>1667                                                                                                                                                                                 | 1652<br>1668                                                                                                                                                                                                 | 1669                                                                                                                                                                                                                 | 1670                                                                                                                                                                                                         | 1655<br>1671                                                                                                                                                                                                                                         | 1656<br>1672                                                                                                                                                                                                          | 1657<br>1673                                                                                                                                                                                                 | 1658<br>1674                                                                                                                                                                                                                                                          | 1659<br>1675                                                                                                                                                                                                 | 1676                                                                                                                                                                                                         | 1677                                                                                                                                                                                                                         | 1678                                                                                                                                                                                                                 | 1663<br>1679                                                                                                                                                                                                         |
| 69                                                                                                                                                                                         | 1680                                                                                                                                                                                                         | 1681                                                                                                                                                                                                                                 | 1682                                                                                                                                                                                                                         | 1683                                                                                                                                                                                         | 1684                                                                                                                                                                                                         | 1685                                                                                                                                                                                                                 | 1686                                                                                                                                                                                                         | 1687                                                                                                                                                                                                                                                 | 1688                                                                                                                                                                                                                  | 1689                                                                                                                                                                                                         | 1690                                                                                                                                                                                                                                                                  | 1691                                                                                                                                                                                                         | 1692                                                                                                                                                                                                         | 1693                                                                                                                                                                                                                         | 1694                                                                                                                                                                                                                 | 1695                                                                                                                                                                                                                 |
| 6A<br>6B                                                                                                                                                                                   | 1696<br>1712                                                                                                                                                                                                 | 1697<br>1713                                                                                                                                                                                                                         | 1698<br>1714                                                                                                                                                                                                                 | $1699 \\ 1715$                                                                                                                                                                               | 1700<br>1716                                                                                                                                                                                                 | 1701<br>1717                                                                                                                                                                                                         | 1702<br>1718                                                                                                                                                                                                 | 1703<br>1719                                                                                                                                                                                                                                         | 1704<br>1720                                                                                                                                                                                                          | $1705 \\ 1721$                                                                                                                                                                                               | 1706<br>1722                                                                                                                                                                                                                                                          | 1707<br>1723                                                                                                                                                                                                 | 1708<br>1724                                                                                                                                                                                                 | 1709<br>1725                                                                                                                                                                                                                 | 1710<br>1726                                                                                                                                                                                                         | $1711 \\ 1727$                                                                                                                                                                                                       |
| 6C_                                                                                                                                                                                        | 1728                                                                                                                                                                                                         | 1729                                                                                                                                                                                                                                 | 1730                                                                                                                                                                                                                         | 1731                                                                                                                                                                                         | 1732                                                                                                                                                                                                         | 1733                                                                                                                                                                                                                 | 1734                                                                                                                                                                                                         | 1735                                                                                                                                                                                                                                                 | 1736                                                                                                                                                                                                                  | 1737                                                                                                                                                                                                         | 1738                                                                                                                                                                                                                                                                  | 1739                                                                                                                                                                                                         | 1740                                                                                                                                                                                                         | 1741                                                                                                                                                                                                                         | 1742                                                                                                                                                                                                                 | 1743                                                                                                                                                                                                                 |
| 6D_                                                                                                                                                                                        | 1744                                                                                                                                                                                                         | 1745                                                                                                                                                                                                                                 | 1746                                                                                                                                                                                                                         | 1747                                                                                                                                                                                         | 1748                                                                                                                                                                                                         | 1749                                                                                                                                                                                                                 | 1750                                                                                                                                                                                                         | 1751                                                                                                                                                                                                                                                 | 1752                                                                                                                                                                                                                  | 1753                                                                                                                                                                                                         | 1754                                                                                                                                                                                                                                                                  | 1755                                                                                                                                                                                                         | 1756                                                                                                                                                                                                         | 1757                                                                                                                                                                                                                         | 1758                                                                                                                                                                                                                 | 1759                                                                                                                                                                                                                 |
| 8E_<br>8F_                                                                                                                                                                                 | 1760<br>1776                                                                                                                                                                                                 | 1761<br>1777                                                                                                                                                                                                                         | $1762 \\ 1778$                                                                                                                                                                                                               | 1763<br>1779                                                                                                                                                                                 | 1764<br>1780                                                                                                                                                                                                 | 1765<br>1781                                                                                                                                                                                                         | 1766<br>1782                                                                                                                                                                                                 | 1767<br>1783                                                                                                                                                                                                                                         | 1768<br>1 <b>784</b>                                                                                                                                                                                                  | 1769<br>1785                                                                                                                                                                                                 | 1770<br>1786                                                                                                                                                                                                                                                          | 1771<br>1787                                                                                                                                                                                                 | 1772<br>1788                                                                                                                                                                                                 | 1773<br>1789                                                                                                                                                                                                                 | 1774<br>1790                                                                                                                                                                                                         | 1775<br>1791                                                                                                                                                                                                         |
| 70_                                                                                                                                                                                        | Ì                                                                                                                                                                                                            |                                                                                                                                                                                                                                      |                                                                                                                                                                                                                              |                                                                                                                                                                                              |                                                                                                                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                       |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                              | 1804                                                                                                                                                                                                         | 1805                                                                                                                                                                                                                         | 1806                                                                                                                                                                                                                 | 1807                                                                                                                                                                                                                 |
| 71_                                                                                                                                                                                        | 1792<br>1808                                                                                                                                                                                                 | 1793<br>1809                                                                                                                                                                                                                         | 1794<br>1810                                                                                                                                                                                                                 | $1795 \\ 1811$                                                                                                                                                                               | 1796<br>1812                                                                                                                                                                                                 | 1797<br>1813                                                                                                                                                                                                         | 1798<br>1814                                                                                                                                                                                                 | 1799<br>1815                                                                                                                                                                                                                                         | 1800<br>1816                                                                                                                                                                                                          | 1801<br>1817                                                                                                                                                                                                 | 1802<br>1818                                                                                                                                                                                                                                                          | 1803<br>1819                                                                                                                                                                                                 | 1804                                                                                                                                                                                                         | 1805                                                                                                                                                                                                                         | 1822                                                                                                                                                                                                                 | 1823                                                                                                                                                                                                                 |
| 72<br>73                                                                                                                                                                                   | 1824                                                                                                                                                                                                         | 1825                                                                                                                                                                                                                                 | 1826                                                                                                                                                                                                                         | 1827                                                                                                                                                                                         | 1828                                                                                                                                                                                                         | 1829                                                                                                                                                                                                                 | 1830                                                                                                                                                                                                         | 1831                                                                                                                                                                                                                                                 | 1832                                                                                                                                                                                                                  | 1833                                                                                                                                                                                                         | 1834                                                                                                                                                                                                                                                                  | 1835                                                                                                                                                                                                         | 1836                                                                                                                                                                                                         | 1837                                                                                                                                                                                                                         | 1838                                                                                                                                                                                                                 | 1839                                                                                                                                                                                                                 |
| 74_                                                                                                                                                                                        | 1840<br>1856                                                                                                                                                                                                 | 1841                                                                                                                                                                                                                                 | 1842                                                                                                                                                                                                                         | 1843                                                                                                                                                                                         | 1844                                                                                                                                                                                                         | 1845<br>1861                                                                                                                                                                                                         | 1846<br>1862                                                                                                                                                                                                 | 1847<br>1863                                                                                                                                                                                                                                         | 1848<br>1864                                                                                                                                                                                                          | 1849<br>1865                                                                                                                                                                                                 | 1850<br>1866                                                                                                                                                                                                                                                          | 1851<br>1867                                                                                                                                                                                                 | 1852<br>1868                                                                                                                                                                                                 | 1853<br>1869                                                                                                                                                                                                                 | 1854<br>1870                                                                                                                                                                                                         | $1855 \\ 1871$                                                                                                                                                                                                       |
| 75_                                                                                                                                                                                        | 1872                                                                                                                                                                                                         | 1857<br>1873                                                                                                                                                                                                                         | $1858 \\ 1874$                                                                                                                                                                                                               | $1859 \\ 1875$                                                                                                                                                                               | 1860<br>1876                                                                                                                                                                                                 | 1877                                                                                                                                                                                                                 | 1878                                                                                                                                                                                                         | 1803                                                                                                                                                                                                                                                 | 1880                                                                                                                                                                                                                  | 1865                                                                                                                                                                                                         | 1882                                                                                                                                                                                                                                                                  | 1883                                                                                                                                                                                                         | 1884                                                                                                                                                                                                         | 1885                                                                                                                                                                                                                         | 1886                                                                                                                                                                                                                 | 1887                                                                                                                                                                                                                 |
| 76_<br>77_                                                                                                                                                                                 | 1888                                                                                                                                                                                                         | 1889                                                                                                                                                                                                                                 | 1890                                                                                                                                                                                                                         | 1891                                                                                                                                                                                         | 1892                                                                                                                                                                                                         | 1893                                                                                                                                                                                                                 | 1894                                                                                                                                                                                                         | 1895                                                                                                                                                                                                                                                 | 1896                                                                                                                                                                                                                  | 1897                                                                                                                                                                                                         | 1898                                                                                                                                                                                                                                                                  | 1899                                                                                                                                                                                                         | 1900                                                                                                                                                                                                         | 1901                                                                                                                                                                                                                         | 1902                                                                                                                                                                                                                 | 1903                                                                                                                                                                                                                 |
| 78_                                                                                                                                                                                        | 1904<br>1920                                                                                                                                                                                                 | 1905<br>1921                                                                                                                                                                                                                         | 1906<br>1922                                                                                                                                                                                                                 | 1907<br>1923                                                                                                                                                                                 | 1908<br>1924                                                                                                                                                                                                 | 1909<br>1925                                                                                                                                                                                                         | 1910<br>19 <b>26</b>                                                                                                                                                                                         | 1911<br>1927                                                                                                                                                                                                                                         | 1912<br>1928                                                                                                                                                                                                          | 1913<br>19 <b>2</b> 9                                                                                                                                                                                        | 1914<br>1930                                                                                                                                                                                                                                                          | 1915<br>1931                                                                                                                                                                                                 | 1916<br>1932                                                                                                                                                                                                 | 1917<br>1933                                                                                                                                                                                                                 | 1918<br>1934                                                                                                                                                                                                         | 1919<br>1935                                                                                                                                                                                                         |
| 79_                                                                                                                                                                                        | 1936                                                                                                                                                                                                         | 1937                                                                                                                                                                                                                                 | 1938                                                                                                                                                                                                                         | 1939                                                                                                                                                                                         | 1940                                                                                                                                                                                                         | 1941                                                                                                                                                                                                                 | 1942                                                                                                                                                                                                         | 1943                                                                                                                                                                                                                                                 | 1920                                                                                                                                                                                                                  | 1945                                                                                                                                                                                                         | 1946                                                                                                                                                                                                                                                                  | 1947                                                                                                                                                                                                         | 1948                                                                                                                                                                                                         | 1949                                                                                                                                                                                                                         | 1950                                                                                                                                                                                                                 | 1951                                                                                                                                                                                                                 |
| 7A_<br>7B_                                                                                                                                                                                 | 1952                                                                                                                                                                                                         | 1953                                                                                                                                                                                                                                 | 1954                                                                                                                                                                                                                         | 1955                                                                                                                                                                                         | 1956                                                                                                                                                                                                         | 1957                                                                                                                                                                                                                 | 1958                                                                                                                                                                                                         | 1959                                                                                                                                                                                                                                                 | 1960                                                                                                                                                                                                                  | 1961                                                                                                                                                                                                         | 1962                                                                                                                                                                                                                                                                  | 1963                                                                                                                                                                                                         | 1964<br>1980                                                                                                                                                                                                 | 1965<br>1981                                                                                                                                                                                                                 | 1966<br>1982                                                                                                                                                                                                         | 1967                                                                                                                                                                                                                 |
| 7C_                                                                                                                                                                                        | 1968<br>1984                                                                                                                                                                                                 | 1969<br>1985                                                                                                                                                                                                                         | 1970<br>1986                                                                                                                                                                                                                 | 1971<br>1987                                                                                                                                                                                 | 1972<br>1988                                                                                                                                                                                                 | 1973<br>1989                                                                                                                                                                                                         | 1974<br>1990                                                                                                                                                                                                 | 1975<br>1991                                                                                                                                                                                                                                         | 1976<br>1992                                                                                                                                                                                                          | 1977<br>1993                                                                                                                                                                                                 | 1978<br>1994                                                                                                                                                                                                                                                          | 1979<br>1995                                                                                                                                                                                                 | 1980                                                                                                                                                                                                         | 1901                                                                                                                                                                                                                         | 1982                                                                                                                                                                                                                 | 1983<br>1999                                                                                                                                                                                                         |
| 7D_                                                                                                                                                                                        | 2000                                                                                                                                                                                                         | 2001                                                                                                                                                                                                                                 | 2002                                                                                                                                                                                                                         | 2003                                                                                                                                                                                         | 2004                                                                                                                                                                                                         | 2005                                                                                                                                                                                                                 | 2006                                                                                                                                                                                                         | 2007                                                                                                                                                                                                                                                 | 2008                                                                                                                                                                                                                  | 2009                                                                                                                                                                                                         | 2010                                                                                                                                                                                                                                                                  | 2011                                                                                                                                                                                                         | 2012                                                                                                                                                                                                         | 2013                                                                                                                                                                                                                         | 2014                                                                                                                                                                                                                 | 2015                                                                                                                                                                                                                 |
| 7E_<br>7F_                                                                                                                                                                                 | 2016<br>2032                                                                                                                                                                                                 | 2017<br>2033                                                                                                                                                                                                                         | 2018<br>2034                                                                                                                                                                                                                 | 2019<br>2035                                                                                                                                                                                 | 2020<br>2036                                                                                                                                                                                                 | 2021<br>2037                                                                                                                                                                                                         | 2022<br>2038                                                                                                                                                                                                 | 2023<br>2039                                                                                                                                                                                                                                         | 2024<br>2040                                                                                                                                                                                                          | 2025<br>2041                                                                                                                                                                                                 | 2026<br>2042                                                                                                                                                                                                                                                          | 2027<br>2043                                                                                                                                                                                                 | 2028<br>2044                                                                                                                                                                                                 | 2029<br>2045                                                                                                                                                                                                                 | 2030<br>2046                                                                                                                                                                                                         | 2031<br>2047                                                                                                                                                                                                         |
|                                                                                                                                                                                            | 0                                                                                                                                                                                                            | 1                                                                                                                                                                                                                                    | 2                                                                                                                                                                                                                            | 3                                                                                                                                                                                            | 4                                                                                                                                                                                                            | 5                                                                                                                                                                                                                    | 6                                                                                                                                                                                                            | 7                                                                                                                                                                                                                                                    | 8                                                                                                                                                                                                                     | 9                                                                                                                                                                                                            | A                                                                                                                                                                                                                                                                     | B                                                                                                                                                                                                            |                                                                                                                                                                                                              | D                                                                                                                                                                                                                            | E                                                                                                                                                                                                                    | F                                                                                                                                                                                                                    |
| 80_                                                                                                                                                                                        | 0040                                                                                                                                                                                                         |                                                                                                                                                                                                                                      |                                                                                                                                                                                                                              |                                                                                                                                                                                              |                                                                                                                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                       |                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                              |                                                                                                                                                                                                              |                                                                                                                                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                                                                                                                      |
| 81_                                                                                                                                                                                        | 2048                                                                                                                                                                                                         | 2049                                                                                                                                                                                                                                 | 2050                                                                                                                                                                                                                         | 2051                                                                                                                                                                                         | 2052                                                                                                                                                                                                         | 2053                                                                                                                                                                                                                 | 2054                                                                                                                                                                                                         | 2055                                                                                                                                                                                                                                                 | 2056                                                                                                                                                                                                                  | 2057                                                                                                                                                                                                         | 2058                                                                                                                                                                                                                                                                  | 2059                                                                                                                                                                                                         | 2060                                                                                                                                                                                                         | 2061                                                                                                                                                                                                                         | 2062                                                                                                                                                                                                                 | 2063                                                                                                                                                                                                                 |
|                                                                                                                                                                                            | 2064                                                                                                                                                                                                         | 2065                                                                                                                                                                                                                                 | 2066                                                                                                                                                                                                                         | 2067                                                                                                                                                                                         | 2068                                                                                                                                                                                                         | 2069                                                                                                                                                                                                                 | 2070                                                                                                                                                                                                         | 2071                                                                                                                                                                                                                                                 | 2072                                                                                                                                                                                                                  | 2073                                                                                                                                                                                                         | 2074                                                                                                                                                                                                                                                                  | 2075                                                                                                                                                                                                         | 2076                                                                                                                                                                                                         | 2077                                                                                                                                                                                                                         | 2078                                                                                                                                                                                                                 | 2079                                                                                                                                                                                                                 |
| 82                                                                                                                                                                                         | 2064<br>2080                                                                                                                                                                                                 | 2065<br>2081                                                                                                                                                                                                                         | 2066<br>2082                                                                                                                                                                                                                 | 2067<br>2083                                                                                                                                                                                 | 2068<br>2084                                                                                                                                                                                                 | 2069<br>2085                                                                                                                                                                                                         | 2070<br>2086                                                                                                                                                                                                 | 2071<br>2087                                                                                                                                                                                                                                         | 2072<br>2088                                                                                                                                                                                                          | 2073<br>2089                                                                                                                                                                                                 | 2074<br>2090                                                                                                                                                                                                                                                          | 2075<br>2091                                                                                                                                                                                                 | 2076<br>2092                                                                                                                                                                                                 |                                                                                                                                                                                                                              |                                                                                                                                                                                                                      | 2079<br>2095                                                                                                                                                                                                         |
| 82<br>83                                                                                                                                                                                   | 2064                                                                                                                                                                                                         | 2065                                                                                                                                                                                                                                 | 2066                                                                                                                                                                                                                         | 2067                                                                                                                                                                                         | 2068                                                                                                                                                                                                         | 2069<br>2085<br>2101<br>2117                                                                                                                                                                                         | 2070                                                                                                                                                                                                         | 2071                                                                                                                                                                                                                                                 | 2072                                                                                                                                                                                                                  | 2073                                                                                                                                                                                                         | 2074                                                                                                                                                                                                                                                                  | 2075                                                                                                                                                                                                         | 2076                                                                                                                                                                                                         | 2077<br>2093                                                                                                                                                                                                                 | 2078<br>2094<br>2110<br>2126                                                                                                                                                                                         | 2079<br>2095<br>2111<br>2127                                                                                                                                                                                         |
| 82<br>83<br>84<br>85_                                                                                                                                                                      | 2064<br>2080<br>2096<br>2112<br>2128                                                                                                                                                                         | 2065<br>2081<br>2097<br>2113<br>2129                                                                                                                                                                                                 | 2066<br>2082<br>2098<br>2114<br>2130                                                                                                                                                                                         | 2067<br>2083<br>2099<br>2115<br>2131                                                                                                                                                         | 2068<br>2084<br>2100<br>2116<br>2132                                                                                                                                                                         | 2069<br>2085<br>2101<br>2117<br>2133                                                                                                                                                                                 | 2070<br>2086<br>2102<br>2118<br>2134                                                                                                                                                                         | 2071<br>2087<br>2103<br>2119<br>2135                                                                                                                                                                                                                 | 2072<br>2088<br>2104<br>2120<br>2136                                                                                                                                                                                  | 2073<br>2089<br>2105<br>2121<br>2137                                                                                                                                                                         | 2074<br>2090<br>2106<br>2122<br>2138                                                                                                                                                                                                                                  | 2075<br>2091<br>2107<br>2123<br>2139                                                                                                                                                                         | 2076<br>2092<br>2108<br>2124<br>2140                                                                                                                                                                         | 2077<br>2093<br>2109<br>2125<br>2141                                                                                                                                                                                         | 2078<br>2094<br>2110<br>2126<br>2142                                                                                                                                                                                 | 2079<br>2095<br>2111<br>2127<br>2143                                                                                                                                                                                 |
| 82<br>83<br>84<br>85_<br>86                                                                                                                                                                | 2064<br>2080<br>2096<br>2112                                                                                                                                                                                 | 2065<br>2081<br>2097<br>2113                                                                                                                                                                                                         | 2066<br>2082<br>2098<br>2114                                                                                                                                                                                                 | 2067<br>2083<br>2099<br>2115                                                                                                                                                                 | 2068<br>2084<br>2100<br>2116                                                                                                                                                                                 | 2069<br>2085<br>2101<br>2117                                                                                                                                                                                         | 2070<br>2086<br>2102<br>2118                                                                                                                                                                                 | 2071<br>2087<br>2103<br>2119                                                                                                                                                                                                                         | 2072<br>2088<br>2104<br>2120                                                                                                                                                                                          | 2073<br>2089<br>2105<br>2121                                                                                                                                                                                 | 2074<br>2090<br>2106<br>2122                                                                                                                                                                                                                                          | 2075<br>2091<br>2107<br>2123                                                                                                                                                                                 | 2076<br>2092<br>2108<br>2124                                                                                                                                                                                 | 2077<br>2093<br>2109<br>2125                                                                                                                                                                                                 | 2078<br>2094<br>2110<br>2126                                                                                                                                                                                         | 2079<br>2095<br>2111<br>2127                                                                                                                                                                                         |
| 82_<br>83_<br>84_<br>85_<br>86_<br>87_<br>88_                                                                                                                                              | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176                                                                                                                                                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177                                                                                                                                                                         | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178                                                                                                                                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179                                                                                                                                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180                                                                                                                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181                                                                                                                                                         | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182                                                                                                                                                 | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183                                                                                                                                                                                         | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2184                                                                                                                                                          | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185                                                                                                                                                 | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186                                                                                                                                                                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187                                                                                                                                                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188                                                                                                                                                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189                                                                                                                                                                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190                                                                                                                                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191                                                                                                                                                         |
| 82<br>83<br>85_<br>85_<br>86_<br>87_<br>88_<br>88_                                                                                                                                         | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192                                                                                                                                         | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193                                                                                                                                                                 | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2194                                                                                                                                                         | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2195                                                                                                                         | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180<br>2196                                                                                                                                         | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197                                                                                                                                                 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198                                                                                                                                         | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2199                                                                                                                                                                                 | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2184<br>2200                                                                                                                                                  | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201                                                                                                                                         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202                                                                                                                                                                                                  | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203                                                                                                                                         | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2204                                                                                                                                         | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205                                                                                                                                                         | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206                                                                                                                                                 | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207                                                                                                                                                 |
| 82<br>83<br>84<br>85<br>86<br>87<br>88<br>88<br>88<br>8A                                                                                                                                   | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176                                                                                                                                                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177                                                                                                                                                                         | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178                                                                                                                                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179                                                                                                                                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180                                                                                                                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181                                                                                                                                                         | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182                                                                                                                                                 | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183                                                                                                                                                                                         | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2184                                                                                                                                                          | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185                                                                                                                                                 | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186                                                                                                                                                                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187                                                                                                                                                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188                                                                                                                                                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189                                                                                                                                                                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190                                                                                                                                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191                                                                                                                                                         |
| 82_<br>83_<br>85_<br>85_<br>86_<br>87_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_                                                                                             | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2224                                                                                                                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241                                                                                                                                         | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2194<br>2210<br>2226<br>2242                                                                                                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2195<br>2211<br>2227<br>2243                                                                                                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180<br>2196<br>2212<br>2228<br>2244                                                                                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245                                                                                                                         | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246                                                                                                                 | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2199<br>2215<br>2231<br>2247                                                                                                                                                         | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2184<br>2200<br>2216<br>2232<br>2248                                                                                                                          | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249                                                                                                                 | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2202<br>2218<br>2234<br>2250                                                                                                                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251                                                                                                                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2204<br>2220<br>2236<br>2252                                                                                                                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253                                                                                                                                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254                                                                                                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207<br>2223<br>2239<br>2255                                                                                                                         |
| 82_<br>83_<br>85_<br>85_<br>86_<br>87_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_                                                                                             | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2224<br>2224<br>2240<br>2256                                                                                         | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257                                                                                                                                 | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2194<br>2210<br>2226<br>2242<br>2258                                                                                                                         | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2195<br>2211<br>2227<br>2243<br>2259                                                                                         | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180<br>2196<br>2212<br>2228<br>2244<br>2260                                                                                                         | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261                                                                                                                 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246<br>2262                                                                                                         | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2199<br>2215<br>2231<br>2247<br>2263                                                                                                                                                 | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2184<br>2200<br>2216<br>2232<br>2248<br>2264                                                                                                                  | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265                                                                                                         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2234<br>2250<br>2266                                                                                                                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251<br>2267                                                                                                         | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2204<br>2220<br>2236<br>2252<br>2268                                                                                                         | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269                                                                                                                         | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254<br>2254<br>2270                                                                                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207<br>2223<br>2239<br>2255<br>2271                                                                                                                 |
| 82_<br>83<br>84_<br>85_<br>86_<br>87_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88                                                                                        | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2224                                                                                                                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241                                                                                                                                         | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2194<br>2210<br>2226<br>2242                                                                                                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2195<br>2211<br>2227<br>2243                                                                                                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180<br>2196<br>2212<br>2228<br>2244                                                                                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245                                                                                                                         | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246                                                                                                                 | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2199<br>2215<br>2231<br>2247                                                                                                                                                         | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2184<br>2200<br>2216<br>2232<br>2248                                                                                                                          | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249                                                                                                                 | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2202<br>2218<br>2234<br>2250                                                                                                                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251                                                                                                                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2204<br>2220<br>2236<br>2252                                                                                                                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253                                                                                                                                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254                                                                                                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207<br>2223<br>2239<br>2255                                                                                                                         |
| 82_<br>83_<br>84_<br>85_<br>86_<br>87_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88                                                                                       | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2220<br>2226<br>2272                                                                                                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273                                                                                                                         | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2194<br>2210<br>2226<br>2242<br>2258<br>2274                                                                                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2219<br>2221<br>2227<br>2243<br>2259<br>2275                                                                                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180<br>2196<br>2212<br>2228<br>2224<br>2228<br>2244<br>2260<br>2276                                                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261<br>2277                                                                                                         | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246<br>2262<br>2278                                                                                                 | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2199<br>2215<br>2231<br>2247<br>2263<br>2279                                                                                                                                         | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2184<br>2200<br>2216<br>2232<br>2248<br>2264<br>2280                                                                                                          | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281                                                                                                 | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2266<br>2282                                                                                                                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283                                                                                                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2204<br>2236<br>2252<br>2268<br>2268<br>2284                                                                                                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285                                                                                                                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2290<br>2222<br>2238<br>2254<br>2270<br>2286                                                                                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2197<br>2207<br>2223<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319                                                                                         |
| 82                                                                                                                                                                                         | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2220<br>2256<br>2272<br>2288<br>2304<br>2320                                                                         | 2065<br>2081<br>2097<br>2113<br>2145<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2289<br>2305<br>2321                                                                                                 | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2194<br>2210<br>2226<br>22258<br>2274<br>2290<br>2306<br>2322                                                                                                | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2195<br>2211<br>2227<br>2243<br>2259<br>2275<br>2291<br>2307<br>2323                                                         | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2196<br>2212<br>2228<br>2244<br>2260<br>2276<br>2292<br>2308<br>2324                                                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261<br>2277<br>2293<br>2277<br>2293<br>2309<br>2325                                                                 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246<br>2262<br>2278<br>2294<br>2310<br>2326                                                                         | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2199<br>2215<br>2231<br>2247<br>2263<br>2279<br>2295<br>2311<br>2327                                                                                                                 | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2152<br>2168<br>2232<br>2248<br>2264<br>2280<br>2296<br>2296<br>2312<br>2328                                                                                  | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329                                                                         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2266<br>2282<br>2298<br>2298<br>2314<br>2330                                                                                                                          | 2075<br>2091<br>2107<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283<br>2299<br>2315<br>2331                                                                                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2204<br>2236<br>2252<br>2268<br>2284<br>2284<br>2300<br>2316<br>2332                                                                         | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333                                                                                         | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254<br>2270<br>2286<br>2302<br>2318<br>2334                                                                                 | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207<br>2223<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319<br>2335                                                                                 |
| 82                                                                                                                                                                                         | 2064<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2208<br>2224<br>2256<br>2272<br>2288<br>2304<br>2336                                                                         | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2283<br>2289<br>2305<br>2321<br>2337                                                                                 | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2190<br>2226<br>2242<br>2258<br>2274<br>2290<br>2306<br>2322<br>2338                                                                                         | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2195<br>2211<br>2227<br>2243<br>2259<br>2275<br>2291<br>2307<br>2323<br>2339                                                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180<br>2196<br>2212<br>2228<br>2244<br>2260<br>2276<br>2292<br>2308<br>2324<br>2340                                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261<br>2277<br>2293<br>2309<br>2325<br>2341                                                                         | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246<br>2262<br>2278<br>2294<br>2310<br>2326<br>2342                                                                 | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2199<br>2215<br>2231<br>2247<br>2263<br>2279<br>2295<br>2311<br>2327<br>2343                                                                                                         | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2152<br>2168<br>2216<br>2232<br>2248<br>2264<br>2280<br>2290<br>2290<br>2212<br>2328<br>2324                                                                  | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345                                                                 | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2266<br>2282<br>2298<br>2314<br>2330<br>2346                                                                                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283<br>2299<br>2315<br>2331<br>2347                                                                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2200<br>2236<br>2252<br>2268<br>2284<br>2300<br>2316<br>2332<br>2348                                                                         | 2077<br>2093<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349                                                                                         | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254<br>2270<br>2286<br>2306<br>2318<br>2334<br>2350                                                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207<br>2223<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319<br>2335<br>2351                                                                         |
| 82                                                                                                                                                                                         | 2064<br>2080<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2220<br>2256<br>2272<br>2288<br>2304<br>2320                                                                         | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2283<br>2305<br>2321<br>2337<br>2353                                                                                 | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2190<br>2226<br>2242<br>2258<br>2274<br>2290<br>2306<br>2322<br>2338<br>2354                                                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2195<br>2211<br>2227<br>2243<br>2259<br>2275<br>2291<br>2307<br>2323<br>2339<br>2355                                         | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180<br>2196<br>2212<br>2228<br>2244<br>2260<br>2276<br>2276<br>2292<br>2308<br>2324<br>2340<br>2356                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261<br>2277<br>2293<br>2309<br>2325<br>2341<br>2357                                                                 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246<br>2262<br>2278<br>2294<br>2310<br>2326<br>2342<br>2358                                                         | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2199<br>2215<br>2231<br>2247<br>2263<br>2279<br>2295<br>2311<br>2327<br>2343<br>2359                                                                                                 | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2152<br>2168<br>2216<br>2232<br>2248<br>2264<br>2290<br>2290<br>2290<br>2290<br>2292<br>2328<br>2344<br>2360                                                  | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345<br>2345                                                         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2266<br>2282<br>2298<br>2314<br>2330<br>2346<br>2346<br>2346                                                                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283<br>2299<br>2315<br>2331<br>2347<br>2363                                                         | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2204<br>2236<br>2252<br>2268<br>2284<br>2300<br>2316<br>2332<br>2348<br>2348                                                                 | 2077<br>2093<br>2105<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349<br>2365                                                                                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254<br>2270<br>2286<br>2302<br>2302<br>2318<br>2334<br>2350<br>2366                                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207<br>2223<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319<br>2335<br>2351<br>2367                                                                 |
| 82_<br>83_<br>85_<br>85_<br>85_<br>86_<br>87_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88_<br>88                                                                                              | 2064<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2240<br>2250<br>2272<br>2288<br>2304<br>2320<br>2336<br>2336<br>2336<br>2336                                                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2289<br>2305<br>2321<br>2337<br>2353<br>2369<br>2385                                                                 | 2066<br>2082<br>2082<br>2114<br>2130<br>2146<br>2162<br>2174<br>2210<br>2226<br>2242<br>2258<br>2274<br>2290<br>2306<br>2322<br>2338<br>2354<br>2370<br>2386                                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2195<br>2211<br>2227<br>2243<br>2259<br>2275<br>2291<br>2307<br>2323<br>2355<br>2355<br>2371<br>2387                                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2196<br>2212<br>2228<br>2244<br>2260<br>2276<br>2292<br>2308<br>2324<br>2340<br>2356<br>2372<br>2388                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261<br>2277<br>2293<br>2309<br>2325<br>2309<br>2325<br>2341<br>2357<br>2373<br>2389                                 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2298<br>2214<br>2230<br>2246<br>2262<br>2278<br>2294<br>2310<br>2326<br>2326<br>2328<br>2374<br>2390                                         | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2187<br>2299<br>2215<br>2231<br>2247<br>2263<br>2279<br>2295<br>2311<br>2327<br>2343<br>2359<br>2375<br>2391                                                                                 | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2216<br>2232<br>2248<br>2280<br>2296<br>2312<br>2328<br>2348<br>2348<br>2348<br>2346<br>2396<br>2376<br>2392                                                  | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345<br>2361<br>2377<br>2393                                         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2260<br>2282<br>2298<br>2314<br>2330<br>2346<br>2346<br>2378<br>2394                                                                                                  | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283<br>2299<br>2315<br>2331<br>2347<br>2347<br>2347<br>2395                                                 | 2076<br>2092<br>2108<br>2124<br>2124<br>2156<br>2172<br>2186<br>2200<br>2236<br>2252<br>2268<br>2284<br>2300<br>2316<br>2332<br>2348<br>2348<br>2364<br>2396                                                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349<br>2365<br>2381<br>2397                                                         | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254<br>2270<br>2286<br>2302<br>2318<br>2334<br>2350<br>2366<br>2382<br>2398                                                 | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2197<br>2207<br>2223<br>2239<br>2255<br>2271<br>2303<br>2319<br>2335<br>2351<br>2367<br>2383<br>2399                                                         |
| 82                                                                                                                                                                                         | 2064<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2240<br>2256<br>2272<br>2288<br>2304<br>2336<br>2336<br>2352<br>2368<br>2352                                                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2257<br>2257<br>2257<br>2289<br>2305<br>2321<br>2337<br>2353<br>2365<br>2365<br>2401                                         | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2216<br>2210<br>2226<br>2242<br>2258<br>2274<br>2290<br>2306<br>2322<br>2338<br>2354<br>2354<br>2356<br>2402                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2179<br>2219<br>2211<br>2227<br>2243<br>2279<br>2275<br>2291<br>2307<br>2323<br>2339<br>2355<br>2371<br>2387<br>2403                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2180<br>2212<br>2228<br>2244<br>2260<br>2276<br>2292<br>2308<br>2324<br>2340<br>2356<br>2356<br>2358<br>2324                                         | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2213<br>2229<br>2245<br>2261<br>2271<br>2293<br>2309<br>2325<br>2341<br>2357<br>2339<br>2325<br>2341                                                 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246<br>2262<br>2278<br>2294<br>2310<br>2326<br>2342<br>2358<br>2374<br>2358<br>2374<br>2390<br>2406                 | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2187<br>2183<br>2199<br>2215<br>2231<br>2247<br>2263<br>2279<br>2295<br>2311<br>2327<br>2343<br>2359<br>2375<br>2391<br>2407                                                                         | 2072<br>2088<br>2104<br>2136<br>2152<br>2168<br>2152<br>2168<br>2216<br>2232<br>2248<br>2264<br>2280<br>2296<br>2312<br>2328<br>2344<br>2360<br>2376<br>2392<br>2344                                                  | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345<br>2345<br>2361<br>2373<br>2393<br>2409                         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2266<br>2282<br>2298<br>2314<br>2330<br>2346<br>2346<br>2352<br>2374<br>2374<br>2374                                                                                  | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2287<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283<br>2299<br>2315<br>2331<br>2347<br>2363<br>2395<br>2395<br>2411                                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2200<br>2236<br>2252<br>2268<br>2284<br>2300<br>2316<br>2332<br>2348<br>2348<br>2348<br>2396<br>2396<br>2412                                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349<br>2365<br>2381<br>2397<br>2413                                                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254<br>2270<br>2280<br>2302<br>2318<br>2334<br>2350<br>2366<br>2382<br>2398<br>2398<br>2398<br>2414                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207<br>2223<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319<br>2335<br>2351<br>2367<br>2383<br>2399<br>2415                                         |
| 82_<br>83_<br>84_<br>85_<br>886_<br>887_<br>888_<br>888_<br>888_<br>888_<br>888_<br>90_<br>991_<br>991_<br>993_<br>993_<br>994_<br>995_<br>994_<br>995_<br>998_                            | 2064<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2240<br>2250<br>2272<br>2288<br>2304<br>2320<br>2336<br>2336<br>2336<br>2336                                                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2289<br>2305<br>2321<br>2337<br>2353<br>2369<br>2385                                                                 | 2066<br>2082<br>2082<br>2114<br>2130<br>2146<br>2162<br>2174<br>2210<br>2226<br>2242<br>2258<br>2274<br>2290<br>2306<br>2322<br>2338<br>2354<br>2370<br>2386                                                                 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2195<br>2211<br>2227<br>2243<br>2259<br>2275<br>2291<br>2307<br>2323<br>2355<br>2355<br>2371<br>2387                                 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2196<br>2212<br>2228<br>2244<br>2260<br>2276<br>2292<br>2308<br>2324<br>2340<br>2356<br>2372<br>2388                                                 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261<br>2277<br>2293<br>2309<br>2325<br>2309<br>2325<br>2341<br>2357<br>2373<br>2389                                 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2298<br>2214<br>2230<br>2246<br>2262<br>2278<br>2294<br>2310<br>2326<br>2326<br>2328<br>2374<br>2390                                         | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2187<br>2299<br>2215<br>2231<br>2247<br>2263<br>2279<br>2295<br>2311<br>2327<br>2343<br>2359<br>2375<br>2391                                                                                 | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2216<br>2232<br>2248<br>2280<br>2296<br>2312<br>2328<br>2348<br>2348<br>2348<br>2346<br>2396<br>2376<br>2392                                                  | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345<br>2361<br>2377<br>2393                                         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2260<br>2282<br>2298<br>2314<br>2330<br>2346<br>2346<br>2378<br>2394                                                                                                  | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283<br>2299<br>2315<br>2331<br>2347<br>2347<br>2347<br>2395                                                 | 2076<br>2092<br>2108<br>2124<br>2124<br>2156<br>2172<br>2186<br>2200<br>2236<br>2252<br>2268<br>2284<br>2300<br>2316<br>2332<br>2348<br>2348<br>2364<br>2396                                                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349<br>2365<br>2381<br>2397                                                         | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254<br>2270<br>2286<br>2302<br>2318<br>2334<br>2350<br>2366<br>2382<br>2398                                                 | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2197<br>2207<br>2223<br>2239<br>2255<br>2271<br>2303<br>2319<br>2335<br>2351<br>2367<br>2383<br>2399                                                         |
| 82                                                                                                                                                                                         | 2064<br>2096<br>2112<br>2128<br>2144<br>2160<br>2172<br>2208<br>2224<br>2208<br>2224<br>2240<br>2256<br>2272<br>2288<br>2304<br>2320<br>2336<br>2352<br>2368<br>2352<br>2368<br>2354<br>2448                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2289<br>2305<br>2321<br>2337<br>2353<br>2385<br>2419<br>2385<br>2449                                                 | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2162<br>22178<br>2216<br>2226<br>2228<br>2274<br>2290<br>2306<br>2322<br>2338<br>2354<br>2370<br>2386<br>2402<br>2418<br>2434<br>2450                        | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2195<br>2211<br>2227<br>2243<br>2259<br>2275<br>2291<br>2307<br>2323<br>2355<br>2371<br>2387<br>2403<br>2419                         | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2164<br>2164<br>2212<br>2228<br>2224<br>2228<br>2224<br>2260<br>2276<br>2292<br>2308<br>2324<br>2340<br>2356<br>2372<br>2388<br>2404<br>2436<br>2452 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2293<br>2229<br>2245<br>2261<br>2277<br>2293<br>2305<br>2325<br>2341<br>2357<br>2373<br>2389<br>2405<br>2421<br>2437                         | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>22198<br>2294<br>2230<br>2246<br>2262<br>2278<br>2294<br>2310<br>2326<br>2342<br>2358<br>2374<br>2390<br>2446<br>2454                | 2071<br>2087<br>2103<br>2135<br>2151<br>2167<br>2183<br>2195<br>2215<br>2231<br>2247<br>2263<br>2279<br>2295<br>2311<br>2327<br>2343<br>2359<br>2375<br>2391<br>2432<br>2439<br>2425                                                                 | 2072<br>2088<br>2104<br>2136<br>2152<br>2168<br>2152<br>22168<br>2216<br>2232<br>2248<br>2264<br>2230<br>2296<br>2312<br>2328<br>2344<br>2360<br>2376<br>2392<br>2408<br>2424<br>2440<br>2456                         | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2220<br>2266<br>2282<br>2298<br>2314<br>2346<br>2346<br>2346<br>2346<br>2346<br>2346<br>2346<br>234                                                                           | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283<br>2299<br>2315<br>2347<br>2363<br>2347<br>2345<br>2347<br>2395<br>2411<br>2427<br>2443<br>2459 | 2076<br>2092<br>2108<br>2128<br>2140<br>2156<br>2172<br>2188<br>2200<br>2236<br>2252<br>2268<br>2284<br>2300<br>2316<br>2332<br>2348<br>2348<br>2364<br>2396<br>2412<br>2428<br>2444<br>2460                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349<br>2365<br>2381<br>2397<br>2413<br>2445<br>2461                                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2206<br>2202<br>2238<br>2254<br>2270<br>2286<br>2302<br>2318<br>2334<br>2350<br>2366<br>2382<br>2398<br>2414<br>2462                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2207<br>2223<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319<br>2335<br>2351<br>2367<br>2383<br>2399<br>2415<br>2447<br>2463                                 |
| 82                                                                                                                                                                                         | 2064<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2240<br>2256<br>2272<br>2288<br>2304<br>2336<br>2336<br>2352<br>2368<br>2352<br>2368<br>2384<br>2400<br>2416<br>2448         | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2289<br>2305<br>2321<br>2337<br>2353<br>2369<br>2385<br>2401<br>2417<br>2433<br>2449                                 | 2066<br>2082<br>2082<br>2114<br>2130<br>2146<br>2162<br>2178<br>2210<br>2226<br>2242<br>2258<br>2274<br>2290<br>2306<br>2322<br>2338<br>2354<br>2370<br>2386<br>2402<br>2418<br>2434<br>2450<br>2466                         | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2195<br>2211<br>2227<br>2243<br>2275<br>2291<br>2307<br>2323<br>2339<br>2355<br>2371<br>2387<br>2403<br>2419<br>2435<br>2451<br>2467 | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2196<br>2212<br>2228<br>2244<br>2260<br>2276<br>2292<br>2308<br>2324<br>2340<br>2356<br>2372<br>2388<br>2404<br>2420<br>2428                         | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261<br>2277<br>2293<br>2309<br>2325<br>2341<br>2377<br>2389<br>2405<br>2405<br>2421<br>2433<br>2469                 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246<br>2267<br>2278<br>2294<br>2310<br>2326<br>2342<br>2342<br>2342<br>2342<br>2342<br>2342<br>2342                 | 2071<br>2087<br>21087<br>2135<br>2151<br>2151<br>2167<br>2283<br>2295<br>2231<br>2247<br>2263<br>2295<br>2311<br>2327<br>2343<br>2359<br>2391<br>2407<br>2491<br>2407<br>2423<br>2495<br>2471                                                        | 2072<br>2088<br>2104<br>2120<br>2136<br>2152<br>2168<br>2216<br>2232<br>2248<br>2264<br>2280<br>2296<br>2312<br>2328<br>2344<br>2360<br>2376<br>2392<br>2408<br>2424<br>2424<br>2424<br>24256<br>2472                 | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345<br>2361<br>2377<br>2393<br>2409<br>2425<br>2425<br>2425<br>2473 | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2262<br>2298<br>2298<br>2314<br>2330<br>2346<br>2382<br>2394<br>2394<br>2394<br>2410<br>2426<br>2425<br>2426                                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2203<br>2219<br>2235<br>2251<br>2265<br>2283<br>2299<br>2315<br>2331<br>2347<br>2367<br>2395<br>2411<br>2427<br>2443<br>2459<br>2475                 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2200<br>2236<br>2252<br>2268<br>2252<br>2268<br>2264<br>2300<br>2316<br>2332<br>2348<br>2348<br>2348<br>2396<br>2412<br>2428<br>2442<br>2428 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349<br>2365<br>2381<br>2397<br>2413<br>2429<br>2445<br>2461<br>2477                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2206<br>2222<br>2238<br>2254<br>2270<br>2286<br>2302<br>2318<br>2334<br>2350<br>2362<br>2398<br>2398<br>2414<br>2430<br>2442<br>2438                 | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2207<br>2223<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319<br>2335<br>2351<br>2367<br>2389<br>2415<br>2431<br>2447<br>2463<br>2479                         |
| 82_<br>883_<br>884_<br>885_<br>886_<br>887_<br>888_<br>888_<br>888_<br>888_<br>901_<br>991_<br>992_<br>993_<br>994_<br>995_<br>994_<br>998_<br>998_<br>998_<br>998_<br>998_<br>998_<br>998 | 2064<br>2096<br>2112<br>2128<br>2144<br>2160<br>2172<br>2208<br>2224<br>2208<br>2224<br>2240<br>2256<br>2272<br>2288<br>2304<br>2320<br>2336<br>2352<br>2368<br>2352<br>2368<br>2354<br>2448                 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2289<br>2305<br>2321<br>2337<br>2353<br>2385<br>2385<br>2385<br>2401<br>2417<br>2433<br>2449<br>2465<br>2481<br>2497 | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2190<br>2226<br>2242<br>2258<br>2274<br>2290<br>2306<br>2322<br>2338<br>2354<br>2370<br>2386<br>2322<br>2418<br>2402<br>2418<br>2434<br>2450<br>2482<br>2498 | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2195<br>2211<br>2227<br>2243<br>2259<br>2275<br>2291<br>2307<br>2323<br>2355<br>2371<br>2387<br>2403<br>2419                         | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2164<br>2164<br>2212<br>2228<br>2224<br>2228<br>2224<br>2260<br>2276<br>2292<br>2308<br>2324<br>2340<br>2356<br>2372<br>2388<br>2404<br>2436<br>2452 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2293<br>2229<br>2245<br>2261<br>2277<br>2293<br>2305<br>2325<br>2341<br>2357<br>2373<br>2389<br>2405<br>2421<br>2437                         | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>22198<br>2294<br>2230<br>2246<br>2262<br>2278<br>2294<br>2310<br>2326<br>2342<br>2358<br>2374<br>2390<br>2446<br>2454                | 2071<br>2087<br>2103<br>2119<br>2135<br>2151<br>2167<br>2183<br>2197<br>2215<br>2231<br>2247<br>2263<br>2295<br>2311<br>2327<br>2343<br>2359<br>2375<br>2395<br>2375<br>2395<br>2375<br>2395<br>2375<br>2395<br>2407<br>2423<br>2439<br>2455<br>2439 | 2072<br>2088<br>2104<br>2136<br>2152<br>2168<br>2152<br>22168<br>2216<br>2232<br>2248<br>2264<br>2230<br>2296<br>2312<br>2328<br>2344<br>2360<br>2376<br>2392<br>2408<br>2424<br>2440<br>2456                         | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>22018<br>2218<br>2234<br>2250<br>2266<br>2282<br>2298<br>2314<br>2330<br>2346<br>2362<br>2378<br>2398<br>2314<br>2362<br>2378<br>2378<br>2378<br>2410<br>2426<br>2442<br>2458<br>2440<br>2490<br>2506 | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2187<br>2203<br>2219<br>2235<br>2251<br>2267<br>2283<br>2299<br>2315<br>2347<br>2363<br>2347<br>2345<br>2347<br>2395<br>2411<br>2427<br>2443<br>2459 | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2200<br>2236<br>2252<br>2268<br>2284<br>2300<br>2316<br>2332<br>2348<br>2348<br>2364<br>2396<br>2412<br>2428<br>2444<br>2460                 | 2077<br>2093<br>2109<br>2125<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349<br>2365<br>2381<br>2397<br>2413<br>2429<br>2445<br>2461<br>2473<br>2493<br>2509 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2206<br>2202<br>2238<br>2254<br>2270<br>2286<br>2302<br>2318<br>2334<br>2350<br>2366<br>2382<br>2398<br>2414<br>2462                                         | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2203<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319<br>2335<br>2351<br>2367<br>2383<br>2399<br>2415<br>2431<br>2447<br>2463<br>2479<br>2495<br>2511 |
| 82_<br>83_<br>84_<br>85_<br>86_<br>87_<br>88_<br>88_<br>88_<br>88_<br>88_<br>8B_<br>88_<br>82_<br>85_<br>85_                                                                               | 2064<br>2096<br>2112<br>2128<br>2144<br>2160<br>2176<br>2192<br>2208<br>2224<br>2240<br>2250<br>2272<br>2288<br>2304<br>2336<br>2336<br>2352<br>2336<br>2352<br>2368<br>2384<br>2400<br>2416<br>2448<br>2448 | 2065<br>2081<br>2097<br>2113<br>2129<br>2145<br>2161<br>2177<br>2193<br>2209<br>2225<br>2241<br>2257<br>2273<br>2289<br>2305<br>2321<br>2337<br>2353<br>2369<br>2385<br>2401<br>2417<br>2433<br>2449<br>2465<br>2481                 | 2066<br>2082<br>2098<br>2114<br>2130<br>2146<br>2162<br>2178<br>2210<br>2226<br>2242<br>2258<br>2274<br>2290<br>2306<br>2322<br>2338<br>2354<br>2370<br>2386<br>2402<br>2418<br>2434<br>2434<br>2456<br>2466<br>2482         | 2067<br>2083<br>2099<br>2115<br>2131<br>2147<br>2163<br>2195<br>2211<br>2227<br>2243<br>2259<br>2275<br>2291<br>2307<br>2323<br>2339<br>2355<br>2371<br>2387<br>2403<br>2419<br>2483         | 2068<br>2084<br>2100<br>2116<br>2132<br>2148<br>2164<br>2196<br>2212<br>2228<br>2244<br>2260<br>2276<br>2292<br>2308<br>2324<br>2340<br>2356<br>2372<br>2388<br>2404<br>2420<br>2468<br>2452<br>2468<br>2484 | 2069<br>2085<br>2101<br>2117<br>2133<br>2149<br>2165<br>2181<br>2197<br>2213<br>2229<br>2245<br>2261<br>2277<br>2293<br>2309<br>2325<br>2341<br>2377<br>2373<br>2389<br>2405<br>2421<br>2437<br>2453<br>2469<br>2485 | 2070<br>2086<br>2102<br>2118<br>2134<br>2150<br>2166<br>2182<br>2198<br>2214<br>2230<br>2246<br>2267<br>2278<br>2294<br>2310<br>2326<br>2342<br>2357<br>2342<br>2357<br>2390<br>2406<br>2422<br>2438<br>2458 | 2071<br>2087<br>21087<br>2135<br>2151<br>2151<br>2187<br>2283<br>2295<br>2215<br>2231<br>2247<br>2263<br>2279<br>2295<br>2311<br>2327<br>2343<br>2359<br>2391<br>2407<br>2423<br>2499<br>2455                                                        | 2072<br>2088<br>2104<br>2136<br>2152<br>2168<br>22152<br>2216<br>2232<br>2248<br>2264<br>2232<br>2248<br>2280<br>2296<br>2312<br>2328<br>2344<br>2360<br>2376<br>2392<br>2408<br>2424<br>2408<br>2424<br>2440<br>2456 | 2073<br>2089<br>2105<br>2121<br>2137<br>2153<br>2169<br>2185<br>2201<br>2217<br>2233<br>2249<br>2265<br>2281<br>2297<br>2313<br>2329<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345<br>2345         | 2074<br>2090<br>2106<br>2122<br>2138<br>2154<br>2170<br>2186<br>2202<br>2218<br>2234<br>2250<br>2266<br>2282<br>2298<br>2314<br>2330<br>2346<br>2382<br>2346<br>2378<br>2394<br>2410<br>2426<br>2442<br>2458<br>2474<br>2490                                          | 2075<br>2091<br>2107<br>2123<br>2139<br>2155<br>2171<br>2283<br>2219<br>2235<br>2251<br>2263<br>2299<br>2315<br>2331<br>2347<br>2363<br>2395<br>2411<br>2427<br>2443<br>2427<br>2443                         | 2076<br>2092<br>2108<br>2124<br>2140<br>2156<br>2172<br>2188<br>2200<br>2236<br>2252<br>2268<br>2284<br>2300<br>2316<br>2332<br>2348<br>2348<br>2348<br>2396<br>2412<br>2428<br>2444<br>2428                 | 2077<br>2093<br>2105<br>2141<br>2157<br>2173<br>2189<br>2205<br>2221<br>2237<br>2253<br>2269<br>2285<br>2301<br>2317<br>2333<br>2349<br>2365<br>2341<br>2397<br>2413<br>2429<br>2445<br>2461<br>2477<br>2493                 | 2078<br>2094<br>2110<br>2126<br>2142<br>2158<br>2174<br>2190<br>2200<br>2200<br>2222<br>2238<br>2254<br>2270<br>2302<br>2318<br>2334<br>2350<br>2366<br>2382<br>2398<br>2414<br>2430<br>2446<br>2462<br>2478<br>2494 | 2079<br>2095<br>2111<br>2127<br>2143<br>2159<br>2175<br>2191<br>2207<br>2223<br>2239<br>2255<br>2271<br>2287<br>2303<br>2319<br>2335<br>2351<br>2367<br>2383<br>2399<br>2415<br>2431<br>2447<br>2463                 |

......

×

| <b></b>                                                                                                                                                       | 0                                                                                                                                                                                                 | 1                                                                                                                                                                                                                                                                                                                                                         | 2                                                                                                                                                                                                                 | 3                                                                                                                                                                                                                                                                                                              | 4                                                                                                                                                                                                                  | 5                                                                                                                                                                                                 | 6                                                                                                                                                                                         | 7                                                                                                                                                                         | 8                                                                                                                                                                                         | 9                                                                                                                                                                                                 | A                                                                                                                                                                                 | В                                                                                                                                                                                                                                                                                                                                           | С                                                                                                                                                                                                 | D                                                                                                                                                                                 | E                                                                                                                                                                                         | F                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0 <u>+</u><br>A1_<br>A2_                                                                                                                                     | 2560<br>2576<br>2592                                                                                                                                                                              | 2561<br>2577<br>2593                                                                                                                                                                                                                                                                                                                                      | 2562<br>2578<br>2594                                                                                                                                                                                              | 2563<br>2579<br>2595                                                                                                                                                                                                                                                                                           | 2564<br>2580<br>2596                                                                                                                                                                                               | 2565<br>2581<br>2597                                                                                                                                                                              | 2566<br>2582<br>2598                                                                                                                                                                      | 2567<br>2583<br>2599                                                                                                                                                      | 2568<br>2584<br>2600                                                                                                                                                                      | 2569<br>2585<br>2601                                                                                                                                                                              | 2570<br>2586<br>2602                                                                                                                                                              | 2571<br>2587<br>2603                                                                                                                                                                                                                                                                                                                        | 2572<br>2588<br>2604                                                                                                                                                                              | 2573<br>2589<br>2605                                                                                                                                                              | 2574<br>2590<br>2606                                                                                                                                                                      | 2575<br>2591<br>2607                                                                                                                                                                      |
| A3_<br>A4_<br>A5_<br>A6_                                                                                                                                      | 2608<br>2624<br>2640<br>2656                                                                                                                                                                      | 2609<br>2625<br>2641<br>2657                                                                                                                                                                                                                                                                                                                              | 2610<br>2626<br>2642<br>2658                                                                                                                                                                                      | 2611<br>2627<br>2643<br>2659                                                                                                                                                                                                                                                                                   | 2612<br>2628<br>2644<br>2660                                                                                                                                                                                       | 2613<br>2629<br>2645<br>2661                                                                                                                                                                      | 2614<br>2630<br>2646<br>2662                                                                                                                                                              | 2615<br>2631<br>2647<br>2663                                                                                                                                              | 2616<br>2632<br>2648<br>2664                                                                                                                                                              | 2617<br>2633<br>2649<br>2665                                                                                                                                                                      | 2618<br>2634<br>2650<br>2666                                                                                                                                                      | 2619<br>2635<br>2651<br>2667                                                                                                                                                                                                                                                                                                                | 2620<br>2636<br>2652<br>2668                                                                                                                                                                      | 2621<br>2637<br>2653<br>2669                                                                                                                                                      | 2622<br>2638<br>2654<br>2670                                                                                                                                                              | 2623<br>2639<br>2655<br>2671                                                                                                                                                              |
| A7_<br>A8_<br>A9_                                                                                                                                             | 2672<br>2688<br>2704                                                                                                                                                                              | 2673<br>2689<br>2705                                                                                                                                                                                                                                                                                                                                      | 2674<br>2690<br>2706                                                                                                                                                                                              | 2675<br>2691<br>2707                                                                                                                                                                                                                                                                                           | 2676<br>2692<br>2708                                                                                                                                                                                               | 2677<br>2693<br>2709                                                                                                                                                                              | 2678<br>2694<br>2710                                                                                                                                                                      | 2679<br>2695<br>2711                                                                                                                                                      | 2680<br>2696<br>2712                                                                                                                                                                      | 2681<br>2697<br>2713                                                                                                                                                                              | 2682<br>2698<br>2714                                                                                                                                                              | 2683<br>2699<br>2715                                                                                                                                                                                                                                                                                                                        | 2684<br>2700<br>2716                                                                                                                                                                              | 2685<br>2701<br>2717                                                                                                                                                              | 2686<br>2702<br>2718                                                                                                                                                                      | 2687<br>2703<br>2719                                                                                                                                                                      |
| AA_<br>AB_<br>AC_                                                                                                                                             | 2720<br>2736<br>2752                                                                                                                                                                              | 2721<br>2737<br>2753                                                                                                                                                                                                                                                                                                                                      | 2722<br>2738<br>2754                                                                                                                                                                                              | 2723<br>2739<br>2755                                                                                                                                                                                                                                                                                           | 2724<br>2740<br>2756                                                                                                                                                                                               | 2725<br>2741<br>2757                                                                                                                                                                              | 2726<br>2742<br>2758                                                                                                                                                                      | 2727<br>2743<br>2759                                                                                                                                                      | 2728<br>2744<br>2760                                                                                                                                                                      | 2729<br>2745<br>2761                                                                                                                                                                              | 2730<br>2746<br>2762                                                                                                                                                              | 2731<br>2747<br>2763                                                                                                                                                                                                                                                                                                                        | 2732<br>2748<br>2764                                                                                                                                                                              | 2733<br>2749<br>2765                                                                                                                                                              | 2734<br>2750<br>2766                                                                                                                                                                      | 2735<br>2751<br>2767                                                                                                                                                                      |
| AD_<br>AE_<br>AF_<br>B0_                                                                                                                                      | 2768<br>2784<br>2800                                                                                                                                                                              | 2769<br>2785<br>2801                                                                                                                                                                                                                                                                                                                                      | 2770<br>2786<br>2802                                                                                                                                                                                              | 2771<br>2787<br>2803                                                                                                                                                                                                                                                                                           | 2772<br>2788<br>2804                                                                                                                                                                                               | 2773<br>2789<br>2805                                                                                                                                                                              | 2774<br>2790<br>2806                                                                                                                                                                      | 2775<br>2791<br>2807                                                                                                                                                      | 2776<br>2792<br>2808                                                                                                                                                                      | 2777<br>2793<br>2809                                                                                                                                                                              | 2778<br>2794<br>2810                                                                                                                                                              | 2779<br>2795<br>2811                                                                                                                                                                                                                                                                                                                        | 2780<br>2796<br>2812                                                                                                                                                                              | 2781<br>2797<br>2813<br>2829                                                                                                                                                      | 2782<br>2798<br>2814<br>2830                                                                                                                                                              | 2783<br>2799<br>2815<br>2831                                                                                                                                                              |
| B1_<br>B2_<br>B3_                                                                                                                                             | 2816<br>2832<br>2848<br>2864                                                                                                                                                                      | 2817<br>2833<br>2849<br>2865                                                                                                                                                                                                                                                                                                                              | 2818<br>2834<br>2850<br>2866                                                                                                                                                                                      | 2819<br>2835<br>2851<br>2867                                                                                                                                                                                                                                                                                   | 2820<br>2836<br>2852<br>2868                                                                                                                                                                                       | 2821<br>2837<br>2853<br>2869                                                                                                                                                                      | 2822<br>2838<br>2854<br>2870                                                                                                                                                              | 2823<br>2839<br>2855<br>2871                                                                                                                                              | 2824<br>2840<br>2856<br>2872                                                                                                                                                              | 2825<br>2841<br>2857<br>2873                                                                                                                                                                      | 2826<br>2842<br>2858<br>2874                                                                                                                                                      | 2827<br>2843<br>2859<br>2875                                                                                                                                                                                                                                                                                                                | 2828<br>2844<br>2860<br>2876                                                                                                                                                                      | 2829<br>2845<br>2861<br>2877                                                                                                                                                      | 2830<br>2846<br>2862<br>2878                                                                                                                                                              | 2831<br>2847<br>2863<br>2879                                                                                                                                                              |
| B4_<br>B5_<br>B6_<br>B7_                                                                                                                                      | 2880<br>2896<br>2912<br>2928                                                                                                                                                                      | 2881<br>2897<br>2913<br>2929                                                                                                                                                                                                                                                                                                                              | 2882<br>2898<br>2914<br>2930                                                                                                                                                                                      | 2883<br>2899<br>2915<br>2931                                                                                                                                                                                                                                                                                   | 2884<br>2900<br>2916<br>2932                                                                                                                                                                                       | 2885<br>2901<br>2917<br>2933                                                                                                                                                                      | 2886<br>2902<br>2918<br>2934                                                                                                                                                              | 2887<br>2903<br>2919<br>2935                                                                                                                                              | 2888<br>2904<br>2920<br>2936                                                                                                                                                              | 2889<br>2905<br>2921<br>2937                                                                                                                                                                      | 2890<br>2906<br>2922<br>2938                                                                                                                                                      | 2891<br>2907<br>2923<br>2939                                                                                                                                                                                                                                                                                                                | 2892<br>2908<br>2924<br>2940                                                                                                                                                                      | 2893<br>2909<br>2925<br>2941                                                                                                                                                      | 2894<br>2910<br>2926<br>2942                                                                                                                                                              | 2895<br>2911<br>2927<br>2943                                                                                                                                                              |
| B8_<br>B9_<br>BA_<br>BB_                                                                                                                                      | 2944<br>2960<br>2976<br>2992                                                                                                                                                                      | 2945<br>2961<br>2977<br>2993                                                                                                                                                                                                                                                                                                                              | 2946<br>2962<br>2978<br>2994                                                                                                                                                                                      | 2947<br>2963<br>2979<br>2995                                                                                                                                                                                                                                                                                   | 2948<br>2964<br>2980<br>2996                                                                                                                                                                                       | 2949<br>2965<br>2981<br>2997                                                                                                                                                                      | 2950<br>2966<br>2982<br>2998                                                                                                                                                              | 2951<br>2967<br>2983<br>2999                                                                                                                                              | 2952<br>2968<br>2984<br>3000                                                                                                                                                              | 2953<br>2969<br>2985<br>3001                                                                                                                                                                      | 2954<br>2970<br>2986<br>3002                                                                                                                                                      | 2955<br>2971<br>2987<br>3003                                                                                                                                                                                                                                                                                                                | 2956<br>2972<br>2988<br>3004                                                                                                                                                                      | 2957<br>2973<br>2989<br>3005                                                                                                                                                      | 2958<br>2974<br>2990<br>3006                                                                                                                                                              | 2959<br>2975<br>2991<br>3007                                                                                                                                                              |
| BC_<br>BD_<br>BE_                                                                                                                                             | 3008<br>3024<br>3040                                                                                                                                                                              | 3009<br>3025<br>3041                                                                                                                                                                                                                                                                                                                                      | 3010<br>3026<br>3042                                                                                                                                                                                              | 3011<br>3027<br>3043                                                                                                                                                                                                                                                                                           | 3012<br>3028<br>3044                                                                                                                                                                                               | 3013<br>3029<br>3045                                                                                                                                                                              | 3014<br>3030<br>3046                                                                                                                                                                      | 3015<br>3031<br>3047                                                                                                                                                      | 3016<br>3032<br>3048                                                                                                                                                                      | 3017<br>3033<br>3049                                                                                                                                                                              | 3018<br>3034<br>3050                                                                                                                                                              | 3019<br>3035<br>3051                                                                                                                                                                                                                                                                                                                        | 3020<br>3036<br>3052                                                                                                                                                                              | 3021<br>3037<br>3053                                                                                                                                                              | 3022<br>3038<br>3054                                                                                                                                                                      | 3023<br>3039<br>3055                                                                                                                                                                      |
| BF_                                                                                                                                                           | 3056                                                                                                                                                                                              | 3057                                                                                                                                                                                                                                                                                                                                                      | 3058                                                                                                                                                                                                              | 3059                                                                                                                                                                                                                                                                                                           | 3060                                                                                                                                                                                                               | 3061                                                                                                                                                                                              | 3062                                                                                                                                                                                      | 3063                                                                                                                                                                      | 3064                                                                                                                                                                                      | 3065                                                                                                                                                                                              | 3066                                                                                                                                                                              | 3067                                                                                                                                                                                                                                                                                                                                        | 3068                                                                                                                                                                                              | 3069                                                                                                                                                                              | 3070                                                                                                                                                                                      | 3071                                                                                                                                                                                      |
|                                                                                                                                                               | 3056<br>0                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                    |                                                                                                                                                                                                   | 3062<br>6                                                                                                                                                                                 | 3063<br>7                                                                                                                                                                 |                                                                                                                                                                                           |                                                                                                                                                                                                   | 3066<br>A                                                                                                                                                                         | 3067<br>B                                                                                                                                                                                                                                                                                                                                   | 3068<br>C                                                                                                                                                                                         | 3069<br><br>D                                                                                                                                                                     | 3070<br>E                                                                                                                                                                                 | 3071<br>                                                                                                                                                                                  |
|                                                                                                                                                               | ـــــــــــــــــــــــــــــــــــــ                                                                                                                                                             | 3057<br>1<br>3073<br>3089<br>3105                                                                                                                                                                                                                                                                                                                         | 3058<br>2<br>3074<br>3090<br>3106                                                                                                                                                                                 | 3059<br>3<br>3075<br>3091<br>3107                                                                                                                                                                                                                                                                              | 3060<br>4<br>3076<br>3092<br>3108                                                                                                                                                                                  | 3061<br>5<br>3077<br>3093<br>3109                                                                                                                                                                 | 6<br>3078<br>3094<br>3110                                                                                                                                                                 | 7<br>3079<br>3095<br>3111                                                                                                                                                 | 3064<br>8<br>3080<br>3096<br>3112                                                                                                                                                         | 3065<br>9<br>3081<br>3097<br>3113                                                                                                                                                                 | A<br>3082<br>3098<br>3114                                                                                                                                                         | B<br>3083<br>3099<br>3115                                                                                                                                                                                                                                                                                                                   | C<br>3084<br>3100<br>3116                                                                                                                                                                         | D<br>3085<br>3101<br>3117                                                                                                                                                         |                                                                                                                                                                                           | F<br>3087<br>3103<br>3119                                                                                                                                                                 |
| BF_<br>C0_<br>C1_<br>C2_<br>C3_<br>C4_<br>C5_<br>C6_                                                                                                          | 0<br>3072<br>3088<br>3104<br>3120<br>3136<br>3152<br>3168                                                                                                                                         | 3057<br>1<br>3073<br>3089<br>3105<br>3121<br>3137<br>3153<br>3169                                                                                                                                                                                                                                                                                         | 3058<br>2<br>3074<br>3090<br>3106<br>3122<br>3138<br>3154<br>3170                                                                                                                                                 | 3059<br>3<br>3075<br>3091<br>3107<br>3123<br>3139<br>3155<br>3171                                                                                                                                                                                                                                              | 3060<br>4<br>3076<br>3092<br>3108<br>3124<br>3140<br>3156<br>3172                                                                                                                                                  | 3061<br>5<br>3077<br>3093<br>3109<br>3125<br>3141<br>3157<br>3173                                                                                                                                 | 6<br>3078<br>3094<br>3110<br>3126<br>3142<br>3158<br>3174                                                                                                                                 | 7<br>3079<br>3095<br>3111<br>3127<br>3143<br>3159<br>3175                                                                                                                 | 3064<br>8<br>3080<br>3096<br>3112<br>3128<br>3144<br>3160<br>3176                                                                                                                         | 3065<br>9<br>3081<br>3097<br>3113<br>3129<br>3145<br>3161<br>3177                                                                                                                                 | A<br>3082<br>3098<br>3114<br>3130<br>3146<br>3162<br>3178                                                                                                                         | B<br>3083<br>3099<br>3115<br>3131<br>3147<br>3163<br>3179                                                                                                                                                                                                                                                                                   | C<br>3084<br>3100<br>3116<br>3132<br>3148<br>3164<br>3180                                                                                                                                         | D<br>3085<br>3101<br>3117<br>3133<br>3149<br>3165<br>3181                                                                                                                         | E<br>3086<br>3102<br>3118<br>3134<br>3150<br>3166<br>3182                                                                                                                                 | F<br>3087<br>3103<br>3119<br>3135<br>3151<br>3167<br>3183                                                                                                                                 |
| BF_<br>C0_<br>C1_<br>C2_<br>C3_<br>C4_<br>C5_<br>C6_<br>C7_<br>C8_<br>C9_<br>CA_                                                                              | 0<br>3072<br>3088<br>3104<br>3120<br>3136<br>3152<br>3168<br>3184<br>3200<br>3216<br>3232                                                                                                         | 3057<br>1<br>3073<br>3089<br>3105<br>3121<br>3137<br>3153<br>3169<br>3185<br>3201<br>3217<br>3233                                                                                                                                                                                                                                                         | 3058<br>2<br>3074<br>3090<br>3106<br>3122<br>3138<br>3154<br>3170<br>3186<br>3202<br>3218<br>3234                                                                                                                 | 3059<br>3<br>3075<br>3091<br>3107<br>3123<br>3139<br>3155<br>3171<br>3187<br>3203<br>3219<br>3235                                                                                                                                                                                                              | 3060<br>4<br>3076<br>3092<br>3108<br>3124<br>3140<br>3156<br>3172<br>3188<br>3204<br>3220<br>3236                                                                                                                  | 3061<br>5<br>3077<br>3093<br>3109<br>3125<br>3141<br>3157<br>3173<br>3189<br>3205<br>3221<br>3237                                                                                                 | 6<br>3078<br>3094<br>3110<br>3126<br>3142<br>3158<br>3174<br>3190<br>3206<br>3222<br>3238                                                                                                 | 7<br>3079<br>3111<br>3127<br>3143<br>3159<br>3175<br>3191<br>3207<br>3223<br>3239                                                                                         | 3064<br>8<br>3080<br>3096<br>3112<br>3128<br>3144<br>3160<br>3176<br>3192<br>3208<br>3224<br>3240                                                                                         | 3065<br>9<br>3081<br>3097<br>3113<br>3129<br>3145<br>3161<br>3177<br>3193<br>3209<br>3225<br>3241                                                                                                 | A<br>3082<br>3098<br>3114<br>3130<br>3146<br>3162<br>3178<br>3194<br>3210<br>3226<br>3242                                                                                         | <b>B</b><br>3083<br>3099<br>3115<br>3131<br>3147<br>3163<br>3179<br>3195<br>3211<br>3227<br>3243                                                                                                                                                                                                                                            | C<br>3084<br>3100<br>3116<br>3132<br>3148<br>3164<br>3180<br>3196<br>3212<br>3228<br>3244                                                                                                         | D<br>3085<br>3101<br>3117<br>3133<br>3149<br>3165<br>3181<br>3197<br>3213<br>3229<br>3245                                                                                         | E<br>3086<br>3102<br>3118<br>3134<br>3150<br>3166<br>3182<br>3198<br>3214<br>3230<br>3246                                                                                                 | F<br>3087<br>3103<br>3119<br>3135<br>3151<br>3167<br>3183<br>3199<br>3215<br>3231<br>3247                                                                                                 |
| BF_<br>C0_<br>C1_<br>C2_<br>C3_<br>C4_<br>C5_<br>C6_<br>C7_<br>C8_<br>C9_                                                                                     | 0<br>3072<br>3088<br>3104<br>3120<br>3136<br>3152<br>3168<br>3184<br>3200<br>3216                                                                                                                 | 3057<br>1<br>3073<br>3089<br>3105<br>3121<br>3137<br>3153<br>3169<br>3185<br>3201<br>3217                                                                                                                                                                                                                                                                 | 3058<br>2<br>3074<br>3090<br>3106<br>3122<br>3138<br>3154<br>3170<br>3186<br>3202<br>3218                                                                                                                         | 3059<br>3075<br>3091<br>3107<br>3123<br>3139<br>3155<br>3171<br>3187<br>3203<br>3219                                                                                                                                                                                                                           | 3060<br>4<br>3076<br>3092<br>3108<br>3124<br>3140<br>3156<br>3172<br>3188<br>3204<br>3220                                                                                                                          | 3061<br>5<br>3077<br>3093<br>3125<br>3141<br>3157<br>3173<br>3189<br>3205<br>3221                                                                                                                 | 6<br>3078<br>3094<br>3110<br>3126<br>3142<br>3158<br>3174<br>3190<br>3206<br>3222                                                                                                         | 7<br>3079<br>3095<br>3111<br>3127<br>3143<br>3159<br>3175<br>3191<br>3207<br>3223                                                                                         | 3064<br>8<br>3080<br>3096<br>3112<br>3128<br>3144<br>3160<br>3176<br>3192<br>3208<br>3224                                                                                                 | 3065<br>9<br>3081<br>3097<br>3113<br>3129<br>3145<br>3161<br>3177<br>3193<br>3209<br>3225                                                                                                         | A<br>3082<br>3098<br>3114<br>3130<br>3146<br>3162<br>3178<br>3194<br>3210<br>3226                                                                                                 | <b>B</b><br>3083<br>3099<br>3115<br>3131<br>3147<br>3163<br>3179<br>3195<br>3211<br>3227                                                                                                                                                                                                                                                    | C<br>3084<br>3100<br>3116<br>3132<br>3148<br>3164<br>3180<br>3196<br>3212<br>3228                                                                                                                 | D<br>3085<br>3101<br>3117<br>3133<br>3149<br>3165<br>3181<br>3197<br>3213<br>3229                                                                                                 | E<br>3086<br>3102<br>3118<br>3134<br>3150<br>3166<br>3182<br>3198<br>3214<br>3230                                                                                                         | F<br>3087<br>3103<br>3119<br>3135<br>3151<br>3167<br>3183<br>3199<br>3215<br>3231                                                                                                         |
| BF_<br>C0_<br>C1_<br>C2_<br>C3_<br>C4_<br>C5_<br>C6_<br>C7_<br>C8_<br>C9_<br>CA_<br>CB_<br>CC_<br>CD_<br>CE_                                                  | 0<br>3072<br>3088<br>3104<br>3120<br>3136<br>3152<br>3168<br>3216<br>3221<br>3248<br>3264<br>3280<br>3296                                                                                         | 3057<br>1<br>3073<br>3089<br>3105<br>3121<br>3137<br>3153<br>3169<br>3185<br>3201<br>3217<br>3233<br>3249<br>3265<br>3281<br>3297                                                                                                                                                                                                                         | 3058<br>2<br>3074<br>3090<br>3106<br>3122<br>3138<br>3154<br>3154<br>3154<br>3154<br>3170<br>3186<br>3202<br>3218<br>3234<br>3234<br>3250<br>3266<br>3282<br>3298                                                 | 3059<br>3075<br>3091<br>3107<br>3123<br>3139<br>3155<br>3171<br>3187<br>3203<br>3219<br>3235<br>3251<br>3267<br>3283<br>3299<br>3315<br>3331<br>3347<br>3363                                                                                                                                                   | 3060<br>4<br>3076<br>3092<br>3108<br>3124<br>3140<br>3156<br>3172<br>3188<br>3204<br>3220<br>3236<br>3252<br>3268<br>3252<br>3268<br>3252<br>3268<br>3252<br>3268<br>3254<br>3300<br>3316<br>3332<br>3348<br>3364  | 3061<br>5<br>3077<br>3093<br>3109<br>3125<br>3141<br>3157<br>3173<br>3189<br>3205<br>3221<br>3237<br>3253<br>3269<br>3285<br>3301<br>3117<br>3331<br>3349<br>3365                                 | 6<br>3078<br>3094<br>3110<br>3126<br>3142<br>3158<br>3174<br>3190<br>3206<br>3222<br>3238<br>3254<br>3254<br>3270<br>3286<br>3302                                                         | 7<br>3079<br>3095<br>3111<br>3127<br>3143<br>3159<br>3175<br>3191<br>3207<br>3223<br>3239<br>3255<br>3271<br>3287<br>3303                                                 | 3064<br>8<br>3080<br>3096<br>3112<br>3128<br>3144<br>3160<br>3176<br>3192<br>3208<br>3224<br>3226<br>3272<br>3288<br>3304<br>3320<br>3336<br>3352<br>3368                                 | 3065<br>9<br>3081<br>3097<br>3113<br>3129<br>3145<br>3161<br>3177<br>3193<br>3209<br>3225<br>3241<br>3257<br>3241<br>3257<br>3273<br>3289<br>3305<br>3321<br>3337<br>3353<br>3369                 | A<br>3082<br>3098<br>3114<br>3130<br>3146<br>3162<br>3178<br>3194<br>3210<br>3226<br>3258<br>3274<br>3290<br>3306<br>3322<br>3338<br>3354<br>3370                                 | <b>B</b><br>3083<br>3099<br>3115<br>3131<br>3147<br>3163<br>3179<br>3195<br>3211<br>3227<br>3243<br>3259<br>3275<br>3291<br>3307<br>3223<br>3339<br>3355<br>3371                                                                                                                                                                            | C<br>3084<br>3100<br>3116<br>3132<br>3148<br>3164<br>3180<br>3196<br>3212<br>3228<br>3244<br>3260<br>3276<br>3292<br>3308<br>3324<br>3340<br>3356<br>3372                                         | D<br>3085<br>3101<br>3117<br>3133<br>3149<br>3165<br>3181<br>3197<br>3213<br>3229<br>3245<br>3261<br>3277<br>3293<br>3309                                                         | E<br>3086<br>3102<br>3118<br>3134<br>3150<br>3166<br>3182<br>3198<br>3214<br>3230<br>3246<br>3262<br>3278<br>3294<br>3310                                                                 | F<br>3087<br>3103<br>3119<br>3135<br>3151<br>3167<br>3183<br>3199<br>3215<br>3231<br>3247<br>3263<br>3279<br>3295<br>3311<br>3227<br>3327<br>3327<br>3327<br>3327<br>3327<br>3327         |
| BF_<br>C0_<br>C1_<br>C2_<br>C3_<br>C4_<br>C5_<br>C6_<br>C7_<br>C8_<br>C9_<br>C4_<br>C9_<br>CC_<br>CB_<br>CC_<br>CE_<br>CF_<br>D0_<br>D1_<br>D2_               | 0<br>3072<br>3088<br>3104<br>3120<br>3136<br>3152<br>3168<br>3152<br>3168<br>3184<br>3200<br>3216<br>3232<br>3248<br>3264<br>3280<br>3296<br>3312<br>3328<br>3344<br>3360                         | 3057           1           3073           3089           3105           3121           3137           3153           3169           3185           3201           3217           3233           3249           3265           3281           3297           3313           3293           3345           3361                                             | 3058<br>2<br>3074<br>3090<br>3106<br>3122<br>3138<br>3154<br>3154<br>3176<br>3282<br>3218<br>3220<br>3266<br>3282<br>3298<br>3314<br>3346<br>3346<br>3346                                                         | 3059<br>3075<br>3091<br>3107<br>3123<br>3139<br>3155<br>3171<br>3187<br>3203<br>3219<br>3235<br>3251<br>3267<br>3283<br>3299<br>3215<br>3315<br>3341<br>3347<br>3363<br>3379<br>3395                                                                                                                           | 3060<br>4<br>3076<br>3092<br>3108<br>3124<br>3140<br>3156<br>3172<br>3188<br>3204<br>3236<br>3252<br>3268<br>3252<br>3268<br>3348<br>3316                                                                          | 3061<br>5<br>3077<br>3093<br>3109<br>3125<br>3141<br>3157<br>3173<br>3189<br>3205<br>3221<br>3237<br>3253<br>3269<br>3285<br>3301<br>3317<br>3317<br>3333<br>3349                                 | 6<br>3078<br>3094<br>3110<br>3126<br>3142<br>3158<br>3174<br>3190<br>3206<br>3228<br>3254<br>3254<br>3254<br>3254<br>3254<br>3254<br>3270<br>3286<br>3302<br>3318<br>3334<br>3350<br>3366 | 7<br>3079<br>3095<br>3111<br>3127<br>3143<br>3159<br>3175<br>3191<br>3207<br>3223<br>3239<br>3255<br>3271<br>3287<br>3303<br>3319<br>3335<br>3351<br>3367                 | 3064<br>8<br>3080<br>3096<br>3112<br>3128<br>3144<br>3160<br>3176<br>3176<br>3192<br>3208<br>3224<br>3240<br>3256<br>3272<br>3288<br>3304<br>3320<br>3336<br>3352                         | 3065<br>9<br>3081<br>3097<br>3113<br>3129<br>3145<br>3161<br>3177<br>3193<br>3209<br>3225<br>3241<br>3257<br>3273<br>3289<br>3305<br>3321<br>3337<br>3353                                         | A<br>3082<br>3098<br>3114<br>3130<br>3146<br>3162<br>3178<br>3194<br>3216<br>3242<br>3258<br>3274<br>3290<br>3306<br>3322<br>3338<br>3354                                         | <b>B</b><br>3083<br>3099<br>3115<br>3131<br>3147<br>3163<br>3179<br>3195<br>3211<br>3227<br>3243<br>3259<br>3275<br>3291<br>3307<br>3323<br>3339                                                                                                                                                                                            | C<br>3084<br>3100<br>3116<br>3132<br>3148<br>3164<br>3180<br>3196<br>3212<br>3228<br>3244<br>3260<br>3276<br>3292<br>3308<br>3324<br>3340<br>3356                                                 | D<br>3085<br>3101<br>3117<br>3133<br>3149<br>3165<br>3181<br>3197<br>3213<br>3229<br>3245<br>3261<br>3277<br>3293<br>3309<br>3325<br>3341<br>3357<br>3373                         | E<br>3086<br>3102<br>3118<br>3134<br>3150<br>3166<br>3182<br>3198<br>3214<br>3236<br>3246<br>3262<br>3278<br>3294<br>3310<br>3326<br>3326<br>3326<br>3327                                 | F<br>3087<br>3103<br>3119<br>3135<br>3151<br>3167<br>3183<br>3199<br>3215<br>3231<br>3247<br>3263<br>3279<br>3295<br>3311<br>3327<br>3343<br>3359                                         |
| BF_<br>C0_<br>C1_<br>C2_<br>C3_<br>C4_<br>C5_<br>C6_<br>C7_<br>C8_<br>C9_<br>CA_<br>CB_<br>CC_<br>CD_<br>CE_<br>CF_<br>D1_<br>D2_<br>D3_<br>D4_<br>D5_<br>D6_ | 0<br>3072<br>3088<br>3104<br>3120<br>3136<br>3152<br>3168<br>3152<br>3168<br>3184<br>3200<br>3216<br>3232<br>3248<br>3264<br>3280<br>3296<br>3312<br>3328<br>3344<br>3360<br>3376<br>3392<br>3408 | 3057           1           3073           3089           3105           3121           3137           3153           3169           3185           3201           3217           3233           3249           3265           3281           3313           3329           3345           361           3377           3933           3409           3425 | 3058<br>2<br>3074<br>3090<br>3106<br>3122<br>3138<br>3154<br>3154<br>3170<br>3186<br>3202<br>3218<br>3234<br>3234<br>3250<br>3266<br>3282<br>3298<br>3314<br>3330<br>3346<br>3362<br>3378<br>3394<br>3410<br>3426 | 3059           3           3075           3091           3107           3123           3155           3171           3155           3219           32251           3267           3283           3299           3315           3331           3347           3363           3379           3395           3411 | 3060<br>4<br>3076<br>3092<br>3108<br>3124<br>3124<br>3140<br>3156<br>3172<br>3188<br>3204<br>3236<br>3252<br>3268<br>3252<br>3268<br>3252<br>3268<br>3316<br>33316<br>3332<br>3348<br>3364<br>3396<br>3412<br>3428 | 3061<br>5<br>3077<br>3093<br>3109<br>3125<br>3141<br>3157<br>3173<br>3189<br>3205<br>3221<br>3237<br>3253<br>3269<br>3285<br>3301<br>3317<br>3333<br>3349<br>3365<br>3381<br>3397<br>3413<br>3429 | 6<br>3078<br>3094<br>3110<br>3126<br>3142<br>3158<br>3174<br>3190<br>3206<br>3222<br>3238<br>3254<br>3270<br>3286<br>3302<br>3318<br>3334<br>3350<br>3366<br>3382<br>3398<br>3414<br>3430 | 7<br>3079<br>3095<br>3111<br>3127<br>3143<br>3159<br>3175<br>3191<br>3203<br>3239<br>3255<br>3271<br>3287<br>3303<br>3319<br>3335<br>3351<br>3367<br>3383<br>3399<br>3415 | 3064<br>8<br>3080<br>3096<br>3112<br>3128<br>3144<br>3160<br>3176<br>3192<br>3208<br>3224<br>3240<br>3256<br>3272<br>3288<br>3304<br>3320<br>3336<br>3352<br>3368<br>3384<br>3416<br>3432 | 3065<br>9<br>3081<br>3097<br>3113<br>3129<br>3145<br>3161<br>3177<br>3193<br>3209<br>3225<br>3241<br>3257<br>3273<br>3289<br>3305<br>3321<br>3337<br>3353<br>3369<br>3385<br>3401<br>3417<br>3433 | A<br>3082<br>3098<br>3114<br>3130<br>3146<br>3162<br>3178<br>3194<br>3210<br>3226<br>3242<br>3258<br>3274<br>3290<br>3306<br>3322<br>3338<br>3354<br>3370<br>3386<br>3402<br>3418 | B           3083           3099           3115           3131           3147           3163           3179           3195           3211           3227           3243           3259           3275           3291           3307           3323           3339           3355           3371           3403           3419           3435 | C<br>3084<br>3100<br>3116<br>3132<br>3148<br>3164<br>3180<br>3196<br>3212<br>3228<br>3244<br>3260<br>3276<br>3292<br>3308<br>3324<br>3340<br>3356<br>3372<br>3388<br>3404<br>3356<br>3372<br>3388 | D<br>3085<br>3101<br>3117<br>3133<br>3149<br>3165<br>3181<br>3197<br>3213<br>3229<br>3245<br>3261<br>3277<br>3293<br>3309<br>3325<br>3341<br>3357<br>3373<br>3389<br>3405<br>3421 | E<br>3086<br>3102<br>3118<br>3134<br>3150<br>3166<br>3182<br>3198<br>3214<br>3230<br>3246<br>3262<br>3278<br>3294<br>3310<br>3326<br>3342<br>3358<br>3374<br>3390<br>3406<br>3422<br>3438 | F<br>3087<br>3103<br>3119<br>3135<br>3151<br>3167<br>3183<br>3199<br>3215<br>3231<br>3247<br>3263<br>3279<br>3295<br>3311<br>3327<br>3343<br>3359<br>3375<br>3391<br>3407<br>3423<br>3439 |

0

C

|            | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | A            | в            | С            | D                    | E            | F            |
|------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|----------------------|--------------|--------------|
| E0         | 3584<br>3600 | 3585<br>3601 | 3586<br>3602 | 3587<br>3603 | 3588<br>3604 | 3589<br>3605 | 3590<br>3606 | 3591<br>3607 | 3592<br>3608 | 3593<br>3609 | 3594<br>3610 | 3595<br>3611 | 3596<br>3612 | 3597<br>3613         | 3598<br>3614 | 3599         |
| E1<br>E2   | 3616         | 3617         | 3618         | 3619         | 3620         | 3621         | 3622         | 3623         | 3624         | 3625         | 3626         | 3627         | 3628         | 3629                 | 3630         | 3615<br>3631 |
| E3_        | 3632         | 3633         | 3634         | 3635         | 3636         | 3637         | 3638         | 3639         | 3640         | 3641         | 3642         | 3643         | 3644         | 3645                 | 3646         | 3647         |
| E4_        | 3648         | 3649         | 3650         | 3651         | 3652         | 3653         | 3654         | 3655         | 3656         | 3657         | 3658         | 3659         | 3660         | 3661                 | 3662         | 3663         |
| E5_<br>E6  | 3664         | 3665<br>3681 | 3666<br>3682 | 3667<br>3683 | 3668<br>3684 | 3669<br>3685 | 3670<br>3686 | 3671<br>3687 | 3672<br>3688 | 3673<br>3689 | 3674<br>3690 | 3675<br>3691 | 3676<br>3692 | 3677<br>3693         | 3678<br>3694 | 3679<br>3695 |
| E0_<br>E7_ | 3696         | 3697         | 3698         | 3699         | 3700         | 3701         | 3702         | 3703         | 3704         | 3705         | 3706         | 3707         | 3708         | 3709                 | 3710         | 3711         |
| E8_        | 3712         | 3713         | 3714         | 3715         | 3716         | 3717         | 3718         | 3719         | 3720         | 3721         | 3722         | 3723         | 3724         | 3725                 | 3726         | 3727         |
| E9_<br>EA_ | 3728         | 3729<br>3745 | 3730<br>3746 | 3731<br>3747 | 3732<br>3748 | 3733<br>3749 | 3734<br>3750 | 3735<br>3751 | 3736<br>3752 | 3737<br>3753 | 3738<br>3754 | 3739<br>3755 | 3740<br>3756 | 3741<br>3757         | 3742<br>3758 | 3743<br>3759 |
| EB_        | 3760         | 3761         | 3762         | 3763         | 3764         | 3765         | 3766         | 3767         | 3768         | 3769         | 3770         | 3771         | 3772         | 3773                 | 3774         | 3775         |
| EC_        | 3776         | 3777         | 3778         | 3779         | 3780         | 3781         | 3782         | 3783         | 3784         | 3785         | 3786         | 3787         | 3788         | 3789                 | 3790         | 3791         |
| ED_        | 3792         | 3793         | 3794         | 3795         | 3796         | 3797         | 3798         | 3799         | 3800         | 3801         | 3802         | 3803         | 3804         | 3805                 | 3806<br>3822 | 3807         |
| EE_<br>EF_ | 3808<br>3824 | 3809<br>3825 | 3810<br>3826 | 3811<br>3827 | 3812<br>3828 | 3813<br>3829 | 3814<br>3830 | 3815<br>3831 | 3816<br>3832 | 3817<br>3833 | 3818<br>3834 | 3819<br>3835 | 3820<br>3836 | 3821<br>3837         | 3838         | 3823<br>3839 |
| F0_        | 3840         | 3841         | 3842         | 3843         | 3844         | 3845         | 3846         | 3847         | 3848         | 3849         | 3850         | 3851         | 3852         | 3853                 | 3854         | 3855         |
| F1_        | 3856         | 3857         | 3858         | 3859         | 3860         | 3861         | 3862         | 3863         | 3864         | 3865         | 3866         | 3867         | 3868         | 3869                 | 3870         | 3871         |
| F2_        | 3872         | 3873         | 3874         | 3875         | 3876         | 3877         | 3878         | 3879         | 3880         | 3881         | 3882         | 3883         | 3884         | 3885                 | 3886         | 3887         |
| F3_        | 3888         | 3889         | 3890         | 3891         | 3892         | 3893         | 3894         | 3895         | 3896         | 3897         | 3898         | 3899         | 3900         | 3901                 | 3902         | 3903         |
| F4_<br>F5_ | 3904<br>3920 | 3905<br>3921 | 3906<br>3922 | 3907<br>3923 | 3908<br>3924 | 3909<br>3925 | 3910<br>3926 | 3911<br>3927 | 3912<br>3928 | 3913<br>3929 | 3914<br>3930 | 3915<br>3931 | 3916<br>3932 | 3917<br>393 <b>3</b> | 3918<br>3934 | 3919<br>3935 |
| F6_        | 3936         | 3937         | 3938         | 3939         | 3940         | 3941         | 3942         | 3943         | 3944         | 3945         | 3946         | 3947         | 3948         | 3949                 | 3950         | 3951         |
| F7_        | 3952         | 3953         | 3954         | 3955         | 3956         | 3957         | 3958         | 3959         | 3960         | 3961         | 3962         | 3963         | 3964         | 3965                 | 3966         | 3967         |
| F8_<br>F9_ | 3968<br>3984 | 3969<br>3985 | 3970<br>3986 | 3971<br>3987 | 3972<br>3988 | 3973<br>3989 | 3974<br>3990 | 3975<br>3991 | 3976<br>3992 | 3977<br>3993 | 3978<br>3994 | 3979<br>3995 | 3980<br>3996 | 3981<br>3997         | 3982<br>3998 | 3983<br>3999 |
| FA_        | 4000         | 3985<br>4001 | 3986<br>4002 | 4003         | 3988<br>4004 | 3989<br>4005 | 3990<br>4006 | 4007         | 3992<br>4008 | 3993<br>4009 | 3994<br>4010 | 3995<br>4011 | 3990<br>4012 | 4013                 | 3998<br>4014 | 4015         |
| FB_        | 4016         | 4017         | 4018         | 4019         | 4020         | 4021         | 4022         | 4023         | 4024         | 4025         | 4026         | 4027         | 4028         | 4029                 | 4030         | 4031         |
| FC_        | 4032         | 4033         | 4034         | 4035         | 4036         | 4037         | 4038         | 4039         | 4040         | 4041         | 4042         | 4043         | 4044         | 4045                 | 4046         | 4047         |
| FD_<br>FE_ | 4048<br>4064 | 4049<br>4065 | 4050<br>4066 | 4051<br>4067 | 4052<br>4068 | 4053<br>4069 | 4054<br>4070 | 4055<br>4071 | 4056<br>4072 | 4057<br>4073 | 4058<br>4074 | 4059<br>4075 | 4060<br>4076 | 4061<br>4077         | 4062<br>4078 | 4063<br>4079 |
| FF_        | 4080         | 4005         | 4082         | 4083         | 4084         | 4005         | 4086         | 4071         | 4088         | 4073         | 4090         | 4015         | 4070         | 4093                 | 4094         | 4095         |

·

~

.

| 2n                                                                                                       | n          |
|----------------------------------------------------------------------------------------------------------|------------|
| 18,446,744,073,709,551,616                                                                               | 64         |
| 36,893,488,147,419,103,232                                                                               | 65         |
| 73,786,976,294,838,206,464<br>147,573,952,589,676,412,928                                                | 66<br>67   |
| 295,147,905,179,352,825,856                                                                              | 68         |
| 590,295,810,358,705,651,712<br>1,180,591,620,717,411,303,424                                             | 69<br>70   |
| 2,361,183,241,434,822,606,848                                                                            | 71         |
| 4,722,366,482,869,645,213,696                                                                            | 72         |
| 9,444,732,965,739,290,427,392<br>18,889,465,931,478,580,854,784                                          | 73<br>74   |
| 37,778,931,862,957,161,709,568                                                                           | 75         |
| 75,557,863,725,914,323,419,136                                                                           | 76         |
| 151,115,727,451,828,646,838,272<br>302,231,454,903,657,293,676,544                                       | 77<br>78   |
| 604,462,909,807,314,587,353,088                                                                          | 79         |
| 1,208,925,819,614,629,174,706,176<br>2,417,851,639,229,258,349,412,352                                   | 80<br>81   |
| 4,835,703,278,458,516,698,824,704                                                                        | 82         |
| 9,671,406,556,917,033,397,649,408                                                                        | 83         |
| 19,342,813,113,834,066,795,298,816<br>38,685,626,227,668,133,590,597,632                                 | 84<br>85   |
| 77,371,252,455,336,267,181,195,264                                                                       | 86         |
| 154,742,504,910,672,534,362,390,528                                                                      | 87         |
| 309,485,009,821,345,068,724,781,056<br>618,970,019,642,690,137,449,562,112                               | 88<br>89   |
| 1,237,940,039,285,380,274,899,124,224                                                                    | 90         |
| 2,475,880,078,570,760,549,798,248,448                                                                    | 91         |
| 4,951,760,157,141,521,099,596,496,896<br>9,903,520,314,283,042,199,192,993,792                           | 92<br>93   |
| 19,807,040,628,566,084,398,385,987,584                                                                   | 94         |
| 39,614,081,257,132,168,796,771,975,168                                                                   | 95         |
| 79,228,162,514,264,337,593,543,950,336<br>158,456,325,028,528,675,187,087,900,672                        | 96<br>97   |
| 316,912,650,057,057,350,374,175,801,344<br>633,825,300,114,114,700,748,351,602,688                       | 98<br>99   |
|                                                                                                          |            |
| 1,267,650,600,228,229,401,496,703,205,376<br>2,535,301,200,456,458,802,993,406,410,752                   | 100<br>101 |
| 5,070,602,400,912,917,605,986,812,821,504<br>10,141,204,801,825,835,211,973,625,643,008                  | 102<br>103 |
| 20,282,409,603,651,670,423,947,251,286,016                                                               | 104        |
| 40,564,819,207,303,340,847,894,502,572,032                                                               | 104        |
| 81,129,638,414,606,681,695,789,005,144,064<br>162,259,276,829,213,363,391,578,010,288,128                | 106<br>107 |
| 324,518,553,658,426,726,783,156,020,576,256                                                              | 108        |
| 649,037,107,316,853,453,566,312,041,152,512                                                              | 109        |
| 1,298,074,214,633,706,907,132,624,082,305,024<br>2,596,148,429,267,413,814,265,248,164,610,048           | 110<br>111 |
| 5,192,296,858,534,827,628,530,496,329,220,096                                                            | 112        |
| 10,384,593,717,069,655,257,060,992,658,440,192                                                           | 113        |
| 20,769,187,434,139,310,514,121,985,316,880,384<br>41,538,374,868,278,621,028,243,970,633,760,768         | 114<br>115 |
| 83,076,749,736,557,242,056,487,941,267,521,536                                                           | 116        |
| 166,153,499,473,114,484,112,975,882,535,043,072<br>332,306,998,946,228,968,225,951,765,070,086,144       | 117<br>118 |
| 664,613,997,892,457,936,451,903,530,140,172,288                                                          | 119        |
| 1,329,227,995,784,915,872,903,807,060,280,344,576                                                        | 120        |
| 2,658,455,991,569,831,745,807,614,120,560,689,152<br>5,316,911,983,139,663,491,615,228,241,121,378,304   | 121<br>122 |
| 10,633,823,966,279,326,983,230,456,482,242,756,608                                                       | 123        |
| 21,267,647,932,558,653,966,460,912,964,485,513,216                                                       | 124        |
| 42,535,295,865,117,307,932,921,825,928,971,026,432<br>85,070,591,730,234,615,865,843,651,857,942,052,864 | 125<br>126 |
| 170,141,183,460,469,231,731,687,303,715,884,105,728                                                      | 127        |
| 340,282,366,920,938,463,463,374,607,431,768,211,456                                                      | 128        |

|          |          |           |            |            | Fishelia                 |            |                |
|----------|----------|-----------|------------|------------|--------------------------|------------|----------------|
|          |          |           |            |            | Eight bit<br>data inter- |            | PTTC/          |
| Decimal  | Hex      | Binary    | EBCDIC     | ASCII      | change                   | PTTC/EBCD  | Correspondence |
| 0        | 00       | 0000 0000 | NUL        |            |                          |            |                |
| 1        | 00       | 0000 0000 |            | NUL        | NUL                      |            |                |
| 2        | 01       | 0001      | SOH<br>STX | SOH<br>STX | NUL                      | space      | space          |
| 3        | 02       | 0010      | ETX        |            |                          | 1          | 1,]            |
| 1 1      | 03       |           |            | ETX        | @                        |            | •              |
| 4        |          | 0100      | PF         | EOT        |                          | 2          | 2              |
| 5        | 05       | 0101      | HT         | ENQ        | space                    |            | 1              |
| 6        | 06       | 0110      | LC         | ACK        |                          |            | •              |
| 7        | 07       | 0111      | DEL        | BEL        |                          | 3          | 3              |
| 8        | 08       | 1000      |            | BS         |                          | 4          | 5              |
| 9        | 09       | 1001      | RLF        | HT         |                          |            |                |
| 10       | 0A       | 1010      | SMM        | LF         | P (even parity)          |            |                |
| 11       | 0B       | 1011      | VT         | VT         | P (odd parity)           | 5          | 7              |
| 12       | 0C       | 1100      | FF         | FF         | 0 (even parity)          |            |                |
| 13       | 0D       | 1101      | CR         | CR         | 0 (odd parity)           | 6          | 6              |
| 14       | 0E       | 1110      | SO         | SO         |                          | 7          | 8              |
| 15       | 0F       | 1111      | SI         | SI         |                          |            | -              |
| 16       | 10       | 0001 0000 | DLE        | DLE        |                          | 8          | 4              |
| 17       | 11       | 0001      | DC1        | DC1        |                          |            |                |
| 18       | 12       | 0010      | DC2        | DC2        | H (even parity)          |            |                |
| 19       | 13       | 0011      | ТМ         | DC3        | H (odd parity)           | 9          | 0              |
| 20       | 14       | 0100      | RES        | DC4        | ( (even parity)          |            |                |
| 21       | 15       | 0101      | NL         | NAK        | ( (odd parity)           | 0          | Z              |
| 22       | 16       | 0110      | BS         | SYN        |                          | (EOA)      | (EOA),9        |
| 23       | 17       | 0111      | IL         | ETB        |                          | •          | •              |
| 24       | 18       | 1000      | CAN        | CAN        |                          |            |                |
| 25       | 19       | 1001      | ЕМ         | ЕМ         |                          |            |                |
| 26       | 1A       | 1010      | CC         | SUB        | [ [                      |            |                |
| 27       | 1B       | 1011      | CU1        | ESC        | x                        |            |                |
| 28       | 1C       | 1100      | IFS        | FS         |                          | upper case | upper case     |
| 29       | 1D       | 1101      | IGS        | GS         | 8                        | apper cutt | ₹              |
| 30       | 1E       | 1110      | IRS        | RS         | Ů                        |            | ~              |
| 31       | 1F       | 1111      | IUS        | US         |                          | (EOT)      | (EOT)          |
| 32       | 20       | 0010 0000 | DS         | space      |                          | @ (201)    | t (LOI)        |
| 33       | 21       | 0001      | SOS        | 1          | ЕОТ                      | Ŭ          | ·              |
| 34       | 22       | 0010      | FS         | ·<br>"     | D (even parity)          |            |                |
| 35       | 23       | 0011      | 15         | #          | D (odd parity)           | 1          | х              |
| 36       | 23       | 0100      | BYP        | \$         | S (even parity)          | 1          | ^              |
| 30       | 24<br>25 | 0100      | LF         | \$<br>%    | S (odd parity)           |            | n              |
| 38       | 23<br>26 | 0101      | ETB        | 70<br>&    | 5 (our parity)           | s<br>t     | u              |
| 38<br>39 | 26<br>27 | 0110      | EIB        | α<br>,     |                          | L I        | u              |
|          |          |           | Lac        | 6          |                          |            |                |
| 40       | 28<br>20 | 1000      |            | 5          |                          |            |                |
| 41       | 29<br>24 | 1001      | CM         | )          | [ [                      | u          | e              |
| 42       | 2A<br>2D | 1010      | SM         |            |                          | v          | d              |
| 43       | 2B       | 1011      | CU2        | +          | Т                        |            | 1.             |
| 44       | 2C       | 1100      | TNC        | ,          |                          | w          | k              |
| 45       | 2D       | 1101      | ENQ        | -          | 4                        |            |                |
| 46       | 2E       | 1110      | ACK        | •          |                          |            |                |
| 47       | 2F       | 1111      | BEL        | /          |                          | x          | c              |
| 48       | 30       | 0011 0000 |            | 0          | form feed                |            |                |
| 49       | 31       | 0001      | ar 11 -    | 1          | form feed                | У          | 1              |
| 50       | 32       | 0010      | SYN        | 2          |                          | Z          | h              |
| 51       | 33       | 0011      |            | 3          | L                        |            |                |
| 52       | 34       | 0100      | PN         | 4          | [                        |            |                |
| 53       | 35       | 0101      | RS         | 5          | ,                        |            |                |
| 54       | 36       | 0110      | UC         | 6          |                          |            |                |



|            |           | · ·               |             |                | Eight bit                         |              |                |
|------------|-----------|-------------------|-------------|----------------|-----------------------------------|--------------|----------------|
| Decimal    | Hex       | Binary            | EBCDIC      | ASCII          | data inter-<br>change             | PTTC/EBCD    | PTTC/          |
| 55         | 37        |                   | EOT         | 7              | chunge                            |              | Correspondence |
| 55<br>56   | 38        | 0011 0111<br>1000 | EOI         | 8              |                                   | (SOA), comma | b              |
| 57         | 39        | 1000              |             | 9              |                                   |              |                |
| 58         | 3A        | 1010              |             | :              | $\setminus$ (even parity)         |              |                |
| 59         | 3B        | 1011              | CU3         | ;              | \ (odd parity)                    | index        | index          |
| 60         | 3C        | 1100              | DC4         | <              | < (even parity)                   |              |                |
| 61         | 3D        | 1 1 0 1           | NAK         | =              | < (odd parity)                    | B (EOB)      |                |
| 62<br>62   | 3E        | 1110              | aven        | >              |                                   |              |                |
| 63<br>64   | 3F<br>40  | 1111<br>0100 0000 | SUB         | ?              |                                   |              |                |
| 64<br>65   | 40<br>41  | 0100 0000         | space       | @<br>A         | EOA                               | N .,-        | !              |
| 66         | 42        | 0010              |             | B              | B (even parity)                   |              |                |
| 67         | 43        | 0011              |             | c              | B (odd parity)                    | i            | m              |
| 68         | 44        | 0100              |             | D              | " (even parity)                   | -            |                |
| 69         | 45        | 0101              |             | E              | " (odd parity)                    | k            |                |
| 70         | 46        | 0110              |             | F              |                                   | 1            | v              |
| 71         | 47        | 0111              |             | G              |                                   |              |                |
| 72         | 48        | 1000              |             | н              |                                   |              |                |
| 73<br>74   | 49<br>4 A | 1001              | <u>ا</u>    | I              |                                   | m            | ,              |
| 74<br>75   | 4A<br>4B  | 1010<br>1011      | ¢           | J<br>K         | R                                 | n            | r              |
| 75<br>76   | 4В<br>4С  | 1100              | <           | L              | ĸ                                 | 0            | i              |
| 77         | 4C<br>4D  | 1100              | $\tilde{(}$ |                | 2                                 | 5            | L              |
| 78         | 4E        | 1110              | +           | N              | -                                 |              |                |
| 79         | 4F        | 1111              | ]           | 0              |                                   | р            | а              |
| 80         | 50        | 0101 0000         | &           | Р              | line feed                         |              |                |
| 81         | 51        | 0001              |             | Q              | line feed                         | q            | 0              |
| 82         | 52        | 0010              |             | R              |                                   | r            | S              |
| 83         | 53        | 0011              |             | S              | J                                 |              |                |
| 84         | 54        | 0100              |             | Т              |                                   |              |                |
| 85         | 55        | 0101              |             | U              | *                                 |              |                |
| 86<br>87   | 56<br>57  | 0110              |             | V<br>W         |                                   | \$           |                |
| 87<br>88   | 57<br>58  | 0111<br>1000      |             | x              |                                   | <b>\$</b>    | w              |
| 88<br>89   | 59        | 1000              |             | Ŷ              |                                   |              |                |
| 90         | 5A        | 1010              | !           | z              | Z (even parity)                   |              |                |
| 91         | 5B        | 1011              | \$          | [              | Z (odd parity)                    | CRLF         | CRLF           |
| 92         | 5C        | 1100              | *           | Ň              | : (even parity)                   |              |                |
| 93         | 5D        | 1101              | )           | ]              | : (odd parity)                    | backspace    | backspace      |
| 94         | 5E        | 1110              | ;           | Л              |                                   | idle         | idle           |
| 95         | 5F        | 1111              |             |                |                                   |              |                |
| 96         | 60        | 0110 0000         | -           |                | ACK                               |              |                |
| 97         | 61<br>62  | 0001              | /           | a              |                                   | &            | j<br>g         |
| 98<br>99   | 62<br>63  | 0010<br>0011      |             | b<br>c         | F                                 | a            | g              |
| 99<br>100  | 63<br>64  | 0100              |             | d              | <                                 | b            |                |
| 100        | 65        | 0100              |             | e              | &                                 | ~            |                |
| 102        | 66        | 0110              |             | f              |                                   |              |                |
| 103        | 67        | 0111              |             | g              |                                   | c            | f              |
| 104        | 68        | 1000              |             | h              |                                   | d            | р              |
| 105        | 69        | 1001              |             | i              |                                   |              |                |
| 106        | 6A        | 1010              | i           | j              | V (even parity)                   |              |                |
| 107        | 6B        | 1011              | ,           | k<br>1         | V (odd parity)                    | e            |                |
| 108<br>109 | 6C<br>6D  | 1100<br>1101      | 9           | 1<br>m         | 6 (even parity)<br>6 (odd parity) | f            | q              |
| 109        | 6D<br>6E  | 1101              | - >         | n              | o (ouu parity)                    | g            | ч<br>comma     |
| 111        | 6F        | 1110              | ?           | 0              |                                   | 5            | vomma          |
| 1112       | 70        | 0111 0000         | -           | р <sup>.</sup> |                                   | h            | 1              |
| 113        | 71        | 0001              |             | q              | shift out                         |              |                |
| 114        | 72        | 0010              |             | r              | N (even parity)                   |              |                |
| 115        | 73        | 0011              |             | s              | N (odd parity)                    | i            | у              |
| 116        | 74        | 0100              |             | t              | . (even parity)                   |              |                |

C

| -       |     |           |        |       | Eight bit       |              |                |
|---------|-----|-----------|--------|-------|-----------------|--------------|----------------|
|         |     |           |        |       | data inter-     |              | PTTC/          |
| Decimal | Hex | Binary    | EBCDIC | ASCII | change          | PTTC/EBCD    | Correspondence |
| 117     | 75  | 0111 0101 |        | u     | . (odd parity)  |              |                |
| 118     | 76  | 0110      |        | v     |                 | (Y) ,period  |                |
| 119     | 77  | 0111      |        | w     |                 | <b>U</b>     |                |
| 120     | 78  | 1000      |        | x     |                 |              |                |
| 121     | 79  | 1001      |        | у     |                 |              |                |
| 122     | 7A  | 1010      | :      | z,    |                 | horiz tab    | tab            |
| 123     | 7B  | 1011      | #      | {     | 1               |              |                |
| 124     | 7C  | 1100      | @      | 1     |                 | lower case   | lower case     |
| 125     | 7D  | 1101      | ,      | }     | >               |              |                |
| 126     | 7E  | 1110      | =      | ~     |                 |              |                |
| 127     | 7F  | 1111      | "      | DEL   |                 | delete       |                |
| 128     | 80  | 1000 0000 |        |       |                 |              |                |
| 129     | 81  | 0001      | a      |       | SOM             | space        | space          |
| 130     | 82  | 0010      | b      |       | A (even parity) | =            | ±, [           |
| 131     | 83  | 0011      | c      |       | A (odd parity)  |              |                |
| 132     | 84  | 0100      | d      |       | ! (even parity) | <            | @              |
| 133     | 85  | 0101      | e      |       | ! (odd parity)  |              |                |
| 134     | 86  | 0110      | f      |       |                 |              |                |
| 135     | 87  | 0111      | g      |       |                 | ;            | #              |
| 136     | 88  | 1000      | h      |       | X-ON            | :            | %              |
| 137     | 89  | 1001      | i      |       |                 |              |                |
| 138     | 8A  | 1010      |        |       |                 |              |                |
| 139     | 8B  | 1011      |        |       | Q               | %            | &              |
| 140     | 8C  | 1100      |        |       |                 |              |                |
| 141     | 8D  | 1101      |        |       | 1               | ,            | ¢              |
| 142     | 8E  | 1110      |        |       |                 | >            | *              |
| 143     | 8F  | 1111      |        |       |                 |              |                |
| 144     | 90  | 1001 0000 |        |       | horiz tab       | *            | \$             |
| 145     | 91  | 0001      | j      |       | horiz tab       |              |                |
| 146     | 92  | 0010      | k      |       |                 |              |                |
| 147     | 93  | 0011      | 1      |       | I               | (            | )              |
| 148     | 94  | 0100      | m      |       |                 |              |                |
| 149     | 95  | 0101      | n      |       | )               | )            | Z              |
| 150     | 96  | 0110      | 0      |       |                 | (EOA),"      | (              |
| 151     | 97  | 0111      | p      |       |                 |              |                |
| 152     | 98  | 1000      | q      |       |                 |              |                |
| 153     | 99  | 1001      | r      |       |                 |              |                |
| 154     | 9A  | 1010      |        |       | Y (even parity) |              |                |
| 155     | 9B  | 1011      |        |       | Y (odd parity)  |              |                |
| 156     | 9C  | 1100      |        |       | 9 (even parity) | upper case   | upper case     |
| 157     | 9D  | 1101      |        |       | 9 (odd parity)  |              |                |
| 158     | 9E  | 1110      |        |       |                 |              | •              |
| 159     | 9F  | 1111      |        |       |                 | (EOT)        | C (EOT)        |
| 160     | A0  | 1010 0000 |        |       | WRU (even)      | © (ЕОТ)<br>¢ | Т              |
| 161     | A1  | 0001      | ~      |       | WRU (odd)       |              |                |
| 162     | A2  | 0010      | s      |       |                 |              |                |
| 163     | A3  | 0011      | t      |       | E               | ?            | Х              |
| 164     | A4  | 0100      | u      |       |                 |              |                |
| 165     | A5  | 0101      | v      |       | %               | S            | N              |
| 166     | A6  | 0110      | w      |       |                 | Т            | U              |
| 167     | A7  | 0111      | х      |       |                 |              |                |
| 168     | A8  | 1000      | у      |       |                 |              |                |
| 169     | A9  | 1001      | z      |       |                 | U            | Ε              |
| 170     | AA  | 1010      | Γ      |       | U (even parity) | v            | D              |
| 171     | AB  | 1011      |        |       | U (odd parity)  |              |                |
| 172     | AC  | 1100      |        |       | 5 (even parity) | W            | K              |
| 173     | AD  | 1101      |        |       | 5 (odd parity)  |              |                |
| 174     | AE  | 1110      |        |       |                 |              |                |
| 175     | AF  | 1111      |        |       |                 | X            | С              |
| 176     | B0  | 1011 0000 |        |       |                 |              |                |
| 177     | B1  | 0001      |        |       | return          | Y            | L              |
| 178     | B2  | 0010      |        |       | M (even parity) | Z            | Н              |

.

C

Character Codes E-3

-

|              |          |              |          |       | Eight bit                         |               |               |
|--------------|----------|--------------|----------|-------|-----------------------------------|---------------|---------------|
|              |          |              |          |       | data inter-                       |               | PTTC/         |
| Decimal      | Hex      | Binary       | EBCDIC   | ASCII | change                            | PTTC/EBCD     | Correspondenc |
| 179          | B3       | 1011 0011    |          |       | M (odd parity)                    |               |               |
| 180          | B4       | 0100         |          |       | - (even parity)                   |               |               |
| 101          | B5       | 0101         |          |       | (a did marian)                    |               |               |
| 181<br>182   | в5<br>В6 | 0101<br>0110 |          |       | - (odd parity)                    |               |               |
| 182          | B7       | 0110         |          |       |                                   | (\$) (SOA), 1 | В             |
| 184          | B8       | 1000         |          |       | ×                                 | (SOA), '      | D             |
| 185          | B9       | 1001         |          |       |                                   |               |               |
| 186          | BA       | 1010         |          |       |                                   |               |               |
| 187          | BB       | 1011         |          |       | ]                                 | index         | index         |
| 188          | BC       | 1100         |          |       | -                                 |               |               |
| 189          | BD       | 1101         |          |       | =                                 | (EOB)         |               |
| 1 <b>9</b> 0 | BE       | 1110         |          |       |                                   | -             |               |
| 191          | BF       | 1111         |          |       |                                   |               |               |
| 192          | C0       | 1100 0000    | {        |       | EOM (even)                        | N ,-          |               |
| 193          | C1       | 0001         | Α        |       | EOM (odd)                         |               |               |
| 194          | C2       | 0010         | В        |       |                                   |               |               |
| 195          | C3       | 0011         | С        |       | С                                 | J             | М             |
| 196          | C4       | 0100         | D        |       |                                   |               |               |
| 197          | C5       | 0101         | E        |       | #                                 | K             |               |
| 198          | C6       | 0110         | F        |       |                                   | L             | v             |
| 199          | C7       | 0111         | G        |       |                                   |               |               |
| 200          | C8       | 1000         | Н        |       | NAUE                              |               | **            |
| 201          | C9       | 1001         | I        |       | X-OFF                             | M             |               |
| 202          | CA       | 1010         |          |       | S (even parity)                   | N             | R             |
| 203          | CB       | 1011         | ጌ        | ļ     | S (odd parity)                    |               |               |
| 204          | CC       | 1100         | U        | ł     | 3 (even parity)                   | 0             | I             |
| 205<br>206   | CD<br>CE | 1101<br>1110 | ų        |       | 3 (odd parity)                    |               |               |
| 200<br>207   | CF       | 1110         | Т        |       |                                   | Р             | Α             |
| 207          | D0       | 1101 0000    | }        |       |                                   | I             | А             |
| 200<br>209   | D1       | 0001         | J ,      |       | vertical tab                      | Q             | 0             |
| 210          | D2       | 0010         | ĸ        |       | K (even parity)                   | R             | Š             |
| 211          | D3       | 0011         | L        |       | K (odd parity)                    |               | 5             |
| 212          | D4       | 0100         | M        |       | + (even parity)                   |               |               |
| 213          | D5       | 0101         | N        |       | + (odd parity)                    |               |               |
| 214          | D6       | 0110         | 0        |       |                                   |               |               |
| 215          | D7       | 0111         | Р        |       |                                   | !             | W             |
| 216          | D8       | 1000         | Q        | ļ     |                                   |               |               |
| 217          | D9       | 1001         | R        |       |                                   |               |               |
| 218          | DA       | 1010         |          |       |                                   |               | _             |
| 219          | DB       | 1011         |          |       | [                                 | CRLF          | CRLF          |
| 220          | DC       | 1100         |          |       |                                   |               |               |
| 221          | DD       | 1101         |          |       | ;                                 | backspace     | backspace     |
| 222          | DE       | 1110         |          | 1     |                                   | idle          | idle          |
| 223          | DF       | 1111         | <b>,</b> |       | PAD                               |               |               |
| 224          | E0       | 1110 0000    | 1        | Į     | hall                              |               | т             |
| 225<br>226   | E1<br>E2 | 0001<br>0010 | l c      |       | bell<br>C (even parity)           | +             | J<br>G        |
| 226<br>227   | E2<br>E3 | 0010         | S<br>T   |       | G (even parity)<br>G (odd parity) | A             | ŭ             |
| 227          | E3<br>E4 | 0100         | U<br>U   |       | , (even parity)                   | В             | +             |
| 228<br>229   | E4<br>E5 | 0100         | v        |       | , (odd parity)                    |               |               |
| 230          | E6       | 0101         | w        |       | , (our parity)                    |               |               |
| 230<br>231   | E7       | 0110         | x        |       |                                   | С             | F             |
| 232          | E8       | 1000         | Y        | 1     | 1                                 | D             | F<br>P        |
| 232          | E9       | 1000         | z        |       |                                   |               | -             |
| 234          | EA       | 1010         | 1        |       |                                   |               |               |
| 235          | EB       | 1010         |          |       | w                                 | Е             |               |
| 236          | EC       | 1100         | Н        |       |                                   |               |               |
| 237          | ED       | 1101         | 1.       |       | 7                                 | F             | Q             |
| 238          | EE       | 1110         |          |       | 1                                 | G             | comma         |
| 239          | EF       | 1111         | 1        | 1     |                                   | 1             |               |

 $\bigcirc$ 

| Decimal | Hex | Binary    | EBCDIC | ASCII | Eight bit<br>data inter-<br>change | PTTC/EBCD  | PTTC/<br>Correspondence |
|---------|-----|-----------|--------|-------|------------------------------------|------------|-------------------------|
| 240     | F0  | 1111 0000 | 0      |       | shift in (even)                    | Н          | ?                       |
| 241     | F1  | 0001      | 1      |       | shift in (odd)                     |            |                         |
| 242     | F2  | 0010      | 2      |       |                                    |            |                         |
| 243     | F3  | 0011      | 3      |       | 0                                  | I          | Y                       |
| 244     | F4  | 0100      | 4      |       |                                    |            |                         |
| 245     | F5  | 0101      | 5      |       | 1                                  |            |                         |
| 246     | F6  | 0110      | 6      |       |                                    | 𝒮, ¬       |                         |
| 247     | F7  | 0111      | 7      |       |                                    |            |                         |
| 248     | F8  | 1000      | 8      |       |                                    |            |                         |
| 249     | F9  | 1001      | 9      |       |                                    |            |                         |
| 250     | FA  | 1010      | LVM    |       | ← (even parity)                    | horiz tab  | tab                     |
| 251     | FB  | 1011      |        |       | ← (odd parity)                     |            |                         |
| 252     | FC  | 1100      |        |       | ? (even parity)                    | lower case | lower case              |
| 253     | FD  | 1101      |        |       | ? (odd parity)                     |            |                         |
| 254     | FE  | 1110      |        |       |                                    |            |                         |
| 255     | FF  | 1111      |        |       | delete<br>rub out                  | delete     |                         |

 $\square$ 

E-6 GA34-0021

# Appendix F. Carry and Overflow Indicators

This appendix explains the meaning of the carry and overflow indicators for signed and unsigned numbers. Examples for setting these indicators are also provided.

### Signed Numbers

For signed addition and subtraction, the overflow indicator signals a result that exceeds the representation capability of the system for the result operand size. When overflow is indicated, the carry indicator and the resulting operand together form a valid result with the carry indicator being the most significant bit. For addition, the carry indicator is the sign (high-order bit) of this result. For subtraction, the carry indicator is the complement of the sign (highorder bit) of the result. A negative result appears in two's complement form. When no overflow is indicated, the carry indicator provides no information about the result.

Figure F-1 shows how the carry and overflow indicators are set for an add operation when using 16-bit operands. Figure F-2 provides the same information for a subtract operation.

### SIGNED NUMBERS

# ADD OPERATION-All possible results (16-bit example) Indicators Result value



Notes.

- 1. When overflow occurs, the carry indicator and the result together form a valid 17-bit signed number, of which the carry is the sign, and the result is the magnitude. A negative result is in two's complement from. When no overflow occurs, no useful information is provided by the carry indicator.
- 2. The carry indicator may be on or off depending on the operands.
- Figure F-1. All possible results of an add operation regarding the operands as signed 16-bit numbers

### SIGNED NUMBERS

SUBTRACT OPERATION-All possible results (16-bit example)



### Notes.

- 1. When overflow occurs, the carry indicator and the result form a valid 17-bit signed number, of which the carry is the complement of the correct sign, and the result is the magnitude. A negative result is in two's complement form. When no overflow occurs, no useful information is provided by the carry indicator.
- 2. The carry indicator may be on or off depending on the operands.
- Figure F-2. All possible results of a subtract operation regarding the operands as signed 16-bit numbers

### **Unsigned Numbers**

For unsigned addition and subtraction, the carry indicator signals that:

- 1. On an add instruction, a carry out of the high-order bit position has occurred (result exceeds result operand size). The carry indicator and the resulting operand together form a valid result of which the carry indicator is the most significant bit.
- 2. On a subtract operation, a borrow beyond the highorder bit position has occurred. A borrow during a subtract operation is defined as either of the following:
  - No carry is generated out of the high-order bit position when a two's complement of the subtrahend and add is performed to accomplish the subtract operation.
  - The most significant digit of the minuend must be made larger to generate a difference of zero or one when subtracting the most significant digit of the subtrahend; for example, 1 subtracted from 0.

When a borrow is signalled on a subtract operation, the result is in two's complement form.

The overflow indicator provides no useful information about unsigned operations.

Figure F-3 shows how the carry and overflow indicators are set for an add operation when using 16-bit operands. Figure F-4 provides the same information for a subtract operation.

### UNSIGNED NUMBERS

### ADD OPERATION-All possible results (16-bit example)

| Indicat  | ors   | Result v    | alue    |                   |
|----------|-------|-------------|---------|-------------------|
| Overflow | Carry | Hexadecimal | Decimal |                   |
| (Note 2) |       | 0000        | 0       | )                 |
|          |       | •           |         |                   |
|          |       | 7FFF        | 32767   | 16-bit            |
|          |       | 8000        | 32768   | representable     |
|          |       | •           |         | range             |
|          |       | •           |         |                   |
|          |       | FFFE        | 65534   |                   |
|          |       | FFFF        | 65535   | /                 |
|          | 1     | 0000        | 65536   | )                 |
|          |       | •           |         |                   |
|          |       | •           |         | 17-bit range      |
|          |       | 7FFF        | 98303   | s using carry bit |
|          |       | 8000        | 98304   | (See Note 1)      |
|          | Ţ     | •           |         |                   |
|          | Y     | •           |         | 1                 |
|          | 1     | FFFE        | 131070  | /                 |

### Notes.

- 1. With the carry indicator on, the result and carry form a valid 17-bit unsigned number of which the carry is the most significant bit.
- 2. The overflow indicator may be set; however, it provides no useful information.

Figure F-3. All possible results of an add operation regarding the operands as unsigned 16-bit numbers

### UNSIGNED NUMBERS

SUBTRACT OPERATION-All possible results (16-bit example)

| Indicators |       | Result va   | alue    | <b>-</b> -     |
|------------|-------|-------------|---------|----------------|
| Overflow   | Carry | Hexadecimal | Decimal |                |
| (Note 2)   | 1     | 0001        | 65535   |                |
|            |       |             |         | 17-bit         |
|            |       | 7FFF        | -32769  | negative range |
|            |       | 8000        | -32768  | (See Note 1)   |
|            |       | 8001        | -32767  |                |
|            |       | •           |         |                |
|            | 1     | •           |         |                |
|            |       | •           |         |                |
|            | 1     | FFFF        | -1      | /              |
|            |       | 0000        | 0       |                |
|            |       | 0001        | +1      |                |
|            |       | •           |         |                |
|            |       | •           |         | 16-bit         |
|            |       | 7FFF        | +32767  | representable  |
|            |       | 8000        | +32768  | range          |
|            |       | •           |         |                |
|            |       | •           |         |                |
|            |       | •           |         |                |
|            |       | FFFF        | +65535  | /              |

### Notes.

- 1. With carry (borrow) on, the result and carry indicator form a valid 17-bit negative number of which the carry is the sign and result is the magnitude in normal two's complement form.
- 2. The overflow indicator may be set; however, it provides no useful information.

Figure F-4. All possible results of a subtract operation regarding the operands as unsigned 16-bit numbers

### **Carry Indicator Setting**

The carry indicator is used to signal overflow of the result when operands are presented as unsigned numbers. The machine does not regard the numbers as either signed or unsigned, but performs the designated operation (add or subtract) on the values presented. The programmer must interpret the condition of the result for the number representation involved. The machine detects the carry condition during the operation in two ways:

- 1. Add operation when a carry out of the high-order bit position of the result operand occurs.
- 2. Subtract operation when a borrow beyond the highorder bit position of the result operand occurs.

### Add Operation Examples

A four-bit operand size is used in the following examples. Note that the unsigned number range for this operand is 0 to 15. No other unsigned number values may be represented for this size operand.

Addition (carry indicator is not set) Desired operation: 6 + 9 = 15

| Machine operation: | Augend<br>Addend | 0110<br>1001 |
|--------------------|------------------|--------------|
|                    | Result           | 1111         |
|                    | •                |              |

High-order bit carry = 0

The result fits as an unsigned number. The carry indicator is not set (C=0).

Addition (carry indicator is set) Desired operation: 15 + 1 = 16

| Machine operation: | Augend | 1111 |
|--------------------|--------|------|
|                    | Addend | 0001 |
|                    | Result | 0000 |

High-order bit carry = 1

The result does not fit as an unsigned number. The carry indicator is set (C=1).

Addition (carry indicator is set)

| Desired operation: | 15 + 15 = 30 |      |
|--------------------|--------------|------|
| Machine operation: | Augend       | 1111 |
|                    | Addend       | 1111 |
|                    | Result       | 1110 |

Result

High-order bit carry = 1

Result does not fit as an unsigned number. The carry indicator is set (C=1).

Note. The result of adding the two largest numbers can be contained in the operand size and the carry indicator. The carry indicator represents the most significant bit.

Carry and Overflow Indicators F-3

## Subtract Operation Examples

The processor performs subtraction by using the complement addition method. The second operand is complemented (two's complement) then an add operation is performed. This is actually a three-way add operation between the minuend, the subtrahend (one's complement), and a constant of one. To provide the correct carry (borrow) indication for the subtraction, the carry result of the complement add operation must be inverted to determine the carry indicator setting. The following examples use a four-bit operand with an unsigned number range of 0 to 15.

| ٠ | Subtract (carry indicator is not set) |             |  |                                          |  |  |  |
|---|---------------------------------------|-------------|--|------------------------------------------|--|--|--|
|   | Desired operation:                    | 15 – 1 = 14 |  |                                          |  |  |  |
|   | Machine operation:                    |             |  | one's complement<br>for two's complement |  |  |  |
|   | High-order bit carry                  | = 1         |  | invert for carry<br>indicator            |  |  |  |

The result fits as an unsigned number. The carry indicator is not set (C=0).

Note. The carry indicator setting (C=0) for this subtract operation was determined by inverting the complement-add carry.

### • Subtract (carry indicator is not set)

| Desired operation:   | 15 - 15 = 0 |                            |
|----------------------|-------------|----------------------------|
| Machine operation:   | Minuend     | 1111                       |
|                      | Subtrahend  | 0000 one's complement      |
|                      | Constant    | for two's complement       |
|                      | Result      | 0000                       |
| High-order bit carry | = 1         | invert for carry indicator |

The result fits as an unsigned number. The carry indicator is not set (C=0).

### • Subtract (carry indicator is set)

The following two examples show the case of a negative result (subtrahend greater than minuend). This negative result cannot be represented in the operand width because all operand bits are used to represent the unsigned number. To flag this condition the carry indicator is set.

| Example 1.           |                                   |                                                         |
|----------------------|-----------------------------------|---------------------------------------------------------|
| Desired operation:   | 0 - 1 = -1                        |                                                         |
| Machine operation:   | Minuend<br>Subtrahend<br>Constant | 0000<br>1110 one's complement<br>1 for two's complement |
|                      | Result                            | 1111                                                    |
| High-order bit carry | r = 0                             | invert for carry indicator                              |

The result does not fit as an unsigned number. The carry indicator is set (C=1).

| Example 2.           |              |        |                      |
|----------------------|--------------|--------|----------------------|
| Desired operation:   | 0 - 15 = -15 |        |                      |
| Machine operation:   | Minuend      | 0000   |                      |
|                      | Subtrahend   | 0000   | one's complement     |
|                      | Constant     | 1      | for two's complement |
|                      | Result       | 0001   | •                    |
| High-order bit carry | = 0          | invert | for carry indicator  |

The result does not fit as an unsigned number. The carry indicator is set (C=1).

*Note.* When a negative result occurs on a subtract operation, the values may be useful to the programmer. The carry indicator and the result form a signed number. The carry indicator is the sign and the result is the number in two's complement form (see Figure F-4).

## **Overflow Indicator Setting**

The overflow indicator is used to signal overflow of the result when the operands are presented as *signed* numbers. The machine does not regard the numbers as either signed or unsigned, but performs the designated operation (add or subtract) on the values presented. The programmer must interpret the condition of the result for the number representation involved. The machine detects this condition by inspection of any carry into and out of the high-order bit (sign position) of the result operand during the operation. The overflow indicator is set (O = 1) for the two cases where the carries disagree:

- 1. A carry into, but no carry out of the sign position.
- 2. No carry into, but a carry out of the sign position.

The overflow indicator is not set (O = 0) for the remaining two cases where the carries agree:

- 1. A carry into and out of the sign position.
- 2. No carry into and no carry out of the sign position.

# Examples

A four-bit operand size is used in the following examples. Note that the signed number range for a four-bit operand is -8 to +7. No other signed number values may be represented.

• Addition (overflow indicator is not set) Desired operation: +5 + (+2) = +7Machine operation: Augend 0101 0010 Addend 0111 Result Carry into sign position = 0 Carry out of sign position = 0carries agree The result fits as a signed number. The overflow indicator is not set (O = 0). Desired operation: -4 + (-4) = -8Machine operation: Augend 1100 two's complement Addend 1100 two's complement Result 1000 two's complement Carry into sign position = 1 Carry out of sign position = 1 carries agree The result fits as a signed number. The overflow indicator is not set (O = 0). Addition (overflow indicator is set) Desired operation: +4 + (+4) = +8Machine operation: Augend 0100 Addend 0100 1000 Result Carry into sign position = 1 Carry out of sign position = 0carries disagree The result does not fit as a signed number. The overflow indicator is set (O = 1). Desired operation: -4 + (-5) = -9Machine operation: Augend 1100 two's complement Addend 1011 two's complement Result 0111 Carry into sign position = 0 Carry out of sign position = 1carries disagree

The result does not fit as a signed number. The overflow indicator is set (O = 1).

• Subtraction (overflow indicator is not set) Desired operation: +7 - (+2) = +50111 Machine operation: Minuend 1101 one's complement Subtrahend 1 for two's complement Constant 0101 Result Carry into sign position = 1 Carry out of sign position = 1carries agree The result fits as a signed number. The overflow indicator is not set (0 = 0). Desired operation: +5 - (-1) = +6Note. -1 is equal to 1111 Machine operation: Minuend 0101 Subtrahend 0000 one's complement Constant 1 for two's complement 0110 Result Carry into sign position = 0 Carry out of sign position = 0carries agree The result fits as a signed number. The overflow indicator is not set (O = 0). Subtraction (overflow indicator is set). Desired operation: +7 - (-2) = +9Note. -2 is equal to 1110 Machine operation: Minuend 0111 Subtrahend 0001 one's complement Constant 1 for two's complement Result 1001 Carry into sign position = 1 Carry out of sign position = 0carries disagree The result does not fit as a signed number. The overflow indicator is set (O = 1). Desired operation: -3 - (+6) = -9Machine operation: Minuend 1101 two's complement Subtrahend 1001 one's complement Constant 1 for two's complement Result 0111 Carry into sign position = 0Carry out of sign position = 1 carries disagree

The result does not fit as a signed number. The overflow indicator is set (O = 1).

.

# s's .

. .

F-6 GA34-0021

.

C

# Appendix G. Reference Information

This appendix contains the following reference information:

- Address key register (AKR) ۰
- Condition codes •
- General registers •
- Interrupt status byte ۰
- Level status register (LSR)
- Processor status word (PSW)

# Address Key Register (AKR)

# Bits Contents

- 0 Equate operand spaces
- (not used, always zero) 1
- (not used, always zero) 2
- (not used, always zero) 3
- 4 (not used, always zero) Operand-1 key (bit 0) 5
- Operand-1 key (bit 1) 6
- Operand-1 key (bit 2) 7
- 8 (not used, always zero)
- 9 Operand-2 key (bit 0)
- 10 Operand-2 key (bit 1)
- Operand-2 key (bit 2) 11
- (not used, always zero) 12
- 13 Instruction space key (bit 0)
- 14 Instruction space key (bit 1)
- 15 Instruction space key (bit 2)

# **Condition Codes**

# I/O Instruction Condition Codes

These codes are reported during execution of an Operate I/O instruction.

| Condition          |      | LSR posit | tion          |                |                       |
|--------------------|------|-----------|---------------|----------------|-----------------------|
| code (CC)<br>value | Even | Carry     | Over-<br>flow | Reported<br>by | Meaning               |
| 0                  | 0    | 0         | 0             | channel        | Device not attached   |
| 1                  | 0    | 0         | 1             | device         | Busy                  |
| 2                  | 0    | 1         | 0             | device         | Busy after reset      |
| 3                  | 0    | 1         | 1             | chan/dev       | Command reject        |
| 4                  | 1    | 0         | 0             | device         | Intervention required |
| 5                  | 1    | 0         | 1             | chan/dev       | Interface data check  |
| 6                  | 1    | 1         | 0             | controller     | Controller busy       |
| 7                  | 1    | 1         | 1             | chan/dev       | Satisfactory          |

# Interrupt Condition Codes

These condition codes are reported by the device or controller during priority interrupt acceptance.

| Condition | L    | SR positio | n     |            |                          |
|-----------|------|------------|-------|------------|--------------------------|
| code (CC) |      |            | Over- | Reported   |                          |
| value     | Even | Carry      | flow  | by         | Meaning                  |
| 0         | 0    | 0          | 0     | controller | Controller end           |
| 1         | 0    | 0          | 1     | device     | Program controlled       |
|           |      |            |       |            | interrupt (PCI)          |
| 2         | 0    | 1          | 0     | device     | Exception                |
| 3         | 0    | 1          | 1     | device     | Device end               |
| 4         | 1    | 0          | 0     | device     | Attention                |
| 5         | 1    | 0          | 1     | device     | Attention and PCI        |
| 6         | 1    | 1          | 0     | device     | Attention and exception  |
| 7         | 1    | 1          | 1     | device     | Attention and device end |

## **General Registers**

| R or RB* field value | Register selected |
|----------------------|-------------------|
| 000                  | Register 0        |
| 001                  | Register 1        |
| 010                  | Register 2        |
| 011                  | Register 3        |
| 100                  | Register 4        |
| 101                  | Register 5        |
| 110                  | Register 6        |
| 111                  | Register 7        |

\*The RB field sometimes contains only the two low-order bits. In this case, registers 4 through 7 cannot be specified.

# Interrupt Status Byte (ISB)

## **DPC Devices**

- **Bits** Contents
- 0 Device status available
- Delayed command reject 1
- 2 Device dependent
- 3 Device dependent
- 4` Device dependent
- 5 Device dependent
- 6 Device dependent 7
- Device dependent

## **Cycle Steal Devices**

- Bits Contents
- 0 Device status available
- 1 Delayed command reject
- 2 Incorrect length record
- 3 DCB specification check
- 4 Storage data check
- 5 Invalid storage address
- 6 Protect check
- 7 Interface data check

# Level Status Register (LSR)

- Bit Contents
- 0 Even indicator
- 1 Carry indicator
- 2 Overflow indicator
- 3 Negative result indicator
- 4 Zero result indicator
- 5 (not used, always zero)
- 6 (not used, always zero)
- 7 (not used, always zero)
- 8 Supervisor state
- 9 In process
- 10 Trace
- 11 Summary mask
- 12 (not used, always zero)
- 13 (not used, always zero)
- 14 (not used, always zero)
- 15 (not used, always zero)

## Processor Status Word (PSW)

- Bit Contents
- 0 Specification check
- 1 Invalid storage address
- 2 Privilege violate
- 3 Protect check
- 4 Invalid function
- 5 Floating-point exception
- 6 Stack exception
- 7 (not used, always zero)
- 8 Storage parity check
- 9 (not used, always zero)
- 10 CPU control check
- 11 I/O check
- 12 Sequence indicator
- 13 Auto-IPL
- 14 Translator enabled
- 15 Power/thermal warning

# Index

add byte (AB) instruction 8-2 add byte immediate (ABI) instruction 8-3 add carry register (ACY) instruction 8-3 add double word (AD) instruction register/storage format 8-4 storage/storage format 8-4 add word (AW) instruction register/register 8-5 register/storage format 8-5 storage/storage format 8-6 storage to register long format 8-6 add word immediate (AWI) instruction register immediate long format 8-7 storage immediate format 8-8 add word with carry (AWCY) instruction 8-7 address generation, effective 2-12 address key register (AKR) 2-5, 5-1 address key register (AKR), example of use 5-2 address mode (AM) 2-14 address space management 5-3 active address key 5-3 address key values after interrupts 5-5 address space 5-4 AKR (see address key register) AKR key, console 7-8 alternate IPL source, console switch 7-2 ALU (see arithmetic and logic unit) AM (see address mode) and word immediate (NWI) instruction 8-59 arithmetic and logic unit (ALU) 2-3 assembler syntax, summary of C-1 attention and device end condition code 4-20 attention and exception condition code 4-20 attention and PCI condition code 4-19 attention condition code 4-19 auto IPL, bit in PSW 3-11 auto IPL mode, console switch 7-2

base règister (RB) used for effective address generation 2-13 basic console 7-2 branch and link (BAL) instruction 8-10 branch and link external (BALX) instruction 8-10 branch and link short (BALS) instruction 8-10 branch external (BX) instruction 8-9 branch if mixed (BMIX) instruction 8-11 branch if negative (BN) instruction 8-11 branch if not off (BNOFF) instruction 8-13 branch if not on (BNON) instruction 8-13 branch if off (BOFF) instruction 8-11 branch if on (BON) instruction 8-11 branch if on (BON) instruction 8-11 branch if on (BON) instruction 8-11 branch if on (BON) instruction 8-11 branch/jump instructions branch and link (BAL) 8-10 branch and link external (BALX) branch and link short (BALS) 8-10 branch indexed short (BXS) 8-16 branch on condition (BC) 8-11 branch if mixed (BMIX) branch if negative (BN) branch if off (BOFF) branch if on (BON) branch on arithmetically less than (BLT) branch on arithmetically less than or equal (BLE) branch on carry (BCY) branch on equal (BE) branch on even (BEV) branch on logically less than (BLLT) branch on logically less than or equal (BLLE) branch on positive (BP) branch on zero (BZ) branch on condition code (BCC) 8-12 branch on not error (BNER) branch on not condition (BNC) 8-13 branch if not off (BNOFF) branch if not on (BNON) branch on arithmetically greater than (BGT) branch on arithmetically greater than or equal (BGE) branch on logically greater than (BLGT) branch on logically greater than or equal (BLGE) branch on no carry (BNCY) branch on not equal (BNE) branch on not even (BNEV) branch on not mixed (BNMIX) branch on not negative (BNN) branch on not positive (BNP) branch on not zero (BNZ) branch on not condition code (BNCC) 8-14 branch on error (BER) branch on not overflow (BNOV) 8-15 branch on overflow (BOV) 8-15 branch unconditional (B) 8-9 branch external (BX) jump and link (JAL) 8-40 jump on condition (JC) 8-41 jump if mixed (JMIX) jump if off (JOFF) jump if on (JON) jump on arithmetically less than (JLT) jump on arithmetically less than or equal (JLE) jump on carry (JCY) jump on equal (JE) jump on even (JEV) jump on logically less than (JLLT) jump on logically less than or equal (JLLE)

branch/jump instructions (continued) jump on condition (JC) (continued) jump on negative (JN) jump on positive (JP) jump on zero (JZ) jump on count (JCT) 8-42 jump on not condition (JNC) 8-43 jump if not off (JNOFF) jump if not on (JNON) jump on arithmetically greater than (JGT) jump on arithmetically greater than or equal (JGE) jump on logically greater than (JLGT) jump on logically greater than or equal (JLGE) jump on no carry (JNCY) jump on not equal (JNE) jump on not even (JNEV) jump on not mixed (JNMIX) jump on not negative (JNN) jump on not positive (JNP) jump on not zero (JNZ) jump unconditional (J) 8-39 no operation (NOP) 8-59 branch on arithmetically greater than (BGT) instruction 8-13 branch on arithmetically greater than or equal (BGE) instruction 8-13 branch on arithmetically less than (BLT) instruction 8-11 branch on arithmetically less than or equal (BLE) instruction 8-11 branch on carry (BCY) instruction 8-11 branch on condition (BC) instruction 8-11 branch on condition code (BCC) instruction 8-12 branch on equal (BE) instruction 8-11 branch on error (BER) instruction 8-14 branch on even (BEV) instruction 8-11 branch on logically greater than (BLGT) instruction 8-13 branch on logically greater than or equal (BLGE) instruction 8-13 branch on logically less than (BLLT) instruction 8-11 branch on logically less than or equal (BLLE) instruction 8-11 branch on no carry (BNCY) instruction 8-13 branch on not condition (BNC) instruction 8-13 branch on not condition code (BNCC) instruction 8-14 branch on not equal (BNE) instruction 8-13 branch on not error (BNER) instruction 8-12 branch on not even (BNEV) instruction 8-13 branch on not mixed (BNMIX) instruction 8-13 branch on not negative (BNN) instruction 8-13 branch on not overflow (BNOV) instruction 8-15 branch on not positive (BNP) instruction 8-13 branch on not zero (BNZ) instruction 8-13 branch on overflow (BOV) instruction 8-15 branch on positive (BP) instruction 8-11 branch on zero (BZ) instruction 8-11 branch unconditional (B) instruction 8-9 burst mode 4-13 busy, condition code 4-19 busy after reset, condition code 4-19

carry and overflow indicators F-1 carry indicator how used 2-6 setting F-3, 2-6 examples, add operation F-3 examples, subtract operation F-4 chaining 4-13 chaining flag bit in DCB 4-5 character codes E-1 check indicator 7-4 check restart key, console 7-6 CIAR (see current instruction address register) CIAR key, console 7-8 class interrupts 3-5 console 3-8 machine check 3-6 power/thermal warning 3-7 present and accept 3-6 priority of 3-5 program check 3-7 soft exception trap 3-8 summary of 3-9 supervisor call 3-7 trace 3-8 codes, character E-1 command field, IDCB 4-3 command reject, condition code 4-19 commands I/O, general 4-6 communications features, description 1-5 compare byte (CB) instruction register/storage format 8-17 storage/storage format 8-17 compare byte field equal and decrement (CFED) instruction 8-20 compare byte field equal and increment (CFEN) instruction 8-20 compare byte field not equal and decrement (CFNED) instruction 8-21 compare byte field not equal and increment (CFNEN) instruction 8-21 compare byte immediate (CBI) instruction 8-18 compare double word (CD) instruction register/storage format 8-19 storage/storage format 8-19 compare operation example 2-7 indicator settings 2-7 testing results 2-7 compare word (CW) instruction register/register format 8-29 register/storage format 8-29 storage/storage format 8-29 compare word immediate (CWI) instruction register immediate long format 8-30 storage immediate format 8-30 compatibility between the relocation translator and the storage protection mechanism 6-5 complement register (CMR) instruction 8-22

condition codes, defined interrupt 4-19 IO instruction 4-19 console 7-1 basic 7-2 indicators 7-2 keys and switches 7-2 programmer 7-3 combination keys/indicators 7-5 display 7-3 displaying main storage 7-10 displaying registers 7-11 indicators 7-4 keys and switches 7-7 storing into main storage 7-10 storing into registers 7-11 console data buffer 2-4, 7-3 console interrupt 3-8 console interrupt key 7-7 control command 4-7 controller busy condition code 4-19 controller end condition code 4-19 conversion tables, numbering systems and D-1 copy address key register (CPAKR) instruction system register/register format 8-23 system register/storage format 8-23 copy console data buffer (CPCON) instruction 8-24 copy current level (CPCL) instruction 8-24 copy floating level block (CPFLB) instruction 9-6 copy in-process flags (CPIPF) instruction 8-25 copy instruction space key (CPISK) instruction system register/register format 8-23 system register/storage format 8-23 copy interrupt mask register (CPIMR) instruction 8-25 copy level block (CPLB) instruction 8-26 copy level status register (CPLSR) instruction 8-26 copy operand 1 key (CPOOK) instruction system register/register format 8-23 system register/storage format 8-23 copy operand 2 key (CPOTK) instruction system register/register format 8-23 system register/storage format 8-23 copy processor status and reset (CPPSR) instruction 8-27 copy segmentation register (CPSR) instruction 8-28 copy storage key (CPSK) instruction 8-27 count residual byte 4-13 restrictions for the start cycle steal status operation 4-12 word in DCB 4-6 CPU control check, bit in PSW 3-11 current-instruction address register (CIAR) 2-5 cycle steal description 4-10 device options 4-13 interrupt status byte (ISB) 4-20 start cycle steal status operation 4-12 start operation 4-10 status words 4-12 termination conditions 4-15 cycle steal, typical operation 4-10 cycle steal address key in DCB 4-5

data buffer key, console 7-7 data display indicators 7-4 data entry keys (0-F), console 7-9 data stacking 2-24 example, allocating fixed storage areas 2-25 pop operation 2-25 push operation 2-25 DCB (see device control block) DCB chaining 4-13 DCB specification check status bit 4-21 delayed command reject status bit 4-20 device address field, IDCB 4-3 device control block (DCB) 4-5 control word 4-5 count word 4-6 data address word 4-6 device parameter word 3 4-5 device parameter word 4 4-6 device parameter word 5 4-6 device parameter words 1-2 4-5 for start command, summary of 4-5 for start cycle steal status command, summary of 4-12 specification check status bit 4-21 device cycle-steal-status word 1 4-13 device dependent status available status bit 4-20 device dependent status words 4-13 device end condition code 4-19 device ID word 4-6 device mask (I-bit) 3-15, 4-7 device not attached, condition code 4-19 device options, cycle steal 4-13 burst mode 4-13 chaining 4-13 programmed controlled interrupt 4-13 suppress exception 4-14 device reset command 4-8 diagnose (DIAG) instruction 8-33 diagnostic mode, console switch 7-2 direct program control (DPC) operation 4-8 disable (DIS) instruction 8-34 displaying main storage 7-10 displaying registers 7-11 divide byte (DB) instruction 8-31 divide check, floating-point 9-3 divide double word (DD) instruction 8-32 divide word (DW) instruction 8-35 DPC (direct program control) operation 4-8

EA (see effective address) effective address 2-12 effective address generation 2-12 base register storage address 2-17 base register word displacement 2-13 base register word displacement short 2-13 five-bit address argument 2-17 four-bit address argument 2-13 address mode (AM) 2-14 enable (EN) instruction 8-36 end of chain (EOC) bit 4-14 EOC bit (see end of chain bit) EOS (see equate operand spaces) equate operand spaces (EOS) 5-3 error conditions recovery from 3-9 relocation translator, recovery from 6-6 that cause class interrupts 3-5 error recovery considerations, relocation translator 6-6 even indicator 2-6 exception condition code 4-19 exception conditions, during instruction execution program check basic instructions 8-1 floating-point instructions 9-4 soft exception trap basic instructions 8-1 floating-point instructions 9-5 exceptions, suppression of (I/O) 4-14 exclusive OR byte (XB) instruction 8-102 exclusive OR double word (XD) instruction 8-103 exclusive OR word (XW) instruction register/register format 8-104 register/storage format 8-104 storage to register long format 8-105 exclusive OR word immediate (XWI) instruction 8-105

fill byte field and decrement (FFD) instruction 8-37 fill byte field and increment (FFN) instruction 8-37 flags, status (residual status block) 4-14 floating add (FA) instruction general description (short precision) 9-7 register to register format 9-7 storage/register format 9-7 floating add double (FAD) instruction general description (double precision) 9-8 register/register format 9-8 storage/register format 9-8 floating compare (FC) instruction 9-9 floating compare double (FCD) instruction 9-9 floating divide (FD) instruction register to register format 9-10 storage/register format 9-10 floating divide double (FDD) instruction register to register format 9-11 storage/register format 9-11 floating move (FMV) instruction register to register format 9-14 register to storage format 9-14 storage to register format 9-14 floating move and convert (FMVC) instruction register to storage format 9-15 storage to register format 9-15 floating move and convert double (FMVCD) instruction register to storage format 9-16 storage to register format 9-16 floating move double (FMVD) instruction register to register format 9-17 register to storage format 9-17 storage to register format 9-17 floating multiply (FM) instruction general description (short precision) 9-12 register to register format 9-12 storage/register format 9-12

floating multiply double (FMD) instruction general description (double precision) 9-13 register to register format 9-13 storage/register format 9-13 floating-point conversion of binary integers 9-2 data format 9-1 normalization 9-2 numbers 9-1 programming considerations 9-2 arithmetic indicators 9-2 divide check 9-3 exceptions 9-2 feature not installed 9-2 level control 9-3 overflow 9-3 registers 9-2 underflow 9-3 floating-point exception 9-4 floating-point exception, bit in PSW 3-11 floating-point feature 9-1 floating-point instructions copy floating level block (CPFLB) 9-6 descriptions 9-6 exception conditions 9-4 floating add (FA) 9-7 floating add double (FAD) 9-8 floating compare (FC) 9-9 floating compare double (FCD) 9-9 floating divide (FD) 9-10 floating divide double (FDD) 9-11 floating move (FMV) 9-14 floating move and convert (FMVC) 9-15 floating move and convert double (FMVCD) 9-16 floating move double (FMVD) 9-17 floating multiply (FM) 9-12 floating multiply double (FMD) 9-13 floating subtract (FS) 9-18 floating subtract double (FSD) 9-19 formats 9-4 general description 9-3 set floating level block (SEFLB) 9-20 floating subtract (FS) instruction general description (short precision) 9-18 register to register format 9-18 storage/register format 9-18 floating subtract double (FSD) instruction general description (double precision) 9-19 register to register format 9-19 storage/register format 9-19

general registers G-1, 2-5

halt I/O command 4-8 high limit address (HLA) 2-25 HLA (see high limit address)

I-bit, device mask 3-15 I-bit (device mask), field in IDCB 4-7 I/O check, bit in PSW 3-11 I/O commands, general control 4-7 device reset 4-8 halt I/O 4-8 prepare 4-7 read 4-6 read ID 4-6 read status 4-7 start 4-8 start cycle steal status 4-8 summary chart 4-4 write 4-7 I/O condition codes and status information, general 4-15 I/O status information 4-20 interrupt status byte (ISB) 4-20 interrupt condition codes 4-19 interrupt information byte (IIB) 3-3, 4-20 IO instruction condition codes 4-19 summary of 4-15 I/O interrupts 3-3 prepare I/O device for 3-3 present and accept 3-3 I/O storage access using the relocation translator 6-5 IAR (see instruction address register) IAR key, console 7-8 IBM 4955 processor 1-1 ID word device 4-6 interrupt 3-3, 4-20 IDCB (immediate device control block) 4-3 IIB (see interrupt information byte) ILR (see incorrect length record) immediate data field, IDCB 4-3 immediate device control block (IDCB) 4-3 in-process bit 2-10 effect on program controlled level switching 3-12 incorrect length record (ILR) status bit 4-20 indicator bits in LSR 2-5 indicators affected by floating-point operations 9-2 arithmetic 2-5 basic console 7-2 programmer console 7-4 sequence 3-11 indicators, add and subtract operations (carry and overflow) F-1, 2-6 signed numbers F-1 unsigned numbers F-2 indicators, compare operations 2-7 indicators, condition code for I/O operations 2-6 indicators, multiple-word operands 2-8 indicators, result (even, negative, and zero) 2-6 indicators, shift operations (carry and overflow) 2-7 indicators, testing with branch and jump instructions 2-8 indirect address 2-15, 2-18 inhibit trace (IT) bit 8-78 effect on SELB instruction 8-78 how used, programming note 3-8 initial program load (IPL) 2-22 auto IPL, bit in PSW 3-11 auto IPL mode, console switch 7-2 source switch, console 7-2 storage protection during 5-3

input flag bit in DCB 4-5 input/output (see also I/O) commands (see I/O commands) condition codes and status information 4-15 interrupt status byte (ISB) 4-20 operate I/O (IO) instruction 4-2, 8-38 input/output operations 4-1 instruct step key/indicator 7-5 instruction exception conditions 8-1 formats 2-10 floating-point 9-3 index of X-12 names 2-12 one word 2-10 summary of B-1 two word 2-11 variable length 2-11, 2-18 index of, by name X-15 privileged 2-21 termination or suppression 8-2, 9-3 instruction address register (IAR) 2-5 instruction execution time when using the translator 6-7 instruction execution times A-1 relocation translator disabled A-4 additional time for addressing mode A-2 relocation translator enabled A-14 additional time for addressing mode A-3 instruction formats B-1, 2-10 instruction space key (ISK) 5-3 interchange operand keys (IOPK) instruction 8-38 interchange registers (IR) instruction 8-39 interface data check, condition code 4-19 interface data check status bit 4-21 interrupt automatic branching 3-2 class 3-5 I/O 3-3 masking facilities 3-15 device mask (I-bit) 3-15 mask register, interrupt level 3-15 summary mask 3-15 priority scheme 3-1 interrupt ID word 3-3, 4-20 interrupt information byte (IIB) 3-3, 4-20 interrupt level mask register 3-15 interrupt scheme 3-1 interrupt status byte (ISB) defined 4-20 for cycle stealing devices 4-20 for devices that do not cycle steal 4-20 interrupts and level switching, introduction 3-1 intervention required, condition code 4-19 invalid function, bit in PSW 3-11 invalid function, program check condition 8-1 invalid function, soft exception trap condition 8-1 invalid storage address 8-1, 9-4 invalid storage address, bit in PSW 3-10 invalid storage address status bit, I/O 4-21 invert register (VR) instruction 8-102 IO (operate I/O) instruction 4-2, 8-38 IPL (see initial program load) IPL source switch 7-2 ISB (see interrupt status byte) ISK (see instruction space key) IT bit (see inhibit trace bit)

jump and link (JAL) instruction 8-40 jump if mixed (JMIX) instruction 8-41 jump if not off (JNOFF) instruction 8-43 jump if not on (JNON) instruction 8-43 jump if off (JOFF) instruction 8-41 jump if on (JON) instruction 8-41 jump on arithmeticall greater than or equal (JGE) instruction 8-43 jump on arithmetically greater than (JGT) instruction 8-43 jump on arithmetically less than (JLT) instruction 8-41 jump on arithmetically less than or equal (JLE) instruction 8-41 jump on carry (JCY) instruction 8-41 jump on condition (JC) instruction 8-41 jump on count (JCT) instruction 8-42 jump on equal (JE) instruction 8-41 jump on even (JEV) instruction 8-41 jump on logically greater than (JLGT) instruction 8-43 jump on logically greater than or equal (JLGE) instruction 8-43 jump on logically less than (JLLT) instruction 8-41 jump on logically less than or equal (JLLE) instruction 8-41 jump on negative (JN) instruction 8-41 jump on no carry (JNCY) instruction 8-43 jump on not condition (JNC) instruction 8-43 jump on not equal (JNE) instruction 8-43 jump on not even (JNEV) instruction 8-43 jump on not mixed (JNMIX) instruction 8-43 jump on not negative (JNN) instruction 8-43 jump on not positive (JNP) instruction 8-43 jump on not zero (JNZ) instruction 8-43 jump on positive (JP) instruction 8-41 jump on zero (JZ) instruction 8-41 jump unconditional (J) instruction 8-39 level exit (LEX) instruction 8-44 level status block (LSB) 2-4 level status register (LSR) G-2, 2-5 level switching priority interrupt 3-3 program controlled 3-12 level 0 kev/indicator 7-5 level 1 key/indicator 7-5 level 2 key/indicator 7-5 level 3 key/indicator 7-5

level 3 key/indicator 7-5 linkage stacking description 2-28 example, reenterable subroutine 2-28 LLA (see low limit address) load indicator 7-2 load key 7-2 load multiple and branch (LMB) instruction 8-44 load state 2-20 low limit address (LLA) 2-25 LSB (see level status block) LSB pointer, class interrupts 3-3 LSR (see level status register) LSR key, console 7-8 machine check conditions 3-10 machine check interrupt 3-6 main storage 2-1 address boundaries, instruction and operand 2-1 addressing 2-1 defined 2-3 storage protection 5-1 main storage key, console 7-8 mask register, interrupt level 2-5, 3-15 mode switch 7-2 move address (MVA) instruction storage address to register format 8-47 storage immediate format 8-47 move byte (MVB) instruction register/storage format 8-48 storage/storage format 8-48 move byte and zero (MVBZ) instruction 8-49 move byte field and decrement (MVFD) instruction 8-52 move byte field and increment (MVFN) instruction 8-52 move byte immediate (MVBI) instruction 8-49 move double word (MVD) instruction register/storage format 8-50 storage/storage format 8-50 move double word and zero (MVDZ) instruction 8-51 move word (MVW) instruction register/register format 8-53 register/storage format 8-53 register to storage long format 8-53 storage/storage format 8-54 storage to register long format 8-54 move word and zero (MVWZ) instruction 8-57 move word immediate (MVWI) storage immediate format 8-55 storage to register format 8-55 move word short (MVWS) instruction register to storage format 8-56 storage to register format 8-56 multiple register/storage instructions load multiple and branch (LMB) 8-44 store multiple (STM) 8-93 multiply byte (MB) instruction 8-45 multiply double word (MD) instruction 8-46 multiply word (MW) instruction 8-58

NE bit (see no exception bit) negative indicator 2-6 no exception (NE) bit 4-14 no operation (NOP) instruction 8-59 normal mode, console switch 7-2 normalization, floating-point numbers 9-2 numbering representation 2-3 floating-point 9-1 signed numbers 2-3 unsigned numbers 2-3 numbering systems and conversion tables D-1

op reg key, console 7-8 operand 1 key (OP1K) 5-3 operand 2 key (OP2K) 5-3 operate I/O (IO) instruction 4-2, 8-38 options, cycle steal device 4-13 OP1K (see operand 1 key) OP2K (see operand 2 key) OR byte (OB) instruction register/storage format 8-60 storage/storage format 8-60 OR double word (OD) instruction register/storage format 8-61 storage/storage format 8-61 OR word (OW) instruction register/register format 8-62 register/storage format 8-62 storage/storage format 8-63 storage to register long format 8-63 OR word immediate (OWI) instruction register immediate format 8-64 storage immediate format 8-64 overflow, floating-point 9-3 overflow indicator setting F-4, 2-6 examples, arithmetic F-5 parametric instructions diagnose (DIAG) 8-33 disable (DIS) 8-34 enable (EN) 8-36 interchange operand keys (IOPK) 8-38 level exit (LEX) 8-44 stop (STOP) 8-94 supervisor call (SVC) 8-94 PCI (see programmed controlled interrupt) PDE (see permissive device end) permissive device end (PDE) (see device end) 4-19 pop byte (PB) instruction 8-65 pop doubleword (PD) instruction 8-65 pop operation 2-25 pop word (PW) instruction 8-67 power on indicator 7-2 power on/off switch 7-2 power-on reset, effects of 2-21 power/thermal warning, bit in PSW 3-11 power/thermal warning condition 3-10 power/thermal warning interrupt 3-7 prepare command 4-7 primary IPL source, console switch 7-2 privilege violate 8-1, 9-4 privilege violate, bit in PSW 3-10 privileged instructions, list of 2-21 problem state 2-21 processing unit description 2-1 processor data flow 2-2 description 1-1 features communications 1-5 input/output units 1-5 optional 1-1 standard 1-1 introduction 1-1 models 1-3

processor (continued) options miscellaneous 1-5 packaging and power 1-5 sensor input/output 1-5 processor, 4955 1-1 processor state control 2-19 processor status word (PSW) 2-5, 3-10 program check conditions basic instructions 8-1 floating-point instructions 9-4 program check conditions in PSW 3-10 program check interrupt 3-7 program check or soft exception trap conditions 3-10 program controlled interrupt condition code 4-19 program controlled level switching 3-12 program execution 2-10 jumping and branching 2-23 level switching and interrupts 2-23 sequential instructions 2-22 programmed controlled interrupt (PCI) 4-13 programmer console 7-3 protect check 8-1, 9-4 protect check, bit in PSW 3-11 protect check status bit 4-21 protection, storage 5-1 PSW (see processor status word) PSW key, console 7-8 push byte (PSB) instruction 8-66 push double word (PSD) instruction 8-66 push operation 2-25 push word (PSW) instruction 8-67

RB (see base register) read command 4-6 read ID command 4-6 read status command 4-7 recovery from error conditions 3-9 reference information G-1 address kev register G-1 condition codes G-1 general registers G-1 interrupt status byte G-1 level status register G-2 processor status word G-2 register immediate instructions add byte immediate (ABI) 8-3 add word immediate (AWI) 8-7 AND word immediate (NWI) 8-59 compare byte immediate (CBI) 8-18 compare word immediate (CWI) 8-30 exclusive OR word immediate (XWI) 8-105 move byte immediate (MVBI) 8-49 OR word immediate (OWI) 8-64 reset bits word immediate (RBTWI) 8-72 subtract word immediate (SWI) 8-98 test word immediate (TWI) 8-101 register/register instructions add carry register (ACY) 8-3 add word (AW) 8-5 add word with carry (AWCY) 8-7 compare word (CW) 8-29

register/register instructions (continued) complement register (CMR) 8-22 copy level status register (CPLSR) 8-26 exclusive OR word (XW) 8-104 interchange registers (IR) 8-39 invert register (VR) 8-102 move word (MVW) 8-53 OR word (OW) 8-62 reset bits word (RBTW) 8-70 set indicators (SEIND) 8-77 subtract carry indicator (SCY) 8-73 subtract word (SW) 8-95 subtract word with carry (SWCY) 8-97 register/storage instructions add byte (AB) 8-2 add double word (AD) 8-4 add word (AW) 8-5 compare byte (CB) 8-17 compare double word (CD) 8-19 compare word (CW) 8-29 divide byte (DB) 8-31 divide double word (DD) 8-32 divide word (DW) 8-35 exclusive OR byte (XB) 8-102 exclusive OR double word (XD) 8-103 exclusive OR word (XW) 8-104 move address (MVA) 8-47 move byte (MVB) 8-48 move byte and zero (MVBZ) 8-49 move double word (MVD) 8-50 move double word and zero (MVDZ) 8-51 move word (MVW) 8-53 move word and zero (MVWZ) 8-57 move word immediate (MVWI) 8-55 multiply byte (MB) 8-45 multiply double word (MD) 8-46 multiply word (MW) 8-58 OR byte (OB) 8-60 OR double word (OD) 8-61 OR word (OW) 8-62 pop byte (PB) 8-65 pop double word (PD) 8-65 pop word (PW) 8-67 push byte (PSB) 8-66 push double word (PSD) 8-66 push word (PSW) 8-67 reset bits byte (RBTB) 8-68 reset bits double word (RBTD) 8-69 reset bits word (RBTW) 8-70 subtract byte (SB) 8-73 subtract double word (SD) 8-74 subtract word (SW) 8-95 register/storage long instructions add word (AW) 8-6 exclusive OR word (XW) 8-105 move word (MVW) 8-53 operate I/O (IO) 8-38 OR word (OW) 8-63 reset bits word (RBTW) 8-71 subtract word (SW) 8-96 register/storage short instruction move word short (MVWS) 8-56

registers address key 5-1 address key (AKR) 2-5 base 2-13 console data buffer 2-4 current-instruction address (CIAR) 2-5 floating-point 9-2 general 2-5 instruction address (IAR) 2-5 level status (LSR) 2-5 mask 2-5 processor status word (PSW) 2-5 segmentation 6-1 storage address (SAR) 2-5 storage key 5-1 relocation addressing 6-4 relocation translator (see storage address relocation translator) reserved storage locations 3-2 reset 2-21 reset bits byte (RBTB) instruction register/storage format 8-68 storage/storage format 8-68 reset bits double word (RBTD) instruction register/storage format 8-69 storage/storage format 8-69 reset bits word (RBTW) instruction register/register format 8-70 register/storage format 8-70 storage/storage format 8-71 storage to register long format 8-71 reset bits word immediate (RBTWI) instruction register immediate long format 8-72 storage immediate format 8-72 reset key, console 7-7 residual address 4-12 after power-on reset 4-12 updating 4-12 residual byte count 4-13 residual status block size of 4-14 storing 4-14 restrictions instruction and operand address boundaries 2-1 programming, DCB 4-6 programming, DCB (start cycle steal status) 4-12 when in problem state 2-21 result indicators (even, negative, and zero) 2-6 run indicator 7-2 run state 2-20 R0 key, console 7-8 R1 key, console 7-8 R2 key, console 7-8 R3 key, console 7-8 R4 key, console 7-8 R5 key, console 7-8 R6 key, console 7-8 R7 key, console 7-8

SAR (see storage address register) SAR key, console 7-8 satisfactory, condition code 4-19

scan byte field equal and decrement (SFED) instruction 8-81 scan byte field equal and increment (SFEN) instruction 8-81 scan byte field not equal and decrement (SFNED) instruction 8-82 scan byte field not equal and increment (SFNEN) instruction 8-82 SE (see suppress exception) segmentation registers 6-1 bit 13 (valid bit) 6-5 bit 14 (read-only bit) 6-5 description 6-2 how used 6-2 sensor input/output options, description 1-5 sequence indicator, bit in PSW 3-11 set address key register (SEAKR) instruction system register/register format 8-75 system register/storage format 8-75 set console data lights (SECON) instruction 8-76 set floating level block (SEFLB) instruction 9-20 set indicators (SEIND) instruction 8-77 set instruction space key (SEISK) instruction system register/register format 8-75 system register/storage format 8-75 set interrupt mask register (SEIMR) instruction 8-76 set level status block (SELB) instruction 8-78 set operand 1 key (SEOOK) instruction system register/register format 8-75 system register/storage format 8-75 set operand 2 key (SEOTK) instruction system register/register format 8-75 system register/storage format 8-75 set segmentation register (SESR) instruction 8-80 set storage key (SESK) instruction 8-79 shift instructions shift left and test (SLT) 8-88 shift left and test double (SLTD) 8-88 shift left circular (SLC) 8-83 shift left circular double (SLCD) 8-84 shift left logical (SLL) 8-86 shift left logical double (SLLD) 8-87 shift right arithmetic (SRA) 8-89 shift right arithmetic double (SRAD) 8-90 shift right logical (SRL) 8-91 shift right logical double (SRLD) 8-92 shift left and test (SLT) instruction 8-88 shift left circular (SLC) instruction count in register format 8-83 immediate count format 8-83 shift left circular double (SLCD) instruction count in register format 8-85 immediate count format 8-84 shift left logical (SLL) instruction count in register format 8-86 immediate count format 8-86 shift left logical double (SLLD) instruction count in register format 8-87 immediate count format 8-87

shift right arithmetic (SRA) instruction count in register format 8-89 immediate count format 8-89 shift right arithmetic double (SRAD) instruction count in register format 8-90 immediate count format 8-90 shift right logical (SRL) instruction count in register format 8-91 immediate count format 8-91 shift right logical double (SRLD) instruction count in register format 8-92 immediate count format 8-92 SIA (see start instruction address) 3-3 signed numbers examples 2-3 single bit manipulation instructions test bit (TBT) 8-99 test bit and invert (TBTV) 8-100 test bit and reset (TBTR) 8-99 test bit and set (TBTS) 8-100 soft exception trap conditions basic instructions 8-1 floating-point instructions 9-5 soft exception trap conditions in PSW 3-10 soft exception trap interrupt 3-8 specification check 8-1, 9-5 specification check, bit in PSW 3-10 stack control block, relationship to data stack 2-24 stack exception 8-2 stack exception, bit in PSW 3-11 stack operations 2-23 stacking data, description 2-24 linkage, description 2-28 start command 4-8 start cycle steal status command 4-8 start cycle steal status operation 4-12 DCB format 4-12 DCB restrictions 4-12 residual parameters (status) 4-12 start instruction address (SIA) 3-3 start key, console 7-7 start operation, cycle steal 4-10 states, processor following a reset 2-21 load 2-20 problem 2-21 run 2-20 stop 2-19 supervisor 2-20 wait 2-20 status address, DCB word 4 4-6 status after resets, processor 2-21 status block, residual 4-14 status flags, in PSW 3-10 status flags, in residual status block 4-14 status information, I/O 4-20 status of translator after power transitions and resets 6-6 status words, cycle steal 4-12 stop (STOP) instruction 8-94 stop key/indicator 7-5 stop on address key/indicator 7-5

stop on address mode 7-6 stop on error key, console 7-6 stop state 2-19 storage address register (SAR) 2-5 storage address relocation translator 6-1 addressing, example of 6-4 addressing range 6-1 compatibility with storage protection mechanism 6-5 characteristics that are dissimilar 6-6 characteristics that are similar 6-6 description 6-1 error recovery considerations 6-6 invalid storage address 6-6 protect check 6-6 I/O storage access when using 6-5 instruction execution time when using 6-7 status after power transitions and resets 6-6 storage mapping 6-2 storage protection when using 6-5 read-only bit 6-5 valid bit 6-5 storage data check status bit 4-21 storage immediate instructions add word immediate (AWI) 8-7 compare word immediate (CWI) 8-30 move address (MVA) 8-47 move word immediate (MVWI) 8-55 OR word immediate (OWI) 8-64 reset bits word immediate (RBTWI) 8-72 subtract word immediate (SWI) 8-98 test word immediate (TWI) 8-101 storage key register 5-1 storage mapping, relocation translator 6-2 example of 6-3 storage parity, bit in PSW 3-11 storage protection 5-1 during IPL 5-3 for I/O devices 5-3 in supervisor state 5-3 storage protection during IPL 5-3 storage protection in supervisor state 5-3 storage protection when using the relocation translator 6-5 storage/storage instructions add double word (AD) 8-4 add word (AW) 8-6 compare byte (CB) 8-17 compare byte field equal and decrement (CFED) 8-20 compare byte field equal and increment (CFEN) 8-20 compare byte field not equal and decrement (CFNED) 8-21 compare byte field not equal and increment (CFNEN) 8-21 compare double word (CD) 8-19 compare word (CW) 8-29 move byte (MVB) 8-48 move byte field and decrement (MVFD) 8-52 move byte field and increment (MVFN) 8-52 move double word (MVD) 8-50 move word (MVW) 8-54 OR byte (OB) 8-60 OR double word (OD) 8-61 OR word (OW) 8-63

storage/storage instructions (continued) reset bits byte (RBTB) 8-68 reset bits double word (RBTD) 8-69 reset bits word (RBTW) 8-71 subtract double word (SD) 8-74 subtract word (SW) 8-96 store key, console 7-7 store multiple (STM) instruction 8-93 storing into main storage 7-10 storing into registers 7-11 subtract byte (SB) instruction 8-73 subtract carry indicator (SCY) instruction 8-73 subtract double word (SD) instruction register/storage format 8-74 storage/storage format 8-74 subtract word (SW) instruction register/register format 8-95 register/storage format 8-95 storage/storage format 8-96 storage to register long format 8-96 subtract word immediate (SWI) instruction register immediate long format 8-98 storage immediate format 8-98 subtract word with carry (SWCY) instruction 8-97 summary mask 3-15 summary mask bit 2-10 summary of assembler syntax C-1 summary of character codes E-1 summary of class interrupts 3-9 summary of instructions by format X-12 by name X-15 supervisor call (SVC) instruction 8-94 supervisor call interrupt 3-7 supervisor state 2-20 supervisor state bit 2-10 suppress exception (SE) 4-14 suppression of instructions 8-2, 9-3 syntax, assembler (summary of) C-1 system register/register instructions copy address key register (CPAKR) 8-23 copy instruction space key (CPISK) copy operand 1 key (CPOOK) copy operand 2 key (CPOTK) copy console data buffer (CPCON) 8-24 copy current level (CPCL) 8-24 set address key register (SEAKR) 8-75 set instruction space key (SEISK) set operand 1 key (SEOOK) set operand 2 key (SEOTK) set console data lights (SECON) 8-76 system register/storage instructions copy address key register (CPAKR) 8-23 copy instruction space key (CPISK) copy operand 1 key (CPOOK) copy operand 2 key (CPOTK) copy floating level block (CPFLB) 9-6 copy in-process flags (CPIPF) 8-25 copy interrupt mask register (CPIMR) 8-25 copy level block (CPLB) 8-26 copy processor status and reset (CPPSR) 8-27 copy segmentation register (CPSR) 8-28 copy storage key (CPSK) 8-27

```
system register/storage instructions (continued)
   set address key register (SEAKR) 8-75
       set instruction space key (SEISK)
       set operand 1 key (SEOOK)
       set operand 2 key (SEOTK)
   set floating level block (SEFLB) 9-20
   set interrupt mask register (SEIMR) 8-76
   set level status block (SELB) 8-78
   set segmentation register (SESR) 8-80
   set storage key (SESK) 8-79
TEA (see top element address)
termination conditions, cycle steal 4-15
termination of instructions 8-2, 9-3
test bit (TBT) instruction 8-99
test bit and invert (TBTV) instruction 8-100
test bit and reset (TBTR) instruction 8-100
test bit and set (TBTS) instruction 08-100
test word immediate (TWI) instruction
   register immediate long format 8-101
   storage immediate format 8-101
testing indicators with conditional instructions 2-8
top element address (TEA) 2-25
trace bit 2-10
trace interrupt 3-8
translator (see storage address relocation translator)
translator description 6-1
translator enabled, bit in PSW 3-11
underflow, floating-point 9-3
unsigned numbers
   defined 2-3
   examples 2-3
   how used 2-6
variable field length byte instructions
   compare byte field equal and decrement (CFED) 8-20
   compare byte field equal and increment (CFEN) 8-20
   compare byte field not equal and decrement
    (CFNED) 8-21
   compare byte field not equal and increment
    (CFNEN) 8-21
   fill byte field and decrement (FFD) 8-37
   fill byte field and increment (FFN) 8-37
   move byte field and decrement (MVFD) 8-52
   move byte field and increment (MVFN) 8-52
   scan byte field equal and decrement (SFED) 8-81
   scan byte field equal and increment (SFEN) 8-81
   scan byte field not equal and decrement (SFNED) 8-82
   scan byte field not equal and increment (SFNEN) 8-82
variable length instructions
   defined 2-11
   examples for address arguments 2-18
wait indicator 7-2
wait state 2-20
WD (see word displacement)
word displacement (WD) 2-13
```

zero indicator 2-6

write command 4-7

# Index of Instructions by Format

branch/jump instructions branch and link (BAL) 8-10 branch and link external (BALX) branch and link short (BALS) 8-10 branch indexed short (BXS) 8-16 branch on condition (BC) 8-11 branch if mixed (BMIX) branch if negative (BN) branch if off (BOFF) branch if on (BON) branch on arithmetically less than (BLT) branch on arithmetically less than or equal (BLE) branch on carry (BCY) branch on equal (BE) branch on even (BEV) branch on logically less than (BLLT) branch on positive (BP) branch on zero (BZ) branch on condition code (BCC) 8-12 branch on not error (BNER) branch on not condition (BNC) 8-13 branch if not off (BNOFF) branch if not on (BNON) branch on arithmetically greater than (BGT) branch on arithmetically greater than or equal (BGE) branch on logically greater than (BLGT) branch on logically greater than or equal (BLGE) branch on no carry (BNCY) branch on not equal (BNE) branch on not even (BNEV) branch on not mixed (BNMIX) branch on not negative (BNN) branch on not positive (BNP) branch on not zero (BNZ) branch on not condition code (BNCC) 8-14 branch on error (BER) branch on not overflow (BNOV) 8-15 branch on overflow (BOV) 8-15 branch unconditional (B) 8-9 branch external (BX) jump and link (JAL) 8-40 jump on condition (JC) 8-41 jump if mixed (JMIX) jump if off (JOFF) jump if on (JON) jump on arithmetically less than (JLT) jump on arithmetically less than or equal (JLE) jump on carry (JCY) jump on equal (JE) jump on even (JEV) jump on logically less than (JLLT) jump on logically less than or equal (JLLE) jump on negative (JN) jump on positive (JP) jump on zero (JZ)

branch/jump instructions (continued) jump on count (JCT) 8-42 jump on not condition (JNC) 8-43 jump if not off (JNOFF) jump if not on (JNON) jump on arithmetically greater than (JGT) jump on arithmetically greater than or equal (JGE) jump on logically greater than (JLGT) jump on logically greater than or equal (JLGE) jump on no carry (JNCY) jump on not equal (JNE) jump on not even (JNEV) jump on not mixed (JNMIX) jump on not negative (JNN) jump on not positive (JNP) jump on not zero (JNZ) jump unconditional (J) 8-39 no operation (NOP) 8-59

floating-point instructions copy floating level block (CPFLB) 9-6 floating add (FA) 9-7 floating add double (FAD) 9-8 floating compare (FC) 9-9 floating compare double (FCD) 9-9 floating divide (FD) 9-10 floating divide double (FDD) 9-11 floating move (FMV) 9-14 floating move and convert (FMVC) 9-15 floating move and convert double (FMVCD) 9-16 floating move double (FMVD) 9-17 floating multiply (FM) 9-12 floating multiply double (FMD) 9-13 floating subtract (FS) 9-18 floating subtract double (FSD) 9-19 set floating level block (SEFLB) 9-20

multiple register/storage instructions load multiple and branch (LMB) 8-44 store multiple (STM) 8-93

parametric instructions diagnose (DIAG) 8-33 disable (DIS) 8-34 enable (EN) 8-36 interchange operand keys (IOPK) 8-38 level exit (LEX) 8-44 stop (STOP) 8-94 supervisor call (SVC) 8-94 register immediate instructions add byte immediate (ABI) 8-3 add word immediate (AWI) 8-7 AND word immediate (NWI) 8-59 compare byte immediate (CBI) 8-18 compare word immediate (CWI) 8-30 exclusive OR word immediate (XWI) 8-105 move byte immediate (MVBI) 8-49 OR word immediate (OWI) 8-64 reset bits word immediate (RBTWI) 8-72 subtract word immediate (SWI) 8-98 test word immediate (TWI) 8-101 register/register instructions add carry register (ACY) 8-3 add word (AW) 8-5 add word with carry (AWCY) 8-7 compare word (CW) 8-29 complement register (CMR) 8-22 copy level status register (CPLSR) 8-26 exclusive OR word (XW) 8-104 interchange registers (IR) 8-39 invert register (VR) 8-102 move word (MVW) 8-53 OR word (OW) 8-62 reset bits word (RBTW) 8-70 set indicators (SEIND) 8-77 subtract carry indicator (SCY) 8-73 subtract word (SW) 8-95 subtract word with carry (SWCY) 8-97 register/storage instructions add byte (AB) 8-2 add double word (AD) 8-4 add word (AW) 8-5 compare byte (CB) 8-17 compare double word (CD) 8-19 compare word (CW) 8-29 divide byte (DB) 8-31 divide double word (DD) 8-32 divide word (DW) 8-35 exclusive OR byte (XB) 8-102 exclusive OR double word (XD) 8-103 exclusive OR word (XW) 8-104 move address (MVA) 8-47 move byte (MVB) 8-48 move byte and zero (MVBZ) 8-49 move double word (MVD) 8-50 move double word and zero (MVDZ) 8-51 move word (MVW) 8-53 move word and zero (MVWZ) 8-57 move word immediate (MVWI) 8-55 multiply byte (MB) 8-45 multiply double word (MD) 8-46 multiply word (MW) 8-58 OR byte (OB) 8-60 OR double word (OD) 8-61 OR word (OW) 8-62 pop byte (PB) 8-65 pop double word (PD) 8-65 pop word (PW) 8-67 push byte (PSB) 8-66 push double word (PSD) 8-66 push word (PSW) 8-67 reset bits byte (RBTB) 8-68 reset bits double word (RBTD) 8-69

register/storage instructions (continued) reset bits word (RBTW) 8-70 subtract byte (SB) 8-73 subtract double word (SD) 8-74 subtract word (SW) 8-95 register/storage long instructions add word (AW) 8-6 exclusive OR word (XW) 8-105 move word (MVW) 8-53 operate I/O (IO) 8-38 OR word (OW) 8-63 reset bits word (RBTW) 8-71 subtract word (SW) 8-96 register/storage short instruction move word short (MVWS) 8-56 shift instructions shift left and test (SLT) 8-88 shift left and test double (SLTD) 8-88 shift left circular (SLC) 8-83 shift left circular double (SLCD) 8-84 shift left logical (SLL) 8-86 shift left logical double (SLLD) 8-87 shift right arithmetic (SRA) 8-89 shift right arithmetic double (SRAD) 8-90 shift right logical (SRL) 8-91 shift right logical double (SRLD) 8-92 single bit manipulation instructions test bit (TBT) 8-99 test bit and invert (TBTV) 8-100 test bit and reset (TBTR) 8-99 test bit and set (TBTS) 8-100 storage immediate instructions add word immediate (AWI) 8-8 compare word immediate (CWI) 8-30 move address (MVA) 8-47 move word immediate (MVWI) 8-55 OR word immediate (OWI) 8-64 reset bits word immediate (RBTWI) 8-72 subtract word immediate (SWI) 8-98 test word immediate (TWI) 8-101 storage/storage instructions add double word (AD) 8-4 add word (AW) 8-6 compare byte (CB) 8-17 compare byte field equal and decrement (CFED) 8-20 compare byte field equal and increment (CFEN) 8-20 compare byte field not equal and decrement (CFNED) 8-21 compare byte field not equal and increment (CFNEN) 8-21 compare double word (CD) 8-19 compare word (CW) 8-29 move byte (MVB) 8-48 move byte field and decrement (MVFD) 8-52 move byte field and increment (MVFN) 8-52 move double word (MVD) 8-50 move word (MVW) 8-54 OR byte (OB) 8-60 OR double word (OD) 8-61 OR word (OW) 8-63 reset bits byte (RBTB) 8-68 reset bits double word (RBTD) 8-69

storage/storage instructions (continued) reset bits word (RBTW) 8-71 subtract double word (SD) 8-74 subtract word (SW) 8-96 system register/register instructions copy address key register (CPAKR) 8-23 copy instruction space key (CPISK) copy operand 1 key (CPOOK) copy operand 2 key (CPOTK) copy console data buffer (CPCON) 8-24 copy current level (CPCL) 8-24 set address key register (SEAKR) 8-75 set instruction space key (SEISK) set operand 1 key (SEOOK) set operand 2 key (SEOTK) 8-76 set console data lights (SECON) system register/storage instructions copy address key register (CPAKR) 8-23 copy instruction space key (CPISK) copy operand 1 key (CPOOK) copy operand 2 key (CPOTK) copy floating level block (CPFLB) 9-6 copy in-process flags (CPIPF) 8-25 copy interrupt mask register (CPIMR) 8-25 copy level block (CPLB) 8-26 copy processor status and reset (CPPSR) 8-27 copy segmentation register (CPSR) 8-28 copy storage key (CPSK) 8-27 set address key register (SEAKR) 8-75 set instruction space key (SEISK) set operand 1 key (SEOOK) set operand 2 key (SEOTK) set floating level block (SEFLB) 9-20 set interrupt mask register (SEIMR) 8-76 set level status block (SELB) 8-78 set segmentation register (SESR) 8-80 set storage key (SESK) 8-79

variable field length byte instructions
compare byte field equal and decrement (CFED) 8-20
compare byte field equal and increment (CFEN) 8-20
compare byte field not equal and decrement (CFNED) 8-21
compare byte field not equal and increment (CFNEN) 8-21
fill byte field and decrement (FFD) 8-37
fill byte field and decrement (FFN) 8-37
move byte field and decrement (MVFD) 8-52
move byte field and increment (MVFN) 8-52
scan byte field equal and decrement (SFED) 8-81
scan byte field not equal and decrement (SFNED) 8-82
scan byte field not equal and decrement (SFNED) 8-82

# Index of Instructions by Name

add byte (AB) instruction 8-2 add byte immediate (ABI) instruction 8-3 add carry register (ACY) instruction 8-3 add double word (AD) instruction register/storage format 8-4 storage/storage format 8-4 add word (AW) instruction register/register 8-5 register/storage format 8-5 storage/storage format 8-6 storage to register long format 8-6 add word immediate (AWI) instruction register immediate long format 8-7 storage immediate format 8-8 add word with carry (AWCY) instruction 8-7 and word immediate (NWI) instruction 8-59

branch and link (BAL) instruction 8-10 branch and link external (BALX) instruction 8-10 branch and link short (BALS) instruction 8-10 branch external (BX) instruction 8-9 branch if mixed (BMIX) instruction 8-11 branch if negative (BN) instruction 8-11 branch if not off (BNOFF) instruction 8-13 branch if not on (BNON) instruction 8-13 branch if off (BOFF) instruction 8-11 branch if on (BON) instruction 8-11 branch indexed short (BXS) instruction 8-16 branch on arithmetically greater than (BGT) instruction 8-13 branch on arithmetically greater than or equal (BGE) instruction 8-13 branch on arithmetically less than (BLT) instruction 8-11 branch on arithmetically less than or equal (BLE) instruction 8-11 branch on carry (BCY) instruction 8-11 branch on condition (BC) instruction 8-11 branch on condition code (BCC) instruction 8-12 branch on equal (BE) instruction 8-11 branch on error (BER) instruction 8-14 branch on even (BEV) instruction 8-11 branch on logically greater than (BLGT) instruction 8-13 branch on logically greater than or equal (BLGE) instruction 8-13 branch on logically less than (BLLT) instruction 8-11 branch on logically less than or equal (BLLE) instruction 8-11 branch on no carry (BNCY) instruction 8-13 branch on not condition (BNC) instruction 8-13 branch on not condition code (BNCC) instruction 8-14 branch on not equal (BNE) instruction 8-13 branch on not error (BNER) instruction 8-12 branch on not even (BNEV) instruction 8-13 branch on not mixed (BNMIX) instruction 8-13

branch on not negative (BNN) instruction 8-13 branch on not overflow (BNOV) instruction 8-15 branch on not positive (BNP) instruction 8-13 branch on not zero (BNZ) instruction 8-13 branch on overflow (BOV) instruction 8-15 branch on positive (BP) instruction 8-11 branch on zero (BZ) instruction 8-11 branch unconditional (B) instruction 8-9

compare byte (CB) instruction register/storage format 8-17 storage/storage format 8-17 compare byte field equal and decrement (CFED) instruction 8-20 compare byte field equal and increment (CFEN) instruction 8-20 compare byte field not equal and decrement (CFNED) instruction 8-21 compare byte field not equal and increment (CFNEN) instruction 8-21 compare byte immediate (CBI) instruction 8-18 compare double word (CD) instruction register/storage format 8-19 storage/storage format 8-19 compare word (CW) instruction register/register format 8-29 register/storage format 8-29 storage/storage format 8-29 compare word immediate (CWI) instruction register immediate long format 8-30 storage immediate format 8-30 complement register (CMR) instruction 8-22 copy address key register (CPAKR) instruction system register/register format 8-23 system register/storage format 8-23 copy console data buffer (CPCON) instruction 8-24 copy current level (CPCL) instruction 8-24 copy floating level block (CPFLB) instruction 9-6 copy in-process flags (CPIPF) instruction 8-25 copy instruction space key (CPISK) instruction system register/register format 8-23 system register/storage format 8-23 copy interrupt mask register (CPIMR) instruction 8-25 copy level block (CPLB) instruction 8-26 copy level status register (CPLSR) instruction 8-26 copy operand 1 key (CPOOK) instruction system register/register format 8-23 system register/storage format 8-23 copy operand 2 key (CPOTK) instruction system register/register format 8-23 system register/storage format 8-23 copy processor status and reset (CPPSR) instruction 8-27 copy segmentation register (CPSR) instruction 8-28 copy storage key (CPSK) instruction 8-27

diagnose (DIAG) instruction 8-33 disable (DIS) instruction 8-34 divide byte (DB) instruction 8-31 divide double word (DD) instruction 8-32 divide word (DW) instruction 8-35

enable (EN) instruction 8-36 exclusive OR byte (XB) instruction 8-102 exclusive OR double word (XD) instruction 8-103 exclusive OR word (XW) instruction register/register format 8-104 register/storage format 8-104 storage to register long format 8-105 exclusive OR word immediate (XWI) instruction 8-105

fill byte field and decrement (FFD) instruction 8-37 fill byte field and increment (FFN) instruction 8-37 floating add (FA) instruction general description (short precision) 9-7 register to register format 9-7 storage/register format 9-7 floating add double (FAD) instruction general description (double precision) 9-8 register/register format 9-8 storage/register format 9-8 floating compare (FC) instruction 9-9 floating compare double (FCD) 9-9 floating divide (FD) instruction register to register format 9-10 storage/register format 9-10 floating divide double (FDD) instruction register to register format 9-11 storage/register format 9-11 floating move (FMV) instruction register to register format 9-14 register to storage format 9-14 storage to register foramt 9-14 floating move and convert (FMVC) instruction register to storage format 9-15 storage to register format 9-15 floating move and convert double (FMVCD) instruction register to storage format 9-16 storage to register format 9-16 floating move double (FMVD) instruction register to register format 9-17 register to storage format 9-17 storage to register format 9-17 floating multiply (FM) instruction general description (short precision) 9-12 register to register format 9-12 storage/register format 9-12 floating multiply double (FMD) instruction general description (double precision) 9-13 register to register format 9-13 storage/register format 9-13 floating subtract (FS) instruction general description (short precision) 9-18 register to register format 9-18 storage/register format 9-18 floating subtract double (FSD) instruction general description (double precision) 9-19 register to register format 9-19 storage/register format 9-19

interchange operand keys (IOPK) instruction 8-38 interchange registers (IR) instruction 8-39 invert register (VR) instruction 8-102 jump and link (JAL) instruction 8-40 jump if mixed (JMIX) instruction 8-41 jump if not off (JNOFF) instruction 8-43 jump if not on (JNON) instruction 8-43 jump if off (JOFF) instruction 8-41 jump if on (JNON) instruction 8-41 jump on arithmeticall greater than or equal (JGE) instruction 8-43 jump on arithmetically greater than (JGT) instruction 8-43 jump on arithmetically less than (JLT) instruction 8-41 jump on arithmetically less than or equal (JLE) instruction 8-41 jump on carry (JCY) instruction 8-41 jump on condition (JC) instruction 8-41 jump on count (JCT) instruction 8-42 jump on equal (JE) instruction 8-41 jump on even (JEV) instruction 8-41 jump on logically greater than (JLGT) instruction 8-43 jump on logically greater than or equal (JLGE) instruction 8-43 jump on logically less than (JLLT) instruction 8-41 jump on logically less than or equal (JLLE) instruction 8-41 jump on negative (JN) instruction 8-41 jump on no carry (JNCY) instruction 8-43 jump on not condition (JNC) instruction 8-43 jump on not equal (JNE) instruction 8-43 jump on not even (JNEV) instruction 8-43 jump on not mixed (JNMIX) instruction 8-43 jump on not negative (JNN) instruction 8-43 jump on not positive (JNP) instruction 8-43 jump on not zero (JNZ) instruction 8-43 jump on positive (JP) instruction 8-41 jump on zero (JZ) instruction 8-41 jump unconditional (J) instruction 8-39

level exit (LEX) instruction 8-44 load multiple and branch (LMB) instruction 8-44

move address (MVA) instruction storage address to register format 8-47 storage immediate format 8-47 move byte (MVB) instruction register/storage format 8-48 storage/storage format 8-48 move byte and zero (MVBZ) instruction 8-49 move byte field and decrement (MVFD) instruction 8-52 move byte field and increment (MVFN) instruction 8-52 move byte immediate (MVBI) instruction 8-49 move double word (MVD) instruction register/storage format 8-50 storage/storage format 8-50 move double word and zero (MVDZ) instruction 8-51 move word (MVW) instruction register/register format 8-53 register/storage format 8-53

move word (MVW) instruction (continued) register to storage long format 8-53 storage/storage format 8-54 storage to register long format 8-54 move word and zero (MVWZ) instruction 8-57 move word immediate (MVWI) storage immediate format 8-55 storage to register format 8-55 move word short (MVWS) instruction register to storage format 8-56 storage to register format 8-56 multiply byte (MB) instruction 8-45 multiply double word (MD) instruction 8-46 multiply word (MW) instruction 8-58 no operation (NOP) instruction 8-59 operate I/O (IO) instruction 8-38 OR byte (OB) instruction 8-60 register/storage format storage/storage format 8-60 OR double word (OD) instruction register/storage format 8-61 storage/storage format 8-61 OR word (OW) instruction register/register format 8-62 register/storage format 8-62 storage/storage format 8-63 storage to register long format 8-63 OR word immediate (OWI) instruction register immediate format 8-64

storage immediate format 8-64

pop byte (PB) instruction 8-65 pop doubleword (PD) instruction 8-65 pop word (PW) instruction 8-67 push byte (PSB) instruction 8-66 push double word (PSD) instruction 8-66 push word (PSW) instruction 8-67

reset bits byte (RBTB) instruction register/storage format 8-68 storage/storage format 8-68 reset bits double word (RBTD) instruction register/storage format 8-69 storage/storage format 8-69 reset bits word (RBTW) instruction register/register format 8-70 register/storage format 8-70 storage/storage format 8-71 storage to register long format 8-71 reset bits word immediate (RBTWI) instruction register immediate long format 8-72 storage immediate format 8-72

scan byte field equal and decrement (SFED) instruction 8-81 scan byte field equal and increment (SFEN) instruction 8-81 scan byte field not equal and decrement (SFNED) instruction 8-82 scan byte field not equal and increment (SFNEN) instruction 8-82 set address key register (SEAKR) instruction system register/register format 8-75 system register/storage format 8-75 set console data lights (SECON) instruction 8-76 set floating level block (SEFLB) instruction 9-20 set indicators (SEIND) instruction 8-77 set instruction space key (SEISK) instruction system register/register format 8-75 system register/storage format 8-75 set interrupt mask register (SEIMR) instruction 8-76 set level status block (SELB) instruction 8-78 set operand 1 key (SEOOK) instruction system register/register format 8-75 system register/storage format 8-75 set operand 2 key (SEOTK) instruction system register/register format 8-75 system register/storage format 8-75 set segmentation register (SESR) instruction 8-80 set storage key (SESK) instruction 8-79 shift left and test (SLT) instruction 8-88 shift left and test double (SLTD) instruction 8-88 shift left circular (SLC) instruction count in register format 8-83 immediate count format 8-83 shift left circular double (SLCD) instruction count in register format 8-85 immediate count format 8-84 shift left logical (SLL) instruction count in register format 8-86 immediate count format 8-86 shift left logical double (SLLD) instruction count in register format 8-87 immediate count format 8-87 shift right arithmetic (SRA) instruction count in register format 8-89 immediate count format 8-89 shift right arithmetic double (SRAD) instruction count in register format 8-90 immediate count format 8-90 shift right logical (SRL) instruction count in register format 8-91 immediate count format 8-91 shift right logical double (SRLD) instruction count in register format 8-92 immediate count format 8-92 stop (STOP) instruction 8-94 store multiple (STM) instruction 8-93 subtract byte (SB) instruction 8-73 subtract carry indicator (SCY) instruction 8-73 subtract double word (SD) instruction register/storage format 8-74 storage/storage format 8-74 subtract word (SW) instruction register/register format 8-95 register/storage format 8-95 storage/storage format 8-96 storage to register long format 8-96

subtract word immediate (SWI) instruction register immediate long format 8-98 storage immediate format 8-98 subtract word with carry (SWCY) instruction 8-97 supervisor call (SVC) instruction 8-94

test bit (TBT) instruction 8-99 test bit and invert (TBTV) instruction 8-100 test bit and reset (TBTR) instruction 8-99 test bit and set (TBTS) instruction 8-100 test word immediate (TWI) instruction register immediate long format 8-101 storage immediate format 8-101 IBM Series/1 Model 5 4955 Processor and Processor Features Description GA34-0021-1

1

Cut or Fold Along Line

1

READER'S COMMENT FORM

### YOUR COMMENTS, PLEASE ....

Your comments assist us in improving the usefulness of our publications; they are an important part of the input used in preparing updates to the publications. All comments and suggestions become the property of IBM.

Please do not use this form for technical questions about the system or for requests for additional publications; this only delays the response. Instead, direct your inquiries or requests to your IBM representative or to the IBM branch office serving your locality.

Corrections or clarifications needed:

Page Comment

What is your occupation?\_\_\_\_

Number of latest Technical Newsletter (if any) concerning this publication: \_\_\_\_\_ Please indicate your name and address in the space below if you wish a reply.

Thank you for your cooperation. No postage stamp necessary if mailed in the U.S.A. (Elsewhere, an IBM office or representative will be happy to forward your comments.)

GA34-0021-1 1 Your comments, please . . . 1 This manual is part of a library that serves as a reference source for IBM systems. Cut Along Line Your comments on the other side of this form will be carefully reviewed by the persons responsible for writing and publishing this material. All comments and suggestions become the property of IBM. Fold Fold BM Series/1 Model 5 Processor and Processor Features Description (S1-01) Printed in U.S.A. GA34-0021-1 **First Class** Permit 40 1 Armonk New York I 1 **Business Reply Mail** 1 No postage stamp necessary if mailed in the U.S.A. I I **IBM** Corporation Systems Publications, Dept 27T P.O. Box 1328 Boca Raton, Florida 33432 Fold Fold ۱ I 1 Ξ 1, International Business Machines Corporation General Systems Division 5775D Glenridge Drive N.E. ļ P.O. Box 2150, Atlanta, Georgia 30301 (U.S.A. only)

IBM Series/1 Model 5 4955 Processor and Processor Features Description GA34-0021-1

1

ł

1

Cut or Fold Along Line

I.

READER'S COMMENT FORM

## YOUR COMMENTS, PLEASE ....

Your comments assist us in improving the usefulness of our publications; they are an important part of the input used in preparing updates to the publications. All comments and suggestions become the property of IBM.

Please do not use this form for technical questions about the system or for requests for additional publications; this only delays the response. Instead, direct your inquiries or requests to your IBM representative or to the IBM branch office serving your locality.

Corrections or clarifications needed:

Page Comment

What is your occupation?\_

Number of latest Technical Newsletter (if any) concerning this publication: \_\_\_\_\_ Please indicate your name and address in the space below if you wish a reply.

Thank you for your cooperation. No postage stamp necessary if mailed in the U.S.A. (Elsewhere, an IBM office or representative will be happy to forward your comments.)



### Your comments, please . . .

This manual is part of a library that serves as a reference source for IBM systems. Your comments on the other side of this form will be carefully reviewed by the persons responsible for writing and publishing this material. All comments and suggestions become the property of IBM.

Fold Fold IBM Series/1 Model 5 Processor and Processor Features Description (S1-01) Printed in U.S. First Class Permit 40 1 Armonk New York 1 1 **Business Reply Mail** 1 No postage stamp necessary if mailed in the U.S.A. I **IBM** Corporation Systems Publications, Dept 27T P.O. Box 1328 Boca Raton, Florida 33432 1 1 Fold Fold 1 ₽ ١ GA34-0021-1 ΥĒ 1 International Business Machines Corporation General Systems Division 5775D Glenridge Drive N.E. P.O. Box 2150, Atlanta, Georgia 30301 (U.S.A. only) 1 .

1

1

Cut Along Line



International Business Machines Corporation

General Systems Division 5775D Glenridge Drive N.E. P. O. Box 2150 Atlanta, Georgia 30301 (U.S.A. only)

ENTER

THE

1 026 20