Reference Manual

XEROXEROXEROXEROXEROXEROXEROX OXEROXEROXEROXEROXEROXEROXERO pOXEROXEROXEROXEROXEROXEROXER ROXEROXEROXEROXEROXEROXEROXE EROXEROXEROXEROXEROXEROXEROX XEROXEROXEROXEROXEROXEROXERO, OXEROXEROXEROXEROXEROXEROXERC ROXEROXEROXEROXEROXEROXEROXER EROXEROXEROXEROXEROXEROXEROXE XEROXEROXEROXEROXEROXEROXEROX DXEROXEROXEROXEROXEROXEROXERO OXEROXEROXEROXEROXEROXEROXERO ROXEROXEROXEROXEROXEROXEROXES EROXEROXEROXEROXEROXEROXEROX XEROXEROXEROXEROXEROXEROXEROX OXEROXEROXEROXEROXEROXEROXERO ROXEROXEROXEROXEROXEROXEROXER EROXEROXEROXEROXEROXEROXEROXE EEROXEROXEROXEROXEROXEROXEROX

# Xerox 560 Computer 

## Keéerence M̄anuai

## FIRST EDITION

9030 76A

January 1974

Price: \$7.25

## RELATED PUBLICATIONS

Xerox Symbol/LN, OPS Reference Manual ..... 901790
Xerox Meta-Symbol/LN, OPS Reference Manual ..... 900952
Xerox Macro-Symbol/LN, OPS Reference Manual ..... 901578
Manual Content Codes: BP - batch processing, LN - language, OPS - operations, RP - remote processing, RT - real-time, SM - system management, TS - time-sharing, UT - utilities.

## CONTENTS

1. XEROX 560 COMPUTER SYSTEM ..... 1
Introduction ..... 1
General Characteristics ..... 1
Standard and Optional Features ..... 3
General-Purpose Features ..... 3
Time-Sharing Features ..... 4
Real-Time Features ..... 5
Multiuse Features ..... 6
Multiprocessor Features ..... 6
Multiprocessor Interlock ..... 6
Multiport Memory System ..... 7
Manual Partitioning Capability ..... 7
Multiprocessor Control Function ..... 7
Shared Input/Output ..... 7
2. SYSTEM ORGANIZATION ..... 8
Processor Clusters ..... 8
System Control Processor ..... 8
Basic Processor ..... 8
General Registers ..... 8
Memory Control Storage ..... 11
Computer Modes ..... 11
Information Format ..... 12
Information Boundaries ..... 13
Instruction Register ..... 13
Main Memory ..... 14
 ..... 14
Maintainability and Performance ..... 16
Virtual and Real Memory ..... 17
Types of Addressing ..... 19
Memory Address Control ..... 26
Program Status Words ..... 28
Centralized Interrupts ..... 30
States of an Interrupt Level ..... 30
Dialogue Between the Basic Processor and the Interrupt System During an Interrupt-Entering Sequence ..... 32
Dialogue During an Interrupt-Exiting Sequence ..... 32
Physical Organization ..... 32
Interrupt Groups ..... 32
Control of the Interrupt System ..... 35
Single-Instruction Interrupts ..... 36
Trap System ..... 36
Trap Entry Sequence ..... 36
Trap Addressing ..... 36
Trap Condition Code ..... 39
Nonallowed Operation Trap ..... 39
Push-Down Stack Limit Trap ..... 41
Fixed-Point Overflow Trap ..... 41
Floating-Point Arithmetic Fault Trap ..... 42
Decimal Arithmetic Fault Trap ..... 42
Watchdog Timer Runout Trap ..... 43
Programmed Trap ..... 43
Call Instruction Trap ..... 43
Hardware Error Trap ..... 43
Instruction Exception Trap ..... 44
Power On Trap ..... 44
Power Off Trap ..... 44
Processor Detected Fault Flag ..... 44
Register Altered Bit ..... 45
3. INSTRUCTION REPERTOIRE ..... 47
Load/Store Instructions ..... 49
Analyze/Interpret Instructions ..... 57
Fixed-Point Arithmetic Instructions ..... 59
Comparison Instructions ..... 66
Logical Instructions ..... 69
Shift Instructions ..... 70
Floating-Point Shift ..... 72
Conversion Instructions ..... 73
Floating-Point Arithmetic Instructions ..... 74
Floating-Point Numbers ..... 75
Floating-Point Add and Subtract ..... 76
Floating-Point Multiply and Divide ..... 78
Condition Codes for Floating-Point Instructions ..... 78
Decimal Instructions ..... 80
Packed Decimal Numbers ..... 81
Zoned Decimal Numbers ..... 81
Decimal Accumulator ..... 81
Uecimai instruction Formar ..... 81
Illegal Digit and Sign Detection ..... 81
Overflow Detection ..... 82
Decimal Instruction Nomenclature ..... 82
Condition Code Settings ..... 82
Byte-String Instructions ..... 86
Push-Down Instructions (Non-Privileged) ..... 96
Stack Pointer Doubleword (SPD) ..... 96
Push-Down Condition Code Settings ..... 97
Push-Down Instructions (Privileged) ..... 101
Status Stack Pointer Doubleword ..... 101
Execute/Branch Instructions ..... 106
Nonallowed Operation Trap During Execution of Branch Instruction ..... 106
Call Instructions ..... 109
Control Instructions ..... 109
Loading the Memory Map ..... 114
Memory Write Protection Locks ..... 116
Interruption of MMC ..... 117
Memory Access Traps by MMC Instruction ..... 117
Read Direct, Internal Basic Processor Control (Mode 0) ..... 120
Read Direct, Interrupt Control (Mode 1) ..... 121
Read Direct (Mode 9) ..... 123
Write Direct, Internal Basic Processor
Control (Mode 0) ..... 123
Input/Output Instructions ..... 127
Overall Characteristics ..... 127
1/O Status Information ..... 127
4. INPUT/OUTPUT OPERATIONS ..... 142
External DIO Interface ..... 142
Multiplexor Input/Output Processor (MIOP) Device Controllers ..... 142
Rotating Memory Processor (RMP) ..... 143
Input/Output Processor (IOP) Fundamentals ..... 143
Command List ..... 143
Operational IOCD ..... 143
Control IOCD ..... 146
I/O Operation Phases ..... 148
Preparation Phase ..... 148
Initiation Phase ..... 148
Fetching Phase ..... 148
Execution Phase ..... 149
Termination Phase ..... 151
5. OPERATIONAL CONTROL ..... 152
External Control Subsystem ..... 152
Centralized System Control ..... 152
Control Console Devices ..... 152
Control Commands ..... 153
Operator Control Commands ..... 153
Diagnostic Control Commands ..... 156
Maintenance Control Commands ..... 158
System Control Panel ..... 161
Operating Procedures and Information ..... 164
6. SYSTEM CONFIGURATION CONTROL ..... 167
Configuration Control Panel (CCP) ..... 167
APPENDIXES
A. REFERENCE TABLES ..... 173
Standard Symbols and Codes ..... 173
Standard Character Sets ..... 173
Control Codes ..... 173
Special Code Properties ..... 173
Standard 8-Bit Computer Codes (EBCDIC) ..... 174
Standard 7-Bit Communication Codes (ANSCII) ..... 174
Standard Symbol-Code Correspondences ..... 175
Hexadecimal Arithmetic ..... 179
Addition Table ..... 179
Multiplication Table ..... 179
Table of Powers of Sixteen 10 ..... 180
Table of Powers of Ten 16 ..... 180
Hexadecimal-Decimal Integer Conversion
Table ..... 181
Hexadecimal-Decimal Fraction Conversion Table ..... 187
Table of Powers of Two ..... 191
Mathematical Constants ..... 191
B. GLOSSARY OF SYMBOLIC TERMS ..... 192
C. FAULT STATUS REGISTERS ..... 195

FIGURES

1. A Xerox 560 Computer System ..... 9
2. The Basic Processor ..... 10
3. Information Boundaries ..... 13
4. Main Memory ..... 15
5. Addressing Logic ..... 18
6. Index Displacement Alignment (Real and Virtual Addressing Modes) ..... 21
7. Generation of Actual Addresses Indirect, Virtual Addressing ..... 22
8. Index Displacement Alignment (Real- Extended Addressing) ..... 23
9. Generation of Effective Virtual Address (Indirect Real-Extended Addressing) ..... 24
10. Operational States of an Interrupt Level ..... 31
11. Interrupt Priority Chain ..... 34
12. Typical 28 -Word Portion of Memory Stack for PSS and PLS ..... 102
13. Formats of $\mathrm{I} / \mathrm{O}$ Instructions ..... 128
14. Bootstrap Loader ..... 155
15. System Control Panel ..... 162
16. Chassis Physical Configuration ..... 168
17. Sample Rows of CCP Switches ..... 168
TABLES
18. Basic Processor Operating Modes and Addressing Cases ..... 25
19. Interrupt Locations ..... 33
20. Summary of Trap Locations ..... 37
21. TCC Setting for Instruction Exception Trap X $^{\prime} 4 D^{\prime}$ ..... 44
22. Registers Changed at Time of a Trap Due to an Operand Access ..... 45
23. ANALYZE Table for Operation Codes ..... 57
24. Floating-Point Number Representation ..... 76
25. Condition Code Settings for Floating-Point Instructions ..... 79
26. Status Word 0 ..... 119
27. Status Word 1 ..... 119
28. Read Direct Mode 9 Status Word ..... 123
29. Chassis Type Assignments ..... 124
30. Description of $\mathrm{I} / \mathrm{O}$ Instructions ..... 128
31. I/O Status Information (Register R) ..... 130
32. Device Status Byte (Register R or Rul) (SIO, TIO, and HIO only) ..... 131
33. Operational Status Byte (Register RuI) ..... 132
34. Status Response Bits for I/O Instructions ..... 133
35. IOP Status Byte ..... 134
36. Status Response Bits for AIO Instruction ..... 135
37. I/O Address (AIO Response) ..... 135
38. Event Messages ..... 153
39. Diagnostic Control (P-Mode) Commands ..... 157
40. Bit Assignments and Description, Processor Control Word, Register Q30 (X'IE') ..... 165
41. Bit Assignments, Address Compare Register Q31 (X'1F') ..... 166
42. Functions of Processor Cluster Configuration Control Panel Row ..... 169
43. Functions of Memory Unit Configuration Control Panel Row ..... 170
C-I. Fault Status Registers ..... 195
C-2. Memory Unit Status Register ..... 196

## 1. XEROX 560 COMPUTER SYSTEM

## INTRODUCTION

The Xerox 560 general-purpose, digital, computer system accommodates a variety of scientific, business, real-time, and time-sharing applications. A system includes system control, basic processor, I/O processor, and main memory (up to 256 K words) with two ports. Each major system element performs asynchronously with respect to other elements.

The basic system can be readily expanded. Memory access paths can be increased from the basic two ports to a maximum of six ports. Input/output capability can be increased by adding more input/output processors (IOPs), device controllers, and peripheral devices.

The basic processor (BP) has an extensive instruction set that includes floating-point, byte-string, and decimal instructions.

The multiaccess memory units, with interleaving, afford a high level of system performance. Main memory can be expanded in 16 K word increments to a maximum of 256 K words. Address interleaving may be performed between memory units of like size. The number of ports to each memory unit can be expanded to allow independent access to memory by up to six "processor clusters" (i.e., functional groups).

Processor clusters are the grouping of two or more functions (such as a basic processor, an I/O processor, and interfaces) on a common bus. Clustering permits processors to share common facilities, e. g. , buses and memory interfaces. Therefore, the hardware is less redundant, hence less complex, resulting in more reliability at a lower cost. There are multiple combinations of functional groups from which to select.

Existing Sigma 5-9 programs may be run on the system. The upward compatibility of the comprehensive, modular software (assemblers, compilers, mathematical and utility routines, and application packages) eliminates reprogramming.

Features have been incorporated in this design to enhance overall system reliability, maintainability, and availability. Centralized switches for system repartitioning may permit faulty units, or an entire subsystem, to be isolated for diagnosis or repair while the primary system continues operation. Parity checking is performed on each byte of information for most system interfaces and internal control signals. Most failed instructions are automatically retried, and uninterrupted processing continues. The only apparent effect may be an entry in the error log. In the event an error is irrecoverable, there are error storage registers that return complete data on the fault and the status of the system at that point.

## GENERAL CHARACTERISTICS

The following system features and characteristics permit efficient operation in general-purpose, multiprocessor, time-sharing, real-time, and multiuse environments:

- Word-oriented memory (32-bit word plus parity bit per byte) that can be addressed and altered as byte (8-bit), halfword (2-byte), word (4-byte), and doubleword (8-byte) quantities.
- Memory expandable to 256 K words $(\mathrm{K}=1024)$ in modular units of 16 K words each.
- Indirect addressing with or without postindexing.
- Displacement index registers, automatically selfadjusting for all data sizes.
- Immediate operand instructions for greater storage efficiency and increased speed.
- Four blocks of 16 general-purpose registers for addressing, indexing, and accumulating. Multiple registers permit rapid context switching.
- Hardware memory mapping, which virtually eliminates memory fragmentation and provides dynamic program relocation.
 security and protection.
- Memory write protection within memory units to prevent inadvertent destruction of critical areas of memory from any processor cluster.
- Watchdog timer to assure nonstop operation.
- Real-time priority interrupt system with automatic identification and priority assignment, fast response time, and 14 internal and up to 48 external levels that can be individually armed, enabled, and triggered by program control.
- Instructions with long execution times can be interrupted.
- Automatic traps for error or fault conditions, with masking capability and maximum recoverability, under program control.
- Power fail-safe for automatic shutdown and resumption of processing in event of power failure.
- Multiple interval timers with a choice of resolutions for independent time bases.
- Privileged instruction logic for program integrity in multiuse environments.
- Extensive instruction set that includes:
- Byte, halfword, word, and doubleword operations.
- Use of all memory-referencing instructions for register-to-register operations, with or without indirect addressing and postindexing, and within normal instruction format.
- Multiple register operations.
- Fixed-point integer arithmetic operations in halfword, word, and doubleword modes.
- Immediate operand instructions.
- Floating-point hardware operations in short and long formats with significance, zero, and normalization control and checking, all under full program control.
- Full complement of logical operations (AND, OR, exclusive $O R$ ).
- Comparison operations, including compare between limits (with limits in memory or in registers).
- Call instructions that permit up to 64 dynamically variable, user-defined instructions, and allow a program access to operating system functions without operating system intervention.
- Decimal hardware operations, including arithmetic, edit, and pack/unpack.
- Byte-string instructions.
- Push-down stack operations (hardware implemented) of single or multiple words, with automatic limit checking, for dynamic space allocation, subroutine communication, and recursive routine capability.
- Automatic conversion operations, including binary/ $B C D$ and any other weighted-number systems.
- Analyze instruction that facilitates effective address computation.
- Interpret instruction that increases speed of interpretive programs.
- Shift operations (left and right) of word or doubleword, including logical, circular, arithmetic, searching shift, and floating-point modes.
- Built-in reliability and maintainability features that include:
- Extensive error logging. When a fault is detected, system status and fault information are available for program retrieval and logging for subsequent analysis.
- Full parity checking on all data and addresses communicated in either direction on buses between memory units and processors, providing fault detection and location capability to permit the operating system or diagnostic program to quickly determine a faulty unit.
- Address stop feature that permits operator or maintenance personnel to:

Stop on any instruction address.
Stop on any memory reference address.
Stop when any word in a selected page of memory is referenced.

- Traps that provide for detection of a variety of fault conditions, designed to enable a high degree of system recoverability.
- Partitioning features that enable system reconfiguration via a centralized Configuration Control Panel. Units may be partitioned from the system by selectively disabling them from buses (assuming other system facilities can handle the additional load). Thus, faulty units, processors, devices, or an alternate system can be isolated from the operational system to enable diagnosis or repair while the primary system continues operation.
- Independently operating I/O system with the following features:
- Direct input/output (READ DIRECT, WRITE DIRECT instructions) for transfer of 32-bit words between the specified general register and an external device; a 16-bit address is transferred for selection and control purposes; and each transfer is under direct program control.
- Up to five independent $1 / \mathrm{O}$ processor clusters (restricted only by the maximum number of 6 ports).
- Multiplexor I/O processors (MIOPs) (up to 3 per I/O cluster), each providing for simul taneous operation of up to 16 devices per processor.
- Data chaining for gather-read and scatter-write operations.
- Command chaining for multiple record operations.
- Write lock protect feature within memory unit for positive protection from all processors storing into memory.
- Comprehensive modular software that is program compatible with Sigma 5-9 computers:
- Expands in capability and speed as system grows.
- Operating system: Control Program-Five (CP-V).
- Language processors and utilities and applications software for both commercial and scientific users.
- Peripheral equipment includes:
- Card equipment: Reading speeds up to 1500 cards per minute; punching speed of 100 cards per minute; intermixed binary and EBCDIC card codes.
- Line printers: Fully buffered with speeds up to 1250 lines per minute; 132 print positions with character sets containing 64 or 95 characters.
- Magnetic tape units: 9-track systems, single or dual density ( 1600 or $800 / 1600 \mathrm{BPI}$ ), industrycompatible; high-speed, automatic loading units operating at 125 inches per second with transfer rates up to 200,000 bytes per second; and at 75 inches per second with transfer rates up to 120,000 bytes per second.
- Rapid Access Data (RAD) and disk files: RAD capacity of 2.9 million bytes, with a transfer rate of 750,000 bytes per second; disk capacities in increments of 86 million bytes (formatted) per unit with a transfer rate of 806,000 bytes per second, and in increments of 49 million bytes per unit with a transfer rate of 312,500 bytes per second.
- Keyboard printers: 10 characters per second.
- Data communications equipment: Complete line of character-oriented, message-oriented, and procedure-oriented equipment to connect remote user terminals (including remote batch) to the computer center via common carrier lines and local terminals directly.


## STANDARD AND OPTIONAL FEATURES

A basic system has the following standard features:

- A basic processor (BP) that includes:
- Full instruction set
- Memory map with access protection
- Register blocks (4)
- Multiplexor Input/Output Processor (MIOP) with:
- 16 subchannels
- 1- or 4-byte interface
- Input/Output Adapter
- Two memory units that include:
- Dual port access
- Memory write lock protection
- A system control processor that includes:
- Real-time clocks (4)
- Internal interrupts (14)
- Power fail-safe detection
- External Direct Input/Output Interface (DIO)
- External Control Subsystem (ECS)
- System Control Panel (SCP)
- Configuration Control Panel (CCP)
- Local and remote assist facility
- Error detection facilities
- Diagnostics

A system may have the following optional features:

- BP options:
- Up to 48 external priority interrupts (in groups of 12)
- Memory options:
- Memory expansion up to 256 K words
- Up to 4 additional access ports (in sets of 2).
- Input/Output options:
- Multiple I/O clusters ${ }^{\dagger}$.
- Up to 3 additional MIOPs, each with 16 subchannels, per cluster.
- One Input/Output Adapter (for one MIOP) per cluster.
- One Rotating Memory Processor (RMP) per cluster.


## GENERAL-PURPOSE FEATURES

General-purpose computing applications are characterized by emphasis on computation and internal data handling.

[^0]Many operations are performed in floating-point format and on strings of characters. Other typical characteristics include decimal arithmetic operations, binary to decimal number conversion (for printing or display), and high system input/output transfer rates.

General-purpose features are described in the following paragraphs.

Floating-Point Hardware. Both short (32-bit) and long (64-bit) formats are available in the floating-point instructions. Under program control, the user may select optional zero checking, normalization, floating-point rounding and significance checking. Significance checking permits use of short floating-point format for high processing speed and storage economy and of long floatingpoint format when loss of significance is detected.

Decimal Arithmetic Hardware. Decimal arithmetic instructions operate on up to 31 digits plus sign. This instruction set includes pack/unpack instructions for convertingto/from the packed format of two digits per byte, and a generalized edit instruction for zero suppression, check protection, and formatting, with punctuation to display or print it.

Indirect Addressing. Indirect addressing facilitates table linkages and permits keeping data sections of a program separate from procedure sections for ease of maintenance.

Displacement Indexing. Indexing by means of a"floating" displacement permits accessing a desired unit of data without considering its size. The index registers automatically align themselves appropriately; thus, the same index register may be used on arrays with different data sizes. For example, in a matrix multiplication of any array of full word, single-precision, fixed-point numbers, the results may be stored in a second array as double-precision numbers, using the same index quantity for both arrays. If an index register contains the value of $k$, then the user always accesses the kth element, whether it is a byte, halfword, word, or doubleword. Incrementing by various quantities according tio data size is not required; iñstead, incrementing is always by units in a continuous array table regardless of the size of data element used.

Instruction Set. More than 100 major instructions permit short, highly optimized programs to be written. These are rapidly assembled and minimize both program space and execution time.

Translate Instruction. The Translate instruction permits rapid translation between any two 8-bit codes; thus, data from a variety of input sources can be handled and reconverted easily for output.

Conversion Instructions. Two generalized conversion instructions provide for bidirectional conversions between internal binary and any other weighted number system, including BCD.

Call Instructions. These four instructions permit handling up to 64 user-defined subroutines, as if they were built-in machine instructions. Call instructions also gain access to specified operating system services without requiring its intervention.

Interpret Instruction. The Interpret instruction simplifies and speeds interpretive operations such as compilation, thus reducing space and time requirements for compilers and other interpretive systems.

Four-Bit Condition Code. Checking results is simplified by automatically providing information on almost every instruction execution, including indicators for overflow, underflow, zero, minus, and plus, as appropriate, without requiring an extra instruction execution.

Direct Input/Output (DIO). Direct input/output facilitates in-line program control of asynchronous or specialpurpose devices. This feature permits information to be transmitted directly to or from general-purpose registers.

Multiplexor Input/Output Processor (MIOP). Once initialized, 1/O processors operate independently of the basic processor, freeing it to provide faster response to system needs. An MIOP requires minimal interaction with the basic processor. I/O command doublewords permit both command chaining and data chaining without intervening basic processor control. I/O equipment speeds range from slow rates involving human interaction (teletypewriter, for example) to transfer rates of rotating memory devices of over 750,000 bytes per second. Peripheral controllers attached to an MIOP may be operated simultaneously.

Rotating Memory Processor (RMP). An RMP supports up to 15 disk drives, one at a time, permitting large capacity, high transfer rate files. Dual access (between 2 RMPs) option is available.

## TIME-SHARNG FEATURES

Time-sharing is the ability of a system to share its total resources among many users at the same time. Each user may be performing a different task, requiring a different share of the available resources. Some users may be online in an interactive, "conversational" mode with the basic processor while other users may be entering work to be processed that requires only final output.

Time-sharing features are described in the following paragraphs.

Rapid Context Saving. When changing from one user to another, the operating environment can be switched quickly and easily. Stack-manipulating instructions permit storing in a push-down stack of 1 to 16 general-purpose registers by a single instruction. Stack status is updated automatically and information in the stack can be retrieved when needed
(also, by a single instruction). The current program status words, which contain the entire description of the current user's environment and mode of operation, may be stored anywhere in memory, and new program status words may be loaded, all with a single instruction.

Multiple Register Blocks. The availability of four blocks of 16 general-purpose registers improves response time by reducing the need to store and load register blocks. A distinct block may be assigned for different functions as needed; the program status words automatically select the applicable register block.

User Protection. The slave mode feature restricts each user to his own set of instructions while reserving to the operating system certain "privileged" (master mode) instructions that could destroy another user's program if used incorrectly. Also, a memory access - protection feature prevents a user from accessing any storage areas other than those assigned to him. It permits him to access certain areas for reading only, such as those containing public subroutines, while preventing him from reading, writing, or accessing instructions in areas set aside for other users.

Storage Management. Main memory is expandable to 256 K (K = 1024) words. To make efficient use of available memory, the memory map hardware permits storing a user's program in fragments as small as a page of 512 words, wherever space is available; yet all fragments appear as a single, contiguously addressable block of storage at execution time. The memory map also automatically handles dynamic program relocation so that the program appears to be stored in a standard woy nt execution time, even though it may actually be stored in a different set of locations each time it is brought into memory. The memory map provides the ability to locate any 128 K -word virtual program in the basic processor's logical addressing space. Thus, the system can always address a virtual memory of 128 K words regardless of physical memory size.

Input/Output Capability. Time-sharing input/output requirements are handled by the same general-purpose input/ output capabilities described under "General-Purpose Features".

Nonstop Operation. A "watchdog" timer assures that the system continues to operate even in case of halts or delays due to failure of special I/O devices. Multiple real-time clocks with varying resolutions permit independent time bases for flexible allocation of time slices to each user.

Reliability, Maintainability, Availability. Since timesharing systems have many on-line users needing immediate system response, "downtime" defeats time sharing's primary purpose. Pooling of resources along with flexible reconfiguration control ensures a high level of continuous availability. Configuration controls are provided to switch the load from one unit to another in the event of a failure with no loss of functional capability, only capacity. In addition, a nonworking subset of the total system may be
logically isolated (partitioned) so that maintenance may proceed on the subset while the remainder of the system continues to operate.

To minimize the effect of transient errors, automatic retry of failed instructions is performed.

## REAL-TIME FEATURES

Real-time applications are characterized by a need for: (1) hardware that provides quick response to an external environment; (2) speed that is sufficient to keep up with the real-time process itself; (3) input/output flexibility to handle a wide variety of data types at different speeds; and (4) reliability features to minimize irreplaceable lost time.

Multilevel, Priority Interrupt System. The real-timeoriented system provides rapid response to external interrupt levels. Each interrupt is automatically identified and responded to according to its priority. For further flexibility, each level can be individually disarmed (to discontinue input acceptance) and disabled (to defer responses). Use of the disarm/disable feature makes programmed dynamic reassignment of priorities quick and easy, even while a realtime process is in progress.

Programs involving interrupts from specially designed equipment often require checkout before the equipment is actually available. To permit simulating this special equipment, any external interrupt level can be "triggered" by the basic processor through execution of a single instruction. This capability is also useful in establishing a modified hierarchy of responses. For example, in responding to a high-priority interrupt, after the urgent processing is completed, it may be desirable to assign a lower priority to the remaining portion so that the interrupt routine is free to respond to other critical stimuli. The interrupt routine can accomplish this by triggering a lower-priority level, which processes the remaining data only after other interrupts have been handled.

READ DIRECT and WRITE DIRECT instructions (described in Chapter 3) allow the program to completely interrogate, preserve, and alter the condition of the interrupt system at any time and to restore that system at a later time.

Nonstop Operation. When connected to special devices (on a ready/resume basis), the basic processor may be excessively delayed if the specific device does not respond quickly. As in the time-sharing environment, the built-in watchdog timer assures that the basic processor cannot be delayed for an excessive length of time.

Real-Time Clocks. Many real-time functions must be timed to occur at specific instants. Other timing information is also needed - for example, elapsed time since a given event, or the current time of day. The computer system can contain up to four real-time clocks with varying degrees of resolution to meet these needs. These clocks also allow easy handling of separate time bases and relative time priorities.

Rapid Context Switching. When responding to a new set of interrupt-initiated circumstances, a computer system must preserve the current operating environment, for continuance later, while setting up the new environment. This changing of environments must be done quickly, with a minimum of "overhead" time costs. Any one of the four blocks of general-purpose arithmetic registers can, if desired, be assigned to a specific environment. All relevant information about the current environment (instruction address, current general register block, memory-protection key, etc.) is kept in the program status words. A single instruction stores the current program status words anywhere in memory and loads new ones from memory to establish a new environment, which includes information identifying a new block of general-purpose registers. Thus, the system's operating environment can be preserved and changed completely through the execution of a single instruction.

Memory Protection. Both foreground (real-time) and background can run concurrently in the system because a foreground program is protected against destruction by an unchecked background program. Under operating system control, the memory access-protection feature prevents accessing memory for specified combinations of reading, writing, and instruction acquisition.

Variable Precision Arithmetic. Much of the data encountered in real-time systems are 16 bits or less. To process this data efficiently, both halfword and fullword arithmetic operations are provided. For extended precision, doubleword arithmetic operations are also included.

Direct Input/Output. For handling asynchronous I/O, a 32-bit word can be transferred directly between any generalpurpose register and external devices.

Reliability, Maintainability, Availability. The capabilities described in the section, "Time-Sharing Features" apply equally to the real-time environment.

## MULTIUSE FEATURES

As implemented in this system, "multiuse" combines two or more application areas. The real-time application is the most difficult general computing task because of its severe requirements. Similarly, another difficult multiuse task is a time-sharing application that includes one or more realtime processes. Because the system is designed on a realtime base, it is qualified for a mixture of applications in a multiuse environment. Many hardware features that prove valuable for certain application areas are equally useful in others, although in different ways. This multiple capability makes the system particularly effective in multiuse applications.

The major multiuse features are described in the following paragraphs.

Priority Interrupt System. In a multiuse environment, many elements operate simulatneously and asynchronously. Thus, an efficient priority interrupt system is essential. It allows the computer system to respond quickly, and in proper order, to the many demands made on it, with attendant improvements in resource efficiency.

Quick Response. The many features that combine to produce a quick-response system (multiple register blocks, rapid context saving, multiple push-pull operations) benefit all users because more of the system's resources are readily available at any instant.

Memory Protection. The memory protection features protect each user from every other user and guarantee the integrity of programs essential to critical real-time applications.

Input/Output. Because of the wide range of capacities and speeds, the I/O system simultaneously satisfies the needs of many different application areas economically, both in terms of equipment and programming.

Instruction Set. The comprehensive instruction set provides the computational and data-handling capabilities required for widely differing application areas; therefore, each user's program length and running time is minimized, and the throughput is maximized.

## MULTIPROCESSOR FEATURES

System design readily permits expansion to shared memory in a multiprocessor system. The system can contain a combination of functional clusters, each of which in turn may contain multiple processors. The total number of clusters is restricted to the maximum port limitation of six. All processors in a system may share common memory.

The following paragraphs describe the major multiprocessor features of the system.

## MULTIPROCESSOR INTERLOCK

In a multiprocessor system, the basic processors often need exclusive control of a system resource. This resource may be a region of memory, a particular peripheral device, or, in some cases, a specific software process. There is a special instruction to provide this required multiprocessor interlock. This special instruction, LOAD AND SET, unconditionally sets a " 1 " bit in the sign position of the referenced memory location during the restore cycle of the memory operation. If this bit had been previously set by another processor, the interlock is said to be "set" and the testing program proceeds to another task. On the other hand, if the sign bit of the tested location is a zero, the resource is allocated to the testing processor, and simultaneously the interlock is set for any other processor.

## MULTIPORT MEMORY SYSTEM

The system has growth capability of up to 6 ports per memory unit. A memory unit may contain 16 K or 32 K words. This architecture allows flexibility in growth patterns and provides high memory bandwidth, essential to multiprocessor systems.

## MANUAL PARTITIONING CAPABILITY

Manual partitioning capability is afforded for all system units. Thus, besides the primary advantage of increased throughput, a secondary advantage of a multiprocessor system is the "fail-soft" ability. Given a duplicate unit, any unit can be partitioned by selectively disabling it from the system buses. Depending on the type of failing unit, the system will be operable, with some degree of degraded performance. An alternate processor bus with dual system capabilities can be provided.

## MULTIPROCESSOR CONTROL FUNCTION

A multiprocessor control function is provided on all multiprocessor systems. This function provides these basic features:

1. Control of the External Direct Input/Output bus (External DIO), used for controlling system maintenance
and special purpose units such as analog to digital converters.
2. Central control of system partitioning.
3. Centralized interrupt system, providing capability for the operating system to use interrupts to schedule tasks independently of the number of basic processors present in a system.
4. Processor to processor communication via processor buses.

## SHARED INPUT/OUTPUT

In a multiprocessor system, any basic processor may direct I/O actions to any I/O processor. Specifically, any basic processor can issue an SIO, TIO, TDV, or HIO instruction to begin, test, or stop any I/O process. However, the "end-action" sequence of the I/O process is directed to one of the basic processors in the system by the System Control Processor. This feature (accomplished by setting a pair of configuration control switches) allows dedicating I/O end-action tasks to a single processor and avoids conflict resolution problems.

## 2. SYSTEM ORGANIZATION

The elements of this computer system include a basic processor (BP), input/output processors (IOPs), memory, I/O device controllers, and devices (see Figure 1). The processors and interfaces clustered into functional groups, interconnected via buses and controlled from a Configuration Control Panel and a System Control Processor. Elements within a processor cluster share an access path for intracluster communications. Thus, the total computer system can be viewed functionally as a group of program-controlled processor clusters communicating with each other and a common memory. Each processor cluster operates asynchronously and semi-independently, automatically overlapping the operation of elements within as well as the operation of other processor clusters for greater speed (when circumstances permit).

## PROCESSOR CLUSTERS

Processors (basic processor and MIOP, for example) are grouped functionally along with a Memory Interface (MI) and a Processor Interface (PI) into a processor cluster. Elements within a processor cluster share an access path (the cluster bus) to the Memory Inferface, which connects to the memory system via a memory bus. The Memory Interface resolves contention problems and controls use of the cluster bus by the elements in the cluster.

A processor communicates with processors in other processor clusters through the Processor Interface, which connects directly to a processor bus. Via the processor bus, any processor can communicate with or control any other processor anywhere in the system configuration.

Note: Although two processor buses are provided, a Processor Interface can be connected to one or the other of the processor buses, but not to both at the same time.

Within a basic processor-MIOP processor cluster, the basic processor primarily performs overall control and data reduction tasks whereas the MIOP performs the task associated with the exchange of digital information between main memory and selected peripheral devices. The MIOP communicates with device controllers via the I/O bus, which connects to the Controller Interface (CI).

## SYSTEM CONTROL PROCESSOR

The System Control Processor performs these primary functions in the overall system:

1. System control.
2. External Control Subsystem.
3. Internal and external interrupt processing.
4. External and certain internal direct I/O (DIO) control.

It provides these major interfaces with other parts of the system:

1. System console interface.
2. System control bus interface.
3. Processor bus interface.
4. Internal and external interrupt interfaces.
5. External and certain internal DIO interfaces.
6. System clock interface.

In addition to these major interfaces it provides paths for other signals including system reset, 1.024 MHz clock, power on/power off trap requests, and external real-time clocks.

Figure 1 shows the interconnection of a System Control Processor to processor clusters via a processor bus as wellas interconnection to the system console, external Direct Input/ Output (DIO), and external interrupts.

## BASIC PROCESSOR

This section describes the organization and operation of the basic processor in terms of instruction and data formats, information processing, and program control. The basic processor comprises a fast memory and an arithmetic and control unit as functionally shown in Figure 2.

Note: Functionally associanted with the basic processor but physically located elsewhere are a memory map, memory access protection codes, and memory write protection codes. Memory control storage for the memory map and access codes is located in the Memory Interface, and the memory control storage for the write protection codes (write locks) is located in the memory. These functions are described in "Memory System", later in this chapter.

## GENERAL REGISTERS

A fast (integrated circuit) memory consisting of ninety-six 32-bit registers is used within the basic processor. A group of 24 registers is referred to as a register block; thus, a basic processor contains four register blocks. A 2-bit control field (called a register block pointer) in the program status words (PSWs) selects the register block currently


Figure 1. A Xerox 560 Computer System

FAST MEMORY


Figure 2. The Basic Processor
available to a program. The register block pointer can be changed when the basic processor is in the master mode or the master-protected mode. Only the first 16 general registers of a register block may be used by programs; the last eight are reserved.

Each of the first 16 general registers in a register block is identified by a 4 -bit code in the range $0000_{2}$ through $1111_{2}$ ( 0 through 15 in decimal notation, or $X^{\prime} 0^{\prime}$ through $X^{\prime} F^{\prime}$ in hexadecimal notation). Any of these 16 registers can be used as a fixed-point temporary data storage location, or to contain control information such as a data address, count, pointer, etc. General registers 1 through 7 can be used as index registers and registers 12 through 15 can be used as a decimal accumulator capable of containing a decimal number of 31 digits plus sign. Registers 12 through 15 are always used when a decimal instruction is executed.

## MEMORY CONTROL STORAGE

The memory control storage for the memory map and the associated memory access protection codes are contained in the Memory Interface (MI). Memory control storage for the 4-bit write locks are contained in the memory units. Memory control storage can be modified when the basic processor is in the master mode or the master-protected mode.

## MEMORY MAP

Two terms are essential in understanding the memory mapping concept: actual (i.e., absolute or real) address and virtual address.

An actual address is used within the memory unit (memory address registers) to access a specific, physical memory location for storage or retrieval of information as required by the execution sequence of an instruction. Actual addresses are fixed and are dependent on the wired-in hardware.

A virtual address refers to a logical location as required by an individual program. Like an actual address, a virtual address may designate a location that contains a program instruction, an element of data, a data address (indirect address), or it may also be an explicit quantity. Normally, virtual addresses are derived from programmer-supplied labels through an assembly (or compilation) process followed by a loading process. Virtual addresses may also be computed during a program's execution. Virtual addresses include all instruction addresses, indirect addresses, and addresses used as counts within a stored program, as well as those instructions computed by the program. (See "Virtual and Real Memory", later in this chapter.)

Memory mapping transforms virtual addresses as seen by the individual program into actual addresses as seen by the memory system. Thus, when the memory map is in effect, any program can be broken into 512 -word pages and dynamically relocated throughout memory in whatever pages of space are available.

When the memory map is not in effect, all virtual address values above ${ }^{15} 10$ are used by the memory as actual addresses. Virtual addresses 0 through 15 are always ${ }^{\dagger}$ used by the basic processor as general register addresses rather than as memory addresses. For example, if an instruction uses virtual address 5 to address the location where a result is to be stored, the basic processor stores that result in general register 5 in the current register block instead of in memory location 5.

When the basic processor is operating with the memory map in effect, virtual addresses 0 through 15 are still used as general register addresses. Virtual addresses above 15 are transformed into actual addresses by replacing the highorder portion of the virtual address with a value obtained from the memory map. (The memory map address replacement process is described in "Memory Address Control", later in this chapter.)

## MEMORY ACCESS PROTECTION

When the basic processor is operating with the memory map in the slave mode or the master-protected mode, the access protection codes determine whether the program may access instructions from, read from, or write into specific regions of the virtual address continuum (virtual memory). If the slave mode or master-protected mode program attempts to access a protected region of virtual memory, a trap occurs (see "Memory Address Control", "Virtual and Real Memory", and "Trap System", later in this chapter).

## MEMORY WRITE PROTECTION

The memory write-protection feature operates independently of access protection and the memory map. The 4-bit write lock operates in conjunction with a 4 -bit field, called the write key, in bits 32-35 of the Program Status Words (PSWs). The lock and the key determine whether any program may alter any word of main memory. The write key can be changed when the basic processor is in the master mode or the master-protected mode. (The functions of the write lock and key are described in "Memory Address Control", later in this chapter.)

## COMPUTER MODES

The basic processor operates in one of three modes: master, master-protected, or slave. The operation mode is determined by the setting of three bits (bits 8, 9, and 61) of the Program Status Words (PSWs). (See "Program Status Words", later in this chapter.) Additionally, the basic processor operates in a mapped mode or an unmapped mode.

[^1]
## MASTER MODE

The master/slave control bit (bit 8 of the PSWs) must contain a zero for the basic processor to operate in master mode. In this mode the basic processor can perform all of its control functions and can modify any part of the system. The restrictions upon the basic processor's operations in this mode are those imposed by the write locks on certain protected parts of memory. It is assumed that there is a resident operating system (operating in the master mode) that controls and supports the operation of other programs (which may be in the master, master-protected, or slave mode).

## MASTER-PROTECTED MODE

The master-protected mode of operation provides additional protection for programs that operate in the master mode. The master-protected mode occurs when the basic processor is operating in the master mode with the memory map in effect and the mode altered control bit (bit 61 of the PSWs) is on. In this mode the memory protection violation trap occurs (location $X^{\prime} 40^{\prime}$, with CC4 = 1), as it does in all mapped slave programs, if a program makes a reference to a virtual page to which access is prohibited by the current setting of the access protection codes.

## SLAVE MODE

The slave mode of operation is the problem-solving mode of the basic processor. In this mode, access protection codes apply to the slave mode program if mapping is in effect, and all "privileged"operations are prohibited. Privileged operations are those relating to input/output and to changes in the fundamental control state of the basic processor. All privileged operations are performed in the master or master-protected mode by a group of privileged instructions. Any attempt by a program to execute a privileged instruction while the basic processor is in the slave mode results in a trap. The master/slave mode control bit (bit 8 of the PSWs) can be changed when the basic processor is in the master or master-protected mode. Nevertheless, a slave mode program can goin direct access to certain executive program operations by means of CALL instructions. The operations available through CALL instructions are established by the resident operating system.

## MAPPED MODE

Although the memory map is located in the Memory Interface (MI), it functions as part of the basic processor. The basic processor communicates with memory through the MI. Mapping is effective for all the words of real memory, and is invoked when bit 9 (MM) of the PSWs contains a one. Memory mapping generares reai page addresses from virtual addresses. The memory map can be loaded with either ll-bit real page addresses or 8-bit real page addresses by means of the MOVE MEMORY CONTROL (MMC) privileged instruction (see Chapter 3, "Control Instructions"). Elevenbit real page addresses are always provided for in the map, thus if 8 -bit real page addresses are generated, the three
high-order bits contain zeros. The memory map always maps 17-bit virtual addresses into 20-bit real addresses (see "Memory Address Control", later in this chapter for a discussion of how the map is used).

## UNMAPPED MODE

When the basic processor is operating in the unmapped mode, there is a direct one-to-one relationship between the effective virtual address of each instruction and the actual address used to access main memory. (See "Real Addressing", later in this chapter.)

## INFORMATION FORMAT

Nomenclature associated with digital information within the computer system is based on functional and/or physical attributes. A "word" may be either a 32-bit instruction word or a 32-bit data word.

The bit positions of a word are numbered from 0 through 31 as follows:


A word can be divided into two 16-bit parts (halfwords) in which the bit positions are numbered from 0 through 15 as follows:

| Halfword 0 | Halfword 1 |
| :---: | :---: |

A word can also be divided into four 8-bit parts (bytes) in which the bit positions are numbered 0 through 7 as follows:

| Byte 0 | Byte 1 | Byte 2 | Byte 3 |
| :---: | :---: | :---: | :---: |
| $0123 / 45670$ | $23 / 45670123 / 45670123 / 4567$ |  |  |

Two words can be combined to form a 64-bit element (a doubleword) in which the bit positions are numbered 0 through 63 as follows:


In fixed-point binary arithmetic each element of information represents numerical data as a signed integer (bit 0 represents the sign, remaining bits represent the magnitude, and the binary point is assumed to be just to the right of the least significant or righimost bit). Negative values are represented in two's complement form. Other formats required for floating-point and decimal instructions are described in Chapter 3.

## INFORMATION BOUNDARIES

Basic processor instructions assume that bytes, halfwords, and doublewords are located in main memory according to the following boundary conventions:

1. A byte is located in bit positions 0 through 7,8 through 15,16 through 23 , and 24 through 31 of a word.
2. A halfword is located in bit positions 0 through 15 and 16 through 31 of a word.
3. A doubleword is located such that bitpositions 0 through 31 are contained within an even-numbered word, and bit positions 32 through 63 are contained within the next consecutive word (which is odd-numbered).

Figure 3 illustrates these boundaries.

| Doubleword |  |  |  |  |  |  |  | Doubleword |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Word (even address) |  |  |  | Word (odd address) |  |  |  | Word (even address) |  |  |  | Word (odd address) |  |  |  |
| Halfword 0 |  | Halfword 1 |  | Hal fword 0 |  | Halfword 1 |  | Halfword 0 |  | Halfword 1 |  | Halfword 0 |  | Halfword 1 |  |
| Byte 0 | Byte 1 | Byte 2 | Byte 3 | Byte 0 | Byte 1 | Byte 2 | Byte 3 | Byte 0 | Byte 1 | Byte 2 | Byte 3 | Byte 0 | Byte 1 | Byte 2 | Byte 3 |

Figure 3. Information Boundaries

## INSTRUCTION REGISTER

The instruction register contains the instruction the basic processor is currently executing. The format and fields of the two general types of instructions (memory reference and immediate operand) are described below. Specific formats for each instruction are given in Chapter 3.

## MEMORY REFERENCE INSTRUCTIONS

Instructions that make reference to an operand in main memory may have the following format:

| * | Operation Code | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

Bits Description
0 Indirect addressing. One level of indirect addressing is performed only if this bit position contains a one.

1-7 Operation code. This 7-bit field contains the code that designates the operation to be performed. See the inside front and back covers for complete listings of operation codes.

8-11 $\quad \mathrm{R}$ field. For most instructions this 4-bit field designates one of the first 16 general registers of the current register block as an operand source, result destination, or both.

12-14 $X$ field. This 3-bit field designates one of general registers 1-7 of the current register block as an

## Bits Description

12-14 index register. If $X$ contains zero, indexing will
(cont.) not be performed; hence register 0 cannot be used as an index register. (See "Address Modification Example: Indexing (Real and Virtual Addressing)", later in this chapter for a description of the indexing process.)

15-31 Reference address. This 17-bit field normally contains the reference address of the instruction operand. The reference address is translated into an effective virtual address in accordance with the addressing type (real, real extended, or virtual) and the address modification required (direct/ indirect or indexing). (See "Memory Reference Addresses" later in this chapter.)

## IMMEDIATE OPERAND INSTRUCTIONS

Immediate operand type instructions are particularly efficient because the required operand is contained within the instruction word. Hence, memory reference, indirect addressing, and indexing are not required.

| 0 | Operation Code | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

Bits Description
0 Bit position 0 must be coded with a zero. If it contains a one, the instruction is interpreted as being nonexistent. (See "Trap System", later in this chapter.)

Operation code. This 7-bit field contains the code that designates the operation to be performed. When the basic processor encounters any immediate operand operation, it interprets bits 12-31 of the instruction word as an operand. These are the immediate operand operation codes:

| Operation Code | Instruction Name | Mnemonic |
| :---: | :---: | :---: |
| X'02' | Load Conditions and Floating Control Immediate | LCFI |
| X'20' | Add Immediate | AI |
| X'21' | Compare Immediate | CI |
| X'22' | Load Immediate | LI |
| X'23' | Multiply Immediate | MI |

8-11 $\quad \mathrm{R}$ field. This 4-bit field designates one of the first 16 general registers in the current general register block. The register may contain another operand and/or be designated as the register in which the results of the operation are to be stored or accumulated.

12-31 Operand. This 20-bit field contains the immediate operand. Negative numbers are represented in two's complement form. For arithmetic operations bit 12 (the sign bit) is extended by duplication to the left through bit position 0 to form a 32-bit operand.

The byte-string instructions (described in Chapter 3) are similar to immediate-operand instructions in that they cannot be modified by indexing. Nevertheless, the operand field of byte-string instructions contains either a byte address displacement or a byte address that is a virtual address subject to modification by the memory map. If a byte-string instruction has a one in bit position zero, the basic processor treats it as a nonexistent instruction (see "Trap System ", later in this chapter).

## MAIN MEMORY

The memory system comprises memory units, memory interfaces (MIs), and memory buses. Figure 4 illustrates the relationships among these components.

The primary technology for main memory is magnetic core. The maximum physical storage is 256 K words. Memory units can be interleaved on a two-way interleave basis. Each memory unit is provided with a set of starting address switches on the Configuration Control Panel (see Chapter 6) together with a two-position switch that selects one of two
possible clock and power sources. Memory units may contain two, four, or six ports, which have a fixed priority order for the resolution of contention problems.

The following sections describe the organization and operation of the memory system. Also described are the various modes and types of addressing, including indexing.

## MEMORY UNIT

Main memory is divided physically and logically into one to eight module assemblies called memory units. Because the memory unit is a logical component that contains all the functions available in the entire memory, the minimum memory is one memory unit. The minimum storage capacity per memory unit is 16 K words; the maximum is 32 K words. A memory location stores a word of 36 bits; the first 32 bits are information and the last 4 are byte parity bits (the latter being unavailable to the program). Each memory unit comprises a specific storage capacity, drive and sense circuits, a set of operational registers (address, data, and status), a set of write lock control registers for 32 K words of memory, and a timing and control unit.

## CORE MEMORY MODULES

Core memory modules (CMMs) provide a storage facility of standard modules (see Figure 4).

## MEMORY DRIVER

The memory driver in each memory unit performs all memory operations except storage (provided for by the CMMs) and the few operations performed by the ports. The major functions of the memory driver are:

1. Store address word.
2. Store data-in and data-out words during memory cycles.
3. Store write locks in special memory (other than CMMs).
4. Perform parity generation and checking on address and memory bus data words, and on core memory module words.
5. Generate and store status words.
6. Control and time all transfers of address words, data words, status words, write locks, and write key among the ports, CMM, and the storage registers.
7. Contro! and time a!! data, parity; and contro! signa!s issued to the memory bus.
8. Accept one of two or more simultaneous memory requests on the basis of port positional priority and other priority status information such as "high priority" and "memory reserved".


Figure 4. Main Memory

## PORTS AND MEMORY BUSES

A memory unit may contain two, four, or six ports, which have a fixed priority order for the resolution of access contention. Each port allows the memory unit to communicate via a memory bus with a different external system (i.e., a processor cluster), which communicates with the memory bus via the Memory Interface (MI) (see Figure 4). Ports are numbered from 1 (top priority) to 6 (lowest priority). The selection logic is biased to select port 1 (the fast port) whenever the memory is quiescent. Thus performance is improved for the Memory Interface (MI) connected to that port, and hence to the processors connected to that MI.

A memory reserve function insures proper execution of instructions that require guaranteed re-access to a memory location before a second processor can access it.

Each port is equipped with an inhibit function that can be activated from the Configuration Control Panel (see Chapter 6).

Other major functions performed by the ports are:

## 1. Address recognition.

## 2. Address interleaving.

The memory system is built up by interconnection of identically numbered ports of all memory units. Each interconnecting cable is called a memory bus, which is dedicated to a single processor cluster (see Figure 4).

## PORT PRIORITY

The multiport structure allows two simultaneous requests for memory to be processed immediately if the requests are received on different ports for different memory units, and neither memory unit is busy. If a requested memory unit is busy or receives simultaneous requests, the memory port logic selects the highest priority request first.

Normally, all ports in a memory unit operate on the fixed priority basis (the fast port has the highest priority and the highest-numbered normal port the lowest). Thus, if a single memory unit simultaneously receives requests on port 2 and port 4, port 2 has first access to the memory unit.

Each port also has associated with it a high-priority line which, upon receiving a high-priority request, raises the port's priority above that of all other ports except for any higher priority port, which also has a high-priority request on its line.

## MEMORY INTERLEAVING

Memory interleaving is a hardware feature that distributes sequential addresses into two independently operating memory units. Interleaving increases the probability that a processor (i.e., basic processor, RMP, or MIOP) can gain
access to a given memory location without encountering interference from another processor that is making sequential requests.

Two memory units of the same size can be two-way interleaved. Both memory units transform an incoming address, as follows:

| Size of Each <br> Memory Unit | Address Bits <br> Interchanged |
| :---: | :---: |
| 32 K |  |
| 16 K |  |

As a result of the address transformation, even incoming addresses are assigned to one memory unit and odd incoming addresses to the other. Note that the incoming address (untransformed) is stored in the status register of the accessed unit in each cycle and is available as are other types of dynamic status information. (Interleaved memory units have two status registers, one in each of the units.)

## MEMORY UNIT STARTING ADDRESS

Each memory unit is individually identified by starting address switches located on the Configuration Control Panel (see Chapter 6). These switches define the range of addresses the memory unit responds to when servicing memory requests. All addresses, including the starting address, for a given memory unit are the same for all ports in that unit; that is, the address of a given word remains the same regardless of the port used to access the word. The starting address of a memory unit must be on a boundary equal to a multiple of the size of the memory unit when two memory units (of the same size) are interleaved. The starting address of one memory unit must be a multiple of the size of the two memory units together; the second memory unit must have a starting address higher than that of its companion by its own size. Another way to say this is that the starting address for the combined units must be on a boundary equal to a multiple of the total size of the interleaved assembly.

## MAINTAINABILITY AND PERFORMANCE

Memory maintainability is enhanced by the following features:

1. Error detection. Each memory unit senses and remembers parity errors in the CMM data as well as parity errors in the address word or the memory bus data, port selection errors, CMM selection error, and undefined operations. This status information is available to diagnostic programs to facilitate error localization in space and time of occurrence. The memory unit senses and reports, but does not remember (for diagnostic purposes) a write lock violation.
2. Modularity. For ease of replacement, the logic and storage circuitry is packaged on modules that are removable from backpanels without requiring cable disconnections.
3. Diagnostic logic. Each memory driver module carries logic used exclusively for localizing faulty elements in that module. The benefit derived from this diagnostic logic depends on such external factors as the accessibility to a module tester.

Memory system performance depends on these factors:

1. Access time of memory unit.
2. Cycle time of memory unit.
3. Type of cycle requested.
4. Number of memory units.
5. Interleaving.
6. Type of port (fast or normal) selected.
7. Self or mutual interference between memory requests.

All these factors characterize not only memory performance but also system performance.

Port access time and cycle time are essential memory speed characteristics pertaining to CMM operations.

1. Port access time. This is the time interval measured between the clock pulse that transmits an address word from the Memory Interface (MI) to an idle memory unit and the clock pulse that translates a memory word from the same memory unit to the MI.
2. Cycle time. Cycle time depends on the operation being performed and on the sequence of operation. Cycle time determines the maximum rate at which a memory unit can accept requests.

## VIRTUAL AND REAL MEMORY

Virtual memory is the address space available to an individual program. The maximum size of virtual memory is 128 K words, broken into as many as 256 pages of 512 words each distributed throughout the available pages of real memory.

Real memory corresponds to the physical memory, and its size is equal to the total number of words contained within all memory units in the system. The size of real memory ranges from a minimum of 16 K words to a maximum of 256 K words.

Note: Real memory address space is 1 million words.

## MEMORY REFERENCE ADDRESS

Memory locations 0 through 15 are not normally accessible to the programmer because their memory addresses are reserved as register designators for "register-to-register" operations. Nevertheless an instruction treats any of the
first 16 registers of the current register block as if it were a location in main memory. Furthermore, the register block can hold an instruction (or a series of as many as 16 instructions) for execution just as though the instruction (or instructions) were in main memory.

The following terms are used in the various types of addressing described in subsequent sections. See also Figure 5, which illustrates the control and data flow during address generation.

1. Instruction Address. This is the address of the next instruction to be executed. For real, real-extended, and virtual addressing the 17 -bit instruction address is contained within bits 15-31 of the program status words (PSWs).
2. Reference Address. This is the 17-bit or 20-bit address associated with any instruction (except that in a trap or interrupt location that has a 0 in bit position 10). For real, real extended, direct, and virtual addressing, the reference address is the address contained within bits 15-31 of the instruction itself.

The reference address may be modified by using indirect addressing, indexing, and memory mapping. A reference address becomes an effective virtual address after the indirect addressing and/or postindexing (if required) is performed.
3. 20-Bit Trap or Interrupt Reference Address. If bit position 10 of any instruction in a trap or interrupt location contains a 0 , bits 12-31 of that instruction are used as a 20-bit reference address. This 20 -bit reference address can be modified only by using indirect addressing. This 20-bit reference address cannot be indexed or mapped. (See "Interrupt and Trap Entry Addressing", later in this chapter.)
4. Direct Reference Address. If neither indirect addressing nor indexing is called for by the instruction (i.e., if bit 0 and the $X$ field contain zero), the reference address of the instruction (as defined above) becomes the effective virtual address. Direct addressing may be used during real, virtual, or real extended addressing modes, including trap and interrupt operations. Direct addressing during virtual addressing does not preclude memory mapping.
5. Indirect Reference Address. The 7-bit operation code field of the instruction word format provides for as many as 128 instruction operation codes, nearly all of which can use indirect addressing (except immediate-operand and byte-string instructions). If the instruction calls. for indirect addressing (bit position 0 contains a 1 ), the reference address (as defined above) is used to access a word location that contains the direct reference address in bit positions 15-31, or bit positions 12-31 for certain real extended addressing operations. The indirect addressing operation is limited to one level, regardless of the contents of the word location pointed to by the reference address field of the instruction. Indirect addressing occurs before indexing; that is, the 17-bit


Figure 5. Addressing Logic
reference address field of the instruction is used to obtain a word, and the 17 or 20 low-order bits of the word thus obtained effectively replace the initial reference address field; then indexing is carried out according to the operation code of the instruction. See Figures 7 and 9, later in this chapter.
6. Index Reference Address. If indexing is called for in the instruction (a value other than zero in bits 12-14 of the instruction), the direct or indirect reference address is modified by addition of the displacement value in the general register (index) called for by the instruction (after scaling the displacement according to the instruction type). This final reference address value (after indirect addressing, indexing, or both) is defined as the effective virtual address of the instruction. Indexing after indirect addressing is called postindexing. See also Figures 7 and 9, later in this chapter.
7. Displacements. Displacements are the 16- to 22-bit values used in index registers and by byte-string instructions to generate effective addresses of the appropriate size (byte, halfword, word, or doubleword).
8. Register Address. If any instruction provides a virtual address that is a memory reference (i.e., a direct, indirect, or indexed reference address) in the range 0 through 15, the basic processor does not attempt to read from or write into main memory locations 0 through 15. Instead, the four low-order bits of the reference address are used as a general register address and the general register corresponding to this address is used as the operand location or result destination. Thus, the instruction can use any of the first 16 registers in the current register block as the source of an operand, the location of a direct address, or the destination of a result. Such usage is called a "register-to-register" operation.
9. Actual Address. This is the address value actually used by the basic processor to access main memory via the memory address register (see Figure 5). If the effective virtual address is in the range 0 through 15 ( $\mathrm{X}^{\prime} 0$ through $\left.X^{\prime} F^{\prime}\right)$, one of the first 16 general registers in the current register block is being addressed. If the basic processor is operating in the virtual addressing mode, all addresses greater than 15 ( $X^{\prime} F^{\prime}$ ) are transformed (usually into addresses in a different memory page) by the memory map into actual addresses. Contrarily, if the basic processor is operating in either real or real extended mode, no transformation via the memory map takes place.
10. Effective Address. The effective address is defined as the final virtual address computed for an instruction. Note, however, that some instructions do not use the effective address as a location reference; instead, the effective address is used to control the operation of the instruction (as in a shift instruction), to designate the address of an input/output device (as in an input/ output instruction), or to designate a specific element of the system (as in a READ DIRECT or WRITE DIRECT instruction).
11. Effective Location. An effective location is defined as the actual location (in main memory or in the current register block) that is to receive the result of a memoryreferencing instruction, and is referenced by means of an effective address. Because an effective address may be either an actual address or a virtual address, when applicable, this definition of an effective location assumes the transformation of a virtual address into an actual address.
12. Effective Operand. An effective operand is defined as the contents of an actual location (in main memory or in the current register block) that is to be used as an operand by a memory-referencing instruction, and is referred to by means of an effective address. This also presupposes the transformation of a virtual address into an actual address.

## TYPES OF ADDRESSING

Except for the special type of addressing performed by some interrupt and trap instructions, all addressing within the computer system is real, real extended, or virtual.

## REAL ADDRESSING

In real addressing, a one-to-one relationship prevails between the effective virtual address of each instruction and the actual address used to access main memory. Real addressing has these characteristics:

1. Each reference address is a 17-bit word address.
2. The reference address may be direct or indirect, with or without postindexing.
3. Displacements associated with indexing are automatically aligned, as required, using the full 32-bit contents of the index register. The final result is truncated to the left of the high-order bit of the original 17-bit reference address, and the effective real address is a 16-bit doubleword address, 17-bit word address, 18-bit halfword address, or a 19-bit byte address.
4. If indirect addressing is invoked, the 17-bit reference address in the instruction word is used to access the indirect address word in memory. The low-order 17 bits of this word then replace the reference address of the instruction word in the calculations described in (3), above.
5. Memory mapping and memory access protection are never invoked.
6. Memory write protection is automatically invoked.
7. Leading zeros are automatically appended to the effective address to generate an actual word address as required by the main memory.
8. Real addressing is allowed in master mode and in slave mode, and is specified when bit positions 9 and 61 of the PSWs both contain zero.

## VIRTUAL ADDRESSING

Virtual addressing uses the memory map to determine the actual address to be associated with a particular reference address of each instruction. Virtual addressing differs from real addressing in that there is normally no exact relationship between the effective virtual address and the actual address. These are the characteristics of virtual addressing:

1. Each reference address is a 17-bit address.
2. The reference address may be direct or indirect, with or without postindexing.
3. Displacements associated with indexing are automatically aligned, as required, using the full 32-bit contents of the index register. The final result is truncated to the left of the high-order bit of the original 17-bit reference address, and the effective virtual address is a 16-bit doubleword address, 17-bit word address, 18-bit halfword address, or a 19-bit byte address.
4. Virtual memory access protection is always invoked. If the access protection code is invalid, the instruction aborts and traps to location X'40'. (See "Trap System", later in this chapter.)
5. Memory mapping translates the 8 most significant bits of the effective virtual address (the page portion) into an 11-bit page address. This page address is concatenated with the 9 least significant bits of the reference address. The resultant 20-bit word address is the actual address used to access memory. This feature permits any one user at any given time to have a virtual memory of as many as 128 K words ( 256 pages) located throughout real (actual) memory comprising as many as 256 K words ( 512 pages). Although virtual memory may be physically fragmented, it is logically contiguous.

Note that Sigma $6 / 7$ programs may run on this computer system without requiring change to the mapping structure. The memory map is loaded with 8-bit page addresses (the 3 high-order bits of the 11-bit real page address are reset to zeros). The most significant 8 bits of the effective virtual address are then translated into the designated 8 -bit page address.
6. The memory write-protection feature is invoked for the actual address in real memory.
7. Virtual addressing may be used in all modes (master, master-protected, and slave) and is specified when bit 9 of the PSWs contains a one.

## ADDRESS MODIFICATION EXAMPLE: INDEXING (REAL AND VIRTUAL ADDRESSING)

Figure 6 shows how the indexing operation takes place during real and virtual addressing operations. The instruction is brought from memory and loaded into a 34-bit instruction register that initially contains zeros in the two low-order bit positions ( 32 and 33 ). The displacement value from the index register is then aligned with the instruction register (as an integer) according to the address type of the instruction; that is, if it is a byte operation, the low-order bit of the displacement is aligned with the least significant bit of the 34 -bit instruction register (bit position 34). The displacement is then shifted one bit to the left of this position for a halfword operation, two bits to the left for a word operation, and three bits to the left for a doubleword operation. An addition process then takes place to develop a 19-bit address, referred to as the effective address of the instruction. High-order bits of the 32-bit displacement are ignored in the development of this effective address (i.e., the 15 high-order bits are ignored for word operations, the 25 high-order bits are ignored for shift operations, and the 16 high-order bits are ignored for doubleword operations). The displacement value, however, can cause the effective address to be less than the initial reference address (within the instruction) if the displacement value contains a sufficient number of high-order $1_{2}$ 's (i.e., if the displacement value is a negative integer in two's complement form).

The effective virtual address of an instruction is always a 19-bit byte address value. This value, however, is automatically adjusted to the information boundary conventions. Thus, for halfword operations the low-order bit of the effective halfword address is zero; for word operations the two low-order bits of the effective word address are zeros; and for doubleword operations the three low-order bits of the effective doubleword address are zeros.

In a byte operation with no indexing, the effective byte is the first byte (byte 0 in bit positions $0-7$ ) of a word location; in a halfword operation with no indexing, the effective halfword is the first halfword (halfword 0 in bit positions 0-15) of a word location. A doubleword operation always involves a word at an even numbered address and the word at the nextsequential (which is odd numbered) word address. Thus, if an odd numbered word location is specified for a doubleword operation, the low-order bit of the effective address field (bit position 31) is automatically forced to zero. This means that in a doubleword operation an odd numbered word (reference) address designates the same doubleword as the next lower even numbered word address.

In the real addressing mode, the 19-bit effective virtual address is concatenated with 3 leading zeros to form a 22-bit actual address. In the virtual addressing mode, the 8 most significant bits of the 19-bit virtual address are mapped (using the memory map) into the 11-bit actual page address, thus forming a 22-bit actual address.


Figure 5. Index Displacement Alignment (Real and Virtual Addressing Modes)

## ADDRESS MODIFICATION EXAMPLE: INDIRECT, INDEXED HALFWORD (VIRTUAL ADDRESSING)

Figure 7 illustrates the address modification and mapping process for an indirectly addressed, indexed, halfword operation. As shown, reference address 1 is the content of the reference address field in the instruction stored in memory. The instruction is brought into the instruction register, and if the value of the reference address field is greater than 15, the memory map converts the 19-bit effective virtual address into a 22 -bit actual address. The 17 low-order bits of the main memory location pointed to by the actual address, labeled reference address 2 , then replaces reference address 1 in the instruction register. The index register designated by the $X$ field of the instruction is subsequently aligned for incrementing at the halfword-address level. The final effective virtual address is formed by the address generator, and if the value of the reference address is greater than 15, the effective virtual address is transformed through the memory map into an actual address. The resultant 22-bit actual (main memory) address, which automatically contains a low-order 0, is then used to access the halfword to be used as the operand for the instruction.

Note that for the real addressing mode, the modifications required for indirect, indexed halfword operation are the same with one exception: reference address 1 and the final effective address are concatenated with three leading zeros (as opposed to being transformed by the memory map).

## REAL-EXTENDED ADDRESSING

Real-extended addressing is similar to real addressing in that a direct relationship exists between the effective virtual address of each instruction and the actual address. The function of real-extended addressing is to facilitate operations in a memory system larger than 128 K words.

Note: Instructions and indirect addresses that involve real-extended address calculations must themselves reside in the first 128 K words of memory (or in the general registers), although they in turn may ultimately access operands in locations beyond the first 128 K words of memory.

Instruction in memory:


Instruction in instruction registers:


The 8 high-order bits of the reference address are replaced with ll-bit page address Z from memory map:


Actual address of memory location that contains the direct address:


17-bit direct address in memory:


Indirect addressing replaces reference address with direct address:


Halfword operation indexing alignment:


Effective virtual address:

The 8 high-order bits of the effective address are replaced with ll-bit page address N from memory map:

Final memory address, which is the actual address of hal fword location containing the effective halfword:


Figure 7. Generation of Actual Addresses Indirect, Virtual Addressing

Real-extended addressing is specified when PSWs bit location 9 contains zero and PSWs bit location 61 contains one. In real-extended addressing, the 17-bit reference address in the instruction word is expanded to a 20-bit reference address by the appendage of 3 bit positions to the left of the reference address (see Figure 8). If indexing or indirect addressing are not specified in the instruction, these 3 bit positions contain zeros. Otherwise, address calculations are performed in this manner: If indexing is specified ( $X$ field in the instruction contains a value other than zero), the contents of the specified index register are properly aligned with respect to the 17-bit reference address according to the general alignment rules. Arithmetic on the aligned quantities then takes place using the full 32 -bit contents of the index register. The final result is truncated 3 bits to the left of the original 17-bit reference address, these 3 bits having been acquired from the index register plus any carry resulting from the addition of the 17-bit reference address with the index register contents.

If the instruction specifies indirect addressing (bit position 0 contains one), the 17-bit reference address is used to access an indirect word in memory. The low-order 20 bits of the indirect word then replace the 17-bit reference address from the instruction. If indexing is also specified, the
appropriate alignment of the 32 -bit contents of the index register is then made and the addition operation performed. The result is truncated to the left of the 20-bit operand obtained from the indirect address word.

In real-extended addressing, 20-bit address calculations actually encompass 22-, 21-, 20-, and 19-bit calculations, respectively, for byte, halfword, word, and doubleword alignments (see Figures 8 and 9).

The stack pointer doubleword for push-down instructions contains a 20-bit word address for the top of stack address field, as shown in the following format:

|  | Top of stack address |
| :---: | :---: |


| S | Space count | T $\begin{gathered}T \\ W\end{gathered}$ | Word count |
| :---: | :---: | :---: | :---: |
| S |  | W |  |

Instruction in memory:


Figure 8. Index Displacement Alignment (Real-Extended Addressing)

Instruction in memory:


Instruction in instruction register:


Indirect reference addresses:

Contents of indirect reference address:


Address used if bit $0=1$ :


Displacement aligned for halfword indexing:

Final effective address:


Table 1. Basic Processor Operating Modes and Addressing Cases

| PSW BIT |  |  | Mode and Addressing Characteristics |
| :---: | :---: | :---: | :---: |
| MS | MM | MA |  |
| 0 | 0 | 0 | Master mode, unmapped, 17-bit calculations, real addressing (128K words, maximum). |
| 1 | 0 | 0 | Slave mode, unmapped, 17-bit calculations, real addressing (128K words, maximum). |
| 0 | 0 | 1 | Master mode, unmapped, 20-bit calculations, real-extended addressing, 17-bit instruction reference address (instructions and indirect words in first 128 K words only), indexed and indirect addresses are 20 bits. |
| 1 | 0 | 1 | Slave mode, unmapped, 20-bit calculations, real-extended addressing, 17-bit instruction reference address (instructions and indirect words in first 128 K words only), indexed and indirect addresses are 20 bits. |
| 0 | 1 | 0 | Master mode, mapped, 17-bit calculations, virtual addressing ( 128 K words, maximum), map to 1 M words, real (Sigma $6 / 7$ map to first 128 K words by virtue of loading map with three high-order zeros for all pages). |
| 1 | $!$ | - | Slave mode, mapped, 17 -bit calculations, virtual addressing ( 128 K words, maximum), map to 1 M words, real (Sigma $6 / 7$ map to first 128 K words by virtue of loading map with three high-order zeros for all pages). |
| 0 | 1 | 1 | Master-protected mode, mapped, 17-bit calculations, virtual addressing ( 128 K words, maximum), map to $1 M$ words, real (access protection invoked). |

## INTERRUPT AND TRAP ENTRY ADDRESSING

An instruction residing in an interrupt location (see "Centralized Interrupt System" later in this chapter) and executed as the direct result of an interrupt sequence is defined as an interrupt instruction. Both conditions must be true simultaneously. Thus an instruction in an interrupt location is not an interrupt instruction if it is executed as the result of a program branch to the interrupt location under normal program control. The only valid interrupt instructions are XPSD, PSS, MTW, MTH, and MTB.

Similarly, a trap instruction (see "Trap System", later in this chapter) is defined as an instruction in a trap location executed as a direct result of a trap condition. The only valid trap instructions are XPSD and PSS.

XPSD Address Calculations. Address calculations associated with XPSD instructions deviate from the standard forms. Two basic formats are used in XPSD instructions, depending on whether subjective or objective addressing is being used.

Bit 10 of the XPSD instruction is the addressing type (AT) designator. In the circumstances described below, it designates whether the reference address in the XPSD instruction is to be considered unconditionally as a 20-bit real address or whether the current mode of addressing calculations is to be applied to it.

Format 1 :

| * | Operation code | $\begin{array}{\|l\|l\|l} \hline \mathrm{L} & \mathrm{~A} & \mathrm{~A} \\ \mathrm{P} & \mathrm{I} & \mathrm{~T} \\ \hline \end{array}$ | Reference address (20 bits) |
| :---: | :---: | :---: | :---: |

Format 2:

| * | Operation code |  | X | Reference address (17 bits |
| :---: | :---: | :---: | :---: | :---: |

Format 1 is used in these circumstances:

1. Bit position 10 (AT) of the XPSD contains zero. In this format the reference address is a 20-bit actual address (i.e., no mapping). Note that this is true regardless of whether the instruction is in a trap, interrupt, or normal location and independent of the mode (mapped, unmapped, real-extended) of the current PSWs. If indirect addressing is specified, the indirect word contains a 20-bit address with exactly the same properties.
2. Bit position 10 (AT) of the XPSD contains one, the instruction is in a trap or interrupt location, the instruction is being executed as the result of a trap or interrupt, and the current mode of the PSWs is notreal-extended. In this format, the reference address is a 20-bit actual
address if PSWs bit 9 is zero (no map), or a 20-bit virtual address if PSWs bit 9 is one (map). If indirect addressing is specified, the indirect word contains a 20-bit address with exactly the same properties.

Format 2 is used in all other circumstances, namely:

1. Bit position $10(\mathrm{AT})$ contains a one, and
a. The XPSD is not being executed as the result of a trap or interrupt, or
b. It is in a trap or interrupt location, is being executed as the result of a trap or interrupt, but the current mode of the PSWs is real-extended.

In these cases, all of the normal rules of address calculations hold, i.e., indirect, index, and map.

PSS Address Calculations. PUSH STATUS (PSS) address calculations are similar to but simpler than those for the XPSD instruction. Two basic formats are used:

Format 1:


Format 2:


Format 1 is used when the PSS is executed in an interrupt or trap location as a result of an interrupt or trap sequence. No indexing is possible because its designator field is preempted by the reference address. Indirect addressing is permitted with the same constraint against indexing; the indirect address word contains a 20-bit real address with precisely the same properties as the reference address. In the case of a trap instruction, the 20-bit reference address can be either a real address or a virtual address according to the value in PSWs bit position 9.

Format 2 is used when the PSS instruction is executed in the course of normal program execution. Addressing in this case is completely standard, including indexing and indirect addressing.

During the execution of the PSS instruction the interrupt stack pointer is accessed from real memory locations 0 and 1 . The interrupt stack address therein is a real 20-bit address with no indexing or mapping used.

MTW, MTH, and MTB Address Calculations. Two basic formats are used in modify and test instructions:

Format 1:

| $*$Operation <br> code | $R$ | Reference address (20 bits) |
| :---: | :---: | :---: |

Format 2:

| Operation code | R | X | Reference address (17 bits) |
| :---: | :---: | :---: | :---: |

Format 1 is used when the modify and test instruction is executed in an interrupt or trap location as a result of an interrupt or trap sequence. When used as an interrupt instruction, the MTW, MTH, or MTB instruction uses the 20-bit reference address as a real address (except counter 4), without indexing or mapping. Interrupt Counter 4 uses the map if mapping is called for. Access protect and write lock violations are not active.

When used as a trap instruction, the MTW, MTH, or MTB instruction uses the 20-bit address without indexing; if the PSWs specify mapping, however, the map is used, with bits 12-14 of the address ignored.

Format 2 is used when the modify and test instruction is executed in the normal course of program execution. Addressing in this case is completely standard, including indexing and indirect addressing.

RD and WD Address Calculations. The final output address for a READ DIRECT (RD) or a WRITE DIRECT (WD) instruction is the low-order 16 bits of the effective virtual address. If indexing is specified in the instruction, the low-order 17 bits of the instruction are modified by the indexing operation, and the resultant 17-bit address is truncated to 16 bits and transmitted as the final address. No mapping takes place.

If indirect addressing is specified in the instruction, the indirect address word is generated in the standard manner according to the mode bits in the PSWs. Thus mapping will occur if it is specified in the PSWs. If indexing is also specified, the indirect address in the indirect word is modified by the indexing operation and the resultant address is truncated to 16 bits and transmitted as the final address.

## MEMORY ADDRESS CONTROL

Two methods of program control of main memory are the memory map and the memory locks. The memory map provides for dynamic relocation of programs and for access protection through inhibitions imposed on slave or masterprotected mode programs. Access protection violations in either mode are trapped to location $X^{\prime} 40^{\prime}$. The memory locks provide memory write protection for all modes of programs throughout all real memory. The memory locks apply to input/output operations as well as basic processor operations. This protection is effective at the page level, is for real addresses, and is operative in addition to the protection provided virtual addresses at the page level. Memory protection violations in any mode are trapped to location $X^{\prime} 40^{\prime}$.

Note: A WD instruction used to write into main memory locations 0 through 31 is not subject to write protection.

## MEMORY MAPPING AND ACCESS PROTECTION

The memory map is physically an array of 256 11-bit registers. The array resides in the Memory Interface (MI) of the processor cluster containing the basic processor. Each register has an 8-bit address (that corresponds to an 8-bit virtual page address) and contains an 11-bit actual page address for a specific 512-word page of memory. Mapping always transforms a 17 -bit virtual address into a 20 -bit real address.

The actual page addresses are assigned to pages of virtual addresses in this manner:

| Actual page $X$ (11 bits) | Actual page K (11 bits) | Actual page N (11 bits) |
| :---: | :---: | :---: |
| Virtual addresses X'10'-X'1FF' <br> (virtual page 0) | Virtual addresses $X^{\prime} 200^{\prime}-X^{\prime} 3 F F^{\prime}$ <br> (virtual page 1) | Virtual addresses <br> X'IFEOO'-X'IFFFF <br> (virtual page 255) |

Just prior to a memory reference, the most significant 8 bits of a 17-bit virtual address are used as the address of an element of the map array. The 11 bits contained within that element are then used in conjunction with the loworder 9 bits of the 17 -bit virtual address to produce a 20-bit actual address.

Sigma 6/7 compatible mapping is accomplished by loading the map with 8-bit address elements (instead of 11-bit address elements) via the MOVE TO MEMORY CONTROL (MMC) instruction. The 8 bits are stored in the low-order 8 bits of each map element and the 3 high-order bit positions are reset to zero. Thus the map will always relocate to the same address in the first 128 K words of real memory and be compatible for Sigma 6/7 programs.

Associated with the memory map feature is another array of 256 2-bit registers, also located in the Memory Interface. Each register contains a 2-bit access control code for a specific 512-word page of virtual addresses. The access-protection code indicates the allowed use or availability of the corresponding page of virtual memory. Access protection applies to all pages of the virtual address space of the active program, and is only active when the memory map is invoked.


The memory page address and access-control codes can be changed only by use of the privileged MMC instruction (see Chapter 3, "Control Instructions).

Access protection is in effect whenever the memory map is in effect (PSWs $9=1$ ) and the basic processor is operating in the slave mode (PSWs $8=1$ ) or in the master-protected mode (PSWs $61=1$ ). Access protection is not in effect when the basic processor is operating in the master mode.

When the memory map is in effect, all memory references used by the program (including instruction addresses) whether direct, indirect, or indexed, are referred to as virtual addresses. Virtual addresses in the range 0 through 15 are not used to address main memory; instead the 4 low-order bits of the virtual address comprise a general register address. If, however, an instruction produces a virtual address greater than 15 , the 8 high-order bits of the virtual address are used to obtain the appropriate 11-bit actual memory page address and 2-bit access control codes. For example, if the 8 high-order bits of the virtual address are 0000 0000, the first page address code and the first access control code are used; if the 8 high-order bits of the virtual address are 00000001 , the second page address code and the second access control code are used, etc., through the 256 th page address and access control codes. Thus each 512-word page of virtual addresses is associated with its own memory page address and access control codes.

When the memory map is accessed during a slave mode or master-protected mode program, the basic processor determines whether there are any inhibitions to using the virtual address.

These are the four types of access protection codes:
00 A slave mode or master-protected mode program can write into, read from, or access instructions from this page of virtual address.

01 A slave mode or master-protected mode program cannot write into this page of virtual addresses; it can, however, read from or access instructions from this page of virtual addresses.

10 A slave mode or master-protected mode program cannot write into or access instructions from this page of virtual addresses; it can, however, read from this page of virtual addresses.

11 A slave mode or master-protected mode program is denied any access to this page of virtual addresses.

If the instruction being executed by the slave or masterprotected program fails the foregoing test, the instruction is aborted and the basic processor traps to location $X^{\prime} 40^{\prime}$, the "non-allowed operation" trap (see "Trap System", later in this chapter).

Contrarily, if the instruction being executed by the slave mode or master-protected mode program passes this test (or if the basic processor is operating in the master mode), the

11-bit page address in the accessed element of the memory map array replaces the 8 high-order bits of the virtual address to produce the actual address of the main memory location to be used by the instruction (20-bit word address that is automatically adjusted as required for doubleword, halfword, or byte operation). See Figure 7.

Note: If the 11-bit page address in the accessed element of the memory map is all zeros, and an actual address is produced that corresponds to a word address in the range 0 through 15, when the 11 -bit page address is combined with the 9 low-order bits of the virtual address, the corresponding general register in the current register block is not accessed. In this one particular instance a word address in the range 0 through 15 corresponds to an actual main memory location rather than a general register.

## REAL MEMORY WRITE LOCKS

Additional memory protection, independent of the access protection, is provided by a write lock and key technique. A 4-bit write protect lock (WL) is provided for each 512word page of actual memory. Thus, for the maximum $1 \mathrm{M}-$ word real memory there would be 2048 4-bit write locks. Write locks are assigned to pages of actual addresses as follows:


The write protect locks can be changed only by executing the privileged instruction MOVE TO MEMORY CONTROL (see Chapter 3, "Control Instructions").

The write key (a 4-bit field in the PSWs for any operating program, or in the command doubleword for I/O operations) works in conjunction with the write lock to determine whether any program (slave, master-protected, or master mode) can write inio a specific page of main memory locations. The write key and lock control access for writing according to these rules:

1. A lock value of 0000 means that the corresponding memory page is unlocked; write access to that page is permitted independent of the key value.
2. A key value of 0000 is a "skeleton" key that will open any lock; thus write access to any memory page is permitted independent of its lock value.
3. A lock value other than 0000 for a memory page permits write access to that page only if the key value (other than 0000 ) is identical to the lock value.

Thus a program can write into a given memory page if the lock value is 0000 , if the key value is 0000 , or if the key value matches the lock value.

Note: The memory access protection feature operates during virtual addressing modes and on virtual addresses, whereas the memory write protection feature always operates on actual memory addresses. Thus, if the memory access protection feature is invoked (that is, if the basic processor is operating in the slave mode or the master-protected mode and is using the memory map), the access protection codes are examined when the virtual address is converted into an actual address. Then the lock and key are examined to determine whether the program (master, master-protected, or slave mode) is allowed to alter the contents of the main memory location corresponding to the final actual address. If an instruction attempts to write into a write-protected memory page, the basic processor aborts the instruction, and traps to location X'40', the "nonallowed operation" trap (see "Trap System", later in this chapter). If an I/O procedure attempts to write into a writeprotected memory page, the write lock violation bit in the IOP status byte is set, and can be tested by the AIO, TIO, and TDV instructions.

## PROGRAM STATUS WORDS

The critical control conditions of the basic processor are defined within 64 bits of information collectively referred to as the program status words (PSWs). The current PSWs may be consideredas one 64-bit internal basic processor register, although they actually exist as a collection of separate registers and flip-flops (see Figure 2 appearing earlier in this chapter). When stored in memory, the PSWs have the following format:


They may be optionally followed by an additional two words with the following format:



## Designation Function

CC Condition code. This generalized 4-bit code indicates the nature of the results of an instruction. The significance of the condition code bits depends upon the particular instruction just executed. After an instruction is executed, the BRANCH ON CONDITIONS SET (BCS) and BRANCH ON CONDITIONS RESET (BCR) instructions can be used singly or in combination to test for a particular condition code setting. (These instructions are described in Chapter 3, "Execute/Branch Instructions").

In some operations only a portion of the condition code is involved; thus, the term CCl refers to the first bit of the condition code, CC2 to the second bit, and CC3 and CC4, respectively, to the third and fourth bits. Any program can change the current value of the condition code by executing either the LOAD CONDITIONS AND FLOATING CONTROL IMMEDIATE (LCFI) or the LOAD CONDITIONS AND FLOATING CONTROL (LCF) instruction. Any program can store the current condition code by executing the STORE CONDITIONS AND FLOATING CONTROL (STCF) instruction. These instructions are described in Chapter $\overline{3}$, "Load/Store Instructions".

FR Floating round mode control (see FN below).

FS Floating significance mode control (see FN below).

FZ Floating zero mode control (see FN below).

FN Floating normalize mode control. The four floating-point mode control bits (FR, FS, FZ, and FN ) control the operation of the basic processor with respect to invoking the roundoff mode of floating-point calculations, checking floating-point significance, generating zero results, and normalizing the results of floating-point additions and subtractions, respectively. (The floating-point mode controls are described in Chapter 3, "Floating-Point Instructions".) Any program can change the state of the current floatingpoint mode controls by executing either the LCFI or the LCF instruction. Any program can store the current state of the current floatingpoint mode controls by executing the STCF instruction.

Designation Function
MS Master/slave mode control. The basic processor is in the master mode when this bit and the mode altered bit (bit 61) both contain zero; it is in the slave mode when this bit contains one. (See MS for a description of master-protected mode.) A master mode or master-protected mode program can change this mode control bit by executing the LOAD PROGRAM STATUS WORDS (LPSD), EXCHANGE PROGRAM STATUS WORDS (XPSD), PUSH STATUS (PSS), or PULL STATUS (PLS) instruction. These privileged instructions are described in Chapter 3, "Control Instructions".

MM Memory map control. The memory map is in effect when this bit position contains a one. A master mode or master-protected mode program can change the memory map control by executing an LPSD, XPSD, PSS, or PLS instruction.

DM Decimal mask. The decimal arithmetic trap (see "Trap System", later in this chapter) is permitted to occur when this bit position contains a one. The conditions that cause a decimal arithmetic trap are described in Chapter 3, "Decimal Instructions". The decimal trap mask can be changed by a master mode or master-protected mode program executing the LPSD, XPSD, PSS, or PLS instruction.

Arithmetic mask. The fixed-point arithmetic overflow trap is permitted to occur when this bit contains one. The instructions that can cause fixed-point overflow are described in the section "Trap System", later in this chapter. The arithmetic trap mask can be changed by a master mode or master-protected mode program executing an LPSD, XPSD, PSS, or PLS instruction.

Instruction address. This 17-bit field contains the virtual address of the next instruction to be executed.

WK Write key. This field contains the 4-bit key used in conjunction with a write lock in the memory write protection feature. A master mode or master-protected mode program can change the value of the write key by executing an LPSD, XPSD, PSS, or PLS instruction.

CI Counter interrupt group inhibit (see EI, below).

II
$\frac{\text { Input/output interrupt group inhibit (see EI, }}{\text { below). }}$

## Designation Function

EI External interrupt group inhibit. The three interrupt group inhibit bits (CI, II, and EI) determine whether certain interrupts are allowed to occur. The function of these group interrupt inhibits are described in "Centralized Interrupt System", later in this chapter. A master mode or master-protected mode program can change the group interrupt inhibits by executing an LPSD, XPSD, PSS, PLS, or WRITE DIRECT (WD) instruction. These privileged instructions are described in Chapter 3, "Control Instructions".

Register pointer. This 2-bit field selects one of the 4 possible blocks of general-purpose registers as the current register block. A master or master-protected mode program can change the register pointer by executing LPSD, XPSD, PSS, PLS, or the LOAD REGISTER POINTER (LRP) instruction. LRP is described in Chapter 3, under "Control Instructions".

RA Register altered bit. When a trap occurs, this bit is set to one when any general register or location in memory has been altered in the execution or partial execution of the instruction that caused the trap.

Mode altered. This bit is used to invoke both the master-protected mode of operation and the real-extended addressing mode). Table ! details the function of the setting of this bit in conjunction with the setting of the MS (bit 8) and MM (bit 9) fields. The bits are set by an LPSD, XPSD, PSS, or PLS instruction.

Memory protection violation address. If the XPSD instruction is being executed in a trap routine as a result of a memory protection violation and the SP bit in the XPSD is a one, the effective virtual address causing the violation is stored in the fourth word. This storage may be invoked so that memory protection violations can be recorded.

## CENTRALIZED INTERRUPTS

The system includes a single, centralized interrupt feature. A!! interrupts are terminated in the System Contro! Processor. The System Control Processor is described earlier and also in Chapters 5 and 6.

When a condition that will result in an interrupt is sensed, a signal is sent to the corresponding interrupt level. If that level is "armed", it advances to the waiting state.

When all the conditions for acknowledging the interrupt have been achieved, the basic processor stops executing the current program and executes the instruction in the corresponding interrupt location. After the basic processor has successfully accessed the interrupt instruction, it advances the interrupt level to the active state. The basic processor may actually execute many program instructions between the time that the interrupt-requesting condition is sensed and the time that the actual interrupt acknowledgment occurs. After the interrupt is completely processed, the basic processor returns to the interrupted program and resumes its execution.

## STATES OF AN INTERRUPT LEVEL

An interrupt level is mechanized by means of three flipflops. Two flip-flops are used to define four mutually exclusive states: disarmed, armed, waiting, and active. The third flip-flop provides the disabled/enabled function and is independent of the defined state. The various states and the conditions of interrupt levels are described in the following paragraphs. Figure 10 conceptually illustrates the operational state changes of a typical interrupt level.

## DISARMED

When an interrupt level is in the disarmed state, no signal is admitted to that interrupt level; that is, the level neither accepts nor remembers an interrupt event, nor is any program interrupt caused by it at any time.

Although an interrupt level can change from any state to the disarmed state, only a special form of the WRITE DIRECT instruction (WD) can cause a disarmed level to change to another state. The WD instruction is described in Chapter 3, "Control Instructions".

## ARMED

When an interrupt level is in the armed state, it can accept and remember an interrupt signal. The receipt of such a signal advances the interrupt level to the waiting state where it remains until it is allowed to advance to the active state. A special form of the WD instruction can cause an armed level to be advanced directly to the active state.

A level can change from any state to the armed state.

## WAITING

For an interrupt level to be in the waiting state, that level must have been previously armed and received an interrupt signal. The signal may have been generated externally, internally, or have resulted from a WD operation. Any signals received by an interrupt level already in the waiting state are ignored.


Figure 10. Operational States of an Interrupt Level

When an interrupt level is in the waiting state, the following conditions must all existsimultaneously before the level advances to the active state:

1. The level must be enabled (i.e., its enable/disable flip-flop must be set to one).
2. The group inhibit (CI, II, or EI, if applicable) must be zero.
3. Nohigher-priority interrupt level is in the active state, or is in the waiting state, enabled, and not inhibited.
4. The basic processor must be at an interruptible point in the execution of a program.

Note that one or more interrupt levels of higher priority can also be in the waiting state if they are disabled, inhibited, or both disabled and inhibited.

Generally, if the enable/disable flip-flop is off (level is disabled), the interrupt level can undergo all state changes except that of moving from the waiting to the active state (see exception case, below). Furthermore, if the interrupt level is disabled, it is completely removed from the chain that determines the priority of access to the basic processor. Thus a disabled interrupt level in the waiting state does not prevent an enabled, waiting interrupt level of lower priority from moving to the active state.

Note this exception to the foregoing description: Although generally no interrupt level can move from the waiting state to the active state unless it is enabled, a special form of the WD instruction can move a waiting level to the active state whether or not the level is enabled.

## ACTIVE

After the basic processor has successfully accessed the interrupt instruction, then the interrupting level advances to the active state. When all the conditions for acknowledgment have been achieved, the interrupt level causes the
basic processor to execute the contents of the assigned interrupt location as the next instruction. (Interrupt locations are defined in "Physical Organization", later in this chapter.) The instruction address portion of the program status words (PSWs) remains unchanged until the instruction in the interrupt location is executed.

The instruction in the interrupt location must be one of the following: XPSD, PSS, MTB, MTH, or MTW. If the execution of any other instruction in an interrupt location is attempted as the result of an interrupt level advancing to the conditions for acknowledgment, an instruction exception trap occurs.

The use of the privileged instruction XPSD or PSS in an interrupt location permits an interrupt-servicing routine to save the entire current machine environment. If working registers are needed by the routine and additional register blocks are available, the contents of the current register block can be saved automatically with no time loss. This is accomplished by changing the value of the register pointer (using the LOAD REGISTER POINTER instruction), which results in the assignment of a new block of 24 registers to the routine. The instruction LOAD REGISTER POINTER (LRP) is described in Chapter 3, "Control Instructions".

An interrupt level remains in the active state until it is cleared (removed from the active state and returned to the disarmed or armed state) by the execution of the LPSD, PLS, or WD instruction. An interrupt-servicing routine can itself be interrupted (whenever a higher priority interrupt level meets all the conditions for becoming active) and then continued (after the higher priority interrupt is cleared). However, an interrupt-servicing routine cannot be interrupted by an interrupt of the same or lower priority as long as the higher priority interrupt level remains in the active state. Any signals received by an interrupt level in the active state are ignored. Normally, the interrupt-servicing routine clears its interrupt level and transfers program control back to the point of interrupt by means of an LPSD instruction with the same effective address as the XPSD instruction in the interrupt location.

## DIALOGUE BETWEEN THE BASIC PROCESSOR AND THE INTERRUPT SYSTEM DURING AN INTERUPTENTERING SEQUENCE

When an interrupt level is ready to be moved to the active state, a dialogue takes place between the interrupt system and the basic processor. This dialogue takes place over the processor bus and involves the Processor Interface (PI) associated with the processor cluster of which the basic processor is a member. When the processor bus becomes available and the basic processor is at an interruptible point, the interrupt system transmits the interrupt address to the basic processor. It initiates its interrupt actions (i.e., executes the instruction in the interrupt location and services the interrupt at the appropriate time to avoid race conditions, and communicates with the interrupt system with an indication to move the level to the active state. This latter
transmission is delayed until the new inhibit states of the basic processor are known; these states are transmitted to the interrupt system so the latter can record the new basic processor status.

## dIALOGUE DURING AN INTERRUPT-EXITING SEQUENCE

When the basic processor exits an interrupt-servicing routine, it must notify the interrupt system to move the interrupt level associated with that routine from the active state to either the armed or disarmed state. To do this it must gain access to the processor bus and the interrupt system, either of which may be busy at the time access is requested. When communication with the interrupt system is established, the basic processor transmits information for setting the level state to armed or disarmed, and new inhibit states it has assumed as a result of the exit operation.

## PHYSICAL ORGANIZATION

Up to 62 interrupt levels are available, each with a unique location (see Table 2) assigned in the System Control Processor, and with a unique priority. The basic processor can selectively arm, enable, or arm and enable any interrupt level. The basic processor can also "trigger" any interrupt level (supply a signal at the same physical point where the signal from the external source would enter the interrupt level). The triggering of an interrupt permits testing special systems programs before the special systems equipment is available. The basic processor also permits an interruptservicing routine to defer a portion of the processing associated with an interrupt level by processing the urgent portion of an interrupt-servicing routine, triggering a lower priority level (for a routine that handles the less urgent part), then clearing the high-priority interrupt level so that other interrupts can occur before the deferred interrupt response is processed.

## INTERRUPT GROUPS

Interrupt levels are organized in standard group configurations that are connected in a predetermined and fixed priority chain (see Table 2 and Figure 11). The priority of each level within a group is fixed; the first level has the highest priority and the last level has the lowest.

## INTERNAL INTERRUPTS

Standard internal interrupts are provided with the system and include all group D levels (internal override, counter-equals-zero, and $I / O)$.

Table 2. Interrupt Locations

| Group | Address |  | Function | PSWs <br> Inhibit | DIO Address |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dec | Hex |  |  | Group | Register Bit |
| Internal Override (optional) | $\begin{aligned} & 82 \\ & 83 \\ & 84 \\ & 85 \\ & 86 \\ & 87 \end{aligned}$ | 52 53 54 55 56 57 | Counter 1 count pulse Counter 2 count pulse Counter 3 count pulse Counter 4 count pulse Processor fault Memory Fault | none | 0 | $\begin{aligned} & 16 \\ & 17 \\ & 18 \\ & 19 \\ & 20 \\ & 21 \end{aligned}$ |
| External Override | $\begin{aligned} & 112 \\ & 113 \\ & 114 \\ & 115 \\ & 116 \\ & 117 \\ & 118 \\ & 119 \\ & 120 \\ & 121 \\ & 122 \\ & 123 \end{aligned}$ | $\begin{aligned} & 70 \\ & 71 \\ & 72 \\ & 73 \\ & 74 \\ & 75 \\ & 76 \\ & 77 \\ & 78 \\ & 79 \\ & 7 A \\ & 7 B \end{aligned}$ | External group 3 (first 12 levels) | EI | 3 | 16 17 18 19 20 21 22 23 24 25 26 27 |
| Counter-Equals-Zero | $\begin{aligned} & 88 \\ & 89 \\ & 90 \\ & 91 \end{aligned}$ | $\begin{aligned} & 58 \\ & 59 \\ & 5 A \\ & 5 B \end{aligned}$ | Counter 1 zero <br> Counter 2 zero <br> Counter 3 zero <br> Counter 4 zero | Cl | 0 | $\begin{aligned} & 22 \\ & 23 \\ & 24 \\ & 25 \end{aligned}$ |
| I/O | $\begin{aligned} & 92 \\ & 93 \\ & 94 \\ & 95 \end{aligned}$ | $\begin{aligned} & 5 C \\ & 5 \mathrm{D} \\ & 5 \mathrm{E} \\ & 5 \mathrm{~F} \end{aligned}$ | Input/Output Control panel Reserved Reserved | II | 0 | $\begin{aligned} & 26 \\ & 27 \\ & 28 \\ & 29 \end{aligned}$ |
| External Group 2 (optional) | $\begin{gathered} 96 \\ \cdot \\ \dot{1} 07 \end{gathered}$ | $\begin{gathered} 60 \\ \cdot \\ 6 B \end{gathered}$ | External group 2 (first 12 levels) | EI | 2 | 16 $27$ |
| External Group 4 (optional) | $\begin{gathered} 128 \\ \cdot \\ \dot{139} \end{gathered}$ | $\begin{gathered} 80 \\ \cdot \\ \cdot \\ 8 \mathrm{~B} \end{gathered}$ | External group 4 (first 12 levels) | EI | 4 | $16$ $27$ |
| External Group 5 (optional) | $\begin{gathered} 144 \\ \cdot \\ \stackrel{\cdot}{155} \end{gathered}$ | $\begin{gathered} 90 \\ \cdot \\ \cdot \\ \cdot 9 B \end{gathered}$ | External group 5 (first 12 levels) | EI | 5 | $\begin{gathered} 16 \\ \cdot \\ 27 \end{gathered}$ |



Figure 11. Interrupt Priority Chain

Internal Override Group (Locations X'52' through X'57'). The six interrupt levels of this group always have the highest priority in the system. The four count-pulse interrupt levels are triggered by pulses from clock sources. Counter 4 has a constant frequency of 500 Hz . Counters 1, 2, and 3 can be individually set to any of four manually switchable frequencies - the commercial line frequency, $500 \mathrm{~Hz}, 2000 \mathrm{~Hz}$, or a user-supplied external signal - that may be different for each counter. Each of the count pulse interrupt locations must contain one of the modify and test instructions (MTB, MTH, or MTW), an XPSD, or a PSS instruction. When the modificution (of the effective byte, hulfiword, or word) causes a zero result, the appropriate counter-equalszero interrupt level (see "Counter-Equals-Zero Group") is triggered.

Note: Count pulse interrupt level 4 is a subjective time counter with the following special attribute: When the instruction in location $X^{\prime} 55$ ' is executed as the result of an interrupt, it must be an MTB, MTH, or MTW; otherwise, an instruction exception trap ( $X^{\prime} 40^{\prime}$ ) will occur.

The internal override group also contains a processor fault and a memory fault interrupt level. Both locations normally contain an XPSD or a PSS instruction. The processor fault interrupt level is triggered by a signal when certain fault conditions are detected. A POLR instruction must be used to reset the fault. The memory fault interrupt level is
triggered by a signal that the memory generates when it detects certain fault conditions. An LMS instruction must be used to reset the fault. (See "Trap System" later in this chapter for further information on processor and memory faults.)

Counter-Equals-Zero Group (Locations X'58' through X'5B'). Each interrupt level in the counter-equals-zero group is associated with a corresponding count-pulse interrupt level in the internal override group. When the execution of a modify und test instiuction in the count=pulse interiupt location causes a zero result in the effective byte, halfword, or word location, the corresponding counter-equals-zero interrupt level is triggered. The counter-equals-zero interrupt locations normally contain an XPSD or a PSS instruction and they can be inhibited or permitted as a group. If bit 37 (CI) of the current PSW contains a zero, the counter-equalszero interrupt levels are allowed to interrupt the program being executed. If the CI bit contains a one, the counter-equals-zero interrupt levels are inhibited frombeing allowed to interrupt the program. These interrupt levels wait until the CI bit is reset to zero and then interrupt the program according to priority.

Input/Output Group (Locations $X^{\prime} 5 C^{\prime}$ through $X^{\prime} 5 F^{\prime}$ ). This interrupt group comprises the input/output (I/O) interrupt level, the control panel interrupt level, and two levels reserved for future use. The I/O interrupt level accepts interrupt signals from the $I / C$ system. The $I / O$ interrupt location
is assumed to contain an XPSD or a PSS instruction that transfers program control to a routine for servicing all I/O interrupts. The I/O routine should contain an ACKNOWLEDGE I/O INTERRUPT (AIO) instruction that identifies the source and reason for the interrupt. (The AIO instruction is discussed in Chapter 3 "Input/Output Instructions".)

The control panel interrupt level is activated from the operator's console. This location normally contains an XPSD or a PSS instruction. The operator can thus trigger this interrupt level to initiate a specific routine.

The interrupt levels in the I/O group can be inhibited or permitted by means of bit position 38 (II) of the PSWs. If II is reset to zero, interrupt signals affecting the I/O group interrupt levels are allowed to interrupt the program being executed. If the II bit is set to one, interrupt signals in this group are inhibited from interrupting the program.

## EXTERNAL INTERRUPTS

A system can contain 4 optional groups of external interrupt levels. The external override group, group 3, contains the first 12 external interrupt levels. External groups 2, 4 , and 5 each contain 12 external interrupt levels. (See Table 2 and Figure 11.) External levels may be triggered by external sources or via WD instructions, while internal levels may be triggered by internal sources or via WD instructions.

All external interrupt levels normally contain XPSD or PSS instructions and can be inhibited or permitted by means of the setting of bit position 39 ( EI ) of the program status words. If EI contains a zero, external interrupts are allowed to interrupt a program; if EI contains a one, all external interrupts are inhibited from interrupting the program.

## NUMBER OF INTERRUPT GROUPS

The 14 internal interrupt levels are standard in every system and all external levels are optional. The addition of the external groups ( 12 levels per group) raises the number of interrupt levels to a maximum of 62 .

## CONTROL OF THE INTERRUPT SYSTEM

The system has two points of interrupt control. One point of interrupt control is achieved by means of the interrupt inhibit bits (CI, II, and EI) in the program status words (PSWs). The basic processor is inhibited from interrupting a program if the interrupt inhibit bit for a corresponding class of interrupt levels is set to one, that is, no interrupt level in the inhibited group can advance from the waiting state to the active state, and the entire group is disabled (removed from the interrupt recognition priority chain). Consequently, a waiting, enabled, interrupt level in an inhibited group does not prevent a lower priority, waiting, enabled interrupt
level in an uninhibited group from interrupting the program. However, if an interrupt group is inhibited while a level in that group is in the active state, no lower priority interrupt level can advance to the active state.

Note also this special case: When the processor detected fault (PDF) flag is set to 1 (see "Processor Detected Faults", later in this chapter), the processor fault, memory fault, and count pulse interrupts are automatically inhibited.

The second point of interrupt control is at the individual interrupt level. The basic processor can interact with any interrupt level by means of special modes of the RD and WD instructions (described in Chapter 3, "Control Instructions"). For this purpose, the interrupt levels are organized into the following DIO address groups (see last two columns in Table 2):

1. The 14 levels of internal interrupts (internal override group, counter-equals-zero group, and I/O group) are designated as group code 0 in bits 28-31 of the effective address of the RD or WD instruction.
2. The 12 levels of each group of external interrupts are designated as group codes $2,3,4$, and 5 . That is, external group 2 is designated group code 2, external group 3 is designated group code 3, etc.
3. There is no group code 1.

The addressing of an individual interrupt level within its DIO group of 12 or 14 is accomplished by an assigned selection bit within the low-order 16-bit positions of the R register designated in the RD or WD instruction (see last column in Table 2).

The WD instruction can individually arm, disarm, enable, disable, or trigger (move to the active state) any interrupt level. The RD instruction can determine which interrupt levels within a selected DIO group are in the armed or waiting state, waiting or active state, or are enabled.

## TIME OF INTERRUPT OCCURRENCES

The basic processor permits an interrupt to occur during the following time intervals (related to the execution cycle of an instruction) provided the SCP basic processor (BP) status indicators are either in the RUN or WAIT condition:

1. Between instructions an interrupt is permitted between the completion of any instruction and the initiation of the next instruction.
2. Between instruction initiations an interrupt is also permitted to occur during the execution of the following multiple-operand instructions:

MOVE BYTE STRING (MBS)

COMPARE BYTE STRING (CBS)
TRANSLATE BYTE STRING (TBS)

TRANSLATE AND TEST BYTE STRING (TTBS)
EDIT BYTE STRING (EBS)
DECIMAL MULTIPLY (DM)
DECIMAL DIVIDE (DD)

## MOVE TO MEMORY CONTROL (MMC)

The control and immediate results of these instructions reside in registers and memory; thus, the instruction can be interrupted between the completion of one iteration (operand execution cycle) and that time (during the next iteration) when a memory location or register is modified. If an interrupt occurs during this time, the current iteration is aborted and the instruction address portion of the program status words (PSWs) remains pointing to the interrupted instruction. After the interrupt-servicing routine is completed, the instruction continues from the point at which it was interrupted and does not begin anew.

## SINGLE-INSTRUCTION INTERRUPTS

A single-instruction interrupt occurs in this situation: an interrupt level is activated, the current program is interrupted, the single instruction in the interrupt location is executed, the interrupt level is automatically cleared and armed, and the interrupted program continues without being disturbed or delayed (except for the time required to execute the single instruction).

If any of the following instructions is executed in any interrupt location, then the corresponding interrupt is automatically a single-instruction interrupt:

MODIFY AND TEST BYTE (MTB)
MODIFY AND TEST HALFWORD (MTH)
MODIFY AND TEST WORD (MTW)

A modify and test instruction modifies the effective byte, halfword, or word (as described in Chapter 3, "Fixed-Point Arithmetic Instructions") but the current condition code remains unchanged (even if overflow occurs). The effective address of a modify and test instruction in an interrupt location (except counter 4) is always treated as an actual address, regardless of whether the memory map is currently being used. Counter 4 uses the mapped location if mapping is currentily invoked (as specified in the PSWs). The execution of a modify and test instruction in an interrupt location, including mapped and unmapped counter 4, is independent of the virtual memory access-protection code and the real memory write lock; thus, a memory protection violation trap cannot occur as the result of overflow caused by executing MTH or MTW in an interrupt location.

The execution of a modify and test instruction in an interrupt location automatically clears and arms the corresponding interrupt level, allowing the interrupted program to continue.

When a modify and test instruction is executed in a countpulse interrupt location, all of the above conditions apply as well as the following: If the resultant value in the effective location is zero, the corresponding counter-equalszero interrupt is triggered.

## TRAP SYSTEM

A trap is similar to an interrupt in that when a trap condition occurs, program execution automatically branches to a predesignated location. A trap differs from an interrupt in that a trap location must contain an XPSD or PSS instruction. The time of trap occurrence can vary: The instruction in the trap location can be executed immediately (i.e., the current instruction in the program being executed is aborted), or when the current instruction has been partially executed (i.e., in the case of a long byte-string operation), or upon completion of the current instruction. The trap instruction is not held in abeyance by higher priority traps, whereas interrupts possibly may not be processed before an entire sequence of instructions is executed.

## TRAP ENTRY SEQUENCE

A trap entry sequence begins when the basic processor detects the trap condition and ends when the new program status words (PSWs) have successfully replaced the old PSWs. Detection of any condition (function) listed in Table 3, which summarizes the trap system, results in a trap to a unique location in memory. When a trap condition occurs, the basic processor sets the trap state. The operation the basic processor is currently performing may or may not be carried to completion, depending on the type of trap and the operation being performed. In any event, the program instruction is terminated with a trap sequence (branch to the appropriate trap location). During this sequence the program counter is not advanced; instead, the XPSD instruction in the trap location is executed. If any interrupt level is ready to move to the active state at the same time an XPSD trap instruction is in process, the interrupt acknowledgment will not occur until the XPSD trap instruction is completed. Should a trap location not contain an XPSD or PSS instruction, a second trap sequence is immediately invoked (see "Instruction Exception Trap" later in this chapter).

## TRAP ADDRESSING

Trap addressing is described under "Interrupt and Trap Entry Addressing".

Table 3. Summary of Trap Locations

| Locations |  | Function | PSWs <br> Mask Bit | Time of Occurrence | Trap Condition Code |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Dec. | Hex. |  |  |  |  |
| 64 | 40 | Nonallowed operation <br> 1. Nonexistent instruction <br> 2. Nonexistent memory address <br> 3. Privileged instruction in slave mode <br> 4. Memory protection violation <br> 5. Write lock violation | None <br> None <br> None <br> None <br> None | At instruction decode. <br> Prior to memory access. <br> At instruction decode. <br> Prior to memory access. <br> Prior to memory access. | Set TCCl ${ }^{\dagger}$ <br> Set TCC2 <br> Set TCC3 <br> Set TCC4 <br> Set TCC3, TCC4 |
| 65 | 41 | Reserved |  |  |  |
| 66 | 42 | Push-down stack limit reached | TW, TS (in stack pointer) | At the time of stack limit detection. (The aborted pushdown instruction does not change memory, registers, or the condition code.) | None |
| 67 | 43 | Fixed-point arithmetic overflow | AM | For all instructions except DW and DH, trap occurs after completion of instruction. For DW and DH, instruction is aborted with memory, register, $C C 1, C C 3$, and CC4 unchanged. | None |
| 68 | 44 | Floating-point arithmetic fault <br> 1. Characteristic overflow <br> 2. Divide by zero <br> 3. Significance check | None <br> None $F S, F Z, F N$ | At detection. <br> (The floating-point instruction is aborted without changing any registers. The condition code is set to indicate the reason for the trap.) | None <br> None <br> None |
| 69 | 45 | Decimal arithmetic fault | DM | At detection. (The aborted decimal instruction does not change memory, registers, CC3, or CC4.) | None |
| 70 | 46 | Warchdog timer runout | None | At runout. (The PDF ${ }^{\dagger \dagger}$ flag will be set.) | Set TCC2 if basic processor using processor bus; <br> set TCC3 if basic processor using memory bus; and <br> set TCC4 if basic processor using DIO bus. |
| 71 | 47 | Programmed trap | None | Interruptible point reached upon completion of WD. | None |
| ${ }^{\dagger}$ See "Trap Condition Code", later in this chapter. <br> ${ }^{\text {tt }}$ See "Processor Detected Faults", later in this chapter. |  |  |  |  |  |

Table 3. Summary of Trap Locations (cont.)

| Locations |  | Function | PSWs Mask Bit | Time of Occurrence | Trap Condition Code |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Dec. | Hex. |  |  |  |  |
| 72 | 48 | CALLI | None | At instruction decode. | Equal to $R$ field of CALL instruction. |
| 73 | 49 | CALL2 | None | At instruction decode. | Equal to $R$ field of CALL instruction. |
| 74 | 4A | CALL3 | None | At instruction decode. | Equal to $R$ field of CALL instruction. |
| 75 | 4B | CALL4 | None | At instruction decode. | Equal to $R$ field of CALL instruction. |
| 76 | 4C | Hardware error trap | None | At time of basic processor detection (the PDF ${ }^{\dagger}$ flag will be set). | $\mathrm{TCC1}, 2,3=0$ <br> TCC4 $=0$ if parity error on general register or internal control register. <br> TCC4 = 1 if other hardware errors. |
| 77 | 4D | Instruction exception trap | None | (The PDF ${ }^{\dagger}$ flag will be set.) | Set TCC3 if MMC configuration illegal; set $T C C=X^{\prime} C^{\prime}$ if trap or interrupt sequence with illegal instruction; set $T C C=X^{\prime} F^{\prime}$ if trap or interrupt sequence and processor detected fault; <br> set TCC4 if invalid register designation (odd register on AD, SD, FAL, FSL, FML, FDL, T̄BS, TTBS, EBS, and register 0 on EBS). |
| 78 | 4E | Reserved |  |  |  |
| 79 | 4F | Reserved |  |  |  |
| 80 | 50 | Power on |  | Interruptible point. |  |
| 81 | 51 | Power off |  | Interruptible point. |  |

${ }^{\dagger}$ See "Processor Detected Faults", later in this chapter.

## TRAP MASKS

The programmer may mask the four trap conditions described below in the program status words (PSWs) or the stack pointer doubleword, as appropriate; other traps cannot be masked.

1. The push-down stack limit trap is masked within the stack pointer doubleword for each individual stack.
2. The fixed-point overflow trap is masked in bit position 11 (AM) of the PSWs. If this bit position contains a zero, the trap is allowed to occur; if bit 11 contains a zero, the trap is not allowed to occur. AM can be masked by operator intervention, or by execution of the XPSD, PSS, PLS, or LPSD privileged instructions.
3. The floating-point significance check trap is masked by a combination of the floating significance (FS), floating zero (FZ), and floating normalize (FN) mode control bits in the PSWs (see "Floating-Point Arithmetic Faul t Trap", later in this chapter). FS, FZ, and FN can be set or cleared by the execution of any of the following instructions:

## LOAD CONDITIONS AND FLOATING CONTROL (LCF)

LOAD CONDITIONS AND FLOATING CONTROL IMMEDIATE (LCFI)

EXCHANGE PROGRAM STATUS WORDS (XPSD) LOAD PROGRAM STATUS WORDS (LPSD)

PUSH STATUS (PSS)
PULL STATUS (PLS)
4. The decimal arithmetic fault trap is masked by bit position 10 (DM) of the PSWs. If DM contains a one, the trap is allowed; if DM contains a zero, the trap is not allowed. DM can be masked by execution of the XPSD, PSS, PLS, or LPSD privileged instruction.

## TRAP CONDITION CODE

For the push-down stack limit trap, fixed-point overflow trap, floating-point fault trap, and decimal fault trap, the normal condition code register (CC1-CC4) is loaded with more detailed information about the trap condition just before the trap occurs. These condition codes are saved as part of the old program status words when the XPSD or PSS instruction is executed in response to the trap.

For the nonallowed operation trap, watchdog timer runout trap, hardware error trap, instruction exception trap, and CALL trap, a special register (trap condition codes TCC1TCC4) is loaded just before the trap occurs. When the XPSD or PSS instruction is executed in response to the trap, this register is added to the new program address if bit 9 (MM) contains a one; TCC1-TCC4 are also logically ORed
with the condition code bits (CC1-CC4) of the new PSWs when loading $\mathrm{CCl}-\mathrm{CC} 4$. See also "Instruction Exception Trap" later in this chapter for more information on the trap condition code.

## NONALLOWED OPERATION TRAP

The attempt to perform a nonallowed operation always causes the basic processor to abort the instruction being executed when the nonallowed operation is detected and to immediately execute the XPSD or PSS instruction in trap location $X^{\prime} 40^{\prime}$. A nonallowed operation cannot be masked.

## NONEXISTENT INSTRUCTION

Any instruction that is not standard is defined as nonexistent. This includes immediate operand instructions that specify indirect addressing (a one in bit 0 of the instruction). If a nonexistent instruction is detected, the basic processor traps to location $X^{\prime} 40^{\prime}$ when the nonexistent instruction is decoded. No general registers or memory locations are changed; the PSWs point to the instruction trapped. With respect to the condition code and instruction address fields of the program status words, the operation of the XPSD or PSS in location $X^{\prime} 40^{\prime}$ is as follows:

1. Store the current PSWs. The condition codes stored are those that existed at the end of the last instruction prior to the nonexistent instruction.
2. Store the 16 general registers of the current register block if instruction in trap location is a PSS.
3. Load the new PSWs.
4. Modify the new PSWs.
a. Set CCl to one. The other condition code bits remain unchanged from the values loaded from memory.
b. If bit position 9 (AI) of the XPSD or PSS instruction contains a one, the program counter is incremented by eight. If AI contains a zero, the program counter remains unchanged from the value loaded from memory.

## NONEXISTENT MEMORY ADDRESS

Any attempt to access a nonexistent memory address causes a trap to location $X^{\prime} 40^{\prime}$ at the time of the request for memory service. A nonexistent memory address condition is detected when an actual address is presented to the memory
system. If the basic processor is in the map mode, the program address will already have been modified by the memory map to generate an actual (but nonexistent) address. (See Table 5 for possible changes to registers and memory locations later in this chapter.) The operation of the XPSD or PSS in location $X^{\prime} 40^{\prime}$ is as follows:

1. Store the current PSWs.
2. Store general registers if PSS.
3. Load the new PSWs.
4. Modify the new PSWs.
a. Set CC2 to one. The other condition code bits remain unchanged from the values loaded from memory.
b. If bit position 9 (AI) of the XPSD or PSS instruction contains a one, the program counter is incremented by four. If AI contains a zero, the program counter remains unchanged from the value loaded from memory.

## PRIVILEGED INSTRUCTION IN SLAVE MODE

An attempt to execute a privileged instruction while the basic processor is in the slave mode causes a trap to location $X^{\prime} 40^{\prime}$ before the privileged operation is performed. No general registers or memory locations are changed, and the PSWs point to the instruction trapped. The operation of the XPSD or PSS in trap location $X^{\prime} 40^{\prime}$ is as follows:

1. Store the current PSWs.

## 2. Store general registers if PSS.

3. Load rhe new PS'V's.
a. Set CC3 to one. The other condition code bits remain unchanged from the values loaded from memory.
b. If bit position 9 (AI) of the XPSD or PSS contains a one, the program counter is implemented by two. If AI contains a zero, the program counter remains unchanged from the values loaded from memory.

## MEMORY PROTECTION VIOLATION

A memory protection violation occurs because of a memory map access control bit violation (by a program executed in slave mode or master-protected mode using the memory map). When memory protection violation occurs, the basic processor aborts execution of the current instruction
without changing protected memory and traps to location $X^{\prime} 40^{\prime}$. Refer to Table 5 for possible changes to registers and memory locations. (The virtual page address that caused the violation is in the fourth PSW word.) The operation of the XPSD or PSS in trap location $X^{\prime} 40^{\prime}$ is as follows:

1. Store the current PSWs.
2. Store general registers if PSS.
3. Load the new PSWs.
4. Modify the new PSWs.
a. Set CC4 to one. The other condition code bits remain unchanged from the values loaded from memory.
b. If bit position 9 (AI) of the XPSD or PSS contains a one, the program counter is incremented by one. If AI contains a zero, the program counter remains unchanged from the value loaded from memory.

## WRITE LOCK VIOLATION

A memory write lock violation occurs when an instruction (program in master, master-protected, or slave mode) tries to alter the contents of a write-protected memory page. If a write lock violation occurs, the basic processor aborts execution of the current instruction without changing protected memory and traps to location $X^{\prime} 40$ '. (Refer to Table 5 for possible changes to registers and memory locations.) (The virtual page address that caused the violation is the fourth PSW word.) The operation of the XPSD or PSS in trap location $X^{\prime} 40^{\prime}$ is as follows:

1. Store the current PSWs.
2. Store general registers if PSS.
3. Load the new PSWs.
4. Modify the new PSWs.
a. Set CC3 and CC4 to ones. The other condition code bits remain unchanged from the values loaded from memory.
b. If bit position 9 (AI) of the XPSD or PSS contains a one, the program counter is incremented by three. If AI contains a zero, the program counter remains unchanged from the value loaded from memory.

## PUSH-DOWN STACK LIMIT TRAP

Push-down stack overflow or underflow can occur during execution of any of the following instructions:

| Instruction | Mnemonic | Operation Code |
| :---: | :---: | :---: |
| Push Word | PSW | X'09' |
| Pull Word | PLW | X'08' |
| Push Multiple | PSM | $X^{\prime} 0 B^{\prime}$ |
| Pull Multiple | PLM | $X^{\prime} 0 A^{\prime}$ |
| Modify Stack Pointer | MSP | X'13' |

During the execution of any stack-manipulating instruction (see Chapter 3, "Push-down Instructions"), the stack is either pushed (words added to stack) or pulled (words removed from stack). In either case, the space ( S ) and words (W) fields of the stack pointer doubleword are tested prior to moving any words. If execution of the instruction would cause the space ( $S$ ) field to become less than 0 or greater than $2^{15}-1$, the instruction is aborted with memory and registers unchanged. If TS (bit 32) of the stack pointer doubleword is set to 0 , the basic processor traps to location $X^{\prime} 42^{\prime}$. If TS is set to 1 , the trap is inhibited and the basic processor processes the next instruction. If execution of the instruction would cause the words (W) field to become less than 0 or greater than 215-1, the instruction is aborted with memory and registers unchanged. If TW (bit 48) of the stack pointer doubleword is set to 0 , the basic processor traps to location X'42'. If the TW is set to 1 , the trap is inhibited and the basic processor processes the next instruction. If trapping is inhibited, CC1 or CC3 is set to 1 to indicate the reason for aborting the instruction. The stack pointer doubleword, memory, and registers are modified only if the instruction is successfully executed.

If a push-down instruction traps, the execution of XPSD or PSS in trap location $X^{\prime} 42^{\prime}$ is as follows:

1. Store the current PSWs. The condition codes that are stored are those that existed prior to execution of the aborted push-down instruction.
2. Store general registers if PSS.
3. Load the new PSWs. The condition code and instruction address portions of the PSWs remain at the value loaded from memory.

## FIXED-POINT OVERFLOW TRAP

Overflow can occur for any of the following instructions:

| Instruction |  | Operation <br> Code |  |
| :--- | :--- | :--- | :--- |
|  |  |  | Mnemonic |
| Load Absolute Word | LAW |  | $X^{\prime}$ |
| Load Absolute Doubleword | LAD | $X^{\prime} 1 B^{\prime}$ |  |


| Instruction | Mnemonic | Operation Code |
| :---: | :---: | :---: |
| Load Complement Word | LCW | $X^{\prime} 3 A^{\prime}$ |
| Load Complement Doubleword | LCD | $X^{\prime} 1 A^{\prime}$ |
| Add Halfword | AH | $\chi^{\prime} 50{ }^{\prime}$ |
| Subtract Halfword | SH | $\mathrm{X}^{\prime} 58^{\prime}$ |
| Divide Halfword | DH | X'56' |
| Add Immediate | AI | $\mathrm{X}^{\prime} 20^{\prime}$ |
| Add Word | AW | $\mathrm{X}^{\prime} 30^{\prime}$ |
| Subtract Word | SW | X'38' |
| Divide Word | DW | $\mathrm{X}^{\prime} 36^{\prime}$ |
| Add Doubleword | AD | $X^{\prime} 10^{\prime}$ |
| Subtract Doubleword | SD | X'18' |
| Modify and Test Halfword | MTH | $\mathrm{X}^{153}$ |
| Modify and Test Word | MTW | $\mathrm{X}^{\prime} 33^{\prime}$ |
| Add Word to Memory | AWM | X'66' |

Except for the instructions DIVIDE HALFWORD (DH) and DIVIDE WORD (DW), instruction execution is allowed to proceed to completion. CC2 is set to 1 and CC3 and CC4 represent the actual result ( $0,-$, or + ) after overflow.

If the fixed-point arithmetic trap mask (bit 11 of PSWs) is a 1 , the basic processor traps to location $X^{\prime} 43^{\prime}$ instead of executing the next instruction in sequence.

For DW and DH, the instruction execution is aborted without changing any register, and CC2 is set to $1 ; C C 1, C C 3$, and CC4 remain unchanged from their values at the end of the instruction immediately prior to the DW or DH. If the fixed-point arithmetic trap mask is a 1 , the basic processor traps to location $X^{\prime} 43$ ' instead of executing the next instruction in sequence.
The execution of XPSD or PSS in trap location $X^{\prime} 43^{\prime}$ is as follows:

1. Store the current PSWs. (Store general registers if PSS.) If the instruction trapped was any instruction other than DW or DH, the stored condition code is interpreted as follows:

| $\frac{C C 1}{-t \dagger}$ | $\frac{C C 2}{1}$ | $\frac{C C 3}{}$ | $\frac{C C 4}{0}$ |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| - | 1 | 0 | 1 | Meaning <br> Result after overflow is zero. <br> Result after overflow is <br> negative. |  |
| - | 1 | 1 | 0 | Result after overflow is <br> positive. |  |

[^2]| $\mathrm{CCl}^{\dagger}$ | CC2 | CC3 | CC4 | Meaning <br> 0 |
| :---: | :---: | :---: | :---: | :---: |
| No carry out of bit 0 of the <br> adder (add and subtract in- <br> structions only). |  |  |  |  |

If the instruction trapped was a DW or DH, the stored condition code is interpreted as follows:

## 

2. Load the new PSWs. The condition code and instruction address portions of the PSWs remain at the value loaded from memory.

## FLOATING-POINT ARITHMETIC FAULT TRAP

Floating-point fault detection is performed after the operation called for by the instruction code is performed, but before any results are loaded into the general registers. Thus, a floating-point operation that causes an arithmetic fault is not carried to completion in that the original contents of the general registers are unchanged.

Instead, the basic processor traps to location $X^{\prime} 44$ ' with the current condition code indicating the reason for the trap. A characteristic overflow or an attempt to divide by zero always results in a trap condition. A significance check or a characteristic underflow results in a trap condition only if the floating-point mode controls (FS, FZ, and FN) in the current program status words are set to the appropriate state.

If a floating-point instruction traps, the execution of XPSD or PSS in trap location $X^{\prime} 44$ ' is as follows:

1. Store the current PSWs. (Store general registers if PSS.) If division is attempted with a zero divisor or if characteristic overflow occurs, the stored condition code is interpreted as follows:

| $C C 1$ | $C C 2$ | $C C 3$ | $C C 4$ | Meaning |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 0 | Zero divisor. |
| 0 | 1 | 0 | 1 | Characteristic overflow, <br> negative result. |
| 0 | 1 | 1 | 0 | Characteristic overflow, <br> positive result. |

[^3]If none of the above conditions occurred but characteristic underflow occurs with floating zero mode bit (FZ) $=1$, the stored condition code is interpreted as follows:

$$
\begin{array}{ccccc}
\text { CC1 } & \frac{C C 2}{} & \frac{\text { CC3 }}{} & \frac{C C 4}{} & \frac{1}{\text { Meaning }} \\
1 & 1 & 0 & 1 & \begin{array}{l}
\text { Characteristic underflow, } \\
\text { negative result. }
\end{array} \\
1 & 1 & 1 & 0 & \begin{array}{l}
\text { Characteristic underflow, } \\
\text { positive result. }
\end{array}
\end{array}
$$

If none of the above conditions occurred but an addition or subtraction results in either a zero result (with FS $=1$ and $\mathrm{FN}=0$ ), or a postnormalization shift of more than two hexadecimal places (with FS $=1$ and $\mathrm{FN}=0$ ), the stored condition code is interpreted as follows:

| CC1 | CC2 | CC3 | CC4 | Leaning |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | Mero result of addition or |
| 1 | 0 | 0 | 1 | Mubtraction. |
| 1 | 0 | 1 | 0 | More than two postnormaliz- <br> ing shifts, negative result. |
| More than two postnormaliz- <br> ing shifts, positive result. |  |  |  |  |

2. Load the new PSWs. The condition code and instruction address portions of the PSWs remain at the values loaded from memory.

## DECIMAL ARITHMETIC FAULT TRAP

When either of two decimal fault conditions occurs (see Chapter 3, "Decimal Instructions"), the normal sequencing of instruction is halted, CCl and CC 2 are set according to the reason for the fault condition, and CC3, CC4, memory, and the decimal accumulator remain unchanged by the instruction. If the decimal arithmetic trap mask (bit position 10 of PSW1) is a 0 , the instruction execution sequence continues with the next instruction in sequence at the time of fault detection; however, if the decimal arithmetic trap mask contains a 1, the basic processor traps to location X'45' at the time of fault detection. The following are the fault conditions for decimal instructions:

| Instruction Name |  | Mnemonic |  |
| :--- | :--- | :--- | :--- |
|  | Fault |  |  |
| Decimal Load | DL |  | Illegal digit |
| Decimal Store | DS |  | Illegal digit |
| Decimal Add | DA |  | Overflow, illegal <br> digit |
| Decimal Subtract | DS |  | Overflow, illegal <br> digit |
| Decimal Multiply | DM |  | Illegal digit |


| Instruction Name | Mnemonic | Fault |
| :---: | :---: | :---: |
| Decimal Divide | DD | Overflow, illegal digit |
| Decimal Compare | DC | Illegal digit |
| Decimal Shift Arithmetic | DSA | Illegal digit |
| Pack Decimal Digits | PACK | Illegal digit |
| Unpack Decimal Digits | UNPK | Illegal digit |
| Edit Byte String | EBS | Illegal digit |

The execution of XPSD or PSS in trap location $X^{\prime} 45^{\prime}$ is as follows:

1. Store the current PSWs. (Store general registers if PSS.) The stored condition code is interpreted as follows:

| CCl | CC2 | CC3 | CC4 | Meaning |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | - | - | All digits legal and overflow. |
| 1 | 0 | - | - | Illegal digit detected. |

2. Load the new PSWs. The condition code and instruction address portions of the PSWs remain at the values loaded from memory.

## WATCHDOG TIMER RUNOUT TRAP

The watchdog timer monitors and controls the maximum amount of basic processor time each instruction can take. The timer is normally in operation at all times and is initialized at the beginning of each instruction. If the instruction is not completed by the time the watchdog timer has completed its count, the instruction is aborted, TCCl is set to 0 , and a trap occurs immediately to location $X^{\prime} 46^{\prime}$. Additional information as to probable cause of delay is provided: TCC2 is set if the basic processor was using the processor bus, TCC 3 is set if the basic processor was using the memory bus, TCC4 is set if the basic processor was using the DIO bus. The register altered flag of the PSWs is also set if any register or main memory location has been changed when the trap occurred.

A watchdog timer runout is considered a basic processor fault and the PDF is set. (See "Processor Detected Fault Flag", later in this chapter.)

## PROGRAMMED TRAP

The programmed trap occurs at instruction interruptible point. It is set by a WRITE DIRECT (WD). See Chapter 3. The basic processor traps to location $X^{\prime} 47^{\prime}$.

## CALL INSTRUCTION TRAP

The four CALL instructions (CAL1, CAL2, CAL3, and CAL4) cause the basic processor to trap to location $X^{\prime} 48^{\prime}$ (for CAL1), $X^{\prime} 49^{\prime}$ (for CAL2), $X^{1} 4 A^{\prime}$ (for CAL3), or $X^{\prime} 4 B^{\prime}$ (for CAL4). Execution of the XPSD or PSS instruction in the trap location is as follows:

1. Store the current PSWs. The stored condition code bits are those that existed prior to the CALL instruction.
2. Store the general registers in PSS.
3. Load the new PSWs.
4. Modify the new PSWs.
a. The R Field of the CALL instruction is logically ORed with the condition code register as loaded from memory.
b. If bit 9 (AI) of XPSD or PSS contains a 1, the $R$ field of the CALL instruction is added to the program counter. If AI contains a 0 , the program counter remains unchanged from the value loaded from memory.

Note: Return from a CALL trap will be to the trapping instruction +1 .

## HARDWARE ERROR TRAP

A hardware error trap occurs when either a parity or a sequence check fault error is detected by a memory unit, basic processor, or any processor communicating with the basic processor, resulting in a basic processor trap to location $X^{\prime} 4 C^{\prime}$. The Trap Condition Code bits (TCCs) are set to $X^{\prime} 0001$ ' for all hardware fault conditions except general register and control register parity errors, where the TCCs are set to $X^{\prime} 0000^{\prime}$.

To determine which of the possible detectable errors is responsible for the hardware error trap, the fault status registers of the various processors in the system must be polled with either the POLP or POLR instruction; the memory's status register must be read with the LMS instruction. The fault status register bit settings for processors and interfaces are given in Appendix C, Table C-1. The fault status register bit settings for the memory unit are given in Appendix C, Table C-2.

If the basic processor defects or receives a report of a hardware error, it attempts automatic retry of the current instruction. If retry is unsuccessful, the basic processor traps to location $X^{\prime} 4 C^{\prime}$. If retry is successful, the basic processor resumes execution of the next instruction in the program, the Processor Fault Interrupt (PFI) and the "successful instruction retry" bit (bit position 11) in the Basic Processor Fault Status Register are set to 1. There is automatic instruction
retry only for hardware errors that would otherwise result in a basic processor trap to location $X^{\prime} 4 C^{\prime}$. Automatic instruction retry is inhibited if:

1. The current instruction is being executed as a trap or interrupt instruction;
2. The Register Altered bit (bit position 60) of the current PSWs is set to 1 at the time of detection of the hardware error; or
3. The Retry Inhibit bit (bit position 0 ) in the basic processor control register is set to 1.

## INSTRUCTION EXCEPTION TRAP

The instruction exception trap occurs whenever the basic processor detects a set of operations that are called for in an instruction but cannot be executed because of either a hardware restriction or a previous event.

The different conditions that cause the instruction exception trap are:

1. A processor-detected fault that occurs during the execution of an interrupt or trap entry sequence. An interrupt or trap entry sequence is defined as the sequence of events that consists of: (a) initiating an interrupt or trap; (b) accessing the instruction in the interrupt or trap location; and (c) executing that instruction, including the exchange of the program status words, if required. Note that instructions executed as a result of the interrupt or trap location are not considered part of the entry sequence.
2. An illegal instruction is found in the trap (not XPSD or PSS) or interrupt (not XPSD, PSS, MTB, MTH, MTW) location when executing a trap or interrupt sequence.
3. Bit positions 12-14 of the MOVE TO MEMORY CONTROL (MMC) instruction are interpreted as an illegal configuration. This is, any configuration other than 100, 010, 101, 001, or 011.
4. The set of operations, primarily doubleword and bytestring instructions, that yield an unpredictable result when an incorrect register is specified; this type of fault is called "invalid register designation" and includes the following instructions". ${ }^{\dagger}$
$\underline{\text { Register } 0 \text { Specified }}$
Edit Byte String (EBS)

Odd Register Specified
Add Doubleword (AD)
Subtract Doubleword (SD)
${ }^{\dagger}$ "Invalid register designation" faults do not set the PDF flag.

Floating Add Long (FAL)
Floating Subtract Long (FSL)
Floating Multiply Long (FML)
Floating Divide Long (FDL)
Translate Byte String (TBS)
Translate and Test Byte String (TTBS)
Edit Byte String (EBS)
Move to Memory Control (MMC)

## TRAP CONDITION CODE

The Trap Condition Code (TCC) differentiates between the different fault types. Table 4 shows the settings of the TCC for the various faults that may be detected during a trap or interrupt entry sequence.

Table 4. TCC Setting for Instruction Exception Trap $X^{\prime} 4 D^{\prime}$
$\left.\begin{array}{|l|lll|}\hline \text { Fault Type } & \text { TCC } \\ \hline \begin{array}{l}\text { Trap or interrupt sequence and } \\ \text { processor-detected fault. }\end{array} & \begin{array}{llll}1 & 1 & 1 & 1 \\ \hline \begin{array}{l}\text { Trap or interrupt sequence with } \\ \text { invalid instruction. }\end{array} & 1 & 1 & 0\end{array} 0 \\ \hline \text { MMC configuration invalid. } & 0 & 0 & 1\end{array}\right]$

## POWER ON TRAP

Power On causes the basic processor to reset and then trap to location $X^{\prime} 50$ '. This will occur only following restoration of power after an interruption of less than 500 milliseconds.

## POWER OFF TRAP

Power Off occurs at interruptible point. As source power is going off, the basic processor traps to location $X^{\prime} 51^{\prime}$ and allows sufficient time for storage of information before the system becomes inoperable.

## PROCESSOR DETECTED FAULT FIAG

The Processor Detected Fault (PDF) flag aids in solving a multiple error problem. Most traps occur because of a dynamic programming consideration (i.e., overflow, attempted division by zero, incorrect use of an instruction or address, etc.) and recovery is easily handled by another software
subroutine. However, with certain classes of errors, if a second error occurs while the basic processor is attempting to recover from the first error, unpredictable results occur. Included in this class of traps are the hardware error trap, some cases of the instruction exception trap, and the watchdog timer runout trap. Upon the first occurrence of this type of trap, the PDF flag is set.

When the PDF flag is set, the processor fault interrupt, the memory fault interrupt, and count pulse interrupts are automatically inhibited. The other interrupts may or may not be inhibited as specified by the program status words, which are loaded when the trap entry XPSD or PSS is executed. The PDF flag is normally reset by the last instruction of a trap routine, which is an LPSD or PLS instruction having bit 10 equal to 0 and bit 11 equal to 1 .

If a second PDF is detected before the PDF flag is reset, the basic processor "hangs up" until the PDF flag is reset either by the operator entering the command for RESET BASIC PROCESSOR or RESET SYSTEM on the operator's console.

This reset will cause the following actions:

1. The processor fault status register is cleared.
2. The PDF flag is cleared and the processor fault interrupt generated flag is cleared.
3. The PSWs are cleared to zero except that the instruction address is set to location $X^{\prime} 26$ '.
4. The basic processor will begin execution with the instruction contained in location $X^{\prime} 26^{\prime}$.

## REGISTER ALTERED BIT

Complete recoverability after a trap may require that no main memory location, no fast memory register, and no part (or flags) of the PSWs be changed when the trap occurs. If any of these registers or flags are changed, the Register Altered bit (60) of the old PSWs is set to 1 and is saved by the trap XPSD.

Changes to CC1-CC4 cause the Register Altered bit to be set only if the instruction requires these condition code bits as subsequent inputs.

Traps caused by conditions detected during operand fetch and store memory cycles, such as nonexistent memory, access protection violation, and memory parity error may or may not leave registers, memory, and PSWs unchanged, depending on when they occur during instruction execution. Generally, these traps are recoverable. This is done by checking for protection violations and nonexistent memory at the beginning of execution in case of a multiple operand access instruction, restoring the original register contents if execution cannot be completed because of a trap, and not loading the first word of the PSWs until a possible trap condition due to access of the second word could have been detected. Table 5 contains a list of instructions and indicates for these instructions what registers, memory locations, and bits of the PSWs, if any, have been changed when a trap due to an operand access memory cycle occurs.

Tíbie 5. K̂egisiers Changed aí îime of a îrap Duve io an Operand Àccess

| Instructions | Changes |
| :--- | :--- |
| AI, CI, LCFI, LI, MI | Immediate type, no operand access. |
| CALI-CAL4, SF, S, WAIT, RD, WD, RIO, <br> POLR, POLP, DSA | No operand access. |
| LRA | Has operand access but traps are suppressed; register bits and <br> condition codes are set instead. |
| LB, LCF, LRP, CB <br> LH, LAH, LCH, AH, SH, MH, DH, CH |  |
| LW, LAW, LCW, AW, SW, MW, DW, CW | No operand store, registers and PSWs unchanged when trap <br> due to operand fetch. CCl-4 may be changed but are not <br> used as input to any of these instructions. |
| EOR, OR, AND, LS, INT, CS <br> FAS, FSS, FMS, FDS, FAL, FSL, FML, FDL | Registers and memory are preserved, condition codes may be <br> changed but are not used as input to these instructions. |
| AWM, XW, STS, MTB, MTH, MTW <br> STB, STCF, STH, STW, LAS | Memory will be altered and the Register Altered bit set. |
| EXU, BCR, BCS <br> BAL, BDR, BIR | If the branch condition is true (always for EXU and BAL) and <br> a trap occurs due to access of the indirect address or of the <br> next (branched to or executed) instruction, the register used <br> is left unchanged and the program address saved in the PSWs <br> is the address of the branch or execute instruction. |

Table 5. Registers Changed at Time of a Trap Due to an Operand Access (cont.)

| Instructions | Changes |
| :--- | :--- |
| MBS, CBS, TBS, TTBS, EBS, MMC <br> DA, DS, DL, DST, DC, DM, DD, PACK, <br> UNPK, LM, STM, PLM, PSM, STD | Registers and memory may be changed and the Register Altered <br> bit set. |
| CVA, CVS | If a trap occurs, the instruction will be aborted before altering <br> registers. CCl-4 may be changed but not used as input to any <br> of these instructions. |
| XPSD, LPSD, PSS, PLS | If a trap occurs due to storing the old PSWs or fetching the <br> new PSWs, the instruction is aborted before changing the old <br> PSWs. |
| SIO, TIO, TDV, HIO, AIO, RIO | If trap occurs, the instruction will be aborted without altering <br> condition codes, registers, or memory. |
| *ANLZ | An indirect ANALYZE instruction executed in the master- <br> protected mode will trap. No registers are altered. |

## 3. INSTRUCTION REPERTOIRE

This chapter describes the instructions, grouped in the following functional classes:

1. Load and Store
2. Analyze and Inferpret
3. Fixed-Point Arithmetic
4. Comparison
5. Logical
6. Shift
7. Conversion
8. Floating-Point Arithmetic
9. Decimal
10. Byte String
11. Push Down
12. Execute and Branch
13. Call
14. Control (privileged)
15. Input/Output (privileged)

Instructions are described in the following format:


| 0 | Operation Code | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Operand |

Description ${ }^{(7)}$

$$
\text { Affected }{ }^{(8)} \quad \text { Trap }{ }^{(9)}
$$

Symbolic Notation ${ }^{(10)}$
Condition Code Settings ${ }^{(11)}$
Trap Action (12)
Example ${ }^{(13)}$

1. MNEMONIC is the code used by Xerox assemblers to produce the instruction's basic operation code.
2. INSTRUCTION NAME is the instruction's descriptive title.
3. The instruction's addressing type is one of the following:
a. Byte index alignment: the reference address field of the instruction (plus the displacement value) can be used to address a byte in main memory or in the current block of general registers.
b. Halfword index alignment: the reference address field of the instruction (plus the displacement value) can be used to address a halfword in main memory or in the current block of general registers.
c. Word-index alignment: the reference address field of the instruction (plus the displacement value) can be used to address any word in main memory or in the current block of general registers.
d. Doubleword index alignment: the reference address field of the instruction (plus the displacement value) can be used to address any doubleword in main memory or in the current block of general registers. The addressed doubleword is automatically located within doubleword storage boundaries. (The low order bit of the reference address is ignored.)
e. Immediate operand: the instruction word contains an operand value used as part of the instruction execution. If indirect addressing is attempted with this type of instruction (i.e., bit 0 of the instruction word is a $\mathbf{1}$ ), the instruction is treated as a nonexistent instruction, and the basic processor unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $\mathrm{X}^{\prime} 40^{\prime}$, the "nonallowed operation" trap. Indexing does not apply to this type of instruction.
f. Immediate displacement: the instruction word contains an address displacement used as part of the instruction execution. If indirect addressing is attempted with this type of instruction, the basic processor treats the instruction as a nonexistent instruction, and it unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$. Indexing does not apply to this type of instruction.
4. If the instruction is not executable while the basic processor is in the slave mode, it is labeled "privileged" If execution of a privileged instruction is attempted while the basic processor is in the slave mode, it unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$.
5. If the instruction can be successfully resumed after its execution sequence has been interrupted by an interrupt acknowledgment, the instruction is labeled
"continue after interrupt". In the case of the "continue after interrupt" instructions, certain general registers contain intermediate results or control information that allows the instruction to continue properly.
6. Instruction format:
a. Indirect addressing - If bit position 0 of the instruction format contains an asterisk (*), the instruction can use either indirect or direct addressing. If bit position 0 of the instruction format contains a 0 , the instruction is of the immediate operand type, which is treated as a nonexistent instruction if indirect addressing is attempted (resulting in a trap to location $X^{\prime} 40^{\prime}$ ).
b. Operation code - The operation code field (bit positions 1-7) of the instruction is shown in hexadecimal notation. For certain I/O instructions, the operation code field is extended and includes bit positions 15-17 of the instruction.
c. $\quad$ field - If the register address field (bit positions 8-11) of the instruction format contains the character "R", the instruction can specify any register in the current block of general registers as an operand source, result destination, or both; otherwise, the function of this field is determined by the instruction.
d. $X$ field - If the index register address field (bit positions 12-14) of the instruction format contains the character " X ", the instruction specifies indexing with any one of registers 1 through 7 in the current block of general registers; otherwise, the function of this field is determined by the instruction.
e. Reference address field - Normally, the address field (bit positions 15-31) of the instruction format is used as the reference address value for real, real extended, and virtual addresses (see Chapter 2). This reference address field is also used to address $I / O$ systems (see $I / Q$ instructions later in this chapter and also Chapter 4). For immediate operand instructions, this field is augmented with the contents of the $X$ field, as illustrated, to form a 20 -bit operand.
f. Value field - In some fixed-point arithmetic instructions, bit positions 12-31 of the instruction format contain the word "value". The field is treated as a 20-bit integer, with negative integers represented in two's complement form.
g. Displacement field - In the byte string instructions bit positions 12-31 of the instruction format contain the byte "displacement". In the execution of the instruction, this field is used to modify the source address of an operand, the destination address of a result, or both.
h. Reserved fields - In any format diagram that depicts system inputs (i.e., instruction, data word), a shaded area represents a field that is ignored by the basic processor (i.e., the content of the shaded field has no effect on instruction execution). It should not be used or must be coded with 0's to preclude conflict with possible future modifications.

In any format diagram that depicts system outputs (i.e., general register, memory word modified by an instruction, or $1 / O$ status word), a shaded area represents a field whose content is indeterminate and must not be used (i.e., masked).
7. The description of the instruction defines the operations performed by the basic processor in response to the instruction configuration depicted by the instruction format diagram. Any instruction configuration that causes an unpredictable result is so specified in the description.
8. All programmable registers and storage areas that can be affected by the instruction are listed (symbolically) after the word "Affected". The instruction address portion of the program status words is considered to be affected only if a branch condition can occur as a result of the instruction execution, since the instruction address is incremented by 1 as part of every instruction execution.
9. All trap conditions that may be invoked by the execution of the instruction are listed after the word "Trap". Trap locations are summarized in the section "Trap System" in Chapter 2.
10. The symbolic notation presents the instruction operation as a series of generalized symbolic statements. The symbolic terms used in the notation are defined in the Appendix, "Glossary of Symbolic Terms".
11. Condition Code settings are given for each instruction that affects the condition code. A 0 or a 1 under any of columns 1, 2, 3, or 4 indicates that the instruction causes a 0 or 1 to be placed in CC1, CC2, CC3 or CC4, respectively, for the reasons given. If a hyphen (-) appears in columns $1,2,3$, or 4 , that portion of the condition code is not affected. For example, the following condition code settings are given for a comparison instruction:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of comparison

$$
\begin{array}{llll}
- & - & 0 & \text { Equal. } \\
- & - & 1 & \begin{array}{l}
\text { Register operand is arithmetically less } \\
\text { than effective operand. }
\end{array} \\
\cdots & - & 0 & \begin{array}{l}
\text { Register operand is arithmetically greater } \\
\text { than effective operand. }
\end{array} \\
-1 & - & \begin{array}{l}
\text { The logical product of the two operands } \\
\text { is nonzero. }
\end{array} \\
- & - & -\quad \begin{array}{l}
\text { The logical product (AND) of the two op- } \\
\text { erands is zero. }
\end{array}
\end{array}
$$

CC1 is unchanged by the instruction. CC2 indicates whether or not the two operands have l's in corresponding bit positions, regardless of their arithmetic relationship. CC3 and CC4 are set according to the arithmetic relationship of the two operands, regardless of whether or not the two operands have l's in corresponding bit positions. For example, if the register operand is arithmetically less than the effective operand, and the two operands both have l's in at least one corresponding bit position, the condition code setting for the comparison instruction is:

1234

- 101

The above statements about the condition code are valid only if no trap occurs before the successful completion of the instruction execution cycle. If a trap does occur during the instruction execution, the condition code is normally reset to the value it contained before the instruction was started and the register altered bit (bit 60 in PSWs) is set to 1 if a register has been altered. Then the appropriate trap location is activated.
12. Acrions taken by the basic processor for those trap conditions that may be invoked by the execution of the instruction are described. The description includes the criteria for the trap condition, any controlling trap mask or inhibit bits, and the action taken by the basic processor.

Note: To avnid unnecessary repetition, the three trap conditions that apply to all instructions (i.e., nonallowed operations, parity error, and watchdog timer runout) are not described for each instruction.
13. Some instruction descriptions provide one or more examples to illustrate the results of the instruction. These examples are intended only to show how the instructions operate, and not to demonstrate their full capability. Within the examples, hexadecimal notation is used to represent the contents of general registers and storage locations. Condition code settings are shown in binary notation. The character " $x$ " is used to indicate irrelevant or ignored information.
Note: In the following text, BP is used as an abbreviation for basic processor.

## LOAD/STORE INSTRUCTIONS

The load/store instructions are as follows:
Instruction Name
Mnemonic
Load Immediate
LI
Load Byte
LB

| Instruction Name | Mnemonic |
| :---: | :---: |
| Load Halfword | LH |
| Load Word | LW |
| Load Doubleword | L. |
| Load Complement Halfword | LCH |
| Load Absolute Halfword | LAH |
| Load Complement Word | LCW |
| Load Absolute Word | LAW |
| Load Complement Doubleword | LCD |
| Load Absolute Doubleword | LAD |
| Load Read Address (see "Control Instructions") | LRA |
| Load and Set | LAS |
| Load Memory Status (see "Control Instructions") | LMS |
| Load Selective | LS |
| Load Multiple | LM |
| Load Conditions and Floating Control Immediate | LCFI |
| Load Conditions and Floating Control | LCF |
| Load Virtual Address Word | LVAW |
| Exchange Word | XW |
| Store Byte | STB |
| Store Halfword | STH |
| Store Word | STW |
| Store Doubleword | STD |
| Store Selective | STS |
| Store Multiple | STM |
| Store Conditions and Floating Control | STCF |

The load and store instructions operate with information fields of byte, halfword, word, and doubleword lengths. Load instructions load the information indicated into one or more of the general registers in the current register block. Load instructions do not affect the source of information; however, nearly all load instructions provide a condition code setting that indicates the following information about
the contents of the affected general register(s) after the instruction is successfully completed:

Condition code settings:

## 1234 Result

-     - 00 Zero - the result in the affected register(s) is all 0 's.
-     - 0 I Negative - register $R$ contains a 1 in bit position 0 .
-     - 10 Positive - register R contains a 0 in bit position 0 , and at least one 1 appears in the remainder of the affected register(s) (or appeared during execution of the current instruction.)
- 0 - - No fixed-point overflow - the result in the affected register(s) is arithmetically correct.
- 1 - - Fixed-point overflow - the result in the affected register(s) is arithmetically incorrect.

Store instructions affect only that portion of memory storage that corresponds to the length of the information field specified by the operation code of the instruction; thus, register bytes are stored in memory byte locations, register halfwords in memory halfword locations, register words in memory word locations, and register doublewords in memory doubleword locations. Store instructions do not affect the contents of the general register specified by the $R$ field of the instruction, unless the same register is also specified by the effective virtual address of the instruction.

## LI LOAD IMMEDIATE <br> (Immediate operand)



LOAD IMMEDIATE extends the sign of the value field (bit position 12 of the instruction word) 12 bit positions to the left and then loads the 32 -bit result into register $R$.

Affected: (R), CC3, CC4 Trap: Nonexistent instruction, (I) $12-31 S E \longrightarrow$

Condition code settings:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in $R$

- 00 Zero
- 01 Negative
-     - 10 Positive

If LI is indirectly addressed, it is treated as a nonexistent instruction, in which case the BP unconditionally aborts
execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$ with the contents of register $R$ and the condition code unchanged.

## LB LOAD BYTE

(Byte index alignment)

| $*$ | 72 | $R$ | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 1231456 |  |  |  |

LOAD BYTE loads the effective byte into bit positions 24-31 of register $R$ and clears bit positions 0-23 of the register to all 0 's.

Affected: (R), CC3, CC4


Condition code settings:

| 1 | 2 | 3 | 4 | Result in $R$ |
| :--- | :--- | :--- | :--- | :--- |
| $-\quad 0$ | 0 | Zero |  |  |
| $-\quad-\quad 1$ | 0 | Nonzero |  |  |

LH LOAD HALFWORD
(Halfword index alignment)


LOAD HALFWORD extends the sign of the effective halfword 16 bit positions to the left and then loads the 32-bit result into register $R$.

Affected: (R), CC3, CC4
$\mathrm{EH}_{\mathrm{SE}} \longrightarrow \mathrm{R}$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Resultinn

-     - 00 Zero
-     - 01 Negative
- 10 Positive

LW LOAD WORD
(Word index alignment)

| * | 32 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

LOAD WORD loads the effective word into register $R$.
Affected: (R), CC3, CC4
$\mathrm{EW} \longrightarrow R$

Condition code settings:
1234 Result in $R$

-     - 00 Zero
-     - 01 Negative
-     - 10 Positive

LD
LOAD DOUBLEWORD
(Doubleword index alignment)

| * | 12 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

LOAD DOUBLEWORD loads the 32 low-order bits of the effective doubleword into register Rul and then loads the 32 high-order bits of the effective doubleword into register R.

If $R$ is an odd value, the result in register $R$ is the 32 highorder bits of the effective doubleword. The condition code settings are based on the effective doubleword, rather than the final result in register $R$ (see example 3, below).

> Affected: (R), (Rul), CC3, CC4
> $\mathrm{ED}_{32-63} \mathrm{Rul} ; \mathrm{ED}_{0-3} \vec{\longrightarrow} \mathrm{R}$

Condition code settings:
1231 Effoctive doublaword

-     - 0 Zero
-     - 01 Negative
- 10 Positive

Example 1, even R field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
| ED | $=X^{\prime} 0123456789 A B C D E F '$ | X'0123456789ABCDEF' |
|  | $=x x x x x x x x$ | X'01234567 |
| (Rul) | $=x \times x x x x x x$ | X'89ABCDEF' |
| CC | $=x x x x$ | xx 10 |

Example 2, odd $R$ field value:

|  | Before execution |
| :--- | :--- |
| $E D=X^{\prime} 0123456789 A B C D E F$ |  |
|  | $X^{\prime} 0123456789 A B C D E F^{\prime}$ |
| $(R)=x x x x x x x x$ | $X^{\prime} 01234567^{\prime}$ |
| $C C=x x x x$ | $x \times 10$ |

Example 3, odd R field value:

|  | Before execution |  |  |  | After execution |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ED | X'0000000012345678' |  |  |  | X'0000000012345678' |
| (R) | xxxxxxxx |  |  |  | X'00000000' |
| CC | $=\mathrm{x}$ | xxxx |  |  | xx 10 |
| LCH | LOAD COMPLEMENT HALFWORD (Halfword index alignment) |  |  |  |  |
| * | 5A | A R | R | X | Reference address |

LOAD COMPLEMENT HALFWORD extends the sign of the effective halfword 16 bit positions to the left and then loads the 32-bit two's complement of the result into register $R$. (Overflow cannot occur.)

Affected: (R), CC3, CC4
$-\left[\mathrm{EH}_{\mathrm{SE}}\right] \longrightarrow \mathrm{R}$
Condition code settings:
$1 \begin{array}{llll}1 & 3 & 4\end{array}$ Result in R

-     - 00 Zero
-     - 01 Negative
-     - 10 Positive


## LAH LOAD ABSOLUTE HALFWORD (Halfword index alignment)



If the effective halfword is positive, LOAD ABSOLUTE HALFWORD extends the sign of the effective halfword 16 bit positions to the left and then loads the 32-bit result in register R. If the effective halfword is negative, LAH extends the sign of the effective halfword 16 bit positions to the left and then loads the 32-bit two's complement of the result into register R. (Overflow cannot occur.)

Affected: (R), CC3, CC4

$$
\mathrm{EH}_{\mathrm{SE}} \longrightarrow \mathrm{R}
$$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in $R$

-     - 00 Zero
- 10 Nonzero

LOAD COMPLEMENT WORD
(Word index alignment)

|  | 3A | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

LOAD COMPLEMENT WORD loads the 32-bit two's complement of the effective word into register R. Fixed-point overflow occurs if the effective word is $-2^{31}$ ( $X^{\prime} 80000000$ ') in which case the result in register $R$ is $-2^{31}$ and CC2 is set to 1 ; otherwise, CC2 is reset to 0 .

Affected: (R),CC2,CC3,CC4 Trap: Fixed-pointoverflow.
$-E W \longrightarrow R$
Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4 \\ \text { Result in } R\end{array}$

- 000 Zero
- 01 Negative
- 010 Positive
- 0 - - No fixed-point overflow
- 101 Fixed-point overflow

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the BP traps to location $X^{\prime} 43^{\prime}$ after execution of LOAD COMPLEMENT WORD; otherwise, the BP executes the next instruction in sequence.

LAW LOAD ABSOLUTE WORD
(Word index alignment)


If the effective word is positive, LOAD ABSOLUTE WORD loads the effective word into register R. If the effective word is negative, LAW loads the 32-bit two's complement of the effective word into register R. Fixed-point overflow occurs if the effective word is $-2^{31}\left(X^{\prime} 80000000\right.$ ), in which case the result in register $R$ is $-2^{31}$, and CC2 is set to 1 ; otherwise, CC2 is reset to 0 .

Affected: (R),CC2,CC3,CC4 Trap: Fixed-point overflow

$$
|E W| \longrightarrow R
$$

Condition code settings:
$12 \begin{array}{lll}1 & 4 \\ \text { Result in } R\end{array}$

- 000 Zero
-     - 10 Nonzero
- 0 - - No fixed-point overflow
- 101 Fixed-point overflow (sign bit on)

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the $B P$ traps to location $X^{\prime} 43^{\prime}$ after execution of LOAD ABSOLUTE WORD; otherwise, the BP executes the next instruction in sequence.

## LCD LOAD COMPLEMENT DOUBLEWORD

 (Doubleword index alignment)| * | 1A | R | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |

LOAD COMPLEMENT DOUBLEWORD forms the 64-bit two's complement of the effective doubleword, loads the 32 low-order bits of the result into register Rul, and then loads the 32 high-order bits of the result into register $R$.

If $R$ is an odd value, the result in register $R$ is the 32 highorder bits of the two's complemented doubleword. The condition code settings are based on the two's complement of the effective doubleword, rather than the final result in register R.

Fixed-point overflow occurs if the effective doubleword is $-2^{63}$ ( $X^{\prime} 8000000000000000$ ), in which case the result in registers $R$ and Rul is $-2^{63}$ and CC2 is set to 1; otherwise, CC2 is reset to 0 .

Affected: (R),(Rul),CC2, Trap: Fixed-point overflow CC3,CC4
$[-E D]_{32-63} \longrightarrow \mathrm{RuI} ;[-E D]_{0-31} \longrightarrow \mathrm{R}$
Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Two's complement of effective doubleword

- 000 Zero
-     - 01 Negative
- 010 Positive
- 0 - - No fixed-point overflow
- 101 Fixed-point overflow

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the BP traps to location $X^{\prime} 43^{\prime}$ after execution of LOAD COMPLEMENT DOUBLEWORD; otherwise, the $B P$ executes the next instruction in sequence.

Example 1, even $R$ field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
| ED | - X'0123450́707ADCDEF' | X'1023456789ABCDEF' |
| (R) | $=x x x x x x x x$ | X'FEDCBA98' |
| (Rul) | $=x x x x x x x x$ | X'76543211' |
| CC | $=x \times x x$ | $\times 001$ |

After execution
X'1023456709ABCDEF'
X'FEDCBA98'
X'765432111
$\times 001$

Example 2, odd $R$ field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
| ED | $=\mathrm{X}^{\prime} 0123456789 \mathrm{ABCDEF}{ }^{\prime}$ | X'0123456789ABCDEF' |
| (R) | $=x \times x x x x x x$ | X'FEDCBA98' |
| CC | $=x x x x$ | x001 |

## LAD LOAD ABSOLUTE DOUBLEWORD (Doubleword index alignment)

| * | 1B | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If the effective doubleword is positive, LOAD ABSOLUTE DOUBLEWORD loads the 32 low-order bits of the effective doubleword into register Rul, and then loads the 32 highorder bits of the effective doubleword into register $R$. If $R$ is an odd value, the result in register $R$ is the 32 high-order bits of the effective doubleword. The condition code settings are based on the effective doubleword, rather than the final result in register $R$.

If the effective doubleword is negative, LAD forms the 64-bit two's complement of the effective doubleword, loads the 32 low-order bits of the two's complemented doubleword into register Rul, and then loads the 32 high-order bits of the two's complemented doubleword into register $R$. If $R$ is an odd value, the result in register $R$ is the 32 highorder bits of the two's complemented doubleword. The condition code settings are based on the two's complement of the effective duubleworu, ruiher thon the final result in register R.

Fixed-point overflow occurs if the effective doubleword is -263 ( $X^{\prime} 8000000000000000^{\prime}$ ), in which case the result in registers $R$ and Rul is -263 and CC2 is set to 1 ; otherwise, CC2 is reset to 0 .

> Affected: $\begin{aligned} & (R),(R u 1), C C 2, \quad \text { Trap: Fixed-point overflow } \\ & C C 3, C C 4\end{aligned}$ $|E D|_{32-63} \longrightarrow R u 1 ;|E D|_{0-31} \longrightarrow R$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Absolute value of effective doubleword

- 0000 Zero
-     - 10 Nonzero
- 0 - - No fixed-point overflow
- 101 Fixed-point overflow (sign bit on)

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the BP traps to location $X^{\prime} 43^{\prime}$ after execution
of LOAD ABSOLUTE DOUBLEWORD; otherwise, the BP executes the next instruction in sequence.

Example 1, even $R$ field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
| ED | $=\mathrm{X}^{\prime} 0123456789 \mathrm{ABCDEF}{ }^{\prime}$ | X'0123456789ABCDEF' |
|  | $=x x x x x x x x$ | X'01234567' |
| (Rul) | $=x x x x x x x x$ | X'89ABCDEF' |
| CC | $=x x x x$ | $\times 010$ |

Example 2, even $R$ field value:

| Before execution | After execution |
| :--- | :--- |
| $E D=X^{\prime}$ FEDCBA9876543210' | $X^{\prime}$ FEDCBA9876543210' |
| $(R)=x x x x x x x x$ | $X^{\prime} 01234567^{\prime}$ |
| $(R u 1)=x x x x x x x x$ | $X^{\prime} 89 A B C D F 0^{\prime}$ |
| $C C=x x x x$ | $x 010$ |

Example 3, odd $R$ field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
| ED |  |  |
| (R) | $=x x x x x x x x$ | X'01234567' |
| CC | $=x x x x$ | x010 |

LAS LOAD AND SET
(Word index alignment)

| * | 26 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

LOAD AND SET loads the effective word into R. If the effective address is equal to or greater than 16 , a one is stored in the sign position of the effective location. If the effective address is equal to or less than 15 (effective location is a general register), the sign bit remains unchanged. This instruction is used to interlock multiple processors from the simultaneous execution of certain sections of code or from the simultaneous access to certain tables.

Affected: (R), CC3, CC4
$\mathrm{EW} \longrightarrow \mathrm{R}$
$1 \longrightarrow \mathrm{EW}_{0}$, if $\mathrm{EA} \geq 16$

## Condition code settings:

## $1 \begin{array}{llll}1 & 3 & 4 \\ \text { Result in } R\end{array}$ <br> - - 0 Zero <br> - - 0 I Negative <br> - 10 Positive

Note: Write locks protect memory and traps are not inhibited during the execution of LAS.

## LS LOAD SELECTIVE <br> (Word index alignment)

| * | 4A | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

Register Rul contains a 32-bit mask. If $R$ is an even value, LOAD SELECTIVE loads the effective word into register $R$ in those bit positions selected by a 1 in corresponding bit positions of register Rul. The contents of register R are not affected in those bit positions selected by a 0 in corresponding bit positions of register Rul.

If $R$ is an odd value, LS logically ANDs the contents of register $R$ with the effective word and loads the result into register $R$. If corresponding bit positions of register $R$ and the effective word both contain l's, a 1 remains in register $R$; otherwise, a 0 is placed in the corresponding bit position of register $R$.

Affected: (R), CC3, CC4
If $R$ is even, $[E W n(R u I)] \cup[(R) n(\overline{\operatorname{RuI})})] \longrightarrow R$
If $R$ is odd, $E W n(R) \longrightarrow R$
Condition code settings:

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

-     - 00 Zero.
-     - 0 Bit 0 of register $R$ is a 1 .
-     - 10 Bit 0 of register $R$ is a 0 and bitpositions 1-31 of register $R$ contain at least one 1 .

Example 1, even $R$ field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
|  | $=\times 10123456{ }^{\prime \prime}$ | X'01234567' |
| (Rul) | $=\mathrm{X}^{\prime}$ 'FFOOFFOO' | X'FFOOFFOO' |
| (R) | $=x \times x x x x x x$ | $X^{\prime} 01 \times x 45 x x^{\prime}$ |
| CC | $=x x x x$ | xx 10 |

Example 2, odd R field value:



LOAD MULTIPLE loads a sequential set of words into a sequential set of registers, the set of words to be loaded begins with the word pointed to by the effective address of LM, and the set of registers begins with register $R$. The set of registers is treated modulo 16 (i.e., the next register loaded after register 15 is register 0 in the current register block).

The number of words to be loaded into the general registers is determined by the setting of the condition code immediately before the execution of LM. (The desired value of the condition code can be set with LCF or LCFI.) An initial value of 0000 for the condition code causes 16 consecutive words to be loaded into the register block.

Affected: ( R ) to ( $\mathrm{R}+\mathrm{CC}-1$ )
$(E W L \longrightarrow R ;(E W L+1) \longrightarrow R+1), \ldots,(E W L+C C-1) \longrightarrow R+C C-1$
The LM instruction may cause a trap if its operation extends into a page of memory that is protected by the access protection codes. A trap may also occur if the operation extends into a nonexistent memory region.

If the effective virtual address of the LM instruction is in the range 0 through 15 , then the words to be loaded are taken from the general registers rather than from main memory. In this case the results wil! be unpredictable if any of the source registers are also used as destination registers.

## LCFI LOAD CONDITIONS AND FLOATING CONTROL IMMEDIATE <br> (Immediate operand)



If bit position 10 of the instruction word contains a 1, LOAD CONDITIONS AND FLOATING CONTROL IMMEDIATE loads the contents of bit positions 24 through 27 of the instruction word into the condition code; however, if bit 10 is 0 , the condition code is not affected.

If bit position 11 of the instruction word contains a 1, LCFI loads the contents of bit positions 28 through 31 of the instruction word into the floating round (FR), floating
significance (FS), floating zero (FZ), and floating normalize (FN) mode control bits, respectively (in the program status words); however, if bit 11 is 0 , the FR, FS, FZ, and FN control bits are not affected. The functions of the floatingpoint control bits are described in the section "FloatingPoint Arithmetic Instructions".

Affected: CC, FR, FS, FZ, FN
Trap: Nonexistent instruction, if bit 0 is a 1 .

If (I) ${ }_{10}=1,(\mathrm{I})_{24-27} \longrightarrow \mathrm{CC}$
If (I) $10=0, C C$ is not affected.
If (I) ${ }_{11}=1,{ }^{(\mathrm{I})_{28-31} \longrightarrow F R, F R, F S, F Z, F N}$
If $(\mathrm{I})_{11}=0, F R, F S, F Z$, and $F N$ not affected.
Condition code settings, if (I) $10=1$ :

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |
| ${ }^{(\mathrm{I})_{24}}$ | ${ }^{(\mathrm{I})_{25}}$ | ${ }^{(\mathrm{I})} 26$ | ${ }^{(\mathrm{I})} 27$ |

If LCFI is indirectly addressed, it is treated as a nonexistent instruction, in which case the computer unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{1}$ with the condition code unchanged.

LCF LOAD CONDITIONS AND FLOATING CONTROL
('Byte index alignment)


If bit position 10 of the instruction word contains a 1 , LOAD CONDITIONS AND FLOATING CONTROL loads bits 0 through 3 of the effective byte into the condition code; however, if bit 10 is 0 , the condition code is not affected.

If bit position 11 of the instruction word contains a 1, LCF loads bits 4 through 7 of the effective byte into the floating round (FR), floating significance (FS), floating zero (FZ), and floating normalize (FN) mode control bits, respectively; however, if bit 11 is 0 , the FR, FS, FZ, and FN control bits are not affected. The functions of the floating-point mode control bits are described in the section "FloatingPoint Arithmetic Instructions".

Affected: CC, FR,FS,FZ,FN
If (I) ${ }_{10}=1, \mathrm{~EB}_{0-3} \longrightarrow \mathrm{CC}$
If (I) ${ }_{10}=0, \mathrm{CC}$ not affected
If (I) ${ }_{11}=1, \mathrm{~EB}_{4-7} \longrightarrow \mathrm{FR}, \mathrm{FS}, \mathrm{FZ}, \mathrm{FN}$
If (I) $11=0, F R, F S, F Z, F N$ not affected

Condition code settings, if (I) $10=1$ :

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |
| $(E B)_{0}$ | $(E B)_{1}$ | $(E B)_{2}$ | $(E B)_{3}$ |

## LVAW LOAD VIRTUAL ADDRESS WORD (Word index alignment)

| * | 34 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

LOAD VIRTUAL ADDRESS WORD loads bit positions 15-31 of register $R$ with the effective virtual word address of the instruction while bit positions $0-14$ of register $R$ are cleared to zero.

Affected: (R)
$E V A \longrightarrow R_{15-31,} \quad 0 \longrightarrow R_{0-14}$

Note: Condition code is not affected by LVAW.

XW EXCHANGE WORD
(Word index alignment)

| * | 46 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

EXCHANGE WORD exchanges the contents of register $R$ with the contents of the effectivo word location.

Affected: (R), (EWL), CC3, CC4
$(R) \longrightarrow(E W L)$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4 \\ \text { Result in R }\end{array}$

-     - 00 Zero
-     - 01 Negative
-     - 10 Positive

STB STORE BYTE
(Byte index alignment)


STORE BYTE stores the contents of bit positions 24-31 of register $R$ into the effective byte location.

Affected: (EBL)
$(\mathrm{R})_{24-31} \longrightarrow E B L$

STORE HALFWORD
(Halfword index alignment)

| * | 55 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

STORE HALFWORD stores the contents of bit positions 16-31 of register $R$ into the effective halfword location. If the information in register $R$ exceeds halfword data limits, CC2 is set to 1 ; otherwise, CC2 is reset to 0 .

Affected: (EHL), CC2
${ }^{(\mathrm{R})}{ }_{16-31} \longrightarrow \mathrm{EHL}$

Condition code settings:
12344 Information in R

- $0-\quad-{ }^{(R)} 0_{0-16}=$ all 0 's or all 1 's.
- 1 - $-(R)_{0-16} \neq$ all 0 's or all 1 's.

STW STORE WORD
(Word index alignment)


STORE WORD stores the contents of register $R$ into the effective word location.

Affected: (EWL)
$(R) \longrightarrow E W L$

STD STORE DOUBLEWORD
(Doubleword index alignment)

| * | 15 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

STORE DOUBLEWORD stores the contents of register $R$ into the 32 high-order bit positions of the effective doubleword location and then stores the contents of register Rul into the 32 low-order bit positions of the effective doubleword location.

Affected: (EDL)
$(\mathrm{R}) \longrightarrow \mathrm{EDL}_{0-31^{\prime}}(\mathrm{Rul}) \longrightarrow \mathrm{EDL}_{32-63}$
Example 1, even R field value:


## Before execution

R) $=X^{\prime} 01234567^{\prime}$

X'89ABCDEF'
$X^{\prime} 0123456789 A B C D E F{ }^{\prime}$

Example 2, odd R field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
| $(\mathrm{R})=$ | X'89ABCDEF' | X'89ABCDEF' |
| $(E D L)=$ | x $\times x \times x \times x \times x \times x \times x \times x \times x$ | X'89ABCDEF89ABCDEF' |
| STS | STORE SELECTIVE <br> (Word index alignment) |  |



Register Rul contains a 32-bit mask. If $R$ is an even value, STORE SELECTIVE stores the contents of register $R$ into the effective word location in those bit positions selected by a 1 in corresponding bit positions of register Rul; the effective word remains unchanged in those bit positions selected by a 0 in corresponding bit positions of register Rul.

If $R$ is an odd value, STS logically inclusive ORs the contents of register $R$ with the effective word and stores the result into the effective word location. The contents of register $R$ are not affected.

Affected: (EWL)
If $R$ is even, $[(R) n(R u l)] \cup[E W n(\overline{\operatorname{RuI}})] \longrightarrow E W L$
If $R$ is odd, $(R) \cup E W \longrightarrow E W L$
Example 1, even R field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
|  | $\chi^{\prime} 12345678^{\prime}$ | X'12345678' |
| (Ru1) | X'FOFOFOFO' | X'FOFOFOFO' |
| EW |  | $X^{\prime} 1 \times 3 \times 5 \times 7 x^{\prime}$ |

Example 2, odd p field value:

Before execution
(R) $=X^{\prime} 00 \mathrm{FF} 00 \mathrm{FF}^{\prime}$
$X^{\prime} 00 F F 00 F F '$
$E W=X^{\prime} 12345678^{\prime}$
$C^{\prime} 12 F F 56 F F^{\prime}$

STM STORE MULTIPLE
(Word index alignment)

| * | 2B | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

STORE MULTIPLE stores the contents of a sequential set of registers into a sequential set of word locations. The set of locations begins with the location pointed to by the effective word address of STM, and the set of registers begins with register $R$. The set of registers is treated modulo 16 (i.e., the
next sequential register after register 15 is register 0 ). The number of registers to be stored is determined by the value of the condition code immediately before execution of STM. (The condition code can be set to the desired value before execution of STM with LCF or LCFI.) An initial value of 0000 for the condition code causes 16 general registers to be stored.

Affected: (EWL) to (EWL+CC-1)
$(R) \longrightarrow E W L,(R+1) \longrightarrow E W L+1, \ldots,(R+C C-1) \longrightarrow E W L+C C-1$

The STM instruction may cause a trap if its operation extends into a page of memory that is protected by the access protection codes or the write locks. A trap may also occur if the operation extends into a nonexistent memory region.

If the effective virtual address of the STM instruction is in the range 0 through 15, then the registers indicated by the $R$ field of the STM instruction are stored in the general registers rather than main memory. In this case, the results will be unpredictable if any of the source registers are also used as destination registers.

STCF STORE CONDITIONS AND FLOATING CONTROL
(Byte index alignment)


STORE CONDITIONS AND FLOATING CONTROL stores the current condition code and the current value of the floating round (FR), floating significance (FS), floating zero (FZ), and floating normalize (FN) mode control bits of the program status words into the effective byte location as follows:


Affected: (EBL)
$(\mathrm{PSWs})_{0-7} \longrightarrow E B L$

## ANALYZE/INTERPRET INSTRUCTIONS

ANLZ ANALYZE
(Word index alignment)

| * | 44 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

ANALYZE evaluates the effective word as an instruction. The ANALYZE instruction always sets the condition codes to indicate the addressing type of the analyzed instruction (see condition code settings and Table 6). Except when

Table 6. ANALYZE Table for Operation Codes

| X'n' | $\mathrm{X}^{\prime} 00^{\prime}+\mathrm{n}$ | $X^{\prime} 20^{\prime}+n$ | $X^{\prime} 40^{\prime}+n$ | $X^{\prime} 60^{\prime}+n$ |
| :---: | :---: | :---: | :---: | :---: |
| 00 | - | AI | TTBS | CBS |
| 01 | - | Cl | TBS | MBS |
| 02 | LCFI (9) ${ }^{\text {ti }}$ | LI | -(1) ${ }^{\text {fr }}$ | - |
| 03 | - | MI | - | EBS |
| 04 | CALI | SF | ANLZ | BDR |
| 05 | CAL2 | S | CS | BIR |
| 06 | CAL3 | LAS | XW | AWM |
| 07 | CAL4 | - | STS | EXU |
| 08 | PLW | CVS | EOR | BCR |
| 09 | PSW | CVA $t$ | OR | BCS |
| 0A | PLM | LM (8) ${ }^{\text {tr }}$ | LS | BAL |
| OB | PSM | STM | AND | INT |
| OC | PLS ${ }^{\dagger}$ | LRA ${ }^{\dagger}$ | SIO ${ }^{\dagger}$ | RD ${ }^{\dagger}$ |
| OD | PSS ${ }^{\dagger}$ | LMS $^{\dagger}{ }^{+}$ | $\mathrm{TIO}^{\dagger}$ | $W D^{\dagger}$ |
| OE | LPSD ${ }^{\dagger}$ (12) ${ }^{\text {t }}$ | WAIT $^{\dagger}$ | $\mathrm{TDV}^{\dagger}{ }^{\dagger}$ | $\mathrm{AlO}^{\dagger}$ |
| OF | XPSD ${ }^{\dagger}$ | LRP ${ }^{\dagger}$ | $\mathrm{HIO}^{\dagger}$ | MMC ${ }^{\dagger}$ |
| 10 | AD | SW | AH | LCF |
| 11 | $C D$ | CW | CH | CB |
| 12 | LD | LW | LH | LB |
| 13 | MSP | MTW | MTH | MTB |
| 14 | - | LVAW | - | STCF |
| 15 | STD | STW | STH ${ }^{\text {t }}$ | STB ${ }^{\text {tt }}$ |
| 16 | - | DW | DH(4) ${ }^{\text {(t) }}$ | PACK (1) ${ }^{\text {ft }}$ |
| 17 | - | MW | MH | UNPK |
| 18 | SD | SW | SH | DS |
| 19 | CLM | CLR | - | DA |
| 1A | LCD | LCW | LCH | DD |
| 1B | LAD | LAW | LAH | DM |
| IC | FSL | FSS | - | DSA |
| 1D | FAL | FAS | - | DC |
| 1E | FDL | FDS | - | DL |
| 1 F | FML | FMS | - | DST |

${ }^{\dagger}$ Privileged instructions.
${ }^{\dagger t}$ Decimal value of condition code settings when analyzed instruction calls for direct addressing. If analyzed instruction calls for indirect addressing, add 2 to the value shown.
the analyzed instruction is an immediate operand instruction, an effective virtual address for the analyzed instruction is also calculated and loaded into register $R$.

The nonexistent instruction, the privileged instruction violation, and the unimplemented instruction trap conditions can never occur during execution of the ANLZ instruction. However, either the nonexistent memory address condition or the memory protection violation trap condition (or both) can occur as a result of any memory access initiated by the ANLZ instruction. If either of these trap conditions occurs, the instruction address stored by an XPSD in trap location $X^{\prime} 40^{\prime}$ is always the virtual address of the ANLZ instruction.

## The detailed operation of ANALYZE is as follows:

1. The contents of the location pointed to by the effective virtual address of the ANLZ instruction is obtained. This effective word is the instruction to be analyzed. From a memory-protection viewpoint, the instruction (to be analyzed) is treated as an operand of the ANLZ instruction; that is, the analyzed instruction may be obtained from any memory area to which the program has read access.
2. If the operation code portion of the effective word specifies an immediate-addressing instruction type, the condition code is set to indicate the addressing type, and instruction execution proceeds to the next instruction in sequence after ANLZ. The original contents of register $R$ are not changed when the analyzed instruction is of the immediate-addressing type.

If the operation code portion of the effective word specifies a reference-addressing instruction type, the condition code is set to indicate the addressing type of the analyzed instruction and the effective address of the analyzed instruction is computed (using all of the normal address computation rules). If bit 0 of the effective word is a 1 , the contents of the memory location specified by bits 15-31 of the effective word are obtained and then used as a direct address. The nonallowed operation trap (memory protection violation or nonexistent memory address) can occur as a result of the memory access. Indexing is always performed (with an index register in the current register block) if bits 12-14 of the analyzed instruction are nonzero. During real extended addressing, the effective virtual address of the analyzed instruction is aligned as an integer displacement value and loaded into register $R$, according to the instruction addressing type, as follows:

Byte Addressing: $M A=0$


Byte Addressing: $M A=1, M M=0$


Halfword Addressing: $M A=0$


Halfword Addressing: $M A=1, M M=0$

| 0 | trap info |  | 21-bit halfword displacement |
| :---: | :---: | :---: | :---: |

Word Addressing: $M A=0$

| $0 \begin{aligned} & \text { trap } \\ & \text { info }\end{aligned}$ | 17-bit word displacement |
| :---: | :---: |

Word Addressing: $M A=1, M M=0$

Doubleword Addressing: $M A=0$


Doubleword Addressing: $M A=1, M M=0$


When the ANALYZE instruction is executed in the masterprotected mode and a trap condition occurs, it traps only on an indirect ANALYZE. Otherwise, instead of trapping it completes its execution by storing in register $R$ the address that would have caused the instruction to trap. Since the mode is master-protected, the access protection codes will apply to the interpretation of addresses. If a slave mode program is trapped because an instruction has referenced protected memory, the ANALYZE instruction in the master-protected mode can determine which address actually caused the trap.

To aid the interpreting program, when operating in the master-protected mode, the ANLZ instruction uses bits 1, 2, and 3 of register $R$ to indicate which memory accessinitiated by the ANLZ would have trapped. The meaning of the possible codes in register $R(1-3)$ is as follows:

Register R Bits
R1 R2 R3 Meaning

Successful generation of the effective virtual address of the analyzed instruction. The CCs are set to the addressing type of the analyzed instruction and $R(10-31)$ contain the effective virtual address of the analyzed instruction aligned as an integer displacement value according to the instruction addressing type.
$0 \quad 1$ The indirect reference of the analyzed instrucrion would have trapped because it was either nonexistent, memory protected, or had a parity error. The CCs are set to the addressing type of the analyzed instruction and $R(10-31)$ contain the virtual address of the indirect reference of the analyzed instruction aligned as a word displacement.

## R1 R2 R3 Meaning

011 The effective virtual address of the ANLZ instruction would have trapped because it was either nonexistent, memory protected, or had a parity error. The CCs are indeterminate since the instruction to be analyzed may not have been fetched (nonexistent memory). $R(10-31)$ contain the effective virtual address of the ANLZ instruction aligned as a word displacement.

If no trap condition occurs, ANLZ will execute normally and return the effective address of the instruction analyzed.

Table 6 shows the instruction set as a 4 by 32 matrix (arranged as a function of the operation code). This table also shows how the instruction set is divided into six groups as a function of the addressing type (delineated by heavy lines). For example, if the operation code of the analyzed instruction is either $X^{\prime} 02{ }^{\prime}, X^{\prime} 20^{\prime}, X^{\prime} 21^{\prime}, X^{\prime} 22^{\prime}$, or $X^{\prime} 23^{\prime}$, then CC1 is set to $1, C C 2$ is set to $0, C C 3$ is set to 0 (when analyzed instruction specifies direct addressing), and CC4 is set to 1 . The decimal equivalent of the condition code setting for this group of immediate, word addressing type of instructions is shown as a 9 within a circle. The decimal equivalents of the condition code settings for the other five groups are shown in the same manner. If the analyzed instruction calls for indirect addressing, CC3 is always set to a 1 and the decimal value of the condition code setting shown in Table 6 should be increased by 2 .

Affected: (R), CC
Cündition cưúe sethingós:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Instruction addressing type
0 0-0 Byte
0 0-1 Immediate, byte
0 1-0 Halfword
10 - 0 Word
10 - 1 Immediate, word
1 1-0 Doubleword

-     - 0 - Direct addressing $\left(E W_{0}=0\right)$
-     - 1 - Indirect addressing $\left(\mathrm{EW}_{0}=1\right)$

INT
INTERPRET
(Word index alignment)


INTERPRET loads bits $0-3$ of the effective word into the condition code, loads bits 16-31 of the effective word into bit positions 16-31 of register Rul (and loads 0 's into bit positions $0-15$ of register Rul, loads bits 4-15 of the
effective word into bit positions 20-31 of register $R$ (and clears the remaining bits of register $R$ ). If $R$ is an odd value, INT loads bits $0-3$ of the effective word into the condition code, loads bits 16-31 of the effective word into bit positions 16-31 of register $R$, and loads 0 's into bit positions $0-15$ of register $R$ (bits 4-15 of the effective word are ignored in this case).

$$
\begin{aligned}
& \text { Affected: }(\mathrm{R}),(\mathrm{Rul}), \mathrm{CC} \\
& \mathrm{EW}_{0-3} \longrightarrow \mathrm{CC} \\
& \mathrm{EW}_{4-15} \longrightarrow \mathrm{R}_{20-31} ; 0 \longrightarrow \mathrm{R}_{0-19} \\
& \mathrm{EW}_{16-31} \longrightarrow \mathrm{Rul}_{16-31^{; 0} \longrightarrow \mathrm{Rul}_{0-15}}
\end{aligned}
$$

Condition code settings:

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |
| $(\mathrm{EW})_{0}$ | $(\mathrm{EW})_{1}$ | $(\mathrm{EW})_{2}$ | $(\mathrm{EW})_{3}$ |

Example 1, even $R$ field value:

| EW Before execution |  |
| :--- | :--- |
| After execution |  |
| $(R)=X^{\prime} 12345678^{\prime}$ |  |
| (Rul) $=x \times x \times x \times x \times x \times x \times x$ | $X^{\prime} 12345678^{\prime}$ |
| $C C=x \times 0000234^{\prime}$ |  |
|  |  |
|  |  |

## FIXED-POINT ARITHMETIC INSTRUCTIONS

The fixed-point arithmetic instructions are:

| Instruction Name | Mnemonic |
| :--- | :--- |
| Add Immediate | AI |
| Add Halfword | AH |
| Add Word | AW |
| Add Doubleword | SH |
| Subtract Halfword | SW |
| Subtract Word | SD |
| Subtract Doubleword | MI |
| Multiply Immediate | MH |
| Multiply Halfword | MW |
| Multiply Word | DH |

Add Word to Memory
AWM
Modify and Test Byte
Modify and Test Halfword
MTH

Modify and Test Word MTW

The fixed-point arithmetic instruction set performs binary addition, subtraction, multiplication, and division with integer operands that may be data, addresses, index values, or counts. One operand may be either in the instruction word itself or may be in one or two of the current general registers; the second operand may be either in main memory or in one or two of the current general registers. For most of these instructions, both operands may be in the same general register, thus permitting the doubling, squaring, or clearing the contents of a register by using a reference address value equal to the $R$ field value.

All fixed-point arithmetic instructions provide a condition code setting that indicates the following information about the result of the operation called for by the instruction:

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result

-     - 00 Zero - the result in the specified general register(s) is all zeros.
-     - 01 Negative - the instruction has produced a fixed-point negative result.
-     - 10 Positive - the instruction has produced a fixed-point positive result.
- 0 - - Fixed-point overflow has not occurred during execution of an add, subtract, or divide instruction, and the result is correct.
- 1 - - Fixed-point overflow has occurred during execution of an add, subtract, or divide instruction. For addition and subtraction, the incorrect result is loaded into the designated register(s). For a divide instruction, the designated register(s), and CC1, CC3, and CC4 are not affected.

0 - - No carry - for an add or subtract instruction, there was no carry of a l-bit out of the highorder (sign) bit position of the result.

1 - - - Carry - for an add or subtract instruction, there was a l-bit carry out of the sign bit position of the result. (Subtracting zero will always produce carry.)

AI ADD IMMEDIATE
(Immediate operand)

| 0 | 20 | R | Value |
| :---: | :---: | :---: | :---: |

The value field (bit positions 12-31 of the instruction word) is treated as a 20-bit, two's complement integer. ADD IMMEDIATE extends the sign of the value field (bit position 12 of the instruction word) 12 bit positions to the left, adds the resulting 32-bit value to the contents of register R , and loads the sum into register $R$.

Affected: (R), CC Trap: Fixed-pointoverflow, or nonexistent instruction if bit 0 is a 1 .
$(\mathrm{R})+{ }^{(\mathrm{I})}{ }_{12-31 S E} \longrightarrow \mathrm{R}$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in R

-     - 0 Zero
-     - 01 Negative
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - No carry from bit position 0
1 - - Carry from bit position 0

If AI is indirectly addressed, it is treated as a nonexistent instruction, in which case the BP unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$ with the contents of register R and the condition code unchanged.

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1, the BP traps to location $X^{\prime} 43$ ' after loading the sum into register $R$; otherwise, the BP executes the next instruction in sequence.

## AH ADD HALFWORD

(Halfword index alignment)

| * | 50 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

ADD HALFWORD extends the sign of the effective halfword 16 bit positions to the left (to form a 32-bit word in which bit positions $0-15$ contain the sign of the effective halfword), adds the 32-bit result to the contents of register $R$, and loads the sum into register $R$.

Affected: (R), CC
Trap: Fixed-point overflow
$(\mathrm{R})+\mathrm{EH}_{\mathrm{SE}} \longrightarrow \mathrm{R}$

Condition code settings:

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

-     - 00 Zero
- 01 Negative
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - No carry from bit position 0
1 - - Carry from bit position 0

If CC2 is set to 1 and the fixed-point arithmetic trap mask is 1 , the BP traps to location $\mathrm{X}^{\prime} 43^{\prime}$ after loading the sum into register $R$; otherwise, the $B P$ executes the next instruction in sequence.

## AW ADD WORD <br> (Word index alignment)

| * | 30 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

ADD WORD adds the effective word to the contents of register $R$ and loads the sum into register $R$.

Affected: (R), CC
Trap: Fixed-point overflow
$(\mathrm{R})+\mathrm{EW} \longrightarrow \mathrm{R}$

Condition code settings:


If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the BP traps to location $X^{\prime} 43$ ' after loading the sum into register $R$; otherwise, the $B P$ executes the next instruction in sequence.

ADD DOUBLEWORD
(Doubleword index alignment)

|  | 10 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

ADD DOUBLEWORD adds the effective doubleword to the contents of registers R and Rul (treated as a single, 64-bit register); loads the 32 low-order bits of the sum into register Rul and then loads the 32 high-order bits of the sum into register $R$. $R$ must be an even value; if $R$ is an odd value, the BP traps with the contents in register $R$ unchanged.

Affected: (R), (RuI), CC
Trap: Fixed-pointoverflow, instruction exception
$(R, R u l)+E D \longrightarrow R, R u l$

Condition code settings:

1 | 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

-     - 0 Zero
- 01 Negative
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - No carry from bit position 0
1 - - Carry from bit position 0

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the BP traps to location $X^{\prime} 43^{\prime}$ after loading the sum into registers $R$ and Rul; otherwise, the BP executes the next instruction in sequence.

The $R$ field of the $A D$ instruction must be an even value for proper operation of the instruction; if the $R$ field of $A D$ is an odd value, the instruction traps to location $\mathrm{X}^{\prime} 4 \mathrm{D}^{\prime}$, instruction exception trap.

Example 1, even $R$ field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
| ED | $=X^{\prime} 33333333 E E E E E E E E^{\prime}$ | X'33333333EEEEEEEE' |
|  | = X'1111111 | X'44444445' |
| (Rul) | $=X^{\prime} 33333333{ }^{\prime}$ | $X^{\prime} 22222221^{1}$ |
| CC | $=x x x x$ | 0010 |

SUBTRACT HALFWORD
(Halfword index alignment)

| * | 58 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

SUBTRACT HALFWORD extends the sign of the effective halfword 16 bit positions to the left (to form a 32-bit word in which bit positions $0-15$ contain the sign of the effective halfword), forms the two's complement of the resulting word, adds the complemented word to the contents of register $R$, and loads the sum into register $R$.

Affected: (R), CC
Trap: Fixed-point overflow
$-\mathrm{EH}_{S E}+(\mathrm{R}) \longrightarrow \mathrm{R}$
Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in $R$

-     - 00 Zero
-     - 01 Negative
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - No carry from bit position 0
1 - - Carry from bit position 0

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the BP traps to location $X^{\prime} 43^{\prime}$ after loading the sum into register $R$; otherwise, the $B P$ executes the next instruction in sequence.

## SW SUBTRACT WORD <br> (Word index alignment)

| * | 38 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

SUBTRACT WORD forms the two's complement of the effective word, adds that complement to the contents of register $R$, and loads the sum into register $R$.

Affected: (R), CC
Trap: Fixed-point overflow
$-E W+(R) \longrightarrow R$
Condition sode settings:
$12 \begin{array}{llll}1 & 3 & \text { Result in R }\end{array}$

-     - 00 Zero
- 01 Negative
$123 \quad 4$ Result in $R$
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - No carry from bit position 0
1 - - Carry from bit position 0
If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a I , the BP traps to location $\mathrm{X}^{\prime} 43^{\prime}$ after loading the sum into register $R$; otherwise, the $B P$ executes the next instruction in sequence.

SD SUBTRACT DOUBLEWORD
(Doubleword index alignment)

| * | 18 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

SUBTRACT DOUBLEWORD forms the 64-bit two's complement of the effective doubleword, adds the complemented doubleword to the contents of registers R and Rul (treated as a single, 64-bit register), loads the 32 low-order bits of the sum into register Rul and loads the 32 high-order bits of the sum into register $R$.

Affected: (R), (Rul), CC Trap: Fixed-pointoverflow, $\begin{gathered}\text { instruction exception }\end{gathered}$ $-E D+(R, R u I) \longrightarrow R, R u I$

Condition code settings:
1234 Result in R, Rul

-     - 0 Zero
-     - 01 Negative
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - No carry from bit position 0
1- - Carry from bit position 0
If $C C 2$ is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the $B P$ traps to location $X^{\prime} 43$ ' after the result is loaded into registers R and Rul; otherwise, the BP executes the next instruction in sequence.

The $R$ field of the SD instruction must be an even value for proper operation of the instruction; if the $R$ field of SD is an odd value, the instruction traps to location $X^{\prime} 4 D^{\prime}$, instruction exception trap; the contents in register $R$ remain unchanged.

MI MULTIPLY IMMEDIATE
(Immediate operand)


The value field (bit positions 12-31 of the instruction word) is treated as a 20-bit, two's complement integer. MULTIPLY IMMEDIATE extends the sign of the value field (bit position 12) of the instruction word 12 bit positions to the left and multiplies the resulting 32 -bit value by the contents of register Rul, then loads the 32 high-order bits of the product into register $R$, and then loads the 32 low-order bits of the product into register Rul.

If $R$ is an odd value, the result in register $R$ is the 32 loworder bits of the product. Thus, in order to generate a 64-bit product, the $R$ field of the instruction must be even and the multiplicand must be in register $R+1$. The condition code settings are based on the 64-bit product formed during instruction execution, rather than on the final contents of register R. Overflow cannot occur.

Affected: (R), (Rul), CC2, Trap: Nonexistent instrucCC3, CC4 tion if bit 0 is a 1.
(Rul) $\times$ (I) $12-31 \mathrm{SE} \longrightarrow \mathrm{R}, \mathrm{Rul}$

Condifion code seitings:
$12 \begin{array}{llll} & 2 & 4 & \text { 64-bit product }\end{array}$

- 00 Zero.
-     - 0 l iveguative.
-     - 10 Positive
- 0 - - Result is correct, as represented in register Rul.
- 1 - - Result is not correctly representable in register Rul alone.

If MI is indirectly addressed, it is treated as a nonexistent instruction, in which case the BP unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$ with the contents of register $R$, register Rul, and the condition code unchanged; otherwise, the BP executes the next instruction in sequence.

Example 1, even R field value:


Example 2, odd $R$ field value:


| * | 57 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

MULTIPLY HALFWORD multiplies the contents of bit positions 16-31 of register $R$ by the effective halfword (with both halfwords treated as signed, two's complement integers) and stores the product in register Rul (overflow cannot occur). If $R$ is an even value, the original multiplier in register $R$ is preserved, allowing repetitive halfword multiplication with a constant multiplier; however, if $R$ is an odd value, the product is loaded into the same register. Overflow cannot occur.

Affected: (Rul), CC3, CC4
${ }^{(R)}{ }_{16-31} \times \mathrm{EH} \longrightarrow \mathrm{RuI}$
Condition code settings:
$1 \begin{array}{llll}1 & 3 & 4\end{array}$

- 00 Zero
-     - 01 Negative
-     - 10 Positive

Example 1, even $R$ field value:

|  |  | Before execution | After execution |
| :---: | :---: | :---: | :---: |
| EH | $=$ | X'FFFF' | X'FFFF' |
|  |  | $X^{\prime} \times x \times x 000 A^{\prime}$ | $X^{\prime} \times x \times x 000 A^{\prime}$ |
| (RuT) | $=$ | x $x \times x \times x \times x \times$ | X'FFFFFFF6' |
| CC | $=$ | xxxx | xx01 |

Example 2, odd $R$ field value:

|  | Before execution | After execution |
| :---: | :---: | :---: |
| EH | $=\mathrm{X}^{\prime} \mathrm{FFFF}^{\prime}$ | X'FFFF' |
| (R) | $=X^{\prime} \times x \times x 000 A^{\prime}$ | X'FFFFFFF6' |
| CC | $=x x x x$ | xx01 |


| * | 37 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

MULTIPLY WORD multiplies the contents of register Rul by the effective word, loads the 32 high-order bits of the product into register $R$ and then loads the 32 loworder bits of the product into register Rul (overflow cannot occur).

If $R$ is odd value, the result in register $R$ is the 32 loworder bits of the product. Thus, in order to generate a 64-bit product, the $R$ field of the instruction must be even and the multiplicand must be in register $\mathrm{R}+1$. The condition code settings are based on the 64-bit product formed during instruction execution, rather than on the final contents of register $R$.

Affected: (R), (Rul), CC
(RuI) $\times \mathrm{EW} \longrightarrow R, R u I$

Condition code settings:
$1 \begin{array}{llll}1 & 2 & 3 & 64 \text {-bit product }\end{array}$

- 00 Zero.
- $\quad 01$ Negative.
-     - 10 Positive.
- 0 - - Result is correct, as represented in register Rul.
- 100 Result is not correctly representable in register Rul alone.

DH DIVIDE HALFWORD
(Halfword index alignment)

| * | 56 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

DIVIDE HALFWORD divides the contents of register R (treated as a 32-bit fixed-point integer) by the effective halfword and loads the quotient into register R. If the absolute value of the quotient cannot be correctly represented in 32 bits, fixed-point overflow occurs; in which case CC2 is set to 1 and the contents of register $R$, and $C C 1, C C 3$, and CC4 are unchanged.

Affected: (R), CC2, CC3, CC4 Trap: Fixed-point overflow
$(\mathrm{R}) \div \mathrm{EH} \longrightarrow \mathrm{R}$

Condition code settings:

1 | 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

- 000 Zero quotient, no overflow.
- 001 Negative quotient, no overflow.
- 010 Positive quotient, no overflow.
- 1 - Fixed-point overflow.

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the BP traps to location $X^{\prime} 43^{\prime}$ with the contents of register $\mathrm{R}, \mathrm{CC} 1, \mathrm{CC} 3$, and CC 4 unchanged.

DW DIVIDE WORD
(Word index alignment)


DIVIDE WORD divides the contents of registers $R$ and Rul (treated as a 64-bit fixed-point integer) by the effective word, loads the integer remainder into register $R$ and then loads the integer quotient into register Rul. If a nonzero remainder occurs, the remainder has the same sign as the dividend (original contents of register $R$ ). If $R$ is an odd value, DW forms a 64-bit register operand by extending the sign of the contents of register R 32 bit positions to the left, then divides the 64-bit register operand by the effective word, and loads the quotient into register $R$. In this case, the remainder is lost and only the contents of register $R$ are affected.

If the absolute value of the quotient cannot be correctly represented in 32 bits, fixed-point overflow occurs; in which case CC2 is set to 1 and the contents of register $R$, register Rul, CC1, CC3, and CC4 remain unchanged; otherwise, CC2 is reset to $0, ~ C C 3$ and CC4 reflect the quotient in register Rul, and CCl is unchanged.

Affected: (R), (RuI), CC2 Trap: Fixed-point overflow CC3, CC4
$(R, R u l) \div E W \longrightarrow R$ (remainder), Rul (quotient)
Condition code settings:

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

- 000 Zero quotient, no overflow.
- 001 Negative quotient, no overflow.
- 010 Positive quotient, no overflow.
- 1 - - Fixed-point overflow.

If CC2 is set to 1 and the fixed-point arithmetic trap mask $(A M)$ is a 1 , the $B P$ traps to location $X^{\prime} 43$ ' with the
original contents of register $R$, register Rul, $C C 1, C C 3$, and CC4 unchanged; otherwise, the BP executes the next instruction in sequence.

AWM ADD WORD TO MEMORY ${ }^{\dagger}$
(Word index alignment)

| * | 66 | $R$ | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

ADD WORD TO MEMORY adds the contents of register R to the effective word and stores the sum in the effective word location. The sum is stored regardless of whether or not overflow occurs.

Affected: (EWL), CC
Trap: Fixed-point overflow
$E W+(R) \longrightarrow E W L$
Condition code settings:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in EWL

-     - 00 Zero
-     - 01 Negative
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - No carry from hit nosition O
1- - Carry from bit position 0
If CC2 is set to 1 and fixed-point arithmetic trap mask (AM) is a 1 , the BP traps to location $X^{\prime} 43^{\prime}$ after the result is stored in the effective word location; otherwise, the BP executes the next instruction in sequence.

## MTB MODIFY AND TEST BYTE ${ }^{\dagger}$

(Byte index alignment)

| * | 73 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If the value of the $R$ field is nonzero, the high-order bit of the $R$ field (bit position 8 of the instruction word) is extended 4 bit positions to the left, to form a byte with bit positions 0-4 of that byte equal to the high-order bit of

[^4]the R field. This byte is added to the effective byte and then (if no memory protection violation occurs) the sum is stored in the effective byte location and the condition code is set according to the value of the resultant byte. This process allows modification of a byte by any number in the range -8 through +7 , followed by a test.

If the value of the $R$ field is zero, the effective byte is tested for being a zero or nonzero value. The condition code is set according to the result of the test, but the effective byte is not affected. A memory write-protection violation cannot occur in this case; however, a memory read-protection violation can occur.

If (I) $8_{8-11} \neq 0, E B+(\mathrm{I})_{8-11 S E} \longrightarrow E B L$ and set $C C$
If (I) $8_{-11}=0$, test byte and set CC
Condition code settings:

```
1 2 3 4 Result in EBL
- 0 0 0 Zero
- 0 1 0 Nonzero
0 - - - No carry from byte
1 - - - Carry from byte
```

If MTR :s erocuted in an interrupt or tiop lucation, the condition code is not affected and a 20 -bit reference address is used, as described under "Interrupt and Trap Entry Addressing", Chapter 2.

Note: All "Modify and Test" instructions in interrupt locations other than Counter 4 use real, or real extended, addressing mode. Counter 4 uses virtual addressing mode.

MTH MODIFY AND TEST HALFWORD ${ }^{\dagger}$
(Halfword index alignment)

| $*$ | 53 | $R$ | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 231455678 | 910111213141516171819202122232425262728293031 |  |  |

If the value of the $R$ field is nonzero, the high-order bit of the R field (bit position 8 of the instruction word) is extended 12 bit positions to the left, to form a halfword with bit positions 0-11 of that halfword equal to the high-order bit of the R field. This halfword is added to the effective halfword and then (if no memory protection violation occurs) the sum is stored in the effective halfword location and the condition code is set according to the value of the resultant halfword. The sum is stored regardless of whether or not overflow occurs. This process allows modification of a halfword by any number in the range -8 through +7 , followed by a test.

If the value of the R field is zero, the effective halfword is tested for being a zero, negative, or positive value. The condition code is set, according to the result of the test, but the effective halfword is not affected. A memory write-protection violation cannot occur in this case; however, a memory read-protection violation can occur.

Affected: CC if $(\mathrm{I})_{8-11}=0$; Trap: Fixed-pointoverflow

$$
(\mathrm{EHL}) \text { and } C C \text { if }(\mathrm{I})_{8-11} \neq 0
$$

If $(\mathrm{I})_{8-11}=0$, test halfword and set CC
If (I) $8-11 \neq 0, \mathrm{EH}+(\mathrm{I})_{8-11 S E} \longrightarrow E H L$ and set CC

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in EHL

-     - 00 Zero
-     - 01 Negative
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - No carry from halfword
1 - - Carry from halfword
If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1 , the $B P$ traps to location $X^{\prime} 43 '$ after the result is stored in the effective halfword location; otherwise, the BP executes the next instruction in sequence.

If MTH is executed in an interrupt or trap location, the condition code is not affected and a 20 -bit reference address is used, as described under "Interrupt and Trap Entry Addressing", Chapter 2.

MTW MODIFY AND TEST WORD ${ }^{\dagger}$ (Word index alignment)


If the value of the $R$ field is nonzero, the high-order bit of the R field (bit position 8 of the instruction word) is extended 28 bit positions to the left, to form a word with bit positions 0-27 of that word equal to the high-order bit

[^5]of the $R$ field. This word is added to the effective word and then (if no memory protection violation occurs) the sum is stored in the effective word location and condition code is set according to the value of the resultant word. The sum is stored regardless of whether or not overflow occurs. This process allows modification of a word by any number in the range -8 through +7 , followed by a test.

If the value of the $R$ field is zero, the effective word is tested for being a zero, negative, or positive value. The condition code is set according to the result of the test, but the effective word is not affected. A memory writeprotection violation cannot occur in this case; however, a memory read-protection violation can occur.

Affected: $C C$ if (I)8-11 $=0$; Trap: Fixed-pointoverflow (EWL) and CC if (I) $)_{8-1} \neq 0$
If $(\mathrm{I})_{8-11}=0$, test word and set CC
If (I) $8-11 \neq 0, E W+I_{8}-11 S E \longrightarrow E W L$ and set $C C$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in EWL

-     - 00 Zero
- 01 Negative
-     - 10 Positive
- 0 - - No fixed-point overflow
- 1 - - Fixed-point overflow

0 - - - No carry from word
1 - - Carry from word
If CC2 is set to 1 and the fixed-point arithmetic trap mask ( $\Delta M$ ) is a ?, the BP trops to location X'43' after the result is stored in the effective word location; otherwise, the BP executes the next instruction in sequence.

If MTW is executed in an interrupt or trap location, the condition code is not affected and a 20-bit reference address is used, as described under "Interrupt and Trap Entry Addressing", Chapter 2.

## COMPARISON INSTRUCTIONS

The comparison instivciions are:

| Instruction Name | Mnemonic |
| :--- | :--- |
| Compare Immediate | CI |
| Compare Byte | CB |


| Instruction Name |  |  | Mnemonic |
| :---: | :---: | :---: | :---: |
| Compare Halfword |  |  | CH |
| Compare Word |  |  | CW |
| Compare Doubleword |  |  | $C D$ |
| Compare Selective |  |  | CS |
| Compare With Limits in Register |  |  | CLR |
| Compare With Limits in Memory |  |  | CLM |
| All comparison instructions produce a condition code setting which is indicative of the results of the comparison, without affecting the effective operand in memory and without affecting the contents of the designated register. |  |  |  |
| CI |  |  |  |
| 0 | 21 | R |  |

COMPARE IMMEDIATE extends the sign of the value field (bit position 12) of the instruction word 12 bit positions to the left, compares the 32-bit result with the contents of register $R$ (with both operands treated as signed fixed-point quantities), and then sets the condition code according to ine resuitis of the comparison.

Affected: CC2, CC3, CC4 Trap: Nonexistent instruction if bit 0 is a 1 .
(R) : (I) $12-31 \mathrm{SE}$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of Comparison

-     - 00 Equal.
-     - 01 Register value less than immediate value.
-     - 10 Register value greater than immediate value.
- 0 - - No 1-bits compare, (R) n (I) ${ }_{12-32 S E}=0$.
- 1 - - One or more 1-bits compare,

$$
\text { (R) } n(\mathrm{I}) 12-32 S E \neq 0
$$

If Cl is indirectly addressed, it is treated as a nonexistent instruction, in which case the basic processor unconditionally aborts execution of the instruction (at the time of operation code decoding) and then traps to location $X^{\prime} 40^{\prime}$ with the condition code unchanged.

COMPARE BYTE
(Byte index alignment)

| $*$ | 71 | $R$ | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |
| $012^{3} 145^{5} 678$ | 78 |  |  |  |

COMPARE BYTE compares the contents of bit positions 24-31 of register $R$ with the effective byte (with both bytes treated as positive integer magnitudes) and sets the condition code according to the results of the comparison.

Affected: CC2, CC3, CC4
${ }^{(R)}{ }_{24-31}$ : EB

Condition code settings:
$\begin{array}{lllll}1 & 2 & 3 & 4 & \text { Result of Comparison }\end{array}$

-     - 00 Equal.
-     - 01 Register byte less than effective byte.
-     - 10 Register byte greater than effective byte.
- 0 - - No 1-bits compare, $(R)_{24-31}$ n $E B=0$.
- 1 - - One or more 1-bits compare, ${ }^{(R)}{ }_{24-31}$ n $\mathrm{EB} \neq 0$.

CH COMPARE HALFWORD
(Halfword index alignment)


COMPARE HALFWORD extends the sign of the effective halfword 16 bit positions to the left, then compares the resultant 32-bit word with the contents of register R (with both words treated as signed, fixed-point quantities) and sets the condition code according to the results of the comparison.

Affected: CC2, CC3, CC4
(R) : $E H_{S E}$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of Comparison

-     - 00 Equal.
-     - 01 Register word less than effective halfword with sign extended.
-     - 10 Register word greater than effective halfword with sign extended.
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of Comparison
- 0 - - No l-bits compare, ( R ) $n \mathrm{EH}_{S E}=0$.
- 1 - - One or more 1-bits compare, (R) $n \mathrm{EH}_{\mathrm{SE}} \neq 0$.

CW COMPARE WORD
(Word index alignment)


COMPARE WORD compares the contents of register R with the effective word, with both words treated as signed fixedpoint quantities, and sets the condition code according to the results of the comparison.

Affected: CC2, CC3, CC4
(R) : EW

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of Comparison

-     - 00 Equal.
-     - 01 Register word less than effective word.
-     - 10 Register word greater than effective word.
- 0 - - No l-bits compare, $(R) n E W=0$.
- 1 - - One or more l-bits compare, ( R ) n EW $\neq 0$.


## CD COMPARE DOUBLEWORD

| * | 11 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

COMPARE DOUBLEWORD compares the effective doubleword with the contents of registers R and Rul (with both doublewords treated as signed, fixed-point quantities) and sets the condition code according to the results of the comparison. If the $R$ field of $C D$ is an odd value, $C D$ forms a 64-bit register operand (by duplicating the contents of register R for both the 32 high-order bits and the 32 loworder bits) and compares the effective doubleword with the $64-b i t$ register operand. The condition code settings are based on the 64-bit comparison.

## Affected: CC3, CC4

(R, Rul) : ED

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of Comparison

- 00 Equal.
-     - 01 Register doubleword less than effective doubleword.
-     - 10 Register doubleword greater than effective doubleword.


## cs COMPARE SELECTIVE



COMPARE SELECTIVE compares the contents of register $R$ with the effective word in only those bit positions selected by a 1 in corresponding bit positions of register Rul (mask). The contents of register $R$ and the effective word are ignored in those bit positions designated by a 0 in corresponding bit positions of register Rul. The selected contents of register $R$ and the effective word are treated as positive integer magnitudes, and the condition code is set according to the result of the comparison. If the $R$ field of $C S$ is an odd value; CS compares the contents of register $R$ with the logical product (AND) of the effective word and the contents of register R.

Affected: CC3, CC4
If $R$ is even: ( R ) n (Rul): EW n (Rul)
If $R$ is odd: ( R ) : EW $\mathrm{n}(\mathrm{R})$
Condition code settings:
$1 \begin{array}{lll}1 & 2 & 4 \\ \text { Results of Comparison under Mask in Rul }\end{array}$

- 00 Equal.
-     - 01 Register word less than effective word.
-     - 10 Register word greater than effective word. (if $R$ is even).


## CLR COMPARE WITH LIMITS IN REGISTERS (Word index alignment)

| * | 39 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

COMPARE WITH LIMITS IN REGISTERS simultaneously compares the effective word with the contents of register $R$ and with the contents of register Ruil (with aii three words treated as signed fixed-point quantities), and sets the condition code according to the results of the comparisons.

Affected: CC
(R) : EW, (Rul) : EW

Condition code settings:

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

-     - 00 Contents of $R$ equal to effective word.
-     - 0 Contents of $R$ less than effective word.
-     - 10 Contents of $R$ greater than effective word.

0 - - Contents of Rul equal to effective word.
01 - - Contents of Rul less than effective word.
10 - - Contents of Rul greater than effective word.

CLM COMPARE WITH LIMITS IN MEMORY (Doubleword index alignment)


COMPARE WITH LIMITS IN MEMORY simultaneously compares the contents of register $R$ with the 32 high-order bits of the effective doubleword and with the 32 low-order bits of the effective doubleword, with all three words treated as 32 -bit signed quantities, and sets the condition code according to the results of the comparisons.

Affected: CC

$$
(R): E D_{0-31^{\prime}}(R): E D_{32-63}
$$

Condition code settings:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of Comparison

-     - 00 Contents of $R$ equal to most significant word, $(R)=E D_{0-31}$.
-     - 01 Contents of $R$ less than most significant word, $(R)<E D_{0-31}$
-     - 10 Contents of $R$ greater than most significant word, $(R)>E D_{0-31}$.

00 - - Contents of $R$ equal to least significant word, $(R)=E D_{32-63}$.
0 1 - - Contents of $R$ less than least significant word, (R) $<\mathrm{ED}_{32-63}$.

10 - - Contents of $R$ greater than least significant word, $(R)>E D_{32-63}$.

## LOGICAL INSTRUCTIONS

All logical operations are performed bit by corresponding bit between two operands; one operand is in register $R$ and
the other operand is the effective word. The result of the logical operation is loaded into register R.

OR ORWORD
(Word index alignment)


OR WORD logically ORs the effective word into register R. If corresponding bits of register R and the effective word are both 0 , a 0 remains in register $R$; otherwise, a 1 is placed in the corresponding bit position of register $R$. The effective word is not affected.

Affected: (R), CC3, CC4
$(R) \cup E W \longrightarrow R$, where $0 \cup 0=0,0 \cup 1=1$, $1 \cup 0=1$, $1 \cup 1=1$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in R

- 00 Zero.
-     - 01 Bit 0 of register $R$ is a 1 .
-     - 10 Bit 0 of register $R$ is a 0 and bit positions 1-31 of register $R$ contain at least one 1 .

EOR EXCLUSIVE OR WORD
(Word index alignment)


EXCLUSIVE OR WORD logically exclusive ORs the effective word into register R. If corresponding bits of register $R$ and the effective word are different, alis placed in the corresponding bit position of register $R$; if the contents of the corresponding bit positions are alike, a 0 is placed in the corresponding bit position of register $R$. The effective word is not affected.

Affected: (R), CC3, CC4
(R) (1) EW $\rightarrow R$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in R

-     - 00 Zero.
-     - 0 Bit 0 of register $R$ is al.
-     - 10 Bit 0 of register $R$ is a 0 and bit positions $1-31$ of register $R$ contain at least one 1 .

AND WORD
(Word index alignment)

| * | 4B | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

AND WORD logically ANDs the effective word into register R. If corresponding bits of register R and the effective word are both 1 , a 1 remains in register $R$; otherwise, a 0 is placed in the corresponding bit position of register $R$. The effective word is not affected.

Affected: (R), CC3, CC4
$(\mathrm{R}) \mathrm{n} \mathrm{EW} \longrightarrow \mathrm{R}$

Condition code settings:
$123 \quad 4$ Result in $R$

-     - 00 Zero.
-     - 01 Bit 0 of register $R$ is a 1 .
-     - 10 Bit 0 of register $R$ is a 0 and bit positions 1-31 of register R contain at least one 1 .


## SHIFT INSTRUCTIONS

The instruction format for logical, circular, arithmetic, and searching shift operations is:

## S SHIFT

(Word index alignment)


If neither indirect addressing nor indexing is called for in the instruction SHIFT, bit positions 21-23 of the reference address field determine the type, and bit positions 25-31 determine the direction and amount of the shift.

If only indirect addressing is called for in the instruction, bits 15-31 of the instruction are used to access the indirect word and then bits 21-23 and 25-31 of the indirect word determine the type, direction, and amount of the shift.

If only indexing is called for in the instruction, bits 21-23 of the instruction word determine the type of shift; the direction and amount of shift are determined by bits 25-31 of the instruction plus bits $25-31$ of the specified index register.

If both indirect addressing and indexing are called for in the instruction, bits 15-31 of the instruction are used to access the indirect word and then bits 21-23 of the indirect word determine the type of shift; the direction and
amount of the shift are determined by bits 25-31 of the indirect word plus bits 25-31 of the specified index register.

The effective address does not reference memory. Bit positions $15-20$ and 24 of the effective virtual address are ignored. Bit positions 21, 22, and 23 of the effective virtual address determine the type of shift, as follows:
$21 \quad 22 \quad 23$ Shift Type

000 Logical, single register
$0 \quad 0 \quad 1$ Logical, double register
010 Circular, single register
$0 \quad 1 \quad 1$ Circular, double register
100 Arithmetic, single register
101 Arithmetic, double register
110 Searching, single register
111 Searching, double register
Bit positions 25 through 31 of the effective virtual address are a shift count that determines the direction and amount of the shift. The shift count (C) is treated as a 7-bit signed binary integer, with the high-order bit (bit position 25) as the sign (negative integers are represented in two's complement form). A positive shift count causes a left shift of C bit positions. A negative shift count causes a right shift of $|C|$ bit positions. The value of $C$ is within the range: $-64 \leq C \leq+63$.

All double-register shift operations require an even value for the R field of the instruction, and treat registers R and Rul as a 64-bit register with the high-order bit (bit position 0 of register R ) as the sign for the entire register. If the $R$ field of SHIFT is an odd value and a double-register shift operation is specified, a register doubleword is formed by duplicating the contents of register $R$ for both the 32 high-order bits and the 32 low-order bits of the doubleword. The shift operation is then performed and the 32 high-order bits of the result are loaded into register $R$.

Overflow occurs (on left shifts only) whenever the value of the sign bit (bit position 0 of register R ) changes. At the completion of logical left, circular left, arithmetic left, and searching left shifts, the condition code is set as follows:

## $1 \quad 2 \quad 3 \quad 4$ Result of Shift

0 - - Even number of 1 's shifted off left end of register R.

1 - - Odd number of 1 's shifted off left end of register $\mathrm{R}^{\dagger}$.

[^6]$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of Shift

- 0 - - No overflow on left shift.
- 1 - - Overflow on left shift.
-     - 1 Searching shift terminated with $R_{0}$ equal to 1.

At the completion of right shifts, the condition code is set as follows:

1234

0 - -

Logical Shift, Single Register


If the shift count, $C$, is positive, the contents of register $R$ are shifted left $C$ places, the 0 's copied into vacated bit positions on the right. (Bits shifted past $R_{0}$ are lost.) If $C$ is negative, the contents of register $R$ are shifted right $|C|$ places, with 0 's copied into vacated bit positions on the left. (Bits shifted past $R_{31}$ are lost.)

Affected: (R), CC1, CC2

Logical Shift, Double Register

|  | 25 | $\boldsymbol{\pi}$ | X | Reference address |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 |  |  |  |  | Count |

If the shift count, $C$, is positive, the contents of registers $R$ and Rul are shifted left $C$ places, with 0 's copied into vacated bit positions on the right. Bits shifted past bit position 0 of register Rul are copied into bit position 31 of register R. (Bits shifted past $R_{0}$ are lost.) If $C$ is negative, the contents of registers $R$ and $R u l$ are shifted right $\mid \mathrm{Cl}$ places with 0 's copied into vacated bit positions on the left. Bits shifted past bit position 31 of register R are copied into bit position 0 of register Rul. (Bits shifted past Rul ${ }_{31}$ are lost.)

Affected: (R), (Rul), CC1, CC2

Circular Shift, Single Register


If the shift count, $C$, is positive, the contents of register $R$ are shifted left $C$ places. Bits shifted past bit position 0 are copied into bit position 31. (No bits are lost.) If C is negative, the contents of register $R$ are shifted right $|C|$ places. Bits shifted past bit position 31 are copied into bit position 0. (No bits are lost.)

Affected: (R), CCl, CC2

Circular Shift, Double Register

| $\mid *$ | 25 | R | X | Reference address |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Count |

If the shift count, $C$, is positive, the contents of registers $R$ and Rul are shifted left $C$ places. Bits shifted past bit position 0 of register $R$ are copied into bit position 31 of register Rul. (No bits are lost.) If C is negative, the contents of registers $R$ and Rul are shifted right $|C|$ places. Bits shifted past bit position 31 of register Rul are copied into bit position 0 of register R. (No bits are lost.)

Affected: (R), (Rul), CC1, CC2

Arithmetic Shift, Single Register


If the shift count, $C$, is positive, the contents of register $R$ are shifted left $C$ places, with 0 's copied info vacated bit positions on the right. (Bits shifted past $R_{0}$ are lost.) If $C$ is negative, the contents of register $R$ are shifted right $|C|$ places, with the contents of bit position 0 copied into vacated bit positions on the left. (Bits shifted past $R_{31}$ are lost.)

Affected: ( R , $\mathrm{CC} 1, \mathrm{CC} 2$

Arithmetic Shift, Double Register


If the shift count, $C$, is positive, the contents of register $R$ and Rul are shifted left $C$ places, with 0 's copied into vacated bit positions on the right. Bits shifted past bit position 0 of register Rul are copied into bit position 31 of register $R$. (Bits shifted past $R_{0}$ are lost.) If $C$ is negative, the contents of registers $R$ and $R u l$ are shifted right $|C|$ places, with the contents of bit position 0 of register $R$ copied into vacated bit positions on the left. Bits shifted past bit position 31 of register $R$ are copied into bit position 0 of register Rul. (Bits shifted past Rul 31 are lost.)

Affected: (R), (Rul), CCl, CC2

Searching Shift, Single Register


The searching shift is circular in either direction. If the shift count, $C$, is positive, the contents of register $R$ are shifted left $C$ bit positions or until a 1 appears in bit position 0 . If $C$ is negative, the contents are shifted right $|C|$ positions or until a 1 appears in bit position 0 . When the shift is terminated, the remaining count is stored in register 1 , which is dedicated to the searching shift instruction.

Bits 0-24 of register 1 are cleared and the remaining count is loaded into bits 25-31. If the initial contents of bit 0 is equal to 1 , then no bits are shifted by the instruction. In this case the original count in the instruction is stored in register 1.

Searching shift causing a change in bit position 0 causes CC 2 to be set to 1 . If bit position 0 is not changed during a searching shift, CC2 is cleared. CC4 is set to 1 if the shift is terminated with a 1 in bit position 0 .

Affected: (R), (R1), CC2, CC4

Searching Shift, Double Register

|  | 25 | R | X | Reference address |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| * |  |  |  | \%"\% | $1\|1\| 1 \mid \geqslant$ | Count |

The searching shift is circular in either direction. If the shift count, $C$, is positive, the contents of registers $R$ and Rul are shifted left C bit positions or until a 1 appears in bit position 0 of register $R$. If $C$ is negative, the contents are shifted right $|\mathrm{C}|$ positions or until a 1 appears in bit position 0 . When the shift is terminated, the remaining count is stored in register 1 , which is dedicated to the searching shift instruction. Bits $0-24$ of register 1 are cleared and the remaining count is loaded into bits 25-31.

Searching shift causing a change in bit position 0 causes CC 2 to be set to 1 . If bit position 0 is not changed during a searching shift, CC2 is cleared. CC4 is set to 1 if the shift is terminated with a 1 in bit position 0.

Affected: (R), (Rul), (R1), CC2, CC4

## FLOATING-POINT SHIFT

Floating-point numbers are defined in the "FloatingPoint Arithmetic Instructions" section. The format for the flocting=point shift instivetion is:

## SF SHIFT FLOATING

(Word index alignment)

|  | 24 | R | X | Reference address |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| * |  |  |  |  | Count |

If direct addressing and no indexing is called for in the instruction SHIFT FLOATING, bit position 23 of the reference address field determines the type (long or short format) of shift, and bit positions 25-31 determine the direction and amount of the shift.

If indirect addressing and no indexing is called for in the instruction, bit positions 15-31 of the instruction are used to access the indirect word and then bit positions 23 and 25-31 of the indirect word determine the type, direction, and amount of the shift.

If direct addressing and indexing are called for in the instruction, bit 23 of the reference address (not affected by subsequent indexing) determines the type of shift. Bits 25-31 of the reference address plus bits 25-31 of the specified indexed register determine the direction and amount of the shift.

If indirect addressing and indexing are called for in the instruction, bits 15-31 of the reference address are used to access the indirect word. Bit 23 of the indirect word (not affected by subsequent indexing) determines the type of shift. Bits 25-31 of the indirect address plus bits 25-31 of the specified index register determine the direction and amount of the shift.

The shift count, $C$, in bit positions 25-31 of the effective virtual address determines the amount and direction of the shift. The shift count is treated as a 7-bit signed binary integer, with the high-order bit (bit position 25) as the sign (negative integers are represented in two's complement form).

The absolute value of the shift count determines the number of hexadecimal digit positions the floating-point number is to be shifted. If the shift count is positive, the floatingpoint number is shifted left; if the count is negative, the number is shifted right.

SHIFT FLOATING loads the floating-point number from the register(s) specified by the $R$ field of the instruction into a set of internal registers. If the number is negative, it is two's complemented. A record of the original sign is retained. The floating-point number is then separated into a characteristic and a fraction, and CC1 and CC2 are both reset to 0 's.

A positive shift count produces the following left shift operations:

1. If the fraction is normalized (i.e., is less than 1 and is equal to or greater than $1 / 16$ ), or the fraction is all 0 's, CCl is set to 1 .
2. If the fraction field is ull 0 's, the entire flouting-point number is set to all 0's ("true" zero), regardless of the sign and the characteristic of the original number.
3. If the fraction is not normalized, the fraction field is shifted 1 hexadecimal digit position ( 4 bit positions) to the left and the characteristic field is decremented by 1. Vacated digit positions at the right of the fraction are filled with hexadecimal 0 's.

If the characteristic field underflows (i.e., is all l's as the result of being decremented), CC2 is set to 1 . However, if the characteristic field does not underflow, the shift process (shift fraction, and decrement characteristic) continues until the fraction is normalized, until the characteristic field underflows, or until the fraction is shifted left $C$ hexadecimal digit positions, whichever occurs first. (Any two, or all three, of the terminating conditions can occur simultaneously.)
4. At the completion of the left shift operation, the floating-point result is loaded back into the general register(s). If the number was originally negative, the two's complement of the resultant number is loaded into the general register(s).
5. The condition code settings following a floating-point left shift are as follows:

1234 Result

-     - 0 "True" zero (all 0's).
- 01 Negative.
- 10 Positive.

0 - - C digits shifted (fraction unnormalized, no characteristic underflow).

1 - - Fraction normalized (includes "true" zero).

- 1 - - Characteristic underflow.

A negative shift count produces the following right shift operations (again assuming that negative numbers are two's complemented before and after the shift operation):

1. The fraction field is shifted 1 hexadecimal digit position to the right and the characteristic field is incremented by 1. Vacated digit positions at the left are filled with hexadecimal 0 's.
2. If the characteristic field overflows (i.e., is all $0^{\prime}$ s as the result of being incremented), CC2 is set to 1 . However, if the characteristic field does not overflow, the shift process (shift fraction, and increment characteristic) continues until the characteristic field . overflows or until the fraction is shifted right $|C|$ hexadecimal digit positions, whichever occurs first. (Both terminating conditions can occur simultaneously.)
3. If the resultant fraction field is all $0^{\prime}$ 's, the entire floating-point number is set to all 0's ("true" zero), regardless of the sign and the characteristic of the original number.
4. At the completion of the right shift operation, the floating-point result is loaded back into the general register(s). If the number was originally negative, the two's complement of the resultant number is loaded into the general register(s).
5. The condition code settings following a floating-point right shift are as follows:

\section*{| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |}

-     - 00 "True" zero (all zeros).
-     - 01 Negative.

1234 Result

-     - 10 Positive.
$00-\quad|C|$ digits shifted (no characteristic overflow).

0 1 - - Characteristic overflow.

Floating Shift, Single Register


The short-format floating-point number in register $R$ is shifted according to the rules established above for floatingpoint shift operations.

Affected: (R), CC

Floating Shift, Double Register

| * | 24 | $R$ | X | Reference address |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 1 | Count |

The long-format floating-point number in registers $R$ and Rul is shifted according to the rules established above for floating-point shift operations. (If the R field of the instruction word is an odd value, a long-format floatingpoint number is generated by duplicating the contents of register $R$, and the 32 high-order bits of the result are loaded into register R.)

Affected: (R), (Rul), CC

## CONVERSION INSTRUCTIONS

The conversion instructions are:

| Instruction Name | Mnemonic |
| :--- | :--- |
| Convert by Addition | CVA |
| Convert by Subtraction | CVS |

These two conversion instructions can be used to accomplish bidirectional translation between binary code and any other weighted binary code, such as BCD.

The effective addresses of the instructions CONVERT BY ADDITION and CONVERT BY SUBTRACTION each point to the starting location of a conversion table of 32 words, containing weighted values for each bit position of register Rul. The 32 words of the conversion table are considered to be 32-bit positive quantities, and are referred
to as conversion values. The intermediate results of these instructions are accumulated in internal basic processor registers until the instruction is completed; the result is then loaded into the appropriate general register. Both instructions use a counter $(\mathrm{n})$ that is set to 0 at the beginning of the instruction execution and is incremented by 1 with each iteration, until a total of 32 iterations has been performed.

If a memory parity or protection violation trap occurs during the execution of either instruction, the instruction sequence is aborted (without having changed the contents of register $R$ or Rul) and may be restarted (at the beginning of the instruction sequence) after the trap routine is processed.

## CVA CONVERT BY ADDITION

(Word index alignment)

| * | 29 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

CONVERT BY ADDITION initially clears the internal A register and sets an internal counter ( n ) to 0 . If bit position n of register Rul contains a 1, CVA adds the $n$th conversion value (contents of the word location pointed to by the effective address plus $n$ ) to the contents of the A register, accumulates the sum in the $A$ register, and increments $n$ by 1. If bit position $n$ of register Rul contains a 0, CVA only increments $n$. If $n$ is less than 32 after being incremented, the next bit position of register Rul is examined, and the addition process continues through $n$ equal to 31 ; the result is then loaded into register $R$. If, on any iteration, the sum has exceeded the value $2^{32-1}, \mathrm{CCl}$ is set to 1 ; otherwise, CCl is reset to 0 .

Affected: (R), CCI, CC3, CC4
$0 \longrightarrow A, 0 \longrightarrow n$
If $(R \cup 1)_{n}=1$, then $(E W L+n)+(A) \longrightarrow A, n+1 \longrightarrow n$
If (Rul) ${ }_{\mathrm{n}}=0$; then $\mathrm{n}+1 \longrightarrow \mathrm{n}$
If $n<32$, repeat; otherwise, $(A) \longrightarrow R$ and continue to next instruction.

## Condition code settings:

$1 \begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in R

- 00 Zero.
-     - $0 \quad 1 \quad$ Bit 0 of register $R$ is a 1 .
-     - 10 Bit 0 of register $R$ is a 0 and bitpositions I-31 of register $R$ contain at least one 1 .

0 - - - Sum is correct (less than $2^{32}$ ).
1 - - - Sum is greater than $2^{32}-1$.

CONVERT BY SUBTRACTION (Word index alignment)

| * | 28 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

CONVERT BY SUBTRACTION loads the internal A register with the contents of register $R$, clears the internal $B$ register, and sets an internal counter ( n ) to 0 . All conversion values are considered to be 32 -bit positive quantities. If the $n$th conversion value (the contents of the word location pointed to by the effective address plus $n$ ) is equal to or less than the current contents of the A register, CVS increments $n$ by 1 , adds the two's complement of the $n$th conversion value to the contents of the A register, stores the sum in the $A$ register, and stores a 1 in bit position $n$ of the $B$ register. If the $n$th conversion value is greater than the current contents of the A register, CVS only increments $n$ by 1. If n is less than 32 after being incremented, the next conversion value is compared and the process continues through $n$ equal to 31 ; the remainder in the $A$ register is loaded into register $R$, and the converted quantity in the B register is loaded into register Rul.

Affected: (R), (Rul), CC3, CC4
$(\mathrm{R}) \longrightarrow \mathrm{A}, \mathrm{O} \longrightarrow \mathrm{B}, \mathrm{O} \longrightarrow \mathrm{n}$
If $(E W L+n) \leq(A)$ then $A-(E W L+n) \longrightarrow A$,


If $(E W L+n)>(A)$ then $n+1 \longrightarrow n$
If $n<32$, repeat; otherwise, $(A) \longrightarrow R,(B) \longrightarrow R u l$ and continue to the next instruction.

Condition code settings:
12344 Result in Rul

-     - 00 Zero.
-     - Ò ì Bittō of register Rū is a ì.
-     - 10 Bit 0 of register Rul is a 0 and bit positions 1-31 of register Rul contain at least one 1.


## FLOATING-POINT ARITHMETIC INSTRUCTIONS

The floating-point arithmetic instructions are:

| Instruction Name | Mnemonic |
| :--- | :--- |
| Floating Add Short | FAS |
| Floating Add Long | FAL |
| Floating Subtract Short | FSS |


| Instruction Name | Mnemonic |
| :--- | :--- |
| Floating Subtract Long | FSL |
| Floating Multiply Short | FMS |
| Floating Multiply Long | FML |
| Floating Divide Short | FDS |
| Floating Divide Long | FDL |

## FLOATING-POINT NUMBERS

Two number formats are accommodated for floating-point arithmetic: short and long. A short-format floating-point number consists of a sign (bit 0 ), a biased ${ }^{\dagger}$, base 16 exponent, which is called a characteristic (bits 1-7), and a six-digit hexadecimal fraction (bits 8-31). A long-format floating-point number consists of a short-format floatingpoint number followed by an additional eight hexadecimal digits of fractional significance, and occupies a doubleword memory location or an even-odd pair of general registers.

A floating-point number ( N ) has the following format:

| $+$ | Characteristic (C) | Fraction (F) |
| :---: | :---: | :---: |



A floating-point number ( $N$ ) has the following formal definition:

1. $N=F \times 16^{C-64}$ where $F=0$ or
$16^{-6} \leq|\mathrm{F}| \leq 1$ (short format) or
$16^{-14} \leq|\mathrm{F}| \leq 1$ (long format)
and $0 \leq C \leq 127$.
2. A positive floating-point number with a fraction of zero and a characteristic of zero is a "true" zero. A positive floating-point number with a fraction of zero and a nonzero characteristic is an "abnormal" zero. For floating-point multiplication and division, an abnormal zero is treated as a true zero. However,
${ }^{\dagger}$ The bias value of 4016 is added to the exponent for the purpose of making it possible to compare the absolute magnitude of two numbers, i.e., without reference to a sign bit. This manipulation effectively removes the sign bit, making each characteristic a 7-bit positive number.
for addition and subtraction, an abnormal zero is treated the same as any nonzero operand.
3. A positive floating-point number is normalized if and only if the fraction is contained in the interval

$$
1 / 16 \leq F<1
$$

4. A negative floating-point number is the two's complement of its positive representation.
5. A negative floating-point number is normalized if and only if its two's complement is a normalized positive number.

By this definition, a floating-point number of the form
1xxx xxxx $11110000 \ldots 0000$
is normalized, and a floating-point number of the form
1xxx xxxx 00000000 ... 0000
is illegal and, whenever generated by floating-point instructions, is converted to the form

$$
\text { lyyy yyyy } 11110000 \ldots 0000
$$

where $y y \ldots y$ is 1 less than $x x \ldots x$. Table 7 contains examples of floating-point numbers.

## Modes of Operation

There are four mode control bits that are used to qualify flü̆ting-puint uperütions. These anuale cuntiol bits uie identified as FR (floating round), FS (floating significance), FZ (floating zero), and FN (floating normalize); they are contained in bit positions 4, 5, 6, and 7, respectively, of the program status words (PSWs $4-7$ ).

The floating-point mode is established by setting the four floating-point mode control bits. This can be performed by any of the following instructions:

| Instruction Name | Mnemonic |
| :---: | :---: |
| Load Conditions and Floating Control | LCF |
| Load Conditions and Floating Control Immediate | LCFI |
| Load Program Status Words | LPSD |
| Exchange Program Status Words | XPSD |
| The floating-point mode control bits are stored by executing either of the following instructions: |  |
| Instruction Name | Mnemonic |
| Store Conditions and Floating Control | STCF |
| Exchange Program Status Words | XPSD |

Table 7. Floating-Point Number Representation

| Decimal Number | Short Floating-Point Format |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\pm$ | C |  | F |  |  |  |  |  | Hexadecimal Value |  |
| $+\left(16^{+63}\right)\left(1-2{ }^{-24}\right)$ | 0 | 11 | 111 | 111 | 111 | 111 | 1111 | 111 | 111 | 7 F | FFFFFF |
| $+\left(16^{+3}\right)(5 / 16)$ | 0 | 100 | 0011 | 0101 | 0000 | 0000 | 0000 | 0000 | 0000 | 43 | 500000 |
| $+\left(16^{-3}\right)(209 / 256)$ | 0 |  | 1101 | 1101 | 0001 | 0000 | 0000 | 0000 | 0000 | 3D | D10000 |
| $+\left(16^{-63}\right)(2047 / 4096)$ | 0 | 000 | 0001 | 0111 | 111 | 111 | 0000 | 0000 | 0000 | 01 | 7FF000 |
| $+\left(16^{-64}\right)(1 / 16)$ | 0 | 000 | 0000 | 0001 | 0000 | 0000 | 0000 | 0000 | 0000 | 00 | 100000 |
| 0 (called true zero) | 0 | 000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 00 | 000000 |
| $-\left(16^{-64}\right)(1 / 16)$ | 1 |  | 111 | 1111 | 0000 | 0000 | 0000 | 0000 | 0000 | FF | F00000 |
| $-\left(16^{-63}\right)(2047 / 4096)$ | 1 |  | 1110 | 1000 | 0000 | 0001 | 0000 | 0000 | 0000 | FE | 801000 |
| $-\left(16^{-3}\right)(209 / 256)$ | 1 |  | 0010 | 0010 | 111 | 0000 | 0000 | 0000 | 0000 | C2 | 2F0000 |
| $-\left(16^{+3}\right)(5 / 16)$ | 1 |  | 1100 | 1011 | 0000 | 0000 | 0000 | 0000 | 0000 | BC | B00000 |
| $-\left(16^{+63}\right)\left(1-2^{24}\right)$ | 1 |  | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0001 | 80 | 000001 |
| Special Case |  |  |  |  |  |  |  |  |  |  |  |
| $-\left(16^{\mathrm{e}}\right)(1)$ | 1 | $\bar{e}$ |  | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |  |  |
| is changed to |  |  |  |  |  |  |  |  |  |  |  |
| $-\left(16^{\mathrm{e}+1}\right)(1 / 16)$ | 1 | ${ }^{+}$ |  | 1111 | 0000 | 0000 | 0000 | 0000 | 0000 |  |  |

## floanng-point add and subtract

The floating round (FR), floating normalize (FN), floating zero (FZ), and floating significance (FS) mode control bits determine the operation of floating-point addition and subtraction (if characteristic overflow does not occur) as follows:

FR
Floating round:

Note: The floating round facility is available only in the hardware floating-point. In the absence of this feature, the floating-point subroutines offer only truncation; hence, to guarantee hardware and software identical results, FR (bit 4 of PSWs) must be zero.
$F R=0 \quad$ No rounding specified (truncation).
$F R=1 \quad$ The results of additions and subtractions are to be rounded. Each value associated with the operation (i.e., augend, addend, and intermediate result of an add) is extended by the hardware to include one guard digit. (Short-format values are extended into bit positions 32-35 and long-format values are extended into bit positions 64-67.) Contents of guard digits may be affected during prealignment, computation, or postnormalization. Rounding is performedby evaluating the guard digit of the intermediate result after any required postnormalization. If the value of the guard digit is $0-7$, the other digits are not modified. If the value of the guard digit is 8-F, the value contained within the other digits is incremented by one.

The following table shows the possible cases:

| Pre-alignment (exponents $\neq$ ) | Postnormalization |  |  |
| :---: | :---: | :---: | :---: |
|  | Scale <br> Answer <br> Left | Scale <br> Answer <br> Right | Guard Digit Action |
| 0 | 0 | 0 | (Guard digit = 0.) |
| 0 | 0 | 1 | Round on guard digit. ${ }^{\text {(1) }}$ |
| 0 | 1 | 0 | Guard digit left shifted into low end of register. ${ }^{(2)}$ |
| 0 | 1 | 1 | Not possible. |
| 1 | 0 | 0 | Round on guard digit. ${ }^{\text {(1) }}$ |
| 1 | 0 | 1 | Round on guard digit. ${ }^{(1)}$ |
| 1 | 1 | 0 | Guard digit left shifted into low end of register. ${ }^{(2)}$ |
| 1 | 1 | 1 | Not possible. |
| Notes: ${ }^{(1)}$ Increment fraction if guard digit $\geq 8$. |  |  |  |
| ${ }^{(2)}$ Contents of guard digit become zero on first left shift. |  |  |  |

Normally, there is no time penalty for the rounding operation. However, if the intermediate value is . FFFFFF and the guard digit is 8-F after postnormalization, a right alignment is done after rounding. (See the example below.)

Example
.FFFFFFF (intermediate result before rounding)
1.000000 (result after rounding and truncating not valid)
. 100000 (result after postrounding alignment)

FN Floating normalize:
$\mathrm{FN}=0 \quad$ The results of additions and subtractions are to be postnormalized. If characteristic underflow occurs, if the result is zero, or if more than two postnormalization hexadecimal shifts are required, the settings for FZ and FS determine the resultant action. If none of the above conditions occurs, the condition code is set to 0010 if the result is positive, or to 0001 if the result is negative.

FN = 1 Inhibit postnormalization of the result of additions and subtractions. The settings of FZ
and FS have no effect on the instruction operation. If the result is zero, the result is set to "true" zero and the condition code is set to 0000 . If the result is positive, the condition code is set to 0010. If the result is negative, the condition code is set to 0001 .

FZ $=0$ If the final result of $c$ addition or subtraction operation cannot be expressed in normalized form because of the characteristic being reduced below zero, underflow has occurred, in which case the result is set equal to "true" zero and the condition code is set to 1100 . (Exception: if a trap results from significance checking with FS $=1$ and $F Z=0$, an underflow generated in the process of postnormalizing is ignored.)

FZ $=1$ Characteristic underflow causes the basic processor to trap to location $X^{\prime} 44$ ' with the contents of the general registers unchanged. If the result is positive, the condition code is set to 1110. If the result is negative, the condition code is set to 1101 .

FS Floating significance: (applies only if $\mathrm{FN}=0$ )

FS $=0 \quad$ Inhibit significance trap. If the result of an addition or subtraction is zero, the result is set equal to "true" zero, the condition code is set to 1000, and the basic processor executes the next instruction in sequence. If more than two hexadecimal places of postnormalization shifting are required and characteristic underflow does not occur, the condition code is set to 1010 if the result is positive, or to 1001 if the result is negative; then, the basic processor executes the next instruction in sequence. (Exception: if characteristic underflow occurs with $F S=0$, FZ determines the resultant action.)
$F S=1$ The basic processor traps to location $X^{\prime} 44^{\prime}$ if more than two hexadecimal places of postnormalization shifting are required or if the result is zero. The condition code is set to 1000 if the result is zero, to 1010 if the result is positive, or to 1001 if the result is negative; however, the contents of the general registers are not changed. (Exception: if a trap results from characteristic underflow with $F Z=1$, the results of significance testing are ignored.)

If characteristic overflow occurs, the basic processor always traps to location X'44' with the general registers unchanged and the condition code set to 0110 if the result is positive, or to 0101 if the result is negative.

## FLOATING-POINT MULTIPLY AND DIVIDE

The floating round (FR) and floating zero (FZ) mode control bits determine the operation of floating-point multiplication and division (if characteristic overflow does not occur and division by zero is not attempted) as follows:

FR Floating round:
$F R=0 \quad$ No rounding specified.
$F R=1 \quad$ The results of floating multiplication and division instructions are to be rounded. For multiply or divide operations, a normalized product or quotient is produced, appended by a guard digit. This will be an absolute value.

Note: The example above (under "Floating-Point Add and Subtract") is not possible for multiply and divide. Therefore, there is never a time penalty for rounding.

FZ Floating zero:
$F Z=0 \quad$ If the final result of a multiplication or division operation cannot be expressed in normalized form because of the characteristic being reduced below zero, underflow has occurred. If underflow occurs, the result is set equal to "true" zero and the condition code is set to 1100. If underflow does not occur, the condition code is set to 0010 if the result is positive, to 0001 if the result is negative, or to 0000 if the result is zero.

FZ $=1$ Underflow causes the basic processor to trap to location X'44' with the contents of the general registers unchanged. The condition code is set to 1110 if the result is positive, or to 1101 if the result is negative. If underflow does not occur, the resultant action is the same as that for $F Z=0$.

If the divisor is zero in a floating-point division; the basic processor always traps to location $X^{\prime} 44$ ' with the general registers unchanged and the condition code set to 0100 . If characteristic overflow occurs, the basic processor always traps to location $X^{\prime} 44$ ' with the general registers unchanged and the condition code set to 0110 if the result is positive, or to 0101 if the result is negative.

## CONDITION CODES FOR FLOATING-POINT INSTRUCTIONS

The condition code settings for floating-point instructions are summarized in Table 8. The following provisions apply to all floating-point instructions:

1. Undeflow and overflow detection apply to the final characteristic, not to any "intermediate" value.
2. If a floating-point operation results in a trap, the original contents of all general registers remain unchanged.
3. All shifting, truncation, and rounding are performed on absolute magnitudes. If the fraction is negative, then the two's complement is formed after shifting or truncation.

## FAS FLOATING ADD SHORT <br> (Word index alignment)

| * | 3D | $R$ | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |

The effective word and the contents of register $R$ are loaded into a set of internal registers and a low-order hexadecimal zero (guard digit) is appended to both fractions, extending them to seven hexadecimal digits each. FAS then forms the floating-point sum of the two numbers. (See "FR Floating round" under "Floating-Point Add and Subtract", if rounding applies.) If no floating-point arithmetic fault occurs, the sum is loaded into register $R$ as a short-format floatingpoint number.

Affected: (R), CC Trap: Floating-point arith-
$(\mathrm{R})+\mathrm{EW} \longrightarrow \mathrm{R}$

FAL FLOATING ADD LONG
(Doubleword index alignment)

| * | 1D | R | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |

The effective doubleword and contents of registers R and Rul are loaded into a set of internal registers.

The operation of FAL is identical to that of FLOATING ADD SHORT (FAS) except that the fractions to be added are each 14 hexadecimal digits long, guard digits are appended to the fractions only if rounding is specified, and $R$ must be an even value for correct results. If no floatingpoint arithmetic fault occurs, the sum is loaded into registers $R$ and Rul as a long-format floating-point number.

Affected: (R), (RuI), CC Trap: Floating-point arith-
$(R, R u l)+E D \longrightarrow R, R u I$ metic fault, instruction exception

Table 8. Condition Code Settings for Floating-Point Instructions


The $R$ field of the FAL instruction must be an even value for proper operation of the instruction; if the $R$ field of FAL is an odd value, the instruction traps to location $X^{\prime} 4 D^{\prime}$, instruction exception trap.

FSS FLOATING SUBTRACT SHORT (Word index alignment)


The effective word and the contents of register $R$ are loaded into a set of internal registers.

FLOATING SUBTRACT SHORT forms the two's complement of the effective word and then operates identically to FLOATING ADD SHORT (FAS). If no floating-point arithmetic fault occurs, the difference is loaded into register $R$ as a short-format floating-point number.

Affected: (R), CC Trap: Floating-point arithmetic fault

FSL FLOATING SUBTRACT LONG (Doubleword index alignment)

| * | 1 C | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

The effective doubleword and the contents of registers $R$ and Rul are loaded into a set of internal registers.
-FLOATING SUBTRACT LONG forms the two's complement of the effective doubleword and then operates identically to FLOATING ADD LONG (FAL). If no floatingpoint arithmetic fault occurs, the difference is loaded into registers $R$ and Rul as a long-format floating-point number.

Affected: (R), (Rul), CC Trap: Floating-point arithmetic fault, instruc$(R, R \cup I)-E D \longrightarrow R, R u I \quad$ tion exception

The $R$ field of the FSL instruction must be an even value for proper operation of the instruction; if the R field of FSL is an odd value, the instruction traps to location $\mathrm{X}^{\prime} 4 \mathrm{D}^{\prime}$, instruction exception trap.
(Word index alignment)

| * | 3F | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

The effective word (multiplier) and the contents of register $R$ (multiplicand) are loaded into a set of internal registers, and both numbers are then prenormalized (if necessary). A normalized 6-digit product is produced, appended by a guard digit. If FR equals 1, and the guard digit contains 8 or greater, the fraction is incremented. If no floatingpoint arithmetic fault occurs, the product is loaded into register $R$ as a short-format floating-point number.

Affected: (R), CC
Trap: Floating-point arithmetic fault
$(R) \times E W \longrightarrow R$

## FML FLOATING MULTIPLY LONG

(Doubleword index alignment)

| * | 1F | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

The effective doubleword (multiplier) and the contents of registers $R$ and Rul (multiplicand) are loaded into a set of internal registers. (FLOATING MULTIPLY LONG then operates identically to FLOATING MULTIPLY SHORT (FMS), except that the operands are each 14 hexadecimal digits long. R must be an even value for correct results. If no floating-point arithmetic fault occurs, the product is loaded into registers $R$ and Rul as a long-format floatingpoint number.

Affected: (R), (Rul), CC
Trap: Floating-point arithmetic fault, instruction exception
$(R, R u I) \times E D \longrightarrow R, R u l$
The $R$ field of the FML instruction must be an even value for proper operation of the instruction; if the $R$ field of FML is an odd value, the instruction traps to location $X^{\prime} 4 D^{\prime}$, instruction exception trap.

FDS FLOATING DIVIDE SHORT
(Word index alignment)


The effective word (divisor) and the contents of register $R$ (dividend) are loaded into a set of internal registers and both numbers are then prenormalized (if necessary). A normalized 6-digit quotient is produced, appended by a guard digit. If FR equals 1 , and the guard digit contains 8 or greater, the fraction is incremented. If no floatingpoint arithmetic fault occurs, the quotient is loaded into register $R$ as a short-format floating-point number.
Affected: (R), CC
$(R) \div E W \longrightarrow R$
Trap: Floating-point arithmetic fault

| * | IE | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

The effective doubleword (divisor) and the contents of registers R and Rul (dividend) are loaded into a set of internal registers. FLOATING DIVIDE LONG then operates identically to FLOATING DIVIDE SHORT (FDS), except that the operands are each 14 hexadecimal digits long. R must be an even value for correct results. If no floatingpoint arithmetic fault occurs, the quotient is loaded into registers $R$ and Rul as a long-format floating-point number.

Affected: (R), (Rul), CC
$(R, R u I) \div E D \longrightarrow R, R u I$
Trap: Floating-point arithmetic fault, instruction exception

The $R$ field of the FDL instruction must be an even value for proper operation of the instruction; if the $R$ field of FDL is an odd value, the instruction traps to location $X^{\prime} 4 D^{\prime}$ instruction exception trap.

## DECIMAL INSTRUCTIONS

The following instructions comprise the decimal instruction set:

| Instruction Name | Mnemonic |
| :--- | :--- |
| Decimal Load | DL |
| Decimal Store | DST |
| Decimal Add | DA |
| Decimal Subtract | DS |
| Decimal Multiply | DM |
| Decimal Divide | DD |
| Decimal Compare | DC |
| Decimal Shift Arithmetic | DSA |
| Pack Decimal Digits | UNPK |
| Unpack Decimal Digits | EBS |
| Edit Byte String (described under |  |
| "Byte-String Instructions") |  |

## PACKED DECIMAL NUMBERS

All decimal arithmetic instructions operate on packed decimal numbers, each consisting of from 1 to 31 decimal digits ${ }^{\dagger}$ (in absolute form) plus a decimal sign. A decimal digit is a 4-bit code in the range 0000 through 1001, where $0000=0,0001=1,0010=2,0011=3,0100=4$, $0101=5,0110=6, \quad 0111=7, \quad 1000=8$, and $1001=9$. A positive decimal sign is a 4-bit code of the form: 1010( $\left.\mathrm{X}^{\prime} \mathrm{A}^{\prime}\right)$, $1100\left(\mathrm{X}^{\prime} \mathrm{C}^{\prime}\right)$, $1110\left(\mathrm{X}^{\prime} \mathrm{E}^{\prime}\right)$, or $1111\left(\mathrm{X}^{\prime} \mathrm{F}^{\prime}\right)$. A negative decimal sign is a 4-bit code of the form: $1011\left(X^{\prime} \mathrm{B}^{\prime}\right)$, or $1101\left(X^{\prime} D^{\prime}\right)$. However, the decimal sign codes generated for the result of a decimal instruction are: 1100 ( $\mathrm{X}^{\prime} \mathrm{C}^{\prime}$ ) for positive results, and 1101 ( $X^{\prime} D^{\prime}$ ) for negative results. The format of packed decimal numbers is:


For the decimal arithmetic instructions, a packed decimal number must occupy an integral number ( 1 through 16) of consecutive bytes. Thus, a decimal number must contain an odd number of decimal digits, the high-order digit (zero or nonzero) of the number must be in bit positions 0-3 of the first byte, the decimal sign must be in bit positions 4-7 of the last byte, and all decimal digits and the decimal sign must be 4-bit codes of the form described above.

## ZONED DECIMAL NUMBERS

In zoned decimal format, a single decimal digit is contained
 the byte are referred to as the "zone" of the decimal digit. A zoned decimal number consists of from 1 to 31 bytes, with the decimal sign appearing as the zone for the last byte, as follows:


The sign format is EBCDIC and the zones are 1111.
A decimal number can be converted from zoned to packed format by means of the instruction PACK DECIMAL DIGITS. A decimal number can be converted from packed to zoned format by means of the instruction UNPACK DECIMAL DIGITS.

## DECIMAL ACCUMULATOR

All decimal arithmetic instructions imply the use of registers 12 through 15 of the current register block as the

[^7]decimal accumulator, and registers 12 through 15 are treated as a single 16-byte register. The entire decimal accumulator is used in every decimal arithmetic instruction.

## DECIMAL INSTRUCTION FORMAT

The general format of a decimal instruction is as follows:

| Operation code | L | X | Reference address |
| :---: | :---: | :---: | :---: |

The indirect address bit (position 0), the operation code (positions 1-7), the index field (12-14), and the reference address field (15-31) all have the same functions for the decimal instructions as they do for any other byte-addressing instruction. However, bit positions $8-11$ of the instruction word do not refer to a general register; instead, the contents of this field (designated by the character "L") designate the length, in bytes, of a packed decimal number. (If $L=0$, a length of 16 bytes is assumed.)

## ILLEGAL DIGIT AND SIGN DETECTION

Prior to executing any decimal instruction, the basic processor checks all decimal operands for the presence of illegal decimal digits or illegal decimal signs. For all decimal arithmetic instructions, an illegal decimal digit is a sign code (i.e., in the range $X^{\prime} A^{\prime}$ through $X^{\prime} F^{\prime}$ ) that appears anywhere except in bit positions $4-7$ of the least significant byte (the sign position) of the packed decimal number; an illegal decimal sign is a digit code (i.e., in the range $X^{\prime} 0^{\prime}$ through $X^{\prime} 9^{\prime}$ ) that appears in the sign position of the packed decimal number.

For the instructions DECIMAL MULTIPLY and DECIMAL DIVIDE, the illegal sign and digit check also includes a check for an illegal L field in the instruction. Illegal L fields are $X^{\prime} 0^{\prime}$ and the range $X^{\prime} 9^{\prime}$ to $X^{\prime} F^{\prime}$.

For the DECIMAL MULTIPLY instruction, only registers R14 and R15 are checked for illegal digits. The original contents of R12 and R13 are ignored and are presumed to be zeros.

If an illegal digit or sign is detected, the basic processor unconditionally aborts the execution of the instruction (at the time that the illegal digit or sign is detected), sets CC 1 to 1 and resets CC 2 to 0 . If the decimal arithmetic fault trap mask (bit position 10 of the program status words) is a 0 , the basic processor then executes the next instruction in sequence; however, if the decimal arithmetic fault trap mask is a 1 , the basic processor traps to location $X^{\prime} 45^{\prime}$. In either case, the contents of the decimal accumulator, the effective decimal operand, CC3, and CC4 remain unchanged.

## OVERFLOW DETECTION

Arithmetic overflow can occur during execution of the following decimal instructions:

DECIMALADD. Overflow occurs when the sum of the two decimal numbers exceeds the 31 -digit capacity of the decimal accumulator $\left(+10^{31}-1\right.$ to $\left.-10^{31}+1\right)$.

DECIMAL SUBTRACT. Overflow occurs when the difference between the two decimal numbers exceeds the 31-digit capacity of the decimal accumulator.

DECIMAL DIVIDE. Overflow occurs either when the divisor is zero, or when the dividend is greater than 14 digits in length and the absolute value of the significant digits to the left of the 15 th digit position (counting from the right) is greater than or equal to the absolute value of the divisor.

If arithmetic overflow occurs during execution of DECIMAL ADD, DECIMAL SUBTRACT, or DECIMAL DIVIDE, the basic processor unconditionally aborts execution of the instruction (at the time of overflow detection), resets CCl to 0 , and sets CC2 to 1 . Then, if the decimal arithmetic fault trap mask (PSWs10) is a 1, the basic processor traps to location $\mathrm{X}^{\prime} 45$ '; if the decimal arithmetic fault trap mask is a 0 , the basic processor executes the next instruction in sequence. In either case, the contents of the decimal accumulator, memory storage, CC3, and CC4 remain unchanged.

## DECIMAL INSTRUCTION NOMENCLATURE

For the purpose of abbreviating the instruction descriptions to follow, the symbolic term "DECA" is used to represent the decimal accumulator, and the symbolic term "EDO" is used to represent the effective decimal operand of the instruction. For the instructions DECIMAL LOAD, DECIMAL ADD, DECIMALSUBTRACT, DECIMALMULTIPLY, DECIMAL DIVIDE, and DECIMAL COMPARE, the effective decimal operand is a packed decimal number that is "L" bytes in length, where $L$ is the numeric value of bit positions $8-11$ of the instruction word, and a value of 0 for $L$ designates 16 bytes. The effective byte addresses of these instructions point to the byte location that contains the most significant byte (high-order digits) of the decimal number, and the effective bytc address plus $L-1$ (where $L=0=16$ ) points to the least significant byte (low-order digit and sign) of the decimal number. Thus, for these instructions, the effective decimal operand (EDO) is the contents of the byte string that begins with the effective byte location, is $L$ bytes in length, and ends with the effective byte location plus L-1.

## CONDITION CODE SETTINGS

All decimal instructions provide condition code settings, using CCl to indicate whether or not an illegal digit or sign has been detected, and CC2 to indicate whether or not overflow has occurred. Most (but not all) of the decimal instructions provide condition code settings, using CC3 and CC4 to indicate whether the decimal number in the decimal accumulator is zero, negative, or positive, as follows:

## CC3 CC4 Result in DECA

00
Zero - the decimal accumulator contains a positive or negative decimal sign code in the four low-order bit positions; the remainder of the decimal accumulator contains all 0 's.

01 Negative - the decimal accumulator contains a negative decimal sign code in the four low-order bit positions; the remainder of the decimal accumulator contains at least one nonzero decimal digit.

10 Positive - the decimal accumulator contains a positive decimal sign code in the four loworder bit positions; the remainder of the decimal accumulator contains at least one nonzero decimal digit.

## DL DECIMAL LOAD

(Byte index alignment)

| * | 7E | L | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If no illegal digit or sign is detected in the effective decimal operand, DECIMAL LOAD expands the effective decimal operand to 16 bytes ( 31 digits + sign) by appending high-order 0 's, and then loads the expanded decimal number into the decimal accumulator. If the result in the decimal accumulator is zero, the converted sign remains unchanged.


DECIMAL STORE
(Byte index alignment)

| * | 7F | L | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If no illegal digit or sign is detected in the decimal accumulator, DECIMAL STORE stores the low-order L bytes of the decimal accumulator into memory from the effective byte location to the effective byte location plus L-I. If the decimal accumulator contains more significant information than is actually stored (i.e., at least one nonzero digit was not stored), CC2 is set to 1 ; orherwise, CC2 is reset to 0 . If the result in memory is zero, the converted sign remains unchanged.

Affected: (EBL to EBL $+\mathrm{L}-1$ ), Trap: Decimal arithmetic $\mathrm{CC1}, \mathrm{CC} 2$
(DECA) low-order bytes $\longrightarrow E B L$ to $E B L+L-I$

Condition code settings:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of DST

10 - - Illegal digit or sign detected, instruction aborted

00 - - All significant information stored

0 1- - Some significant informarion noí stored

No illegal digit or illegal sign detected, instruction completed

DA DECIMAL ADD
(Byte index alignment)


If no illegal digit or sign is detected in the effective decimal operand or in the decimal accumulator, DECIMAL ADD algebraically adds the decimal number to the contents of the decimal accumulator. If the result in the decimal accumulator is zero, the resulting sign is forced to the positive form.

Overflow occurs if the sum exceeds the capacity of the decimal accumulator (i.e., if the absolute value of the sum is equal to or greater than $10^{31}$ ), in which case CC1 is reset to $0, \mathrm{CC} 2$ is set to 1 , and the instruction aborted with the previous contents of the decimal accumulator, CC3 and CC4 unchanged.

Affected: (DECA), CC
Trap: Decimal arithmetic

Condition code settings:

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

$\left.\begin{array}{cc}10- & \begin{array}{l}\text { Illegal digit or } \\ \text { sign detected }\end{array} \\ 01-\text { Overflow }\end{array}\right\}$
Instruction aborted
$0 \quad 0 \quad 0 \quad 0 \quad$ Zero
$\begin{array}{llll}0 & 0 & 0 & 1\end{array}$ Negative
$\begin{array}{llll}0 & 0 & 1 & 0 \\ P o s i t i v e\end{array}$
No illegal digit or sign detected, no overflow, instruction completed

DS DECIMAL SUBTRACT
(Byte index alignment)

| * | 78 | L | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If no illegal digit or sign is detected in the effective decimal operand or in the decimal accumulator, DECIMAL SUBTRACT algebraically subtracts the decimal number from the contents of the decimal accumulator, and then loads the difference into the decimal accumulator. If the result in the decimal accumulator is zero, the resulting sign is forced to the positive form.

Overflow occurs if the difference exceeds the capacity of the decimal accumulator (i.e., if the absolute value of the difference is equal to or greater than $10^{31}$ ), in which case $\mathrm{CC1}$ is reset to $0, \mathrm{CC} 2$ is set to 1 , and the instruction is aborted with the contents of the previous decimal accumulator, CC3 and CC4 unchanged.

Affected: (DECA), CC Trap: Decimal arithmetic
(DECA) - EDO $\longrightarrow$ DECA

Condition code settings:
$123 \quad 4$ Result in DECA
$\left.\begin{array}{c}10-\quad \begin{array}{l}\text { Illegal digit or } \\ \text { sign detected }\end{array} \\ 01-\text { Overflow }\end{array}\right\}$

Instruction aborted
$\begin{array}{lllll}0 & 0 & 0 & 0 & \text { Zero }\end{array}$
$\begin{array}{llll}0 & 0 & 0 & 1\end{array}$ Negative

0010 Positive

No illegal digit or sign detected, no overflow, instruction completed
(Byte index alignment, continue after interrupt)

| * | 7B | L | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If no illegal digit or sign is detected in the effective decimal operand or decimal accumulator, DECIMAL MULTIPLY multiplies the effective decimal operand (multiplicand) by the contents of the decimal accumulator registers R14 and R15 (multiplier) and then loads the product into the entire decimal accumulator. If the result in the decimal accumulator is zero, the resulting sign is forced to the positive form.
Affected: (DECA), CC
Trap: Decimal arithmetic
(DECA) $\times$ EDO $\longrightarrow$ DECA
Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result in DECA
10 - - Illegal digit or sign detected, instruction
\(\left.\begin{array}{lllll}0 \& 0 \& 0 \& 0 \& Zero <br>
0 \& 0 \& 0 \& 1 \& Negative <br>

0 \& 0 \& 1 \& 0 \& Positive\end{array}\right\}\)| No illegal digit or sign |
| :--- |
| detected, instruction |
| completed |

## DD DECIMAL DIVIDE

(Byte index alignment, continue after interrupt)

| * | 7A | L | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If there is no illegal digit or sign in the effective decimal operand and if there is at least one decimal sign in the decimal accumulator, DECIMAL DIVIDE divides the contents of the decimal accumulator (dividend) by the effective decimal operand (divisor). Then, if no overflow has occurred, the basic processor loads the quotient ( 15 decimal digits plus sign) into the eight low-order bytes of the decimal accumulator (registers 14 and 15), and loads the remainder (also 15 decimal digits plus sign) into the eight high-order bytes of the decimal accumulator (registers 12 and 13). The sign of the remainder is the same as that of the original dividend. If the quotient is zero, the sign of the quotient is forced to the positive form.

Overflow occurs if any of the following conditions are not satisfied before the initial execution of DECIMAL DIVIDE:

1. The divisor must not be zero.
2. If the length of the dividend is greater than 15 decimal digits, the absolute value of the significant digits to the left of the 15th digit position (i.e., those digits in registers 12 and 13 ) must be less than the absolute value of the divisor.

Affected: (DECA), CC
Trap: Decimal arithmetic
$(D E C A) \div E D O \longrightarrow D E C A$

Condition code settings:

1 | 1 | 3 | 4 |
| :--- | :--- | :--- | :--- |

$\left.\begin{array}{ccc}1 & 0- & \begin{array}{l}\text { Illegal digit or } \\ \text { sign detected }\end{array} \\ 01 & -\quad \text { Overflow }\end{array}\right\}$ Instruction aborted
$\left.\begin{array}{lllll}0 & 0 & 0 & 0 & \text { Zero quotient } \\ 0 & 0 & 0 & 1 & \text { Negative quotient } \\ 0 & 0 & 1 & 0 & \text { Positive quotient }\end{array}\right\}$

No illegal digit or sign detected, no overflow, instruction completed

DC DECIMAL COMPARE
(Byte index alignment)

| * | 7D | L | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If there is no illegal digit or sign in the effective decimal operand or in the decimal accumulator, DECIMAL COMPARE expands the effective decimal operand to 16 bytes ( 31 digits plus sign) by appending high-order 0 's, algebraically compares the expanded decimal number to the contents of the entire decimal accumulator, and sets CC3 and CC4 according to the result of the comparison (a positive zero compares equal to a negative zero).

Affected: CC Trap: Decimal arithmetic
(DECA) : EDO
Condition code settings:

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

10 - - Illegal digit or sign detected, instruction aborted
$\left.\begin{array}{lllll}0 & 0 & 0 & 0 & \text { (DECA) equals EDO } \\ 0 & 0 & 0 & 1 & \text { (DECA) less than EDO } \\ 0 & 0 & 1 & 0 & \begin{array}{l}\text { (DECA) greater than } \\ \end{array}\end{array}\right\}$

No illegal digit or sign detected, instruction completed

DSA DECIMAL SHIFT ARITHMETIC

## (Byte index alignment)



If no illegal digit or sign is derecred in tine decimal accumulator, DECIMAL SHIFT ARITHMETIC arithmetically shifts the contents of the decimal accumulator (excluding the decimal sign), with the direction and amount of the shift determined by the effective virtual address of the instruction. If the result in the decimal accumulator is zero, the resulting sign remains unchanged.

If no indirect addressing or indexing is used with DSA, the shift count $C$ is the confents of bit positions 16-31 of the instruction word. If only indirect addressing is used with DSA, the shift count is the contents of bit positions 16-31 of the word pointed to by the indirect address in the instruction word. If indexing only is used with DSA, the shift count is the contents of bit positions 16-31 of the instruction word plus the contents of bit positions 14-29 of the designated index register (bits $0-13,30$, and 31 of the index are ignored). If indirect addressing and indexing are both used with DSA, the shift count is the sum of the contents of bit positions 16-31 of the word pointed to by the indirect address and the contents of bit positions 14-29 of the designated index register.

The shift count, $C$, is treated as a 16 -bit signed binary integer, with negative integers in two's complement form. If the shift count is positive, the contents of the decimal accumulator are shifted left $C$ decimal digit positions; if the shift count is negative, the contents of the decimal accumulator are shifted right -C decimal digit positions. In either case, the decimal sign is not shifted, vacated decimal digit positions are filled with $0^{1} s$, and any digits shifted out of the decimal accumulator are lost. Although the range of possible values for $C$ is $2-15 \leq C \leq 215-1$. a shift count greater than +31 or less than -31 is interpreted as a shift count of exactly +31 or $\mathbf{- 3 1}$.

If any nonzero decimal digit is shifted out of the decimal accumulator during a left shift, CC2 is set to 1 ; otherwise, . CC2 is reset to 0 . CC2 is unconditionally reset to 0 at the completion of a right shift.


Condition code settings:

\section*{| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |}

$10-l_{\text {aborted }}$ Illegal digit or sign detected, instruction

PACK PACK DECIMAL DIGITS
(Byte index alignment)


PACK DECIMAL DIGITS converts the effective decimal operand (assumed to be in zoned format) into a packed decimal number and, if necessary, appends sufficient highorder 0 's to produce a decimal number that is 16 bytes (31 decimal digits plus sign) in length. The zone (bits 0-3) of the low-order digit of the effective decimal operand is used to select the sign code for the packed decimal number; all other zones are ignored in formatting the packed decimal number. If no illegal digit or sign appears in the packed decimal number, it is then loaded into the decimal accumulator. If the result in the decimal accumulator is zero, the resulting sign remains unchanged.

The $L$ field of this instruction specifies the length, in bytes, of the resultant packed decimal number in the decimal accumulator; therefore, the length of the effective decimal operand is $2 \mathrm{~L}-1$ bytes (where $\mathrm{L}=0$ implies a length of 31 bytes for the effective decimal operand).

Affected: (DECA), CC Trap: Decimal arithmetic
packed $(E B L$ to $E B L+2 L-2) \longrightarrow D E C A$

## Condition code settings:

## 1234 Result in DECA

1 0 - - Illegal digit or sign detected, instruction aborted

| 0 | 0 | 0 | 0 | Zero |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 1 | Negative |
| 0 | 0 | 1 | 0 | Positive |

No illegal digit or sign detected, instruction completed

Example 1, $L=6$ :

|  |  | Before execution | After executio |
| :---: | :---: | :---: | :---: |
| EDO | $=$ | X'F0F1F2F3 | X'F0F1F2F3 |
|  |  | F4F5F6F7 | F4F5F6F7 |
|  |  | F8F9F0 ${ }^{1}$ | F8F9F0' |
| (DECA) | $=$ | $x x x x x x y x$ | X'00000000 |
|  |  | $x \times x \times x \times x \times$ | 00000000 |
|  |  | x $x \times x \times x \times x \times$ | 00000123 |
|  |  | x $x$ x $x$ x $x$ x | 4567890' ${ }^{\prime}$ |
| CC | $=$ | xxxx | 0010 |


|  | Before execution | After execution |
| :---: | :---: | :---: |
| EDO | $=\mathrm{X}^{\prime} 000938 \mathrm{~F} 7$ | X'000938F7 |
|  | E655B483 | E655B483 |
|  | 02F1B0' | 02F1B0' |
| (DECA) | $=x x x x x x x x$ | X'00000000 |
|  | x $\times$ x $\times$ x $\times$ x $\times$ x | 00000000 |
|  | xxxxxxxx | 00000987 |
|  | x $x \times x \times x \times x \times$ | $6543210{ }^{\text {' }}$ |
| CC | $=x x x x$ | 0001 |

UNPK UNPACK DECIMAL DIGITS
(Byte index alignment, continue after interrupt)

| * | 77 | L | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

If no illegal digit or sign is detected in the decimal accumulator (assumed to be in packed decimal format), UNPACK DECIMAL DIGITS converts the contents of the low-order L bytes of the decimal accumulator to zoned decimal format and stores the result, as a byte string, from the effective byte location to the effective byte location plus 2L-2. The contents of the four low-order bit positions of the decimal accumulator are used to select the sign code for the last digit of the string; for all other digits, the zones are 1111 ( $\mathrm{X}^{\prime} \mathrm{F}^{\prime}$ ). The contents of the decimal accumulator remain unchanged, and only $2 \mathrm{~L}-1$ bytes of memory are altered. If the decimal accumulator contains more significant information than is actually unpacked and stored, CC2 is set to 1 ; otherwise, CC2 is reset to 0 . If the result in memory is zero, the resulting sign remains unchanged.

Affected: (EBL to EBL $+2 \mathrm{~L}-2$ ), Trap: Decimal arithmetic CC1, CC2
zoned $(D E C A) \longrightarrow E B L$ to $E B L+2 L-2$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of UNPK
10 - - Illegal digit or sign detected, instruction aborted

0 0 - All significant information zoned and stored

0 1 - - Some significant information not zoned and stored

No illegal digit or sign detected, instruction completed

Example 1, L = 10:


Example 2, L = 8:

|  |  | Before execution | After execution |
| :---: | :---: | :---: | :---: |
| (DECA) | $=$ | X'00000000 | X'00000000 |
|  |  | 23000000 | 23000000 |
|  |  | 10001234 | 10001234 |
|  |  | 0012345C' | $0012345 C^{\prime}$ |
| EDO | $=$ | xxxxxxxx | X'FIFOFOFO |
|  |  |  | F1F2F3F4 |
|  |  | xxxxxxxx | FOFOF1F2 |
|  |  | xxxxxx | F3F4C5' |
| CC | $=$ | xxxx | 01xx |

Example 3, L=4:

|  |  | Before execution | After execution |
| :---: | :---: | :---: | :---: |
| (DECA) | $=$ | X'00001001 | X'00001001 |
|  |  | 00001002 | 00001002 |
|  |  | 00001003 | 00001003 |
|  |  | 0001004F' | $0001004 \mathrm{~F}^{\prime}$ |
| EDO | $=$ | $x x x x x x x x$ | X'FOFOFOF1 |
|  |  | x $x \times x \times x \times x \times$ | FOFOC4' |
| CC | $=$ | xxxx | 01xx |

## BYTE-STRING INSTRUCTIONS

Five instructions provide for the manipulation of strings of consecutive bytes. The byte-string instructions and their mnemonic codes are as follows:

| Instruction Name | Mnemonic |
| :--- | :--- |
| Move Byte String | MBS |
| Compare Byte String | CBS |

Instruction Name
Translate Byte String
Translate and Test Byte String
Edit Byte String

These instructions are in the immediate byte operand class and are memory-to-memory operations. These operations are under the control of information that must be loaded into certain general registers before the instruction is executed. Except for the MOVE BYTE STRING instruction, which proceeds four bytes at a time under certain conditions, a byte string instruction proceeds one byte at a time and may be interrupted after any individual byte operation. Upon return, execution resumes from the point of interruption.

The general format for the information in the instruction word and in the general registers is as follows:

Instruction word:

| 0 | Operation code | R | Displacement |
| :---: | :---: | :---: | :---: |

## Contents of register R :



## Contents of register Rul:

| Count | 毋. Destination address |
| :---: | :---: |
|  |  |
| Designation | Function |
| Operation | The 7-bit operation code of the instruction. (If any byte-string instruction is indirectly addressed, the basic processor traps to location $X^{\prime} 40^{\prime}$ at the time of operation code decoding.) |
| R | The 4-bit field that identifies register $R$ of the current general register block. |
| Displacement | A 20-bit field that contains a signed byte displacement value, used to form an effective byte address. The displacement value is right-justified in the 20-bit field, and negative values are in two's complement form. |
| Mask/Fill | An 8-bit field used only with TRANSLATE AND TEST BYTE STRING and EDIT BYTE STRING. The purpose of this field is explained in the detailed discussion of the TTBS and EBS instructions. |
| Source Address | A 19-bit field that normally contains the byte address of the first (most significant) |


| Designation | Function <br> Source Address <br> (cont.) |
| :--- | :--- |
| byte of the source byte string operand. <br> The effective source address is the source <br> address in register $R$ plus the displacement <br> value in the instruction word. |  |
| Count | An 8-bit field that contains the true count <br> (from 0 to 255) of the number of bytes <br> involved in the operation. This field is <br> decremented by 1 as each byte in the <br> destination byte string is processed. A |
| 0 count means "no operation" with re- |  |
| spect to the registers and main memory. |  |

In any byte-string instruction, any portion of register $R$ or Rul that is not explicitly defined (i.e., bit positions 8-12), should be coded with zeros for real and virtual addressing.

Since the value Rul is obtained by performing a logical inclusive OR with the value 0001 and the value of the $R$ field of the instruction word, the two control registers are $R$ and $R+1$ if $R$ is even. However, if $R$ is an odd value, register $R$ contains an address value that functions both as a source operand address and as a destination operand address. Also, if register 0 is designated in any byte-string instruc-
 EDIT BYTE STRING), its contents are ignored and a zero source address value is obtained. Thus, the following three cases exist for most byte-string instructions, depending on whether the value of the $R$ field of the instruction word is even and nonzero, odd, or zero:

## Case $\mathrm{I}, \mathrm{R}$ is even and nonzero

The effective source address is the address in register R plus the displacement in the instruction word; the destination address is the address in register $\mathrm{R}+1$, but without the displacement added.

## Case II, R is odd

The effective source address is the address in register $R$ plus the displacement in the instruction word; the destination address is also the address in register $R$, but without the displacement added.

## Case III, R is zero

The effective source address is the displacement value in the instruction word; the destination address is the address in register 1. In this case, the source byte-string operand is always a single byte.

In the descriptions of the byte-string instructions, the following abbreviations and terms are used:

| D | Displacement, ${ }^{(1)} 12-31^{\circ}$ |
| :--- | :--- |
| SA | Source address, $(\mathrm{R})$ |
| $13-31$ |  |
| ESA | Effective source address, $\left[(\mathrm{R}) 13-31^{+(\mathrm{I})} 12-31\right][13-31$ |

The contents of bit positions 13-31 of register $R$ are added (right aligned) to the contents of bit positions 12-31 of the instruction word; the 19 loworder bits of the result are used as the effective source address.

C Count, (Rul) $0-7$
DA Destination address, (Rul) 13-31

SBS Source byte string, the byte string that begins with the byte location pointed to by the 19-bit effective source address and is $C$ bytes in length (if $R$ is 0 ).

DBS Destination byte string, the byte string that begins with the byte location pointed to by the destination address and is always $C$ bytes in length.

## TRAPS BY BYTE-STRING INSTRUCTIONS

Byte-string instructions cause a trap if either of the addressed byte strings come from memory pages that are protected by either access protection or write locks. A trap also occurs if either byte string is fully or partly contained within memory pages that are physically not present. A check for these access trap conditions is made prior to initiation of any byte relocation or general register change. These tests are performed for MOVE BYTE STRING and TRANSLATE BYTE STRING. The source and destination locations are tested for MOVE BYTE STRING; only the destination location is tested for TRANSLATE BYTE STRING, since there is no assurance that the translate table will be accessed in its entirety in the course of execution. If an access protection violation were to occur in trying to reach a byte in the translate table or decimal digit strings during the course of execution, then the instruction would trap and result in a puitially executed condition. However, if the destinution byte string does overlap the translation table, the registers would be restored in such a manner that the instruction could be restarted after the protection violation had been corrected. When a trap occurs resulting in a partially executed instruction, the Register Altered indicator will be set.


MOVE BYTE STRING copies the contents of the source byte string (left to right) into the destination byte string. The previous contents of the destination byte string are destroyed, but the contents of the source byte string are not affected unless the destination byte string overlaps the source byte string.

When the destination byte string overlaps the source byte string, the resulting destination byte string contains one or more repetitions of bytes from the source byte string. Thus, if a destination byte string of $C$ bytes begins with the kth byte of a source byte string (numbering from 1), the first $\mathrm{k}-1$ bytes of the source byte string are duplicated in the destination byte string $x$ number of times, where $x=C /(k-1)$. For example, if the destination byte string begins with the second byte of the source byte string, the first byte of the source byte string is duplicated throughout the destination byte string.

If both byte strings begin with the same byte (i.e., $k=1$ ) and the $R$ field of MBS is nonzero, the destination byte string is read and replaced into the same memory locations. However, if both byte strings begin with the same byte and the $R$ field of MBS is zero, the first byte of the byte string is duplicated throughout the remainder of the byte string (see "Case III", below).

Affected: (DBS), (R), (Rul)
$(S B S) \longrightarrow$ DBS

If MBS is indirectly addressed, it is treated as a nonexistent instruction. The basic processor unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$ with the contents of register $R$ and the destination byte string unchanged. See "Traps by Byte String Instructions" (in this section) for other trap conditions.

Case I, even, nonzero $R$ field (Rul $=R+1$ )
Contents of register R :


Contents of register $\mathrm{R}+\mathrm{l}$ :


The source byte string begins with the byte location pointed to by the source address in register $R$ plus the displacement in MBS; the destination byte string begins with the byte location pointed to by the destination address in register $R+1$.

Both byte strings are $C$ bytes in length. When the instruction is completed, the destination and source addresses are each incremented by $C$, and $C$ is set to zero.

Case II, odd R field (Rul=R)
Contents of register R :


The source byte string begins with the byte location pointed to by the address in register $R$ plus the displacement in MBS; the destination byte string begins with the byte location pointed to by the destination address in register $R$. Both byte strings are C bytes in length. When the instruction is completed, the destination address is incremented by C , and $C$ is set to zero.

Case III, zero R field (Rul=1)
Contents of register 1:

| Count |  | Destination address |
| :---: | :---: | :---: |

The source byte string consists of a single byte, the contents of the byte location pointed to by the displacement in MBS; the destination byte string begins with the byte location pointed to by the destination address in register 1 and is $C$ bytes in length. In this case, the source byte is duplicated throughout the destination byte string. When the instruction is completed, the destination address is incremented by $C$, and $C$ is set to zero.

COMPARE BYTE STRING
(Immediate displacement, continue after interrupt)

| 0 | 60 | R | Displacement |
| :---: | :---: | :---: | :---: |

COMPARE BYTE STRING compares, as magnitudes, the contents of the source byte string with the contents of the destination byte string, byte by corresponding byte, beginning with the first byte of each string. The comparison continues until the specified number of bytes have been compared or until an inequality is found. When CBS is terminated, CC3 and CC4 are set to indicate the result of the last comparison. If the CBS instruction terminates due to inequality, the count in register Rul is one greater than the number of bytes remaining to be compared; the source address in register $R$ and the destination address in register Rul indicate the locations of the unequal bytes.

Affected: (R), (Rul), CC3, CC4
(SBS) : (DBS)

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of CBS

-     - 00 Source byte string equals destination byte string or initial byte count is equal to zero.
-     - 01 Source byte string less than destination byte string.
-     - 10 Source byte string greater than destination byte string.

If CBS is indirectly addressed, it is treated as a nonexistent instruction. The basic processor unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $\mathrm{X}^{\prime} 40^{\prime}$ with the contents of register R and the destination byte string unchanged. See "Traps By Byte String Instructions" (in this section) for other trap conditions.

## Case I, even, nonzero $R$ field (Rul $=R+1$ )

Contents of register $R$ :


Contents of register $\mathrm{R}+\mathrm{l}$ :

| Count | 1 | Destination address |
| :---: | :---: | :---: |

The source byte string begins with the byte iocation pointed to by the source address in register R plus the displacement in CBS; the destination byte string begins with the byte location pointed to by the destination address in register $\mathrm{R}+\mathrm{l}$. Both byte strings are C bytes in length.

Case II, odd R field (Rul=R)
Contents of register R :

| Count |  | Destination address |
| :---: | :---: | :---: |
| $01231456789101112131415161718191202122231^{24} 25262728293031$ |  |  |

The source byte string begins with the byte location pointed to by the address in register $R$ plus the displacement in CBS; the destination byte string begins with the byte location pointed to by the destination address in register $R$. Both byte strings are C bytes in length.

## Case III, zero R field (Rul=1)

Contents of register 1:

| Count | 1 | Destination address |
| :---: | :---: | :---: |

The source byte string consists of a single byte, the contents of the location pointed to by the displacement in CBS;
the destination byte string begins with the byte location pointed to by the destination address in register 1 and is $C$ bytes in length. In this case, the source byte is compared with each byte of the destination byte string until an inequality is found.

TBS
TRANSLATE BYTE STRING
(Immediate displacement, continue after interrupt)


TRANSLATE BYTE STRING replaces each byte of the destination byte string with a source byte located in a translation table. The destination byte string begins with the byte location pointed to by the destination address in register Rul, and is $C$ bytes in length. The translation table consists of up to 256 consecutive byte locations, with the first byte location of the table pointed to by the displacement in TBS plus the source address in register R. A source byte is defined as that which is in the byte location pointed to by the 19 low-order bits of the sum of the following values.

1. The displacement in bit positions 12-31 of the TBS instruction.
2. The current contents of bit positions 13-31 of register $R$ (source address).
3. The numeric value of the current destination byte, the 8-bit contents of the byte location pointed to by the current destination address in bit positions 13-31 of register (Rul).

Affected: (DBS), (Rul) Trap: Instruction exception
translated (DBS) $\longrightarrow$ DBS
The R field of the TBS instruction must be an even value for proper operation of the instruction; if the R field of TBS is an odd value, the instruction traps to location X'AD', instruction exception trap.

If TBS is indirectly addressed, it is treated as a nonexistent instruction. The basic processor unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$ with the contents of register $R$ and the destination byte string unchanged.

See "Traps By Byte String Instructions" (in this section) for other trap conditions. Note that the check for access trap conditions is done only for the source byte string.

Case $I$, even, nonzero $R$ field (Rul=R+1)
Contents of register $R$ :

|  |  | Source address |
| :---: | :---: | :---: |

## Contents of register $\mathrm{R}+\mathrm{l}$ :



The destination byte string begins with the byte location pointed to by the destination address in register $R+1$ and is $C$ bytes in length. The source byte string (translation table) begins with the byte location pointed to by the displacement in TBS plus the source address in register $R$. When the instruction is completed, the destination address is incremented by $C, C$ is set to zero, and the source address remains unchanged.

Case II, odd R field (Rul=R)
Because of the interruptible nature of TRANSLATE BYTE STRING, the instruction traps with the contents of register $R$ unchanged when an odd-numbered general register is specified by the $R$ field of the instruction word.

Case III, zero R field (Rul=1)
Contents of register 1:


The destination byte string begins with the byte location pointed to by the destination address in register 1 and is $C$ bytes in length. The source byte string (translation table) begins with the location pointed to by the displacement in TBS. When the instruction is completed, the destination address is incremented by C and C is set to zero.

TTBS TRANSLATE AND TEST BYTE STRING (Immediate displacement, continue after interrupt)

| 0 | 40 | R | Displacement |
| :---: | :---: | :---: | :---: |

TRANSLATE AND TEST BYTE STRING compares the mask in bit positions 0-7 of register R with source bytes in a byte translation table. The destination byte string begins with the byte location pointed to by the destination address in register Rul, and is C bytes in length. The byte translation table and the translation bytes themselves are identical to that described for the instruction TRANSLATE BYTE STRING. The destination byte string is examined (without being changed) until a translation byte (source byte) is found that contains a 1 in any of the bit positions selected by a 1 in the mask. When such a translation byte is found, TTBS replaces the mask with the logical product (AND) of the transiation byte and the mask, and terminates with CC4 set to 1 .

If the TTBS instruction terminates due to the above condition, the count $(C)$ in register Rul is one greater than the number of bytes remaining to be compared and the destination address in register Rul indicates the location
of the destination byte that caused the instruction to terminate. If no translation byte is found that satisfies the above condition after the specified number of destination bytes have been compared, TTBS terminates with CC4 reset to 0 . In no case does the TTBS instruction change the source byte string.

Affected: (R), (Rul), CC4 Trap: Instruction exception
If translated (SBS) n mask $\neq 0$, translated $(S B S) \mathrm{n}$ mask $\longrightarrow$ mask and stop

If translated (SBS) n mask $=0$, continue

Condition code settings:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of TTBS

-     - 0 Translation bytes and the mask do not compare ones any place.
-     - 1 The last translation byte compared with the mask contained at least one 1 corresponding to a I in the mask.

The $R$ field of the TTBS instruction must be an even value for proper operation of the instruction; if the $R$ field of TTBS is an odd value, the instruction traps to location $\mathrm{X}^{\prime} 4 \mathrm{D}^{\prime}$, instruction exception trap.

If TTBS is indirectly addressed, it is treated as a nonexistent instruction. TThe basic processor unconditionaily aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$ with the contents of register R and the destination byte string unchanged.

See "Traps By Byte String Instructions" (in this section) for other trap conditions. Note that the check for access trap conditions is done only for the source byte string.

Case I, even, nonzero R field (Rul=R+1)
Contents of register R:


Contents of register $\mathrm{R}+1$ :

| Count | Destination address |
| :---: | :---: |

The destination byte string begins with the byte location pointed to by the destination address in register $R+1$ and is $C$ bytes in length. The source byte string (translation table) begins with the byte location pointed to by the displacement in TTBS plus the source address in register R.

Case II, odd R field
Because of the interruptible nature of TRANSLATE AND TEST BYTE STRING the instruction traps with the contents of register $R$ unchanged when an odd-numbered general register is specified by the $R$ field of the instruction word.

Case III, zero R field (Rul=1)
Contents of register 1:

| Count | Destination address |
| :---: | :---: |

The destination byte string begins with the byte location pointed to by the destination address in register 1 and is C bytes in length. The source byte string (translation table) begins with the location pointed to by the displacement in TTBS. In this case, the instruction automatically provides a mask of eight l's. (This is an exception to the general rule, used in the other byte-string instructions, the register 0 provides all 0 's as its contents.)

## EBS EDIT BYTE STRING

(Immediate displacement, continue after interrupt)

| 0 | 63 | R | Displacement |
| :---: | :---: | :---: | :---: |

EDIT BYTE STRING converts a decimal information field from packed decimal format to zoned decimal EBCDIC format, under control of the editing pattern in the destination byte string, and replaces the destination byte string with the edited, zoned result. (See "Decimal Instructions", "Packed Decimal Numbers", and "Zoned Decimal Numbers" for a description of packed and zoned decimal formats.) EBS proceeds one byte at a time, starting with the first (most significant) byte of the editing pattern, and continues until all bytes in the editing pattern have been processed. The fill character, contained in bit position 0-7 of register $R$, replaces the pattern byte under specified conditions. More than one decimal number field can be edited by a single EBS instruction if the pattern in memory is, in fact, a series of patterns corresponding to a series of number fields. In such cases, however, after the EBS instruction is completed, the condition code indicates the result of the last decimal number field processed and register 1 contains the byte address (or the byte address plus I) of the last significance indicator in the edited destination byte string. (This allows the insertion of a floating dollar sign, etc., with a subsequent instruction.)
$R$ must be an even value (excluding 0 ) for proper operation of the instruction; if $R$ is an odd value or equal to zero, the basic processor traps to location $X^{\prime} 4 D^{\prime}$, instruction exception trap, with the contents in register $R$ unchanged.

Contents of register R:


Contents of register $\mathrm{R}+\mathrm{l}$ :


The destination byte string is an editing pattern that begins in the byte location pointed to by the destination address in register $R+1$, and is $C$ bytes in length. The decimal information field, which must be in packed decimal format, begins with the byte location pointed to by the displacement in EBS plus the source address in register R. The decimal information field must contain legal decimal digit and sign codes (packed format) and must begin with a decimal digit.

The destination byte string (the editing pattern) may contain any 8-bit codes desired. However, four byte codes in the editing pattern have special meanings. These codes are as follows:

| Binary value | Function | Abbreviation |
| :--- | :--- | :---: |
| $00100000\left(X^{\prime} 20^{\prime}\right)$ | Digit selector | ds |
| $00100001\left(X^{\prime} 21^{\prime}\right)$ | Significance start | ss |
| $00100010\left(X^{\prime} 22^{\prime}\right)$ | Field separation | fs |
| $00100011\left(X^{\prime} 23^{\prime}\right)$ | Immediate signifi- <br> cance start | si |

Before executing EBS, the condition code should be set to 0000 if the high-order digit of the decima! number is in the left half of a byte, and should be set to 0100 if the high-order digit is in the right half of a byte.

The editing operation performed on each pattern byte of the destination byte string is determined by the following conditions:

1. The pattern byte obtained from the destination byte string.
2. The decimal digit obtained from the decimal number field.
3. The current state of the condition code.

Depending upon various combinations of these conditions, the instruction EDIT BYTE STRING performs one
(and only one) of the following actions with the pattern byte and the decimal digit:

1. The fill character (contents of bit positions 0-7 of register $R$ ) or a blank character replaces the byte in the destination byte string.
2. The decimal digit is expanded to zoned decimal format and replaces the pattern byte in the destination byte string.
3. The pattern byte remains unchanged.

In general, the normal editing process is as follows:

1. Each byte of the destination byte string is replaced by a fill character until significance is present, either in the destination byte string or in the decimal information field. Significance is indicated by any of the following:
a. The pattern byte is $\mathrm{X}^{\prime} 23^{\prime}$ (immediate significance start), which begins significance with the current decimal digit.
b. The pattern byte is $\mathrm{X}^{\prime} 21^{\prime}$ (significance start), which begins significance with the following pattern byte.
c. The current decimal digit is nonzero, which begins significance with the current pattern byte.
2. After significance is encountered, each pattern byte that is $X^{\prime} 20^{\prime}$ (digit selector), $X^{\prime} 21^{\prime}$ (significance start), $X^{\prime} 22^{\prime}$ (field separator), or $\mathrm{X}^{\prime} 23^{\prime}$ (immediate significance start) is replaced by a zoned decimal number from the decimal field and all other pattern bytes are unchanged. This process continues until any of the following conditions occurs:
a. A positive sign is encountered in the decimal field, in which case subsequent pattern bytes are replaced by blank characters until significance is again present, until a field separator is encountered, or until the destination byte string is entirely processed, whichever occurs first.
b. A negative sign is encountered in the decimal field, in which case subsequent pattern bytes are unchanged until significance is again present, until a field separator is encountered, or until the destination byte string is entirely processed, whichever occurs first.
c. A pattern byte of $X^{\prime} 22^{\prime}$ (field separator) is encountered, in which case the field separator is replaced by a fill character; subsequent pattern bytes are replaced by the fill character until significance is
again present, until a positive or negative sign is encountered, or until the destination byte string is entirely processed, whichever occurs first.
d. The destination byte string is entirely processed, in which case the basic processor executes the next instruction in sequence.

Detailed operation of EDIT BYTE STRING follows. The explanation is necessarily quite detailed due to the high degree of flexibility inherent in EBS. Condition code settings are made continuously during the editing process and these settings help determine how each subsequent pattern byte will be edited. The summary of condition code settings given later in this section will help clarify the following discussion:

1. If the count in bit position 0-7 of register $R+1$ is a nonzero, a pattern byte is obtained from the destination byte string; if the count in register $R+1$ is 0 , the basic processor executes the next instruction in sequence.
2. If the pattern byte is a digit selector ( $\mathrm{X}^{\prime} 20^{\prime}$ ), a significance start ( $\mathrm{X}^{\prime} 21^{\prime}$ ), or immediate significance start ( $X^{\prime} 23^{\prime}$ ), a digit is accessed from the decimal information field as follows:
a. A decimal byte is obtained from the byte location pointed to by the displacement in EBS plus the source address in register $R$.
b. If bits $0-3$ of the decimal byte are a sign code, the basic processor automatically aborts execution of EXSS and traps to iocation $\chi^{-} 45^{\circ}$, with the contents of register $R$, register $R+1$, the condition code, and the destination byte string unchanged from their current contents.
c. If CC2 is currently set to 0 , the digit to be used for editing is the left digit (bits $0-3$ ) of the decimal byte; however, if CC2 is currently set to 1 , the digit to be used is the right digit (bits 4-7) of the decimal byte. In either case, CC3 is set to 1 if the digit is nonzero. If CC2 is set to 1 and the right digit (bits 4-7) of the decimal byte is a sign code, the basic processor automatically aborts execution of EBS and traps to location $X^{\prime} 45^{\prime}$, as described above.
d. One of the following editing actions is performed:

| Conditions | Action | Mark |
| :--- | :--- | :--- |
| Pattern byte=SI(X'23') | Expand digit to zoned <br> format, store in pat- <br> tern byte location, <br> and set CC4 to 1 (start <br> significance). | Mode 1 |
| Pattern byte=SS $\left(X^{\prime} 21^{\prime}\right)$ Expand digit to zoned <br> format and store in <br> pattern byte location | None |  |
|  |  |  |


| Conditions | Action | Mark |
| :---: | :---: | :---: |
| Pattern byte=SS (X'21') CC4=1 (cont.) | (because CC4-1 means significance already encountered). |  |
| Pattern byte=SS CC4=0 <br> nonzero digit | Expand digit to zoned format, store in pattern byte location (because nonzero digit begins significance), and set CC4 to 1 . | Mode 1 |
| Pattern byte=SS CC4-0 <br> digit=0 | Store fill character in pattern byte location (because significance starts with next pattern byte) and set CC4 to 1 . | Mode 2 |
| $\text { Pattern byte=DS ( } \left.X^{\prime} 20^{\prime}\right)$ CC4=1 | Expand digit to zoned format, and store digit in pattern byte location. | None |
| Pattern byte=DS CC4=0 <br> nonzero digi† | Expand digit to zoned format, store digit in pattern byte location, and set CC4 to 1 to signal significance. | Mode 1 |
| Pattern byte=DS CC4=0 <br> digit=0 | Store fill character in pattern byte location (because significance not encountered yet). | None |

e. If CC2 is currently reset to 0 and if bits $4-7$ of the decimal byte are a positive decimal sign code, CC1 is set to 1, CC4 is reset to 0 , and the source address in register $R$ is incremented by 1 . If CC2 is currently reset to 0 and if bits $4-7$ of the decimal byte are a negative decimal sign code, CC1 and CC4 are both set to 1 , and the source address is incremented by 1 . Otherwise, CC2 is added to the source address and then CC 2 is inverted.
f. If marking is invoked at set $d$, above, one of the two following marking operations are performed:

Mode 1: Load bits 13-31 of register $\mathrm{R}+1$ into bit positions 13-31 of register 1 ; bit positions 0-12 of register are unpredictable.

Mode 2: Load bits 13-31 of register $\mathrm{R}+1$ into bit positions 13-31 of register 1 and then increment the contents of register 1 by 1 ; bit positions $0-12$ of register 1 are unpredictable.

If marking is not applicable (i.e., significance has not been encountered), the contents of register 1 are not affected.
3. If the pattern byte is a field separator ( $\mathrm{X}^{\prime} 22^{\prime}$ ), the fill character is stored in the pattern byte location. CC1, CC3, and CC4 are all reset to 0 's, and CC2 remains unchanged.
4. If the pattern byte is not a digit selector, significance start, immediate significance start, or field separator, one of the following actions are performed:

| Conditions | Action |
| :---: | :---: |
| $\left.\begin{array}{l} \mathrm{CCl}=0 \\ \mathrm{CC} 4=0 \end{array}\right\}$ | Store fill character in pattern byte location. |
| $\left.\begin{array}{l} \mathrm{CCl}=1 \\ \mathrm{CC} 4=0 \end{array}\right\}$ | Store blank character ( $\mathrm{X}^{\prime} 40^{\prime}$ ) in pattern byte location. |
| CC4=1 | None (pattern byte remains unchanged). |

5. Increment the destination address in register Rul and decrement the count in register Rul. If the count is still nonzero, process the next pattern byte as above; otherwise, execute the next instruction in sequence.

Affected: (R), (Rul)
(register 1),
(DBS), CC
edited $(S B S) \longrightarrow$ DBS

Condition code settings:

\section*{1 | 1 | 3 | 4 |
| :--- | :--- | :--- | :--- |}

0 - - 0 Significance is not present, no sign digit has been encountered.

0 - - 1 Significance is present, no sign digit has been encountered.

1 - - 0 A positive sign has been encountered.
1 - - 1 A negative sign has been encountered.

- 0 - Next digit to be processed is left digit of byte.
- 1 - Next digit to be processed is right digitof byte.
-     - 0 - No nonzero digit has been encountered.
- 1 - A nonzero digit has been encountered.

If EBS is indirectly addressed, it is treated as a nonexistent instruction. The basic processor unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to location $X^{\prime} 40^{\prime}$ with the contents of register R, register Ru1, register 1, the destination byte string, and the condition code unchanged.

The $R$ field of the EBS instruction must be an even value (excluding 0 ) for proper operation of the instruction; if the
$R$ field is an odd value or equal to zero, the instruction traps to location $\mathrm{X}^{\prime} 4 \mathrm{D}^{\prime}$, instruction exception trap.

If an illegal digit or sign is detected in the decimal information field, the basic processor unconditionally aborts execution of the instruction (at the time the illegal digit or sign is encountered) and traps to location $X^{\prime} 45^{\prime}$ with the contents of register R, register Rul, register 1 , the destination byte string, and the condition code containing the results of the last editing operation performed before the illegal digit or sign was encountered.

See "Traps By Byte-String Instructions" (in this section) for other trap conditions.

In the following examples, the hexadecimal codes for the digit selector ( $X^{\prime} 20^{\prime}$ ), the significance start ( $X^{\prime} 21^{\prime}$ ), the field separation ( $\mathrm{X}^{\prime} 22^{\prime}$ ), and the immediate significance start ( $\mathrm{X}^{\prime} 23^{\prime}$ ) are represented by the character groups ds , ss, fs, and si, respectively. Also, the symbol $\hbar$ is used to represent the character blank ( $\mathrm{X}^{\prime} 40^{\prime}$ ). Note that code $\mathrm{X}^{\prime} 5 \mathrm{C}^{\prime}$ represents the * symbol.

Example 1, before execution:
The instruction word is
$X^{\prime} 63600000^{\prime}$

The contents of register 6 are:

## $X^{\prime} 5 C 000100^{\prime}$

The contents of register 7 are:
$X^{\prime} 0 C 001000^{\prime}$

The contents of the decimal information field beginning at byte location $X^{\prime} 100^{\prime}$ are:

ט̂0 ÔO ÔO Ô+

The contents of the destination byte string beginning at byte location X' $1000^{\prime}$ are:
$d s d s, d s d s s s . d s d s ђ \subset R$

The condition code is:
0000

Example 1, after execution:
The instruction word is unchanged.
The new contents of register 6 are:
$X^{\prime} 5 C 000104^{\prime}$

The new contents of register 7 are：
$X^{\prime} 0000100 C^{\prime}$

The contents of the decimal information field are unchanged．

The new contents of the destination byte string are：

```
******.00ちちち
```

The new condition code is：
1000

The contents of register 1 are：
$X^{\prime} x x \times 01006^{\prime}$

By subsequent programming，a floating dollar sign can be inserted in front of the first significant character of the edited byte string by using the contents of register 1， minus 1 ，as the address of the byte location where the dollar sign is to be inserted．

Example 2，before execution：
The initial conditions are identical to example 1，except that the contents of the decimal information field are：

065432 1－

## Example 2，after execution：

The instruction word and the decimal field are unchanged．
The new contents of registers 6 and 7 are identical to those given for example 1.

The new contents of the destination byte string are：
＊6，543．21ちCR

The new condition code is：

## 1011

The new contents of register 1 are：
$X^{\prime} x x \times 01001^{1}$

Example 3，before execution：
The initial conditions are identical to example 1，except that the contents of the decimal field are：
$0054321+$

Example 3，after execution：
The instruction word and the decimal field are unchanged．
The new contents of registers 6 and 7 are identical to that given for example 1.

The new contents of the destination byte string are：
***543.21古もち

The new condition code is：
1010
The new contents of register 1 are：
$X^{\prime} x x x 01003{ }^{\prime}$

## Example 4，before execution：

The instruction word is：

$$
X^{\prime} 63400100^{\prime}
$$

The contents of register 4 are：
$X^{\prime} 7 B 001000^{1}$
The contents of register 5 are：
$X^{\prime} 19002000^{\prime}$
The contents of the decima！information field beginning at byte location $X^{\prime} 1100$ are：
$0612500+01234+035-$
The contents of the destination byte string beginning at byte location X＇2000＇are：

Ads ds si．$d s d s d s f s B d s d s s s . d s d s C f s D$
si ds ds END
The condition code is：
0100

Example 4，after execution：
The instruction word is unchanged．
The new contents of register 4 are：
X＇7B001009＇
The new contents of register 5 are：
$X^{\prime} 00002019{ }^{\prime}$
The decimal information field is unchanged．

The new contents of the destination byte string are:
\#612.500\#\#\#12.34も\#\#035END
The new condition code is:

1011
The new contents of register 1 are:

X'xxx02013'

## PUSH-DOWN INSTRUCTIONS (NON-PRIVILEGED)

The term "push-down processing" refers to the programming technique (used extensively in recursive routines) of storing the context of a calculation in memory, proceeding with a new set of information, and then activating the previously stored information. Typically, this process involves a reserved area of memory (stack) into which operands are pushed (stored) and from which operands are pulled (loaded) on a last-in, first-out basis. The basic processor provides for simplified and efficient programming of pushdown processing by means of the following non-privileged instructions:

| Instruction Name | Mnemon |
| :--- | :--- |
| Push Word | PSW |
| Pull Word | PLW |
| Push Multiple | PSM |
| Pull Multiple | PLM |
| Modify Stack Pointer | MSP |

## STACK POINTER DOURIEWORD (SPD)

Each non-privileged push-down instruction operates with respect to a memory stack that is defined by a doubleword located at effective address of the instruction. This doubleword, referred to as a stack pointer doubleword (SPD), has the following structure:


[^8]Bit positions 15 through 31 of the SPD contain a 17-bit address field ${ }^{\dagger}$ that points to the location of the word currently at the top (highest-numbered address) of the operand stack. In a push operation, the top-of-stack address is incremented by 1 and then an operand in a general register is pushed (stored) into that location, thus becoming the contents of the new top of the stack; the contents of the previous top of the stack remain unchanged. In a pull operation, the contents of the current top of the stack are pulled (loaded) into a general register and then the top-of-stack address is decremented by 1 ; the contents of the stack remain unchanged.

Bit positions 33 through 47 of the SPD, referred to as the space count, contain a 15 -bit count ( 0 to 32,767 ) of the number of word locations currently available in the region of memory allocated to the stack. Bit positions 49 through 63 of the SPD, referred to as the word count, contain a 15-bit count ( 0 to 32,767 ) of the number of words currently in the stack. In a push operation, the space count is decremented by 1 and the word count is incremented by 1 ; in a pull operation, the space count is incremented by 1 and the word count is decremented by 1 . At the beginning of all nonprivileged push-down instructions, the space count and the word count are each tested to determine whether the instruction would cause either count field to be incremented above the upper limit of $2^{15}-1(32,767)$, or to be decremented below the lower limit of 0 . If execution of the push-down instruction would cause either count limit to be exceeded, the basic processor unconditionally aborts execution of the instruction, with the stack, the stack pointer doubleword, and the contents of general registers unchanged. Ordinarily, the basic processor traps to location $\mathrm{X}^{\prime} 42^{\prime}$ after aborting a push-down instruction because of impending stack limit overflow or underflow, and with the condition code unchanged from the value it contained before execution of the instruction.

However, this trap action can be selectively inhibited by setting either (or both) of the trap inhibit bits in the SPD to 1 .

Bit position 32 of the SPD, referred to as the trap-on-space (TS) inhibit bit, determines whether the basic processor will trap to location $X^{\prime} 42^{\prime}$ as a result of impending overflow or underflow of the space count ( $S P D_{33-47}$ ), as follows:

## TS Space count overflow/underflow action

0 If the execution of a pull instruction would cause the space count to exceed $2^{15}-1$, or if the execution of a push instruction would cause the space count to be less than 0 , the basic processor traps to location $X^{\prime} 42^{\prime}$ with the condition code unchanged.

1 Instead of trapping to location $X^{\prime} 42^{\prime}$, the basic processor sets CCl to 1 and then executes the next instruction in sequence.

Bit position 48 of the SPD, referred to as the trap-on-word (TW) inhibit bit, determines whether the basic processor
traps to location $\mathrm{X}^{\prime} 42^{\prime}$ as a result of impending overflow or underflow of the word count (SPD $49-63$ ), as follows:

## TW Word count overflow/underflow action

0 If the execution of a push instruction would cause the word count to exceed $215-1$, or if the execution of a pull instruction would cause the word count to be less than 0 , the basic processor traps to location $X^{\prime} 42^{\prime}$ with the condition code unchanged.

1 Instead of trapping to location $X^{\prime} 42^{\prime}$, the basic processor sets CC3 to 1 and then executes the next instruction in sequence.

## PUSH-DOWN CONDITION CODE SETTINGS

If the execution of a push-down instruction is attempted and the basic processor traps to location $X^{\prime} 42^{1}$, the condition code remains unchanged from the value it contained immediately before the instruction was executed.

If the execution of a push-down instruction is attempted and the instruction is aborted because of impending stack limit overflow or underflow (or both) but the push-down stack limit trap is inhibited by one (or both) of the inhibits (TS and TW), then, CC1 or CC3 is set to 1 (or both are set to l's) to indicate the reason for aborting the push-down instruction, as follows:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Reason for abort

0-1 - Impending overflow of word count on a push operation or impending underflow of word count on a pull operation. The push-down stack limit trap was inhibited by the TW bit (SPD48).

1-0 - Impending overflow of space count on a pull operation or impending underflow of space count on a push operation. The push-down stack limit trap was inhibited by the TS bit (SPD32).

1 - 1 - Impending overflow of word count and underflow of space count on a push operation or impending overflow of space count and underflow of word count on a pull operation. The pushdown stack limit trap was inhibited by both the TW and the TS bits.

If a push-down instruction is successfully executed, CCl and CC3 are reset to 0 at the completion of the instruction. Also, CC2 and CC4 are independently set to indicate
the current status of the space count and the word count, respectively, as follows:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Status of space and word counts

- 0 - 0 The current space count and the current word count are both greater than zero.
- 0 - 1 The current space count is greater than zero, but the current word count is zero, indicating that the stack is now empty. If the next operation on the stack is a pull instruction, the instruction will be aborted.
- 1 - 0 The current word count is greater than zero, but the current space count is zero, indicating that the stack is now full. If the next operation on the stack is a push instruction, the instruction will be aborted.

If the basic processor does not trap to location $\mathrm{X}^{\prime} 42^{\prime}$ as a result of impending stack limit overflow/underflow, CC2 and CC4 indicate the status of the space and word counts at the termination of the push-down instruction, regardless of whether the space and word counts were actually modified by the instruction. In the following descriptions of the push-down instructions, condition code settings given are only those that can be produced by the instruction, provided that the basic processor does not trap to location $X^{\prime} 42^{\prime}$.

PSW PUSH WORD
(Doubleword index alignment)

| * | 09 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

PUSH WORD stores the contents of register R into the pushdown stack defined by the stack pointer doubleword located at the effective doubleword address of PSW. If the push operation can be successfully performed, the instruction operates as follows:

1. The current top-of-stack address (SPD $15-31)^{\dagger}$ is incremented by 1 to point to the new top-of-stack location.
2. The contents of register $R$ are stored in the location pointed to by the new top-of-stack address.
${ }^{\dagger}$ For real extended mode of addressing this is a 20 -bit field (12-31); for real and virtual addressing modes it is a 17-bit field (15-31).
3. The space count $\left(\right.$ SPD $\left._{33-47}\right)$ is decremented by 1 and the word count (SPD 49-63) is incremented by 1 .
4. The condition code is set to reflect the new status of the space count.

Affected: (SPD), (TSA+1), CC Trap: Push-down stack limit (SPD) ${ }_{15-31}+1 \longrightarrow$ SPD $_{15-31}{ }^{\dagger}$
$(R) \longrightarrow\left(\text { SPD }_{15-31}\right)^{\dagger}$
$(S P D)_{33-47^{-1}} \longrightarrow$ SPD $_{33-47}$
(SPD $_{49-63}+1 \longrightarrow$ SPD $_{49-63}$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of PSW

| 0 | 0 | 0 | 0 | Space count is greater <br> than 0. |
| :--- | :--- | :--- | :--- | :--- | | Instruction |
| :--- |
| completed |

0100 Space count is now 0
0010 Word count $=2^{15}-1$, $T W=1$.

1100 Space count $=0$, $T S=1$.

1101 Space count = 0, word count $=0, T S=1$.

1110 Word count $=2^{15}-1$, space count $=0$, $T W=1$, and $T S=1$.

## PLW PULLWORD

(Doubleword index alignment)

| 08 | R | X | Reference address |
| :---: | :---: | :---: | :---: |

PULL W ORD loads register $R$ with the word currently at the top of the push-down stack defined by the stack pointer doubleword located at the effective doubleword address of PLW. If the pulloperation can be performedsuccessfully, the instruction operates as follows:

1. Register $R$ is loaded with the contents of the location pointed to by the current top-of-stack address $\left(S P D_{15-31}\right)^{\dagger}$.
2. The current top-of-stack address is decremented by 1 , to point to the new top-of-stack location.

[^9]3. The space count (SPD $33-47$ ) is incremented by 1 and the word count (SPD $49-63$ ) is decremented by 1.
4. The condition code is set to reflect the status of the new word count.

Affected: (SPD), (R), CC
Trap: Push-down stack limit
$\left.{ }_{(S P D}\right)_{15-31} \longrightarrow R ;(S P D)_{15-31}{ }^{-1} \longrightarrow$ SPD $_{15-31}{ }^{\dagger}$
$(S P D)_{33-47}+1 \longrightarrow$ SPD $_{33-47^{\prime}}$
$(S P D)_{49-63^{-1}} \longrightarrow$ SPD $_{49-63}$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of PLW
00000 Word count is greater than 0.

Instruction
completed
$\begin{array}{lllll}0 & 0 & 0 & 1\end{array}$ Word count is now 0 .
$\begin{array}{lll}0 & 0 & 1\end{array}$ Word count $=0, T W=1$.

0111 Space count $=0$, word count $=0$, TW = 1 .

1000 Space count $=2^{15}-1$, Instruction aborted $T S=1$.

1011 Space count $=2^{15}-1$, word count $=0, T S=1$, and $T W=1$.

PSM PUSH MULTIPLE
(Doubleword index alignment)

| * | OB | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

PUSH MULTIPLE stores the contents of a sequential set of general registers into the push-down stack defined by the stack pointer doubleword located at the effective doubleword address of PSM. The condition code must contain a count of the number of registers to be pushed into the stack. (An initial value of 0000 for the condition code specifies that all lt general registers are to be pushed into the stack.) The registers are treated as a circular set (with register 0 following register 15) and the first register to be pushed into the stack is register $R$. The last register to be pushed in to the stack is register $R+C C-1$, and the contents of this register become the contents of the new top-of-stack location.

If there is sufficient space in the stack for all of the specified registers, PSM operates as follows:

1. The contents of registers $R$ to $R=C C-1$ are stored in ascending sequence, beginning with the location tion pointed to by the current top-of-stack address (SPD $15-31)^{\dagger}$ plus 1 and ending with the current top-of-stack address plus CC.
2. The current top-of-stack address is incremented by the value of CC, to point to the new top-of-stack location.
3. The space count $\left(\right.$ SPD $\left._{33-47}\right)$ is decremented by the value of CC and the word count is incremented by the value of CC.
4. The condition code is set to reflect the new status of the space count.

Affected: (SPD), (TSA+1) to Trap: Push-down stack limit (TSA+CC), CC
$(R) \longrightarrow(S P D)_{15-31}+1 \ldots(R+C C-1) \longrightarrow(S P D)^{\dagger}{ }_{15-31}+C C$
$(S P D)_{15-31}+C C \longrightarrow$ SPD $_{15-31}{ }^{\dagger}$
$(\mathrm{SPD})_{33-47}-\mathrm{CC} \longrightarrow$ SPD $_{33-47}$
(SPD) ${ }_{49-63}+\mathrm{CC} \longrightarrow$ SPD $_{49-63}$

Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of PSM
$0 \quad 0 \quad 0 \quad 0 \quad$ Space count $>0$.
0100 Space count $=0$.
0010 Word count $+C C>2^{15}-1$, $T W=1$.

1000 Space count $\angle C C, T S=1$.
1001 Space count <CC, word count $=0, \mathrm{TS}=1$.

10100 Space count <CC, word count $+C C>2^{15-1}$ $T S=1$, and $T W=1$.

1100 Space count $=0, T S=1$.
1101 Space count $=0$, word count $=0, T S=1$.

1110 Space count $=0$, word count + CC $>2^{15}-1$, $T S=1$, and $T W=1$.
${ }^{\dagger}$ For real extended mode of addressing this is a 20-bit field (12-31); for real and virtual addressing modes it is a 17-bit field (15-31).

If the instruction operation extends into a memory page protected either by the access protection codes or write locks, the memory protection trap can occur. If the operation extends into a memory region that is physically not present, the nonexistent memory address trap can occur.

If the address of the elements within the stack (pointed to by the top-of-stack address) is in the range 0 through 15, then the registers indicated by the $R$ field of the PSM instruction are stored in the general registers rather than in main memory. In this case the results will be unpredictable if any source registers are also used as destination registers.

## PLM PULL MULTIPLE <br> (Doubleword index alignment)

| * | OB | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

PULL MULTIPLE loads a sequential set of general registers from the push-down stack defined by the stack pointer doubleword located at the effective doubleword address of PLM. The condition code must contain a count of the number of words to be pulled from the stack. (An initial value of 0000 for the condition code specifies that 16 words are to be pulled from the stack. ) The registers are treated as a circular set (with register 0 following register 15), the first register to be loaded from the stack is register $R+C C-1$, and the contents of the current top-of-stack location becomes the contents of this register. The last register to be loaded is register $R$.

If there is a sufficient number of words in the stack to load all of the specitied registers, PLM operates as tollows:

1. Registers $\mathrm{R}+\mathrm{CC}-1$ to register R are loaded in descending sequence, beginning with the contents of the location pointed to by the current top-of-stack address $\left(\text { SPD }_{15-31}\right)^{\dagger}$ and ending with the contents of the location pointed to by the current top-of-stack address minus CC-1.
2. The current top-of-stack address is decremented by the value of CC, to point to the new top-of-stack location.
3. The space count ( $S_{3 D_{3}-47}$ ) is incremented by the value of CC and the word count is decremented by the value of CC.
4. The condition code is set to reflect the new status of the word count.

Affected: (SPD), (R+CC-1) Trap: Push-down stack limit to (R), CC
$\left((S P D)_{15-31}{ }^{\dagger} \longrightarrow R+C C-1, \ldots\right.$,
$\left((S P D)_{15-31}-|C C-1|\right) \longrightarrow R^{\dagger}$
$(S P D)_{15-31}-C C \longrightarrow$ SPD $_{15-31}{ }^{\dagger}$
(SPD) 33-47 $+\mathrm{CC} \longrightarrow$ SPD $_{33-47}$
(SPD) $49-63-\mathrm{CC} \longrightarrow$ SPD $_{49-63}$

Condition code settings:

## 1234 Result of PLM

| 0 | 0 | 0 | 0 | Word count $>0$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | Word count $=0$ |
| 0 | 0 | 1 | 0 | $\begin{aligned} & \text { Word count }<C C \text {, } \\ & \text { TW = } 1 \end{aligned}$ |
| 0 | 0 | 1 | 1 | Word count $=0$, $T W=1$ |
| 0 | 1 | 1 | 0 | $\begin{aligned} & \text { Space count = } 0 \text {, } \\ & \text { word count }<C C, \\ & T W=1 \end{aligned}$ |
| 0 | 1 | 1 | 1 | Space count $=0$, word count $=0$, $T W=1$ |
| 1 | 0 | 0 | 0 | $\begin{aligned} & \text { Space count }+C C>2^{15}-1 \text {, } \\ & T S=1 \end{aligned}$ |
| 1 | 0 | 1 | 0 | $\begin{aligned} & \text { Space count }+C C>2^{15}-1 \text {, } \\ & \text { word count }<C C, T S=1 \text {, } \\ & \text { and } T W=1 \end{aligned}$ |
| 1 | 0 | 1 | 1 | Space count $+C C>2^{15}-1$, word count $=0, T S=1$, and $T W=1$ |

If the instruction operation extends into a memory page protected either by the access protection codes or write locks, the memory protection trap can occur. If the operation extends into a memory region that is physically not present, the nonexistent memory address trap can occur.

If the address of the elements within the stack (pointed to by the top-of-stack address) is in the range 0 through 15, then the words to be loaded are token from the genera! registers rather than from main memory. In this case, the results will be unpredictable if any of the source registers are also used as destination registers.

MSP MODIFY STACK POINTER
(Doubleword index alignment)

| * | 13 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

MODIFY STACK POINTER modifies the stack pointer doubleword, loceted at the effective doubleword address of MSP by the contents of register $R$. Register $R$ must have the following format:


Bit positions 16 through 31 of register $R$ are treated as a signed integer, with negative integers in two's complement form (i.e., a fixed-point halfword). The modifier is algebraically added to the top-of-stack address, subtracted from the space count, and added to the word count in the stack pointer doubleword. If, as a result of MSP, either the space count or the word count would be decreased below 0 or increased above $2^{15}-1$, the instruction is aborted. Then, the basic processor either traps to location $X^{\prime} 42^{\prime}$ or sets the condition code to reflect the reason for aborting, depending on the stack limit trap inhibits.

If the modification of the stack pointer doubleword can be successfully performed, MSP operates as follows:

1. The modifier in register R is algebraically added to the current top-of-stack address (SPD $15-31)^{\text {t }}$, to point to a new top-of-stack location. (If the modifier is negative, it is extended to 17 bits by appending a highorder 1.)
2. The modifier is algebraically subtracted from the current space count (SPD33-47) and the result becomes the new space count.
3. The modifier is algebraically added to the current word count (SPD 49-63) and the result becomes the new word count.
4. The condition code is set to reflect the new status of the new space count and new word count.

Affected: (SPD), CC Trap: Push-down stack limit


Condition code settings:
1234 Rcsult of MASP
0000 Space count $>0$, word count $>0$.
$\begin{array}{lllll}0 & 0 & 0 & 1 & \text { Space count }>0 \text {, }\end{array}$ word count $=0$.

0100 Space count $=0$, word count $>0$.

0101 Space count $=0$, word count = 0, modifier $=0$.
${ }^{\dagger}$ For real extended mode of addressing this is a $20-\mathrm{bi} \dagger$ field (12-31); for real and virtual addressing modes it is a 17-bit field (15-31).

If $\mathrm{CC1}$, or CC 3 , or both $\mathrm{CC1}$ and CC 3 are 1's after execution of MSP, the instruction was aborted but the pushdown stack limit trap was inhibited by the trap-on-space inhibit (SPD 32 ), by the trap-on-word inhibit (SPD48), or both. The condition code is set to reflect the reason for aborting as follows:

```
1}20344\mathrm{ Status of space and word counts
- - - 0 Word count>0.
- - 1 Word count = 0.
- - 0 0 < word count + modifier \leq 2 15}-\textrm{T}
- - 1 - Word count + modifier < 0, and TW = 1 or
        word count + modifier > 215-1, and TW =1.
- 0 - - Space count >0.
- 1 - - Space count = 0.
0 - - 0 \leq space count - modifier < 2 15-1.
1 - - Space count -modifier < 0, and TS = 1 or
        space count - modifier > 215-1, and TS = 1.
```


## PUSH-DOWN INSTRUCTIONS (PRIVILEGED)

The computer has two privileged push-down instructions: PUSH STATUS (PSS) and PULL STATUS (PLS). These two instructions and a Status Stack Pointer Doubleword facilitate the storing (pushing) or loading (pulling) of a particular environment (contents of 16 general registers and Program Status Words) into or out of a memory stack.

## STATUS STACK POINTER DOUBLEWORD

The Status Stack Pointer Doubleword (SSPD) always resides in real memory locations 0 and 1 and is dedicated for PSS and PLS instructions. The format of parameters contained within the Status Stack Pointer Doubleword are as follows:

Real Memory Location 0:


Real Memory Location 1:


## TOP OF STACK ADDRESS

The Top of Stack Address (TSA) is always a 20-bit real memory word address and is never mapped. Depending upon
programming considerations, the initial TSA is a specific value either as the result of a Mode 0, WRITE DIRECT instruction or as the result of a PSS or PLS instruction, as described below.

During each PSS instruction, the memory stack is accessed 28 times and the TSA is incremented by 1 before each access. The first memory stack location accessed has a relative address equal to the initial TSA plus $1, \ldots$, and the 28 th memory stack location accessed has a relative address equal to the initial TSA plus 28 . Although 28 memory stack locations are accessed in an ascending sequence, only 20 locations (as selected by the hardware) will contain the basic processor environment. Eight locations (whose contents are designated as "indeterminate", in Figure 12) are reserved and must not be used.

For each PLS instruction, access to the memory stack is contingent upon the Word Count as described subsequently. If access is permitted, the memory stack is accessed 28 times and the TSA is decremented by 1 after each access. The first memory stack location accessed by a PLS instruction has a relative address equal to the initial TSA, the second memory stack location accessed has a relative address equal to the initial TSA minus $1, \ldots$, and the 28 th memory stack location accessed has a relative address equal to the initial TSA minus 27. Although 28 memory stack locations are accessed in a descending sequence, the hardware selects and pulls the contents of only 20 locations containing valid information, as shown in Figure 12, and loaded into the general registers and PSWs. The contents of eight locations designated as indeterminate are ignored.

If the terminal (last) TSA for a PSS or PLS instruction is not modified by a Mode 0 WRITE DIRECT instruction, it may be used as the initial TSA for a subsequent PSS or PLS instruction. Each PSS instruction causes the memory stack to be increased by 28 word locations and each PLS instruction causes the memory stack to be decreased by 28 word locations. The information is pushed and pulled on a last-in, first-out basis.

Note: The PLS instruction is contingent upon the Word Count value, as described below.

## SPACE COUNT

The Space Count field (bit positions 33-47) of the Status Stack Pointer Doubleword is a 15-bit counter that may contain a value of 0 through 32,767. Depending upon programming considerations, the initial Space Count is a specific value either as the result of executing a Mode 0 , WRITE DIRECT instruction or a PLS or PSS instruction.

During a PSS instruction, the Space Count is decremented by 1 for each word pushed into the memory stack. If the Space Count is decremented to a value of zero before all the words have been pushed, the PSS instruction continues (i.e., no trapping occurs). The environment is stored into

tAs a function of the hardware, the contents of these 8 locations are in-
determinate after a PSS instruction and ignored by a PLS instruction. These
locations are reserved for future enhancements and must not be used.

Figure 12. Typical 28-Word Portion of Memory Stack for PSS and PLS
appropriate memory stack locations as specified by the TSA; however, subsequent values of the Space Count are indeterminate.

During a PLS instruction, the Space Count is incremented by 1 for each word pulled from the memory stack. If the Space Count is incremented beyond a value of 32,767, bit position 32 is set to 1 (signifying an overflow condition); however, the PLS instruction continues (i.e., no trapping occurs).

Note: Once bit position 32 has been set to a 1 , it can be reset to a 0 only by executing a Mode 0 , WRITE DIRECT instruction. That is, bit position 32 can not be reset to a 0 by the decrementing process performed during a PSS instruction.

## WORD COUNT

The Word Count field (bit positions 49-63) of the Status Stack Pointer Doubleword is a 15 -bit counter that may contain a value of 0 through 32,767. Depending upon programming considerations, the initial Word Count is a specific value either as the result of executing a Mode 0 , WRITE DIRECT instruction or as the result of executing a PSS or PLS instruction.

During a PSS instruction, the Word Count is incremented by 1 fui euchin woid pushica into the momery stack. Thes, the terminal Word Count for a PSS instruction exceeds the initial Word Count by 28. If the Word Count value exceeds 32,767 , bit position 48 is set to a 1 (signifying that an overflow condition has occurred); however, the PSS instruction continues the stacking operation (i.e., no trapping occurs).

If the initial Word Count for a PLS instruction is equal to or greater than 28, the Word Count is decremented by 1 for each word pulled from the memory stack and the terminal Word Count will be 28 less than the initial Word Count. Note that if bit position 48 was set to a 1 by a PSS instruction previously, it can not be reset to a 0 by the decrementing performed during a PLS instruction.

If the initial Word Count for a PLS instruction is equal to zero, the parameters within the Status Stack Pointer Doubleword are neither effective nor affected by the PLS instruction. However, default PSWs are loaded from real memory locations 2 and 3.

If the initial Word Count for a PLS instruction is less than 28 and not equal to zero, the other parameters of the Status Stack Pointer Doubleword are not effective and none of the parameters are affected by the PLS instruction. Instead the BP traps to location X'4D' (instruction exception trap) and TCC2 is set.
(Doubleword index alignment, privileged)

|  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $x$ | OD | ${ }^{9}$ | 0 | X | Reference address |



PUSH STATUS loads new Program Status Words from an effective doubleword location and stores the current environment (current Program Status Words and contents of all 16 general registers) into a memory stack, as defined by the Status Stack Pointer Doubleword. Note that the reference address points to the memory location of the new PSWs.

The PSS instruction is used for three types of operations: as a normal instruction in an ongoing program; as an interrupt instruction; and as a trap instruction. The effective address of a PSS instruction is generated in one of the following ways:

PSS - normal instruction (see first instruction diagram)
When a PSS instruction is encountered in the course of execution of normal programs, the effective address is generated according to the rules for addressing then in effect as described by the currently active PSWs; that is, the basic processor is operating in real, real extended, or virtual addressing mode. The flags in bit positions 9 and 10 have no effect and must be coded as zeros.

PSS - interrupt instruction (see second instruction diagram)
A PSS instruction (in an interrupt location) executed as a result of an interrupt is called an interrupt instruction. In the interrupt execution sequence, the 20-bit reference address is always real, independent of the map invoking bit in the PSWs. There is no indexing possible since the designator field is preempted by the reference address. Indirect addressing is permitted with precisely the same constraints. The indirect address word contains a 20 -bit real address with the same properties as the reference address described above. The flags in bit positions 9 and 10 have no effect and must be coded as zeros.

PSS - trap instruction (see second instruction diagram)
A PSS instruction (in a trap location) executed as a result of a trap entry operation is called a trap instruction. In a trap execution sequence, the 20-bit reference address may be either a real address or a virtual address according to the map invoking bit in the PSWs. There is no indexing possible since the index field is used for addressing. If indirect addressing is specified, the effective address is generated according to the rules for addressing then in effect as described by the currently active PSWs. Bit positions 9 and 10 must be coded as zeros.

Depending upon the type of addressing, the reference address of the PSS instruction is converted into an effective virtual doubleword address, as described under "PSS Address Calculations", in Chapter 2. Except for the Register Block Pointer field (bit positions 56-59) and the interrupt group inhibit bits (bit positions 37, 38, and 39), the contents of the effective location are always loaded as the new PSWs. If the LP flag (bit 8 of the PSS instruction) is a 1 , the Register Block Pointer of the new PSWs is also loaded. If the LP flag is a 0 , the old Register Block Pointer is retained. The interrupt group inhibit bits of the new PSWs are "ORed" with the corresponding bits of the old PSWs.

The current environment (comprised of 20 words) is stored in memory stack locations having the following relative addresses: initial TSA+1 through initial TSA+16, initial TSA +25 , and initial TSA +26 . Memory stack locations having relative addresses of initial TSA +17 through initial TSA +24 , initial TSA +27 , and initial TSA +28 are reserved and the contents are indeterminate.

The parameters of the Status Stack Pointer Doubleword (as contained within working registers) are appropriately modified to reflect the progress of the PSS instruction and conditions of the memory stack (i.e., the TSA and Word Count are incremented and the Space Count is decremented for each memory word location accessed, as described under Status Stack Pointer Doubleword).

If the Word Count exceeds 32,767 (maximum count for bits 49-63) or if the Space Count is reduced to zero before the PSS instruction is completed, the stacking operations continue until 28 words have been pushed (i.e., no trapping occurs). When the Word Count exceeds 32,767 , bit 48 is set to a 1. Attempting to decrement the Space Count below zero causes the Space Count to become indeterminate.

Affected: (PSWs), CC, Memory Stack, Status Stack Pointer Doubleword.
(PSWs) and CC:

$$
\begin{aligned}
& \mathrm{ED}_{0-3} \longrightarrow \mathrm{CC} \text {; } \\
& E D_{4-7} \longrightarrow F R, F S, F Z, F N ; \\
& E D_{8} \longrightarrow M S ; \\
& E D_{9} \longrightarrow M M ; \\
& E D_{10} \longrightarrow D M_{;} \\
& \mathrm{ED}_{11} \longrightarrow \mathrm{AM} \text {; } \\
& E D_{15-31} \longrightarrow I A_{;} \\
& \mathrm{ED}_{32-35} \longrightarrow \mathrm{WK} \text {; } \\
& \text { ED37-39 ч CI, II, EI } \longrightarrow \mathrm{CI}, \mathrm{II}, \mathrm{EI} \\
& \text { (Note: "u" represents inclusive OR.) } \\
& \mathrm{ED}_{56-59} \longrightarrow \text { RP only if }\left(\mathrm{I}_{8}\right)=1 \\
& \text { ED60 } \longrightarrow \text { RA } \\
& E D_{61} \longrightarrow M A
\end{aligned}
$$

Memory Stack:
(General Register $n$ ) $\longrightarrow$ (initial TSA $+(n+1)$ where $n$ has ascending values from 0 through 15.

PSWI $\longrightarrow$ (initial TSA +25 )
PSW2 $\longrightarrow$ (initial TSA+26)

Status Stack Pointer Doubleword:
TSA $+1 \longrightarrow$ TSA until terminal TSA=initial TSA +28 ; Word Count $+1 \longrightarrow$ Word Count until terminal Word Count $=$ initial Word Count +28 , (if Word Count $>$ 32,767, set bit 48 to 1);

Space Count - $1 \longrightarrow$ Space Count until terminal Space Count = initial Space Count - 28 (if Space Count $=0$, Space Count - 1 is indeterminate).

PLS PULL STATUS (nonaddressing, privileged)


PULL STATUS, in conjunction with the Status Stack Pointer Doubleword, may cause one or more of the following functions to be performed:

1. Selectively load a new environment (PSWs and 16 general registers) from the memory stack; or,
2. Selectively load default PSWs from dedicated memory locations; and,
3. Selectively clear and arm or clear and disarm the highest priority level currently in the active state.

If the initial Word Count of Status Stack Pointer Doubleword is equal to or greater than 28, a new environment is loaded from the memory stack. Twenty eight memory stack locations are accessed in a descending sequence, starting at a location having an address equal to the initial TSA (part of the Status Stack Pointer Doubleword). The hardware selects and loads the contents of 20 memory locations into the general registers and as the PSWs (i.e., the contents of locations having relative addresses of initial TSA-2, initial TSA-3, and initial TSA-12 through initial TSA-27). The contents of 10 memory stack locations (having relative addresses equal to initial TSA, initial TSA-1, and initial TSA-4 through initial TSA-11) are ignored.

Portions of the new PSWs are dependent upon the LP flag (bit 0) of the PLS instruction as weil as the inierrupi group inhibit bits of the old PSWs and the PSWs as pulled from the memory stack. If the LP flag is a 1 , a new Register Block Pointer (as pulled from the memory stack) is loaded as part of the new PSWs. If the LP flag is a 0 , the old Register Block Pointer is retained as the Register Block Pointer for the new PSWs. The new interrupt group inhibit bits (CI,

II, EI) are generated by "ORing" the old CI, II, EI bits with the contents of bits 37,38 , and 39 of the PSWs as pulled from the memory stack.

The clearing and arming or disarming the highest priority interrupt level currently active is dependent upon the coding of the CL and AD flags (bit positions 10 and 11, respectively) of the PLS instruction. If the CL flag is a 0 , the interrupt level is not affected. If the CL flag is a 1 and the AD flag is a 0 , the interrupt level is set to the disarmed state. If the CL flag is a 1 and the AD flag is a 1 , the interrupt level is set to the armed state. Note that if the interrupt level is to be modified (CL flag is set to a 1 ), the instruction may be delayed until the interrupt system is available.

Summary description of $C L$ and $A \bar{D}$ flags and effect on interrupt level and PDF flag follows:

| $\frac{$ Bit Positions  <br> $10(\mathrm{CL})$}{0} | $\frac{11(\mathrm{AD})}{0}$ | No effect upon interrupt level <br> or PDF flag. <br> 0 |
| :---: | :---: | :--- |
| 1 | 1 | Reset PDF flag |
| 1 | 0 | Clear and disarm interrupt level |
| 1 | 1 | Clear and arm interrupt level |

If the initial Word Count is zero, default PSWs are loaded from real memory locations 2 and 3 and the other parameters of the Status Stack Pointer Doubleword are not effective and no parameters are affected.

Portions of the new PSWs (interrupt inhibit group bits and the Register Block Pointer) may be selected or generated in the following manner:

If the LP flag (bit 8) of the PSL instruction is a 1, the new Register Block Pointer will be as obtained from the default PSWs. If the LP flag is a 0, the Register Block Pointer of the old PSWs is retained as the Register Block Pointer for the new PSWs.

The CI, II, and EI bits of the old PSWs are "ORed" with the contents of bit positions 37, 38, and 39 of the default PSWs to generate the CI, II, and EI bits of the new PSWs.

Depending upon the coding of the CL and AD flags (bit positions 10 and 11 , respectively) of the PLS instruction, the highest priority interrupt level currently in the active state may be modified. If the CL flag is a 0 , the interrupt level is not affected. If the CL flag is a 1 and the AD flag is a 0 , the interrupt level is cleared and placed into the disarmed state. If the CL flag is a 1 and the AD flag is a 1 , the interrupt level is cleared and placed into the
armed state. Note that if the interrupt level is to be modified (i.e., the CL flag is a 1), the instruction may be delayed until the interrupt system is available.

A summary description of the action on the interrupt level as a function of the CL and AD flag is as follows:

Bit Positions

| $10(\mathrm{CL})$ | $\frac{11(\mathrm{AD})}{1}$ | Function <br> 0 | 0 |
| :---: | :---: | :---: | :--- | | No effect upon interrupt level <br> or PDF flag |
| :--- |
| 0 |

If the initial Word Count within the Status Stack Pointer Doubleword is less than 28 and not equal to 0 , the basic processor traps to location $X^{\prime} 4 D^{+}$(instruction exception trap) without loading-any new status or affecting the parameters of the Status Stack Pointer Doubleword and the ICC2 bit is set to 1 .

Affected: If word count $\geq 28$, Traps: Instruction excep(PSWs), CC, tion, if word count Status Stack Pointer is less than 28 and Doubleword not 0; nonexistent Interrupt System if instruction if (I) $10=1$. bit $0=1$.

If word count $=0$, (PSWs), CC, and Inferrupt System, if $\mathrm{I}(10)=1$.
(PSWs) and CC

$$
\begin{aligned}
& \mathrm{ED}_{0-3} \longrightarrow \mathrm{CC} \text {; } \\
& \mathrm{ED}_{5-7} \longrightarrow \mathrm{FS}, \mathrm{FZ}, \mathrm{FN} \text {; } \\
& E D_{8} \longrightarrow M S ; \\
& E D_{9} \longrightarrow M M ; \\
& { }^{E D}{ }_{10} \longrightarrow D M ; \\
& E D_{11} \longrightarrow A M \text {; } \\
& \mathrm{ED}_{15-31} \longrightarrow \mathrm{IA} ; \\
& \mathrm{ED}_{32-35} \longrightarrow \mathrm{WK} \\
& \text { ED37-39 } \text { © CI, II, EI } \longrightarrow C I, ~ I I, ~ E I ~ \\
& \text { (Note: "u" represents inclusive OR.) } \\
& E D_{56-59} \longrightarrow R P \text { only if }(\mathrm{I})_{8}=1 \\
& \mathrm{ED}_{60} \longrightarrow \mathrm{RA} \\
& \mathrm{ED}_{61} \longrightarrow \mathrm{MA}
\end{aligned}
$$

Note: If the word count $\geq 28$, the effective doubleword (ED) is pulled from memory stack locations (relative addresses initial TSA-24 and initial TSA+1). If the word count $=0$, the ED is pulled from real memory locations 2 and 3 .

Status Stack Pointer Doubleword: (Only if initial Word Count $\geq 28$ )

TSA-1 $\longrightarrow$ TSA until terminal TSA = initial TSA-28; Word Count $-1 \longrightarrow$ Word Count until terminal Word Count = initial Word Count - 28 (if initial Word Count $>32,767$, bit 48 not affected); and,

Space Count + $1 \longrightarrow$ Space Count until terminal Space Count $=$ initial Space Count +28 (if Space Count $>32,767$, then set bit 32 to 1 ).

Interrupt System:
If $(\mathrm{I})_{10}=1$ and $\left(\mathrm{I}_{1}{ }_{1}=1\right.$, clear and arm interrupt level.

If (I) $10=1$ and (I) $11=0$, clear and disarm interrupt level.

## EXECUTE/BRANCH INSTRUCTIONS

The following instructions can cause the basic processor to execute instructions in an order other than that of sequentially ascending instruction addresses:

| Instruction Name | Mnemonic |
| :--- | :--- |
| Execute | EXU |
| Branch on Conditions Set | BCS |
| Branch on Conditions Reset | BIR |
| Branch on Incrementing Register | BDR |
| Branch on Decrementing Register | BAL |

The EXECUTE instruction can be used to insert another instruction into the program sequence, and the branch instructions can be used to alter the program sequence, either unconditionally or conditionally. If a branch is unconditiona! (or conditiona! and the brench condition is satisfied), the instruction pointed to by the effective address of the branch instruction is normally the next instruction to be executed. If a branch is conditional and the condition for the branch is not satisfied, the next instruction is normally taken from the next location, in ascending sequence, after the branch instruction.

## NONALLOWED OPERATION TRAP DURING EXECUTION OF BRANCH INSTRUCTION

The next instruction after a branch instruction may reside in two possible places: the location following the branch instruction or a location designated by the branch instruction. Either of these two locations may be in a protected memory region or in a region that is physically nonexistent. The execution of the branch does not cause a trap unless the instruction that is actually to follow the branch instruction is in a protected or nonexistent memory region. Traps do not occur because of any anticipation on the part of the hardware.

A nonallowed operation trap condition during execution of a branch instruction will occur for the following reasons:

1. The branch instruction is indirectly addressed and the branch conditions are satisfied, but the address of the location containing the direct address is either nonexistent or unavailable for read access fo the program in the slave mode.
2. The branch instruction is unconditional (or the branch is conditional and the condition for the branch is satisfied), but the effective address of the branch instruction is either nonexistent or unavailable for instruction or read access to the program (in slave or masterprotected mode).

If either of the above situations occurs, the basic processor aborts execution of the branch instruction and executes a nonallowed operation trap.

Prior to the time that an instruction is accessed from memory for execution, bit positions 15-31 of the program status words contain the virtual address of the instruction, referred to as the instruction address. At this time, the basic processor traps to location $\mathrm{X}^{\prime} 40^{\prime}$ if the actual address of the instruction is nonexistent or instruction-access protected. If the instruction address is existent and is not instructionaccess protected, the instruction is accessed and the instruction address portion of the program status words is incremented by 1 , so that it now contains the virtual address of the next instruction in sequence (referred to as the updated instruction address).

If a trap condition occurs during the execution sequence of any instruction, the basic processor decrements the updated instruction address by 1 and then traps to the location assigned to the trap condition. If neither a trap condition nor a satisfied branch condition occurs during the execution of an instruction, the next instruction is accessed from the location pointed to by the updated instruction address. If a satisfied branch condition occurs during the execution of a branch instruction (and no trap condition occurs), the next instruction is accessed from the location pointed to by the effective address of the branch instruction.

In the real extended addressing mode, a 20-bit address may be used as a branch address via indexing or indirect addressing. If such a branch address, ( $A$ ), is beyond the first 128 K of real memory, the instruction at (A) will be executed, but the next instruction address will be ( $A+1$ ) in the original 128 K block unless (A) contains a branch instruction. Note that with this exception all instructions executed in the real extended addressing mode must lie in the first 128 K of real memory.

EXU EXECUTE
(word index alignment)

| * | 67 |  | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

EXECUTE causes the basic processor to access the instruction in the location pointed to by the effective address of EXU and execute the subject instruction. The execution of the subject instruction, including the processing of trap and interrupt conditions, is performed exactly as if the subject instruction were initially accessed instead of the EXU instruction. If the subject instruction is another EXU, the basic processor executes the subject instruction pointed to by the effective address of the second EXU as described above. Such "chains" of EXECUTE instructions may be of any length, and are processed (without affecting the updated instruction address) until an instruction other than EXU is encountered. After the final subject instruction is executed, instruction execution proceeds with the next instruction in sequence after the initial EXU (unless the subject instruction is an LPSD or XPSD instruction, or is a branch instruction and the branch condition is satisfied).

If an interrupt activation occurs between the beginning of an EXU instruction (or chain of EXU instructions) and the last interruptible point in the subject instruction, the BP processes the interrupt-servicing routine for the active interrupt level and then returns program control to the EXU instruction (or the initial instruction of a chain of EXU instructions), which is started anew. Note that a program is interruptible after every instruction access, including accesses made with the EXU instruction, and the interruptibility of the subject instruction is the same as the normal interruptibility for that instruction.

If a trap condition occurs between the beginning of an EXU instruction (or chain of EXU instructions) and the completion of the subject instruction, the basic processor traps to the appropriate trap location. The instruction address stored by the XPSD instruction in the trap location is the address of the EXU instruction (or the initial instruction of a chain of EXU instructions).

Affected: $\begin{aligned} & \text { Determined by } \\ & \text { subject instruction }\end{aligned} \quad$ Traps: $\begin{aligned} & \text { Determined by } \\ & \text { subject instruction }\end{aligned}$

Condition code settings: Determined by subject instruction.

BRANCH ON CONDITIONS SET
(Word index alignment)

| * | 69 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

BRANCH ON CONDITIONS SET forms the logical product (AND) of the $R$ field of the instruction word and the current condition code. If the logical product is nonzero, the branch condition is satisfied and instruction execution proceeds with the instruction pointed to by the effective address of the BCS instruction. However, if the logical product is zero, the branch condition is unsatisfied and instruction execution then proceeds with the next instruction in normal sequence.

Affected: (IA) if $C C \cap R \neq 0$
If $\mathrm{CC} \cap(\mathrm{I})_{8-11} \neq 0, \mathrm{EVA}_{15-31} \longrightarrow \mathrm{IA}$
If $\mathrm{CC} \cap(\mathrm{I})_{8-11}=0$, IA not affected

If the $R$ field of $B C S$ is 0 , the next instruction to be executed after BCS is always the next instruction in ascending sequence, thus effectively producing a "no operation" instruction.

## BCR BRANCH ON CONDITIONS RESET (Word index alignment)

| * | 68 | R | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |

BRANCH ON CONDITIONS RESET formsthe logical product (AND) of the R field of the instruction word and the current condition code. If the logical product is zero, the branch condition is satisfied and instruction execution then proceeds with the instruction pointed to by the effective address of the $B C R$ instruction. However, if the logical product is nonzero, the branch condition is unsatisfied and instruction execution then proceeds with the next instruction in normal sequence.

Affected: (IA) if $C C \cap R=0$
If $\mathrm{CC} \cap(\mathrm{I})_{8-11}=0, \mathrm{EVA}_{15-13} \longrightarrow \mathrm{IA}$
If $C C \cap()_{8-11} \neq 0$, IA not affected

If the $R$ field of $B C R$ is 0 , the next instruction to be executed after BCR is always the instruction located at the effective address of $B C R$, thus effectively producing a "branch unconditionally" instruction.

BRANCH ON INCREMENTING REGISTER (Word index alignment)

| * | 65 | R | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |

BRANCH ON INCREMENTING REGISTER computes the effective virtual address and then increments the contents of general register R by 1 . If the result is a negative value, the branch condition is satisfied and instruction execution then proceeds with the instruction pointed to by the effective address of the BIR instruction. However, if the result is zero or a positive value, the branch condition is not satisfied and instruction execution proceeds with the next instruction in normal sequence.

Affected: (R),(IA)
$(R)+1 \longrightarrow R$
If $(R)_{0}=1, \mathrm{EVA}_{15-31} \longrightarrow \mathrm{IA}$
If $(\mathrm{R})_{0}=0$, IA not affected
If the branch condition is satisfied and if the effective address of BIR is either unavailable to the program (slave or master-protected mode) for instruction access or is nonexistent, the basic processor aborts execution of the BIR instruction and traps to location $X^{\prime} 40^{\prime}$. In this case, the instruction address stored by the XPSD instruction in location $X^{\prime} 40^{\prime}$ is the virtual address of the aborted BIR instruction. If the basic processor traps because of instruction access protection, register $R$ will contain the value that existed just before the BIR execution (i.e., updated instruction address). If a memory parity error occurs due to the accessing of the instruction to which the program is branching, the basic processor aborts execution of the BIR and traps to location $X^{\prime} 4 C^{\prime}$ with register $R$ unchanged.

## BDR BRANCH ON DECREMENTING REGISTER

 (Word index alignment)| $\therefore$ | 064 | $\overline{\mathrm{K}}$ | $\chi$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |

BRANCH ON DECREMENTING REGISTER computes the effective virtual address and then decrements the contents of general register R by 1 . If the result is a positive value, the branch condition is satisfied and instruction execution then proceeds with the instruction pointed to by the effective address of the BDR instruction. However, if the result is zero or a negative value, the branch condition is unsatisfied and instruction execution proceeds with the next instruction in normal sequence.

Affected: (R), (IA)
$(R)-1 \longrightarrow R$
If $(R)_{0}=0$ and $(R)_{1-31} \neq 0$, EVA $_{15-31} \longrightarrow$ IA
If $(R)_{0}=1$ and $(R)=0$, IA not affected

If the effective address of $B D R$ is unavailable to the program (slave or master-protected mode) for instructionaccess and the branch condition is satisfied, or if the effective address of BDR is nonexistent, the basic processor aborts execution of the BDR instruction and traps to location $X^{\prime} 40^{\prime}$. In this case, the instruction address stored by the XPSD instruction in location $X^{\prime} 40^{\prime}$ is the virtual address of the aborted BDR instruction. If the basic processor traps because of instruction access protection, register R will contain the value that existed just before the BDR instruction. If a memory parity error occurs due to the accessing of the instruction to which the program is branching, the basic processor aborts execution of the BDR and traps to location $X^{\prime} 4 C^{\prime}$ with register $R$ unchanged.

## BAL BRANCH AND LINK <br> (Word index alignment)



BRANCH AND LINK determines the effective virtual address, loads the updated instruction address (the virtual address of the next instruction in normal sequence after the BAL instruction) into bit positions 15-31 of general register $R$, clears bit positions $0-14$ of register $R$ to 0 's and then replaces the updated instruction address with the effective virtual address. Instruction execution proceeds with the instruction pointed to by the effective address of the BAL instruction.

The BAL instruction in real extended addressing will store the full address of the next instruction in the specified $R$ register. Positions $0-9$ of the specified register will be set equal to zero.

Affecied: (R), (İA)

IA $\longrightarrow \mathrm{R}_{15-31} ; 0 \longrightarrow \mathrm{R}_{0-14} ; \mathrm{EVA}_{15-31} \longrightarrow \mathrm{IA}$

If the effective address of $B A L$ is unavailable to the program (slave or master-protected mode) for instruction access and the branch condition is satisfied, or if the effective address of BAL is nonexistent, the basic processor aborts execution of the BAL instruction and traps to location $X^{\prime} 40^{\prime}$ (nonallowed operation trap). In this case, the instruction address stored by the XPSD instruction in location $X^{\prime} 40^{\prime}$ is the virtual address of the aborted BAL instruction. If the basic processor traps because of instruction access protection, register R will contain the updated instruction address. If a memory parity error occurs due to the accessing of the instruction to which the program is branching, the basic processor aborts execution of the BAL and traps to location $X^{\prime} 4 C^{\prime}$ with register $R$ changed to the updated instruction address.

## CALL INSTRUCTIONS

Each of the four CALL instructions causes the basic processor to trap to a specific location for the next instruction in sequence. The four CALL instructions, their mnemonics, and the locations to which the basic processor traps are:

| Instruction <br> Name |  | Trap <br> Location |
| :---: | :---: | :---: |
| CALL 1 | CAL1 | $X^{\prime} 48^{\prime}$ |
| CALL 2 | CAL2 | $X^{\prime} 49^{\prime}$ |
| CALL 3 | CAL3 | $X^{\prime} 4 A^{\prime}$ |
| CALL 4 | CAL4 | $X^{\prime} 4 \mathrm{~B}^{\prime}$ |

Each of these four trap locations must conta in an EXCHANGE PROGRAM STATUS WORDS (XPSD) instruction. Execution of XPSD in the trap location for a CALL instruction is described under "Control Instructions, XPSD Exchange Program Status Words". If the XPSD instruction is coded with bit position 9 set to 1 , the next instruction (executed after the XPSD) is taken from one of 16 possible locations, as designated by the value in the $R$ field of the CALL instruction. Each of the 16 locations may contain an instruction that causes the basic processor to branch to a specific routine; thus, the four CALL instructions can be used to enter any of as many as 64 unique routines.

The effective address of either a direct or indirect CALL instruction is not used for a memory reference and, therefore, cannot cause a trap.

CALI CALL 1
(Word index alignment)


CALL 1 causes the basic processor to trap to location $X^{\prime} 48^{\prime}$.

CAL2 CALL 2
(Word index alignment)

| $*$ | 05 | $R$ | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |
| 0 | $2^{2} 3145$ | 6 | 78 |  |

CALL 2 causes the basic processor to trap to location $X^{\prime} 49^{\prime}$.

CAL3 CALL 3
(Word index alignment)


CALL 3 causes the basic processor to trap to location $X^{\prime} 4 A^{\prime}$.

CALL 4
(Word index alignment)

| * | 07 | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

CALL 4 causes the basic processor to trap to location $X^{\prime} 4 \mathrm{~B}^{\prime}$.

## CONTROL INSTRUCTIONS

The following privileged instructions are used to control the basic operating conditions of the basic processor:

| Instruction Name | Mnemonic |
| :--- | :--- |
| Load Program Status Words | LPSD |
| Exchange Program Status Words | XPSD |
| Load Register Pointer | LRP |
| Move to Memory Control | MMC |
| Load Real Address | LRA |
| Load Memory Status | LMS |
| Wait | WAIT |
| Read Direct | RD |
| Write Direct | WD |

If execution of any control instruction is attempted while the basic processor is in the slave mode (i.e., while bit 8 of the current program status words is a 1 ), the basic processor unconditionally traps to location $X^{\prime} 40^{\prime}$ prior to executing the instruction.

## PROGRAM STATUS WORDS

Program status words have the following structure when stored in memory:



| Bit Position | Designation. | Function |
| :---: | :---: | :---: |
| 8 | MS | Master/slave mode control |
| 9 | MM | Memory map mode control |
| 10 | DM | Decimal arithmetic trap mask |
| 11 | AM | Fixed-point arithmetic overflow trap mask |
| 15-31 | IA | Instruction address |
| 32-35 | WK | Write key |
| 37 | Cl | Counter interrupt group inhibit |
| 38 | II | I/O interrupt group inhibit |
| 39 | EI | External interrupt inhibit |
| 56-59 | RP | Register pointer |
| 60 | RA | Register altered |
| 61 | MA | Mode altered |

The detailed functions of the various portions of the program status words are described in Chapter 2, "Program Status Words".

LPSD LOAD PROGRAM STATUS WORDS
(Doubleword index alignment, privileged)


LOAD PROGRAMSTATUS WORDS replaces bits 0 through 39, 60 and 61 of the current program status words with bits 0 through 39, 60 and 61 of the effective doubleword.

Control bits used in the LPSD instruction are:

| Bit |  |  |
| :---: | :---: | :---: |
| Position | Designation | Control Function |
| 8 | LP | Load pointer control |
| 10 | CL | Clearing of interrupt level |
| 11 | AD | Armed/disarmed state |

The following conditional operations are performed:

1. If bit position 8 (LP) of LPSD contains a 1, bits 56 through 59 (register pointer) of the current program status words are replaced by bits 56 through 59 of the effective doubleword; if bit 8 of LPSD is a 0 , the cuirent register pointer value remains unchanged.
2. If bit position $10(\mathrm{CL})$ of LPSD contains a 1 , the highest priority interrupt level currently in the active state is cleared (i.e., reset to either the armed state or the disarmed state); the interrupt level. is armed if bit 11 (AD)
of LPSD is a 1 , or is disarmed if bit 11 of LPSD is a 0. If bit 10 of LPSD is a 0 , no interrupt level is affected in any way, regardless of whether bit 11 of LPSD is 1 or 0 . If bit 10 of the LPSD is a 0 and bit 11 of LPSD is 1 , the PDF flag is cleared. (Interrupt levels are described in detail in Chapter 2, "Interrupt System".)

Bit position

| $\frac{10(C L)}{1}$ | $\frac{11(A D)}{0}$ |  |
| :---: | :---: | :--- |
| 1 | 0 |  |
| 1 | 1 |  |
| Clear and disarm interrupt level. |  |  |
| 0 | 1 | Clear and arm interrupt level. |
| 0 | 0 | No control action. |

3. The PDF flag is normally reset by the last instruction of a trap routine, which is an LPSD instruction having bit 10 equal to 0 and bit 11 equal to 1 .

These portions of the effective doubleword that correspond to undefined fields in the program status words are ignored.

Affected: (PSWs), interrupt system if (I) $10=1$
$\mathrm{ED}_{0-3} \longrightarrow \mathrm{CC} ; \mathrm{ED}_{5-7} \longrightarrow \mathrm{FS}, \mathrm{FX}, \mathrm{FN} ;$
$E D_{8} \longrightarrow \mathrm{MS} ; \mathrm{ED}_{9} \longrightarrow \mathrm{MM} ;$
$\mathrm{ED}_{10} \longrightarrow \mathrm{DM}_{;} \mathrm{ED}_{11} \longrightarrow \mathrm{AM} ;$
$\mathrm{ED}_{15-31} \longrightarrow \mathrm{IA} ; \mathrm{ED}_{32-35} \longrightarrow \mathrm{WK}_{\mathrm{F}}$
$\mathrm{ED}_{37-39} \longrightarrow \mathrm{CI}, \mathrm{II}, \mathrm{EI} ;$ if $(\mathrm{I})_{8}=1, \mathrm{ED}_{56-59} \longrightarrow \mathrm{RP}$
$\mathrm{ED}_{60} \longrightarrow \mathrm{RA} ; \mathrm{ED}_{61} \longrightarrow \mathrm{MA}$

If (I) $10=1$ and (I) $11=1$, clear and amin interivipt
If (I) $10=1$ and (I) ${ }_{11}=0$, clear and disarm interrupt

EXCHANGE PROGRAM STATUS WORDS
(Doubleword index alignment, privileged)


EXCHANGE PROGRAM STATUS WORDS stores the currently active PSWs in the doubleword location addressed by the effective address of the XPSD instruction. The following doubleword is then accessed from memory and loaded into the active PSWs registers.

The XPSD instruction is used for three distinct types of operations: as a normal instruction in an ongoing program; as an interrupt instruction; and as a trap instruction.

Control bits used in the XPSD instructions are:

| Bit <br> Position | Control <br> 8 | Designation <br> Function | Where used |
| :--- | :--- | :--- | :--- |
| Load pointer <br> control | All XPSDs |  |  |
| 9 | AI | Address Increment | Trap XPSD |
| 10 | AT | Addressing type | All XPSDs |

The effective address of an XPSD instruction is generated in one of the following ways:

## XPSD (normal instruction)

When an XPSD instruction is encountered in the course of execution of normal programs, the AT (bit 10) of the instruction determines the type of addressing to be used.

If $\mathrm{AT}=0$, the reference address is 20 bits (12-31). Indexing is not allowed. Indirect addressing is allowed with the same constraints as the reference address. Addressing is always real, independent of the current PSWs.

If $\mathrm{AT}=1$, the reference address is 17 bits (15-31). Address calculations are according to standard addressing rules as determined by the current PSWs. Indexing and indirect addressing are allowed.

XPSD (interrupt instruction)
An XPSD instruction (in an interrupt location) executed as a result of an interrupt is called an interrupt instruction. The type of addressing to be used is determined by the basic processor mode and the AT (bit 10) of the instruction.

In the extended addressing mode ( $M A=1$ and $M M=0$ ), the AT bit is used to determine the type of addressing to be used. If $\mathrm{AT}=0$, the reference address is 20 bits (12-31). Indexing is not allowed. Indirectaddressing is allowed with the same constraints as the reference address. Addressing is always real, independent of the current PSWs. If AT $=1$, the reference address is 17 bits (15-31). Address calculations are according to standard addressing rules as determined by the current PSWs. Indexing and indirect addressing are allowed.

When the addressing mode is not extended addressing, the reference address is 20 bits (12-31). If AT $=0$, indexing is not allowed. Indirect addressing is allowed with the same constraints as the reference address. Addressing is always real, independent of the current PSWs. If AT $=1$, the 20-bit reference address is subject to PSWs bit 9, as is the contents of the indirect address if indirect is specified.

## $\underline{\text { XPSD (trap instruction) }}$

An XPSD instruction (in a trap location) executed as a result of a trap entry operation is called a trap instruction. Addressing is the same as for the interrupt XPSD (see above).

The following additional operations are performed on the new program status words if, and only if, the XPSD is being executed as the result of a nonallowed operation (trap to location $X^{\prime} 40^{\prime}$ ) or a CALL instruction (trap to location $X^{\prime} 48^{\prime}$, $X^{\prime} 499^{\prime}, X^{\prime} 4 A^{\prime}$, or $X^{\prime} 4 B^{\prime}$ ):

1. Nonallowed operations - the following additional functions are performed when XPSD is being executed as a result of a trap to location $X^{\prime} 40$ ':
a. Nonexistent instruction - if the reason for the trap condition is an attempt to execute a nonexistent instruction, bit position 0 of the new program status words (CC1) is set to 1. Then, if bit 9 (AI) of XPSD is a 1, bit positions $15-31$ of the new program status words (next instruction address) are incremented by 8.
b. Nonexistent memory address - if the reason for the trap condition is an attempt to access or write into a nonexistent memory region, bit position 1 of the new program status words (CC2) is set to 1 . Then, if bit 9 of XPSD is a 1 , the instruction address portion of the new program status words is incremented by 4 .
c. Privileged instruction violation - if the reason for the trap condition is an attempt to execute a privileged instruction while the basic processor is in the slave mode, bit position 2 of the new program status words (CC3) is set to 1 . Then, if bit position 0 of XPSD is 1 , the instruction address portion of the new program status words is incremented by 2.
d. Memory protection violation - if the reason for the trap condition is an attempt to read from or write into a memory region to which the program does not have proper access, bit position 3 of the new program status words (CC4) is set to 1 . Then, if bit 9 of XPSD is a 1, the instruction address portion of the new program status words is incremented by 1 .

There are certain circumstances under which two of the above nonallowed operations can occur simultaneously. The following operation codes (including their counterparts) are considered to be both nonexistent and privileged: $X^{\prime} O C^{\prime}$ and $X^{\prime} O D^{\prime}$. If either of these operation codes is used as an instruction while the basic processor is in the slave or master-protected mode, CC 1 and CC3 are both set to 1 's; if bit 9 of XPSD is a 1 , the instruction address portion of the new program status words is incremented by 10 . If an attempt is made to access or write into a memory region that is both nonexistent and prohibited to the program by means of the
memory control feature, CC2 and CC4 are both set to 1's; if bit 9 of XPSD is a 1, the instruction address of the new program status words is incremented by 5 .
2. CALL instructions - the following additional functions are performed when XPSD is being executed as a result of a trap to location $X^{\prime} 48^{\prime}, X^{\prime} 49^{\prime}, X^{\prime} 4 A^{\prime}$, or $X^{\prime} 4 B^{\prime}$.
a. The $R$ field of the CALL instruction causing the trap is logically inclusively ORed into bit positions 0-3 (CC) of the new PSWs.
b. If bit position 9 of XPSD contains a 1, the R field of the CALL instruction causing the trap is added to the instruction address portion of the new PSWs.
3. Watchdog timer, parity error, or instruction exception trap - the following additional functions are performed when XPSD is being executed as a result of a trap to location $X^{\prime} 46^{\prime}, X^{\prime} 4 C^{\prime}$, or $X^{\prime} 4 D^{\prime}$, respectively.
a. The contents of TCC 1-4 are logically inclusively ORed into bit positions 0-3 (CC) of the new PSWs.
b. If bit position 9 of XPSD contains a 1, the contents of TCC 1-4 are added to the instruction address portion of the new PSWs.

If bit position 9 of XPSD contains a 0 , the instruction address portion of the new PSWs always remains at the value established by the second effective doubleword. Bit position 9 of XPSD is effective only if the instruction is being executed as the result of a nonallowed operation, CALL instruction watchdog timer, parity error, or instruction exception trap. Bit position 9 of XPSD must be coded with a 0 in all other cases; otherwise, the results of the XPSD instruction are undefined.

The current program status words are stored in the doubleword location pointed to by the effective address of XPSD in the following form:

Program Status Words


The eurrent program status words (as illustiated above) are replaced by new program status words as described below.

1. The effective address of XPSD is incremented by 2 so that it points to the next doubleword location. The contents of the next doubleword location are referred to as the second effective doubleword, or ED2.
2. Bits $0-35,60$, and 61 of the current program status words are unconditionally replaced by bits $0-35,60$, and 61 of the second effective doubleword. The affected portions of the program status words are:

| Bit |  |  |
| :---: | :---: | :---: |
| Position | Designation | Function |
| 0-3 | CC | Condition code |
| 4-7 | $\begin{gathered} \mathrm{FR}, \mathrm{FS}, \mathrm{FZ}, \\ \mathrm{FN} \end{gathered}$ | Floating control |
| 8 | MS | Master/slave mode control |
| 9 | MM | Mapping mode control |
| 10 | DM | Decimal arithmetic trap mask |
| 11 | AM | Fixed-point arithmetic trap mask |
| 15-31 | IA | Instruction address (real or virtual) |
| 32-35 | WK | Write key |
| 60 | RA | Register altered |
| 61 | MA | Mode altered |

3. A logical inclusive $O R$ is performed between bits 37 through 39 of the current program status words and bits 37 through 39 of the second effective doubleword.

| Bit |  |  |
| :---: | :---: | :---: |
| Position | Designation | Function |
| 37 | Cl | Counter interrupt inhibit |
| 38 | II | I/O interrupt inhibit |
| 39 | EI | External interrupt inhibit |

If any (or all) of bits 37,38 , or 39 of the second effective doubleword are 0 's, the corresponding bits in the current program status words remain unchanged; if any (or all) of bits 37,38 , or 39 of the second effective doubleword are l's, the corresponding bits in the current program status words are set to l's. See "Interrupt System", Chapter 2, for a detailed discussion of the interrupt inhibits.
4. If bit position 8 (LP) of XPSD contains a 1 , bits 58 and 59 (register pointer) of the current program status words are replaced by bits 58 and 59 of the second effeciive doubleword; if bit 8 of XPSD is a 0 , the current register pointer value remains unchanged.

Affected: (EDL),(PSWs)
If (I) $10=1$, trap or interrupt instructions only, effective address is subject to current active addressing mode.

If (I) $10=0$, trap or interrupt instructions only, effective address is independent of current active addressing mode.

PSD $\longrightarrow$ EDL
$\mathrm{ED2}_{0-3} \longrightarrow \mathrm{CC} ; \mathrm{ED}_{4} 4-7 \longrightarrow \mathrm{FR}, \mathrm{FS}, \mathrm{FZ}, \mathrm{FN}$
$E D 2_{8} \longrightarrow M S ; E D 2_{9} \longrightarrow M M$
$\mathrm{ED}^{10} \longrightarrow \mathrm{DM} ; \mathrm{ED}_{11} \longrightarrow \mathrm{AM} ; \mathrm{ED}_{15-31} \longrightarrow \mathrm{IA}$
ED2 $22-35 \rightarrow W K$
ED2 $3_{37-39}$ ч CI, II, EI $\longrightarrow \mathrm{CI}, \mathrm{II}, \mathrm{EI}$
If $(\mathrm{I})_{8}=1, E D 2_{56-59} \longrightarrow R P$
If $(\mathrm{I})_{8}=0, \mathrm{RP}$ not affected
$\mathrm{ED}_{6}{ }_{60} \longrightarrow \mathrm{RA}$
$E D{ }^{6} 1 \longrightarrow M A$
If nonexistent instruction, $1 \longrightarrow \mathrm{CCl}$ then, if $(\mathrm{I})_{9}=1$, $\mathrm{IA}+8 \longrightarrow \mathrm{IA}$

If nonexistent memory address, $1 \longrightarrow$ CC2 then, if $(\mathrm{I})_{9}=1, \mathrm{IA}+4 \longrightarrow \mathrm{IA}$

If privileged instruction violation, $1 \longrightarrow \mathrm{CC} 3$ then, if $(\mathrm{I})_{9}=1, \mathrm{IA}+2 \longrightarrow \mathrm{IA}$

If memory protection violation, $1 \longrightarrow \mathrm{CC} 4$ then, if $(\mathrm{I})_{9}=1$, $\mathrm{IA}+1 \longrightarrow \mathrm{IA}$

If CALL instruction, $\mathrm{CC} \cup \mathrm{CALL}_{8-11} \longrightarrow \mathrm{CC}$ then, if $(\mathrm{I})_{9}=1, \mathrm{IA}+\mathrm{CALL}_{8-11} \longrightarrow \mathrm{IA}$

If $(\mathrm{I})_{9}=0, \mathrm{IA}$ not affected
If watchdog timer, parity error, or instruction exception trap, ED2 $0-3$ U TCC 1-4 $\longrightarrow \mathrm{CC1}-4$ then, if $(\mathrm{I})_{9}=1$, $\mathrm{IA}+\mathrm{TCCI-4} \longrightarrow \mathrm{IA}$

LRP LOAD REGISTER POINTER
(Word index alignment, privileged)


LOAD REGISTER POINTER loads bits 24-27 of the effective word into the register pointer (RP) portion of the current program status words. Bit positions 0 through 23 and 28 through 31 of the effective word are ignored, and no other portion of the program status words is affected. If the LOAD REGISTER POINTER instruction attempts to load the register pointer with a value that points to a nonexistent block of general registers, the basic processor traps to location $X^{\prime} 4 D^{\prime}$.
Affected: RP Trap: Instruction exception
$\mathrm{EW}_{24-27} \longrightarrow \mathrm{RP}$

## MOVE TO MEMORY CONTROL INSTRUCTIONS

The following instructions may be used to selectively move a string of control words from a control image area to specified memory control registers:

| Instruction Name | Mnemonics |
| :--- | :--- |
| Move to Memory Control | MMC |
| Load Map (8-bit format) | LMAP |
| Load Map (11-bit format) | LMAPRE |
| Load Protection Code | LPC |
| Load Locks (2-bit format) | LLOCKS |
| Load Locks (4-bit format) | LLOCKSE |
| MMC $\quad$MOVE TO MEMORY CONTROL <br> (Word index alignment, privileged, continue <br> after interrupt) |  |



The MMC instruction may be used to perform any move to memory control operation. Depending upon the type and format of the control image, the move to memory control operation may be performed either by an MMC instruction with a specific value in the controi field (bit position $\overline{\mathrm{Z}} \mathrm{z}-\overline{1} \mathbf{4}$ ) or by a special purpose instruction (i.e., LMAP, LMAPRE, LPC, LLOCKS, or LLOCKSE), as shown below:

| Control Field of <br> MMC instruction: <br> Bit positions |  | Type and format of <br> control image to be <br> loaded |  | Alternate <br> Instruction <br> Mnemonic |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 13 | 14 | 1 |  | Memory write protection <br> locks (2-bit format) | LLOCKS

Attempting to execute an MMC instruction with any code other than the five shown above causes the instruction to trap to location X'4D' (instruction exception trap).

Normally, bit positions 15-31 may be ignored insofar as the operation of the MMC instruction is concerned. The results of the instruction are the same whether MMC is indirectly or directly addressed. However, if MMC is indirectly addressed and the indirect reference address is nonexistent, the nonallowed operation trap (location $\mathrm{X}^{\prime} 40^{\prime}$ ) is activated.

The $R$ field, which must be coded with an even value, designates an even-odd pair of general registers ( $R$ and Rul) that contain additional control information required by the MMC instruction. If the $R$ field is coded with an odd value a trap to location $X^{\prime} 4 D^{\prime}$ (instruction exception trap) occurs.

Depending upon the type of addressing, the contents of register $R$ may be as follows:

If $M A=0$, contents of register $R$ are:

|  | 17-bit control Image address |
| :---: | :---: |
|  |  |

If $M A=1$ and $M M=0$, the contents of register $R$ are:


In either case, the Control Image Address is the virtual address of a control word within the control image area to be loaded into a block of memory control registers, as specified by the contents of register Rul.

Depending upon the type of control image being loaded, the contents of register Rul may be in one of the following three formats:

For loading memory map image (either 8-bit or 11-bit format), contents of register Rul are:


For loading 4-bit write lock images, contents of register Rul are:


For loading access protection or 2-bit write lock images, contents of register Rul are:


The Count field (bit positions $0-7$ ) specifies the number of words to be loaded from the control image area. If the initial word count is zero, a word count of 256 is implied.

The Control Start field (bit positions $15-20,21$, or 22) points to the beginning of the memory region controlled by the registers to be loaded. The significance of this field is different for the 5 modes of MMC operations and is described within each mode below.
$\begin{aligned} \text { Affected: } & \begin{array}{l}\text { (R), (Rul), } \\ \text { memory control }\end{array} & \text { Traps: } \begin{array}{l}\text { Instruction exception, } \\ \text { nonallowed operation. }\end{array}\end{aligned}$ storage

## LOADING THE MEMORY MAP

## CONTROL IMAGE

Each word of the memory map control image contains either four 8-bit page addresses or two 11-bit extended page addresses, as illustrated below:

Typical memory map control image word (8-bit format):

| Page <br> Address | Page <br> Address | Page <br> Address | Page <br> Address |
| :---: | :---: | :---: | :---: |
| $012^{3145} 56789$ | 10111213141516171819202122 | 232425262728293031 |  |

Typical memory map control image word (11-bit format):

|  | Extended Page Address |  | Extended Page Address |
| :---: | :---: | :---: | :---: |

Depending upon the memory map control image format, the instruction format is one of the following:

LMAPP LOAD MAP (8-bit format)


## LMAPRE LOAD MAP REAL EXTENDED (11-bit format)



Depending upon the type of addressing, the format of register $R$ contents is one of the following:

If $M A=0$;


If $M A=1$ and $M M=0$;


For either memory map format and either type of addressing, the contents of register Rul are:

| Count | \%/\#\# | Control Start |  |
| :---: | :---: | :---: | :---: |

## MEMORY MAP LOADING PROCESS

The initial map image address (in register R ) is the virtual address of the first word of the memory map control image.

The initial count, as contained in register Rul specifies the word length of the control image to be loaded. A word count of 64 (for 8-bit format) or 128 (for 11-bit format) is sufficient to load an entire block of 256 memory map control registers. The memory map control registers are treated as a circular set, with the first register following the last; thus, a word count greater than 64 (8-bit format) or 128 (11-bit format) causes the first registers to be overwritten.

The initial value of the control start field of register Rul points to the first page ( 512 words) of virtual addresses that are to be controlled by the memory map control image being loaded. The memory map control image is loaded into the memory map control registers one word at a time. As the contents of each word are loaded into either two or four memory map control registers, the map image address is incremented by 1 , the word count is decremented by 1 , and the value in the control start field is incremented either by four (if the memory map control image is in the 8 -bit format) or by two (if the memory map control image is in the 11-bit format). The loading process continues until the word count is reduced to zero.

When the load process is completed, the map image address of register $R$ contains a value equal to the sum of the initial map image address plus the initial word count, the word count of register Rul has a value of zero, and the control start field of register Rul contains a value equal to the sum of the initial contents plus four or two times the initial word count.

## LOADING THE ACCESS PROTECTION CONTROLS

## CONTROL IMAGE

Each access protection control image word contains sixteen 2-bit fields; or, the access protection codes for 16 consecutive pages of virtual memory. Thus, the access protection control image for 128 K word ( 256 page) virtual memory is contained within 16 contiguous memory locations, designated as the access protection control image area.

The format of a typical access protection control image word is:


The instruction format for loading the access protection code is:


Depending upon the type of addressing, the format of register $R$ contents is one of the following:


For either type of addressing, the contents of register Rul are:


## ACCESS PROTECTION LOADING PROCESS

The initial access protection control image address in register $R$ is the virtual address of the first word of the access protection control image.

The initial count in register Rul specifies the word length of the sontro! imoge to be !onded. A. word count of l6 is sufficient to load the entire block of 256 access protection control registers. The access protection control registers are treated as a circular set, with the first register following the last; thus, a word count greater than 16 causes the first registers loaded to be overwritten.

The initial value of the control start field of register Rul points to the first page ( 512 words) of virtual addresses that are to be controlled by the access protection control image being loaded. The access protection control image is loaded into the access control registers one word at a time, thus loading the control registers for 16 consecutive pages with the contents of each image word. As each image word is loaded, the access protection control image address is incremented by 1 , the word count is decremented by 1 , and the value in the control start field is incremented by 4. The loading process continues until the word count is reduced to 0 .

When the loading process is completed, the parameters contained within registers $R$ and Rul have the following values:

Access protection
control image address = initial access protection control image address plus the initial word count.

Count $=0$.
Control Start =
initial contents plus 4 times the initial word count.

## MEMORY WRITE PROTECTION LOCKS

## CONTROL IMAGE

Each write lock control image word may contain either eight 4－bit write lock images or sixteen 2－bit write lock images，as illustrated below：

Typical write locks image word（4－bit format）；

| WL10 | WL11 | $\mathrm{WLI}_{2}$ | $\mathrm{WLI}_{3}$ | $\mathrm{WLI}_{4}$ | $\mathrm{WLl}_{5}$ | $\mathrm{WLI}_{6}$ | $\mathrm{WL}_{7}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Typical write locks image word（2－bit format）；


The number of words required to define the memory write locks control image is dependent upon the format of the write lock images and the number of write lock registers to be loaded by a single MMC instruction．（For example，if the write lock images are of the 4－bit format and the memory system is maximum size（ $1,024,000$ words or 2048 pages） with 2048 write lock control registers，the control image may be defined by 256 words（i．e．， 256 words times 8 write lock images per word is equal to 2048 write lock images or one write lock image per each write lock control register）． If the write lock images are of the 2－bit format and the memory size is the same，as described above，the control image may be defined by 128 words．

The instruction format for loading 2－bit write lock images is：
LLOCKS LOAD LOCKS（2－bit format）


The instruction format for loading 4－bit write lock images is：

## LLOCKSE LOAD LOCKS（4－bit format）



If $M A=0$ ，the contents of register $R$ are：


If $M A=1$ and $M M=0$ ，the contents of register $R$ are：


When loading 2－bit write lock images，the contents of register Rul are：

| Count |  | Control Start |  |
| :---: | :---: | :---: | :---: |

When loading 4－bit write lock images，the contents of reg－ ister Rul are：

| Count |  | Control Start | 为为为为 |
| :---: | :---: | :---: | :---: |

## LOADING PROCESS

Depending upon the addressing mode of the basic processor， the contents of register $R$ are interpreted as either a 17－bit or a 20 －bit virtual address of an image word within the memory write locks control image area（source of write lock images）．The initial lock image address points to the first image word．After the contents of the image word（either 8 or 16 write lock images）are loaded into an equivalent num－ ber of write lock registers，the lock image address is incre－ mented by one．Thus，successive image words are accessed in an ascending sequence．

Depending upon the instruction format，the hardware appends either one or two low order zeros，as necessary，to convert the 9－bit or 10－bit control start field into an 11－bit real ． page address．In addition to being the real page address of 512 consecutive memory word locations，the value of the ll－bit control start field is also the address of the associated write lock control register．The value of the control start field at the time the image word is accessed is the address of the first of either 8 or 16 write lock control registers that will be loaded by the write lock images contained within one image word．When all of the write lock images of a given word have been loaded into either 8 or 16 write lock control registers，the value of the 9－bit or 10－bit con－ trol start field is incremented by 4 ．（Note that this is equi－ valent to incrementing the value of the effective ll－bit field by a value of either 8 or 16 ，the number of control registers loaded．）

The count field of register Rul specifies the number of image words，and indirectly the number of write lock images to be loaded．Depending upon the instruction format，each image word is interpreted as containing either eight 4－bit write lock images or sixteen 2－bit write lock images．In the case of 2－bit write lock images，the hardware appends two high order zeros to each image as it is loaded into the 4－bit con－ trol register．Thus，the number of write lock control regis－ ters loaded is always either 8 or 16 times the initial value of the count field．If the initial value of the count field is zero，it is interpreted to be 256 words．During the load－ ing operation，the count field is decremented by one after the contents of each image word are loaded into the appro－ priate number of control registers．The loading operation continues until the word count is reduced to zero．At that time，the value of the lock image address is equal to its
initial value plus the initial value word count and the value of the 9- or 10-bit control start field is equal to its initial value plus 4 times the initial word count.

The memory write lock registers are treated as a circular set, with the register for memory addresses $\mathrm{X}^{\prime} 0^{\prime}-X^{\prime} 1 F^{\prime}$ (first page) immediately following the register for memory addresses X'FFEOO'-X'FFFFF' (last page). Overwriting the first registers occurs when 2-bit write lock images are being processed and the word count is greater than 128.

## INTERRUPTION OF MMC

The execution of MMC can be interrupted after each word of the control image has been moved into the specified control register. Immediately prior to the time that the instruction in the inferrupt or trap location is executed, the instruction address portion of the program status words contains the virtual address of the MMC instruction, register $R$ contains the virtual address of the next word of the control image to be loaded, and register Rul contains a count of the number of control image words remaining to be moved and a value pointing to the next memory control register to be loaded. After interrupt, the MMC instruction may be resumed from the point it was interrupted.

## MEMORY ACCESS TRAPS BY MMC INSTRUCTION

A trap during execution of the MMC instruction can occur if the pages containing the control images are nonexistent or are protected in the master-protected mode. The registers $R$ and Rul may be altered for the above case. If a parity error should occur during access of a control image word, the MMC instruction will trap with the Register Altered indicator set indicating that a change has been made to the memory control registers. The registers R and Rul will be restored to their initial values, prior to the point at which the trap occurred.

LRA LOAD REAL ADDRESS
(Word index alignment, privileged)

| * | 2 C | R | X | Reference Address |
| :---: | :---: | :---: | :---: | :---: |

LOAD REAL ADDRESS converts the address portion of the effective word into a real byte, halfword, word, or doubleword address (as specified by CC1 and CC2 at the beginning of the LRA instruction) and loads that real address and status information (as listed below) into register R. Upon completion of the LRA instruction, additional information pertaining to the LRA instruction or to the real address is provided via the condition code.

Prior to executing an LRA instruction, CC1 and CC2 must be set to an appropriate value (as shown below).

| $\frac{C C 1}{0}$ | $\frac{C C 2}{0}$ |  | Type of real address to be generated |
| :--- | :--- | :--- | :--- |
| 0 | 0 | Byte (22 bits) |  |
| 0 | 1 | Halfword (21 bits) |  |
| 1 | 0 | Word (20 bits) |  |
| 1 | 1 | Doubleword (19 bits) |  |

The effective virtual address for the LRA instruction itself may be generated in a normal manner (i.e., indirect addressing, indexing, and/or mapping, as applicable, may be specified and performed) with all standard trapping conditions in effect.

The address loaded into the R register is dependent upon the value of the address portion of the effective word. If the address portion of the effective word is equal to or greater than 16, it is converted (mapped) into a $19,20,21$, or 22 -bit real address, as specified by CC 1 and CC 2 .

Note: Converting an effective virtual address into a real address by mapping is performed independently of the state of the map bit in the current PSWs.

If the address portion of the effective word is less than 16, it is not mapped into a real address. Instead, a 19, 20, 21, or 22-bit effective virtual address is generated, as specified by CC 1 and CC 2 .

In either case a $19,20,21$, or 22-bit real or effective virtual address is loaded into a corresponding number of low order bit positions of the R register (i.e., the least significant bit of the address is always loaded into bit position 31 of register R). Except for bit positions reflecting status information, all high order bit positions within register $R$ are set to zero. Contents of the various bit positions of register $R$ after an LRA instruction are as follows:
Bits Contents
0-9 Reserved; always set to 0.
10-31 Real or effective virtual address. For 21-, 20-, and 19-bit addresses, as specified by initial value of $\mathrm{CC1}$ and CC2, bit positions 10,11 , and 12 will be set to zeros, as required.

Affected: (R),CC
Condition code settings:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Results in R register
0 - - No abnormal condition.
1 1 - - Address in $R$ is real but for a nonexistent memory location.

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

1100 Address in $R$ is an effective virtual address (address of a general register).

Note: Condition code setting 11-- and 1100 may be distinguished in the software by examining the address (bits 10-31).

- $\quad-\quad 0 \quad 0 \quad 0 \quad$ Access protect code for the page containing
-     - 100$\}$ the memory location specified by the gener-
- 1 1 ated address.

Note: This instruction requires two memory references to the same location for its execution. To preclude other processors from accessing the effective location during this time, the memory unit containing the effective location is reserved (not accessible to other processors) until the LRA instruction is completed.

LMS LOAD MEMORY STATUS
(Word index alignment, privileged)

| * | 2D | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |

LOAD MEMORY STATUS is used to determine memory unit status and/or to perform diagnostic action on a memory unit. The effective address is used to determine the memory unit. The condition code setting immediately before execution determines the diagnostic action to be performed. The effective address always references memory even if it is less than 16. The condition code can be set to the desired value before execution of LMS with the LCF or LCFI instructions. Register $R$ is loaded with the result of the action. The condition code is set at the conclusion of execution to reflect the status of the word loaded (if any).

## Affected: (R),CC Trap: See "Trap System", Chapter 2.

Initial condition code settings:

\section*{1 | 1 | 2 | 3 |
| :--- | :--- | :--- |}

0000 Read and set - causes the same action as the LOAD AND SET (LAS) instruction, except for condition code settings. Normal traps are allowed including write protect.
$0 \quad 0 \quad 1 \quad$ Read and inhibit parity - loads the effective word into R. If a memory parity error is detected, the memory does not take a "snapshot" or generate a Memory Fault Interrupt (MFI).

1234 LMS Action

It does, however, generate the Memory Parity Error signal. The basic processor inhibits the trap that would ordinarily occur for the memory parity error.

0010 Clear memory - stores zero in the memory location specified by the address.
$\begin{array}{llll}0 & 0 & 1 & \text { Reserved. }\end{array}$
0100 Reserved.
0101 Reserved.
0110 Read write lock - loads a pair of 4-bit write locks into byte 3 of $R$ (bits 24-31) and 0 in all other bit positions of R. The write lock stored in bits 24-27 is stored in the memöry system's Write Lock memory at the location corresponding to bits 17-21 of the effective address, bit $22=0$. The write lock stored in bits 28-31 corresponds to bits 17-21 of the effective address, bit 22=1.
$\begin{array}{llll}0 & 1 & 1 & 1\end{array}$ Write write lock - stores byte 3 of the data word sent to memory as a pair of write locks in the memory system's Write Lock memory at a location corresponding to bits 17-21 of the effective address, bit 22 $=0$ (for data bits 24-27) and bits 17-21 of the effective address, bit 22=1 (for data bits 28-31).

1000 Read status word $0^{\dagger}$ - loads status word 0 into $R$ (see Table 9).

1001 Reserved.
1010 Read status word $1^{\dagger}$ - loads status word 1 into $R$ (see Table 10).

1011 Reserved.
1100 Read status word 0 and clear.
1101 Reserved.
1110 Write double error - stores an arbitrary word into a specified memory location, with two differences compared to a normal Write Word instruction: (1) Byte 3 in memory is forced to zero; (2) the arbitrary word is stored in memory with an intentional wrong parity; on a subsequent read of that word, the memory issues the parity error signal.

## 1111 Reserved.

Condition code settings after execution.

[^10]Table 9. Status Word 0

| Field | Bits | Comments |
| :---: | :---: | :---: |
|  | $\begin{gathered} 0 \\ 1 \\ 2-7 \\ 8-9 \end{gathered}$ | Reserved <br> Power status <br> Memory unit error code <br> Memory type |
| Ports | 10 <br> 11 <br> 12 <br> 13 <br> 14 <br> 15 <br> 16 <br> 17 <br> 18 <br> 19 <br> 20 <br> 21 | Port 1 enabled <br> Port 2 enabled <br> Port 3 enabled <br> Port 4 enabled <br> Port 5 enabled <br> Port 6 enabled <br> Port 1 serviced <br> Port 2 serviced <br> Port 3 serviced <br> Port 4 serviced <br> Port 5 serviced <br> Port 6 serviced |
| Memory fault types | 22 <br> 23 <br> 24 <br> 25 <br> 26 <br> 27 <br> 28 <br> 29 <br> 30 <br> 31 | 0 <br> Uncorrectable memory unit error <br> Memory module selection error <br> Auduriess püitity einui <br> Data in parity error <br> Write lock parity error <br> Port selection error <br> Undefined operation <br> Control error <br> Multiple error |

For "read and inhibit parity" operations, the status of the word loaded (if any) is stored in the condition code bits at the conclusion of execution as follows:

CC 1: Memory Parity Error (from memory)
CC2: Data Bus Check (from CPU)
CC3: Parity Bit (from memory)
CC4: 0

Table 10. Status Word 1

| Field | Bits | Comments |
| :---: | :---: | :---: |
|  | 0 1-3 $4-6$ | Interleave switch ON <br> Memory unit size: <br> Memory unit number (binary code) |
| Starting Address | $\begin{gathered} 7 \\ 8 \\ 9 \\ 10 \end{gathered}$ $9$ $11$ $12$ $13$ | Starting address bit 12 <br> Starting address bit 13 <br> Starting address bit 14 <br> Starting address bit 15 <br> Starting address bit 16 <br> Starting address bit 17 <br> Starting address bit 18 |
|  | 14 | Reserved |
|  | 15-31 | Address received, bits 15-31 |

WAIT WAIT
(Word index alignment, privileged)

| * | 2E | R | $X$ | Reference address |
| :---: | :---: | :---: | :---: | :---: |

WAIT causes the basic processor to cease all operations until an interrupt activation occurs, or until the operator puts the basic processor in the IDLE mode and then back to RUN (see Chapter 5). The instruction address portion of the PSWs is updated before the basic processor begins waiting; therefore, while it is waiting, the INSTRUCTION ADDRESS indicators contain the virtual address of the next location in ascending sequence after WAIT and the contents in the next location are displayed in the DISPLAY indicators on the processor control console. If any input/output operations are being performed when WAIT is executed, the operations proceed to their normal termination.

When an interrupt activation occurs while the basic processor is waiting, it processes the interrupt-servicing routine. Normally, the interrupt-servicing routine begins with an XPSD instruction in the interrupt location, and ends with an LPSD instruction at the end of the routine. After the LPSD instruction is executed, the next instruction to be executed in the interrupted program is the next instruction in sequence after the WAIT instruction. If the interrupt is to a
single-instruction interrupt location, the instruction in the interrupt location is executed and then instruction execution proceeds with the next instruction in sequence after the WAIT instruction. When the basic processor execution mode is changed from RUN mode to IDLE mode and back to RUN while the basic processor is waiting, instruction execution proceeds with the next instruction in sequence after the WAIT instruction.

## Affected: PC

If WAIT is indirectly addressed and the indirect reference address is nonexistent, the nonallowed operation trap to location $X^{\prime} 40^{\prime}$ will not occur. The effective virtual address of the WAIT instruction, however, is not used as a memory reference (thus does not affect the normal operation of the instruction).

## RD READ DIRECT

(Word index alignment, privileged)

| * | 6 C | R | X | Reference address |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Mode | Function |

The basic processor is capable of directly communicating with other elements of the system, as well as performing internal control operations, by means of the READ DIRECT/ WRITE DIRECT (RD/WD) lines. The RD/WD lines consist of 16 address lines, 32 data lines, two condition code lines, and various control lines that are connected to various basic processor circuits and to special system equipment.

READ DIRECT causes bits 16 through 31 of the effective virtual address to be presented to other elements of the system on the RD/WD address lines. Bits 16-31 of the effective virtual address identify a specific element of the system that is expected to return information (two condition code bits plus a maximum of 32 data bits) to the basic processor. The significance and number of data bits returned depend on the selected element. If the R field of RD is nonzero, up to 32 bits of the returned data are loaded into general register $R$; however, if the $R$ field of RD is 0 , the returned data is ignored and general register 0 is not changed. Bits CC3 and CC4 of the condition code are set by the addressed element, regardless of the value of the $R$ field.

Bits 16-19 of the effective virtual address of RD determine the mode of the RD instruction, as follows:

## Bit Position

## 16171819

Mode
0000 Internal basic processor control.
$\begin{array}{llll}0 & 0 & 0 & 1\end{array}$ Interrupt control.
0010
Xerox testers.
$\left.\begin{array}{llll}0 & 0 & 1 & 1 \\ \vdots & & & \\ 1 & 1 & 1 & 1\end{array}\right\}$

Unassigned.

1111 Special systems control (for customer use with specially designed equipment).

If bits $16-19$ select mode 2 through mode $F, C C 1$ and CC 2 are set to zero and CC3 and CC4 are set according to the state of the two condition code lines from the external device.

## READ DIRECT, INTERNAL BASIC PROCESSOR CONTROL (MODE O)

In this mode, the basic processor is able to read the sense switches, the basic processor address, and the interrupt inhibit bits of the PSWs as follows:

## READ SENSE SWITCHES

The following configuration of RD can be used to read the four SENSE switches in the System Control Processor:

| * | 6C | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |

If a particular SENSE switch is set, the corresponding bit of the condition code is set to 1 ; if a SENSE switch is zero, the corresponding bit of the condition code is set to 0 (see "Read Sense Switches" in Chapter 5).

In this case, only the condition code is affected.

## READ BASIC PROCESSOR

The following RD configuration is used to read the basic processor's address:

| * | 6C | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0000 | 0000 | 0001 | 0000 |

If the $R$ field is nonzero, the cluster number in which the basic processor resides is obtained from the associated processor interface and loaded into register $R$ bits 21-23. All other bits in the register are cleared to zero.

Affected: (R)
Cluster Address $\longrightarrow \mathrm{R}_{21-23}$
$0 \longrightarrow R_{0-20}$ and $R_{24-31}$

## READ INTERRUPT INHIBITS

The following configuration of RD can be used to read the contents of the interrupt inhibit field:

|  | 6C | $R$ | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| * |  |  |  | 0000 | 0000 | 0100 | 1000 |

If the $R$ field of $R D$ is nonzero, the contents of the interrupt inhibit field (bits $37,38,39$ ) of the program status words are transferred to the least significant 3 bits of the specified R register (bits 29, 30, 31). The remainder of the R register (bits $0-28$ ) is cleared to zeros.

Affected: (R)
(PSWs) ${ }_{37-39} \longrightarrow R_{29-31}$
$0 \longrightarrow R_{0-28}$

Note that a copy of the interrupt inhibits is retained in the Interrupt Status Register in the Processor Interface associated with each basic processor.

## LOAD FROM LOW MAIN MEMORY

| * | 6C | $R$ | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| * |  |  |  | 0000 | 0001 | + | REAL |

The instruction allows reading the contents of real memory locations 0-31 (locations 0-15 shadowed by the general purpose registers). This allows access to the Status Stack Pointer Doubleword in locations 0-1 and the default Program Status Words (Interrupt Stack is empty) in locations 2-4.

If the R field is nonzero, the contents of the main memory location identified by bits 27-31 are loaded into $R$.

## Affected: (R)

$\mathrm{EW} \longrightarrow R$

## READ INTERNAL CONTROL REGISTERS

The following configuration of RD is used to read the contents of internal control (or Q) registers:


If the $R$ field of the RD instruction is nonzero, the contents of the internal control register, as specified by the "Q Address" field of the instruction (bit positions 27-31), are
loaded into register $R$. Although the $Q$ address field permits any of 32 addresses to be specified, only the following may be used:

| Q Address | Contents |
| :---: | :---: |
|  | $\{$ (Bits 0-13) - Reserved |
| X'1D' | ( Bits 14-3I) - "Branch from" Program Counter |
| X'1E' | $\left\{\begin{array}{l} (\text { Bits 0-7) - Reserved } \\ (\text { Bits 8-31) - Load Device Address } \end{array}\right.$ |

All other $Q$ addresses from $X^{\prime} 00^{\prime}-X^{\prime} 1 F^{\prime}$ are reserved.
Affected: (R)

EW $\longrightarrow R$

## READ DIRECT, INTERRUPT CONTROL (MODE 1)

The following configuration of RD is used to control the sensing of the various states of the individual interrupt levels within the basic processor interrupt system:


Bits 28 through 31 of the effective address specify the identification number of the group of interrupt levels to be controlled by the READ DIRECT instruction.

The $R$ field of the RD instruction specifies a general register that will contain the bits sensed from the individual interrupt levels within a specified group. For external interrupt groups, bit position 16 of register $R$ contains the appropriate indicator bit for the highest priority (lowest number) interrupt level within the group and bit position 31 of register R contains the indicator bit for the lowest priority interrupt level within the group. For assignments in Group $X^{\prime} 0^{\prime}$, see Table 11. Each interrupt level in the designated group is sensed according to the function code specified by bits 21 through 23 of the effective address of RD. The codes and their associated functions are as follows:

## Code Function

001 Read Armed or Waiting State. Set to 1 the bits in the selected register which correspond to interrupt levels in this group that are in either the armed or the waiting state. Reset all other bits to zero.

010 Read Waiting or Active State. Set to 1 the bits in the selected register which correspond to each interrupt level in this group that is in either the waiting or the active state. Reset all other bits to zero.

Read Enabled. Set to 1 the bits in the selected register which correspond to each interrupt level in this group which is enabled. Reset all other bits to zero.

## READ CONFIGURATION CONTROL PANEL



The mode 9 instruction reads the state of the Configuration Control Panel for the addressed cluster or unit. Physical addresses are assigned at the time of system configuration. The returned status to Register R is shown in Tables 11 and 12.

WD WRITE DIRECT
(Word index alignment, privileged)

| * | 6D | R | X | Reference address |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Mode | Function |

WRITE DIRECT causes bits 16-31 of the effective virtual address to be presented to other elements of the system on the RD/WD address lines (see READ DIRECT). Bits 16-31 of the effective virtual address identify a specific element of the system that is to receive control information from the basic processor. If the R field of WD is nonzero, the 32-bit contents of register $R$ are transmitted to the specified element on the RD/WD data lines. If the R field of WD is 0,320 's are transmitted to the specified element (instead of the contents of register 0 ). The specified element may return information to set the condition code.

Bits 16-19 of the effective virtual address determine the mode of the WD instruction, as follows:


11111 Special systems control (for customer use with specially designed equipmeni).

If bits 16-19 select mode 2 through mode $F, C C 1$ and CC2 are set to zero and CC3 and CC4 are set according to the state of the two condition code lines from the external device.

## LOAD SENSE SWITCHES

The following configuration of WD can be used to load the sense switches in the System Control Processor:

| * | 6D | $R$ | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0000 | 0000 | 0000 | 0000 |

If the R field is nonzero, bits 0 through 3 of Register $R$ will be loaded into sense switches 1 through 4 in the System Control Processor. If the R field is zero, sense switches will be reset to zeros. (See the section "System Control Panel" in Chapter 5.)

## SET INTERRUPT INHIBITS

The following configuration of WD can be used to set the interrupt inhibits (bit positions 37-39 of the PSWs):

|  | 6D | $R$ | X | Reference address |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| * |  |  |  | 0000 | 0000 | 0011 | $0 /$ | I | E |

A logical inclusive OR is performed between bits 29-31 of the effective virtual address and bits 37-39 of the PSWs. If any (or all) of bits 29-31 of the effective virtual address are 1 's, the corresponding inhibit bits in the PSWs are set to l 's; the current state of an inhibit bit is not affected if a corresponding bit position of the effective virtual address contains a 0 .

Note that a copy of the Interrupt Inhibits is retained in the Interrupt Status Register in the Processor Interface associated with each basic processor.

## RESET INTERRUPT INHIBITS

The following configuration of WD can be used to reset the interrupt inhibits:

|  | 6D | R | X | Reference address |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0000 | 0000 | 0010 | , |  |  |

If any (or all). of bits 29-31 of the effective virtual address are 1's, the corresponding inhibit bits in the PSWs are reset to $0^{\prime}$ s; the cument state of an inhibit bit is not affected if a corresponding bit position of the effective virtual address contains a 0 .

Note that a copy of the Interrupt Inhibits is retained in the Interrupt Status Register in the Processor Interface associated with each basic processor.

Table 11. Read Direct Mode 9 Status Word

| RD Status Word Bit No. | Processor Cluster 1 | Memory Unit 1 |
| :---: | :---: | :---: |
| $\begin{aligned} & 00 \\ & 01 \\ & 02 \\ & 03 \\ & 04 \\ & 05 \\ & 06 \\ & 07 \end{aligned}$ | System Select <br> Clock Select <br> Processor Cluster Address $2^{2}$ <br> Processor Cluster Address 21 <br> Processor Cluster Address $2^{0}$ <br> BP Enable <br> MIOP Enable <br> DIO Enable | System Select <br> Clock Select <br> Unit No. $2^{2}$ <br> Unit No. $2^{1}$ <br> Unit No. $2^{0}$ <br> Port Enable 1 <br> Port Enable 2 <br> Port Enable 3 |
| $\begin{aligned} & 08 \\ & 09 \\ & 10 \\ & 11 \\ & 12 \\ & 13 \\ & 14 \\ & 15 \end{aligned}$ | Not Assigned <br> ALTSEL <br> FSELA <br> FSELBO <br> FSELBI <br> Real Time Clock 1-S0 <br> Real Time Clock 1-S1 <br> Real Time Clock 2-S0 | Port Enable 4 <br> Port Enable 5 <br> Port Enable 6 <br> Not Assigned <br> Not Assigned <br> Interleave Enable <br> Starting Address S 12 <br> Starting Address S 13 |
| $\begin{aligned} & 16 \\ & 17 \\ & 18 \\ & 19 \\ & 20 \\ & 21 \\ & 22 \\ & 23 \end{aligned}$ | Real Time Clock 2-S1 <br> Real Time Clock 3-S0 <br> Real Time Clock 3-S1 <br> Subjective Time Clock -S0 <br> Subjective Time Clock -S1 <br> Not Assigned <br> Not Assigned <br> Not Assigned | Starting Address S14 <br> Starting Address S15 <br> Starting Address S16 <br> Starting Address S17 <br> Starting Address 518 <br> Not Assigned <br> Not Assigned <br> Not Assigned |
| $\begin{aligned} & 24 \\ & 25 \\ & 26 \\ & 27 \\ & 28 \\ & 29 \\ & 30 \\ & 31 \end{aligned}$ | Not Assigned <br> Not Assigned <br> Not Assigned ${ }^{\dagger}$ Chassis Type-2 ${ }^{4}$ <br> Chassis Type-2 ${ }^{3}$ <br> Chassis Type-2 ${ }^{2}$ <br> Chassis Type-2 ${ }^{1}$ <br> Chassis Type-2 ${ }^{0}$ | Not Assigned <br> Not Assigned <br> Not Assigned ${ }^{\text {t }}$ Chassis Type- $2^{4}$ <br> Chassis Type-2 ${ }^{3}$ <br> Chassis Type-2 ${ }^{2}$ <br> Chassis Type-2 ${ }^{1}$ <br> Chassis Type-2 ${ }^{0}$ |
| ${ }^{\dagger}$ See Chassis Type Table. |  |  |

Table 12. Chassis Type Assignments

| Chassis Type | $2^{4}$ | $2^{3}$ | $2^{2}$ | 21 | 20 | Configuration Information |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Processor Clusters | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Reserved <br> Reserved <br> Processor Cluster Type 1 <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved |
| Controller Clusters | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved |
| Memory Units | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Memory Unit Type 1 <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved |
| Reserved | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Not available <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved |

SET ALARM INDICATOR
The following configuration of WD is used to set the ALARM indicator on the maintenance section of the processor control panel:

| * | 6D | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0000 | 0000 | 0100 | 0001 |

If the processor is in the RUN mode and the AUDIO switch on the maintenance section of the processor control panel is in the ON position, a $1000-\mathrm{Hz}$ signal is transmitted to the basic processor speaker. The signal may be interrupted by changing from RUN mode to IDLE mode, by moving the AUDIO switch to the OFF position, or by resetting the ALARM indicator.

## RESET ALARM INDICATOR

The following configuration of WD is used to reset the ALARM indicator:

|  | 6D | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| * |  |  |  | 0000 | 0000 | 0100 | 0000 |

The ALARM indicator is also reset by either the RESET BP or the RESET SYSTEM Command entered from the operator's control console.

## TOGGLE PROGRAM-CONTROLLED-FREQUENCY FLIP-FLOP

The following configuration of WD is used to set and reset the basic processor program-controlled-frequency (PCF) flip-flop:

| * | 6D | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0000 | 0000 | 0100 | 0010 |

The output of the PCF flip-flop is transmitted to the basic processor speaker through the AUDIO switch on the maintenance section of the System Control Panel. If the PCF flip-flop is reset when the above configuration of WD is executed, the WD instruction sets the PCF flip-flop; if the PCF flip-flop was previously set, the WD instruction resets it. A program can thus generate a desired frequency by setting and resetting the PCF flip-flop at the appropriate rate. Execution of the above configuration of WD also resets the ALARM indicator.

## LOAD INTERRUPT INHIBITS

The following configuration of WD can be used to transfer the contents of the specified $R$ register ( $R_{29-31}$ ) to the Interrupt Inhibit field (PSWs ${ }_{37-39}$ ).

| * | 6D | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0000 | 0000 | 0100 | 1000 |

Affected: $\left(\mathrm{PSW}_{37-39}\right)$
$\left(\mathrm{R}_{29-31}\right) \longrightarrow$ PSWs $_{37-39}$

## TURN ON MODE ALTERED FLAG

The following configuration of WD is used to set the Mode Altered Flag (PSWs 61) to 1:

|  | 6D | R | X |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| * |  |  |  |  |  |  |  |

## TURN OFF MODE ALTERED FLAG

The following configuration of WD is used to reset the Mode Altered Flag (PSWs 61) to 0:

| * | 6D | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0000 | 0000 | 0100 | 0110 |

## STORE IN LOW MAIN MEMORY



This instruction writes into main memory locations 0-31 (locations $0-15$ shadowed by the general purpose registers and reserved locations). This allows storing or changing the Status Stack Pointer Doubleword in locations $0-1$ and the default Program Status Words (Status Stack is empty) in locations 2 through 4.

If the $R$ field is nonzero, the contents of $R$ are stored in the main memory location identified by bits 27-31.

TRAP TO LOCATION X'47י

| * | 6D | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| * |  |  |  | 0000 | 0000 | 0000 | 0010 |

This instruction causes the basic processors to trap to location $X^{\prime} 47$ '.

A line in the Processor Bus is raised by the initiating basic processor (or the associated PI). This line, when true, causes the basic processors to trap to $X^{\prime} 47^{\prime}$ (including the one that executes the instruction).

## WRITE INTO INTERNAL CONTROL REGISTER

The following configuration of WD is used to write into the internal control (or $Q$ ) registers:


If the $R$ field is nonzero, the contents of register $R$ are loaded in the control register, as specified by the "Q Address" field (bit positions 27-31) of the WD instruction. Except for the four $Q$ addresses listed below, all other addresses are reserved:

Q Address

X'ID'

X'IE'
Significance
(Bits 00-13) - Reserved.

$$
\begin{aligned}
& \text { (Bits } 14-31 \text { ) - Write into the "Branch From" } \\
& \text { program counter. }
\end{aligned}
$$

$$
\left\{\begin{array}{l}
(\text { Bits } 00 \text { through 07) - Reserved. } \\
\text { (Bits } 08 \text { through 31) - Write into the "Load } \\
\text { Device Address" register. }
\end{array}\right.
$$

If the $R$ field is zero, the specified register is loaded with all zeros.

Affected: (EL)

## $(\mathrm{R}) \longrightarrow(E L)$

## WRITE DIRECT, INTERRUPT CONTROL (MODE 1)

The following configuration of WD is used to set and reset the various states of the individual interrupt levels within the basic processor interrupt system:

| * | 6D | R | X | Reference address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0001 | 0 Code | 0000 | Group |

Bits 28-31 of the effective address specify the identification number (see Table 11) of the group of interrupt levels to be controlled by the WD instruction.

The $R$ field of the WD instruction specifies a general register that contains the selection bits for the individual interrupt levels within the specified group. For external interrupt groups, bit 16 of register R contains the selection bit for the highest-priority (lowest-numbered) interrupt level within the group, and bit 31 of register R contains the selection bit for the lowest-priority (highest-numbered) interrupt level within the group. For assignments in Group $X^{\prime} 0^{\prime}$, see Table 11.

Except for Power on/Power off interrupt levels, which can not be disabled, disarmed, or inhibited, each level in the designated group is operated on according to the function code specified by bits 21-23 of the effective address of WD. The codes and their associated functions are as follows:

## Code Function

000 Setactive all selected levels currently in the armed or waiting states.
$001^{\dagger}$ Disarm all levels selected by a 1 ; all levels selected by a 0 are not affected.
$010^{\dagger} \quad$ Arm and enable all levels selected by a 1 ; all levels selected by a 0 are not affected.
$011^{\dagger} \quad$ Arm and disable all levels selected by a 1 ; all levels selected by a 0 are not affected.

100 Enable all levels selected by a 1; all levels selected by a 0 are not affected.

101 Disable all levels selected by a 1; all levels selected by a 0 are not affected.

110 Enable all levels selected by a 1 and disable all levels selected by a 0 .

111 Trigger all levels selected by a 1. All such levels that are currently armed advance to waiting state.
${ }^{\dagger}$ These codes clear the current interrupts, i.e., remove from the active or waiting state all levels selected by a 1 (see Figure 12).

## INPUT/OUTPUT INSTRUCTIONS

The I/O instruction set is comprised of eight instructions, as listed below.

| Instruction Name | Mnemonic |
| :--- | :--- |
| Start Input/Output | SIO |
| Test Input/Output | TIO |
| Test Device | TDV |
| Halt Input/Output | HIO |
| Reset Input/Output | PIO |
| Poll Processor | POLR |
| Poll and Reset Processor | AIO |

## OVERALL CHARACTERISTICS

All I/O instructions are privileged and can be performed only when the basic processor (BP) is in either the master or master-protected mode. If the BP attempts to execute an I/O instruction when it is in the slave mode (bit 8 of the current PSW is a 1), the instruction is aborted at the time the oneration conde is deroded and the BP trans to location $X^{\prime} 40^{\prime}$. Programs operating in the slave mode must request I/O services from the System Monitor.

At the end of every I/O instruction, the condition code bits represent a summary description of the results of the I/O operation and conditions within the addressed I/O subsystem. Specific condition code settings and meanings (unique for each $\mathrm{I} / \mathrm{O}$ instruction) are contained in the detailed description for each I/O instruction.

All I/O instructions, except RIO, may request detailed I/O status information. The type and amount of I/O status information that may be requested is determined by the operation code and the $R$ field of the I/O instruction. The $R$ field also designates which general register(s) is to be loaded with the requested information. (Refer to I/O Status Information for further details.)

I/O instructions are similar to other word-addressing instructions in that bits 15-31 may be modified by indirect addressing and/or indexing. However, the final value of these bits is not used as an effective virtual address for memory reference. Instead, depending upon the I/O instruction, these bits are used as an extension to the operation code field, as an I/O address to select a particular I/O subsystem, or they may be reserved. Further details of I/O instructions are illustrated in Figure 13 and described in Table 13.

## I/O STATUS INFORMATION

## SIO, TIO, TDV, AND HIO INSTRUCTIONS

If the $R$ field is coded with a 0 , no status information is requested nor loaded. If the R field is odd, one word of status information is requested to be loaded into register $R$ as specified by the $R$ field. If the $R$ field is even (not zero), two words of status information are requested to be loaded into registers $R$ and Rul.

The following I/O status information may be loaded into register $R$ only when the $R$ field is coded with an even (nonzero) value.


The significance of each bit within register $R$ is described in Table 14.

The following I/O status information may be loaded into register $R$ if the $R$ field is odd, or into register Rul if the $R$ field is even and not zero.

The format of information within the specified general register ( $R$ or Rul) is shown below.

| Device Status Byte | Operational Status Byte | Byte Count |
| :---: | :---: | :---: |

Device Status Byte. These eight bits $(0-7)$ when loaded into the specified general register provide status information pertaining to the addressed device and device controller or IOP. The significance of each bit when requested by an SIO, TIO, and HIO instruction is described in Table 15. The significance of these bits when requested by a TDV instruction is different and is described in the applicable peripheral device reference manual.

Operational Status Byte. Bits 8-15 of the specified general register (R or Rul) indicate either the presence (1) or absence ( 0 ) of various errors which may have occurred during an I/O operation. The significance of the individual bits within the operational status byte are described in Table 16.

Table 17 is the summary description of the Device Status Byte and the Operational Status Byte.

Byte Count. Bits 16-31 of register Rul indicate the number of bytes that have to be transmitted to or from memory in the operation called for by the current I/O command doubleword.

## RIO INSTRUCTION

No status information is returned to the general registers for an RIO instruction (the R field is ignored). Only condition code bits (CCl - CC3) are set to reflect the I/O conditions.

(1) Portions of a word format that are shaded represent bits that are reserved (after the I/O address is generated) and must be coded with zeros to ensure program compatibility with possible enhancements to software and/or hardware.
(2) $\mathrm{OCE}=$ operation code field extension; $C A=$ cluster address; UA = unit address; $D C A=$ device controller address; DA = device address.
(3) To address a single-unit device controller, bit 24 must be a 0 ; to address a multiunit device controller, bit 24 must be a 1 .

Figure 13. Formats of I/O Instructions

Table 13. Description of I/O Instructions

| Bit Position | Applicable Instructions (Mnemonics) | Function and/or Description |
| :---: | :---: | :---: |
| 0 | All I/O instructions | If this bit is a ; bits $15-3$ ! of the initio! I/O instruction are modified by indirect addressing. |
| 1-7 | SIO, TIO, TDV, and AIO | For these four instructions, the operation code uniquely defines the I/O operation that is to be performed. |
|  | HIO, RIO, POLP, and POLR | Within bit positions 1-7, these four instructions all have the same operation code ( $\mathrm{X}^{\prime} 4 \mathrm{~F}^{\prime}$ ). The instructions are differentiated by using bits 15,16 , and 17 as an extension of the operation code field. |
| 8-11 | SIO, TIO, TDV, and HIO | The value of the $R$ field specifies how much status information is requested from the addressed I/O subsystem (IOP, device controller, and device) and into which general register(s) the status information is to be loaded. If the value of the $R$ field is even and not 0 , two words of stalus information are requested to be loaded into registers $R$ and Rul. If the value of the $R$ field is odd, one word of status information is requested to be loaded into register $R$. |
|  | RIO | Although the $R$ field is not used by the RIO instruction, the $R$ field may be coded with any value as required by the program. |

Table 13. Description of I/O Instructions (cont.)
\(\left.$$
\begin{array}{|l|l|l|}\hline \begin{array}{l}\text { Bit } \\
\text { Position }\end{array} & \begin{array}{l}\text { Applicable Instructions } \\
\text { (Mnemonics) }\end{array} & \begin{array}{l}\text { Function and/or Description }\end{array} \\
\hline \text { (cont.) } & \text { POLP and POLR } & \begin{array}{l}\text { This field specifies which general register (including register 0) is to receive } \\
\text { processor (MIOP, RMP, BP, MI, PI, or System Control Processor) fault information. }\end{array}
$$ <br>
\hline 12-14 \& All I/O instructions <br>
If the R field is 0, no status information is requested. If the R field is not 0, the <br>

designated general register is to be loaded with the requested status information.\end{array}\right\}\)| The X field may be used to specify indexing. |
| :--- |

Table 13. Description of I/O Instructions (cont.)

| Bit <br> Position | Applicable Instructions <br> (Mnemonics) | Function and/or Description |
| :---: | :--- | :--- |
| 24 | RIO, POLP, POLR, and AIO | After the I/O address is generated, this bit is reserved and must be coded <br> with a zero. |
| (cont.) |  |  |

Table 14. I/O Status Information (Register R)

| Bit <br> Position | Significance |
| :--- | :--- |
| 0 | Reserved $^{\dagger}$ |
| $1^{\dagger t}$ | Bus Check Fault (BCF). This bit is set to 1 <br> if a discrepancy exists between the parity <br> error status in the memory unit and the IOP <br> when an IOP is performing a main memory <br> read cycle. If the error occurs while access- <br> ing data then the device halt is controlled <br> by the Halt-on-Transmission-Error flag (bit <br> position 36 of an I/O command doubleword). <br> If the error occurs while fetching a com- <br> mand, the operation is terminated immedi- <br> ately with an "unusual end". |
| $2^{\dagger t}$ | Control Check Fault (CCF). This bit is set <br> to I when a parity error occurs during a sub- <br> channel read operation within the MIOP. <br> The operation terminates immediately with <br> an "unusual end". |

Table 14. I/O Status Information (Register R) (cont.)

| Bit Position | Significance |
| :---: | :---: |
| $3^{\text {tt }}$ $4-12$ $13-31$ | Memory Interface Error (MIE). IOP Halt condition is the same as a Bus Check Fault. <br> Reserved ${ }^{\dagger}$ <br> Current Command Doubleword Address. The 19 high-order bits of the main memory address from which the command doubleword for the I/O operation currently being processed by the addressed I/O subsystem is fetched. |
| ${ }^{\dagger}$ To ensure program compatibility with possible software and/or hardware enhancements, it is recommended that reserved bits be treated as indeterminate and not used (i. $e_{:}$; masked). <br> ${ }^{\dagger t}$ The IOP unconditionally sets the Processor Fault Indicator (PFI) whenever a Bus Check Fault, Control Check Fault, Control Memory Fault, or Memory Interface Error occurs. The IOP fault status register is set with status information as listed under the POLP or POLR instructions. |  |

Table 15. Device Status Byte (Register R or Rul) (SIO, TIO, and HIO only)


Table 15. Device Status Byte (Register R or Rul) (SIO, TIO, and HIO only) (cont.)

| Bit <br> Position | Significance |
| :---: | :---: |
| $\begin{aligned} & 1,2 \\ & \text { (cont.) } \end{aligned}$ | for proper operation are satisfied. If bits 1 and 2 are 01 (device "not operational"), the addressed device has developed some condition that will not allow it to proceed; in either case, operator intervention is usually required. If bits 1 and 2 are 10 (device "unavailable"), the device has more than one channel of communication available and it is engaged in an operation controlled by a controller other than the one specified by the I/O address. If bits 1 and 2 are 11 (device "busy "), the device has accepted a previous SIO instruction and is already engaged in an I/O operation. |
| 3 | Device Mode. If this bit is 1 , the device is in the "automatic" mode; if this bit is 0 , the device is in the "manual" mode and requires operator intervention. This bit can be used in conjunction with bits 1 and 2 to determine the type of action required. For example, assume that a card reader is able to operate, but no cards are in the hopper. The card reader would be in state 000 (device "ready", but manual intervention required), where the state is indicated by bits 1,2 , and 3 of the $1 / O$ status response. If the operator subsequently loads the card hopper and presses the card reader START switch, the reader would advance to state 001 (device "ready" and in automatic operation). If the card reader is in state 000 when an SIO instruction is executed, the SIO would be accepted by the reader and the reader would advance to state 110 (device "busy", but operator intervention required). Should the operator then place cards in the hopper and press the START switch, the card reader state would advance to 111 (device "busy" and in "automatic" mode), and the input operation would proceed. Should the card reader subsequently become empty (or the operator press the STOP switch) and command chaining is being used to read a number of cards, the card reader would return to state 110 . If the card reader is in sfate 001 when an SIO instruction is executed, the reader advances to state 111, and the input operation continues as normal. Should the hopper subsequently become empty (or should the operator press the card reader STOP switch) and command chaining is being used to read a number of cards, the reader would go to state 110 until the operator corrected the situation. <br> For RMP, this bit is always set to one. |

Table 15. Device Status Byte (Register R or Rul)
(SIO, TIO, and HIO only) (cont.)

| Bit <br> Position | Significance |
| :---: | :---: |
| 4 | Unusual End. If this bit is a 1, the previous $1 / O$ operation terminated in an "unusual end". Unusual end conditions occur for various reasons that are unique to each device (refer to applicable peripheral reference manual for further details). |
| 5,6 | Device Controller or IOP Condition. The function of these two bits is dependent upon the type of IOP (MIOP or RMP) addressed by the $\mathrm{I} / \mathrm{O}$ instruction. |
|  | MIOP Operations: If bits 5 and 6 are 00 (device controller "ready"), all device controller conditions required for its proper operation are satisfied. If bits 5 and 6 are 01 (device controller "not operational"), some condition has developed that does not allow it to operate properly. Operator intervention is usually required. If bits 5 and 6 are 10 (device controller "unavailable"), the device controller is currently engaged in an operation controlled by an IOP other than the one addressed by the $1 / \mathrm{O}$ instruction. If bits 5 and 6 are 11 (device controller "busy"), the device controller has accepted a previous SIO instruction and is currently engaged in performing an operation for the addressed IOP. |
|  | RMP Operations: If bits 5 and 6 are 00 (IOP "ready"), all RMP conditions required for its proper operation are satisfied. If bits 5 and 6 are 11 (IOP "busy"), the IOP has accepted a previous SIO instruction and is currently engaged in performing that $1 / O$ operation. If bits 5 and 6 are 01 , the IOP is not operational. If bits 5 and 6 are 10, the IOP is in an undefined state. |
| 7 | Reserved. To ensure program compatibility with possible software and/or hardware enhancements, it is recommended that this bit be treated as indeterminate and not used (i. e. , masked). |

Table 16. Operational Status Byte (Register Rul)

| Bit <br> Position | Significance |
| :---: | :---: |
| 8 | Incorrect Length. This bit is set to 1 if an incorrect length condition occurred within the responding subchannel. An incorrect length condition is caused by a "channel end" (or end of record) condition occurring before the device controller has a "count done" signal from the IOP (indicating that the byte count has been reduced to zero), or is caused by the device controller receiving a count done signal before channel end (or end of record): e.g., count done before 80 columns have been read from a card. <br> When set to a 1, the incorrect length bit, by itself, always signifies that an incorrect length condition has occurred. If the SIL flag (bit 38 of the I/O command doubleword) is coded with a 0 , the detected incorrect length condition is to be interpreted as an error condition. If the SIL flag is coded with a 1 , the detected incorrect length condition is to be interpreted as a nonerror condition. If an incorrect length condition is to result in a device halt, the SIL flag must be coded with a 0 and the HTE flag (bit 36 of the I/O command doubleword) must be coded with a 1 . |
| 9 | Transmission Data Error. This bit is set to 1 if the device controller or IOP detected a parity error or data overrun in the transmittal information. A device halt occurs as a result of a transmission data error only if the HTE flag of the I/O command doubleword is coded with a 1. |
| 10 | Transmission Memory Error. This bit is set to 1 if a memory parity error was detected during a data input/output operation. A device halt occurs as a result of a transmission memory error only if the HTE flag of the I/O command doubleword is coded with a 1 . |
| 11 | Memory Address Error. This bit is set to 1 if a nonexistent memory address is detected during a chaining operation or a data input/ output operation. This bit is cleared during a successful SIO or HIO. |
| 12 | IOP Memory Error. This bit is set to 1 if the IOP detects a memory parity error while fetching a command. The bit is cleared during a successful SIO or HIO. |
| 13 | IOP Control Error. This bit is set to 1 if the IOP detects two successive Transfer in Channel commands. The bit is cleared during a successful SIO or HIO. |

Table 16. Operational Status Byte (Register Rul) (cont.)

| Bit <br> Position | Significance |
| :--- | :--- |
| 14 | $\frac{\text { IOP Halt. This bit is set to l if an error con- }}{\text { dition is detected which causes the IOP to }}$ <br> issue a halt order to the addressed I/O de- <br> vice. Error conditions which may cause <br> an IOP halt (independent of the HTE flag <br> within the I/O command doubleword) are: |
| 1.Bus check fault that occurs while fetch- <br> ing a command |  |
| 2. Control check fault |  |
| 3. Memory address error |  |
| 4. IOP memory error |  |
| 5. IOP control error |  |

Table 16. Operational Status Byte (Register Rul) (cont.)

| Bit <br> Position | Significance |
| :--- | :--- |
| 14 |  |
| (cont.) | Error conditions which may cause an IOP halt <br> only if the HTE flag is coded with a 1 are: |
|  | 1. Bus check fault that occurs while fetch- <br> ing data <br> 3. Transmission memory error <br> 4. Incorrect length condition occurring <br> while the SIL flag is coded with a 0. <br> An IOP halt condition causes the current  <br> operation to terminate immediately as an  <br> "unusual end".  <br> This bit is set to a 1 if a Write Lock Violation  <br> (WLV) occurs.  |

Table 17. Status Response Bits for I/O Instructions


The $R$ field of these two instructions always specifies a general register (including register 0 ) that may receive up to 16 bits of fault status information from an addressed $B P$, RMP or MIOP. Each bit indicates the presence (1) or absence ( 0 ) of a specific fault condition within the polled processor (as listed in Table C-1). Note that the information represented by a particular bit is also dependent upon the type of processor polled (e.g., bit 18 may indicate a memory parity error in the BP or a control check fault within an MIOP).

## AIO INSTRUCTION

For this instruction, if the $R$ field has a value of 0 , no status information is requested nor loaded. If the $R$ field has a value of $X^{\prime} l^{\prime}$ through $X^{\prime} F^{\prime}$, the specified register may receive one word of $1 / O$ information pertaining to an I/O interrupt.

| DC and Device | IOP |  | IOP | 0 |  | CA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Status Byte | Status Byte |  | Address |  | DCA | DA |

Device and Device Controller Status Byte. Bits 0-7 of the status word obtained by an AIO instruction from a responding I/O subsystem are unique to the device and device controller. These bits are described in the applicable peripheral device reference manual.

IOP Status Byte. Bits 8-15 indicate the presence (1) or absence ( 0 ) of various operation errors and interrupts that may have occurred during an I/O operation. The functions of individual bits within the IOP Status Byte are described in Table 18.

Table 19 is a summary description of the Device/Device Controller Status Byte and the IOP Status Byte.

Bits 16-18. These bits of the AIO response are reserved. To ensure program compatibility with any enhancements (software and/or hardware), it is recommended that these bits be treated as indeterminate and not used (i. e. , masked).

Table 18. IOP Status Byte

| Bit <br> Position | Significance |
| :--- | :--- |
| 8 | Incorrect Length. This bit is set to 1 if an <br> incorrect !ength sondition occurred within |
| the responding subchannel. An incorrect <br> length condition is caused by a " channel <br> end" (or end of record) condition occurring <br> before the device controller has a "count <br> done" signal from the IOP (indicating that |  |

Table 18. IOP Status Byte (cont.)

| Bit Position | Significance |
| :---: | :---: |
| $\begin{aligned} & 8 \\ & \text { (cont.) } \end{aligned}$ | the byte count has been reduced to zero), or is caused by the device controller receiving a count done signal before channel end (or end of record): e.g., count done before 80 columns have been read from a card. <br> When set to a 1 , the incorrect length bit, by itself, always signifies that an "incorrect length" condition has occurred. If the SIL flag (bit 38 of the I/O command doubleword) is coded with a 0 , the detected incorrect length condition is to be interpreted as an error condition. If the SIL flag is coded with a 1, the detected incorrect length condition is to be interpreted as a nonerror condition. If an incorrect length condition is to result in a device halt, the SIL flag must be coded with a 0 and the HTE flag (bit 36 of the I/O command doubleword) must be coded with a 1 . |
| 9 | Transmission Data Error. This bit is set to 1 if, since the last accepted SIO instruction addressed to this subchannel, the device controller or IOP detected a parity error or data overrun in the transmitted information. A device halt occurs as a result of a transmission data error only if the HTE flag of the $1 / \mathrm{O}$ command doubleword is coded with a 1 . |
| 10 | Zero Byte Count Interrupt. This bit is set to 1 if the interrupt on zero byte count flag is 1 and zero byte count is detected. |
| 11 | Channel End Interrupt. This bit is set to 1 if the interrupt at channel end flag is 1 and "channel end" is reported by the device to the IOP. |
| 12 | Unusual End Interrupt. This bit is set to 1 if the interrupt at unusual end flag is 1 and unusual end is reported by the device to the IOP, or if the IOP halt is signaled to the device controller by the IOP. |
| 13 | Write Lock Violation. This bit is set to 1 if the memory signaled a Write Lock Violation in the course of transmitting information from the device to the memory. If the HTE flag and the IUE flag are set, the operation will terminate with an " "nununu end". |
| 14 | Reserved. |
| 15 | Reserved. |



I/O Address. Depending upon the type of device controller responding to the AIO instruction, the I/O address may be comprised either of a processor address and a singleunit device controller address or a processor address, a multiunit device controller address, and a device address. The subfields of the I/O address are described in Table 20.

Table 20. I/O Address (AIO Response)

| Bit <br> Position | Significance |
| :--- | :--- |
| $18-20$ | This field contains the cluster address. |
| $21-23$ | This field contains the unit address. |
| $24-27$ | This field contains all ones. |
| $28-31$ | This field contains the device address. |


| START INPUT/OUTPUT |
| :--- |
| (Word index alignment, privileged) |

Instruction Register

|  |  |  |  | Reference address |
| :---: | :---: | :---: | :---: | :---: |
|  | 4C | R | X | I/O address |

## General Register 0



## START INPUT/OUTPUT performs the following:

1. Attempts to initiate an input or output operation whether an I/O operation is started or not is dependent upon conditions within the addressed I/O subsystem (see meanings of condition code settings).
2. Specifies which IOP, channel, device controller, and input/output device is to be selected (bits 18-31 of the effective virtual address of the instruction word).
3. Specifies the address of the first command doubleword for the subsequent I/O operation (bits 13-31 of general register 0 ).
4. Specifies how much additional status information is to be returned from the I/O system (R field, bits 8-11 of instruction word).
5. Specifies which general registers are to be loaded with the requested status information (R field, bits 8-11, of instruction word).
6. Set MIOP in test mode by using device controller address $X^{\prime} 3 F^{\prime}$ or $X^{\prime} 7 F^{\prime}$. Note that device controller addresses $X^{\prime} 3 F^{\prime}$ and $X^{\prime} 7 F^{\prime}$ are prohibited for normal operation.

General register 0 is temporarily dedicated during SIO instruction execution and must contain the doubleword memory address of the first command doubleword specifying the operation to be started. The required address information must be in general register 0 when the SIO is executed.

Status information for an SIO instruction is always returned via condition code bits. Additional information may be requested and returned via the general registers as specified by the R field of the SIO instruction. However, the return of the additional information is dependent upon conditions encountered within the addressed I/O subsystem (see meanings of condition code settings).

If the $R$ field is coded with a 0 , no additional status information is requested.

If the $R$ field is coded with an odd value, one word of status information is requested to be loaded into register $R$. The format of this information is as follows:

| Device Status <br> Byte | Operational <br> Status Byte | Byte Count |
| :---: | :---: | :---: |
| $012^{3 / 45} 678910111213141516171819202122232425262728293031$ |  |  |

If the $R$ field is coded with an even (nonzero) value, two words of status information are requested. The format of information within register Rul is as shown above. The format of information within register $R$ is as follows:


These responses provide the program with information necessary to determine the current status of the addressed I/O subsystem. The byte count field indicates the number of bytes that are to be transmitted to or from memory in the operation called for by the current command doubleword. The other fields are described in Tables 14-17.

Affected: (R), (Rul), CC

The meaning of the condition code bits during an SIO instruction is:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Meaning
00000 I/O address recognized, SIO accepted, and status information in general registers is correct.
$0 \quad 0 \quad 1 \quad 0$ For RMP, $/$ /O address recognized and SIO accepted; however, status information in general registers may be incorrect. For MIOP, not possible.

0100 I/O address recognized, SIO not accepted because device controller or device is busy, and status information in general registers is correct.

0110 For RMP, I/O address recognized, SIO not accepted because device controller or device is busy, and status informarion in general registers may be incorrect. For MIOP, not possible.

1010 Processor Interface detected parity error on returned status and/or condition code. The result of the SIO is indeterminate.
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Meaning
$1100 \mathrm{I} / \mathrm{O}$ address not recognized, SIO not accepted, and status information returned to general registers is incorrect.

1110 No I/O address recognized and SIO aborted because an error detected when the IOP attempted to read and transfer the SIO parameters (device/device controller address, $R$ field information, and first command doubleword address) from the BP to the IOP via main memory. Status information returned to general registers is incorrect.

If CC4 = 1 , the MIOP is in test mode and the meaning of the condition code during an SIO is:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Meaning

10011 Set test mode is successful.
1011 Set test mode is successful, but a Bus Check Fault was detected.

TIO TEST INPUT/OUTPUT
(Word index alignment, privileged)


TEST INPUT/OUTPUT is used to make an inquiry on the status of data transmission. The operation of the selected IOP, device controller, and device is not affected, and no operations are initiated or terminated by this instruction. The responses to TIO provide the program with the information necessary to determine the current status of the device, device controller, and IOP, the number of bytes remaining to be transmitted into or from main memory in the operation, and the present point at which the IOP is operating in the command list.

If the $R$ field of the TIO instruction is 0 , no general registers are affected, but the condition code is set.

If the $R$ field of TIO is an odd value, the condition code is set and the I/O status and byte count are loaded into register $R$ as follows:

| Device Status <br> Byte | Operational <br> Status Byte | Byte Count |
| :---: | :---: | :---: |
| $01123^{14} 56$ | 6 |  |

If the $R$ field of the TIO instruction is an even value and not 0 , the condition code is set, register Rul is loaded as shown above, and register $R$ is loaded as follows:


Refer to Tables 14-17 for functions of individual bits within status words.
Affected: (R), (Rul), CC

If CC4 $=0$, the MIOP is in a normal mode of operation and the meaning of the condition code during a TIO is:

$$
\begin{array}{lllll}
1 & 2 & 3 & 4 & \text { Meaning } \\
\hline 0 & 0 & 0 & 0 & \begin{array}{l}
\text { I/O address recognized, acceptable SIO is } \\
\text { currently possible, and status information in } \\
\text { general registers is correct. }
\end{array}
\end{array}
$$

0010 For RMP, I/O address recognized, acceptable SIO is currently possible; however, status information in the general registers may be incorrect. For MIOP, not possible.
$010 \begin{array}{llll}0 & 1 & 0 & \text { I/O address recognized but acceptable SIO }\end{array}$ is not currently possible because device controller or device is busy. Status information in general registers is correct.

0110 For RMP, I/O address recognized but acceptable SIO is not currently possible because device controller or device is busy; status information in general registers may be incorrect. For MIOP, not possible.

1010 Processor Interface detected parity error on returned status and/or condition code. The result of the TIO is indeterminate.
$1100 \mathrm{I} / \mathrm{O}$ address not recognized, TIO not accepted, and status information returned to general registers is incorrect.
 because an error detected when the IOP attempted to read and transfer the TIO parameters (device/device controller address and R field information) from the BP to the IOP via main memory. Status information returned to general registers is incorrect.

If CC4 $=1$, the MIOP is in the test mode and the meaning of the condition code during a TIO is:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Meaning
$0 \quad 0 \quad 0 \quad 1$ Unit is performing an Order Out operation.
0101 Unit is performing an Order In operation.
1001 Unit is performing a Data Out operation.
1011 Parity error detected by Processor Interface on returned status and/or condition code. The result of the TIO is indeterminate.

1101 Unit is performing a Data In operation.

1111 BCF detected while unit performing a Data In operation.

| * | 4E | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 1/O address |

TEST DEVICE is used to provide information about a device other than that obtainable by means of the TIO instruction. The operation of the selected IOP, device controller, and device is not affected, and no operations are initiated or terminated. The responses to TDV provide the program with information giving details on the condition of the selected device, the number of bytes remaining to be transmitted in the current operation, and the present point at which the IOP is operating in the command list.

If the $R$ field of the TDV instruction is 0 , the condition code is set, but no general registers are affected.

If the $R$ field of TDV is an odd value, the condition code is set and the device status and byte count are loaded into register $R$ as follows:

| Device Status Byte | Operational Status Byte | Byte Count |
| :---: | :---: | :---: |

If the value of the $R$ field of TDV is an even value and not 0 , the condition code is set, register Rul is loaded as shown above, and register $R$ is loaded as follows:


Rofor to the applicable periphera! reference manual for description of Device Status Byte. Refer to Tables 16 and 17 for functions of other bits within status words.

Affected: (R), (Rul), CC

If CC4 $=0$, the MIOP is in a normal mode of operation and the meaning of the condition code during a TDV is:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Meaning

$0 \quad 0 \quad 0 \quad 0 \quad$ I/O address recognized, no device-dependent condition present, and status information in general registers is correct.

0110 For RMP, I/O address recognized and no device-dependent condition present; however, status information in general registers may be incorrect. For MIOP, not possible.

0100 I/O address recognized and device-dependent condition is present or device controller is in test mode.

0110 For RMP, I/O address recognized, devicedependent condition is present, or device controller is in test mode; but status information in the general registers may be incorrect. For MIOP, not possible.
$1 \quad 2 \quad 3 \quad 4$ Meaning
1010 Processor Interface detected parity error on returned status and/or condition code. The result of the TDV is indeterminate.
$1100 \mathrm{I} / \mathrm{O}$ address not recognized, TDV not accepted, and status information returned to the general registers is incorrect.

1110 No I/O address recognized and TDV aborted because an error detected when the IOP attempted to read and transfer the TDV parameters (device/device controller address and $R$ field information) from the $B P$ to the IOP via main memory. No status information returned to general registers.

If CC4 $=1$, the MIOP is in the test mode and the meaning of the condition code during a TDV is:

1234 Meaning
$\begin{array}{llll}0 & 0 & 0 & 1\end{array}$ Unit is performing an Order Out operation.
0101 Unit is performing an Order In operation.
10001 Unit is performing a Data Out operation.
1011 Parity error detected by Processor Interface on returned status and/or condition code. The result of the TDV is indeterminate.

1101 Unit is performing a Data In operation.
1111 BCF detected while unit performing a Data In operation.

HIO HALT INPUT/OUTPUT
(Word index alignment, ${ }^{\dagger}$ privileged)

| * | 45 | P | $\times$ | Reference address |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 10j0j0] | I/O address |

HALT INPUT/OUTPUT causes the addressed device to immediately halt its current operation (perhaps improperly, in the case of magnetic tape units, when the device is forced to stop at other than an interrecord gap). If the device is in an interrupt-pending condition, the condition is cleared.

[^11]If the R field of the HIO instruction is 0 , the condition code is set, but no general registers are affected.

If the $R$ field is an odd value, the condition code is set and the following information is loaded into register $R$.

| Device Status Byte | Operational Status Byte | Byte Count |
| :---: | :---: | :---: |

If the R field of HIO is an even value and not 0 , the condition code is set, register Rul is loaded as shown above, and register $R$ contains the following information.


This information shows the status of the addressed I/O subsystem at the time of the halt. The byte count field shows the number of bytes remaining to be transmitted to or from memory. Other fields are described in Table 14-17.

The HIO instruction must have zeros in bit positions 15, 16, and 17 to differentiate it from the RIO, POLP, and POLR instructions, which also have $\mathrm{X}^{\prime} 4 \mathrm{~F}^{\prime}$ as an operation code (bits 1-7).

Affected: (R), (Rul), CC

If CC4 $=0$, the MIOP is in a normal mode of operation and the meaning of the condition code during an HIO instruction is:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Meaning
0000 I/O address recognized, HIO accepted, device controller not busy at time of HIO, and status information in general registers is correct.

0010 For RMP, I/O eddress recognized, HIO ac= cepted, and device controller not busy at time of HIO; but statusinformation ingeneral registers may be correct. For MIOP, not possible.

0100 I/O address recognized, HIO accepted, and device controller busy at the time of the HIO , and status information is correct.

0110 For RMP, I/O address recognized, HIO accepted, and device controller busy at the time of the HIO; but the status information in the general registers may be incorrect. For MIOP, not possible.

1000 Not possible.
1010 Processor Interface detected parity error on returned status and/or condition code. The result of the HIO is indeterminate.

1100 I/O address not recognized, HIO not accepted, and no status information returned to general registers.
$1110 \quad \mathrm{No}$ I/O address recognized and HIO aborted because an error detected when the IOP attempted to read and transfer the HIO parameters (device/device controller address and $R$ field information) from the $B P$ to the IOP. No status information returned to general registers.

If CC4 = 1, the MIOP is in the test mode and the meaning of the condition code during an HIO is:
$\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Meaning
$0 \quad 0 \quad 0 \quad 1$ Unit is performing an Order Out operation.
0101 Unit is performing an Order In operation.
1001 Unit is performing a Data Out operation.
1011 Processor Interface detected parity error on returned status and/or condition code. The result of the HIO is indeterminate.

1101 Unit is performing a Data In operation.
1111 BCF detected while unit performing a Data In operation.

RIn RESET INPUT/OUTPIUT
(Word index alignment, ${ }^{\dagger}$ privileged)

| * | 4F | R | X | Reference address |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 0 | $0 \mid 1$ | 1 CA | UA |  |

RESET INPUT/OUTPUT causes the selected IOP to generate an I/O reset signal to all devices attached to it. In addition to the operation code $\mathrm{X}^{\prime} 4 \mathrm{~F}^{\prime}$, bits 15,16 , and 17 must be coded as 001 , respectively.

An RIO instruction resets the selected unit in the same manner as $Z^{C}$ RIO on the operator's control console. However, unlike the control command, the RIO instruction resets only the addressed unit and may be controlled by the executing program. Since the BP may be addressed as an IOP, it will accept an RIO instruction that causes the $B P$ to reset itself in the same manner as $Z^{C}$ RBP. (Note that this procedure is not normal practice.)

Cluster addresses (CA), bit positions 18-20, may have values of $X^{\prime} 0^{\prime}-X^{\prime} 77^{\prime}$. Cluster addresses $X^{\prime} 0^{\prime}-X^{\prime} 6^{\prime}$ may be assigned to any cluster containing processors (i.e., BP, MIOP, and/ or RMP). In a monoprocessor system, cluster address $X^{\prime} 0^{\prime}$ is assigned to the cluster containing the basic processor (BP). Cluster address $X^{\prime} 7^{\prime}$ is assigned only to the cluster containing a system processor. If CA equals $X^{\prime} 7$ ', the UA field is reserved. Unit addresses (UA), bit positions 21-23, may have values of $X^{\prime} 0^{\prime}-X^{\prime} 7^{\prime}$. Unit addresses are required only if the cluster address is $X^{\prime} 0^{\prime}-X^{\prime} 6^{\prime}$, (i.e., cluster
contains either a BP, MIOP, and/or-RMP). Unit addresses $X^{\prime} 0^{\prime}-X^{\prime} 5^{\prime}$ may be assigned to processors within the cluster. Unit address $X^{\prime} 5^{\prime}$ in cluster $X^{\prime} 0^{\prime}$ is reserved for the $B P$. Unit address $X^{\prime} 6^{\prime}$ is assigned always to the MI and unit address $X^{\prime} 7^{\prime}$ is assigned always to the PI for all clusters.

Status information is returned only in the condition code bits. The R field is not used.

Affected: CC1, CC2, CC3

Condition code settings are as shown below:

| 1 | 2 | 3 | 4 | Meaning |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | $-1 / O$ address recognized. |  |
| 1 | 1 | 0 | - I/O address not recognized. |  |

POLP POLL PROCESSOR
(Word index alignment, ${ }^{\dagger}$ privileged)

|  |  |  |  | Reference address |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| * | 4 F | R | X | 0 | 110 | CA | UA |  |

POLL PROCESSOR causes the addressed unit to return unit fault status in bits 16-31 of register $\mathrm{R}^{\mathrm{tt}}$. This status information is unit dependent (see Appendix C, Table C-1).

In addition to the operation code of $X^{\prime} 4 F^{\prime}$, bits 15,16 , and 17 must be coded as 010 , respectively.

Affected: (R), CCI, CC2, CC3

Condition Code settings are as shown below:

| 1 | 2 | 3 | 4 |
| :--- | :--- | :--- | :--- |

000 - Processor fault interrupt not pending.
010 - Processor fault interrupt pending.
110 -. Unit address not recognized.

POLR POLL AND RESET PROCESSOR
(Word index alignment, ${ }^{\dagger}$ privileged)

| * | 4F |  | X | Reference address |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 4 F | R | X |  | 1/1 | CA | UA |  |

POLL AND RESET PROCESSOR causes the selected unit to return unit fault status in bits 16 to 31 of register $\mathrm{R}^{\text {tt }}$ and resets the unit's fault status register. This status information is unit dependent (see Appendix C, Table C-1).

[^12]The POLR instruction also resets and clears this unit's Processor Fault Interrupt signal and the error status register. In addition to the operation code of $X^{\prime} 4 \mathrm{~F}^{\prime}$, bits 15 , 16 , and 17 must be coded as 011 , respectively.

Affected: (R), CC1, CC2, CC3

Condition code settings for the POLR instruction are:
$123 \quad 3 \quad$ Result of POLR
000 - Processor fault interrupt not pending.
010 - Processor fault interrupt pending.
110 - Unit address not recognized.

AIO ACKNOWLEDGE INPUT/OUTPUT INTERRUPT (Word index alignment, privileged)

| * | 6E | R | X | Reference address |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 01001000\% |

ACKNOWLEDGE INPUT/OUTPUT INTERRUPT is used to acknowledge an input/output interrupt and to identify the I/O subsystem (processor, device controller, device) that is causing the interrupt and why. If more than one I/O subsystem has an interrupt pending, only the subsystem with the highest priority will respond to the AIO. Bits 1823 of the effective virtual address of the AIO instruction (normally used to specify the cluster and unit addresses of the $1 / O$ address field) must be coded 000000 to specify the standard I/O system interrupt acknowledgment (other codings of these bits are reserved for use with special I/O systems). The remainder of the I/O selection code field (bit positions 24-31) are not used in the standard I/O interrupt acknowledgment (the address of the interrupt source is a part of the response from the standard I/O system to the AIO instruction).

Standard I/O interrupts are program controlled via the control flags (IZC, ICE, IUE, HTE, and SIL) within the I/O command doublewords (IOCDs) that comprise the command list for the $\mathrm{I} / \mathrm{O}$ operation. If a particular flag is coded as a 1 and if the corresponding condition occurs within the I/O operation, then an I/O interrupt is requested (e.g. , if the IZC flag is set to 1 and if the byte count for the I/O operation has been decremented to zero, then an $1 / \mathrm{O}$ interrupt is requested by that $1 / O$ subsystem to indicate the end of that $1 / O$ operation; if the IZC flag is coded as a 0 , no $I / O$ interrupt is requested as a result of the byte count being decremented to zero).

If two or more flags are coded to souse on interrupt for two or more conditions, an interrupt is requested whenever any of the "flagged" conditions is detected.

For some conditions (transmission errors, incorrect length), two or more flags must be properly coded (see Chapter 4 for further details on IOCDs).

Some error conditions (e. g., parity error on reading command doubleword) will unconditionally cause an I/O interrupt.

The various conditions which may result in an I/O interrupt, the coding of the corresponding control flags within the IOCD, and the bit position within the status word (returned to register $R$ ) that indicates the presence (1) or absence ( 0 ) of that interrupt condition are listed below:

| Condition | Control Flags Coding | Status <br> Bit Set |
| :---: | :---: | :---: |
| Zero byte count | $I Z C=1$ | 10 |
| Channel end | $I C E=1$ | 11 |
| Transmission memory error | $I U E=1, H T E=1$ | 12 |
| Write lock violation | IUE $=1, \mathrm{HTE}=1$ | 12 |
| Incorrect length | $\begin{aligned} & \text { IUE }=1, \mathrm{HTE}=1 \\ & \text { and SIL }=0 \end{aligned}$ | 8,12 |


| Memory address error, IOP memory error, IOP control error, or device connection address parity error | (no flag needed) | 12 |
| :---: | :---: | :---: |
| Transmission data error | IUE $=1, \mathrm{HTE}=1$ | 9,12 |
| Unusual end | IUE $=1$ | 12 |
| IOP halt | IUE $=1$ | 12,14 |

Interrupts may also be requested by certain I/O devices when they execute specific orders (e.g., when a magnetic tape unit executes a Rewind and Interrupt order). Refer to the applicable peripheral reference manual for further details.

When a device interrupt condition occurs, the IOP forwards the request to the interrupt system I/O interrupt level. If this interrupt level is armed; enabled, and not inhibited; the BP eventually acknowledges the interrupt request and executes the XPSD instruction in main memory location $\mathrm{X}^{\prime} 5 \mathrm{C}^{\prime}$, which normally leads to the execution of an AIO instruction.

For the purpose of acknowledging standard I/O interrupts, the IOPs, device controllers, and devices are connected in a preestablished priority sequence that is customer-assigned and is independent of the physical locations of the portions of the $\mathrm{I} / \mathrm{O}$ system in a particular installation.

If the $R$ field of the AIO instruction is 0 , the condition code is set but the general register is not affected.

If the $R$ field of AIO is not 0 , the condition code is set and register $R$ is loaded with the following information.

| DC Status Byte | IOP status | CA | UA | DC address |
| :---: | :---: | :---: | :---: | :---: |

The functions of bits within the DC status byte (which are unique to the device and device controller) are described in applicable peripheral reference manuals. The functions of other bits in the AIO response word are described in Tables 18, 19, and 20.

The AIO instruction resets the interrupt request signal for the I/O subsystem responding to the AIO (i.e., I/O subsystem identified by bits 19-31 of register R).

Affected: (R), CC

If CC4 $=0$, the MIOP is operating in a normal mode of operation and the condition code settings for AIO are shown below:

## $\begin{array}{llll}1 & 2 & 3 & 4\end{array}$ Result of AlO

0000 Normal interrupt recognized and reset. Status information in general register is correct.
$\begin{array}{lllll}0 & 0 & 1 & 0 & \text { For RMP, normal interrupt recognized and }\end{array}$ reset; status information in the general register may be incorrect. For MIOP, not possible. Parity error on returned status and/or condition code. The result of the AIO is indeterminate.

1010 Processor interface detected.
0100 Unusual condition interrupt recognized and reset. Status information in general regisier is correct.

## 1234 Result of AIO

0110 For RMP, unusual condition interrupt recognized and reset; status information in the general register may be incorrect. For MIOP, not possible.

1000 Interrupt recognized and reset. Status information not returned.
$1100 \mathrm{NoI} / \mathrm{O}$ device requesting an interrupt and no status information returned to the general register.

1110 Not possible.

If CC4 $=1$, the MIOP is in the test mode and the meaning of the condition code during an AIO is:
$1 \begin{array}{lll}1 & 2 & 4\end{array}$
$\begin{array}{llll}0 & 0 & 0 & 1\end{array}$ Unit is performing an Order Out operation.
0101 Unit is performing an Order In operation.
1001 Unit is performing a Data Out operation.
1011 Parity error detected by Processor Interface.
1101 Unit is performing a Data In operation.
1111 BCF detected while unit is performing a Data in operation.

## 4. INPUT/OUTPUT OPERATIONS

To accommodate the variety and number of $1 / O$ devices which may be required for scientific and commercial applications, a Xerox 560 computer system may include the following: External Direct Input/Output (DIO) interface, Multiplexor Input/Output Processors (MIOPs), and Rotating Memory Processors (RMPs).

## EXTERNAL DIO INTERFACE

An external DIO interface permits standard and specially designed I/O devices to perform I/O operations (normally in a real-time environment) that are controlled directly by the basic processor (BP). Appropriate control signals and up to one word ( 32 bits) of data may be exchanged between the BP and an addressed I/O device for each READ DIRECT or WRITE DIRECT instruction executed by the BP.

During a WRITE DIRECT instruction (Mode 2 through F), the BP holds the control and data- lines stable until an acknowledgment signal is received from the addressed $\mathrm{I} / \mathrm{O}$ device. During a READ DIRECT instruction (Mode 2 through $F$ ), the $B P$ holds the control lines stable until the addressed I/O device furnishes the data accompanied with an acknowledgment signal. Any delay encountered in receiving the acknowledgment signal, for either READ DIRECT or WRITE DIRECT instructions, does not have an adverse effect upon I/O operations being performed by the MIOP or RMP systems.

Refer to Xerox publication 900973 (Interface Design Manual) for further details pertaining to the external DIO interface. Also, refer to appropriate peripheral reference manuals for details on control and data signals.

## MULTIPLEXOR INPUT/OUTPUT PROCESSOR (MIOP)

An MIOP permits standard and commercially available I/O devices (e.g., card readers, card punches, magnetic tape units, etc.) to be controlled primarily by individual I/O subchannels within the MIOP and associated device controllers. Depending upon the number of I/O subchannels assigned (maximum of 16, as described under "Device Controllers"), an equivalent number of $1 / O$ operations may be performed simultaneously.

## DEVICE CONTROLLERS

All I/O devices associated with an MIOP are connected via an appropriate device controller. Depending upon the number and type of I/O devices to be connected, one or
more of the following types of device controllers may be connected to an MIOP:

1. Single-unit device controller (internal or external).
2. Multi-unit device controller (internal or external).
3. Unit-record controller (internal or external).

Generally, an internal device controller is physically connected via the internal $1 / O$ interface.

An external device controller is located remotely to the MIOP and may require one or more separate chassis to accommodate it.

A single-unit device controller (internal or external) is specifically designed to control only one I/O device, usually a unit-record device such as a card reader, a card punch, or a line printer. Characteristics of a single-unit device controller are dependent upon the device controlled. (Refer to an appropriate peripheral reference manual for further information.)

A multi-unit device controller (internal or external) is specially designed to control more than one I/O device, where all the $1 / O$ devices are of the same type (e.g., magnetic tape units or RADs). However, only one I/O device at a time may be actively involved in a data transfer operation. Characteristics of a multi-unit device controller are dependent upon the I/O devices controlled. For example, a multi-unit device controller for magnetic tape units may control up to eight units. (Refer to an appropriate peripheral reference manual for further information.)

Unit-record controllers (internal or external) are designed to control up to eight unit record type of I/O devices (e.g., card readers, card punches, line printers). Al! I/O devices attached to a unit-record controller need not be of the same type. All I/O devices attached to a unit-record controller may perform separate $1 / \mathrm{O}$ operations, including data transfers, simultaneously.

The number of device controllers, as well as the number of I/O devices, that may be connected to an MIOP is dependent upon the following considerations:

1. The maximum number of $I / O$ subchannels within an MIOP is 16 .
2. Each single-unit device controller (internal or external) requires one $\mathrm{I} / \mathrm{O}$ subchannel.
3. Each multi-unit device controller (internal or external) requires one of the first eight subchannels within the MIOP.
4. Each unit-record controller (internal or external) requires one $1 / O$ subchannel per each unit record device attached, up to a maximum of eight.
5. The maximum number of internal device controllers within an MIOP is eight (where a unit-record device controller is equivalent to one, regardless of the number of assigned subchannels).
6. Any $\mathrm{I} / \mathrm{O}$ subchannel not assigned to an internal device controller may be assigned to an external device controller. Thus, if an MIOP has no internal device controller, all $16 \mathrm{I} / \mathrm{O}$ subchannels may be assigned to external device controllers.

## ROTATING MEMORY PROCESSOR (RMP)

Each RMP is a special purpose, single-channel IOP designed to enhance high-speed data transfers between main memory and any one of up to eight disk units. Functionally, an RMP is comparable to an MIOP, except: (1) at any given time, only one disk unit may be selected for a data transfer operation, (2) data transfer rate of disk units are generally higher than data transfer rates of $\mathrm{I} / \mathrm{O}$ devices attached to an MIOP, and (3) the device controller function is performed by the RMP, hence disk units are connected directly to the RMP rather than via a device controller. (Note: Although only one disk unit may be actively transferring data at any given time, the other units may be active in performing control functions, e.g., seeking).

## 

This section contains general information, programming concepts, and definition of terms pertaining to $1 / O$ operations performed by Input/Output Processors (i.e., MIOP and RMP systems). The large variety of I/O devices which may be used with these IOPs precludes a detailed or exhaustive description of features which are unique to each device. Likewise, a general reference "Refer to an appropriate Xerox peripheral reference manual" is made rather than citing specific manuals.

Within this manual, the following terminology is used to differentiate the hierarchy of control during an I/O operation: The BP executes instructions, the IOPs execute commands, and the device controller/device execute orders.

## COMMAND LIST

Each I/O operation performed by an IOP must be defined by a command list. The characteristics and requirements of a command list are as follows:

1. It is normally created by a BP-executed program prior to the time that the defined $1 / O$ operation is initiated. It must reside in main memory when the $1 / \mathrm{O}$ operation is initiated and subsequently executed.
2. Depending upon various programming considerations, the command list may be contained within one or more areas of memory and each area may be comprised of one or more I/O command doublewords (IOCDs).
3. Command list continuity between IOCDs relating to the same logical record or to the same logical file may be specified (see "Data Chain Flag" and "Command Chain Flag" under "Operational IOCDs"). Command list continuity between portions of a command list located in different areas of main memory may be accomplished by including a control IOCD within the command list (see "Transfer in Channel" under "Control IOCDs").
4. Each IOCD is comprised of two words in contiguous memory word locations. The first word must be stored in an even memory word location and the second word must be stored in the next consecutive (odd) memory word location. Each IOCD is either an operational IOCD or a control IOCD and contains coded parameters to define either a complete I/Ooperation or an integral portion of an I/Ooperation. (See "Operational IOCD" and "Control IOCD" for further details.)

## OPERATIONAL IOCD

An operational IOCD may contain up to five fields of parameters, as required, to define either an entire I/O operation or an integral portion of an $1 / O$ operation. The general format and description of parameters contained within an operational IOCD are as follows:

| Order | 00 | Memory Byte Address |
| :---: | :---: | :---: |


| Flags | WK | 0-0 | Byte Count |
| :---: | :---: | :---: | :---: |

## ORDER

This 8-bit field (bit positions $0-7$ ), if required, may be coded to specify either an input or an output order that is executed by the device controller/device. General coding formats and functions of typical 1/O orders are listed below:

## Bit Position

| 01234567 | Order | Function |
| :---: | :---: | :---: |
| MMMMMM01 | Write | Output operation |
| MMMMMM10 | Read | Input operation |
| MMMMMM11 | Control | Output control information |
| MMMMO 100 | Sense | Input control information |
| MMMM1100 | Read Backward | Input data, in reverse sequence |

Orders that are executed by a specific type of device are listed and described in the appropriate Xerox peripheral equipment reference manual.

When an operational IOCD is fetched by the IOP, the content of the order field, if required, is loaded into an order register within the device controller/device. If two or more IOCDs are required to define a logical record (as described under "Data Chain Flag"), the order obtained from the first IOCD prevails for all subsequent IOCDs within that logical record and any orders contained within the subsequent IOCDs are ignored.

## MEMORY BYTE ADDRESS

This 22-bit field (bit positions 10-31), if required, is coded with the initial memory byte address for the I/O operation that will be performed when the current IOCD is executed. When the IOCD is fetched by the IOP, the content of the memory byte address field is loaded into a memory byte address register within the appropriate I/O subchannel of the IOP. Thereafter, the content of the memory byte address register is incremented (or decremented during Read Backward operations) by one for each byte of data or information transmitted, even though access to main memory may be inhibited (as described under "Skip Flag") or the data is rejected by a memory unit (as described under "Write Key").

Depending upon the characteristics of the I/O device, the content of bit positions 10-31 may either be ignored (e.g., "Rewind" order for magnetic tape units) or specify memory byte locations that contain supplemental control information (e.g., starting address for a disk seek operation). Refer to an appropriate Xerox peripheral equipment reference manual for further details.

## FLAGS

Each operational IOCD contains eight control flags bit positions 32-39). As described below, each control flag is coded to specify a particular control function that may be performed by the IOP either during or at the end of the current IOCD.

Data Chain Flag (Bit Position 32). Coding of the data chain flag is dependent upon the number of IOCDs required to define the data transfers for a logical record. If two or more IOCDs are required (e.g., to perform a "gather-write" or a "scatter-read" operation), the data chain flag of each operational IOCD, except the last IOCD, must be coded as a i. The data chain fiag of the last IOCD or the oniy IOCD (if the record is defined by a single IOCD) is coded as 0 . If data chaining is specified and no error conditions are encountered, the IOP will automatically fetch the next operational IOCD when the byte count (described later) of the current IOCD is reduced to zero. (Note: The IOP may also fetch and execute a control IOCD containing a Transfer
in Channel command, as described later, before fetching the next operational IOCD.) As a result of fetching the next operational IOCD, all parameters, except the I/O order, are updated and the device controller/device continue to operate as if the I/O operation were defined by a single IOCD (i.e., the data chain operation is transparent to the device controller/device). If data chaining is not specified, the IOP will generate a "count done" signal when the byte count of the current IOCD is reduced to zero. The "count done" signal indicates that the IOP has completed all data transfers for the current logical record. However, as described under "Interrupt on Channel End Flag", the I/O order is not completed until the device signals a "channel end".

Interrupt at Zero Byte Count Flag (Bit Position 33). If an I/O interrupt is to be requested when the byte count of the current IOCD is reduced to zero, the Interrupt at Zero Byte Count (IZC) flag must be coded as a 1 . If the I/O interrupt level within the interrupt system (location $\mathrm{X}^{\prime} 5 \mathrm{C}^{\prime}$ ) is armed, enabled, and not inhibited, the request will be processed by the BP in accordance with the priority that prevails within the interrupt system, the IOPs, and the I/O subchannels within an MIOP. The occurrence of an I/O interrupt because of a zero byte count condition is reported as status information (bit position 10 of register R ) when the BP executes an AIO instruction (normally part of the I/O interrupt handling routine). The I/O interrupt request may be processed without interfering with the I/O operation. (Note: An I/O interrupt may be requested at "channel end" or on "unusual end" condition, as described later.)

Command Chain Flag (Bit Position 34). Command chaining permits an I/O device to execute a multiple number of orders relating to the same I/O operation in a consecutive manner (e.g., when reading a multi-record file, the I/O device may automatically receive a new Read order upon completing the current Read order without the BP executing another SIO instruction). Command chaining, if required, is specified by coding the command chain flag as a 1 in the IOCD of each record, except the last.

If command chaining is specified, the IOP will fetch the next operational IOCD when the device signals a "channel end" unless terminated by an "unusual end" condition. As a result, new parameters are stored in the appropriate registers within the $I / O$ subchannel and a new $1 / O$ order is received by the device controller/device.

Thus, an IOP will automatically access main memory and fetch the next operational IOCD if either data chaining or command chaining is specified. If data chaining and command chaining are both specified in the same command doubleword, a data chaining operation will be performed if the byte count is reduced to zero before the device signals a "channel end" and a command chaining operation will be performed if a "channel end" occurs before the byte count is reduced to zero. If neither data chaining or command chaining is specified, the I/O operation is completed when the device signals a "channel end". Note that command chaining is inhibited by "unusual end".

Interrupt at Channel End (Bit Position 35). An I/O interrupt may be requested when the device signals a "channel end" (signifying that the current order has been either completed or terminated) by coding the Interrupt at Channel End (ICE) flag as a 1. If the I/O interrupt level within the interrupt system (location $X^{\prime} 5 C^{1}$ ) is armed, enabled, and not inhibited, the request will be processed by the $B P$ in accordance with the priority that prevails within the interrupt system, the IOPs, and the I/O subchannels of the MIOP. The occurrence of an I/O interrupt because of a "channel end" is reported as status information (bit position 11 of register R ) when the BP executes an AIO instruction (normally part of the $I / O$ interrupt-handling routine). The I/O interrupt request may be processed without affecting the I/O operation. (Note: Specific conditions under which a "channel end" signal may be generated are dependent upon the characteristics of the device. Refer to an appropriate Xerox peripheral reference manual for further details.)

Halt on Transmission Error Flag (Bit Position 36). The following errors (or "unusual end" condition) may be detected by the MIOP when an IOCD is being executed:

1. Bus check fault (BCF) while fetching data.
2. Transmission Data Error (TDE); may also be detected by device controller.
3. Transmission Memory Error (TME).
4. Write Lock Violation (WLV), during input operations only.
5. Incorrect length, conditional; see "Suppress Incorrect Length Flag".
6. Memory Interface Error (MIERR) while fetching data.

If the HTE flag is coded as a 0 , the above errors are recorded when detected and reported as status information when the BP executed an SIO, TIO, or HIO instruction, but the $\mathrm{I} / \mathrm{O}$ operation is not halted.

If the HTE flag is coded as a 1 , and any error (as listed above) is detected, the $1 / O$ operation is terminated immediately. The error is also reported as status information when the BP executes an $\mathrm{SIO}, \mathrm{HIO}$, or TIO instruction.

The HTE flag must be coded identically in every IOCD associated with the same logical record. Thus, if data chaining is specified, the HTE flag in the new IOCD must be the same as the HTE flag in the previous IOCD. This restriction applies to data chaining only, and not to command chaining.

In addition to the "unusual end" conditions listed above, which may terminate the I/O operation only if the HTE flag is coded as a 1, any of the following "unusual end" conditions will unconditionally terminate the I/O operation:

## 1. Memory Address Error (MAE).

2. IOP Control Error (IOPCE).
3. Control Check Error (CCF).
4. IOP Memory Error (IOPME).
5. Bus Check Fault (BCF) while fetching an IOCD.
6. Memory interface Error (MIE) while fetching an IOCD.

Interrupt on Unusual End Flag (Bit Position 37). If an I/O Interrupt is to be requested when an "unusual end" condition is defected while either fetching or executing an IOCD, the Interrupt on Unusual End (IUE) flag must be coded as a 1. If the I/O interrupt level within the interrupt system (location $X^{\prime} 5 C^{\prime}$ ) is armed, enabled, and not inhibited, the request will be processed by the BP in accordance with the priority that prevalis within the interrupt system, the IOPs, and the I/O subchannels within an MIOP. The occurrence of an $1 / O$ interrupt because of an "unusual end" condition is reported as status information (bit position 12 of register R ) when the BP executes an AIO instruction (normally part of an $1 / O$ interrupt-handling routine). The I/O interrupt request may be processed without affecting the progress of the $\mathrm{I} / \mathrm{O}$ operation.

If the IUE flag is coded as a 0 , an "unusual end" condition may be detected but no interrupt will be requested.

Suppress Incorrect Length Flag (Bit Position 38). An incorrect length condition may occur when the specified byte count is not equal to a fixed or prescribed byte count for a record (e.g., attempting to read more than 80 columns of data from a punched card). Specific conditions under which an incorrect length signal is generated are dependent upon the device. Refer to an appropriate Xerox peripheral equipment reference manual for further details.

If the Suppress Incorrect Length (SIL) flag is coded as a 0 when an incorrect length condition is detected, it is reported as an incorrect length and, depending upon the device, may be reported as an "unusual end". If the HTE flag is also coded as a 1, the I/O operation is terminated and reported as an "unusual end".

If the SIL flag is coded as a 1 when an incorrect length condition is detected, it is reported as an incorrect length but suppressed as an "unusual end". Hence, the I/O operation is not terminated.

The presence or absence of an incorrect length condition is reported as status information when the BP executes an $\mathrm{SIO}, \mathrm{HIO}, \mathrm{AIO}$, or TIO instruction.

Skip Flag (Bit Position 39). If the Skip (S) flag is coded as a 0 , it has no effect upon the I/O operation.

If the $S$ flag is coded as a 1 , the IOP is inhibited from accessing main memory and consequently no data is transferred between the main memory and the data buffers of the $1 / \mathrm{O}$ subchannel. All other operations or functions within the

I/O subchannel (i.e., data transfers between the device and data buffers, updating the memory byte address and byte count, and functions as specified by the control flags) are performed in a normal manner.

For input operations, the Skip flag (in conjunction with data chaining) provides the capability to selectively read portions of a record.

For output operations, the IOP will generate and transmit zeros ( $\mathrm{X}^{\prime} 00^{\prime}$ ) until the byte count is reduced to zero. Thus, for example, if the IOCD contains a Punch Binary order, a byte count of 120 , and the $S$ flag is coded as a 1 , a blank card may be punched without accessing main memory for data.

## WRITE KEY

This four-bit field (bit positions 40-43), if required, may be coded with an appropriate write key. During input operations and providing the Skip control flag is coded as a 0 , the IOP will access main memory and furnish a memory unit with up to four bytes of data or information accompanied with a four-bit write key. If the write key matches the preassigned write lock for the memory word location accessed, or if either the key or lock has a value of 0000, the memory unit accepts and stores the information. If the write key does not match the write lock, and neither the key nor the lock has a value of 0000, the memory unit rejects the information, does not disturb the previous content, and transmits a Write Lock Violation (WLV) signal to the IOP. The write key/write lock relationship is compared every time a memory word location is accessed for storing data or information. (Note: The write key/write lock relationship may change during an input operation when the byte address is incremented (or decremented) across a memory page boundary.)

As long as the write key matches the write lock for each memory word location accessed, or the value of either the lock or the key is 0000, the input operation is performed as specified by the other parameters within this IOCD; or the input operation is terminated by an "unusual end" condition which can not be inhibited (i.e., memory address error, control check fault, or IOP memory error).

If the HTE control flag is coded as a 1 when a WLV signal is received, the I/O operation is terminated immediately. If either the ICE or IUE control flag is coded as a 1 , an I/O interrupt is requested.

If the HTE control flag is coded as a 0 when a WLV signal is received, the $1 / O$ operation continues in a normal manner, even though the data or information may be rejected by a memory unit.

When the IOP receives a WLV signal, the WLV bit within the status information register is set to 1 and remains set until a new I/O operation is initiated within this I/O subchannel by an SIO instruction. Thus, after the first WLV signal has been recorded, subsequent WLV signals have no
further effect upon the WLV bit. The status of the WLV bit is reported when the BP executes an SIO, TIO, TDV, HIO , or AIO instruction.

The contents of the write key field is not required and may be ignored when the write key/write lock memory protection feature is not operative (i.e., during any output operation or during any input operation, if the Skip control flag of the current IOCD is coded as a 1 ).

## BYTE COUNT

This 16-bit field (bit positions 48-63), if required, may be coded to specify the total number of data or information bytes that are to be transmitted by the current IOCD. The minimum number of bytes is 1 and the maximum is 65,356 bytes ( 16,384 words). When the IOCD is fetched, the content of the byte count field is loaded into a byte count register within the appropriate $1 / O$ subchannel. Thereafter, the content of the byte count register is decremented by one for each byte transmitted and then tested for a zero byte count condition. (Note: As a consequence of decrementing before testing for a zero byte count condition, an initial byte count value of 0 is interpreted as 65,356 bytes.) Unless the $1 / O$ operation is terminated (e.g., as the result of detecting an "unusual end"), data is transmitted until the byte count is reduced to zero. At any time, the progress of the $1 / O$ operation may be ascertained by evaluating the current byte count which is furnished as status information when the BP executes an $\mathrm{SIO}, \mathrm{TIO}, \mathrm{HIO}$, or TDV instruction. (That is, current byte count is equal to the number of bytes remaining to be transmitted and initial byte count minus current byte count is equal to the number of bytes transmitted.) When the byte count is reduced to zero, the MIOP may perform the following functions:

1. Transmit a "count done" signal to the device controller/ device if data chaining is not specified.
2. Request an I/O interrupt, if the IZC flag is coded as ail.
3. Fetch the next IOCD, if the data chain flag is coded as al.

Depending upon the characteristics of the $1 / O$ device, certain I/O orders (e.g., Rewind for magnetic tape units) may not require a byte count field. In such case, the byte count field is ignored. Refer to an appropriate Xerox peripheral equipment reference manual for further details.

## CONTROL IOCD

A control IOCD may contain either a Transfer in Channel or a Stop command.

Transfer in Channel. A control IOCD containing a Transfer in Channel command has the following format:



The Transfer in Channel command is executed within the IOP and has no direct effect on any of the I/O elements external to the addressed IOP. The primary purpose of this command is to permit branching within the command list (i. e., fetching the next operational IOCD from a pair of memory word locations other than the next two consecutive word locations).

When the IOP executes the Transfer in Channel command, it loads the command address register of the appropriate I/O subchannel with the contents of bit positions 13-31 (the "next command doubleword address" field), fetches and loads the new operational IOCD into appropriate registers within the I/O subchannel and order register within the device controller/device (unless data chaining is specified), and then executes the new IOCD. (Bit positions $8-12$ and $32-61$ are ignored and should be coded as zeros.)

If data chaining or command chaining is specified in the IOCD preceding the IOCD containing a Transfer in Channel command, the chaining flags are not significant to nor altered by the Transfer in Channel command.

When used in conjunction with command chaining, Transfer in Channel command facilitates the control of devices such as unbuffered card punches or unbuffered line printers. For example, assume that it is desired to present the same card image twelve times to an unbuffered card punch. The punch counts the number of times that a record is presented to it and automatically generates a "chain modifier" signal when twelve rows have been punched. The command address register within the I/O subchannel is incremented by two by the "chain modifier" signal and the next consecutive IOCD within the command list is skipped over (not fetched or executed). A command list for punching two cards might be as shown in the following example:

| Locations | Description of Command |
| :---: | :---: |
|  | . |
| A, A +1 | Punch row for card 1, command chain. |
| A $+2, A+3$ | Transfer in Channel to location A. |
| A $+4, A+5$ | Punch row for card 2, command chain. |

Locations Description of Command
$A+6, A+7$ Transfer in Channel to location $A+4$.

| $A+8$ | $A+9$ |
| :---: | ---: |
| - | Stop |
| $\cdot$ | $\cdot$ |
| $\cdot$ | - |
|  | - |

The Transfer in Channel command can be used also in conjunction with data chaining. As one example, consider a situation often encountered in data acquisition applications, where data is transmitted in extremely long, contiguous streams. In this case, the data can be stored alternately in two or more buffer storage areas so that computer processing can be carried out on the data in one buffer while additional data is being input into the other buffer. The command list for such an application might be shown in the following example:

| Locations | Description of Command |
| :---: | :---: |
| - | - |
| - | - |
| - | - |
| $B, B+1$ | Read data, store in buffer 1, data chain. |
| $B+2, B+3$ | Store into buffer 2, data chain. |
| $B+4, B+5$ | Transfer in Channel to location B. |
| - | - |
| - |  |

If the IOP encounters two successive Transfer in Channel commands, an IOP control error (IOPCE) occurs and the 1/O operation is terminated immediately. An IOPCE is reported as status information (bit 13 of register Rul) when the BP executes an $\mathrm{SIO}, \mathrm{HIO}, \mathrm{TIO}$, or TDV instruction.

## STOP

A control IOCD with a Stop command has the following format:


The Stop command causes certain devices to stop, generate a "channel end" signal, and also request an I/O interrupt if bit 0 in the IOCD is coded as a 1. If the I/O interrupt
level within the interrupt system (location $\mathrm{X}^{\prime} 5 \mathrm{C}^{\prime}$ ) is armed, enabled, and not inhibited, the request will be processed by the BP in accordance with the priority that prevails within the interrupt system, the IOPs, and the I/O subchannels within an MIOP. The occurrence of an I/O interrupt because of a Stop command is reported as status information (bit position 7 of register R) when the BP executes an AIO instruction (normally part of an $1 / \mathrm{O}$ handling routine).

Bit positions 1-7 must be coded as zeros. Bit positions 8-31 and 40-63 are ignored; but it is recommended that they also be coded as zeros. Bit positions 32-39 are device dependent and must be coded as specified in the appropriate peripheral reference manual.

The Stop command is primarily used to terminate a command chain for an unbuffered device, as illustrated in the first example given for the Transfer in Channel command. Note that not all devices recognize the Stop order.

## I/0 OPERATION PHASES

This section describes the general sequence of events (or phases) of any $1 / \mathrm{O}$ operation performed by an IOP, the function performed by the BP, IOP, and device controller/ device during each phase, and a description of each type of I/O operation including the applicability of parameters that may be contained within a typical operational IOCD. For explanation purposes, each I/O operation has five major phases: preparation, initiation, fetching, executing, and termination phase. Each phase is further described below.

## PREPARATION PHASE

Before an I/O operation may be performed by an IOP, an appropriate command list must reside in main memory.

## INITIATION PHASE

Assuming that an appropriate command list resides in main memory, an I/O operation is initiated only if the BP executes an SIO instruction that is accepted by the addressed IOP, device controller, and device. The acceptance or rejection of an SIO instruction is contingent upon conditions within the addressed IOP, device controller, and device and is indicated by the condition codes at the completion of the $51 O$ instruction. In either case, the BP is able to perform other instructions or tasks immediately after executing an SIO instruction. (Refer to "SIO" instruction, Chapter 3, for further details.)

A successful SIO instruction causes the addressed device to go from the "ready" condition to the "busy" condition.

## FETCHING PHASE

Although the services of the $B P$ are not required during this phase, the BP may at any time execute either a TIO , TDV, or POL instruction without interfering with the I/O operation. However, excessive TIOs and TDVs may cause a data overrun condition. The BP may also execute either an HIO or RIO instruction and stop the $\mathrm{I} / \mathrm{O}$ operation. (An HIO may leave the device in an unpredictable state; an RIO resets all controllers and devices on the addressed IOP. ) As a result of accepting an SIO instruction, a command address register within the I/O subchannel (assigned to control the addressed device controller/device) is loaded with the first command doubleword address, the content of General Register 0 when the SIO instruction is accepted. At the appropriate time, as determined by the priority, the device controller/device will request that the IOP access main memory and fetch the first word of the IOCD from an even memory word location and increment the command address register by one. The disposition of the first word is dependent upon the contents of the first word.

If the order field contains an I/O order for a device controller/device, the content of the order field is either loaded into an order register within the appropriate device controller/device or ignored (if the IOCD is being fetched for a data chained operation). If the order is a Read Backward order, a control flag is also set within the IOP which allows the memory byte address to be decremented rather than incremented during the data transfer.

For all orders (excluding the Transfer in Channel command, described below), the contents of bit positions 10-31 of the first word is loaded into a memory byte address register of an appropriate I/O subchannel. Depending upon the I/O order, as described under "Execution Phase", the content of the memory byte address register may be used or ignored. If used, it specifies which memory word location is to be accessed and also the number of bytes of data (or control information) to be transferred into or out of that location.

If the order field contains a Transfer in Channel command, it is recognized and executed immediately by the IOP. The content of bit positions 13-31 (designated as the "next command doubleword address" field) is loaded directly into the command address register. The Transfer in Channel command is recognized and executed by the IOP, it is fetched and executed as the result of fetching one word (rather than two), and it is transparent to the device controller/device (that is, it is executed without affecting the continuity of an order that is data chained or an I/O operation that is command chained). Note: Although bit positions 0-3 and 8-12 are currently ignored, it is recommended that they be coded as zeros.

Immediately after executing a Transfer in Channel command, the IOP wili automaticaliy fetch the first word of the nexi IOCD as specified by the contents of the "next command doublewordaddress" field. If the order field of the next IOCD also contains a Transfer in Channel command, the I/O operation is terminated immediately and the IOP enters a Halt state because an IOP control error (IOPCE) occurred (attempting to execute two successive Transfer in Channel commands).

Otherwise, the first word of the next IOCD is fetched and loaded as described above, and the second word is fetched and loaded as described below.

Since the Transfer in Channel command permits IOCDs to be fetched from nonconsecutive locations, IOCDs containing Transfer in Channel commands may be included within a command list either to achieve command list continuity from one segment of a command list to another segment or to construct reiterative loops.

For all IOCDs, except a control IOCD containing a Transfer in Channel command, the IOP will automatically access main memory at the appropriate time, as determined by the priority that prevails for accessing main memory, and fetch the second word of the IOCD from the next consecutive ascending (odd) memory word location of the command list and increment the command address register by one. Thus, in all cases, after a fetching operation is completed, the content of the command address register will be an even (or doubleword) address.

The contents of the second word are stored in appropriate registers within the I/O subchannel. Depending upon the I/O order, as described under "Execution Phase", the contents of the various fields are either used or ignored.

In addition to the IOP Control Error (IOPCE), the following types of "unusual end" conditions may be detected during the fetching phase of an 1/O operation: Memory Address Error (MAE), Control Check Fault (CCF), IOP Memory Error (IOPME), Bus Check Fault (BCF), and Memory Interface Error (MIE). The detection of any of these errors causes the I/O operation to be terminated and if the IUE flag is set to a 1 , an "unusual end" interrupt is requested.

## EXECUTION PHASE

Although the services of the BP are not required during this phase, the BP may at any time execute either a TIO, TDV, or POL instruction without interfering with the I/O operation. However, excessive testing may cause a data overrun condition. The BP may also execute either an HIO or RIO instruction and stop the I/O operation. After the second word of an IOCD is fetched and providing no "unusual end" condition was detected, the IOCD is executed as prescribed by the parameters contained therein. As a function of the order and the status of the Skip flag, if applicable, an IOCD may be executed in one of five ways, as described below:

1. Certain Control orders (e.g. , Stop) may be executed by the device while the IOP monitors the operation in accordance with the applicable control flags. Since no memory accesses and data (or information) transfers occur, the contents of the memory byte address register, write key register, and byte count register may be ignored. Other Control orders (e.g., Rewind for a magnetic tape unit) are listed and described in applicable Xerox peripheral equipment reference manuals.

Depending upon the control function performed, certain Control orders may be a part of an I/O operation which may be continued after the Control order is executed. For example, an I/O operation involving a magnetic tape unit may contain a Rewind order to reposition the tape prior to reading (or writing) one or more records.

Note: Within the context of the above explanation, the Control order is defined to be one that does not transfer any information; thus, data chaining is precluded within the IOCD containing the Control order; however, command chaining may be specified. Control orders that involve information transfers when executed are described below (see paragraphs 2 and 4).
2. If the order specifies an input operation (e.g., Read, Read Backward, or Sense) and the Skip flag is coded as a 0 , all parameters of the current IOCD may be applicable. As a result of receiving an appropriate input order, the device transmits data (Read, or Read Backward order) or information from special registers (Sense order) into data buffers of the associated I/O subchannel within the IOP.

Depending upon the priority that prevails for accessing main memory, the IOP accesses a memory word location (as specified by the current memory byte address), transfers up to four bytes of data or information from the data buffers to a memory unit, provides a write key, and increments (or decrements, if Read Backward order) the memory byte address and decrements the byte count by one for each byte transferred out of the data buffers.

The write key is evaluated against the preassigned write lock for the memory word location accessed. If the write key is valid for each memory word location accessed, the input operation continues, as described above, until it is completed or terminated by an "unusual end" condition, other than Write Lock Violation. If the write key is not valid, the memory unit (1) generates and transmits a Write Lock Violation (WLV) signal to the IOP, (2) rejects the new data, and (3) does not disturb the previous contents of the memory word location accessed.

If the write key is invalid for any memory word location accessed and the HTE flag is coded as a 1, the input operation is terminated immediately upon receipt of a WLV signal (see "Termination Phase").

If the HTE flag is coded as a 0 , the memory unit may accept or reject the data or information, based on the write key/write lock evaluation for each memory word location accessed, without affecting the operations within the IOP, device controller, or device. The input operation continues until either completed or terminated by an "unusual end" condition, other than a Write Lock Violation.

Note: Since the same write key prevails for the entire IOCD and all memory locations within a memory page are assigned the same write lock, the write key/write lock relationship may change when the memory byte address is incremented (or decremented) across a memory page boundary.
3. If the order specifies an input operation (e.g., Read, Read Backward, or Sense) and the Skip flag is coded as a 1, all parameters within the IOCD, except the write key, may be applicable. As a result of receiving an appropriate input order, the device transmits data (Read or Read Backward order) or information from special registers (Sense order) into the data buffers within the I/O subchannel of the IOP. Because the Skip flag is coded as a 1 , the IOP can not access main memory (the write key may be ignored and a Write Lock Violation can not occur). Although the data can not be stored in the main memory, the IOP increments the memory byte address (except during a Read Backward order, when it is decremented) and decrements the byte count by one for each byte transferred out of the data buffers. The device may continue to transmit data into the data buffers and the IOP may continue to update the memory byte address and byte count until the current order is either completed in a normal manner or terminated because of an "unusual end" condition (other than a Write Lock Violation).
4. If the order specifies an output operation (e. g., Write or Control) and if the Skip flag is coded as a 0 , all parameters within the IOCD, except the write key, may be applicable. When transferring data (Write order) or information (Control order) out of main memory, the write key/write lock checking is not performed; hence, the write key may be ignored. Likewise, a Write Lock Violation will not occur. For an output operation, the IOP will access main memory (in accordance with the priority that prevails for accessing main memory) and transfer up to four bytes of data (or information), as specified by the current memory byte address, to the data buffers of the appropriate I/O subchannel. The IOP also increments the memory byte address and decrements the byte count by one for each byte of data transferred. Data is then transferred from the data buffers to the device. The IOP may continue to access main memory, transfer up to four bytes of data from main memory to the appropriate data buffers, and update the memory byte address and byte count. The device continues to output data until the order is either completed in a normal manner or terminated because of an "unusual end" condition.
5. If the order specifies an output operation (e. g. , Write or Control) and if the Skip flag is coded as a 1, all parameters within the current IOCD, except the write key, may be applicable. Because the Skip flag is coded as a 1, the IOP can not access main memory for any data (or information). Instead, the IOP generates and loads zeros ( $\mathrm{X}^{\prime} 00^{\prime}$ ) into the data buffers of the appropriate I/O subchannel and increments the memory byte address and decrements the byte count by one for
each byte loaded. The zeros are then transferred from the data buffer to the device. The IOP may continue to generate and load zeros into the data buffers and update the memory byte address and byte count, accordingly, and the device may continue to output zeros until the order is either completed in a normal manner or terminated because of an "unusual end" condition.

## DATA CHAINING

An order may be continued from the current operational IOCD to the next operational IOCD, if data chaining is specified in the current IOCD. In this case, the IOP will automatically fetch the next operational IOCD, as described under "Fetching Phase", when the byte count of the current IOCD is reduced to zero. In the process of fetching the next operational IOCD, the IOP may fetch and execute a control IOCD containing a Transfer in Channel command without affecting the continuity of the order. The process of fetching and loading the next operational IOCD into the control registers of the $1 / O$ subchannel is transparent to the device. That is, the device continues to operate as if the order were defined by a single IOCD. Also, any changes in the status of the Skip flag or in the write key from one IOCD to the next is transparent to the device. The device continues to receive zeros, data, or information from the data buffers during an output operation, or continues to transmit data (or information) into the data buffers regardless of whether it is subsequently rejected or stored while performing an input operation.

During the execution phase, an I/O interrupt may be requested each time the byte count of an operational IOCD is reduced to zero if the Interrupt at Zero Byte Count (IZC) flag is coded as a 1 . Thus, if data chaining is specified, the IOP may request an I/O interrupt without interfering with the process of fetching the next operational IOCD.

If the I/O interrupt level (location $X^{\prime} 5 C^{1}$ ) within the interrupt system is armed, enabled, and not inhibited, the I/O interrupt may be processed by the BP in accordance with the priority that prevails within the interrupt system, the IOPs, and the device controllers connected to the IOP.

The order may be completed in a normal manner when the Data Chain flag of the current IOCD (the last IOCD of a logical record) is coded as a 0 .

## COMMAND CHAINING

An l/O operation may be continued from the current IOCD to the next IOCD if command chaining is specified in the current IOCD. Command shaining is commonly specified when reading (or writing) consecutive records of data from the same file. In which case, the current IOCD must be the last IOCD for the current record and the next IOCD must be the first IOCD of the next logical record. Although the device may execute the same functional order for both records, logically, it is equivalent to two separate orders.

Depending upon the characteristics of the device, command chaining may also be used to perform different operations on either different but consecutive records or upon the same record (e.g., a magnetic tape unit may be programmed to alternately read or write consecutive records or to read the same record backwards after writing). Refer to an appropriate Xerox peripheral equipment reference manual for further details.

If command chaining is specified, the device controller causes the IOP to fetch the next operational IOCD, as described under "Fetching Phase", when the device signals "channel end" (signifying that it is ready to accept and execute another order). In the process of fetching the next operational IOCD, the IOP may fetch and execute a control IOCD containing a Transfer in Channel command without affecting the continuity of the $\mathrm{I} / \mathrm{O}$ operation (i.e., transparent to the device controller/device); however, the fetching of the next operational IOCD is not transparent to the device controller/device. The process of automatically fetching the next operational IOCD because data chaining and/or command chaining is specified in the current IOCD permits an I/O operation to continue normally until an IOCD is executed in which both chaining flags are coded as zeros (the last IOCD of the last record).

If data chaining and command chaining are both specified within an IOCD, data chaining is performed if the byte count of the current IOCD is reduced to zero before the device generates "channel end"; command chaining is performed if the device generates "channel end" before the byte count is reduced to zero.

During the execution phase, an I/O interrupt may also be requested each time a "channel end" occurs if the Interrupt at Channel End (ICE) flag is coded as a I. Thus, if command chaining is specified, the IOP may request an I/O interrupt without interfering with the process of fetching the next operational IOCD.

## TERMINATION PHASE

An I/O operation may be terminated in one of the following manners:

1. Aborted at any time because the BP executed either an HIO or RIO instruction.
2. Aborted when an unconditional "unusual end" condition was detected.
3. Aborted when a conditional "unusual end" condition was detected while the HTE control flag was coded as al.
4. Completed as specified by the command list but with an "unusual end" condition.
5. Completed as specified by the command list.
6. Aborted whenever a SUPER RESET, SYSTEM RESET, or I/O RESET command is entered from the System Control Console (SCC).

The progress of an $\mathrm{I} / \mathrm{O}$ operation, including the termination, may be ascertained by evaluating the status information returned for $1 / O$ instructions, as described in Chapter 3. Depending upon programming considerations, these I/O instructions may be executed either singly or as part of an I/O handling routine and either imperatively at logical points of a BP-executed program or on an "as needed" basis when an I/O interrupt is requested by an IOP or device controller. Normally, an I/O interrupt is requested whenever a critical or significant event occurs within any I/O subchannel, device controller, or device. Typically, an I/O interrupt may be requested when the byte count of any IOCD is reduced to zero, whenever any device detects a "channel end" condition, or when the IOP or any device controller detects an "unusual end" condition, providing the appropriate control flag (IZC, ICE, and IUE) is coded as a 1 .

Note: An I/O interrupt may also be requested by certain devices, e.g., a magnetic tape unit may be able to execute a Rewind and Interrupt order and other devices may request an I/O interrupt when executing a Stop order in which bit 0 is coded as a 1 . Refer to an appropriate Xerox peripheral reference manual for further details.

Once an I/O interrupt request has been made by a device, that device, device controller, and I/O subchannel remain in an interrupt pending condition until the interrupt request is acknowledged, reseł, or cleared.

Normally, an I/O interrupt request is acknowledged by the BP executing an AIO instruction, as part of an I/O interrupt-handling routine; resetby the BP executing either an HIO or an RIO instruction; or for certain devices cleared automatically, as a function of time. Refer to an appropriate Xerox peripheral equipment reference manual for further details.)

Since a multiple number of $\mathrm{I} / \mathrm{O}$ interrupt requests may prevail simultaneously (one per each device controller) and all requests are serviced by a common I/O interrupt level (location $X^{\prime} 5 C^{\prime}$ ), the BP normally acknowledges an $1 / O$ interrupt request based on the priority that prevails within the interrupt system, the IOPs, and the I/O subchannels within an MIOP, if applicable. An interrupt pending condition prevents a new I/O operation from being initiated by an SIO instruction on a particular subchannel but does not affect the current I/O operation. (That is, if an I/O interrupt was requested as the result of a zero byte count or "channel end" condition, and data chaining or command chaining is specified, the I/O operation may continue as specified by the command list.)

## 5. OPERATIONAL CONTROL

## EXTERNAL CONTROL SUBSYSTEM

The External Control Subsystem (ECS) is a group of elements used in this computer system that provide operational and diagnostic interfaces to control and maintain system hardware and software.

## CENTRALIZED SYSTEM CONTROL

In many other computer systems "software-level" operator interactions are transacted through an operator's teletypewriter console while hardware level interactions are performed through a fixed panel of lamps and switches. In contrast, this Xerox computer system consolidates these interactions and controls into a console telecommunications device, designated as the System Control Console (SCC). Through the SCC, the operator has a single control point for all normal system control activities.

A Remote Diagnostic Interface (RDI) permits the local System Control Console to be augmented with a Remote Console that may have the same degree of system control. (Usage of the RDI and Remote Console as a Remote Assist feature is described below, under "Remote Console".)

A System Control Panel (SCP) contains indicators and basic controls that the operator may use during system startup or to establish connections with the remote location.

## CONTROL CONSOLE DEVICES

The ECS provides an interface for two local (primary and alternate) communications consoles and a data set interface for remote diagnostic connection. Each communications console must hove on EIA RS232 voltage interface and format characters in even parity ASCII code with control protocols of a Model 4691 KSR 35 Keyboard/Printer. Allowed communications rates are 10 and 30 characters per second.

## PRIMARY CONSOLE

The primary console always has the functional capability of the System Control Console to communicate with software through I/O subchannel address X'01'. The communications rate of the primary console is either 120 characters per second or the same as the alternate and remote consoles depending on the setting of the FSELA switch on the Configuration Control Panel (see Chapter 6). If the REMOTE CHANNEL switch on the System Control Panel is in the SCC position (implying a remote diagnostic connection), the remote channel frequency is automatically enforced on the primary console.

## REMOTE CHANNEL

The alternate and remote consoles share the same data paths. Both consoles receive the same output; either one of the consoles is selected for input by the ALTSEL switch on the Configuration Control Panel. The communications rates of 10 or 30 characters per second are selected for both consoles by the FSELBO and FSELB1 switches on the Configuration Control Panel. Both consoles may function either strictly as I/O devices or as parallel System Control Consoles selected by the REMOTE CHANNEL switch on the System Control Panel. Description of communications rate selection is found in Chapter 6.

## ALTERNATE CONSOLE

The alternate console normally functions as an output device residing at $I / O$ subchannel address $X^{\prime} O B^{\prime}$. This console can create an edited system log, while the operator's console functions at a higher communications rate. (REMOTE CHANNEL and ALTSEL switches are both OFF.)

If the primary console fails, the alternate console may function as the System Control Console. In this case, the remote console connection is only inhibited by the operator at the data set. (REMOTE CHANNEL switch in SCC position; ALTSEL switch in ON position.)

## REMOTE CONSOLE

Before the remote device can gain access to the Remote Diagnostic Interface (RDI), the operator must manually intervene to establish the connection at the data set and the System Control Panel. The data set (Bell 103A or equivalent) connection is inhibited while the REMOTE CHANNEL switch is in the OFF position.

The remote console may run on-line diagnostics while the rest of the system performs non-maintenance work. In this case, the remote console preempts $1 / O$ subchannel $X^{\prime} O B^{\prime}$ and the alternate (local) console creates a $\log$ of the online mainentance if not turned off. The remote device does not have access to the SCC hardware controls, but may enter software-level control information through the I/O system (REMOTE CHANNEL switch in I/O position, ALTSEL switch in OFF position).

If the entire system is under the discretionary control of remote maintenance personnel, the operator may connect the remote console to the RDI as the System Control Console. The remote console is then connected logically in parallel. and assumes all the functional capability of the primary console, and shares $1 / O$ subchannel $X^{\prime} 01{ }^{\prime}$. (Note that conventions must be established to ensure that the primary and remote consoles do not generate overlapping input.) The remote console communications rate is automatically imposed on the primary console and the operator may have to
change the rate on the primary console to retain parallel control. The alternate (local) device creates a log of all SCC transactions. The normal (log) output on I/O subchannel $X^{\prime} O B^{\prime}$ is suspended for the duration of the SCC assignment to the remote channel (REMOTE CHANNEL switch in SCC position; ALTSEL switch in OFF position).

## CONTROL COMMANDS

A set of commands and display formats implements operator communication with hardware through the System Control Console. These hardware-control commands, called "SCC Functions", are independent, direct hardware controls as distinguished from the software-level operating controls activated from the SCC through the normal I/O system. A special micro-processor, working independently of the BP, senses and controls the execution of SCC functions. The flexibility of character-oriented communications equipment and micro-programmed control significantly enhance many system operating and diagnostic features.

The basic command format provides a four-level interlock on critical system controls by requiring a correct fourcharacter sequence to initiate a command action. In addition, context analysis is provided to assure that commands are executed only in appropriate system states. This basic format requires that each command is preceded by the "control-Z" character (control and Z keys depressed simultaneously). Note that within this text, the control-Z character is represented with the symbol " $Z^{C_{" 1}}$.

A typical command sequence is to enter " $Z^{C} H L T$ " from the SCC. The system responds by printing "(HLT)" on the next line of the SCC printout, and forcing the system to halt instruction execution and enter the IDLE state. If a command cannot be executed due to improper syntax or context, the system provides an advisory message following the command echo indicating the probable source of error. A typical example of the display format is "(RSY) *EVENT A1*", indicating that a reset command may not be executed prior to halting instruction execution. (Refer to Table 21 for a complete listing of event messages.)

The various control functions that may be exercised from the SCC may be generally classified into three categories: operator control commands, diagnostic control commands, and maintenance control commands.

## OPERATOR CONTROL COMMANDS

These commands provide controls which an operator normally uses to control the computer system. By entering the appropriate command the operator may direct the computer system to load, run, halt, reset, read/set the sense switches, or issue a "console interrupt" to the operating software.

The sense switch control and console interrupt commands may interact with the software and are always operative. All other SCC functions may be enabled or disabled by the SCC FUNCTIONS switch on the SCP.

Table 21. Event Messages

| Display | Significance |
| :---: | :---: |
| *EVENT 00* | System Initialization; POWER ON or SUPER RESET. |
| *EVENT A0* | Improper syntax for $\mathrm{Z}^{\text {c }}$ format command. |
| *EVENT Al* | Command not executed; Improper syntax or system may not be in IDLE mode. |
| *EVENT A2* | Command not executed; system not in maintenance mode. |
| *EVENT A4* | Command not executed; SCC FUNCTION switch is in DISABLE position. |
| *EVENT A8* | Power ride through; recoverable power line failure detected; power on trap requested. |
| *EVENT FO* | Trap requested occurred; inhibited in P-Mode. |
| *EVENT F1* | Basic processor error halt; watchdog timeout reset issued when watchdog timeout alarm bit set. (See "Processor Control Word".) |
| *EVENT F4* | Basic processor halt; Address Halt. |
| *EVENT F6* | Basic processor halt; Processor-Detected Fault (PDF). |
| *EVENT F9* | System failed micro-diagnostic test (followed by Single Clock Status Register display of the element that failed). |

To prevent inadvertent activation from disrupting a running system, the SCC FUNCTIONS switch is placed in the DISABLE position.

The following operator control commands are standard features of this system:

| Input | Display | Name of Command |
| :---: | :---: | :---: |
| $Z^{\text {c }} \mathrm{I}$ | (I) | Operator's Console Interrupt |
| $Z^{\text {c }}$ SSW | (SSW=bbbb) | Read Sense Switches |
| $Z^{c} S S^{\#}{ }^{\dagger}$ | $\left(S S^{\# t}=b b b b\right)$ | Set Sense Switches |
| $Z^{\text {c LDN }}$ \#\#\#\#t,tt, $\dagger+\dagger$ | (LDN@\#\#\#\#「) | Load Normal |
| $Z^{\text {c }} \mathrm{RSY}^{\text {tt }}$, ttt | (RSY) | Reset System |
| $Z^{\text {c }} \mathrm{RBP}^{\text {tt, ttt }}$ | (RBP) | Reset Basic Processor |
| $Z^{\text {c }} \mathrm{RIO}^{\text {tt, ttt }}$ | (RIO) | Reset 1/O System |
| $Z^{\text {c }} \mathrm{HLT}^{\text {tt }}$ | (HLT) | System Halt |
| $\mathrm{Z}^{\mathrm{c}} \mathrm{RUN}^{\text {tt,ttt}}$ | (RUN) | System Run |

## $Z^{\text {C }} \quad$ OPERATOR'S CONSOLE INTERRUPT

The Operator's Console (or SCC) INTERRUPT command permits the operator to interact with the executing software by setting interrupt level $X^{\prime} 5 D^{\prime}$. If this interrupt level is Armed when the INTERRUPT command is entered, the interrupt level is advanced to the Waiting state. If the interrupt level is already in the Active state or Disarmed, the INTERRUPT command has no effect upon the computer system. This command is always enabled.

## ZCSSW READ SENSE SWITCHES

This command causes the status of the sense switches to be displayed as part of the command echo. For example, if all four sense switches were set to a 1 , the console display would be " $(S S W=1111)$ ". The status of the sense switches is also displayed by indicators on the System Control Panel. The READ SENSE SWITCHES command is always enabled.

The status of the sense switches may also be read by executing a READ DIRECT instruction (see Chapter 3).

[^13]
## SET SENSE SWITCHES

This command causes the sense switches to be set to the value specified by the hexadecimal digit in the command (\#). The new sense switch value is displayed as part of the command echo. For example, if the operator enters "ZCSS3" the SCC will print "(SS3=0011)". The new status is also displayed by indicators on the System Control Panel. The SET SENSE SWITCHES command is always operative.

The sense switches may also be set by executing a WRITE DIRECT instruction (see Chapter 3). The sense switches are initialized to zero during the power on and SUPER RESET sequences. While the $\mathrm{Z}^{\mathrm{C} S S^{\#}}$ command is active, the basic processor is momentarily put in the IDLE state. This prevents any conflict between the operator command and a WRITE DIRECT instruction.

## ZCGDN\#\#\# LOAD NORMAL

The loading operation is normally accomplished by readying the load device and entering the LOAD NORMAL command from the System Control Console. The four hexadecimal digits (represented as \#\#\#\#) specify the load device address. Successful completion of the command is signified by the command echo"(LDN@\#\#\#\#)". A failure in the load sequence is indicated by a display of an appropriate error message (see Table F- ) following the command echo. The LOAD NORMAL command is accepted only when the system is in the IDLE state.

This single command initiates the following sequence:

1. A series of internal micro-diagnostic tests are conducted to verify the operation of system paths and elements used in the loading sequence. Each test is preceded by a system reset. If a failure is detected during the micro-diagnostic tests, an error message "*EVENT F9*" is generated and followed by a Single Clock Status Register display identifying the failing element.
2. Upon completion of all micro-diagnostic tests, a system reset is issued.
3. All system memory locations are initialized to zero.
4. The basic processor loads a self-diagnostic program in memory locations X'100' through X' 1FF' and loads the bootstrap loader (see Figure 14) in memory locations $X^{\prime} 20^{\prime}$ through $X^{\prime} 29{ }^{\prime}$. If an error is detected during the process, an error message "*EVENT F0*", is generated.
5. The system is placed in the RUN mode.
6. The basic processor executes the self-diagnostic program, beginning at location $X^{\prime} 160$ '. The processor then executes the bootstrap loader, starting at location $X^{\prime} 26^{\prime}$. If a failure occurs during the processor selfdiagnostic program, the processor enters the WAIT state.

| $\begin{aligned} & \text { Locat } \\ & \text { (hex) } \end{aligned}$ | (dec) | Hexadecimal | Symbolic of instruc | $\begin{aligned} & \text { form } \\ & \text { ion } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| 20 | 32 | 020000A8 |  |  |
| 21 | 33 | OE000058 |  |  |
| 22 | 34 | 22110029 | LI, 1 |  |
| 23 | 35 | 64100023 | BDR, 1 |  |
| 24 | 36 | 68000028 | BCR, 0 | 40 |
| 25 | 37 | 0000\#\#\#\# ${ }^{\text { }}$ |  |  |
| 26 | 38 | 22000010 | LI, 0 |  |
| 27 | 39 | CC000025 | SIO, 0 | *37 |
| 28 | 40 | CD000025 | TIO, 0 | *37 |
| 29 | 41 | 69C00022 | BCS, 12 | 34 |
| ${ }^{\dagger} \# \# \# \#$ represents four hexadecimal digits that specify the load device address as entered by the LOAD NORMAL command. |  |  |  |  |

Figure 14. Bootstrap Loader

Execution of the bootstrap program causes the following actions:

1. The first record on the selected peripheral is read into memrory locations $\mathrm{X}^{\prime} 2 \mathrm{~A}^{\prime}$ through $\mathrm{X}^{\prime} 3 \mathrm{~F}^{\prime}$ (the previous contents of general register 0 are destroyed as a result of executing the bootstrap program in locations $X^{\prime} 26^{\prime}$ through $X^{\prime} 29$ ').
2. After the record has been read, the next instruction is taken from location $X^{\prime} 2 A^{\prime}$ (provided that no error condition has been detected by the device or the (IOP).
3. When the instruction in location $X^{\prime} 2 A^{\prime}$ is executed, the unit device and device controller selected for the load operation can accept a new SIO instruction.
4. Further I/O operations from the load unit may be accomplished by coding subsequent I/O instructions to indirectly address location $X^{\prime} 25$ '.

Following the successful completion of the load sequence, the computer system usually continues execution of the loaded program and begins issuing messages to the operator via the I/O system to the System Control Console.

## $\mathbf{Z}^{\text {CRSY }}$ R RESET SYSTEM

The RESET SYSTEM command performs the combined functions of the RESET BASIC PROCESSOR and RESET I/OSYSTEM commands, as well as the function described below:

1. The system control processor bus interface is initialized.
2. The processor memory bus and processor bus interfaces are initialized.
3. The system memory units are initialized. This process does not alter any memory locations.
4. All interrupt levels are reset to the Disarmed and Disabled state.
5. The system ALARM indicator is cleared.

This command is accepted only when the system is in the IDLE state.
$Z^{\mathrm{C}}$ RBP $\quad$ RESET BASIC PROCESSOR
The RESET BASIC PROCESSOR command initializes the basic processor by performing the following:

1. All bits in the Program Status Words, except the instruction address, are reset.
2. The program counter of the $B P$ (register Q5) is set to a value of $X^{\prime} 26^{\prime}$.
3. The $\bar{B} \bar{P}$ remains in the IDLE state until allowed to begin execution at location $X^{\prime} 26$ '.

This command is accepted only when the system is in the IDLE state.

Since all memory requests are inhibited during a reset, the RESET BASIC PROCESSOR command disrupts any simultoneous memory request from the standard I/O system.

## $Z^{\text {CRIO }}$ RESET I/O SYSTEM

When accepted, the RESET I/O SYSTEM command initializes the IOPs and device controllers of the standard I/O system. All peripheral devices under control of the system are reset to the "ready" condition and all status, interrupt, and control indicators in the $1 / O$ system are reset. This command is accepted only when the system is in the IDLE state. The RESET I/O SYSTEM command does not affect the External Direct Input/Output (DIO), the BP, or other non-input/output system elements.

## ZCHLT SYSTEM HALT

When the HALT command is entered, the BP ceases to execute instructions and is forced into the IDLE state; the RUN indicator on the System Control Panel is extinguished
and the IDLE indicator is illuminated. In the IDLE state the load commands, the reset commands, and the RUN command are enabled. The I/O system may continue to perform I/O operations initiated prior to the $Z^{\text {C }}$ HLT command, even though the BP is halted. Note that the processor HALT status is not set by the ZCHLT command, but is caused by internal processor conditions (see "Processor-Control Word").

## $Z^{\text {CRUN }}$ SYSTEM RUN

The RUN command is accepted only if the BP is in the IDLE state. When the FUN command is accepted, the BP is allowed to execute its instruction stream. On the SCP, the IDLE indicator is extinguished and the RUN indicator is illuminated, subject to the processor control word and system status.

When not in the IDLE state, the system does not accept any of the load and reset control commands. Attempting to enter any load and reset control command while the system is in the RUN mode results in an error message being displayed on the control console (see Table F- ).

## DIAGNOSTIC CONTROL COMMANDS

Diagnostic control commands facilitate isolating software and hardware problems by providing single-instruction execution, as well as permitting read/write access to many processor internal control registers and system memory locations. To perform diagnostic commands, BP instruction execution must be interrupted and the ECS control mode altered. This is accomplished by the ENTER P-MODE command (a "CONTROL-P" character generated by depressing CONTROL and P keys simultaneously). Once in P -Mode the system is forced into the IDLE state and the BP stores and fetches data or executes single instructions only upon request from the operator through the SCC.

Note: Within this text the control-P character is represented by the following symbol, PC .

The diagnostic control ( P -Mode) command format differs from the basic command format. Hexadecimal digits are immediately echoed and stored to be used as data or address depending on the following command. The system truncates the data stream to eight hexadecimal digits and assumes leading zeros if less than eight characters are entered. All non-hexadecimal characters, except basic ( $Z^{C}$ ) format commands, are treated as P -Mode commands. If the sharacter is not in the allowed command set; it is echoed followed by a question mark " $N$ ?" and no action results. Valid commands are echoed; the requested operation is then performed and a P-Mode data display of the form "P:DDDDDDDD@ AAAAAAAA" is generated on the next line of SCC printout. The "P" represents the processor address (normally 0); the "D" field (eight hexadecimal digits)
represents the data in the location specified in the " $A$ " field (eight hexadecimal digits). The first hexadecimal digit of the $A$ field is $X^{\prime} 0^{\prime}$ for memory addresses and $X^{\prime} 8^{\prime}$ for internal register addresses. All valid commands, except EXIT P-MODE, produce a display in this format.

The allowed diagnostic command set is listed in Table 22. An example of the resulting printout is shown in the section entitled "Operating Procedures and Information".

## pc ENTER P-MODE

The ENTER P-MODE control command is generated by depressing the CONTROL and $P$ keys, simultaneously ( $\mathrm{P}^{\mathrm{C}}$ ). The system is forced into the IDLE state and the processor will execute diagnostic control commands entered from the System Control Console. The ECS remains in the P-Mode until an EXIT P-MODE command (described below) is entered or the $Z^{c}$ format commands SYSTEM RUN or LOAD NORMAL are entered. Successful entry into the P-Mode is indicated by a P-Mode display on the SCC.

## (P-Mode)

## SELECT INTERNAL REGISTER ADDRESSING

## (P-Mode) <br> / SELECT MEMORY ADDRESSING

These commands specify the storage element whose contents are to be displayed and operated upon with subsequent commands. The "/" character following a hexadecimal data stream specifies a memory address; the "." character specifies an internal processor control register address. All address calculations and memory accesses are subject to the write lock keys, address mode, and mapping bits in the program status words.

## (P-Mode) <br> $+\quad$ ADD TO SELECTED LOCATION

The "+" character, following a hexadecimal data stream, causes the value of the data to be added to the contents of the selected storage element.
(P-Mode)

- SUBTRACT FROM SELECTED LOCATION

The "-" character, following a hexadecimal data stream, causes the value of the data to be subtracted from the contents of the selected storage element.

## (P-Mode) <br> M STORE IN SELECTED LOCATION

The " $M$ " character, following a hexadecimal data stream, causes the data to be stored in the selected storage element.

Table 22. Diagnostic Control (P-Mode) Commands

| Character | Function |
| :---: | :---: |
| $P^{c}$ | ENTER P-MODE. |
| \#\#\#\#...\#\# | Input data or address value (context determined by the succeeding operator. $\# \# \# \# . . . \# \#$ is any hex digit string). |
| - | SELECT INTERNAL REGISTER ADDRESSING. |
| / | SELECT MEMORY ADDRESSING. |
| + | ADD TO SELECTED LOCATION. |
| - | SUBTRACT FROM SELECTED LOCATION. |
| M | STORE IN SELECTED LOCATION. |
| L | SHIFT LEFT AND DISPLAY. |
| R | SHIFT RIGHT AND DISPLAY. |
| I | INCREMENT REFERENCED ADDRESS AND DISPLAY. |
| RUBOUT | DISPLAY ADDRESSED LOCATION. |
| S | INSTRUCTIOṄ SINGLE STEP. |
| G | SPECIAL INSTRUCTION SINGLE STEP. |
| X | EXIT P-MODE. |

## ( $\overline{\mathrm{P}}$-Mode) <br> L SHIFT LEFT AND DISPLAY

This command causes an image of the contents of the presently selected memory location or $Q$ register to be shifted one bit position to the left and then displayed. A zero is entered into the least significant bit of the location for each $L$ command.

Actual contents of the memory or Q-register location referenced by the shift instruction are not altered.

## (P-Mode) <br> R SHIFT RIGHT AND DISPLAY

This command causes an image of the contents of the presently selected memory location or $Q$ register to be shifted one bit position to the right and then displayed. A zero is entered into the most significant bit of the memory location or $Q$ register for each $R$ command executed.

Actual contents of the memory or $Q$ register location referenced by the shift instruction are not altered.

## (P-Mode) <br> I INCREMENT REFERENCED ADDRESS AND DISPLAY

This command increments by +1 the address of the currently selected memory location or $Q$ register (as specified by a
previously executed SELECT MEMORY ADDRESSING or SELECT INTERNAL REGISTER ADDRESSING control command). The new address and contents are displayed on the next line.
(P-Mode)
RUB OUT
DISPLAY ADDRESSED LOCATION
This command displays the contents of the currently addressed memory location or $Q$ register (as specified by a previously executed SELECT MEMORY ADDRESSING or SELECT INTERNAL REGISTER ADDRESSING control command).

## (P-Mode) <br> s INSTRUCTION SINGLE STEP

This command causes the BP to execute a single instruction as pointed to by the current contents of the program counter. Execution is precisely the same as if the system were running continuously. Upon completion, the BP returns to the IDLE state. If a trap occurs while the instruction is being executed, the instruction in the trap location is executed before the BP returns to the IDLE state. The resultant display shows the next instruction to be executed.

Condition codes resulting from the instruction execution are displayed as the second hexadecimal digit of the address field.

G SPECIAL INSTRUCTION SINGLE STEP
This command permits the contents of register Q5 to be interpreted as the current instruction, and execution by the BP proceeds as described for the INSTRUCTION SINGLE STEP command. The program counter is incremented by +1 . This command thus allows any single instruction (contained in register Q5) to be executed in lieu of the instruction pointed to by the program counter without otherwise disturbing conditions within the system. The resultant display shows the next instruction to be executed.

Condition codes resulting from the instruction execution are displayed as the second hexadecimal digit of the address field.

## (P-Mode)

## $X$ EXIT P-MODE

The EXIT P-MODE command terminates the P-Mode within the ECS. The BP resumes execution of instructions. If no SYSTEM RUN or LOAD NORMAL commands were in effect before entering the P -Mode, the system remains in the IDLE state.

## MAINTENANCE CONTROL COMMANDS

Maintenance control commands facilitate isolation and analysis of system hardware malfunctions. The commands are accepted only if the SCC FUNCTIONS switch is in the ENABLE position. In addition, most critical maintenance controls can be activated only if the MAINT MODE switch on the SCP is in the ON position.

The primary features of the maintenance control commands are the provision of system clock control and single clock stätus displays. Stưưs is abtained fromi read-oñly registers located in central system elements. These Single Clock Status Registers (SCSR) monitor the state of internal hardware signals. Each SCSR display is printed on the next line of SCC printout in the format "CE:DDDDDDDD CC". The "CE" field contains two hexadecimal digits that represent a cluster and an element address, respectively. The 8-digit D field displays the contents of the register, and the 2-digit "CC" field is a modulo 256 clock step counter. This information is valid only when the system clock is stopped.

The following maintenance control commands are included as standard features of this computer system:

$$
\begin{array}{lll}
\frac{\text { Input }}{} & \frac{\text { Display }}{} & \begin{array}{l}
\text { Name of Command } \\
Z^{c} M M O
\end{array} \\
(M M O) & \text { CLEAR MM FEATURES } \\
Z^{c} M M I^{\dagger} & (M M I) & \begin{array}{l}
\text { SET/CLEAR REPEAT CLOCK- } \\
\text { ING MODE }
\end{array}
\end{array}
$$



This command sets the computer system to the "Single Clock Mode" by simultaneously stopping all central system clocks, except those required by the External Control Subsystem and the I/O system. When the system is in the Single Clock Mode all control commands may be entered and executed. Operations performed in the Single Clock Mode may differ from those performed when the clock is running

[^14]at its normal rate (e.g., fixed duration control sequences may not take effect and diagnostic control commands which operate upon BP 's registers or memory locations require a large number of clock steps to complete the operation). The RESET SYSTEM, RESET I/O, and RESET BASIC PROCESSOR commands are effective in Single Clock Mode. When the Single Clock Mode is set, the contents of the currently selected Single Clock Status Register are displayed (see SELECT/DISPLAY SINGLE CLOCK STATUS REGISTER, $Z^{\text {c }} \mathrm{E}^{\# \#}$ command).

If the computer system is currently in the Single Clock Mode, $\mathrm{Z}^{\mathrm{c}} \mathrm{CLK}$ command resets the two-digit clock step counter to $\mathrm{X}^{\prime} 00^{\prime}$.

The Single Clock Mode may be reset by either a CLEAR SINGLE CLOCK MODE, $Z^{\circ}$ KIL, command or a SUPER RESET, $Z^{\mathrm{C}}$ MM4, command.

Note: Entering a SET SINGLE CLOCK MODE command when the basic processor is performing normal data processing operations may have an adverse effect upon I/O operations. To prevent inadvertent entry into Single Clock Mode, the Z ${ }^{\mathrm{C}}$ CLK command is not accepted unless the MAINT MODE switch is in the ON position. Attempting to enter a $\mathrm{Z}^{\mathrm{c}} \mathrm{CLK}$ command when the MAINT MODE switch is in the OFF position results in an error message (*EVENT A2*) being displayed and no further action.

## § SINGLE-CLOCK STEP

When ine sysiem is in the Sirgle Clock invode, a sirgle space character (depicted as $\phi$ within this text), without a control-Z, is interpreted as a SINGLE-CLOCK STEP command. For each space character received from the control console, the current command or instruction is partially executed (one clock's worth of execution for each space character).

The contents of the currently selected Single Clock Status Register are displayed and the clock step counter is incremented by +1 for each SINGLE-CLOCK STEP.

## $\mathbf{z}^{\text {© }}$ ©\# $\quad$ MULTIPLE-CLOCK STEP

When the system is in the Single Clock Mode, the MULTIPLECLOCK STEP command causes the current instruction or command to be executed for 1 to 256 clock steps (as specified by the two hexadecimal digits "\#\#" in this command). The $\mathrm{Z}^{\mathrm{c}} 00$ command causes 256 clocks to be issued. The contents of the currently selected Single Clock Status Register are displayed. The clock step counter is incremented by the number of clock steps specified by this command.

The MULTIPLE-CLOCK STEP command allows precise stepping to a specific point in a micro-program sequence involving a large number of clock steps.

## Z®\#\# SELECT/DISPLAY SINGLE CLOCK STATUS REGISTER

This command causes the requested SCSR to be displayed. The "\#\#" portion of this command (two hexadecimal digits) is stored within the ECS and used as a reference address in any command which displays the contents of the currently selected Single Clock Status Register. The first hexadecimal digit is the cluster address and the second digit is the element address.

In addition to being modified by subsequent $Z^{C} E^{\# \#}$ commands, the cluster and element addresses may also be changed by the LOAD NORMAL command and the SET CLUSTER DISPLAY MODE conmand. The LOAD NORMAL command sets the address to $X^{\prime} 00^{\prime}$ and the SET CLUSTER DISPLAY MODE command causes the element address to be set to a zero following each cluster scan.

## ZCKIL CLEAR SINGLE CLOCK MODE

When this command is entered, the system clocks are restarted immediately. The $Z^{\mathrm{C}}$ KIL command may be issued at any time. If the system is not in the Single Clock Mode, the $\mathrm{Z}^{\mathrm{C}}$ KIL command is ignored.

## Z9MMO CLEAR MM FEATURES

Upon completion of maintenance operations, the CLEAR
 mand, described below) may be used to restore the system to a standard configuration status. The CLEAR MM FEATURES command does the following:

1. Restores the system clock to its normal frequency.
2. Clears the "Repeat Clocking Mode" (see $Z^{c}$ MMI command).
3. Clears the "Cluster Display Mode" (see $Z^{\mathrm{C}}$ MM2 command).
4. Clears the "P-Mode Repeat Mode" (see $Z^{C} M M 3$ command).
5. Clears the "Micro-diagnostic Repeat Mode" (see $Z^{\mathrm{c}} M M 5$ command).
6. Clears the "Override Interleave Mode" (see $Z^{c}$ MM9 command).
7. Clears the "Display Inhibit Mode" (see $Z^{c} M M A$ command).

Note that the CLEAR MM FEATURES command does not generate any resets ( $Z^{\mathrm{C}}$ RIO, $Z^{\mathrm{c}}$ RSY, or $Z^{\mathrm{C}}$ RBP), does not clear P-Mode, nor does it clear Single Clock Mode (see $Z^{c} C L K$ and $Z^{c}$ KIL commands).

## Z9MM1

This command may be used either to SET REPEAT CLOCKING MODE or to CLEAR REPEAT CLOCKING MODE. When the Repeat Clocking Mode is set, system clocks are repeatedly issued to the system.

If the Display Inhibit Mode, as described below, is also set, the clock rate during Repeat Clocking Mode is approximately 1600 Hertz. If the Display Inhibit Mode is not set (cleared), the clock rate is determined by the communications frequency of the System Control Console.

The amount of information displayed when the Repeat Clocking Mode is set is also dependent upon the Cluster Display Mode. If the Cluster Display Mode (see $Z^{\mathrm{C}}$ MM2 command) is not set, the contents of the selected SingleClock Status Register is displayed after each clock.

If the Cluster Display Mode is set, the contents of all 16 SCSRs within a selected cluster are displayed after each clock.

The above display routine is interrupted during a $Z^{C}$ format command. This mode is cleared by a CLEAR REPEAT CLOCK MODE, $Z^{\mathrm{c}}$ MMI, a CLEAR MM FEATURES, $Z^{\mathrm{c}} M M 0$, or a SUPER RESET, $Z^{C} M M 4$, command.

## Z9MM2 SET/CLEAR CLUSTER DISPLAY MODE

This command may be used either to SET CLUSTER DISPLAY MODE or to CLEAR CLUSTER DISPLAY MODE. When the Cluster Display Mode is set, any console operation which causes the display of a Single-Clock Status Register (e.g., $Z^{\mathrm{C}} \mathrm{CLK}, Z^{\mathrm{C}} M M 1, Z^{C} E^{\# \#}, Z^{\mathrm{C}} \mathrm{C}^{\# \#}, Z^{\mathrm{C}} \mathrm{KIL}$, or " 6 " during Single Clock Mode) will cause the contents of all SCSRs in the selected cluster to be displayed in succession.

If the Cluster Display Mode is set, it may be reset by a CLEAR CLUSTER DISPLAY MODE, $Z^{c} M M 2$, a CLEAR MM FEATURES, ZCAANO, or a SUPER RESET, $Z^{C}$ MAANA, command.

## Z9Mm3 SET/CLEAR P-MODE REPEAT MODE

This command may be used either to SET P-MODE REPEAT MODE or to CLEAR P-MODE REPEAT MODE.

When the P-Mode Repeat Mode is set, any P-Mode function character (see "Diagnostic Control Commands") entered from the control console is automatically repeated following each line of display. The repetition of P -Mode functions is haited by entering any character while reperition is active. Repetition is automatically resumed when another function is entered.

The P-Mode Repeat Mode may be reset by a CLEAR P-MODE REPEAT MODE, $Z^{c} M M 3$, a CLEAR MM FEATURES, $Z^{c}$ MMO, or a SUPER RESET, $Z^{C} M M 4$, command.

The P -Mode repeat feature is particularly useful for scanning through sequential memory locations or $Q$ registers (using the INCREMENT REFERENCED ADDRESS AND DISPLAY command or INSTRUCTION SINGLE STEP command described under "Diagnostic Control Commands").

## ZGMM4 SUPER RESET

The primary application of the SUPER RESET command is to restore the system to a predetermined condition during and following maintenance activities. The SUPER RESET command is accepted and executed only if the MAINT MODE switch on the SCP is in the ON position. Entering a SUPER RESET command when the system is not in the maintenance mode results in an error message without affecting the system.

If a SUPER RESET command is accepted, all reset signals (System, I/O, and BP) are issued. In addition, the ECS is reset and initialized, and the basic processor executes an initializing routine which clears the contents of the $Q$ scratchpad prior to executing a normal reset.

After a SUPER RESET command is executed, the system remains in the IDLE state, and the ECS is automatically placed in P-Mode.

## Z9MM5 SET MICRO-DIAGNOSTIC LOOP MODE

This command allows maintenance personnel to repetitively loop the micro-diagnostic test of a single system element. The operator must ensure that the system is in the IDLE state prior to entering this command.

This mode may be cleared by either a SUPER RESET, $Z^{C} M M 4$, or a CLEAR MM FEATURES, $Z^{C} M M 0$, command.

## zGmm INITIATE ELEMENT MICRO-DIAGNOSTIC

This command causes a single element micro-diagnostic test to be initiated for the selected Single Clock Stutuis element, even if the system is in Single Clock Mode. The operator must ensure that the normal preconditions of micro-diagnostic test execution provided in the LOAD NORMAL sequence are met. This may be accomplished by the following command sequence:

CLEAR SINGLE CLOCK MODE (enables clocks for reset)
SYSTEM HALT (system must be in IDLE state)
RESET SYSTEM (test must be preceded by a system reset)
SELECT/Dísplà Síngle clock státús registek SET SINGLE CLOCK MODE

INITIATE ELEMENT MICRO-DIAGNOSTIC SELECT/DISPLAY SINGLE CLOCK STATUS REGISTER<br>SINGLE CLOCK STEP (step-through sequence)

## $Z^{\text {ºmm }} \quad$ SET LOW CLOCK MARGINS

This command causes the system clock frequency to be set to low margin. The CLOCK MARGIN indicator (see System Control Panel) is illuminated. If high and low clock margins are both set, an undefined intermediate frequency results.

The system clock is restored to a normal frequency by either a SUPER RESET, $Z^{C} M M 4$, or a CLEAR MM FEATURES, $Z^{\mathrm{C}}$ MMO, command. The system clock also assumes the normal level following power on.

## $Z^{\text {MM8 }}$ © $\quad$ SET HIGH CLOCK MARGINS

This command causes the system clock frequency to be set to high margin. The CLOCK MARGIN indicator (see System Control Panel) is illuminated. If high and low clock margins are both set, an undefined intermediate frequency results.

The system clock is restored to a normal level by either a CLEAR MM FEATURES, $Z^{c}$ MMO, command or a SUPER RESET, $Z^{C} M M 4$, command. The system clock also assumes the normal level following power on.

## $Z^{\text {C M M }}$ 9 $\quad$ SET MEMORY INTERLEAVE OVERRIDE

This command inhibits interleaving all memory units and is used primarily when running certain memory diagnostic programs. It is allowed only when the system is in the maintenance mode. The change in the manner in which memory is accessed when interleaving is inhibited versus when interleaving is permitted requires that programs be reloaded each time the interleave control is changed. Note that the SET MEMORY INTERLEAVE OVERRIDE command inhibits interleaving all memory units, whereas the INTERLEAVE switches of the Configuration Control Panel (described in Chapter 6) inhibit interleaving on an individual memory unit basis. The INTERLEAVE DISABLE indicator on the SCP is illuminated while INTERLEAVE OVERRIDE is in effect.

The SET MEMORY INTERLEAVE OVERRIDE command remains in effect (interleaving is inhibited) until either a CLEAR MM FEATURES, $Z^{C} M M O$, or a SUPER RESET, $Z^{C} M M 4$, command is executed. Interleaving is automatically enabled following a power on/off cycle.

## $Z^{\text {CMM }}$ MET/CLEAR DISPLAY INHIBIT MODE

This command may be used either to SET DISPLAY INHIBIT MODE or to CLEAR DISPLAY INHIBIT MODE. When the Display Inhibit Mode is set, all data output associated with the System Control Console (SCC) function is inhibited; however, data output generated by the soffware is not affected.

The Display Inhibit Mode is normally set to inhibit printout during execution of SCC functions which do not require a display.

The Display Inhibit Mode may be cleared by a CLEAR DISPLAY INHIBIT MODE, $Z^{c} M M A$, a CLEAR MM FEATURES, $Z^{C} M M O$, or a SUPER RESET, $Z^{C} M M 4$, command. The Display Inhibit Mode is automatically cleared following power on.

## $z^{\text {c }}$ LDS\#\#\#\# LOAD SPECIAL

The LOAD SPECIAL command is accepted only if the system is in the IDLE state. The LOAD SPECIAL command is used in situations where all of the functions performed by the LOAD NORMAL command are not desired (e.g., in loading a postmortem dump sequence). The LOAD SPECIAL command causes only the bootstrap loader program to be written into memory without diagnostics or memory clearing prior to the load. A "load device address", specified by the hexadecimal digits "\#\#\#\#" in the command, is stored in $Q$ register $X^{\prime} 1 E^{\prime}$. When using the LOAD SPECIAL command, the operator must also enter the SYSTEM RESET and SYSTEM RUN commands before loading will commence.

## $Z^{\text {C LDT }} \quad$ MEMORY SET

This command causes all memory to be set to the value contained in the BP internal register Q26 ( $\left.X^{\prime} 1 A^{\prime}\right)$. The command may be entered only when the system is in the IDLE stare.

## $\mathbf{Z}^{\text {T }} \quad$ SET/CLEAR TRANSPARENT TEXT MODE

This command is used either to SET TRANSPARENT TEXT MODE or to CLEAR TRANSPARENT TEXT MODE. When the Transparent Text Mode is set, software-driven I/O from the System Control Console is inhibited, but all SCC FUNCTIONS are processed in the normal manner. This feature permits the operator to make marginal notes on the console printout for logging purposes. If two different control consoles are connected in parallel (i.e., remote device is connected as a System Control Console), the Transparent Text Mode permits messages to be exchanged between the two devices. If the SCC FUNCTIONS switch is in the DISABLE position, input data is passed into the I/O system regardless of the status of the Transparent Text Mode.

The Transparent Text Mode may also be cleared by a SUPER RESET, $Z^{c} M M 4$, command.

## SYSTEM CONTROL PANEL

The System Control Panel contains indicators and controls which are used primarily when maintenance and/or diagnostic activities are performed. The computer operator normally monitors certain indicators (as described below) to ascertain conditions within the computer system (e.g. , status of primary power, status of sense switches, status of BP, and status of ALARM indicators).

The controls and indicators of the System Control Panel (see Figure 15) are functioanlly described below.

## POWER ON

This alternate-action switch/indicator controls the application of power to the system. The indicator is illuminated only when the switch has been depressed and power is being applied to the system.

## PRIMARY POWER

This indicator is illuminated whenever PRIMARY power is applied to the system.

## POWER FAULT

This indicator is illuminated only if an abnormal power system condition exists. Maintenance action is required when the POWER FAULT indicator is lit.

## MAINTENANCE MODE

This indicator is illuminated when the computer system is placed in the maintenance mode as the result of the MAINT MODE switch being in the ON position.

## INTERLEAVE DISABLE

This indicator is illuminated whenever the two-way interleaving feature of the memory system is inhibited: (See SET MEMORY INTERLEAVE OVERRIDE command, under "Maintenance Control Commands".)

CLOCK MARGIN
This indicator is illuminated whenever the system clock frequency is above or below the normal value (usually as a result of maintenance and/or diagnostic activities; see SET LOW CLOCK MARGINS and SET HIGH CLOCK MARGINS commands, under "Maintenance Control Commands").

## POWER MARGIN

This indicator is illuminated whenever any power supply within the computer system has its low margin switch set.

## SENSE SWITCH

These four indicators display the status of the four sense switches. Each indicator is appropriately marked (1, 2, 3,4 ) and is illuminated only when the corresponding sense switch is on.

## ALARM

This indicator is illuminated whenever the system Alarm flip-flog has been set, signifying that a condition has occurred which requires the attention of the operator. This visual alarm may also be augmented with an audio alarm (see ALARM AUDIO, below).

## IDLE

This indicator is illuminated whenever the BP operations have been interrupted by the ECS. When the system is in the IDLE state, the BP will fetch and store data or execute instructions only upon request from the System Control Console. The BP states (RUN, WAIT, or HALT) are only defined when the BP is executing instructions.


Figure 15. System Control Panel

## BP STATUS AND NO.

This group of indicators permits the processor address (usually 0 ) and current internal state (RUN, WAIT, or HALT) of the BP to be displayed. While executing instructions, the BP is normally in the RUN or WAIT state. The HALT state is entered only when an address halt occurs, the processor disable is on (see "Operating Procedures and Information") or an irrecoverable processor fault occurs. When the system is in the IDLE state as a result of power on, a $Z^{\mathrm{C}} \mathrm{HLT}$ command, or a $\mathrm{p}^{\mathrm{C}}$ command, only the processor address is lighted and RUN, WAIT, and HALT indicators are extinguished.

## ALARM AUDIO

This 4-position rotary switch controls the connection and volume of a loudspeaker, and also permits all indicators (except POWER ON and PRIMARY POWER) on the SCP to be tested. When this switch is in the OFF position, the loudspeaker is disconnected. Note that this switch does not inhibit the ALARM indicator. When this switch is in the LOW position, the loudspeaker is connected and the volume is set to a low level. When this switch is in the HIGH position, the loudspeaker is connected and the volume is set to a high level. When this switch is held in the LAMP TEST position, all back-lighted indicators should illuminate, simultaneously. The switch returns to the HIGH position when released.

## SCC FUNCTIONS

This switch controis the functional capabilities of the System Control Console(s). When this switch is in the ENABLE position, the SCC device(s) may perform the various control functions attributed to a System Control Console. Certain control functions require the system to be in the IDLE state while others (as described under "Maintenance Control Commands") require the MAINT MODE switch to be in the ON position.

When the SCC FUNCTIONS switch is in the DISABLE position, the control functions that may be entered from the control console (to interact with operating software) are limited to the following:

1. Operator requested interrupt $\left(Z^{\mathrm{C}} \mathrm{I}\right)$,
2. Read Sense Switches $\left(Z^{C} S S W\right)$,
3. Set Sense Switches $\left(Z^{C} S S^{\#}\right)$.

The operator may lock out potentially disruptive control commands when the operating software is running by setting the SCC FUNCTIONS switch to DISABLE.

## REMOTE CHANNEL

This 3-position rotary switch controls the manner in which the alternate and remote consoles may operate. When this switch is in the SCC position, the alternate and remote
consoles may be connected in parallel with the System Control Console and may perform the same control functions as the local control device. The remote console also requires a manual connection through the RDI data set. Note that any restrictions upon the control functions imposed upon the local control device by the SCC FUNCTIONS switch being in the DISABLE position also apply to both consoles. Either the alternate or remote console is selected for input by the ALTSEL switch on the Configuration Control Panel (see Chapter 6).

When the REMOTE CHANNEL switch is in the OFF position, the remote device is disconnected from the ECS at the data set (if present). The alternate console functions in the $1 / O$ mode.

When this switch is in the I/O position, the alternate and remote consoles operate strictly as I/O devices communicating with the computer system via IOP subchannel address $X^{\prime} O B^{\prime}$. Only one device is selected for input at a time by the ALTSEL switch on the Configuration Control Panel (see Chapter 6).

## MAINT MODE

During normal operations, this switch is placed in the OFF position. During maintenance and/or diagnostic activies, this switch may be placed in the ON position or momentarily held in the RESET position (switch automatically returns to the ON position when released). In addition to causing the MAINTENANCE MODE indicator to become illuminated when piaced in the Üiv position, the switch also enables certain hardware controls and allows their associated control commands to be entered from the operator's control console (see "Maintenance Control Commands"). This interlocking feature prevents inadvertent adverse effects upon the current program.

Caution should be exercised in activating RESET, since this position (equivalent to the SCC SUPER RESET command) causes all components of the system to be reset and initialized.

## SELECT DISPLAY

These nine switches, labeled CCP/SCSR and 0 through 7, are used to specify the binary address of any one of up to 256 Single Clock Status Registers and up to 32 Configuration Status Registers or Read Direct Mode 9 Status Registers whose content is to be displayed by the 32 binary indicators, labeled 0 through 31.

When the CCP/SCSR switch is in the SCSR position, switches 0 through 3 specify the cluster address and switches 4 through 7 specify the element address of the Single Clock Status Register whose content is to be displayed.

When the CCP/SCSR switch is in the CCP position and switch 0 is in the " 0 " position, switches 3 through 7 specify the binary address of the cabinet whose Read Direct Mode 9 Status Register is to be displayed by the 32 panel indicators.

When the CCP/SCSR switch is in the CCP position and switch 0 is in the " 1 " position, switches 3 through 7 specify the binary address of the cabinet whose 16-bit Configuration Status Register is to be displayed by the 16 lower-order indicators.

## SINGLE CLOCK ENABLE

This switch stops all central system clocks in the same manner as the $Z^{\mathrm{C}} \mathrm{CLK}$ command. Activating this switch when the basic processor is performing normal data processing may have an adverse effect on any active I/O operations. To prevent inadvertent activation of this control, it is disabled unless the MAINT MODE switch is in the ON position.

## SINGLE CLOCK STEP

This switch is active only when in Single Clock Mode or when the Single Clock Enable switch is active. When active, this switch causes one system clock to be issued each time it is placed in the STEP position. The new single clock status, as selected by the MODE and SELECT switches, may be monitored via the 32 binary indicators on the System Control Panel; no display is generated on the System Control Console by activation of the SCP Single Clock Step switch.

## OPERATING PROCEDURES AND INFORMATION

This section contains reference information which may be required by either the operator or maintenance/diagnostic personnel.

## LOAD OPERATION DETAILS

The first executed instruction of the bootstrap program (in location $X^{\prime} 26^{\prime}$ ) loads general register 0 with the address of the first I/O command doubleword (IOCD). The I/O address for the SIO instruction in location $X^{\prime} 27^{\prime}$ is the 13 low-order bits of location X'25' (which have been set equal to the load unit address asaresult of the NORMAL LOAD, $Z^{C}$ LDN $\# \# \# \#$, command). During execution of the SIO instruction, general register 0 points to locations $X^{\prime} 20^{\prime}$ and $X^{\prime} 21^{\prime}$ as the first IOCD for the selected device. This IOCD contains an order to the selected peripheral device to read 88 ( $X^{\prime} 58^{\prime}$ ) bytes of data into consecutive memory locations beginning at word location $X^{\prime} 2 A^{\prime}$ (byte location $X^{\prime} A 88^{\prime}$ ). At the end
of the Read operation, neither data chaining nor command chaining is called for in the IOCD. The Suppress Incorrect Length (SIL) flag is set to 1 so that an incorrect length indication will not cause a Transmission Error Halt. After the SIO instruction has been executed, the basic processor executes a TIO instruction with the same effective address as the SIO instruction. The TIO instruction is coded to accept only condition code data from the IOP. The BCS instruction (in location $X^{\prime} 29^{\prime}$ ) will cause a branch to $X^{\prime} 22^{\prime}$ (a LOAD IMMEDIATE instruction), if either $\mathrm{CC1}$ or CC 2 is set to 1 . Execution of the LOAD IMMEDIATE instruction at $\mathrm{X}^{\prime} 22^{\prime}$ loads a count of X' 10029 into general register 1. The following BDR instruction at location $X^{\prime} 23^{\prime}$ uses this as a "delay" count before executing the BCR instruction in location $X^{\prime} 24$ ', which unconditionally branches to the TIO instruction in location $X^{\prime} \mathbf{2 8}^{\prime}$. In normal operations, $C C 1$ is reset to 0 and $C C 2$ remains set to 1 until the device can accept another SIO instruction. At that time, the next instruction is taken from location $X^{\prime} 2 A^{\prime}$.

If a Transmission Error or equipment malfunction is detected by either the device or the IOP, the IOP instructs the device to halt and to initiate an "unusual end" interrupt signal (as specified by appropriate flags in the IOCD, described in Chapter 4). The "unusual end" interrupt will be ignored since all interrupt levels have been Disarmed and Disabled by the system reset during the load sequence. The device will not accept another SIO while the interrupt is pending and the BCS instruction in location X'29' will continue to branch to location X'22'. The correct operator action at this point is to repeat the NORMAL LOAD, $Z^{C} L^{\prime} N^{\# \# \# \#}$, command. If there is no I/O address recognition of the load unit, the SIO instruction will not cause any $\mathrm{I} / \mathrm{O}$ action and CCl will continue to be set to 1 by the SIO and TIO instructions causing the BCS instruction to branch.

## FETCHING and STORING DATA

The following examples illustrate how diagnostic control ( P -Mode) commands may be used to display and alter the contents of specified memory locations and control registers within the system. Control commands, as entered from a keyboard device functioning as the System Control Console, are shown in the first column. The resulting printouts are shown in the second column. The third column of information is an explanation of the functions performed by the different control commands.

| Input | Printout | Function <br> $P^{c}$ <br> 0:DDDDDDDD @ 80000000 |
| :--- | :--- | :--- |
| Enter $P$-Mode of <br> operations; contents <br> of $Q$ register 0 is <br> normally displayed. |  |  |
| $100 / 100 /$ | Select and display <br> contents of memory <br> location X' 100 |  |


| Input | Printout | Function |
| :--- | :--- | :--- |
| $5 M$ | 5 M | Store X'5' into the <br> currently selected <br> memory location. |
| I 0:00000005@00000100 | I | Increment address <br> of currently selected <br> memory location and <br> display. |

Note that all P-Mode accesses are qualified by address mapping bits and Write Lock keys in the Program Status Words.

## PROCESSOR CONTROL WORD

The Processor Control Word resides in the processor internal addressable register, Q30. This register may be loaded with
appropriate control information to perform maintenance or diagnostic functions, such as halting and resetting the basic processor, setting address hold, and activating various fault detection controls. During normal operations it should not be necessary to access this word. The contents of the Processor Control Word are not affected by either processor or system reset, but are automatically set to zero (default condition) during power-on sequencing and by the SUPER RESET command. The bit assignments of the Processor Control Word (register Q30) are listed and described in Table 23.

## ADDRESS COMPARE WORD

The Address Compare Word is located in register Q31 and contains parameters defining the type of comparison and the desired action (alarm, halt, or none) on detecting an address compare. (See Table 24.)

Table 23. Bit Assignments and Description, Processor Control Word, Register Q30 (X'IE')

| Bit <br> Position | Description |
| :---: | :---: |
| 0 | Retry Inhibit: <br> If this bit is a 0 , the basic processor will automatically retry the instruction which caused the trap to location $X^{\prime} 4 C^{\prime}$; if this bit is a 1 , the basic processor is inhibited from retrying the instruction which caused the trap to location $X^{\prime} 4 C^{\prime}$. |
| 1 | Parity Check Inhibit: <br>  of $R$ register transactions is inhibited. |
| 2 | Watchdog Timer Override: <br> If this bit is a 0 , the watchdog timer is allowed to count; if this bit is a 1 , the watchdog timer is inhibited from counting and the machine will not execute the Watchdog Timer Trap. |
| 3 | Watchdog Timer Alarm: <br> If this bit is a 0 , the Watchdog Timer Trap is enabled; if this bit is a 1 , the Watchdog Timer Trap is inhibited. When a timeout occurs, a system reset is generated and the system will run to timeout again. This provides a dynamic loop for isolating the cause of the timeout. |
| 4-5 | Reserved (must be coded as zeros). |
| 6 | Address Hold: <br> If this bit is a 0 , the address hold is disabled; if this bit is a 1 , the program counter is inhibited from counting (incrementing) causing the machine to loop on the selected instruction (i.e., when the machine is returned to RUN mode, the instruction pointed to by the program counter is executed continuously). |
| 7 | Processor Halt: <br> If this bit is a 0 , the processor is allowed to run under the control of system and P -Mode controls; If this bit is a 1 , the processor is forced into the HALT condition. |
| 8-15 | Reserved. |
| 16-31 | Load device address. |

Table 24. Bit Assignments, Address Compare Register Q31 (X'IF')

| Bit Position | Status | Significance |
| :---: | :---: | :---: |
| 0 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Selects mapped address comparison. <br> Selects unmapped address comparison. |
| 1 | 1 <br> 0 | Selects address comparison during instruction access only. <br> Selects address comparison for all memory cycles. |
| 2 | 1 <br> 0 | Selects comparisons only during memory write cycle. <br> Selects all memory cycle comparisons. |
| 3 | $1$ <br> 0 | Selects page comparisons. <br> Selects word comparisons. |
| 4 | 1 <br> 0 | System turns on audible alarm for 220 microseconds each time an Address Compare occurs (maximum frequency 1 KHz ). <br> Address match alarm is disabled. |
| 5 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | The processor is forced into the HALT state when an Address Compare occurs. Address Halt disabled. |
| 6-7 | - | Reserved. |
| 8-31 | - | Comparison address field. |

## 6. SYSTEM CONFIGURATION CONTROL

Pooled resources along with flexible configuration control provide a high degree of continuous availability. If a problem occurs in an individual unit of a resource pool, the system may allow that unit to be isolated with a loss only in capacity but no loss of functional capability, assuming there is an additional unit of that type in the system that can absorb the added load. Specialized units can be duplicated (with all units being normally used, where possible) and configuration controls used to divert the input from one to the other in the event of a failure.

Chapter 2 describes the system organization and Chapter 5 discusses system operational control. This chapter describes the Configuration Control Panel (CCP), which serves as the principal element for controlling and modifying the configuration of the system.

## CONFIGURATION CONTROL PANEL (CCP)

The CCP provides the capability for enabling and disabling units in the system. It accomplishes this with centrally located manual selection switches used for the following functions:

1. Establish starting addresses for all memory units in the system.
2. Enable or disable memory ports.
3. Enable or disable individual units and clusters.
4. Control the power throughout the system.

The Configuration Control Panel is mounted within the endbell assembly at the end of the row of cabinets containing the chassis assemblies for the MUs, BP, and other system components. On the outer surface of the endbell assembly is the System Control Panel (described and illustrated in Chapter 5). Access is gained to the CCP by opening the hinged endbell assembly (see Figure 16).

A CCP has six rows of 22 toggle switches and two lamp indicators each. A row may control a memory unit, processor cluster, or system control processor. (See Figure 17, and Tables 25 and 26.) The active logic associated with each row of switches and indicators is located within each processor cluster or memory unit itself. Above each row is a marker strip that identifies the function of each switch. The
configuration control is designed in a modular manner. As the system grows, previously unused rows on the panel can be used (up to the panel's maximum of six), and an additional panel may be added. Two panels represent the maximum configuration for one endbell assembly.

Note: The Configuration Control Panel does not contain operational controls as the System Control Panel does. The CCP switches are initially positioned during system configuration and are not normally repositioned during system operation.

## CONFIGURATION CONTROL STATUS WORD

A program may read settings of the panel switches, type of unit, and options installed. A READ DIRECT (RD) instruction using the chassis address of the cluster or unit as an address allows the program to determine the configuration status of a particular processor cluster or memory unit, for example. (The chassis address assignment represents the chassis' physical location relative to the endbell assembly.) (See Figure 16.)

The configuration control status of a panel read by the RD instruction is a 32 -bit status word consisting of panel switch settings and type information. (The RD instruction is described in Chapter 3, "Control Instructions".) The logic for these program provisions resides in each unit.

In addition to reading configuration status information via a READ DIRECT (RD) instruction in a program, the status information may also be obtained by manual switch selection on the System Control Panel; the 32-bit status word is displayed on a bank of lamp indicators. (See Chapter 5 for a discussion of the System Control Panel features. )

## CONFIGURATION BUS

The configuration bus connects to each processor cluster and provides a path for the system control processor to select and read the switch settings on the CCP for the selected unit via an RD instruction.

(Viewed from Module Side)
${ }^{\dagger}$ Starting from the endbell as cabinet number 0 , the most significant four bits designate physical cabinet number. The least significant bit designates the back panel location in the halves of the cabinet.

Figure 16. Chassis Physical Configuration


Figure 17. Sample Rows of CCP Switches

Table 25. Functions of Processor Cluster Configuration Control Panel Row

| Label | Switch/Indicator | Function |
| :---: | :---: | :---: |
| POWER NNORM | 1 indicator | Lighted when unit power is shut down due to abnormal operational condition. |
| POWER ON | 1 switch | When in up or middle position, enables power-on control in the unit power supply. (Middle position inhibits the unit reset signal.) When in down position, power to unit is off. |
| SYSTEM SEL | 1 switch | Selects the processor bus to which the processor cluster is to be connected (up is processor bus $A$, down is $B$ ). |
| $\begin{aligned} & \text { CLOCK } \\ & \text { SEL } \end{aligned}$ | 1 switch | Selects the clock source (up, A or down, B) for the unit clock subsystem. |
| PROCESSOR ADDRESS | 3 switches | Establishes the logical address of the cluster within a group of processor clusters. <br> Note: The 5-bit chassis location number and not the processor address is used in addressing the configuration switches for a given unit by the RD instruction directed to the Configuration Control Panel. |
| BP ENABLE | 1 switch | When in down position, inhibits the BP from operating on the internal bus. |
| MIOP ENABLE | 1 switch | When in down position, inhibits the MIOP from operating on the internal bus. |
| DIO <br> ENABLE | 1 switch | When in down position, inhibits external DIO interface. |
| ALTSEL | 1 switch | Selects either the remote console (down position) or alternate operator's console (up position) to enter data on the Remote Channel Interface. |
| FSELA | 1 switch | Selects communications frequency for the primary operator's console as follows: <br> up = same frequency as remote channel <br> down $=1200$ baud <br> Note: The 1200 baud selection is effective only if the REMOTE CHANNEL switch on the System Control Panel is not in the SCC position. |
| FSELBO/FSELB1 | 2 switches | Selects communications frequency for the alternate operator's console and the Remote Diagnostic Interface (Remote Channel) as follows: |

Table 25. Functions of Processor Cluster Configuration Control Panel Row (cont.)

| Label | Switch/Indicator | Function |
| :---: | :---: | :---: |
| REAL-TIME CLOCK SEL | 8 switches | Four groups (labeled RTC1, RTC2, RTC3, and STC) of 2 switches each (labeled S0 and S1), used for selecting the real-time clock frequencies; each of the three real-time clock counters and the one subjective clock counter may have their frequencies selected by the proper combination of the two switches associated with each counter: |

Table 26. Functions of Memory Unit Configuration Control Panel Row

| Label | Switch/Indicator | Function |
| :---: | :---: | :---: |
| POWER NNORM | 1 indicator | Lighted when unit power is shut down due to abnormal operational condition. |
| POWER ON | 1 switch | When in up or middle position, enables power-on control in the unit power supply. (Middle position inhibits the unit reset signal.) When in down position, power to unit is off. |
| $\begin{aligned} & \text { SYSTEM } \\ & \text { SEL } \end{aligned}$ | 1 switch | Determines to which central shared resources the reset signal is connected. |
| $\begin{aligned} & \text { CLOCK } \\ & \text { SEL } \end{aligned}$ | 1 switch | Selects which clock the memory shall use; up position selects system clock $A$, down position selects system clock $B$. |
| UNIT ADDRESS | 3 switches | Establishes the logical address of the unit within a group of memory units. |
| PORT ENABLE | 6 switches | Down position disables, up enables, corresponding port when setting up different configuration in the system. Switch 1 (leftmost) corresponds to port 1, etc., and switch 6 corresponds to port 6. |
| INTLV | 1 switch | Up position selects interleave addressing mode in each memory unit; down position means no interleaving in any memory unit. Only two-way interleaving is allowed. The unit interleaved with this memory unit must have its interleave switch on and be in the appropriate addressing range. The interleave logic operates only for memory units with a number corresponding to a power of 2: i.e., $16 \mathrm{~K}, 32 \mathrm{~K}$ words; if other than a power of 2 , the interleave signal it receives is ignored. Interleaving is permissible only: <br> 1. Between two memory units of the same size. <br> 2. Provided the two memory units cover an addressing range that is continuous and starts at a multiple of the size of the two memory units taken together. |

Table 26. Functions of Memory Unit Configuration Control Panel Row (cont.)

| Label | Switch/Indicator | Function |
| :---: | :---: | :---: |
| STARTING ADDRESS | 7 switches | Used to set the starting addresses of the memory units. From left to right the switches are labeled $\mathrm{S} 12, \mathrm{~S} 13, \mathrm{~S} 14, \mathrm{~S} 15, \mathrm{~S} 16, \mathrm{~S} 17$, and S 18 . Using the switches as a 7 -position binary field, this allows memory to address up to 1 million words. <br> When the memory system comprises memory units of different sizes, some precautions are necessary to prevent false address recognition as well as to prevent gaps in the memory range. <br> 1. If all memory units have sizes that are powers of two, they can all be different; they must, however, be assigned in order of decreasing size in the address continuum. <br> For instance, three memory units can be used in this manner: <br> 2. If a memory unit has a size that is not a power of two, it must be situated in a memory system that satisfies the following rules: <br> a. All other memory units must have sizes that are a power of two. <br> b. The starting address of the non-power-of-two unit must be a multiple of the next power of two above the size of that unit. <br> c. The memory unit whose size is not a power of two must be at the upper end of the address range. |

## APPENDIX A. REFERENCE TABLES

This appendix contains the following reference material:

Title<br>Standard Symbols and Codes<br>Standard 8-Bit Computer Codes (EBCDIC)<br>Standard 7-Bit Communication Codes (ANSCII)<br>Standard Symbol-Code Correspondences<br>Hexadecimal Arithmetic<br>Addition Table<br>Multiplication Table<br>Table of Powers of Sixteen 10<br>Table of Powers of Ten 16<br>Hexadecimal-Decimal Integer Conversion Table<br>Hexadecimal-Decimal Fraction Conversion Table<br>Table of Powers of Two

Mathematical Constants

## STANDARD SYMBOLS AND CODES

The symbol and code standards described in this publication are applicable to all Xerox computer products, both hardware and software. They may be expanded or altered from time to time to meet changing requirements.

The symbols listed here include two types: graphic symbols and control characters. Graphic symbols are displayable and printable; control characters are not. Hybrids are SP, the symbol for a blank space; and DEL, the delete code, which is not considered a control command.

Three types of code are shown: (1) the 8-bit Xerox Standard Computer Code, i.e., the Extended Binary-Coded-Decimal Interchange Code (EBCDIC); (2) the 7-bit American National Standard Code for Information Interchange (ANSCII); and (3) the Xerox standard card code.

STANDARD CHARACTER SETS

1. EBCDIC

63-character set: same as above plus $\not \subset!\quad$ ? " 7

89-character set: same as 63-character set plus lowercase letters
2. ANSCII

64-character set: uppercase letters, numerals, space,


95-character set: same as above plus lowercase letters and $\}$ :

## CONTROL CODES

In addition to the standard character sets listed above, the symbol repertoire includes 37 control codes and the hybrid code $\bar{U} E L$ ( habrid code $\overline{S F}$ is considered part of ail character sets). These are listed in the table titled Standard Symbol-Code Correspondences.

## SPECIAL CODE PROPERTIES

The following two properties of all standard codes will be retained for future standard code extensions:

1. All control codes, and only the control codes, have their two high-order bits equal to "00". DEL is not considered a control code.
2. No two graphic EBCDIC codes have their seven loworder bits equal.

STANDARD 8-BIT COMPUTER CODES (EBCDIC)


STANDARD 7-BIT COMMUNICATION CODES (ANSCII) ${ }^{1}$

## NOTES:

1 The characters - $\backslash\}$ [] are ANSCII characters that do not appear in any of the EBCDIC-based character sets, though they are shown in the EBCDIC table.

2 The characters $\& \mid \neg$ appear in the 63-and 89-character EBCDIC sets but not in either of the ANSCII-based sets. However, Xerox software translates the characters into ANSCII characters as follows:

| $\frac{\text { EBCDIC }}{x}$ | $=$ |
| :---: | :---: |
| $\frac{\text { ANSCII }}{1(6-0)}$ |  |
| 1 |  |
| $\square$ | $\sim(7-12)$ |
|  |  |

3 The EBCDIC control codes in columns 0 and $I$ and their binary representation are exactly the same as those in the ANSCII table, except for two interchanges: LF/NL with NAK, and HT with ENQ.

4 Characters enclosed in heavy lines are included only in the standard 63-and 89-character EBCDIC sets.

5 These characters are included only in the standard 89-character EBCDIC set.

|  |  |  | Most Significant Digits |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Decimal |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
|  | 1 | Binary 1 | $\times 000$ | $\times 001$ | $\times 010$ | $\times 011$ | $\times 100$ | $\times 101$ | $\times 110$ | $\times 111$ |
|  | 0 | 0000 | NUL | DLE | SP | 0 | @ | P | , | P |
|  | 1 | 0001 | SOH | OCl | $!^{5}$ | 1 | A | Q | a | 9 |
|  | 2 | 0010 | STX | DC2 | " | 2 | B | R | b | 「 |
|  | 3 | 0011 | ETX | DC3 | \# | 3 | C | 5 | c | 5 |
|  | 4 | 0100 | EOT | DC4 | \$ | 4 | D | T | d | $\dagger$ |
|  | 5 | 0101 | ENQ | NAK | \% | 5 | E | U | e | $u$ |
|  | 6 | 0110 | ACK | SYN | 8 | 6 | F | V | f | $\checkmark$ |
|  | 7 | 0111 | BEL | Etb | , | 7 | G | w | 9 | w |
|  | 8 | 1000 | BS | CAN | ( | 8 | H | $x$ | h | $\times$ |
|  | 9 | 1001 | HT | EM | ) | 9 | I | Y | i | $y$ |
|  | 10 | 1010 | $\begin{aligned} & \mathrm{LF} \\ & \mathrm{NL} \end{aligned}$ | SUB | * | : | J | Z | i | $z$ |
|  | 11 | 1011 | VT | ESC | + | ; | K | [ | k | 1 |
|  | 12 | 1100 | FF | FS | ; | $<$ | 1 | $\backslash$ | 1 | 1 |
|  | 13 | 1101 | CR | GS | - | $\doteq$ | M | ] | m | 1 |
|  | 14 | 1110 | SO | RS |  | > | N | $\sim 4$ | $n$ | $\sim^{4}$ |
|  | 15 | 1111 | SI | US | 1 | ? | 0 | -4 | $\bigcirc$ | DEL |

NOTES:

1 Most significant bit, added for 8 -bit format, is either 0 or even parity.
2 Columns 0-1 are control codes.
3 Columns 2-5 correspond to the 64-character ANSCII set. Columns 2-7 correspond to the 95 -character ANSCII set.

4 On many current teletypes, the symbol

$$
\begin{array}{llll}
- & \text { is } & i & (5-i 4) \\
- & \text { is } & - & (5-15) \\
\sim & \text { is } & \text { ESC or ALTMODE control }(7-14)
\end{array}
$$

and none of the symbols appearing in columns 6-7 are provided. Except for the three symbol differences noted above, therefore, such teletypes provide all the characters in the 64 -character ANSCII set. (The Xerox 7015 Remote Keyboard Printer provides the 64 -character ANSCII set also, but prints ${ }^{\wedge}$ as $\wedge$.)

## STANDARD SYMBOL-CODE CORRESPONDENCES

| EBCDIC ${ }^{+}$ |  | Symbol | Card Code | ANSCII ${ }^{\text {t+ }}$ | Meaning | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Hex. | Dec. |  |  |  |  |  |
| 00 | 0 | NUL | 12-0-9-8-1 | 0-0 | null <br> start of header <br> start of text <br> end of text <br> end of transmission <br> horizontal tab <br> acknowledge (positive) <br> bell <br> backspace or end of message <br> enquiry <br> negative acknowledge <br> vertical tab <br> form feed <br> carriage return <br> shift out <br> shift in | 00 through 23 and 2 F are control codes. |
| 01 | 1 | SOH | 12-9-1 | 0-1 |  |  |
| 02 | 2 | STX | 12-9-2 | 0-2 |  |  |
| 03 | 3 | ETX | 12-9-3 | 0-3 |  |  |
| 04 | 4 | EOT | 12-9-4 | 0-4 |  |  |
| 05 | 5 | HT | 12-9-5 | 0-9 |  |  |
| 06 | 6 | ACK | 12-9-6 | 0-6 |  |  |
| 07 | 7 | BEL | 12-9-7 | 0-7 |  |  |
| 08 | 8 | BS or EOM | 12-9-8 | 0-8 |  |  |
| 09 | 9 | ENQ | 12-9-8-1 | 0-5 |  |  |
| 0A | 10 | NAK | 12-9-8-2 | 1-5 |  |  |
| OB | 11 | VT | 12-9-8-3 | 0-11 |  |  |
| ${ }^{O} \mathrm{C}$ | 12 | FF | 12-9-8-4 | 0-12 |  |  |
| OD | 13 | CR | 12-9-8-5 | 0-13 |  |  |
| OE | 14 | SO | 12-9-8-6 | 0-14 |  |  |
| OF | 15 | SI | 12-9-8-7 | 0-15 |  |  |
| 10 | 16 | DLE | 12-11-9-8-1 | 1-0 | data link escape device control 1 device control 2 device control 3 device control 4 line feed or new line sync end of transmission block cancel end of medium substitute escape file separator group separator record separator unit separator | Replaces characters with parity error. |
| 11 | 17 | DC1 | 11-9-1 | 1-1 |  |  |
| 12 | 18 | DC2 | 11-9-2 | 1-2 |  |  |
| 13 | 19 | DC3 | 11-9-3 | 1-3 |  |  |
| 14 | 20 | DC4 | 11-9-4 | 1-4 |  |  |
| 15 | 21 | LF or NL SYN | 11-9-5 | $\begin{aligned} & 0-10 \\ & 1-6 \end{aligned}$ |  |  |
| 16 | 22 |  | $11-9-6$ |  |  |  |
| 17 | 23 | ETB | 11-9-7 | 1-7 |  |  |
| 18 | 24 | CAN | 11-9-8 | 1-8 |  |  |
| 19 | 25 | EM | 11-9-8-1 | 1-9 |  |  |
| IA | 26 | SUB | 11-9-8-2 | 1-10 |  |  |
| 1 B | 27 | ESC | 11-9-8-3 | 1-11 |  |  |
| 1 C | 28 | FS | 11-9-8-4 | 1-12 |  |  |
| 1D | 29 | GS | 11-9-8-5 | 1-13 |  |  |
| IE | 30 | RS | 11-9-8-6 | 1-14 |  |  |
| IF | 31 | US | 11-9-8-7 | 1-15 |  |  |
| 20 | 32 | $\begin{aligned} & \text { ds } \\ & \text { ss } \\ & \text { fs } \\ & \text { si } \end{aligned}$ | $\begin{aligned} & 11-0-9-8-1 \\ & 0-0-1 \end{aligned}$ |  | digit selector <br> significunee sturt <br> field separation immediate significance start | 20 through 23 are used with EDIT PYTE STRINY (EDS) instruction - not input/output control codes. <br> 24 through 2 E are unassigned. |
| 21 | 32 |  |  |  |  |  |
| 22 | 34 |  | 0-9-2 |  |  |  |
| 23 | 35 |  | 0-9-3 |  |  |  |
| 24 | 36 |  | 0-9-4 |  |  |  |
| 25 | 37 |  | 0-9-5 |  |  |  |
| 26 | 38 |  | 0-9-6 |  |  |  |
| 27 | 39 |  | 0-9-7 |  |  |  |
| 28 | 40 |  | 0-9-8 |  |  |  |
| 29 | 41 |  | 0-9-8-1 |  |  |  |
| 2A | 42 |  | 0-9-8-2 |  |  |  |
| 2B | 43 |  | 0-9-8-3 |  |  |  |
| 2 C | 44 |  | 0-9-8-4 |  |  |  |
| 2D | 45 |  | 0-9-8-5 |  |  |  |
| 2 E | 46 47 |  | 0-9-8-6 |  |  |  |
| 2F | 47 |  | 0-9-8-7 |  |  |  |
| 30 | 48 |  | 12-11-0-9-8-1 |  |  | 30 through 3F are unassigned. |
| 31 | 49 |  | 9-1 |  |  |  |
| 32 | 50 |  | 9-2 |  |  |  |
| 33 | 51 |  | 9-3 |  |  |  |
| 34 | 52 |  | 9-4 |  |  |  |
| 35 | 53 |  | 9-5 |  |  |  |
| 36 | 54 |  | 9-6 |  |  |  |
| 37 | 55 |  | 9-7 |  |  |  |
| 38 | 56 |  | 9-8 |  |  |  |
| 39 | 57 |  | $9-8-1$ |  |  |  |
| 3A | 58 |  | 9-8-2 |  |  |  |
| 3B | 59 60 |  | $9-8-3$ $9-8-4$ |  |  |  |
| 3C | 60 61 |  | $9-8-4$ $9-8-5$ |  |  |  |
| 3E | 62 |  | 9-8-6 |  |  |  |
| 3F | 63 |  | 9-8-7 |  |  |  |
| ${ }^{\dagger}$ Hexadecimal and decimal notation. ${ }^{\text {tt}}$ Decimal notation (column-row). |  |  |  |  |  |  |


| EBCDIC ${ }^{\dagger}$ |  | Symbol | Card Code | $\mathrm{ANSCII}^{\text {tt }}$ | Meaning | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Hex. | Dec. |  |  |  |  |  |
| 40 | 64 | SP | blank | 2-0 | blank | 41 through 49 will not be assigned. |
| 41 | 65 |  | 12-0-9-1 |  |  |  |
| 42 | 66 |  | 12-0-9-2 |  |  |  |
| 43 | 67 |  | 12-0-9-3 |  |  |  |
| 44 | 68 |  | 12-0-9-4 |  |  |  |
| 45 | 69 |  | 12-0-9-5 |  |  |  |
| 46 | 70 |  | 12-0-9-6 |  |  |  |
| 47 | 71 |  | 12-0-9-7 |  |  |  |
| 48 | 72 |  | 12-0-9-8 |  |  |  |
| 49 | 73 |  | 12-8-1 |  |  |  |
| 4A | 74 | cor ' | 12-8-2 | 6-0 | cent or accent grave <br> period <br> less than <br> left parenthesis <br> plus <br> vertical bar or broken bar | Accent grave used for left single quote. |
| 4B | 75 | . | 12-8-3 | 2-14 |  |  |
| 4C | 76 | $<$ | 12-8-4 | 3-12 |  |  |
| 4D | 77 | $($ | 12-8-5 | 2-8 |  |  |
| 4E | 78 | + | 12-8-6 | 2-11 |  |  |
| 4F | 79 | I or 1 | 12-8-7 | 7-12 |  |  |
| 50 | 80 | \& | 12 | 2-6 | ampersand | 51 through 59 will not be assigned. |
| 51 | 81 |  | 12-11-9-1 |  |  |  |
| 52 | 82 |  | 12-11-9-2 |  |  |  |
| 53 | 83 |  | 12-11-9-3 |  |  |  |
| 54 | 84 |  | 12-11-9-4 |  |  |  |
| 55 | 85 |  | 12-11-9-5 |  |  |  |
| 56 | 86 |  | 12-11-9-6 |  |  |  |
| 57 | 87 |  | 12-11-9-7 |  |  |  |
| 58 | 88 |  | 12-11-9-8 |  |  |  |
| 59 | 89 |  | 11-8-1 |  |  |  |
| 5A | 90 | $!$ | 11-8-2 | 2-1 | exclamation point |  |
| 5B | 91 | \$ | 11-8-3 | 2-4 | dollars |  |
| 5C | 92 | * | 11-8-4 | 2-10 | asterisk |  |
| 5D | 93 | ) | 11-8-5 | 2-9 | right parenthesis |  |
| 5E | 94 | ; | 11-8-6 | 3-11 | semicolon |  |
| 5F | 95 | $\sim$ or $\sim$ | 11-8-7 | . 7-14 | tilde or logical not |  |
| 60 | 96 | - | 11 | 2-13 | minus, dash, hyphen | 62 through 69 will not be assigned. |
| 61 | 97 | / | 0-1 | 2-15 | slosh |  |
| 62 | 98 |  | 11-0-9-2 |  |  |  |
| 63 | 99 |  | 11-0-9-3 |  |  |  |
| 64 | 100 |  | $11-0-9-4$ |  |  |  |
| 65 | 101 |  | 11-0-9-5 |  |  |  |
| 66 | 102 |  | 11-0-9-6 |  |  |  |
| 67 | 103 |  | 11-0-9-7 |  |  |  |
| 68 | 104 |  | 11-0-9-8 |  |  |  |
| 69 | 105 |  | 0-8-1 |  |  |  |
| 6A | 106 | $\sim$ | 12-11 | 5-14 | circumflex comma percent | On Madel $7015{ }^{\text {n }}$ is $\wedge$ (caret). |
| 6B | 107 | , | 0-8-3 | 2-12 |  |  |
| 6 C | 108 | \% | 0-8-4 | 2-5 |  |  |
| 6D | 109 | - | 0-8-5 | 5-15 | underline greater than question mark | Underline is sometimes called "break character"; may be printed along bottom of character line. |
| 6E | 110 | $>$ | 0-8-6 | 3-14 |  |  |
| 6F | 111 | ? | 0-8-7 | 3-15 |  |  |
| 70 | 112 |  | 12-11-0 |  | colon <br> number <br> at <br> apostrophe (right single quote) <br> equals <br> quotation mark | 70 through 79 will not be assigned. |
| 71 | 113 |  | 12-11-0-9-1 |  |  |  |
| 72 | 114 |  | 12-11-0-9-2 |  |  |  |
| 73 | 115 |  | 12-11-0-9-3 |  |  |  |
| 74 | 116 |  | 12-11-0-9-4 |  |  |  |
| 75 | 117 |  | 12-11-0-9-5 |  |  |  |
| 76 | 118 |  | 12-11-0-9-6 |  |  |  |
| 77 | 119 |  | 12-11-0-9-7 |  |  |  |
| 78 | 120 |  | 12-11-0-9-8 |  |  |  |
| 79 | 121 |  | 8-1 |  |  |  |
| 7A | 122 | : | 8-2 | 3-10 |  |  |
| 7B | 123 | \# | 8-3 | 2-3 |  |  |
| 7 C | 124 | @ | 8-4 | 4-0 |  |  |
| 7 D | 125 | , | 8-5 | 2-7 |  |  |
| 7E | 126 | $=$ | 8-6 | 3-13 |  |  |
| 7F | 127 | " | 8-7 | 2-2 |  |  |
|  | adecin cimal | and decim ation (col | notation. n-row). |  |  |  |

STANDARD SYMBOL-CODE CORRESPONDENCES (cont.)

| EBCDIC ${ }^{\dagger}$ |  | Symbol | Card Code | ANSCII ${ }^{\text {+ }}$ | Meaning | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Hex. | Dec. |  |  |  |  |  |
| 80 | 128 |  | 12-0-8-1 |  |  | 80 is unassigned. |
| 81 | 129 | a | 12-0-1 | 6-1 |  | 81-89, '91-99, A2-A9 comprise the |
| 82 | 130 | b | 12-0-2 | 6-2 |  | lowercase alphabet. Available |
| 83 | 131 | c | 12-0-3 | 6-3 |  | only in standard 89- and 95- |
| 84 | 132 | d | 12-0-4 | 6-4 |  | character sets. |
| 85 | 133 | e | 12-0-5 | 6-5 |  |  |
| 86 | 134 | $f$ | 12-0-6 | 6-6 |  |  |
| 87 | 135 | 9 | 12-0-7 | 6-7 |  |  |
| 88 | 136 | h | 12-0-8 | 6-8 |  |  |
| 89 | 137 | i | 12-0-9 | 6-9 |  |  |
| 8A | 138 |  | 12-0-8-2 |  |  | 8A through 90 are unassigned. |
| 8B | 139 |  | 12-0-8-3 |  |  |  |
| 8 C | 140 |  | 12-0-8-4 |  |  |  |
| 8D | 141 |  | 12-0-8-5 |  |  |  |
| 8E | 142 |  | 12-0-8-6 |  |  |  |
| 8F | 143 |  | 12-0-8-7 |  |  |  |
| 90 | 144 |  | 12-11-8-1 |  |  |  |
| 91 | 145 | j | 12-11-1 | 6-10 |  |  |
| 92 | 146 | k | 12-11-2 | 6-11 |  |  |
| 93 | 147 | 1 | 12-11-3 | 6-12 |  |  |
| 94 | 148 | m | 12-11-4 | 6-13 |  |  |
| 95 | 149 | n | 12-11-5 | 6-14 |  |  |
| 96 | 150 | $\bigcirc$ | 12-11-6 | 6-15 |  |  |
| 97 | 151 | P | 12-11-7 | 7-0 |  |  |
| 98 | 152 | 9 | 12-11-8 | 7-1 |  |  |
| 99 | 153 | r | 12-11-9 | 7-2 |  |  |
| 9A | 154 |  | 12-11-8-2 |  |  | 9A through Al are unassigned. |
| 9B | 155 |  | 12-11-8-3 |  |  |  |
| 9 | 156 |  | 12-11-8-4 |  |  |  |
| 9 D | 157 |  | 12-11-8-5 |  |  |  |
| 9E | 158 |  | 12-11-8-6 |  |  |  |
| 9 F | 159 |  | 12-11-8-7 |  |  |  |
| A0 | 160 |  | 11-0-8-1 |  |  |  |
| ${ }^{4} 1$ | 161 |  | 11-0-1 |  |  |  |
| A2 | 162 | s | 11-0-2 | 7-3 |  |  |
| A3 | 163 | $t$ | 11-0-3 | 7-4 |  |  |
| A4 | 164 | $\checkmark$ | 11-0-4 | 7-5 |  |  |
| A5 | 165 | $v$ | 11-0-5 | 7-6 |  |  |
| A6 | 166 | w | 11-0-6 | 7-7 |  |  |
| A7 | 167 | x | 11-0-7 | 7-8 |  |  |
| A8 | 168 | $y$ | 11-0-8 | 7-9 |  |  |
| A9 | 169 | $z$ | 11-0-9 | 7-10 |  |  |
| AA | 170 |  | 11-0-8-2 |  |  | AA through $B 0$ are unassigned. |
| AB | 171 |  | 11-0-8-3 |  |  |  |
| $A C$ | 172 |  | 11-0-8-4 |  |  |  |
| AD | 173 |  | 11-0-8-5 |  |  |  |
| AE | 174 |  | 11-0-8-6 |  |  |  |
| AF | 175 |  | 11-0-8-7 |  |  |  |
|  |  |  | 12-11-0-8-1 |  |  |  |
| B1 | 177 | 1 | 12-11-0-1 | 5-12 | backslash |  |
| B2 | 178 | , | 12-11-0-2 | 7-11 | left brace |  |
| B3 | 179 | \} | 12-11-0-3 | 7-13 | right brace |  |
| B4 | 180 | [ | 12-11-0-4 | 5-11 | left bracket |  |
| B5 | 181 | ] | 12-11-0-5 | 5-13 | right bracket |  |
| B6 | 182 |  | 12-11-0-6 |  |  | B6 through BF are unassigned. |
| B7 | 183 |  | 12-11-0-7 |  |  |  |
| 88 | 184 |  | 12-11-0-8 |  |  |  |
| B9 | 185 |  | 12-11-0-9 |  |  |  |
| BA | 186 |  | 12-11-0-8-2 |  |  |  |
| BB | 187 |  | 12-11-0-8-3 |  |  |  |
| BC | 188 |  | 12-11-0-8-4 |  |  |  |
| BD | 189 |  | 12-11-0-8-5 |  |  |  |
| BE | 190 |  | 12-11-0-8-6 |  |  |  |
| BF | 191 |  | 12-11-0-8-7 |  |  |  |
| ${ }^{\dagger}$ Hexadecimal and decimal notation. ${ }^{\dagger \dagger}$ Decimal notation (column-row). |  |  |  |  |  |  |

## STANDARD SYMBOL-CODE CORRESPONDENCES (cont.)

| EBCDIC ${ }^{\dagger}$ |  | Symbol | Card Code | ANSCII ${ }^{\dagger \dagger}$ | Meaning | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Hex. | Dec. |  |  |  |  |  |
| C0 | 192 |  | 12-0 |  |  | C 0 is unassigned. |
| Cl | 193 | A | 12-1 | 4-1 |  | C1-C9, D1-D9, E2-E9 comprise the |
| C2 | 194 | B | 12-2 | 4-2 |  | uppercase alphabet. |
| C3 | 195 | C | 12-3 | 4-3 |  |  |
| C4 | 196 | D | 12-4 | 4-4 |  |  |
| C5 | 197 | E | 12-5 | 4-5 |  |  |
| C6 | 198 | F | 12-6 | 4-6 |  |  |
| C7 | 199 | G | 12-7 | 4-7 |  |  |
| C8 | 200 | H | 12-8 | 4-8 |  |  |
| C9 | 201 | I | 12-9 | 4-9 |  |  |
| CA | 202 |  | 12-0-9-8-2 |  |  | CA through CF will not be assigned. |
| CB | 203 |  | 12-0-9-8-3 |  |  |  |
| CC | 204 |  | 12-0-9-8-4 |  |  |  |
| CD | 205 |  | 12-0-9-8-5 |  |  |  |
| CE | 206 |  | 12-0-9-8-6 |  |  |  |
| CF | 207 |  | 12-0-9-8-7 |  |  |  |
| D0 | 208 |  | 11-0 |  |  | DO is unassigned. |
| D1 | 209 | J | 11-1 | 4-10 |  |  |
| D2 | 210 | K | 11-2 | 4-11 |  |  |
| D3 | 211 | L | 11-3 | 4-12 |  |  |
| D4 | 212 | M | 11-4 | 4-13 |  |  |
| D5 | 213 | N | 11-5 | 4-14 |  |  |
| D6 | 214 | O | 11-6 | 4-15 |  |  |
| D7 | 215 | P | 11-7 | 5-0 |  |  |
| D8 | 216 | Q | 11-8 | 5-1 |  |  |
| D9 | 217 | R | 11-9 | 5-2 |  |  |
| DA | 218 |  | 12-11-9-8-2 |  |  | DA through DF will not be assigned. |
| DB | 219 |  | 12-11-9-8-3 |  |  |  |
| DC | 220 |  | 12-11-9-8-4 |  |  |  |
| DD | 221 |  | 12-11-9-8-5 |  |  |  |
| DE | 222 |  | 12-11-9-8-6 |  |  |  |
| DF | 223 |  | 12-11-9-8-7 |  |  |  |
| E0 | 224 |  | 0-8-2 |  |  | E0, El are unassigned. |
| E1 | 225 |  | 11-0-9-1 |  |  |  |
| E2 | 226 | S | 0-2 | 5-3 |  |  |
| E3 | 227 | T | 0-3 | 5-4 |  |  |
| E4 | 228 | U | 0-4 | 5-5 |  |  |
| E5 | 229 | V | 0-5 | 5-6 |  |  |
| E6 | 230 | w | 0-6 | 5-7 |  |  |
| E7 | 231 | $X$ | 0-7 | 5-8 |  |  |
| E8 | 232 | Y | 0-8 | 5-9 |  |  |
| E9 | 233 | Z | 0-9 | 5-10 |  |  |
| EA | 234 |  | 11-0-9-8-2 |  |  | EA through EF will not be assigned. |
| EB | 235 |  | 11-0-9-8-3 |  |  |  |
| EC | 236 |  | 11-0-9-8-4 |  |  |  |
| ED | 237 |  | 11-0-9-8-5 |  |  |  |
| EE | 238 |  | $\mathrm{i}_{1}-\hat{0}-\hat{9}-8-6$ |  |  |  |
| EF | 239 |  | 11-0-9-8-7 |  |  |  |
| F0 | 240 | 0 | 0 | 3-0 |  |  |
| F1 | 241 | 1 | 1 | 3-1 |  |  |
| F2 | 242 | 2 | 2 | 3-2 |  |  |
| F3 | 243 | 3 | 3 | 3-3 |  |  |
| F4 | 244 | 4 | 4 | 3-4 |  |  |
| F5 | 245 | 5 | 5 | 3-5 |  |  |
| F6 | 246 | 6 | 6 | 3-6 |  |  |
| F7 | 247 | 7 | 7 | 3-7 |  |  |
| F8 | 248 | 8 | 8 | 3-8 |  |  |
| F9 | 249 | 9 | 9 | 3-9 |  |  |
| FA | 250 |  | 12-11-0-9-8-2 |  |  | FA through FE will not be assigned. |
| FB | 251 |  | 12-11-0-9-8-3 |  |  |  |
| FC | 252 |  | 12-11-0-9-8-4 |  |  |  |
| FD | 253 |  | 12-11-0-9-8-5 |  |  |  |
| FE | 254 |  | 12-11-0-9-8-6 |  |  |  |
| FF | 255 | DEL | 12-11-0-9-8-7 |  | delete | Special - neither graphic nor control symbol. |
| ${ }^{\dagger}$ Hexadecimal and decimal notation. ${ }^{\dagger \dagger}$ Decimal notation (column-row). |  |  |  |  |  |  |

## HEXADECIMAL ARITHMETIC

AdDITION TABLE

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | c | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | OA | ${ }^{\circ} \mathrm{B}$ | 0 | OD | OE | OF | 10 |
| 2 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | OA | OB | $\bigcirc$ | OD | OE | OF | 10 | 11 |
| 3 | 04 | 05 | 06 | 07 | 08 | 09 | OA | OB | 0 | OD | OE | OF | 10 | 11 | 12 |
| 4 | 05 | 06 | 07 | 08 | 09 | OA | OB | OC | OD | OE | OF | 10 | 11 | 12 | 13 |
| 5 | 06 | 07 | 08 | 09 | OA | OB | 0 O | OD | OE | OF | 10 | 11 | 12 | 13 | 14 |
| 6 | 07 | 08 | 09 | OA | OB | 0 | OD | OE | OF | 10 | 11 | 12 | 13 | 14 | 15 |
| 7 | 08 | 09 | OA | OB | $\bigcirc$ | OD | OE | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
| 8 | 09 | OA | OB | $\propto$ | OD | OE | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 |
| 9 | OA | OB | 0 C | OD | OE | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 |
| A | OB | 0 | OD | OE | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 |
| B | $\bigcirc$ | OD | OE | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A |
| C | OD | OE | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B |
| D | OE | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1 B | 1 C |
| E | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1 C | 1D |
| F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1 C | 1D | IE |

MULTIPLICATION TABLE

| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 2 | 04 | 06 | 08 | 0A | $\bigcirc$ | OE | 10 | 12 | 14 | 16 | 18 | 1A | 1 C | 1E |
| 3 | 06 | 09 | 0 | OF | 12 | 15 | 18 | 1 B | IE | 21 | 24 | 27 | 2A | 2D |
| 4 | 08 | 0 | 10 | 14 | 18 | 1C | 20 | 24 | 28 | 2 C | 30 | 34 | 38 | 3 C |
| 5 | OA | OF | 14 | 19 | IE | 23 | 28 | 2D | 32 | 37 | 3 C | 41 | 46 | 4B |
| 6 | 0 C | 12 | 18 | IE | 24 | 2A | 30 | 36 | 3 C | 42 | 48 | 4E | 54 | 5A |
| 7 | OE | 15 | 1 C | 23 | 2A | 31 | 38 | 3 F | 46 | 4D | 54 | 5B | 62 | 69 |
| 8 | 10 | 18 | 20 | 28 | 30 | 38 | 40 | 48 | 50 | 58 | 60 | 68 | 70 | 78 |
| 9 | 12 | 1B | 24 | 2D | 36 | 3 F | 48 | 51 | 5A | 63 | 6 C | 75 | 7 E | 87 |
| A | 14 | 1E | 28 | 32 | 3 C | 46 | 50 | 5A | 64 | 6 E | 78 | 82 | ${ }_{8} \mathrm{C}$ | 96 |
| B | 16 | 21 | 2 C | 37 | 42 | 4D | 58 | 63 | 6 E | 79 | 84 | 8 F | 9 A | A5 |
| C | 18 | 24 | 30 | 3 C | 48 | 54 | 60 | 6 C | 78 | 84 | 90 | 9 C | A8 | B4 |
| D | 1A | 27 | 34 | 41 | 4 E | 5B | 68 | 75 | 82 | 8F | 9 | A9 | B6 | C3 |
| E | 1 C | 2A | 38 | 46 | 54 | 62 | 70 | 7 E | 8C | 9A | A8 | B6 | C4 | D2 |
| F | IE | 2D | 3 C | $4 B$ | 5A | 69 | 78 | 87 | 96 | A5 | B4 | C3 | D2 | E1 |

## TABLE OF POWERS OF SIXTEEN $\boldsymbol{1 0}^{\mathbf{N}}$

|  |  |  |  |  | $16^{n}$ | n |  |  | $16^{-n}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 1 | 0 | 0.10000 | 00000 | 00000 | 00000 | $\times 10$ |
|  |  |  |  |  | 16 | 1 | 0.62500 | 00000 | 00000 | 00000 | $\times 10^{-1}$ |
|  |  |  |  |  | 256 | 2 | 0.39062 | 50000 | 00000 | 00000 | $\times 10^{-2}$ |
|  |  |  |  | 4 | 096 | 3 | 0.24414 | 06250 | 00000 | 00000 | $\times 10^{-3}$ |
|  |  |  |  | 65 | 536 | 4 | 0.15258 | 78906 | 25000 | 00000 | $\times 10^{-4}$ |
|  |  |  | 1 | 048 | 576 | 5 | 0.95367 | 43164 | 06250 | 00000 | $\times 10^{-6}$ |
|  |  |  | 16 | 777 | 216 | 6 | 0.59604 | 64477 | 53906 | 25000 | $\times 10^{-7}$ |
|  |  |  | 268 | 435 | 456 | 7 | 0.37252 | 90298 | 46191 | 40625 | $\times 10^{-8}$ |
|  |  | 4 | 294 | 967 | 296 | 8 | 0.23283 | 06436 | 53869 | 62891 | $\times 10^{-9}$ |
|  |  | 68 | 719 | 476 | 736 | 9 | 0.14551 | 91522 | 83668 | 51807 | $\times 10^{-10}$ |
|  | 1 | 099 | 511 | 627 | 776 | 10 | 0.90949 | 47017 | 72928 | 23792 | $\times 10^{-12}$ |
|  | 17 | 592 | 186 | 044 | 416 | 11 | 0.56843 | 41886 | 08080 | 14870 | $\times 10^{-13}$ |
|  | 281 | 474 | 976 | 710 | 656 | 12 | 0.35527 | 13678 | 80050 | 09294 | $\times 10^{-14}$ |
| 4 | 503 | 599 | 627 | 370 | 496 | 13 | 0.22204 | 46049 | 25031 | 30808 | $\times 10^{-15}$ |
| 72 | 057 | 594 | 037 | 927 | 936 | 14 | 0.13877 | 78780 | 78144 | 56755 | $\times 10^{-16}$ |
| 1152 | 921 | 504 | 606 | 846 | 976 | 15 | 0.86736 | 17379 | 88403 | 54721 | $\times 10^{-18}$ |

## TABLE OF POWERS OF TEN ${ }_{16}$

|  |  |  | $10^{\mathrm{n}}$ | $\underline{n}$ |  | $10^{-}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1 | 0 | 1.0000 | 0000 | 0000 | 0000 |  |  |
|  |  |  | A | 1 | 0.1999 | 9999 | 9999 | 999A |  |  |
|  |  |  | 64 | 2 | 0.28 F 5 | C28F | 5C28 | F5C3 | $x$ | $16^{-1}$ |
|  |  |  | 3E8 | 3 | 0.4189 | 374B | C6A7 | EF9E |  | $16^{-2}$ |
|  |  |  | 2710 | 4 | 0.68 DB | 8BAC | 710 C | B296 | $x$ | $16^{-3}$ |
|  |  | 1 | 86A0 | 5 | 0.A7C5 | AC47 | 1B47 | 8423 | $x$ | $16^{-4}$ |
|  |  | F | 4240 | 6 | 0.10 C 6 | F7A0 | B5ED | 8D37 | $x$ | $16^{-4}$ |
|  |  | 98 | 9680 | 7 | 0.1 AD7 | F29A | BCAF | 4858 | $\times$ | $16^{-5}$ |
|  |  | 5F5 | E 100 | 8 | 0.2 AF 3 | 1DC4 | 6118 | 73BF | $\times$ | $16^{-6}$ |
|  |  | $3 \mathrm{B9A}$ | CA00 | 9 | 0.44 B 8 | 2FA0 | 9B5A | 52CC | $x$ | $16^{-7}$ |
|  | 2 | 540B | E 400 | 10 | 0.6 DF 3 | 7F67 | 5EF6 | EADF |  | $16^{-8}$ |
|  | 17 | 4876 | E 800 | 11 | 0.AFEB | FF0B | CB24 | AAFF | $\times$ | $16^{-9}$ |
|  | E 8 | D4A5 | 1000 | 12 | 0.1197 | 9981 | 2DEA | 1119 | x | $16^{-9}$ |
|  | 918 | 4E72 | A000 | 13 | 0.1 C25 | C268 | 4976 | 81C2 | $\times$ | $16^{-10}$ |
|  | 5 AF 3 | 107A | 4000 | 14 | 0.2 D 09 | 370D | 4257 | 3604 | $\times$ | $16^{-11}$ |
| 3 | 8D7E | A4C6 | 8000 | 15 | 0.480E | BE7B | 9 D58 | 566D | $x$ | $16^{-12}$ |
| 23 | 86F2 | 6 FCl | 0000 | 16 | 0.734 A | CA5F | 6226 | FOAE | $\times$ | $16^{-13}$ |
| 163 | 4578 | 5D8A | 0000 | 17 | $0 . \mathrm{B} 877$ | AA32 | 36A4 | B449 |  | $16^{-14}$ |
| DE 0 | B6B3 | A764 | 0000 | 18 | 0.1272 | 5DDI | D243 | ABAl | $x$ | $16^{-14}$ |
| 8AC7 | 2304 | 89E8 | 0000 | 19 | 0.1 D83 | C94F | B6 D2 | AC35 | $\times$ | $16^{-15}$ |

The table below provides for direct conversions between hexadecimal integers in the range $0-$ FFF and decimal integers in the range $0-4095$. For conversion of larger integers, the table values may be added to the following figures:


|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 100 | 0256 | 0257 | 0258 | 0259 | 0260 | 0261 | 0262 | 0263 | 0264 | 0265 | 0266 | 0267 | 0268 | 0269 | 0270 | 0271 |
| 110 | 0272 | 0273 | 0274 | 0275 | 0276 | 0277 | 0278 | 0279 | 0280 | 0281 | 0282 | 0283 | 0284 | 0285 | 0286 | 0287 |
| 120 | 0288 | 0289 | 0290 | 0291 | 0292 | 0293 | 0294 | 0295 | 0296 | 0297 | 0298 | 0299 | 0300 | 0301 | 0302 | 0303 |
| 130 | 0304 | 0305 | 0306 | 0307 | 0308 | 0309 | 0310 | 0311 | 0312 | 0313 | 0314 | 0315 | 0316 | 0317 | 0318 | 0319 |
| 140 | 0320 | 0321 | 0322 | 0323 | 0324 | 0325 | 0326 | 0327 | 0328 | 0329 | 0330 | 0331 | 0332 | 0333 | 0334 | 0335 |
| 150 | 0336 | 0337 | 0338 | 0339 | 0340 | 0341 | 0342 | 0343 | 0344 | 0345 | 0346 | 0347 | 0348 | 0349 | 0350 | 0351 |
| 160 | 0352 | 0353 | 0354 | 0355 | 0356 | 0357 | 0358 | 0359 | 0360 | 0361 | 0362 | 0363 | 0364 | 0365 | 0366 | 0367 |
| 170 | 0368 | 0369 | 0370 | 0371 | 0372 | 0373 | 0374 | 0375 | 0376 | 0377 | 0378 | 0379 | 0380 | 0381 | 0382 | 0383 |
| 180 | 0384 | 0385 | 0386 | 0387 | 0388 | 0389 | 0390 | 0391 | 0392 | 0393 | 0394 | 0395 | 0396 | 0397 | 0398 | 0399 |
| 190 | 0400 | 0401 | 0402 | 0403 | 0404 | 0405 | 0406 | 0407 | 0408 | 0409 | 0410 | 0411 | 0412 | 0413 | 0414 | 0415 |
| 1A0 | 0416 | 0417 | 0418 | 0419 | 0420 | 0421 | 0422 | 0423 | 0424 | 0425 | 0426 | 0427 | 0428 | 0429 | 0430 | 0431 |
| 1B0 | 0432 | 0433 | 0434 | 0435 | 0436 | 0437 | 0438 | 0439 | 0440 | 0441 | 0442 | 0443 | 0444 | 0445 | 0446 | 0447 |
| 1C0 | 0448 | 0449 | 0450 | 0451 | 0452 | 0453 | 0454 | 0455 | 0456 | 0457 | 0458 | 0459 | 0460 | 0461 | 0462 | 0463 |
| 1D0 | 0464 | 0465 | 0466 | 0467 | 0468 | 0469 | 0470 | 0471 | 0472 | 0473 | 0474 | 0475 | 0476 | 0477 | 0478 | 0479 |
| 1EO | 0480 | 0481 | 0482 | 0483 | 0484 | 0485 | 0486 | 0487 | 0488 | 0489 | 0490 | 0491 | 0492 | 0493 | 0494 | 0495 |
| 1F0 | 0496 | 0497 | 0498 | 0499 | 0500 | 0501 | 0502 | 0503 | 0504 | 0505 | 0506 | 0507 | 0508 | 0509 | 0510 | 0511 |
| 200 | 0512 | 0513 | 0514 | 0515 | 0516 | 0517 | 0518 | 0519 | 0520 | 0521 | 0522 | 0523 | 0524 | 0525 | 0526 | 0527 |
| 210 | 0528 | 0529 | 0530 | 0531 | 0532 | 0533 | 0534 | 0535 | 0536 | 0537 | 0538 | 0539 | 0540 | 0541 | 0542 | 0543 |
| 220 | 0544 | 0545 | 0546 | 0547 | 0548 | 0549 | 0550 | 0551 | 0552 | 0553 | 0554 | 0555 | 0556 | 0557 | 0558 | 0559 |
| 230 | 0560 | 0561 | 0562 | 0563 | 0564 | 0565 | 0566 | 0567 | 0568 | 0569 | 0570 | 0571 | 0572 | 0573 | 0574 | 0575 |
| 240 | 0576 | 0577 | 0578 | 0579 | 0580 | 0581 | 0582 | 0583 | 0584 | 0585 | 0586 | 0587 | 0588 | 0589 | 0590 | 0591 |
| 250 | 0592 | 0593 | 0594 | 0595 | 0596 | 0597 | 0598 | 0599 | 0600 | 0601 | 0602 | 0603 | 0604 | 0605 | 0606 | 0607 |
| 260 | 0608 | 0609 | 0610 | 0611 | 0612 | 0613 | 0614 | 0615 | 0616 | 0617 | 0618 | 0619 | 0620 | 0621 | 0622 | 0623 |
| 270 | 0624 | 0625 | 0626 | 0627 | 0628 | 0629 | 0630 | 0631 | 0632 | 0633 | 0634 | 0635 | 0636 | 0637 | 0638 | 0639 |
| 280 | 0640 | 0641 | 0642 | 0643 | 0644 | 0645 | 0646 | 0647 | 0648 | 0649 | 0650 | 0651 | 0652 | 0653 | 0654 | 0655 |
| 290 | 0656 | 0657 | 0658 | 0659 | 0660 | 0661 | 0662 | 0663 | 0664 | 0665 | 0666 | 0667 | 0668 | 0669 | 0670 | 0671 |
| 2A0 | 0672 | 0673 | 0674 | 0675 | 0676 | 0677 | 0678 | 0679 | 0680 | 0681 | 0682 | 0683 | 0684 | 0685 | 0686 | 0687 |
| 280 | 0688 | 0689 | 0690 | 0691 | 0692 | 0693 | 0694 | 0695 | 0696 | 0697 | 0698 | 0699 | 0700 | 0701 | 0702 | 0703 |
| 2C0 | 0704 | 0705 | 0706 | 0707 | 0708 | 0709 | 0710 | 071 | 0712 | 0713 | 0714 | 0715 | 0716 | 0717 | 0718 | 0719 |
| 2D0 | 0720 | 0721 | 0722 | 0723 | 0724 | 0725 | 0726 | 0727 | 0728 | 0729 | 0730 | 0731 | 0732 | 0733 | 0734 | 0735 |
| 2E0 | 0736 | 0737 | 0738 | 0739 | 0740 | 0741 | 0742 | 0743 | 0744 | 0745 | 0746 | 0747 | 0748 | 0749 | 0750 | 0751 |
| 2F0 | 0752 | 0753 | 0754 | 0755 | 0756 | 0757 | 0758 | 0759 | 0760 | 0761 | 0762 | 0763 | 0764 | 0765 | 0766 | 0767 |
| 300 | 0768 | 0769 | 0770 | 0771 | 0772 | 0773 | 0774 | 0775 | 0776 | 0777 | 0778 | 0779 | 0780 | 0781 | 0782 | 0783 |
| 310 | 0784 | 0785 | 0786 | 0787 | 0788 | 0789 | 0790 | 0791 | 0792 | 0793 | 0794 | 0795 | 0796 | 0797 | 0798 | 0799 |
| 320 | 0800 | 0801 | 0802 | 0803 | 0804 | 0805 | 0806 | 0807 | 0808 | 0809 | 0810 | 0811 | 0812 | 0813 | 0814 | 0815 |
| 330 | 0816 | 0817 | 0818 | 0819 | 0820 | 0821 | 0822 | 0823 | 0824 | 0825 | 0826 | 0827 | 0828 | 0829 | 0830 | 0831 |
| 340 | 0832 | 0833 | 0834 | 0835 | 0836 | 0837 | 0838 | 0839 | 0840 | 0841 | 0842 | 0843 | 0844 | 0845 | 0846 | 0847 |
| 350 | 0848 | 0849 | 0850 | 0851 | 0852 | 0853 | 0854 | 0855 | 0856 | 0857 | 0858 | 0859 | 0860 | 0861 | 0862 | 0863 |
| 360 | 0864 | 0865 | 0866 | 0867 | 0868 | 0869 | 0870 | 0871 | 0872 | 0873 | 0874 | 0875 | 0876 | 0877 | 0878 | 0879 |
| 370 | 0880 | 0881 | 0882 | 0883 | 0884 | 0885 | 0886 | 0887 | 0888 | 0889 | 0890 | 0891 | 0892 | 0893 | 0894 | 0895 |
| 380 | 0896 | 0897 | 0898 | 0899 | 0900 | 0901 | 0902 | 0903 | 0904 | 0905 | 0906 | 0907 | 0908 | 0909 | 0910 | 0911 |
| 390 | 0912 | 0913 | 0914 | 0915 | 0916 | 0917 | 0918 | 0919 | 0920 | 0921 | 0922 | 0923 | 0924 | 0925 | 0926 | 0927 |
| 3 AO | 0928 | 0929 | 0930 | 0931 | 0932 | 0933 | 0934 | 0935 | 0936 | 0937 | 0938 | 0939 | 0940 | 0941 | 0942 | 0943 |
| 3B0 | 0944 | 0945 | 0946 | 0947 | 0948 | 0949 | 0950 | 0951 | 0952 | 0953 | 0954 | 0955 | 0956 | 0957 | 0958 | 0959 |
| 3 CO | 0960 | 0961 | 0962 | 0963 | 0964 | 0965 | 0966 | 0967 | 0968 | 0969 | 0970 | 0971 | 0972 | 0973 | 0974 | 0975 |
| 3D0 | 0976 | 0977 | 0978 | 0979 | 0980 | 0981 | 0982 | 0983 | 0984 | 0985 | 0986 | 0987 | 0988 | 0989 | 0990 | 0991 |
| 3E0 | 0992 | 0993 | 0994 | 0995 | 0996 | 0997 | 0998 | 0999 | 1000 | 1001 | 1002 | 1003 | 1004 | 1005 | 1006 | 1007 |
| 3F0 | 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 | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 400 | 1024 | 1025 | 1026 | 1027 | 1028 | 1029 | 1030 | 1031 | 1032 | 1033 | 1034 | 1035 | 1036 | 1037 | 1038 | 1039 |
| 410 | 1040 | 1041 | 1042 | 1043 | 1044 | 1045 | 1046 | 1047 | 1048 | 1049 | 1050 | 1051 | 1052 | 1053 | 1054 | 1055 |
| 420 | 1056 | 1057 | 1058 | 1059 | 1060 | 1061 | 1062 | 1063 | 1064 | 1065 | 1066 | 1067 | 1068 | 1069 | 1070 | 1071 |
| 430 | 1072 | 1073 | 1074 | 1075 | 1076 | 1077 | 1078 | 1079 | 1080 | 1081 | 1082 | 1083 | 1084 | 1085 | 1086 | 1087 |
| 440 | 1088 | 1089 | 1090 | 1091 | 1092 | 1093 | 1094 | 1095 | 1096 | 1097 | 1098 | 1099 | 1100 | 1101 | 1102 | 1103 |
| 450 | 1104 | 1105 | 1106 | 1107 | 1108 | 1109 | 1110 | 1111 | 1112 | 1113 | 1114 | 1115 | 1116 | 1117 | 1118 | 1119 |
| 460 | 1120 | 1121 | 1122 | 1123 | 1124 | 1125 | 1126 | 1127 | 1128 | 1129 | 1130 | 1131 | 1132 | 1133 | 1134 | 1135 |
| 470 | 1136 | 1137 | 1138 | 1139 | 1140 | 1141 | 1142 | 1143 | 1144 | 1145 | 1146 | 1147 | 1148 | 1149 | 1150 | 1151 |
| 480 | 1152 | 1153 | 1154 | 1155 | 1156 | 1157 | 1158 | 1159 | 1160 | 1161 | 1162 | 1163 | 1164 | 1165 | 1166 | 1167 |
| 490 | 1168 | 1169 | 1170 | 1171 | 1172 | 1173 | 1174 | 1175 | 1176 | 1177 | 1178 | 1179 | 1180 | 1181 | 1182 | 1183 |
| 4A0 | 1184 | 1185 | 1186 | 1187 | 1188 | 1189 | 1190 | 1191 | 1192 | 1193 | 1194 | 1195 | 1196 | 1197 | 1198 | 1199 |
| 4B0 | 1200 | 1201 | 1202 | 1203 | 1204 | 1205 | 1206 | 1207 | 1208 | 1209 | 1210 | 1211 | 1212 | 1213 | 1214 | 1215 |
| 4C0 | 1216 | 1217 | 1218 | 1219 | 1220 | 1221 | 1222 | 1223 | 1224 | 1225 | 1226 | 1227 | 1228 | 1229 | 1230 | 1231 |
| 4D0 | 1232 | 1233 | 1234 | 1235 | 1236 | 1237 | 1238 | 1239 | 1240 | 1241 | 1242 | 1243 | 1244 | 1245 | 1246 | 1247 |
| 4E0 | 1248 | 1249 | 1250 | 1251 | 1252 | 1253 | 1254 | 1255 | 1256 | 1257 | 1258 | 1259 | 1260 | 1261 | 1262 | 1263 |
| 4FO | 1264 | 1265 | 1266 | 1267 | 1268 | 1269 | 1270 | 1271 | 1272 | 1273 | 1274 | 1275 | 1276 | 1277 | 1278 | 1279 |
| 500 | 1280 | 1281 | 1282 | 1283 | 1284 | 1285 | 1286 | 1287 | 1288 | 1289 | 1290 | 1291 | 1292 | 1293 | 1294 | 1295 |
| 510 | 1296 | 1297 | 1298 | 1299 | 1300 | 1301 | 1302 | 1303 | 1304 | 1305 | 1306 | 1307 | 1308 | 1309 | 1310 | 1311 |
| 520 | 1312 | 1313 | 1314 | 1315 | 1316 | 1317 | 1318 | 1319 | 1320 | 1321 | 1322 | 1323 | 1324 | 1325 | 1326 | 1327 |
| 530 | 1328 | 1329 | 1330 | 1331 | 1332 | 1333 | 1334 | 1335 | 1336 | 1337 | 1338 | 1339 | 1340 | 1341 | 1342 | 1343 |
| 540 | 1344 | 1345 | 1346 | 1347 | 1348 | 1349 | 1350 | 1351 | 1352 | 1353 | 1354 | 1355 | 1356 | 1357 | 1358 | 1359 |
| 550 | 1360 | 1361 | 1362 | 1363 | 1364 | 1365 | 1366 | 1367 | 1368 | 1369 | 1370 | 1371 | 1372 | 1373 | 1374 | 1375 |
| 560 | 1376 | 1377 | 1378 | 1379 | 1380 | 1381 | 1382 | 1383 | 1384 | 1385 | 1386 | 1387 | 1388 | 1389 | 1390 | 1391 |
| 570 | 1392 | 1393 | 1394 | 1395 | 1396 | 1397 | 1398 | 1399 | 1400 | 1401 | 1402 | 1403 | 1404 | 1405 | 1406 | 1407 |
| 580 | 1408 | 1409 | 1410 | 1411 | 1412 | 1413 | 1414 | 1415 | 1416 | 1417 | 1418 | 1419 | 1420 | 1421 | 1422 | 1423 |
| 590 | 1424 | 1425 | 1426 | 1427 | 1428 | 1429 | 1430 | 1431 | 1432 | 1433 | 1434 | 1435 | 1436 | 1437 | 1438 | 1439 |
| 5AO | 1440 | 1441 | 1442 | 1443 | 1444 | 1445 | 1446 | 1447 | 1448 | 1449 | 1450 | 1451 | 1452 | 1453 | 1454 | 1455 |
| 5B0 | 1456 | 1457 | 1458 | 1459 | 1460 | 1461 | 1462 | 1463 | 1464 | 1465 | 1466 | 1467 | 1468 | 1469 | 1470 | 1471 |
| 5 CO | 1472 | 1473 | 1474 | 1475 | 1476 | 1477 | 1478 | 1479 | 1480 | 1481 | 1482 | 1483 | 1484 | 1485 | 1486 | 1487 |
| 5D0 | 1488 | 1489 | 1490 | 1491 | 1492 | 1493 | 1494 | 1495 | 1496 | 1497 | 1498 | 1499 | 1500 | 1501 | 1502 | 1503 |
| 5E0 | 1504 | 1505 | 1506 | 1507 | 1508 | 1509 | 1510 | 1511 | 1512 | 1513 | 1514 | 1515 | 1516 | 1517 | 1518 | 1519 |
| 5F0 | 1520 | 1521 | 1522 | 1523 | 1524 | 1525 | 1526 | 1527 | 1528 | 1529 | 1530 | 1531 | 1532 | 1533 | 1534 | 1535 |
| 600 | 1536 | 1537 | 1538 | 1539 | 1540 | 1541 | 1542 | 1543 | 1544 | 1545 | 1546 | 1547 | 1548 | 1549 | 1550 | 1551 |
| 610 | 1552 | 1553 | 1554 | 1555 | 1556 | 1557 | 1558 | 1559 | 1560 | 1561 | 1562 | 1563 | 1564 | 1565 | 1566 | 1567 |
| 620 | 1568 | 1569 | 1570 | 1571 | 1572 | 1573 | 1574 | 1575 | 1576 | 1577 | 1578 | 1579 | 1580 | 1581 | 1582 | 1583 |
| 630 | 1584 | 1585 | 1586 | 1587 | 1588 | 1589 | 1590 | 1591 | 1592 | 1593 | 1594 | 1595 | 1596 | 1597 | 1598 | 1599 |
| 640 | 1600 | 1601 | 1602 | 1603 | 1604 | 1605 | 1606 | 1607 | 1608 | 1609 | 1610 | 1611 | 1612 | 1613 | 1614 | 1615 |
| 650 | 1616 | 1617 | 1618 | 1619 | 1620 | 1621 | 1622 | 1623 | 1624 | 1625 | 1626 | 1627 | 1628 | 1629 | 1630 | 1631 |
| 660 | 1632 | 1633 | 1634 | 1635 | 1636 | 1637 | 1638 | 1639 | 1640 | 1641 | 1642 | 1643 | 1644 | 1645 | 1646 | 1647 |
| 670 | 1648 | 1649 | 1650 | 1651 | 1652 | 1653 | 1654 | 1655 | 1656 | 1657 | 1658 | 1659 | 1660 | 1661 | 1662 | 1663 |
| 680 | 1664 | 1665 | 1666 | 1667 | 1668 | 1669 | 1670 | 1671 | 1672 | 1673 | 1674 | 1675 | 1676 | 1677 | 1678 | 1679 |
| 690 | 1680 | 1681 | 1682 | 1683 | 1684 | 1685 | 1686 | 1687 | 1688 | 1689 | 1690 | 1691 | 1692 | 1693 | 1694 | 1695 |
| 6 AO | 1696 | 1697 | 1698 | 1699 | 1700 | 1701 | 1702 | 1703 | 1704 | 1705 | 1706 | 1707 | 1708 | 1709 | 1710 | 1711 |
| 6B0 | 1712 | 1713 | 1714 | 1715 | 1716 | 1717 | 1718 | 1719 | 1720 | 1721 | 1722 | 1723 | 1724 | 1725 | 1726 | 1727 |
| $6 \mathrm{C0}$ | 1728 | 1729 | 1730 | 1731 | 1732 | 1733 | 1734 | 1735 | 1736 | 1737 | 1738 | 1739 | 1740 | 1741 | 1742 | 1743 |
| 600 | 1744 | 1745 | 1746 | 1747 | 1748 | 1749 | 1750 | 1751 | 1752 | 1753 | 1754 | 1755 | 1756 | 1757 | 1758 | 1759 |
| 6 E 0 | 1760 | 1761 | 1762 | 1763 | 1764 | 1765 | 1766 | 1767 | 1768 | 1769 | 1770 | 1771 | 1772 | 1773 | 1774 | 1775 |
| 6F0 | 1776 | 1777 | 1778 | 1779 | 1780 | 1781 | 1782 | 1783 | 1784 | 1785 | 1786 | 1787 | 1788 | 1789 | 1790 | 1791 |


|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 700 | 1792 | 1793 | 1794 | 1795 | 1796 | 1797 | 1798 | 1799 | 1800 | 1801 | 1802 | 1803 | 1804 | 1805 | 1806 | 1807 |
| 710 | 1808 | 1809 | 1810 | 1811 | 1812 | 1813 | 1814 | 1815 | 1816 | 1817 | 1818 | 1819 | 1820 | 1821 | 1822 | 1823 |
| 720 | 1824 | 1825 | 1826 | 1827 | 1828 | 1829 | 1830 | 1831 | 1832 | 1833 | 1834 | 1835 | 1836 | 1837 | 1838 | 1839 |
| 730 | 1840 | 1841 | 1842 | 1843 | 1844 | 1845 | 1846 | 1847 | 1848 | 1849 | 1850 | 1851 | 1852 | 1853 | 1854 | 1855 |
| 740 | 1856 | 1857 | 1858 | 1859 | 1860 | 1861 | 1862 | 1863 | 1864 | 1865 | 1866 | 1867 | 1868 | 1869 | 1870 | 1871 |
| 750 | 1872 | 1873 | 1874 | 1875 | 1876 | 1877 | 1878 | 1879 | 1880 | 1881 | 1882 | 1883 | 1884 | 1885 | 1886 | 1887 |
| 760 | 1888 | 1889 | 1890 | 1891 | 1892 | 1893 | 1894 | 1895 | 1896 | 1897 | 1898 | 1899 | 1900 | 1901 | 1902 | 1903 |
| 770 | 1904 | 195 | 1906 | 1907 | 1908 | 1909 | 1910 | 1911 | 1912 | 1913 | 1914 | 1915 | 1916 | 1917 | 1918 | 1919 |
| 780 | 1920 | 1921 | 1922 | 1923 | 1924 | 1925 | 1926 | 1927 | 1928 | 1929 | 1930 | 1931 | 1932 | 1933 | 1934 | 1935 |
| 790 | 1936 | 1937 | 1938 | 1939 | 1940 | 1941 | 1942 | 1943 | 1944 | 1945 | 1946 | 1947 | 1948 | 1949 | 1950 | 1951 |
| 7A0 | 1952 | 1953 | 1954 | 1955 | 1956 | 1957 | 1958 | 1959 | 1960 | 1961 | 1962 | 1963 | 1964 | 1965 | 1966 | 1967 |
| 7B0 | 1968 | 1969 | 1970 | 1971 | 1972 | 1973 | 1974 | 1975 | 1976 | 1977 | 1978 | 1979 | 1980 | 1981 | 1982 | 1983 |
| 7C0 | 1984 | 1985 | 1986 | 1987 | 1988 | 1989 | 1990 | 1991 | 1992 | 1993 | 1994 | 1995 | 1996 | 1997 | 1998 | 1999 |
| 700 | 2000 | 2001 | 2002 | 2003 | 2004 | 2005 | 2006 | 2007 | 2008 | 2009 | 2010 | 2011 | 2012 | 2013 | 2014 | 2015 |
| 7E0 | 2016 | 2017 | 2018 | 2019 | 2020 | 2021 | 2022 | 2023 | 2024 | 2025 | 2026 | 2027 | 2028 | 2029 | 2030 | 2031 |
| 7F0 | 2032 | 2033 | 2034 | 2035 | 2036 | 2037 | 2038 | 2039 | 2040 | 2041 | 2042 | 2043 | 2044 | 2045 | 2046 | 2047 |
| 800 | 2048 | 2049 | 2050 | 2051 | 2052 | 2053 | 2054 | 2055 | 2056 | 2057 | 2058 | 2059 | 2060 | 2061 | 2062 | 2063 |
| 810 | 2064 | 2065 | 2066 | 2067 | 2068 | 2069 | 2070 | 2071 | 2072 | 2073 | 2074 | 2075 | 2076 | 2077 | 2078 | 2079 |
| 820 | 2080 | 2081 | 2082 | 2083 | 2084 | 2085 | 2086 | 2087 | 2088 | 2089 | 2090 | 2091 | 2092 | 2093 | 2094 | 2095 |
| 830 | 2096 | 2097 | 2098 | 2099 | 2100 | 2101 | 2102 | 2103 | 2104 | 2105 | 2106 | 2107 | 2108 | 2109 | 2110 | 2111 |
| 840 | 2112 | 2113 | 2114 | 2115 | 2116 | 2117 | 2118 | 2119 | 2120 | 2121 | 2122 | 2123 | 2124 | 2125 | 2126 | 2127 |
| 850 | 2128 | 2129 | 2130 | 2131 | 2132 | 2133 | 2134 | 2135 | 2136 | 2137 | 2138 | 2139 | 2140 | 2141 | 2142 | 2143 |
| 860 | 2144 | 2145 | 2146 | 2147 | 2148 | 2149 | 2150 | 2151 | 2152 | 2153 | 2154 | 2155 | 2156 | 2157 | 2158 | 2159 |
| 870 | 2160 | 2161 | 2162 | 2163 | 2164 | 2165 | 2166 | 2167 | 2168 | 2169 | 2170 | 2171 | 2172 | 2173 | 2174 | 2175 |
| 880 | 2176 | 2177 | 2178 | 2179 | 2180 | 2181 | 2182 | 2183 | 2184 | 2185 | 2186 | 2187 | 2188 | 2189 | 2190 | 2191 |
| 890 | 2192 | 2193 | 2194 | 2195 | 2196 | 2197 | 2198 | 2199 | 2200 | 2201 | 2202 | 2203 | 2204 | 2205 | 2206 | 2207 |
| 8A0 | 2208 | 2209 | 2210 | 2211 | 2212 | 2213 | 2214 | 2215 | 2216 | 2217 | 2218 | 2219 | 2220 | 2221 | 2222 | 2223 |
| 8B0 | 2224 | 2225 | 2226 | 2227 | 2228 | 2229 | 2230 | 2231 | 2232 | 2233 | 2234 | 2235 | 2236 | 2237 | 2238 | 2239 |
| 8C0 | 2240 | 2241 | 2242 | 2243 | 2244 | 2245 | 2246 | 2247 | 2248 | 2249 | 2250 | 2251 | 2252 | 2253 | 2254 | 2255 |
| 8D0 | 2256 | 2257 | 2258 | 2259 | 2260 | 2261 | 2262 | 2263 | 2264 | 2265 | 2266 | 2267 | 2268 | 2269 | 2270 | 2271 |
| 8E0 | 2272 | 2273 | 2274 | 2275 | 2276 | 2277 | 2278 | 2279 | 2280 | 2281 | 2282 | 2283 | 2284 | 2285 | 2286 | 2287 |
| 8 FO | 2288 | 2289 | 2290 | 2291 | 2292 | 2293 | 2294 | 2295 | 2296 | 2297 | 2298 | 2299 | 2300 | 2301 | 2302 | 2303 |
| 900 | 2304 | 2305 | 2306 | 2307 | 2308 | 2309 | 2310 | 2311 | 2312 | 2313 | 2314 | 2315 | 2316 | 2317 | 2318 | 2319 |
| 910 | 2320 | 2321 | 2322 | 2323 | 2324 | 2325 | 2326 | 2327 | 2328 | 2329 | 2330 | 2331 | 2332 | 2333 | 2334 | 2335 |
| 920 | 2336 | 2337 | 2338 | 2339 | 2340 | 2341 | 2342 | 2343 | 2344 | 2345 | 2346 | 2347 | 2348 | 2349 | 2350 | 2351 |
| 930 | 2352 | 2353 | 2354 | 2355 | 2356 | 2357 | 2358 | 2359 | 2360 | 2361 | 2362 | 2363 | 2364 | 2365 | 2366 | 2367 |
| 940 | 2368 | 2369 | 2370 | 2371 | 2372 | 2373 | 2374 | 2375 | 2376 | 2377 | 2378 | 2379 | 2380 | 2381 | 2382 | 2383 |
| 950 | 2384 | 2385 | 2386 | 2387 | 2388 | 2389 | 2390 | 2391 | 2392 | 2393 | 2394 | 2395 | 2396 | 2397 | 2398 | 2399 |
| 960 | 2400 | 2401 | 2402 | 2403 | 2404 | 2405 | 2406 | 2407 | 2408 | 2409 | 2410 | 2411 | 2412 | 2413 | 2414 | 2415 |
| 970 | 2416 | 2417 | 2418 | 2419 | 2420 | 2421 | 2422 | 2423 | 2424 | 2425 | 242 | 2427 | 2428 | 2429 | 243 | 2431 |
| 980 | 2432 | 2433 | 2434 | 2435 | 2436 | 2437 | 2438 | 2439 | 2440 | 2441 | 2442 | 2443 | 2444 | 2445 | 2446 | 2447 |
| 990 | 2448 | 2449 | 2450 | 2451 | 2452 | 2453 | 2454 | 2455 | 2456 | 2457 | 2458 | 2459 | 2460 | 2461 | 2462 | 2463 |
| 9A0 | 2464 | 2465 | 2466 | 2467 | 2468 | 2469 | 2470 | 2471 | 2472 | 2473 | 2474 | 2475 | 2476 | 2477 | 2478 | 2479 |
| 980 | 2480 | 2481 | 2482 | 2483 | 2484 | 2485 | 2486 | 2487 | 2488 | 2489 | 2490 | 2491 | 2492 | 2493 | 2494 | 2495 |
| 9co | 2496 | 2497 | 2498 | 2499 | 2500 | 2501 | 2502 | 2503 | 2504 | 2505 | 2506 | 2507 | 2508 | 2509 | 2510 | 2511 |
| 9 DO | 2512 | 2513 | 2514 | 2515 | 2516 | 2517 | 2518 | 2519 | 2520 | 2521 | 2522 | 2523 | 2524 | 2525 | 2526 | 2527 |
| 9E0 | 2528 | 2529 | 2530 | 2531 | 2532 | 2533 | 2534 | 2535 | 2536 | 2537 | 2538 | 2539 | 2540 | 2541 | 2542 | 2543 |
| 950 | 2544 | 2545 | 2546 | 2547 | 2548 | 254 | 25 | 25 | 2552 | 2553 | 2554 | 2555 | 2556 | 2557 | 2558 | 2559 |

HEXADECIMAL-DECIMAL INTEGER CONVERSION TABLE (cont.)

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A00 | 2560 | 2561 | 2562 | 2563 | 2564 | 2565 | 256 | 2567 | 256 | 2569 | 2570 | 2571 | 2572 | 2573 | 2574 | 575 |
| A10 | 2576 | 2577 | 2578 | 2579 | 2580 | 2581 | 2582 | 2583 | 258 | 258 | 2586 | 2587 | 258 | 258 | 259 | 2591 |
| A20 | 2592 | 2593 | 2594 | 2595 | 2596 | 2597 | 2598 | 2599 | 2600 | 2601 | 2602 | 2603 | 2604 | 2605 | 2606 | 2607 |
| A30 | 2608 | 2609 | 2610 | 2611 | 2612 | 2613 | 2614 | 2615 | 2616 | 2617 | 2618 | 2619 | 2620 | 2621 | 2622 | 2623 |
| A40 | 2624 | 2625 | 2626 | 2627 | 2628 | 2629 | 2630 | 2631 | 2632 | 2633 | 2634 | 2635 | 2636 | 2637 | 2638 | 2639 |
| A50 | 2640 | 2641 | 2642 | 2643 | 2644 | 2645 | 2646 | 2647 | 2648 | 264 | 2650 | 2651 | 2652 | 265 | 265 | 265 |
| A60 | 2656 | 2657 | 2658 | 2659 | 2660 | 2661 | 2662 | 2663 | 2664 | 2665 | 2666 | 2667 | 2668 | 266 | 267 | 267 |
| A70 | 2672 | 2673 | 2674 | 2675 | 2676 | 2677 | 2678 | 2679 | 2680 | 2681 | 2682 | 2683 | 2684 | 2685 | 2686 | 2687 |
| A80 | 2688 | 2689 | 2690 | 2691 | 2692 | 2693 | 2694 | 2695 | 2696 | 2697 | 2698 | 2699 | 2700 | 2701 | 2702 | 2703 |
| A90 | 2704 | 2705 | 2706 | 2707 | 2708 | 2709 | 2710 | 2711 | 2712 | 2713 | 2714 | 2715 | 2716 | 271 | 2718 | 2719 |
| AAO | 2720 | 2721 | 2722 | 2723 | 2724 | 2725 | 2726 | 2727 | 2728 | 2729 | 2730 | 2731 | 2732 | 273 | 2734 | 2735 |
| ABO | 2736 | 2737 | 2738 | 2739 | 2740 | 2741 | 2742 | 2743 | 2744 | 2745 | 2746 | 2747 | 2748 | 274 | 2750 | 2751 |
| ACO | 2752 | 2753 | 2754 | 2755 | 2756 | 2757 | 2758 | 2759 | 2760 | 276 | 2762 | 2763 | 276 | 276 | 276 | 2767 |
| ADO | 2768 | 2769 | 2770 | 2771 | 2772 | 2773 | 2774 | 2775 | 2776 | 2777 | 2778 | 2779 | 2780 | 278 | 2782 | 2783 |
| AEO | 2784 | 2785 | 2786 | 2787 | 2788 | 2789 | 2790 | 2791 | 2792 | 2793 | 2794 | 2795 | 2796 | 2797 | 2798 | 2799 |
| AFO | 2800 | 2801 | 2802 | 2803 | 2804 | 2805 | 2806 | 2807 | 2808 | 2809 | 2810 | 2811 | 2812 | 2813 | 2814 | 2815 |
| B00 | 281 | 2817 | 2818 | 2819 | 2820 | 2821 | 2822 | 2823 | 2824 | 282 | 2826 | 2827 | 282 | 282 | 283 | 2831 |
| B10 | 2832 | 2833 | 2834 | 2835 | 2836 | 2837 | 2838 | 2839 | 2840 | 2841 | 2842 | 2843 | 284 | 284 | 284 | 2847 |
| B20 | 2848 | 2849 | 2850 | 2851 | 2852 | 2853 | 2854 | 2855 | 2856 | 2857 | 2858 | 2859 | 2860 | 2861 | 2862 | 2863 |
| B30 | 2864 | 2865 | 2866 | 2867 | 2868 | 2869 | 2870 | 2871 | 2872 | 2873 | 2874 | 2875 | 2876 | 2877 | 2878 | 2879 |
| B40 | 2880 | 2881 | 2882 | 2883 | 2884 | 2885 | 2886 | 2887 | 2888 | 2889 | 2890 | 2891 | 2892 | 2893 | 2894 | 2895 |
| B50 | 2896 | 2897 | 2898 | 2899 | 2900 | 2901 | 2902 | 2903 | 2904 | 2905 | 2906 | 2907 | 290 | 290 | 291 | 2911 |
| B60 | 2912 | 2913 | 2914 | 2915 | 2916 | 2917 | 2918 | 2919 | 2920 | 2921 | 2922 | 2923 | 2924 | 2925 | 292 | 2927 |
| B70 | 2928 | 2929 | 2930 | 2931 | 2932 | 2933 | 2934 | 2935 | 2936 | 2937 | 2938 | 293 | 2940 | 294 | 2942 | 2943 |
| B80 | 2944 | 2945 | 2946 | 2947 | 2948 | 2949 | 2950 | 2951 | 2952 | 2953 | 2954 | 2955 | 2956 | 295 | 2958 | 2959 |
| B90 | 2960 | 2961 | 2962 | 2963 | 2964 | 2965 | 2966 | 2967 | 2968 | 296 | 2970 | 2971 | 2972 | 297 | 297 | 2975 |
| BAO | 2976 | 2977 | 2978 | 2979 | 2980 | 2981 | 2982 | 2983 | 2984 | 2985 | 2986 | 2987 | 2988 | 298 | 299 | 2991 |
| BBO | 2992 | 2993 | 2994 | 2995 | 2996 | 2997 | 2998 | 2999 | 3000 | 3001 | 3002 | 3003 | 3004 | 3005 | 3006 | 3007 |
| BCO | 3008 | 3009 | 3010 | 3011 | 3012 | 3013 | 3014 | 3015 | 3016 | 3017 | 3018 | 3019 | 3020 | 3021 | 3022 | 3023 |
| BDO | 3024 | 3025 | 3026 | 3027 | 3028 | 3029 | 3030 | 3031 | 3032 | 3033 | 3034 | 3035 | 3036 | 3037 | 3038 | 3039 |
| BEO | 3040 | 3041 | 3042 | 3043 | 3044 | 3045 | 3046 | 3047 | 3048 | 3049 | 3050 | 3051 | 3052 | 305 | 305 | 3055 |
| BFO | 3056 | 3057 | 3058 | 3059 | 3060 | 3061 | 3062 | 3063 | 3064 | 3065 | 3066 | 3067 | 3068 | 306 | 307 | 3071 |
| C00 | 3072 | 3073 | 3074 | 3075 | 3076 | 3077 | 3078 | 3079 | 3080 | 3081 | 3082 | 3083 | 3084 | 3085 | 3086 | 3087 |
| C10 | 3088 | 3089 | 3090 | 3091 | 3092 | 3093 | 3094 | 3095 | 3096 | 3097 | 3098 | 3099 | 3100 | 3101 | 3102 | 3103 |
| C20 | 3104 | 3105 | 3106 | 3107 | 3108 | 3109 | 3110 | 3111 | 3112 | 3113 | 3114 | 3115 | 3116 | 3117 | 3118 | 3119 |
| C30 | 3120 | 3121 | 3122 | 3123 | 3124 | 3125 | 3126 | 3127 | 3128 | 3129 | 3130 | 3131 | 3132 | 313 | 313 | 3135 |
| C40 | 3136 | 3137 | 3138 | 3139 | 3140 | 3141 | 3142 | 3143 | 3144 | 3145 | 3146 | 3147 | 3148 | 3149 | 3150 | 3151 |
| C50 | 3152 | 3153 | 3154 | 3155 | 3156 | 3157 | 3158 | 3159 | 3160 | 3161 | 3162 | 3163 | 3164 | 3165 | 3166 | 3167 |
| C60 | 3168 | 3169 | 3170 | 3171 | 3172 | 3173 | 3174 | 3175 | 3176 | 3177 | 3178 | 3179 | 3180 | 3181 | 3182 | 3183 |
| C70 | 3184 | 3185 | 3186 | 3187 | 3188 | 3189 | 3190 | 3191 | 3192 | 3193 | 3194 | 3195 | 3196 | 3197 | 3198 | 3199 |
| C80 | 3200 | 3201 | 3202 | 3203 | 3204 | 3205 | 3206 | 3207 | 3208 | 3209 | 3210 | 3211 | 3212 | 3213 | 3214 | 3215 |
| C90 | 3216 | 3217 | 3218 | 3219 | 3220 | 3221 | 3222 | 3223 | 3224 | 3225 | 3226 | 3227 | 3228 | 3229 | 3230 | 3231 |
| CAO | 3232 | 3233 | 3234 | 3235 | 3236 | 3237 | 3238 | 3239 | 3240 | 3241 | 3242 | 3243 | 3244 | 3245 | 3246 | 3247 |
| CBO | 3248 | 3249 | 3250 | 3251 | 3252 | 3253 | 3254 | 3255 | 3256 | 3257 | 3258 | 3259 | 3260 | 3261 | 3262 | 3263 |
| CCO | 3264 | 3265 | 3266 | 3267 | 3268 | 3269 | 3270 | 3271 | 3272 | 3273 | 3274 | 3275 | 3276 | 3277 | 3278 | 3279 |
| CDO | 3280 | 3281 | 3282 | 3283 | 3284 | 3285 | 3286 | 3287 | 3288 | 3289 | 3290 | 3291 | 3292 | 3293 | 3294 | 3295 |
| CEO | 3296 | 3297 | 3298 | 3299 | 3300 | 3301 | 3302 | 3303 | 3304 | 3305 | 3306 | 3307 | 3308 | 330 | 331 | 331 |
| CFO | 3312 | 3313 | 3314 | 3315 | 3316 | 3317 | 3318 | 3319 | 3320 | 3321 | 3322 | 3323 | 3324 | 3325 | 3326 | 332 |

## HEXADECIMAL-DECIMAL INTEGER CONVERSION TABLE (cont.)

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D00 | 3328 | 3329 | 3330 | 3331 | 3332 | 3333 | 3334 | 3335 | 3336 | 3337 | 3338 | 3339 | 3340 | 3341 | 3342 | 3343 |
| D10 | 3344 | 3345 | 3346 | 3347 | 3348 | 3349 | 3350 | 3351 | 3352 | 3353 | 3354 | 3355 | 3356 | 3357 | 3358 | 3359 |
| D20 | 3360 | 3361 | 3362 | 3363 | 3364 | 3365 | 3366 | 3367 | 3368 | 3369 | 3370 | 3371 | 3372 | 3373 | 3374 | 3375 |
| D30 | 3376 | 3377 | 3378 | 3379 | 3380 | 3381 | 3382 | 3383 | 3384 | 3385 | 3386 | 3387 | 3388 | 3389 | 3390 | 3391 |
| D40 | 3392 | 3393 | 3394 | 3395 | 3396 | 3397 | 3398 | 3399 | 3400 | 3401 | 3402 | 3403 | 3404 | 3405 | 3406 | 3407 |
| D50 | 3408 | 3409 | 3410 | 3411 | 3412 | 3413 | 3414 | 3415 | 3416 | 3417 | 3418 | 3419 | 3420 | 3421 | 3422 | 3423 |
| D60 | 3424 | 3425 | 3426 | 3427 | 3428 | 3429 | 3430 | 3431 | 3432 | 3433 | 3434 | 3435 | 3436 | 3437 | 3438 | 3439 |
| D70 | 3440 | 3441 | 3442 | 3443 | 3444 | 3445 | 3446 | 3447 | 3448 | 3449 | 3450 | 3451 | 3452 | 3453 | 3454 | 3455 |
| D80 | 3456 | 3457 | 3458 | 3459 | 3460 | 3461 | 3462 | 3463 | 3464 | 3465 | 3466 | 3467 | 3468 | 3469 | 3470 | 3471 |
| D90 | 3472 | 3473 | 3474 | 3475 | 3476 | 3477 | 3478 | 3479 | 3480 | 3481 | 3482 | 3483 | 3484 | 3485 | 3486 | 3487 |
| DA0 | 3488 | 3489 | 3490 | 3491 | 3492 | 3493 | 3494 | 3495 | 3496 | 3497 | 3498 | 3499 | 3500 | 3501 | 3502 | 3503 |
| DBO | 3504 | 3505 | 3506 | 3507 | 3508 | 3509 | 3510 | 3511 | 3512 | 3513 | 3514 | 3515 | 3516 | 3517 | 3518 | 3519 |
| DC0 | 3520 | 3521 | 3522 | 3523 | 3524 | 3525 | 3526 | 3527 | 3528 | 3529 | 3530 | 3531 | 3532 | 3533 | 3534 | 3535 |
| DD0 | 3536 | 3537 | 3538 | 3539 | 3540 | 3541 | 3542 | 3543 | 3544 | 3545 | 3546 | 3547 | 3548 | 3549 | 3550 | 3551 |
| DE0 | 3552 | 3553 | 3554 | 3555 | 3556 | 3557 | 3558 | 3559 | 3560 | 3561 | 3562 | 3563 | 3564 | 3565 | 3566 | 3567 |
| DF0 | 3568 | 3569 | 3570 | 3571 | 3572 | 3573 | 3574 | 3575 | 3576 | 3577 | 3578 | 3579 | 3580 | 3581 | 3582 | 3583 |
| E00 | 3584 | 3585 | 3586 | 3587 | 3588 | 3589 | 3590 | 3591 | 3592 | 3593 | 3594 | 3595 | 3596 | 3597 | 3598 | 3599 |
| E10 | 3600 | 3601 | 3602 | 3603 | 3604 | 3605 | 3606 | 3607 | 3608 | 3609 | 3610 | 3611 | 3612 | 3613 | 3614 | 3615 |
| E20 | 3616 | 3617 | 3618 | 3619 | 3620 | 3621 | 3622 | 3623 | 3624 | 3625 | 3626 | 3627 | 3628 | 3629 | 3630 | 3631 |
| E30 | 3632 | 3633 | 3634 | 3635 | 3636 | 3637 | 3638 | 3639 | 3640 | 3641 | 3642 | 3643 | 3644 | 3645 | 3646 | 3647 |
| E40 | 3648 | 3649 | 3650 | 3651 | 3652 | 3653 | 3654 | 3655 | 3656 | 3657 | 3658 | 3659 | 3660 | 3661 | 3662 | 3663 |
| E50 | 3664 | 3665 | 3666 | 3667 | 3668 | 3669 | 3670 | 3671 | 3672 | 3673 | 3674 | 3675 | 3676 | 3677 | 3678 | 3679 |
| E60 | 3680 | 3681 | 3682 | 3683 | 3684 | 3685 | 3686 | 3687 | 3688 | 3689 | 3690 | 3691 | 3692 | 3693 | 3694 | 3695 |
| E70 | 3696 | 3697 | 3698 | 3699 | 3700 | 3701 | 3702 | 3703 | 3704 | 3705 | 3706 | 3707 | 3708 | 3709 | 3710 | 3711 |
| E80 | 3712 | 3713 | 3714 | 3715 | 3716 | 3717 | 3718 | 3719 | 3720 | 3721 | 3722 | 3723 | 3724 | 3725 | 3726 | 3727 |
| E90 | 3728 | 3729 | 3730 | 3731 | 3732 | 3733 | 3734 | 3735 | 3736 | 3737 | 3738 | 3739 | 3740 | 3741 | 3742 | 3743 |
| EAO | 3744 | 3745 | 3746 | 3747 | 3748 | 3749 | 3750 | 3751 | 3752 | 3753 | 3754 | 3755 | 3756 | 3757 | 3758 | 3759 |
| EBO | 3760 | 3761 | 3762 | 3763 | 3764 | 3765 | 3766 | 3767 | 3768 | 3769 | 3770 | 3771 | 3772 | 3773 | 3774 | 3775 |
| EC0 | 3776 | 3777 | 3778 | 3779 | 3780 | 3781 | 3782 | 3783 | 3784 | 3785 | 3786 | 3787 | 3788 | 3789 | 3790 | 3791 |
| EDO | 3792 | 3793 | 3794 | 3795 | 3796 | 3797 | 3798 | 3799 | 3800 | 3801 | 3802 | 3803 | 3804 | 3805 | 3806 | 3807 |
| EEO | 3808 | 3809 | 3810 | 3811 | 3812 | 3813 | 3814 | 3815 | 3816 | 3817 | 3818 | 3819 | 3820 | 3821 | 3822 | 3823 |
| EFO | 3824 | 3825 | 3826 | 3827 | 3828 | 3829 | 3830 | 3831 | 3832 | 3833 | 3834 | 3835 | 3836 | 3837 | 3838 | 3839 |
| F00 | 3840 | 3841 | 3842 | 3843 | 3844 | 3845 | 3846 | 3847 | 3848 | 3849 | 3850 | 3851 | 3852 | 3853 | 3854 | 3855 |
| F10 | 3856 | 3857 | 3858 | 3859 | 3860 | 3861 | 3862 | 3863 | 3864 | 3865 | 3866 | 3867 | 3868 | 3869 | 3870 | 3871 |
| F20 | 3872 | 3873 | 3874 | 3875 | 3876 | 3877 | 3878 | 3879 | 3880 | 3881 | 3882 | 3883 | 3884 | 3885 | 3886 | 3887 |
| F30 | 3888 | 3889 | 3890 | 3891 | 3892 | 3893 | 3894 | 3895 | 3896 | 3897 | 3898 | 3899 | 3900 | 3901 | 3902 | 3903 |
| F40 | 3904 | 3905 | 3906 | 3907 | 3908 | 3909 | 3910 | 3911 | 3912 | 3913 | 3914 | 3915 | 3916 | 3917 | 3918 | 3919 |
| F50 | 3920 | 3921 | 3922 | 3923 | 3924 | 3925 | 3926 | 3927 | 3928 | 3929 | 3930 | 3931 | 3932 | 3933 | 3934 | 3935 |
| F60 | 3936 | 3937 | 3938 | 3939 | 3940 | 3941 | 3942 | 3943 | 3944 | 3945 | 3946 | 3947 | 3948 | 3949 | 3950 | 3951 |
| F70 | 3952 | 3953 | 3954 | 3955 | 3956 | 3957 | 3958 | 3959 | 3960 | 3961 | 3962 | 3963 | 3964 | 3965 | 3966 | 3967 |
| F80 | 3968 | 3969 | 3970 | 3971 | 3972 | 3973 | 3974 | 3975 | 3976 | 3977 | 3978 | 3979 | 3980 | 3981 | 3982 | 3983 |
| F90 | 3984 | 3985 | 3986 | 3987 | 3988 | 3989 | 3990 | 3991 | 3992 | 3993 | 3994 | 3995 | 3996 | 3997 | 3998 | 3999 |
| FAO | 4000 | 4001 | 4002 | 4003 | 4004 | 4005 | 4006 | 4007 | 4008 | 4009 | 4010 | 4011 | 4012 | 4013 | 4014 | 4015 |
| FBO | 4016 | 4017 | 4018 | 4019 | 4020 | 4021 | 4022 | 4023 | 4024 | 4025 | 4026 | 4027 | 4028 | 4029 | 4030 | 4031 |
| FC0 | 4032 | 4033 | 4034 | 4035 | 4036 | 4037 | 4038 | 4039 | 4040 | 4041 | 4042 | 4043 | 4044 | 4045 | 4046 | 4047 |
| FDO | 4048 | 4049 | 4050 | 4051 | 4052 | 4053 | 4054 | 4055 | 4056 | 4057 | 4058 | 4059 | 4060 | 4061 | 4062 | 4063 |
| FEO | 4064 | 4065 | 4066 | 4067 | 4068 | 4069 | 4070 | 4071 | 4072 | 4073 | 4074 | 4075 | 4076 | 4077 | 4078 | 4079 |
| FFO | 4080 | 4081 | 4082 | 4083 | 4084 | 4085 | 4086 | 4087 | 4088 | 4089 | 4090 | 4091 | 4092 | 4093 | 4094 | 4095 |


| Hexadecimal | Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| . 00000000 | . 0000000000 | . 40000000 | . 2500000000 | . 80000000 | . 5000000000 | .C0 000000 | . 7500000000 |
| . 01000000 | . 0039062500 | . 41000000 | . 2539062500 | . 81000000 | . 5039062500 | .C1 000000 | . 7539062500 |
| . 02000000 | . 0078125000 | . 42000000 | . 2578125000 | . 82000000 | . 5078125000 | .C2 000000 | . 7578125000 |
| . 03000000 | . 0117187500 | . 43000000 | . 2617187500 | . 83000000 | . 5117187500 | .C3 000000 | . 7617187500 |
| . 04000000 | . 0156250000 | . 44000000 | . 2656250000 | . 84000000 | . 5156250000 | .C4000000 | . 7656250000 |
| . 05000000 | . 0195312500 | . 45000000 | . 2695312500 | . 85000000 | . 5195312500 | .C5 000000 | . 7695312500 |
| . 06000000 | . 0234375000 | . 46000000 | . 2734375000 | . 86000000 | . 5234375000 | .C6 000000 | . 7734375000 |
| . 07000000 | . 0273437500 | . 47000000 | . 2773437500 | . 87000000 | . 5273437500 | .C7 000000 | . 7773437500 |
| . 08000000 | . 0312500000 | . 48000000 | . 2812500000 | . 88000000 | . 5312500000 | .C8 000000 | . 7812500000 |
| . 09000000 | . 0351562500 | . 49000000 | . 2851562500 | . 89000000 | . 5351562500 | .C9 000000 | . 7851562500 |
| . 0 A 000000 | . 0390625000 | .4A 000000 | . 2890625000 | .8A 000000 | . 5390625000 | .CA 000000 | . 7890625000 |
| . OB 000000 | . 0429687500 | .4B 000000 | . 2929687500 | .8B 000000 | . 5429687500 | .CB 000000 | . 7929687500 |
| . $0 C 000000$ | . 0468750000 | .4C 000000 | . 2968750000 | .8C 000000 | . 5468750000 | .CC 000000 | . 7968750000 |
| . 0 D 000000 | . 0507812500 | .4D 000000 | . 3007812500 | .8D 000000 | . 5507812500 | .CD 000000 | . 8007812500 |
| . OE 000000 | . 0546875000 | .4E 000000 | . 3046875000 | .8E 000000 | . 5546875000 | .CE 000000 | . 8046875000 |
| . 0 F 000000 | . 0585937500 | .4F 000000 | . 3085937500 | .8F 000000 | . 5585937500 | .CF 000000 | . 8085937500 |
| . 10000000 | . 0625000000 | . 50000000 | . 3125000000 | . 90000000 | . 5625000000 | .D0 000000 | . 8125000000 |
| . 11000000 | . 0664062500 | . 51000000 | . 3164062500 | . 91000000 | . 5664062500 | .D1 000000 | . 8164062500 |
| . 12000000 | . 0703125000 | . 52000000 | . 3203125000 | . 92000000 | . 5703125000 | .D2 000000 | . 8203125000 |
| . 13000000 | . 0742187500 | . 53000000 | . 3242187500 | . 93000000 | . 5742187500 | .D3 000000 | . 8242187500 |
| . 14000000 | . 0781250000 | . 54000000 | . 3281250000 | . 94000000 | . 5781250000 | .D4 000000 | . 8281250000 |
| . 15000000 | . 0820312500 | . 55000000 | . 3320312500 | . 95000000 | . 5820312500 | .D5 000000 | . 8320312500 |
| . 16000000 | . 0859375000 | . 56000000 | . 3359375000 | . 96000000 | . 5859375000 | .D6 000000 | . 8359375000 |
| . 17000000 | . 0898437500 | . 57000000 | . 3398437500 | . 97000000 | . 5898437500 | .D7 000000 | . 8398437500 |
| . 18000000 | . 0937500000 | . 58000000 | . 3437500000 | . 98000000 | . 5937500000 | .D8 000000 | . 8437500000 |
| . 19000000 | . 0976562500 | . 59000000 | . 3476562500 | . 99000000 | . 5976562500 | .D9 000000 | . 8476562500 |
| .1A 000000 | . 1015625000 | .5A 000000 | . 3515625000 | .9A 000000 | . 6015625000 | .DA 000000 | . 8515625000 |
| . 1 B 000000 | . 1054687500 | .5B 000000 | . 3554687500 | .9B 000000 | . 6054687500 | .DB 000000 | . 8554687500 |
| .1C 000000 | . 1093750000 | .5C 000000 | . 3593750000 | .9C000000 | . 6093750000 | .DC 000000 | . 8593750000 |
| .1D 000000 | . 1132812500 | .5D 000000 | . 3632812500 | .9D 000000 | . 6132812500 | .DD 000000 | . 8632812500 |
| .IE 000000 | . 1171875000 | .5E 000000 | . 3671875000 | .9E 000000 | . 6171875000 | .DE 000000 | . 8671875000 |
| .IF 000000 | . 1210937500 | .5F 000000 | . 3710937500 | .9F 000000 | . 6210937500 | .DF 000000 | . 8710937500 |
| . 20000000 | . 1250000000 | . 60000000 | . 3750000000 | .A0 000000 | . 6250000000 | .EO 000000 | . 8750000000 |
| . 21000000 | . 1289062500 | . 61000000 | . 378962500 | .A1 000000 | . 6289062500 | .E1 000000 | . 8789062500 |
| . 22000000 | . 1328125000 | . 62000000 | . 3828125000 | .A2 000000 | . 6328125000 | .E2 000000 | . 8828125000 |
| . 23000000 | . 1367187500 | . 63000000 | . 3867187500 | .A3 000000 | . 6367187500 | .E3 000000 | . 8867187500 |
| . 24000000 | . 1406250000 | . 64000000 | . 3906250000 | .A4 000000 | . 6406250000 | .E4 000000 | . 8906250000 |
| . 25000000 | . 1445312500 | . 65000000 | . 3945312500 | .A5 000000 | . 6445312500 | .E5 000000 | . 8945312500 |
| . 26000000 | . 1484375000 | . 66000000 | . 3984375000 | .A6 000000 | . 6484375000 | .E6 000000 | . 8984375000 |
| . 27000000 | . 1523437500 | . 67000000 | . 4023437500 | .A7 000000 | . 6523437500 | .E7 000000 | . 9023437500 |
| . 28000000 | . 1562500000 | . 68000000 | . 4062500000 | .A8 000000 | . 6562500000 | .E8 000000 | . 9062500000 |
| . 29000000 | . 1601562500 | . 69000000 | . 4101562500 | .A9 000000 | . 6601562500 | .E9 000000 | . 9101562500 |
| .2A 000000 | . 1640625000 | .6A 000000 | . 4140625000 | .AA 000000 | . 6640625000 | .EA 000000 | . 9140625000 |
| .2B 000000 | . 1679687500 | .6B 000000 | . 4179687500 | . $A B 000000$ | . 6679687500 | .EB 000000 | . 9179687500 |
| .2C 000000 | . 1718750000 | .6C 000000 | . 4218750000 | . AC 000000 | . 6718750000 | .EC 000000 | . 9218750000 |
| .2D 000000 | . 1757812500 | . 6 D 000000 | . 4257812500 | .AD 000000 | . 6757812500 | .ED 000000 | . 9257812500 |
| .2E 000000 | . 1796875000 | . 6 E 000000 | . 4296875000 | .AE 000000 | . 6796875000 | .EE 000000 | . 9296875000 |
| .2F 000000 | . 1835937500 | .6F 000000 | . 4335937500 | .AF 000000 | . 6835937500 | .EF 000000 | . 9335937500 |
| . 30000000 | . 1875000000 | . 70000000 | . 4375000000 | .BO 000000 | . 6875000000 | .FO 000000 | . 9375000000 |
| . 31000000 | . 1914062500 | . 71000000 | . 4414062500 | . 81000000 | . 6914062500 | .FI 000000 | . 9414062500 |
| . 32000000 | . 1953125000 | . 72000000 | . 4453125000 | .B2 000000 | . 6953125000 | .F2 000000 | . 9453125000 |
| . 33000000 | . 1992187500 | . 73000000 | . 4492187500 | . 83000000 | . 6992187500 | .F3 000000 | . 9492187500 |
| . 34000000 | . 2031250000 | . 74000000 | . 4531250000 | . 34000000 | . 7031250000 | .F4 000000 | . 9531250000 |
| . 35000000 | . 2070312500 | . 75000000 | . 4570312500 | .B5 000000 | . 7070312500 | .F5 000000 | . 9570312500 |
| . 36000000 | . 2109375000 | . 76000000 | . 4609375000 | . 86000000 | . 7109375000 | .F6 000000 | . 9609375000 |
| . 37000000 | . 2148437500 | . 77000000 | . 4648437500 | . 87000000 | . 7148437500 | .F7 000000 | . 9648437500 |
| . 38000000 | . 2187500000 | . 78000000 | . 4687500000 | . $\mathrm{B8} 000000$ | . 7187500000 | .F8 000000 | . 9687500000 |
| . 39000000 | . 2226562500 | . 79000000 | . 4726562500 | . 89000000 | . 7226562500 | .F9 000000 | . 9726562500 |
| .3A 000000 | . 2265625000 | .7A 000000 | . 4765625000 | .BA 000000 | . 7265625000 | .FA 000000 | . 9765625000 |
| . 38000000 | . 2304687500 | .7B 000000 | . 4804687500 | .BB 000000 | . 7304687500 | .FB 000000 | . 9804687500 |
| . 3 C 000000 | . 2343750000 | .7C 000000 | . 4843750000 | .BC 000000 | . 7343750000 | .FC 000000 | . 9843750000 |
| .3D 000000 | . 2382812500 | .7D 000000 | . 4882812500 | .BD 000000 | . 7382812500 | .FD 000000 | . 9882812500 |
| . 3 E 000000 | . 2421875000 | .7E 000000 | . 4921875000 | .BE 000000 | . 7421875000 | .FE 000000 | . 9921875000 |
| .3F 000000 | . 2460937500 | .7F 000000 | . 4960937500 | .BF 000000 | . 7460937500 | .FF 000000 | . 9960937500 |


| Hexadecim | Decimal | Hexadecin | Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| . 00000000 | . 0000000000 | . 00400000 | . 0009765625 | . 00800000 | . 0019531250 | . 00 C0 0000 | . 0029296875 |
| . 00010000 | . 0000152587 | . 00410000 | . 0009918212 | . 00810000 | . 0019683837 | . 00 Cl 0000 | . 0029449462 |
| . 00020000 | . 0000305175 | . 00420000 | . 0010070800 | . 00820000 | . 0019836425 | . 00 C2 0000 | . 0029602050 |
| . 00030000 | . 0000457763 | . 00430000 | . 0010223388 | . 00830000 | . 0019989013 | . 00 C3 0000 | . 0029754638 |
| . 00040000 | . 0000610351 | . 00440000 | . 0010375976 | . 00840000 | . 0020141601 | . 00 C4 0000 | . 0029907226 |
| . 00050000 | . 0000762939 | . 00450000 | . 0010528564 | . 00850000 | . 0020294189 | . 00 C5 0000 | . 0030059814 |
| . 00060000 | . 0000915527 | . 00460000 | . 0010681152 | . 00860000 | . 0020446777 | . 00 C6 0000 | . 0030212402 |
| . 00070000 | . 0001068115 | . 00470000 | . 0010833740 | . 00870000 | . 0020599365 | . 00 C7 0000 | . 0030364990 |
| . 00080000 | . 0001220703 | . 00480000 | . 0010986328 | . 00880000 | . 0020751953 | . 00 C8 0000 | . 0030517578 |
| . 00090000 | . 0001373291 | . 00490000 | . 0011138916 | . 00890000 | . 0020904541 | . 00 C9 0000 | . 0030670166 |
| . 00 0a 0000 | . 0001525878 | . 00 4A 0000 | . 0011291503 | . 008 8 0000 | . 0021057128 | . 00 CA 0000 | . 0030822753 |
| . 00 OB 0000 | . 0001678466 | . $004 \mathrm{4B} 0000$ | . 0011444091 | . 008 BB 0000 | . 0021209716 | . 00 CB 0000 | . 0030975341 |
| . 000 C 0000 | . 0001831054 | . 004 C 0000 | . 0011596679 | . 008 CO 000 | . 0021362304 | . 00 CC 0000 | . 0031127929 |
| . 00000000 | . 0001983642 | . 00 4D 0000 | . 0011749267 | . 008 D 0000 | . 0021514892 | . 00 CD 0000 | . 0031280517 |
| . 00 OE 0000 | . 0002136230 | . 00 4E 0000 | . 0011901855 | . $008 \mathrm{8E} 0000$ | . 0021667480 | . 00 CE 0000 | . 0031433105 |
| . 00 OF 0000 | . 0002288818 | . 004 FF 000 | . 0012054443 | . 00880000 | . 0021820068 | . 00 CF 0000 | . 0031585693 |
| . 00100000 | . 0002441406 | . 00500000 | . 0012207031 | . 00900000 | . 0021972656 | . 00 D0 0000 | . 0031738281 |
| . 00110000 | . 0002593994 | . 00510000 | . 0012359619 | . 00910000 | . 0022125244 | . 00 DI 0000 | . 0031890869 |
| . 00120000 | . 0002746582 | . 00520000 | . 0012512207 | . 00920000 | . 0022277832 | . 00 D2 0000 | . 0032043457 |
| . 00130000 | . 0002899169 | . 00530000 | . 0012664794 | . 00930000 | . 0022430419 | . 00 D3 0000 | . 0032196044 |
| . 00140000 | . 0003051757 | . 00540000 | . 0012817382 | . 00940000 | . 0022583007 | . 00 D4 0000 | . 0032348632 |
| . 00150000 | . 0003204345 | . 00550000 | . 0012969970 | . 00950000 | . 0022735595 | . 00 D5 0000 | . 0032501220 |
| . 00160000 | . 0003356933 | . 00560000 | . 0013122558 | . 00960000 | . 0022888183 | . 00 D6 0000 | . 0032653808 |
| . 00170000 | . 0003509521 | . 00570000 | . 0013275146 | . 00970000 | . 0023040771 | . 00 D7 0000 | . 0032806396 |
| . 00180000 | . 0003662109 | . 00580000 | . 0013427734 | . 00980000 | . 0023193359 | . 00 D8 0000 | . 0032958984 |
| . 00190000 | . 0003814697 | . 00590000 | . 0013580322 | . 00990000 | . 0023345947 | . 00 D9 0000 | . 0033111572 |
| . 00 1A 0000 | . 0003967285 | . 00 5A 0000 | . 0013732910 | . 009 Aa 000 | . 0023498535 | . 00 DA 0000 | . 0033264160 |
| . 00 1B 0000 | . 0004119873 | . 00 5B 0000 | . 0013885498 | . 009 B 0000 | . 0023651123 | . 00 DB 0000 | . 0033416748 |
| . 00 IC 0000 | . 0004272460 | . 00 5C 0000 | . 0014038085 | . 0090000 | . 0023803710 | . 00 DC 0000 | . 0033569335 |
| . 00 1D 0000 | . 0004425048 | . 00 5D 0000 | . 0014190673 | . 009 D 0000 | . 0023956298 | . 00 DD 0000 | . 0033721923 |
| . 00 IE 0000 | . 0004577636 | . 00 5E 0000 | . 0014343261 | . 009 E 0000 | . 0024108886 | . 00 DE 0000 | . 0033874511 |
| . 00 1F 0000 | . 0004730224 | . 005 F 0000 | . 0014495849 | . 009 FF 0000 | . 0024261474 | . 00 DF 0000 | . 0034027099 |
| . 00200000 | . 0004882812 | . 00600000 | . 0014648437 | . 00 A0 0000 | . 0024414062 | . 00 EO 0000 | . 0034179687 |
| . 00210000 | . 0005035400 | . 00610000 | . 0014801025 | .00 A1 0000 | . 0024566650 | . 00 El 0000 | . 0034332275 |
| . 00220000 | . 0005187988 | . 00620000 | . 0014953613 | . 00 A2 0000 | . 0024719238 | . 00 E2 0000 | . 0034484863 |
| . 00230000 | . 0005340576 | . 00630000 | . 0015106201 | . 00 A 30000 | . 0224871826 | . 00 E3 0000 | . 0034637451 |
| . 00240000 | . 0005493164 | . 00640000 | . 0015258789 | . 00 A4 0000 | . 0025024414 | . 00 E4 0000 | . 0034790039 |
| . 00250000 | . 0005645751 | . 00650000 | . 0015411376 | .00 A5 0000 | . 0025177001 | . 00 E5 0000 | . 0034942626 |
| . 00260000 | . 0005798339 | . 00660000 | . 0015563964 | . 00 A6 0000 | . 0025329589 | . 00 E6 0000 | . 0035095214 |
| . 00270000 | . 0005950927 | . 00670000 | . 0015716552 | . 00 A7 0000 | . 0025482177 | . 00 E7 0000 | . 0035247802 |
| . 00280000 | . 0006103515 | . 00680000 | . 0015869140 | . 00 A8 0000 | . 0025634765 | . 00 E8 0000 | . 0035400390 |
| . 00290000 | . 0006256103 | . 00690000 | . 0016021728 | .00 A9 0000 | . 0025787353 | .00 E9 0000 | . 0035552978 |
| . 00 2A 0000 | . 0006408691 | . 00 6A 0000 | . 0016174316 | . 00 AA 0000 | . 0025939941 | . 00 EA 0000 | . 0035705566 |
| .00 2800000 | . 00006561279 | . 00 ób u0 OOO | . 000103 20904 | . 00 Ás 0000 | . 002020092529 | . 000 Ez 0000 | . 0035658154 |
| . 002 C 0000 | . 0006713867 | . 00600000 | . 0016479492 | . 00 AC 0000 | . 0026245117 | . 00 EC 0000 | . 0036010742 |
| . 002 D 0000 | . 0006866455 | . 00 6D 0000 | . 0016632080 | . 00 AD 0000 | . 0026397705 | . 00 ED 0000 | . 0036163330 |
| . 00 2E 0000 | . 0007019042 | . 00 6E 0000 | . 0016784667 | . 00 AE 0000 | . 0026550292 | . 00 EE 0000 | . 0036315917 |
| . 00 2F 0000 | . 0007171630 | . 006 FF 0000 | . 0016937255 | . 00 AF 0000 | . 0026702880 | . 00 EF 0000 | . 0036468505 |
| . 00300000 | . 0007324218 | . 00700000 | . 0017089843 | . 00 BO 0000 | . 0026855468 | . 00 FO 0000 | . 0036621093 |
| . 00310000 | . 0007476806 | . 00710000 | . 0017242431 | . 00 Bl 10000 | . 0027008056 | . 00 Fl 0000 | . 0036773681 |
| . 00320000 | . 0007629394 | . 00720000 | . 0017395019 | . 00 B2 0000 | . 0027160644 | . 00 F2 0000 | . 0036926269 |
| . 00330000 | . 0007781982 | . 00730000 | . 0017547607 | . 00 B3 0000 | . 0027313232 | . 00 F3 0000 | . 0037078857 |
| . 00340000 | . 0007934570 | . 00740000 | . 0017700195 | . 00 B4 0000 | . 0027465820 | . 00 F4 0000 | . 0037231445 |
| . 00350000 | . 0008087158 | . 00750000 | . 0017852783 | . 00 B5 0000 | . 0027618408 | . 00 F5 0000 | . 0037384033 |
| . 00360000 | . 0008239746 | . 00760000 | . 0018005371 | . 00 B6 0000 | . 0027770996 | . 00 F6 0000 | . 0037536621 |
| . 00370000 | . 0008392333 | . 00770000 | . 0018157958 | . 00 B7 0000 | . 0027923583 | . 00 F7 0000 | . 0037689208 |
| . 00380000 | . 0008544921 | . 00780000 | . 0018310546 | . 00 B8 0000 | . 0028076171 | . 00 F8 0000 | . 0037841796 |
| . 00300000 | . $000850750 \%$ | . 00790000 | . 0018463134 | . 00 B 90000 | . 0028228759 | . 00 F9 0000 | . 0037994384 |
| . 00 3A 0000 | . 0008850097 | . 00 7A 0000 | . 0018615722 | . 00 BA 0000 | . 0028381347 | . 00 FA 0000 | . 0038146972 |
| . 003 BB 0000 | . 0009002685 | . 007 BB 0000 | . 0018768310 | . 00 BB 0000 | . 0028533935 | . 00 FB 0000 | . 0038299550 |
| . 00 3C 0000 | . 0009155273 | . 007 C 0000 | . 0018920898 | . 00 BC 0000 | . 0028686523 | . 00 FC 0000 | . 0038452148 |
| . 00 3D 0000 | . 0009307861 | . 007 D 0000 | . 0019073486 | . 00 BD 0000 | . 0028839111 | . 00 FD 0000 | . 0038604736 |
| . 003 E 0000 | . 0009460449 | . 00 7E 0000 | . 0019226074 | . 00 BE 0000 | . 0028991699 | . 00 FE 0000 | . 0038757324 |
| . 003 F 0000 | . 0009613037 | . 007 F 0000 | . 0019378662 | . 00 BF 0000 | . 0029144287 | . 00 FF 0000 | . 0038909912 |


| Hexadecimal | Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| . 00000000 | . 0000000000 | .00004000 | . 0000038146 | . 00008000 | . 0000076293 | . 0000 CO 00 | . 0000114440 |
| . 00000100 | . 0000000596 | .00004100 | . 0000038743 | . 00008100 | . 0000076889 | .0000 Cl 00 | . 0000115036 |
| . 00000200 | . 0000001192 | .00004200 | . 0000039339 | .00008200 | . 0000077486 | .0000 C 200 | . 0000115633 |
| . 00000300 | . 0000001788 | .00004300 | . 0000039935 | . 00008300 | . 0000078082 | . 0000 C 300 | .00001 16229 |
| . 00000400 | . 0000002384 | . 00004400 | . 0000040531 | . 00008400 | . 0000078678 | . 0000 C 400 | . 0000116825 |
| . 00000500 | . 0000002980 | .00004500 | . 0000041127 | . 00008500 | . 0000079274 | . 0000 C 500 | . 0000117421 |
| . 00000600 | . 0000003576 | .00004600 | . 0000041723 | .00008600 | . 0000079870 | . 0000 C 600 | . 0000118017 |
| . 00000700 | . 0000004172 | .00004700 | . 0000042319 | . 00008700 | . 0000080466 | .0000 C 700 | . 0000118613 |
| . 00000800 | . 0000004768 | .00004800 | . 0000042915 | .00008800 | . 0000081062 | . 0000 C 800 | . 0000119209 |
| . 00000900 | . 0000005364 | .00004900 | . 0000043511 | .00008900 | . 0000081658 | .0000 C 900 | . 0000119805 |
| . 0000 0A 00 | . 0000005960 | .00004 A 00 | . 0000044107 | . 00008 A 00 | . 0000082254 | . 0000 CA 00 | . 0000120401 |
| . 00000 OB 00 | . 0000006556 | .00004 CO | . 0000044703 | . 00008800 | . 0000082850 | . 0000 CB 00 | . 0000120997 |
| . 0000 OC 00 | . 0000007152 | .00004 C 00 | . 0000045299 | . 00008 C 00 | . 0000083446 | .0000 CC 00 | . 0000121593 |
| . 0000 OD 00 | . 0000007748 | . 0000 4D 00 | . 0000045895 | . 0000 8D 00 | . 0000084042 | . 0000 CD 00 | . 0000122189 |
| . 0000 OE 00 | . 0000008344 | .00004 O 00 | . 0000046491 | . 00008 E 00 | . 0000084638 | . 0000 CE 00 | .00001 22785 |
| . 0000 OF 00 | . 0000008940 | .00004 F 00 | . 0000047087 | $.00008 F 00$ | . 0000085234 | . 0000 CF 00 | . 0000123381 |
| . 00001000 | . 0000009536 | .00005000 | . 0000047683 | .00009000 | . 0000085830 | . 0000 D0 00 | . 0000123977 |
| .00001100 | . 0000010132 | .00005100 | . 0000048279 | .00009100 | . 0000086426 | . 0000 DI 00 | . 0000124573 |
| .00001200 | . 0000010728 | .00005200 | . 0000048875 | .00009200 | . 0000087022 | .0000 D2 00 | . 0000125169 |
| .00001300 | . 0000011324 | .00005300 | . 0000049471 | .00009300 | . 0000087618 | . 0000 D3 00 | . 0000125765 |
| . 00001400 | .0000011920 | .00005400 | . 0000050067 | . 00009400 | . 0000088214 | . 0000 D4 00 | . 0000126361 |
| .00001500 | .0000012516 | .00005500 | . 0000050663 | .00009500 | . 0000088810 | . 0000 D5 00 | . 0000126957 |
| .00001600 | . 0000013113 | .00005600 | . 0000051259 | .00009600 | . 0000089406 | . 0000 D6 00 | . 0000127553 |
| . 00001700 | . 0000013709 | .00005700 | . 0000051856 | . 00009700 | . 0000090003 | . 0000 D7 00 | . 0000128149 |
| . 00001800 | . 0000014305 | .00005800 | . 0000052452 | .00009800 | . 0000090599 | . 0000 D8 00 | . 0000128746 |
| .00001900 | .0000014901 | .00005900 | . 0000053048 | .00009900 | . 0000091195 | . 0000 D9 00 | . 0000129342 |
| . 0000 1A 00 | . 0000015497 | .00005400 | . 0000053644 | .00009 A 00 | . 0000091791 | . 0000 DA 00 | . 0000129938 |
| . 0000 1B 00 | . 0000016093 | .00005 Br 00 | . 0000054240 | .00009800 | . 0000092387 | . 0000 DB 00 | . 0000130534 |
| .00001 C 00 | . 0000016689 | .00005 C 00 | . 0000054836 | .00009000 | . 0000092983 | . 0000 DC 00 | . 0000131130 |
| . 0000 1D 00 | . 0000017285 | . 0000 5D 00 | . 0000055432 | . 00009000 | . 0000093579 | . 0000 DD 00 | . 0000131726 |
| . 0000 1E 00 | .0000017881 | . 00005 O | . 0000056028 | . 00009 OE 00 | . 0000094175 | . 0000 DE 00 | . 0000132322 |
| . 0000 IF 00 | . 0000018477 | . 00005 F 00 | . 0000056624 | . 00009 F 00 | . 0000094771 | . 0000 DF 00 | . 0000132918 |
| . 000020000 | .00000 19973 |  | .00000 57220 |  |  | .UOUOU ÉU UO | .0000133514 |
| . 00002100 | . 0000019669 | . 00006100 | . 0000057816 | . 0000 Al 00 | . 0000095963 | . 0000 El 00 | . 0000134110 |
| . 00002200 | . 0000020265 | .00006200 | . 0000058412 | . 0000 A2 00 | . 0000096559 | . 0000 E2 00 | . 0000134706 |
| . 00002300 | . 0000020861 | .00006300 | . 0000059008 | . 0000 A3 00 | . 0000097155 | . 0000 E3 00 | . 0000135302 |
| . 00002400 | . 0000021457 | .00006400 | . 0000059604 | . 0000 A 400 | . 0000097751 | . 0000 E4 00 | . 0000135898 |
| . 00002500 | . 0000022053 | .00006500 | . 0000060200 | . 0000 A5 00 | . 0000098347 | . 0000 E5 00 | . 0000136494 |
| . 00002600 | . 0000022649 | .00006600 | . 0000060796 | . 0000 A6 00 | . 0000098943 | . 0000 E6 00 | . 0000137090 |
| . 00002700 | . 0000023245 | .00006700 | . 0000061392 | .0000 A7 00 | . 0000099539 | . $0000 \mathrm{E7} 00$ | . 0000137686 |
| . 00002800 | . 0000023841 | .00006800 | . 0000061988 | . $0000 \mathrm{A8} 00$ | . 0000100135 | . $0000 \mathrm{E8} 00$ | . 0000138282 |
| . 00002900 | . 0000024437 | .00006900 | . 0000062584 | . 0000 A 900 | . 0000100731 | . 0000 E9 00 | . 0000138878 |
| . 0000 2A 00 | . 0000025033 | . 0000 6A 00 | . 0000063180 | .0000 AA 00 | . 0000101327 | . 0000 EA 00 | . 0000139474 |
| . 0000 2B 00 | . 0000025629 | .00006 Br 00 | . 0000063776 | .0000 AB 00 | .0000101923 | . 0000 EB 00 | . 0000140070 |
| .00002 C 00 | . 0000026226 | . 00006 C 00 | . 0000064373 | .0000 AC 00 | .0000102519 | . 0000 EC 00 | . 0000140666 |
| . 0000 2D 00 | . 0000026822 | . 0000 6D 00 | . 0000064969 | . 0000 AD 00 | . 0000103116 | . 0000 ED 00 | . 0000141263 |
| . 00002 E 00 | . 0000027418 | . 0000 6E 00 | . 0000065565 | .0000 AE 00 | .0000103712 | . 0000 EE 00 | . 0000141859 |
| . 00002 F 00 | . 0000028014 | . 00006 F 00 | .0000066161 | . 0000 AF 00 | . 0000104308 | . 0000 EF 00 | . 0000142455 |
| .00003000 | . 0000028610 | .00007000 | . 0000066757 | . 0000 BO 00 | .0000104904 | . 0000 FO 00 | . 0000143051 |
| . 00003100 | . 0000029206 | .00007100 | . 0000067353 | . 0000 Bl 00 | . 0000105500 | . 0000 Fl 00 | . 0000143647 |
| . 00003200 | . 0000029802 | .00007200 | . 0000067949 | . 0000 B2 00 | . 0000106096 | . 0000 F2 00 | . 0000144243 |
| . 00003300 | . 0000030398 | .00007300 | . 0000068545 | . $0000 \mathrm{B3} 00$ | . 0000106692 | . 0000 F 300 | . 0000144839 |
| . 00003400 | . 0000030994 | .00007400 | . 0000069141 | . 0000 B4 00 | . 0000107288 | . 0000 F4 00 | . 0000145435 |
| .00003500 | . 0000031590 | .00007500 | . 0000069737 | . $0000 \mathrm{B5} 00$ | . 0000107884 | . 0000 F5 00 | . 0000146031 |
| .00003600 | . 0000032186 | .00007600 | . 0000070333 | . 0000 B6 00 | . 0000108480 | . 0000 F6 00 | . 0000146627 |
| . 00003700 | . 0000032782 | .00007700 | . 0000070929 | . 0000 B7 00 | .0000109076 | .0000 F7 00 | . 0000147223 |
| . 00003800 | . 0000033378 | .00007800 | . 0000071525 | . $0000 \mathrm{B8} 00$ | . 0000109672 | . $0000 \mathrm{F8} 00$ | . 0000147819 |
| . 00003900 | . 0000033974 | .00007900 | . 0000072121 | . 0000 B9 00 | .0000110268 | . 0000 F9 00 | . 0000148415 |
| . 0000 3A 00 | . 0000034570 | . 0000 7A 00 | . 0000072717 | . 0000 BA 00 | . 0000110864 | . 0000 FA 00 | . 0000149011 |
| . 0000 3B 00 | . 0000035166 | .00007 BCO | . 0000073313 | . $0000 \mathrm{BB} \mathrm{\quad 00}$ | . 0000111460 | .0000 FB 00 | . 0000149607 |
| . 0000 3C 00 | . 0000035762 | .00007 C 00 | . 0000073909 | . 0000 BC 00 | . 0000112056 | . 0000 FC 00 | . 0000150203 |
| . 0000 3D 00 | . 0000036358 | . 00007000 | . 0000074505 | . 0000 BD 00 | . 0000112652 | . 0000 FD 00 | . 0000150799 |
| . 0000 3E 00 | . 0000036954 | . 00007 O 00 | . 0000075101 | . 0000 BE 00 | . 0000113248 | . 0000 FE 00 | .0000151395 |
| . 00003 F 00 | . 0000037550 | . 00007 F 00 | . 0000075697 | . 0000 BF 00 | . 0000113844 | . 0000 FF 00 | . 0000151991 |


| Hexadecimal | Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal | Hexadecimal | Decimal |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| . 00000000 | . 0000000000 | . 00000040 | . 0000000149 | . 00000080 | . 0000000298 | . $000000 \mathrm{C0}$ | . 0000000447 |
| . 00000001 | . 0000000002 | . 00000041 | . 0000000151 | . 00000081 | . 0000000300 | . 000000 Cl | . 0000000449 |
| . 00000002 | . 0000000004 | . 00000042 | . 0000000153 | . 00000082 | . 0000000302 | . 000000 C 2 | . 0000000451 |
| . 00000003 | . 0000000006 | . 00000043 | . 0000000155 | . 00000083 | . 0000000305 | . 000000 C 3 | . 0000000454 |
| . 00000004 | . 0000000009 | . 00000044 | . 0000000158 | . 00000084 | . 0000000307 | . 000000 C 4 | . 0000000456 |
| . 00000005 | . 0000000011 | . 00000045 | . 0000000160 | . 00000085 | . 0000000309 | . 000000 C 5 | . 0000000458 |
| . 00000006 | . 0000000013 | . 00000046 | . 0000000162 | . 00000086 | . 0000000311 | . 000000 C 6 | . 0000000461 |
| . 00000007 | . 0000000016 | . 00000047 | . 0000000165 | . 00000087 | . 0000000314 | . $000000 \mathrm{C7}$ | . 0000000463 |
| . 00000008 | . 0000000018 | . 00000048 | . 0000000167 | . 00000088 | . 0000000316 | . $000000 \mathrm{C8}$ | . 0000000465 |
| . 00000009 | . 0000000020 | . 00000049 | . 0000000169 | . 00000089 | . 0000000318 | . 000000 C 9 | . 0000000467 |
| . 0000000 A | . 0000000023 | . 000000 4A | . 0000000172 | . 0000008 A | . 0000000321 | . 000000 CA | . 0000000470 |
| . 000000 OB | . 0000000025 | . 0000004 B | . 0000000174 | . 0000008 BB | . 0000000323 | . 000000 CB | . 0000000472 |
| . 00000000 | . 0000000027 | . 0000004 C | . 0000000176 | . 0000008 C | . 0000000325 | . 000000 CC | . 0000000474 |
| . 000000 OD | . 0000000030 | . 000000 4D | . 0000000179 | . 0000008 D | . 0000000328 | . 000000 CD | . 0000000477 |
| . 000000 OE | . 0000000032 | . 0000004 E | . 0000000181 | . 0000008 EE | . 0000000330 | . 000000 CE | . 0000000479 |
| . 000000 OF | . 0000000034 | . 0000004 F | . 0000000183 | . 0000008 F | . 0000000332 | . 000000 CF | . 0000000481 |
| . 00000010 | . 0000000037 | . 00000050 | . 0000000186 | . 00000090 | . 0000000335 | . 000000 DO | . 0000000484 |
| . 00000011 | . 0000000039 | . 00000051 | . 0000000188 | . 00000091 | . 0000000337 | . 000000 DI | . 0000000486 |
| .00000012 | . 0000000041 | . 00000052 | . 0000000190 | . 00000092 | . 0000000339 | . 000000 D 2 | . 0000000488 |
| . 00000013 | . 0000000044 | . 00000053 | . 0000000193 | . 00000093 | . 0000000342 | . 000000 D 3 | . 0000000491 |
| . 00000014 | . 0000000046 | . 00000054 | . 0000000195 | . 00000094 | . 0000000344 | . 000000 D 4 | . 0000000493 |
| . 00000015 | . 0000000048 | . 00000055 | . 0000000197 | . 00000095 | . 0000000346 | . 000000 D5 | . 0000000495 |
| .00000016 | . 0000000051 | . 00000056 | . 0000000200 | . 00000096 | . 0000000349 | . $000000 \mathrm{D6}$ | . 0000000498 |
| . 00000017 | . 0000000053 | . 00000057 | . 0000000202 | . 00000097 | . 0000000351 | . $000000 \mathrm{D7}$ | . 0000000500 |
| . 00000018 | . 0000000055 | . 00000058 | . 0000000204 | . 00000098 | . 0000000353 | . 000000 D 8 | . 0000000502 |
| . 00000019 | . 0000000058 | . 00000059 | . 0000000207 | . 00000099 | . 0000000356 | . $000000 \mathrm{D9}$ | . 0000000505 |
| . 000000 la | . 0000000060 | . 000000 5A | . 0000000209 | . 0000009 A | . 0000000358 | . 000000 DA | . 0000000507 |
| . 000000 1B | . 0000000062 | . 000000 5B | . 0000000211 | . 00000098 | . 0000000360 | . 000000 DB | . 0000000509 |
| . 000000 IC | . 0000000065 | . 0000005 C | . 0000000214 | . 0000009 | . 0000000363 | . 000000 DC | . 0000000512 |
| . 00000010 | . 0000000067 | . 000000 5D | . 0000000216 | . 0000009 D | . 0000000365 | . 000000 DD | . 0000000514 |
| . 000000 1E | . 0000000069 | . 0000005 E | . 0000000218 | . 0000009 E | . 0000000367 | . 000000 DE | . 0000000516 |
| . 000000 lF | . 0000000072 | . 0000005 F | . 0000000221 | . 0000009 F | . 0000000370 | . 000000 DF | . 0000000519 |
| . 00000020 | . 0000000074 | . 00000060 | . 0000000223 | . 000000 AO | . 0000000372 | . 000000 EO | . $000000052!$ |
| . 00000021 | . 0000000076 | . 00000061 | . 0000000225 | . 000000 Al | . 0000000374 | . 000000 El | . 0000000523 |
| . 00000022 | . 0000000079 | . 00000062 | . 0000000228 | . 000000 A 2 | . 0000000377 | . 000000 E 2 | . 0000000526 |
| . 00000023 | . 0000000081 | . 00000063 | . 0000000230 | . 000000 A 3 | . 0000000379 | . $000000 \mathrm{E3}$ | . 0000000528 |
| . 00000024 | . 0000000083 | . 00000064 | . 0000000232 | . 000000 A 4 | . 0000000381 | . $000000 \mathrm{E4}$ | . 0000000530 |
| . 00000025 | . 0000000086 | . 00000065 | . 0000000235 | . 000000 A5 | . 0000000384 | . 000000 ES | . 0000000533 |
| . 00000026 | . 0000000088 | . 00000066 | . 0000000237 | . 000000 A 6 | . 0000000386 | . 000000 ES | . 0000000535 |
| . 00000027 | . 0000000090 | . 00000067 | . 0000000239 | . 000000 A 7 | . 0000000388 | . $000000 \mathrm{E7}$ | . 0000000537 |
| . 00000028 | . 0000000093 | . 00000068 | . 0000000242 | . $000000 \mathrm{A8}$ | . 0000000391 | . $000000 \mathrm{E8}$ | . 0000000540 |
| . 00000029 | . 0000000095 | . 00000069 | . 0000000244 | . $000000 \mathrm{A9}$ | . 0000000393 | . 000000 Eq | . 0000000542 |
| . 00000024. | .00000 00097 | . 00000064 | . 0000000246 | . 000000 ALA | .0000000395 | . 0000000 EA | . 0000000544 |
| . 0000002 L | . 0000000100 | . 000000 6B | . 0000000249 | . 000000 AB | . 0000000398 | . 000000 EB | . 0000000547 |
| . 0000002 C | . 0000000102 | . 0000006 C | . 0000000251 | . 000000 AC | . 0000000400 | . 000000 EC | . 0000000549 |
| . 0000002 D | . 0000000104 | . 000000 6D | . 0000000253 | . 000000 AD | . 0000000402 | . 000000 ED | . 0000000551 |
| . 0000002 E | . 0000000107 | . 000000 6E | . 0000000256 | . 000000 AE | . 0000000405 | . 000000 EE | . 0000000554 |
| . 0000002 F | . 0000000109 | . 0000006 F | . 0000000258 | . 000000 AF | . 0000000407 | . 000000 EF | . 0000000556 |
| . 00000030 | . 0000000111 | . 00000070 | . 0000000260 | . 000000 BO | . 0000000409 | . 000000 FO | . 0000000558 |
| . 00000031 | . 0000000114 | . 00000071 | . 0000000263 | . 000000 Bl | . 0000000412 | . 000000 Fl | . 0000000561 |
| . 00000032 | . 0000000116 | . 00000072 | . 0000000265 | . $000000 \mathrm{B2}$ | . 0000000414 | . 000000 F 2 | . 0000000563 |
| . 00000033 | . 0000000118 | . 00000073 | . 0000000267 | . $000000 \mathrm{B3}$ | . 0000000416 | . $000000 \mathrm{F3}$ | . 0000000565 |
| . 00000034 | . 0000000121 | . 00000074 | . 0000000270 | . $000000 \mathrm{B4}$ | . 0000000419 | . $000000 \mathrm{F4}$ | . 0000000568 |
| . 00000035 | . 0000000123 | . 00000075 | . 0000000272 | . $000000 \mathrm{B5}$ | . 0000000421 | . $000000 \mathrm{F5}$ | . 0000000570 |
| . 00000036 | . 0000000125 | . 00000076 | . 0000000274 | . $000000 \mathrm{B6}$ | . 0000000423 | . 000000 Fb | . 0000000572 |
| . 00000037 | . 0000000128 | . 00000077 | . 0000000277 | . $000000 \mathrm{B7}$ | . 0000000426 | . $000000 \mathrm{F7}$ | . 0000000575 |
| . 00000038 | . 0000000130 | . 00000078 | . 0000000279 | . $000000 \mathrm{B8}$ | . 0000000428 | . $000000 \mathrm{F8}$ | . 0000000577 |
| . 00000039 | . 0000000132 | . 00000079 | . 0000000281 | . $000000 \mathrm{B9}$ | . 0000000430 | . $000000 \mathrm{F9}$ | . 0000000579 |
| . 000000 3A | . 0000000135 | . 000000 7A | . 0000000284 | . 000000 BA | . 0000000433 | . 000000 FA | . 0000000582 |
| . 000000 3B | . 0000000137 | . 0000007 B | . 0000000286 | . 000000 BB | . 0000000435 | . 000000 FB | . 0000000584 |
| . 00000036 | . 0000000139 | . 0000007 C | . 0000000288 | . 000000 BC | . 0000000437 | . 000000 FC | . 0000000586 |
| . 000000 3D | . 0000000142 | . 0000007 D | . 0000000291 | . 000000 BD | . 0000000440 | . 000000 FD | . 0000000589 |
| . 000000 3E | . 0000000144 | . 0000007 F | . 0000000293 | . 000000 BE | . 0000000442 | . 000000 FE | . 0000000591 |
| . 000000 3F | . 0000000146 | . 0000007 F | . 0000000295 | . 000000 BF | . 0000000444 | . 000000 FF | . 0000000593 |

            \(2^{n} n 2^{-n}\)
                    \(0 \quad 1.0\)
                        10.5
                            \(\begin{array}{ll}2 & 0.25\end{array}\)
                                    \(\begin{array}{lll}8 & 3 & 0.125\end{array}\)
                                    \begin{tabular}{lll}
    16 \& 4 \& 0.062 <br>
\hline
\end{tabular}

                    \(32 \quad 5 \quad 0.031 \quad 25\)
                    \(\begin{array}{lll}64 & 6 & 0.015 \\ 625\end{array}\)
                \(128 \quad 7 \quad 0.0078125\)
                \(256 \quad 8 \quad 0.003906 \quad 25\)
                    \(512 \quad 9 \quad 0.001953125\)
                    \(1024 \quad 10 \quad 0.0009765625\)
                    \(2048 \quad 110.00048828125\)
                    \(\begin{array}{lllllll}4 & 096 & 12 & 0.000 & 244 & 140 & 625\end{array}\)
                    8192130.0001220703125
                    \(\begin{array}{llllllll}16 & 384 & 14 & 0.000 & 061 & 035 & 156 & 25\end{array}\)
                    \(\begin{array}{lllllllll}32 & 768 & 15 & 0.000 & 030 & 517 & 578 & 125\end{array}\)
                    \(65 \quad 536 \quad 16 \quad 0.000015 \quad 2587890625\)
                \(\begin{array}{lllllllll}131 & 072 & 17 & 0.000 & 007 & 629 & 394 & 531 & 25\end{array}\)
                    \(\begin{array}{llllllll}262 & 144 & 18 & 0.000 & 003 & 814 & 697 & 265 \\ 525\end{array}\)
                \(\begin{array}{lllllllllll}524 & 288 & 19 & 0.000 & 001 & 907 & 348 & 632 & 812 & 5\end{array}\)
    

| Term | Meaning | Term | Meaning |
| :---: | :---: | :---: | :---: |
| () $n$ | Contents of. <br> AND (logical product, where $0 \cap 0=0$, $0 \cap 1=0,1 \cdot \cap 0=0$, and $1 \cap 1=1$ ). | EDL <br> (cont.) | forced to 0 . Hence, odd-numbered word address (referring to middle of doubleword) designates same doubleword as even-numbered word address when used for a doubleword operation. |
| $u$ | OR (logical inclusive $O R$, where $0 \cup 0=0$, $0 \cup 1=1,1 \cup 0=1$, and $1 \cup 1=1$ ). | EDO | Effective decimal operand. |
| (1) | EOR (logical exclusive $O R$, where 0 (1) $0=0,0$ (ㄴ) $1=1,1$ (L) $0=1$, and $1($ (1) $1=0)$. | EH | Effective halfword - 16-bit contents of effective halfword location, or (EHL). |
| AM | Fixed-point arithmetic trap mask-bit position 11 of PSWs. If set $(=1)$, basic processor traps to location $X^{\prime} 43$ ' after executing an | EHL | Effectivehalfword location-halfword location pointed to by effective virtual address of an instruction for halfword operation. |
|  | instruction causing fixed-point overflow; if not set, basic processor does not trap. | EI | External interrupt group inhibit - bit position 39 of PSWs. If set $(=1)$, all interrupt levels within this group are |
| CC | Condition code - 4-bit value (bit positions labeled CC1, CC2, CC3, and CC4), established as part of the execution of most instructions. | ESA | inhibited. <br> Effective source address - in byte-string instructions, address of the source byte string. |
| Cl | Counter interrupt group inhibit - bit position 37 of PSWs. If set (=1), all interrupt levels within this group are inhibited. | EVA | Effective virtual address - virtual address value obtained as result of indirect addressing and/or indexing. This address value is |
| DA | Destination address-in byte-string instructions, address of the destination byte string. |  | independent of the program's actual location in main memory, and is final address value before memory mapping is performed. |
| DBS | Destination byte string-operand specified by byte-string instruction. | EW | Effective word - 32-bit contents of effective word location (EWL). |
| DECA DM | Decimal accumulator - general registers 12, 13,14 , and 15 in decimal instructions. | EWL | Effective word location - word location pointed to by effective virtual address of |
| DM | Decimal arithmetic trap mask-bit position 10 of PS'W's. When set $(=1)$, decimal arithmeric fault trap is in effect. | FN | an instruction for a word operation. <br> Floating normalize mode control-bit posi- |
| EB | Effective byte-8-bit contents of effective byte location (EBL). | FN | tion 7 of PSWs. If not set, results of floatingpoint additions and subtractions are to be normalized; if set ( $=1$ ), results are not normalized. |
| EBL | Effective byte location - byte location pointed to by effective virtual address of an instruction for byte operation. | FR | Floating round mode control-bit position 4 of PSWs. If set (=1), basic processor rounds floating-point results. If not set, results |
| ED | Effective doubleword - 64-bit contents of effective doubleword location (EDL). |  | are truncated. |
| EDL | Effective doubleword İocation-doubleword location pointed to by effective virtual address of an instruction for a doubleword operation. If odd-numbered word location is specified, low-order bit of effective address field (bit position 31) is automatically | FS | Floating significance mode control-bit position 5 of PSWs. If set $(=1)$, basic processor traps to location X'44' when more than two hexadecimal places of postnormalization shifting are required for a floating-point addition or subtraction; if not set, no significance checking is performed. |

\begin{tabular}{|c|c|c|c|}
\hline Term \& Meaning \& Term \& Meaning \\
\hline FZ \& Floating zero mode control-bit position 6 of the PSWs. If set \((=1)\), basic processor traps to location X'44' when either characteristic underflow or zero result occurs for a floating-point multiplication or division; if not set, characteristic underflow and zero result are treated as normal conditions. \& Ref. Add. (cont.) \& general register in current register block (by using a value in range \(0-15\) ) or any word in main memory in address range 16 through 131,071 . This address value is initial address value for any subsequent address computations, memory mapping, or both computation and mapping. \\
\hline I \& Instruction register-internal basic processor register that holds instructions obtained from memory while they are being decoded. \& RP \& Register pointer - bit positions 58 and 59 of PSWs; these bits select one of four possible register blocks. \\
\hline IA
II \& \begin{tabular}{l}
Instruction address-17-bit value that defines virtual address of instruction immediately prior to the time that it is executed. \\
I/O interrupt group inhibit - bit position 38 of the PSWs. If set \((=1)\), all interrupt levels within this group are inhibited.
\end{tabular} \& Rul \& Odd register address value - register Rul is general register pointed to by value obtained by logically ORing 0001 into address for register \(R\). Thus, if \(R\) field of instruction contains even value, \(R u l=R+1\) and if \(R\) field contains odd value, Rul \(=R\). \\
\hline L \& Numeric value of bits 8-11 of decimal instruction word (value of 0 is 16 bytes). \& SA \& Source address - in byte-string instructions, contents of specified \(R\) register. \\
\hline MA \& Mode altered - bit position 61 of PSWs. \& SBS \& Source byte string-operand specified by byte string instruction. \\
\hline MM \& \begin{tabular}{l}
This bit is set \((=1)\) during master-protected mode of operation and during real extended type of addressing. \\
Memory map mode control-position 9 of PSWs. When set \((=1)\), the memory map is in effect.
\end{tabular} \& SE \& Sign extension - some instructions operate on two operands of different lengths; they are made equal in length by extending sign of shorter operand by required number of bit positions. For positive operands, result of sign extension is high-order 0's prefixed io the operand; for negarive op- \\
\hline MS \& Master/slave mode control-bit position 8 of PSWs. When set \((=1)\), basic processor is in slave mode; when not set, basic processor may be in master or master-protected mode as determined by bit 40. \& \& erands, high-order l's are prefixed to operand. Sign extension process is performed after operand accessed from memory and before operation called for by instruction code is performed. \\
\hline PSWs \& Program status words - collection of separate registers and flip-flops treated as an internal basic processor register to store and display critical control information. \& SPD \& Stack pointer doubleword - contains the context (TSA, space count, word count, and TS, TW inhibit bits) of the push-down instructions. \\
\hline R \& General register address value-4-bit contents of bit positions 8-11 (R field) of instruction word, also expressed symbolically as (I) 8 -11. In instruction descriptions, register \(R\) is general register (of current register block) that corresponds to \(R\) field address value. \& TCC

TS \& | Trap condition code - 4-bit value (bit positions labeled TCC1, TCC2, TCC3, and TCC4), established as part of trap operations. |
| :--- |
| Trap-on-space inhibit bit - conditions pushdown stack limit trap for impending overflow or underflow of space count. | <br>

\hline RA \& Register altered - bit position 60 of PSWs. When trap occurs, this bit set $(=1)$ when general register or memory location altered in execution of instruction causing the trap. \& TSA \& Top-of-stack address - pointer that points to highest-numbered address of operand stack in push-down instructions. <br>

\hline | Ref. |
| :--- |
| Add. | \& Reference address - contents of bit positions 15-31 of instruction word, a 17-bit field capable of directly addressing any \& TW \& Trap-on-word inhibit bit-conditions pushdown stack limit trap for impending overflow or underflow of word count. <br>

\hline
\end{tabular}

| Term | Meaning | Term | Meaning |
| :--- | :--- | :--- | :--- |
| WK | Write key - bit positions 32, 33, 34, <br> and 35 of PSWs; they are evaluated by <br> the memory write-protect feature to de- <br> termine accessibility of real memory by <br> current program. | $X$ <br> (cont.) | if $X \neq 0$, indexing is performed (after indirect <br> addressing if indirect addressing is called for) <br> with general register $X$ in current registerblock. |
| $X$ | Index register address value - 3-bit con- <br> tents of bit positions 12-14 (X field) of <br> instruction word. In instruction word, <br> if $X=0$, no indexing is performed; | $X ' n '$ | Hexadecimal qualifier - hexadecimal value <br> ( $n$ ) is unsigned string of hexadecimal digits <br> (0 through 9 and $A$ through $F$ ) surrounded by <br> single quotation marks and preceded by the <br> qualifier " $X$ " (for example, 7BO 16 is written <br> $X ' 7 B O '$. |

## APPENDIX C. FAULT STATUS REGISTERS

Table C-1. Fault Status Registers

| Bit Position | Status Registers - Faults Detected By: |  |  |  |  | System Control <br> Processor |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Basic Processor | MIOP | RMP | MI | PI |  |
| 016 | PFI | PFI | PFI | PFI | PFI | PFI |
| 117 | General register parity error | Bus Check Fault (BCF) | BCF | Map or access protect register parity error | Cluster bus parity error | Parity error on processor bus |
| 218 | Control register parity error | Control Check Fault (CCF) | CCF | Cluster bus parity error | Processor bus parity error | Operation code error |
| 319 | Internal basic processor bus parity error | Control Memory Fault (CMF) | CMF | Reserved | Unrecognized operation code | Reserved |
| $4 \quad 20$ | Clusterbus parity error | CMF I/O adapter | ECE | Reserved | Reserved | Reserved |
| $5 \quad 21$ | Processor-Detected Fault flag (PDF) | MIE | MIE | Cluster bus sequence check fault | Reserved | Reserved |
| 622 | Memory parity error | Data/order indicator ${ }^{\dagger}$ | Order type ${ }^{\dagger}$ | Reserved | Reserved | Reserved |
| 723 | Memory Interface Error (MIE) | Out indicator ${ }^{\dagger}$ | Order type ${ }^{\dagger}$ | Reserved | Multiple error | Reserved |
| 824 | Processor interface sequence check fault | Control Memory Fault (CMF) address bit 0 | Reserved | Reserved | Control Memory Fault (CMF) address bit 0 | Reserved |
| 925 | Extended arithmetic sequcnee check füht | CMF ứáress Dii i | Reserved | Reserved | CMF address bit 1 | Reserved |
| $10 \quad 26$ | Basic processor sequence check fault | CMF address bit 2 | Reserved | Reserved | CMF address bit 2 | Reserved |
| $11 \quad 27$ | Successful instruction retry | CMF address bit 3 | Reserved | Reserved | CMF address bit 3 | Reserved |
| $12 \quad 28$ | Control memory parity error (BPE module) | CMF address bit 4 | Reserved | Reserved | CMF address bit 4 | Reserved |
| $13 \quad 29$ | Control memory parity error (BPF module) | CMF address bit 5 | Reserved | Res erved | CMF address bit 5 | Reserved |
| $14 \quad 30$ | Control memory parity error (BPG module) | CMF address bit 6 | Res erved | Reserved | CMF address bit 6 | Reserved |
| $15 \quad 31$ | Control memory parity error (BPH module) | CMF address bit 7 | Reserved | Reserved | CMF address bit 7 | Reserved |
| ${ }^{\dagger}$ This is a 2-bit code indicating type of service call, as follows: |  |  |  |  |  |  |
| $6$ | its <br> 7 | MIOP <br> Significance |  | RMP <br> Significance |  |  |
| 0 | 0 | Data In |  | Sense |  |  |
| 0 | 1 | Data Out |  | Write |  |  |
| 1 | 0 | Order In |  | Read |  |  |
| 1 | 1 | Order Out |  | Control |  |  |

Table C-2. Memory Unit Status Register

| Bit Position | Faults Detected by Memory Unit: |
| :--- | :--- |
| $0-21$ | Fault address snapshot |
| 22 | Reserved |
| 23 | Memory unit parity error |
| 24 | Storage module selection error |
| 25 | Address In parity error |
| 26 | Data In parity error |
| 27 | Write-lock memory storage parity error |
| 28 | Port selection error |
| 29 | Operation mode undefined |
| 30 | Control sequence check fault error |
| 31 | Multiple error |

## Publication Revision Sheet

JANUARY, 1974

CORRECTIONS TO XEROX 560 COMPUTER REFERENCE MANUAL
PUBLICATION NO. 9030 76A, JANUARY, 1974

Page 9 should be replaced with the page attached to this revision sheet. Page 10 is a backup page with no change. The revision bar in the margin of the page indicates that it is corrected information.

## Reader Comment Form



Fold


Attn: Programming Publications
rst Class
EIS
El Segundo

BUSINESS REPLY MAIL

Postage will be paid by
Xerox Corporation
701 South Aviation Boulevard
El Segundo, California 90245

XEROX
701 South Aviation Boulevard El Segundo, California 90245
213 679-4511


[^0]:    ${ }^{\dagger}$ The aggregate of processor clusters is restricted by the maximum memory port limitation of 6 .

[^1]:    ${ }^{\dagger}$ Except for the READ DIRECT (RD)/WRITE DIRECT (WD) instructions which can read from and store into these locations.

[^2]:    ${ }^{\dagger}$ CC1 remains unchanged for instructions LCW, LAW, LCD, and LAD.
    ${ }^{\text {tt }}$ A hyphen indicates that the condition code bits are not af-
    fected by the condition given under the "Meaning" heading.

[^3]:    ${ }^{\dagger} \mathrm{CCl}$ remains unchanged for instructions LCW, LAW, LCD, and LAD.
    ${ }^{\mathrm{Ht}} \mathrm{A}$ hyphen indicates that the condition code bits are not affected by the condition given under the "Meaning" heading.

[^4]:    ${ }^{\dagger}$ This instruction requires two memory references to the same location for its execution. To preclude other processors from accessing the effective location during this time, the memory unit containing the effective location is reserved (not accessible to other processors) until the instruction is completed.

[^5]:    ${ }^{\dagger}$ This instruction requires two memory references to the same location for its execution. To preclude other processors from accessing the effective location during this time, the memory unit containing the effective location is reserved (not accessible to other processors) until the instruction is completed.

[^6]:    ${ }^{\dagger}$ Not applicable for searching shift.

[^7]:    ${ }^{\dagger}$ Except EDIT BYTE STRING (EBS), which has no limit on the size of numbers.

[^8]:    ${ }^{\dagger}$ For real extended mode of addressing this is a $20-$ bit field (12-31); for real and virtual addressing modes it is a 17-bit field (15-31).

[^9]:    ${ }^{\dagger}$ For real extended mode of addressing this is a $20-$ bit field (12-31); for real and virtual addressing modes it is a 17-bit field (15-31).

[^10]:    ${ }^{\dagger}$ Primarily of diagnostic concern.

[^11]:    ${ }^{\dagger}$ When indexing operation code 4 F instructions ( HIO ; RIO, POLP, POLR), the programmer must make certain that the summation of the contents of the index register and the $1 / O$ address (bits 18-31 of the instruction word) does not affect bits 15-17. When indirect addressing is used, the contents of the indirect address location (bits 15,16 , and 17 ) must specify the desired operation code extension.

[^12]:    ${ }^{\dagger}$ See footnote to HIO instruction.
    ${ }^{\text {tt }}$ This fault status is duplicated in bits 0 to 15 of register $R$.

[^13]:    ${ }^{\dagger}$ Hexadecimal digits.
    ${ }^{\dagger \dagger}$ SCC FUNCTIONS switch of SCP must be in the ENABLE position.
    ${ }^{\text {ttt }}$ System must be in the IDLE state.

[^14]:    ${ }^{\dagger}$ All clock controls are inhibited unless the MAINT MODE switch is in the ON position.
    ${ }^{\text {tt }}$ These commands are accepted only if the system is in the MAINT MODE.

