701 South Aviation Boulevard El Segundo, California 90245 213 679-4511

XEROX

# **Xerox SIGMA 9 Computer**

# **Reference Manual**

90 17 33C

June 1972

Price: \$7.00

## REVISION

The major change made in this revision to the Xerox SIGMA 9 Computer/Reference Manual, Publication Number 90 17 33 B (October 1971), is the inclusion of the previously published Revision Package, 90 17 33B-1(4/72). Technical changes from that of the previous manual are indicated by a vertical line in the margin of the page.

## **RELATED PUBLICATIONS**

| <u>Title</u>                                 | Publication No. |
|----------------------------------------------|-----------------|
| Xerox Sigma Glossary of Computer Terminology | 90 09 57        |
| Xerox Meta-Symbol/LN, OPS Reference Manual   | 90 09 52        |
| Xerox Symbol/LN, OPS Reference Manual        | 90 17 90        |

Manual Content Code: BP - batch processing, LN - language, OPS - operations, RBP - remote batch processing, RT - real-time, SM - system management, TS - time-sharing, UT - utilities.

## CONTENTS

1

9

3. INSTRUCTION REPERTOIRE

## 1. SIGMA 9 COMPUTER SYSTEM

| Introduction                    | 1 |
|---------------------------------|---|
| General Characteristics         | 1 |
| Standard and Optional Features  | 3 |
| General–Purpose Features        | 4 |
| Time-Sharing Features           | 5 |
| Real-Time Features              | 6 |
| Multiusage Features             | 7 |
| Multiprocessing Features        | 7 |
| Multiprocessor Interlock        | 7 |
| Homespace                       | 7 |
| Multiport Memory System         | 7 |
| Manual Partitioning Capability  | 8 |
| Multiprocessor Control Function | 8 |
| Shared Input/Output             | 8 |
|                                 |   |

#### 2. SIGMA 9 SYSTEM ORGANIZATION

| Central Processing Unit              |    |
|--------------------------------------|----|
| General Registers                    | 9  |
| Memory Control Storage               | 9  |
| Computer Modes                       | 12 |
| Information Format                   | 12 |
| Information Boundaries               |    |
| Instruction Register                 | 13 |
| Main Memory                          | 14 |
| Memory Unit                          | 14 |
| Virtual and Real Memory              | 15 |
| Homespace                            | 15 |
| Memory Reference Address             | 15 |
| Types of Addressing                  |    |
| Address Modification Examples        | 21 |
| Memory Address Control               |    |
| Program Status Doubleword            | 27 |
| Interrupt System                     |    |
| Internal Interrupts                  |    |
| External Interrupts                  | 31 |
| States of an Interrupt Level         | 31 |
| Control of the Interrupt System      | 33 |
| Time of Interrupt Occurrences        | 33 |
| Single-Instruction Interrupts        |    |
| Trap System                          |    |
| Trap                                 | 34 |
| Trap Entry Sequence                  |    |
| Trap Masks                           | 34 |
| Trap Condition Code                  | 34 |
| Trap Addressing                      | 34 |
| Nonallowed Operation Trap            | 36 |
| Unimplemented Instruction Trap       |    |
| Push-Down Stack Limit Trap           | 38 |
| Fixed-Point Overflow Trap            |    |
| Floating-Point Arithmetic Fault Trap |    |
| Decimal Arithmetic Fault Trap        | 40 |
| Call Instruction Trap                | 40 |
| Processor Detected Faults            | 40 |
| Trap Conditions During "Anticipate"  |    |
| Operations                           | 43 |
| Register Altered Bit                 |    |
|                                      |    |

|    | Load/Store Instructions                    | 47    |
|----|--------------------------------------------|-------|
|    | Analyze/Interpret Instructions             |       |
|    | Fixed-Point Arithmetic Instructions        | 57    |
|    | Comparison Instructions                    |       |
|    | Logical Instructions                       |       |
|    | Shift Instructions                         |       |
|    | Floating-Point Shift                       |       |
|    | Conversion Instructions                    |       |
|    | Floating-Point Arithmetic Instructions     |       |
|    | Floating-Point Numbers                     |       |
|    | Floating-Point Add and Subtract            | 73    |
|    | Floating-Point Multiply and Divide         |       |
|    | Condition Codes for Floating-Point         | - / 1 |
|    | Instructions                               | 74    |
|    | Decimal Instructions                       |       |
|    | Packed Decimal Numbers                     |       |
|    | Zoned Decimal Numbers                      |       |
|    | Decimal Accumulator                        |       |
|    | Decimal Instruction Format                 | 77    |
|    | Illegal Digit and Sign Detection           |       |
|    | Overflow Detection                         |       |
|    | Decimal Instruction Nomenclature           | . 78  |
|    | Condition Code Settings                    |       |
|    | Byte-String Instructions                   |       |
|    | Push-Down Instructions                     |       |
|    | Stack Pointer Doubleword (SPD)             |       |
|    | Push-Down Condition Code Settings          |       |
|    | Execute/Branch Instructions                |       |
|    | Branches in Real Extended Addressing Mode_ |       |
|    | Nonallowed Operation Trap During           |       |
|    | Execution of Branch Instruction            | - 97  |
|    | CALL Instructions                          |       |
|    | Control Instructions                       |       |
|    | Program Status Doubleword                  | . 101 |
|    | Loading the Memory Map                     |       |
|    | Loading the Access Protection Controls     |       |
|    | Loading the Memory Write Protection Locks_ | _ 106 |
|    | Interruption of MMC                        | - 106 |
|    | Memory Access Traps by MMC Instruction     | _ 107 |
|    | Read Direct, Internal Computer Control     |       |
|    | (Mode 0)                                   | - 111 |
|    | Read Direct, Interrupt Control (Mode 1)    |       |
|    | Write Direct, Internal Computer Control    |       |
|    | (Mode 0)                                   | - 112 |
|    | Write Direct, Interrupt Control (Mode 1)   |       |
|    | Input/Output Instructions                  |       |
|    | Overall Characteristics                    | _ 114 |
|    | I/O Status Information                     | - 118 |
|    |                                            |       |
|    |                                            | 100   |
| 4. | INPUT/OUTPUT OPERATIONS                    | 129   |

| Operational Command Doublewords | 130 |
|---------------------------------|-----|
| Order                           | 130 |
| Memory Byte Address             | 130 |
| Flags                           |     |
| Byte Count                      | 132 |
| Control Command Doublewords     | 132 |

45

#### 5. OPERATOR CONTROLS

| 134 |
|-----|
|-----|

| Processor Control Panel              | 134 |
|--------------------------------------|-----|
| Control Mode                         |     |
| POWER                                |     |
| MEMORY CLEAR                         | 135 |
| SYS RESET                            | 135 |
| I/O RESET                            | 135 |
| LOAD                                 |     |
| UNIT ADDRESS                         | 135 |
| SENSE                                | 135 |
| NOT NORMAL                           | 135 |
| HALT                                 | 135 |
| WAIT                                 | 136 |
| RUN                                  |     |
| Program Status Doubleword Indicators | 136 |
| INSERT                               | 137 |
| CPU RESET                            | 137 |
| INTERRUPT                            | 137 |
| ADDRESS STOP                         | 137 |
| SELECT ADDRESS                       | 138 |
| STORE                                | 138 |
| INSTR ADDR                           |     |
| DISPLAY (Indicators)                 |     |
| DISPLAY FORMAT                       |     |
| FORMAT SEL                           | 139 |
| DATA                                 | 139 |
| DISPLAY (Switch)                     | 139 |
| COMPUTE                              |     |
| Maintenance Controls                 | 140 |
| ALARM                                | 140 |
| PDF                                  |     |
| CLOCK MARGINS                        |     |
| PHASES                               | 140 |
| CLOCK MODE                           | 141 |
| SNAP                                 |     |
| MEMORY MODE                          | 141 |
| OVERRIDE MODE                        | 141 |
| SCAN                                 |     |
| EXT DIO                              |     |
| Operating Procedures                 | 143 |
| Loading Operation                    | 143 |
| Fetching and Storing Data            | 144 |
| -                                    |     |

INDEX

183

145

### **APPENDIXES**

### A. REFERENCE TABLES

| Standard Symbols and Codes                  | 145 |
|---------------------------------------------|-----|
| Standard Character Sets                     | 145 |
| Control Codes                               | 145 |
| Special Code Properties                     | 145 |
| Standard 8-Bit Computer Codes (EBCDIC)      | 146 |
| Standard 7-Bit Communication Codes (ANSCII) | 146 |
| Standard Symbol-Code Correspondences        | 147 |

|    | Hexadecimal Arithmetic                                                                                                              | _151  |
|----|-------------------------------------------------------------------------------------------------------------------------------------|-------|
|    | Addition Table                                                                                                                      |       |
|    | Multiplication Table                                                                                                                | _151  |
|    | Table of Powers of Sixteen, a                                                                                                       | _152  |
|    | Table of Powers of Ten <sub>16</sub>                                                                                                | _152  |
|    | Table of Powers of Sixteen <sub>10</sub><br>Table of Powers of Ten <sub>16</sub><br>Hexadecimal-Decimal Integer Conversion<br>Table | 153   |
|    | Hexadecimal-Decimal Fraction Conversion                                                                                             | _155  |
|    | Table                                                                                                                               | 159   |
|    | Table of Powers of Two                                                                                                              |       |
|    | Mathematical Constants                                                                                                              |       |
|    |                                                                                                                                     | _ 100 |
| Β. | SIGMA 9 INSTRUCTION LIST                                                                                                            | 164   |
| c. | INSTRUCTION TIMING                                                                                                                  | 165   |
|    | Timing Considerations                                                                                                               | _165  |
|    | Effects of Memory Interference                                                                                                      |       |
|    | Effects of Indexing                                                                                                                 | _165  |
|    | Effects of Indirect Addressing                                                                                                      | - 165 |
|    | Effects of Register-to-Register Operations                                                                                          | _ 166 |
|    | Other SIGMA 9 Performance Factors                                                                                                   | _ 166 |
| D. | SYSTEM RELIABILITY AND MAINTAINABILITY                                                                                              | 175   |
|    | System Maintainability Features                                                                                                     | _ 175 |
|    | CPU Features                                                                                                                        |       |
|    | Main Memory Features                                                                                                                | 178   |
|    | Multiplexor Input/Output Processor (MIOP)<br>Features                                                                               |       |
|    | High-Speed RAD I/O Processor (HSRIOP)<br>Features                                                                                   |       |
| Ε. | GLOSSARY OF SYMBOLIC TERMS                                                                                                          | 180   |

### **FIGURES**

|     | Frontispiece - SIGMA 9 Computer System                                      |
|-----|-----------------------------------------------------------------------------|
| 1.  | A Typical SIGMA 9 System                                                    |
| 2.  | Central Processing Unit                                                     |
| 3.  | Information Boundaries                                                      |
| 4.  | Addressing Logic                                                            |
| 5.  | Index Displacement Alignment (Real and<br>Virtual Addressing Mode)          |
| 6.  | Index Displacement Alignment (Real Extended<br>Addressing)                  |
| 7.  | Generation of Actual Memory Addresses, Virtual<br>Addressing (SIGMA 9 Mode) |
| 8.  | Generation of Effective Virtual Address, Real<br>Extended Addressing        |
| 9.  | Typical Interrupt Priority Chain                                            |
| 10. | Operational States of an Interrupt Level                                    |
| 11. | Formats of I/O Instructions                                                 |
| 12. | Processor Control Panel                                                     |

### TABLES

| 1.  | Homespace Layout                                                | 16  |
|-----|-----------------------------------------------------------------|-----|
| 2.  | Computer Operating and Addressing Modes                         | 29  |
| 3.  | SIGMA 9 Interrupt Locations                                     | 29  |
| 4.  | Summary of SIGMA 9 Trap Locations                               | 35  |
| 5.  | TCC Setting for Instruction Exception<br>Trap X'4D'             | 42  |
| 6.  | Registers Changed at Time of a Trap Due to<br>an Operand Access | 43  |
| 7.  | ANALYZE Table for SIGMA 9 Operation Codes                       | 56  |
| 8.  | Floating-Point Number Representation                            | 73  |
| 9.  | Condition Code Settings for Floating–Point<br>Instructions      | 75  |
| 10. | Status Word 0                                                   | 109 |

| 11. | Status Word 1                                                      | _ 109 |
|-----|--------------------------------------------------------------------|-------|
| 12. | Status Word 2                                                      | _ 110 |
| 13. | Description of I/O Instructions                                    | _ 115 |
| 14. | I/O Status Information (Register R)                                | - 118 |
| 15. | Device Status Byte (Register R or Ru1)<br>(SIO, TIO, and HIO Only) | _ 118 |
| 16. | Operational Status Byte (Register Ru1)                             | _ 120 |
| 17. | Status Response Bits for I/O Instructions                          | _ 121 |
| 18. | Processor Fault Status                                             | _ 122 |
| 19. | IOP Status Byte                                                    | - 122 |
| 20. | Status Response Bits for AIO Instruction                           | _ 123 |
| 21. | I/O Address (AIO Response)                                         | 123   |
| 22. | Program Status Doubleword (PSD) Indicators                         | _ 136 |
| C-1 | Basic Instruction Timing                                           | 167   |

v



SIGMA 9 Computer System

## 1. SIGMA 9 COMPUTER SYSTEM

#### INTRODUCTION

SIGMA 9 is a high-speed, general-purpose, digital, computer system. It is designed for a variety of scientific, business data processing, and time-sharing applications. A basic system includes a central processing unit (CPU), a main memory subsystem, and an independent input/output subsystem. Each major system element performs asynchronously with respect to other elements.

The basic system can be readily expanded to accommodate the user's requirements. Main memory has addressing space for four million words. Memory access paths can be increased from the basic two ports to a maximum of 12 ports. Input/output capability can be increased by adding more input/output processors (IOPs), device controllers, and I/O devices.

The CPU has a large instruction set that includes floatingpoint and decimal instructions. A special feature called "look-ahead" enables the CPU to overlap instruction execution with memory accessing, thereby reducing program execution time. A large main memory of up to 524,288 (512K) words is available. The memory may consist of up to 16 modular units of 32,768 (32K) words each; a unit consists of two banks of 16,384 (16K) words each. The number of ports in each memory unit can be expanded to allow independent access to memory by up to 12 processors - either CPUs or IOPs. Each bank operates asynchronously, and address interleaving can be provided between adjacent banks. This multibank, multiaccess memory subsystem with interleaving achieves system performance far in excess of single memory bank designs. The SIGMA 9 system can include up to 11 independent I/O processors (limited only by port expansion capability) of two types – multiplexor I/Oprocessors and high-speed RAD I/O processors - which can transfer data at rates up to three million bytes per second, concurrent with CPU instruction execution.

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

SIGMA system reliability, maintainability, and availability have been significantly improved. A partitioning feature, for example, permits faulty units or an entire subsystem, consisting of a CPU, memory unit, IOP, and attached peripherals to be isolated for diagnosis and repair while the primary system continues operation.

#### **GENERAL CHARACTERISTICS**

A SIGMA 9 computer system has features and operating characteristics that permit efficient functioning in general-purpose, multiprocessing, time-sharing, real-time, and multiusage environments:

- Word-oriented memory (32-bit word plus parity bit) which can be addressed and altered as byte (8-bit), halfword (2-byte), word (4-byte), and doubleword (8-byte) quantities.
- Memory expandable from 65,536 (64K) to 524,288 (512K) words in blocks of 16,384 (16K), 32,768 (32K), and 65,536 (64K) words. Expansion proceeds in 16K blocks from 64K to 128K, in 32K blocks from 128K to 256K, and in 64K blocks from 256K to 512K (where K = 1024 words).
- Direct addressing capability (real extended mode) of entire memory.
- 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.
- 16 general-purpose registers, expandable to 64 (in blocks of 16) for addressing, indexing, and accumulating. Multiple registers permit effective use of small, high-speed memories.
- Hardware memory mapping, which virtually eliminates memory fragmentation and provides dynamic program relocation.
- Four modes of memory access protection for system and information security and protection.
- Memory write protection to prevent inadvertent destruction of critical areas of memory.
- Watchdog timer to assure nonstop operation.
- Real-time priority interrupt system with automatic identification and priority assignment, fast response time, and up to 236 levels that can be individually armed, enabled, and triggered by program control.
- Instructions with long execution times can be interrupted to guarantee response to interrupts.
- 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 multiusage environments.
- Complete 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.
  - 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 OR).
  - 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.
  - 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/BCD 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 floatingpoint modes.

- Built-in reliability and maintainability features (see Appendix D) 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 busses 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.

- Programmable "snapshot" registers that enable diagnostic routines to compare contents of a snapshot register with known correct information, thus accurately determining system fault conditions.
- CPU traps, which provide for detection of a variety of CPU and system fault conditions, designed to enable a high degree of system recoverability.
- Partitioning features that enable system reconfiguration. SIGMA 9 units can be partitioned from the system by selectively disabling them from busses. Thus, faulty units or an entire subsystem, consisting of a CPU, memory unit, input/output processor (IOP), and attached peripherals, can be isolated from the operational system to enable diagnosis and repair of a faulty unit while the primary system continues operation.
- Independently operating I/O system with the following features:
  - Direct input/output (READ DIRECT, WRITE DIRECT) 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 eleven I/O processors (restricted only by memory port limitations).
  - Multiplexor I/O processors (MIOP) with dual channel capability, providing for simultaneous

operation of up to 24 devices on one channel, and concurrently, simultaneous operation of eight devices on the other channel.

- High-speed Rapid Access Data I/O processor (HSRIOP) for use with high-speed RAD storage units, allowing data transfer rates of up to three million bytes per second.
- Both data and command chaining, for gatherread and scatter-write operations.
- Comprehensive array of modular software that is upward program compatible with SIGMA 5-8 computers:
  - Expands in capability and speed as system grows.
  - Operating systems: Batch Processing Monitor (BPM), Batch Time-Sharing Monitor (BTM), Universal Time-Sharing System (UTS), and Xerox Operating System (XOS).
  - Language processors that include: Extended FORTRAN IV-H, Extended FORTRAN IV, ANS COBOL, BASIC, FLAG, Symbol, Meta-Symbol; also, utilities and applications software for both commercial and scientific users, e.g., Data Management System (DMS), Generalized Sort and Merge, Manage, 1401 Simulator, Functional Mathematical Programming System (FMPS), FMPS Matrix Generator/Report Writer (GAMMA3), Simulation Language (SL-1), General Purpose Discrete Simulation package (GPDS), Circuit Analysis Systems (CIRC-AC, CIRC-DC), etc.
- Standard and special-purpose peripheral equipment including:
  - Rapid Access Data (RAD) files: Capacities to 6.2 million bytes per unit; transfer rates of three million bytes per second; average access times from 17 milliseconds.
  - Magnetic tape units: 7-track and 9-track systems, IBM-compatible; high-speed units operating at 150 inches per second with transfer rates up to 120,000 bytes per second; and other units operating at 75 inches per second with transfer rates up to 60,000 bytes per second and at 37.5 inches per second with transfer rates up to 20,800 bytes per second.
  - Displays: Graphic display has standard character generator, vector generator, and closeups, as well as light pen, and alphanumeric/ function keyboard.
  - Card equipment: Reading speeds up to 1500 cards per minute; punching speeds up to 300 cards per minute; intermixed binary and EBCDIC card codes.

- Line printers: Fully buffered with speeds up to 1500 lines per minute; 132 print positions with 64 characters.
- Keyboard/printers: 10 characters per second; also available with paper tape reader (20 characters per second) and punch (10 characters per second).
- Paper tape equipment; Readers with speeds up to 300 characters per second; punches with speeds up to 120 characters per second.
- Graph plotters: Digital incremental, providing drift-free plotting in two axes in up to 300 steps per second at speeds from 30 millimeters to 3 inches per second.
- Data communications equipment: Complete line of character-oriented and messageoriented equipment to connect remote user terminals (including remote batch) to the computer system via common carrier lines and local terminals directly.

#### **STANDARD AND OPTIONAL FEATURES**

A basic SIGMA 9 system has the following standard features:

- A CPU that includes:
  - Decimal arithmetic unit
  - Floating-point arithmetic unit
  - Memory map with access protection
  - Memory write protection
  - Two register blocks
  - Two real-time clocks
  - Power fail-safe
  - External interface (Direct I/O)
  - Interrupt control chassis
  - Eight external interrupt levels
- 65,536 (64K) words of main memory with two ports
- Multiplexor Input/Output Processor (MIOP) with eight subchannels (Channel A)
- Motor generator set

A SIGMA 9 system may have the following optional features:

- Up to ten additional memory ports
- Two additional real-time clocks
- Two additional register blocks
- Up to 224 external priority interrupts
- Up to ten high-speed RAD input/output processors (HSRIOPs)<sup>†</sup>
- Up to ten additional MIOPs<sup>†</sup>
- Up to three additional CPUs<sup>t</sup>
- Up to two additional groups of eight multiplexor subchannels with each MIOP
- MIOP (Channel B) additional eight subchannels (per MIOP)
- Four-byte interface
- Memory-to-memory move
- Alternate control busses for CPU, MIOP, and HSRIOP

#### **GENERAL-PURPOSE FEATURES**

General-purpose computing applications are characterized by emphasis on computation and internal data handling 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. The SIGMA 9 computer system includes the following general-purpose features.

<u>Floating-Point Hardware</u>. Floating-point instructions are available in both short (32-bit) and long (64-bit) formats. Under program control, the user may select optional zero checking, normalization, and significance checking (which causes a trap when a post-operation shift of more than two hexadecimal places occurs in the fraction of a floatingpoint number). Significance checking permits use of the short floating-point format for high processing speed and storage economy and of the long format when loss of significance is detected. <u>Decimal Arithmetic Hardware.</u> Decimal arithmetic instructions operate on up to 31 digits plus sign. This instruction set includes pack/unpack instructions for converting to/ 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 to data size is not required; instead, incrementing is always by units in a continuous array table regardless of the size of data element used.

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

<u>Translate Instruction</u>. 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.

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

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

Interpret Instruction. The Interpret instruction simplifies and speeds interpretive operations such as compilation,

<sup>&</sup>lt;sup>t</sup>The aggregate of MIOPs, HSRIOPs, and CPUs is restricted by the maximum memory port limitation of 12.

thus reducing space and time requirements for compilers and other interpretive systems.

Four-Bit Condition Code. This simplifies the checking of results by automatically providing information on almost every instruction execution, including indicators for over-flow, underflow, zero, minus, and plus, as appropriate, without requiring an extra instruction execution.

<u>Multiplexor Input/Output Processor (MIOP).</u> Once initialized, I/O processors operate independently of the CPU, leaving it free to provide faster response to system needs. The MIOP requires minimal interaction with the CPU by using I/O command doublewords, which permit both command chaining and data chaining without intervening CPU control. I/O equipment speeds range from slow rates involving human interaction (teletypewriter, for example) to transfer rates of rotating memory devices of up to one million bytes per second. Many devices can be operated simultaneously.

High-Speed RAD Input/Output Processor (HSRIOP). The HSRIOP is similar to the MIOP in regard to interaction with the CPU. Once initiated, I/O operations proceed independently of the CPU. This I/O processor sustains data transfer rates of up to three million bytes per second. Up to four Model 7212 high-speed RAD units may be connected to an HSRIOP, with one unit operating at a time.

Direct Input/Output (DIO). DIO facilitates in-line program control of asynchronous or special-purpose devices This feature permits information to be transmitted directly to or from general-purpose registers so that an I/O channel need not be used for relatively infrequent transmissions.

#### **TIME-SHARING 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 on-line in an interactive, "conversational" mode with the computer while other users may be entering work to be processed that requires only final output.

The SIGMA 9 computer system provides the time-sharing features described below.

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 doubleword (PSD), which contains the entire description of the current user's environment and mode of operation, can be stored anywhere in memory and a new PSD loaded, all with a single instruction.

<u>Multiple Register Blocks</u>. The optional availability of up to four blocks of 16 general-purpose registers improves response time by reducing the need to store and load register blocks. A distinct block can be assigned for different functions as needed; the program status doubleword automatically selects the applicable register block.

<u>User Protection.</u> 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 system 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. SIGMA 9 memory is available in sizes from 64K (65,536) words to 512K (524,288) words to provide the capacity needed while assuring the potential for expansion. 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, contiguous 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 way at 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 for SIGMA 9 can operate in a compatible SIGMA 6 or 7 mode in addition to providing the ability to locate any 128K-word (131,072) virtual program in the SIGMA 9's logical addressing space of four million words. Thus, the system can always address a virtual memory of 128K 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.

#### **REAL-TIME FEATURES**

Real-time applications are characterized by a need for (1) hardware that provides quick response to an external environment, (2) speed great enough to keep up with the real-time process itself, and (3) sufficient input/output flexibility to handle a wide variety of data types at varying speeds. The SIGMA 9 system includes provisions for the following real-time computing features.

<u>Multilevel, Priority Interrupt System.</u> The real-timeoriented SIGMA 9 system provides quick response to interrupts by means of up to 224 external interrupt levels. The source of 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 real-time process is in progress. In establishing a configuration for the system, each group of up to 16 interrupt levels can have its priority assigned in different ways to meet the specific needs of a problem; the way interrupt levels are programmed is not affected by the priority assignment.

Programs that deal with interrupts from specially designed equipment often require checkout before the equipment is actually available. To permit simulating this special equipment, any external SIGMA 9 interrupt level can be "triggered" by the CPU 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 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 computer may be excessively delayed if the specific device does not respond quickly. A built-in watchdog timer assures that the SIGMA 9 computer cannot be delayed for an excessive length of time.

<u>Real-Time Clocks.</u> 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. SIGMA 9 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. In the SIGMA 9 system, each one of up to 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, memoryprotection key, etc.) is kept in a 64-bit program status doubleword (PSD). A single instruction stores the current PSD anywhere in memory and loads a new one from memory to establish a new environment, which includes information identifying a new block of general-purpose registers. A SIGMA 9 system can thus preserve and change its operating environment completely through the execution of a single instruction.

<u>Memory Protection</u>. Both foreground (real-time) and background programs can be run concurrently in a SIGMA 9 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, SIGMA 9 provides halfword arithmetic operations in addition to fullword operations. Doubleword arithmetic operations (for extended precision) are also included.

Direct Data Input/Output. For handling asynchronous I/O, a 32-bit word can be transferred directly to or from a

general-purpose register so that an I/O channel need not be occupied with relatively infrequent and nonperiodic transmissions.

#### **MULTIUSAGE FEATURES**

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

<u>Priority Interrupt.</u> In a multiusage environment, many elements operate simultaneously 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 savings in improved 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 available at any instant for useful work.

<u>Memory Protection</u>. The memory protection features that protect each user from every other user also guarantee the integrity of programs essential to critical real-time applications.

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

Instruction Set. The large SIGMA 9 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 decreased, and the speed of obtaining results is increased.

#### **MULTIPROCESSING FEATURES**

SIGMA 9 is designed to function as a shared-memory multiprocessor system. It can contain up to four central processing units and up to 11 input/output processors (the sum of both types of processors is restricted by the maximum memory port limitation of 12). All processors in a SIGMA 9 system address memory uniformly.

This section describes the major features of SIGMA 9 that allow expansion from a monoprocessor to a multiprocessor system.

#### **MULTIPROCESSOR INTERLOCK**

In a multiprocessor system, the central processing units (CPUs) 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. SIGMA 9 has a special instruction to provide this required multiprocessor interlock. The 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.

#### HOMESPACE

Since all processors in a multiprocessor system address memory in a uniform manner, it is necessary to retain a private memory that is unique to each processor for its trap and interrupt locations, I/O communication locations, and other dedicated locations. This private memory is called Homespace and consists of 1,024 words for each CPU. Each Homespace region begins with real address zero. The implicitly assigned trap locations, interrupt locations, and IOP communication locations, plus the 16 locations that are reserved for the registers, occupy the first 320 locations of Homespace. The remaining words in the Homespace region can be used as private, independent storage by the CPU.

#### **MULTIPORT MEMORY SYSTEM**

SIGMA 9 has growth capability of up to 12 ports per memory unit. A basic memory unit consists of two banks of 16K words each, in which each bank can be concurrently operating when addressed by two of the possible 12 ports.

This system architecture allows flexibility in growth patterns and provides large amounts of memory bandwidth, essential to multiprocessor systems.

#### MANUAL PARTITIONING CAPABILITY

SIGMA 9 has manual partitioning capability for all system units. Thus, besides its primary advantage of increased throughput capability, a secondary advantage of a multiprocessor system is its fail-soft ability. Any SIGMA 9 unit can be partitioned by selectively disabling it from the system busses. Faulty units are thus isolated from the operational system. Reenabling the connection allows repaired units to be returned to service.

#### **MULTIPROCESSOR CONTROL FUNCTION**

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

1. Control of the External Direct Input/Output bus (External DIO), used for controlling system maintenance and special purpose units such as A/D converters.

- 2. Central control of system partitioning.
- 3. Interprocessor interrupt connection, allowing one processor to directly signal another processor that an action is to be taken.

#### SHARED INPUT/OUTPUT

Provisions have been made in a SIGMA 9 multiprocessor system for any CPU to direct I/O actions to any I/O processor. That is, any CPU can issue an SIO, TIO, TDV, or HIO instruction to begin, stop, or test any I/O process. However, the end-action sequence of the I/O process is directed to one of the possible four CPUs. This feature (accomplished by setting a pair of configuration control switches) allows dedicating I/O endaction tasks to a single processor and avoids conflict resolution problems.

## 2. SIGMA 9 SYSTEM ORGANIZATION

The primary elements of a typical SIGMA 9 computer system, as illustrated in Figure 1, are central processor units, memory units, and input/output processors. These elements permit the total computer system to be viewed as a group of program-controlled subsystems communicating with a common memory. Each subsystem operates asynchronously and semi-independently, automatically overlapping the operation of the other subsystems for greater speed (when circumstances permit). A CPU subsystem primarily performs overall control and data reduction tasks while each IOP (MIOP or HSRIOP) subsystem performs the tasks associated with the exchange of digital information between the main memory and selected peripheral devices. A basic system may be expanded by increasing the number of memory units (up to 16), increasing the number of IOPs (up to 11, including MIOPs and HSRIOPs), or by increasing the number of central processors (up to 4).

#### **CENTRAL PROCESSING UNIT**

This section describes the organization and operation of the SIGMA 9 central processing unit in terms of instruction and data formats, information processing, and program control. Basically, a SIGMA 9 CPU consists of two or more fast memories and an arithmetic and control unit as illustrated in Figure 2.

#### **GENERAL REGISTERS**

An integrated-circuit memory, consisting of sixteen 32-bit general-purpose registers, is used within the SIGMA 9 CPU. These 16 registers of fast memory are referred to as a register block. A SIGMA 9 system may contain up to 4 register blocks. A 4-bit control field (called the register block pointer) in the Program Status Doubleword (PSD) selects the block currently available to a program. The 16 general registers selected by the register block pointer are referred to as the current register block. The register block pointer can be changed when the computer is in the master or master-protected mode.

Each general register in the current register block is identified by a 4-bit code in the range 0000 through 1111 (0 through 15 in decimal, or X'0' through X'F' in hexadecimal notation). Any general register may be used as a fixed-point accumulator, floating-point accumulator, temporary data storage location, or to contain control information such as a data address, count, pointer, etc. General registers 1 through 7 may be used as index registers, and registers 12 through 15 may 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 CPU has three high-speed integrated-circuit memories for storage of a memory map, memory access protection codes associated with the memory map, and memory writeprotection codes. The contents of these memories can only be changed when the computer is in the master or masterprotected mode.

Memory Map. Two terms are essential to a proper understanding of the memory mapping concept: virtual address and actual address.

<u>A virtual address</u> is a value pertaining to the logical space used by a machine-level program, and which designates the location of an instruction, the location of an element of data, or the location of a data address (indirect address). 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. Thus, virtual addresses include all instruction addresses, data addresses, indirect addresses, and addresses used as counts within a stored program, as well as those addresses computed by the program.

<u>An actual address</u> is the address a processor sends to the memory unit (memory address register) to access a specific memory location for storage or retrieval of information. Thus, actual addresses are fixed and dependent on the wired-in hardware. (See "Main Memory" for further details.)

The memory map feature provides for dynamic program relocation into discontinuous segments of memory. When the memory map is in effect, any program may be segmented into an integral number of 512-word pages and distributed throughout memory in whatever pages of space are available. Thus the memory map transforms virtual addresses, as seen by the individual program, into actual addresses, as seen by the memory system.

When the memory map is not in effect, as determined by the memory map control bit in the program status doubleword, all virtual address values above 15 are used by the memory as actual addresses. Virtual addresses in the range 0 through 15 are always used by the CPU as general register addresses rather than as memory addresses. Thus, for example, if an instruction uses a virtual address of 5 as the address where a result is to be stored, the result is stored in general register 5 in the current register block instead of in memory location 5.

When the computer is operating with memory map, virtual addresses in the range 0 through 15 are still used as general register addresses. However, all virtual addresses above 15 are transformed into actual addresses, by replacing the highorder eight bits of the virtual address with a value obtained from the memory map. (The memory map replacement process is described in the section "Memory Address Control".)



Figure 1. A Typical SIGMA 9 System



Figure 2. Central Processing Unit

<u>Memory Access Protection</u>. When the computer is operating in the slave or master-protected mode with the memory map, the access-protection codes determine whether or not the program may access instructions from, read from, or write into specific pages of the virtual address continuum (virtual memory). If the slave or master-protected mode program attempts to access a page of virtual memory that is so protected, a trap occurs. (The access-protection codes are described in the section "Memory Address Control".)

Memory Write Protection. The memory write-protection feature operates independently of the memory map and access protection. The memory write-protection feature includes the necessary integrated-circuit memory to provide 256 2-bit memory write locks. These locks operate in conjunction with a 2-bit field, called the write key, in the program status doubleword. The locks and the key determine whether any program may alter any word located within the first 128K words (256 pages) of main memory. The write key can be changed when the computer is in the master or masterprotected mode. (The functions of the locks and key are described in the section "Memory Address Control".)

#### **COMPUTER MODES**

A SIGMA 9 computer operates in either master, slave, or master-protected mode. The mode of operation is determined by three control bits in the program status doubleword. (See "Program Status Doubleword".)

#### MASTER MODE

In this mode, the CPU can perform all of its control functions and can modify any part of the system. The only restrictions placed upon the CPU's operation in this mode is that imposed by the write locks on protected pages of memory. The Mode Altered control bit (PSD bit position 40) must also be zero for the computer to operate in a SIGMA 7-compatible master mode. 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, slave, or masterprotected mode).

#### **SLAVE MODE**

The slave mode of operation is the problem-solving mode of the computer. 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 basic control state of the computer. 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 computer is in the slave mode results in a trap. The master/ slave mode control bit can be changed when the computer is in the master or master-protected mode. However, a slave mode program can gain direct access to certain executive program operations by means of call instructions without requiring executive program intervention. The operations available through call instructions are established by the resident operating system.

#### MASTER-PROTECTED MODE

The master-protected mode of operation is a modification of the master mode designed to provide additional protection for programs that operate in the master mode. The masterprotected mode can only occur when the CPU is operating in the master mode with the memory map in effect. In this mode, a trap will occur to the memory protection violation trap (Homespace location X'40', 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.

#### **INFORMATION FORMAT**

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

The basic element of SIGMA 9 information is a 32-bit word, in which the bit positions are numbered from 0 through 31, as follows:

|   |   |   |   |   |   |   |   |   |   |    |    |    |    | ۷  | ٧o | rd | I  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |   |   |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | _  |    |    |    |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

A SIGMA 9 word can be divided into two halfwords (16 bits each) in which the bit positions are numbered from 0 through 15, as follows:

|   |   |   |   |   | Ho | alt | fw | or | d | 0  |    |    |    |    |    |   |   |   |   | l | Ho | lf | w | or | d | 1  |    |    |    |    |    |
|---|---|---|---|---|----|-----|----|----|---|----|----|----|----|----|----|---|---|---|---|---|----|----|---|----|---|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5  | 6   | 7  | 8  | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 0 | 1 | 2 | 3 | 4 | 5  | 6  | 7 | 8  | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

A SIGMA 9 word can also be divided into four bytes (8 bits each) in which the bit positions are numbered from 0 through 7, as follows:

| Byte O          | Byte 1          | Byte 2          | Byte 3          |
|-----------------|-----------------|-----------------|-----------------|
| 0 1 2 3 4 5 6 7 | 0 1 2 3 4 5 6 7 | 0 1 2 3 4 5 6 7 | 0 1 2 3 4 5 6 7 |

Two SIGMA 9 words can be combined to form a doubleword (64 bits) in which the bit positions are numbered from 0 through 63, as follows:

#### Most significant word

2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

#### Least significant word

32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63

For 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 rightmost 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**

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

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

The various information boundaries are illustrated in Figure 3.

#### **INSTRUCTION REGISTER**

The instruction register contains the instruction that is currently being executed by the CPU. The format and fields of the two general types of instructions (immediate operand and memory-reference) are described below.

#### MEMORY-REFERENCING INSTRUCTIONS

Most SIGMA 9 CPU instructions make reference to an operand located in main memory. The format for this type of instruction is

| * |   | 0 | bd | le |   |   |   |   |   | 2  |    |    | Х  |    |    |    |    |    |    |    |    |    |    |    |    | dro |    |    |    |    |    |
|---|---|---|----|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|
| 0 | 1 | 2 | 3  | 14 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27 | 28 | 29 | 30 | 31 |

- Bits Description
- 0 Indirect addressing. Indirect addressing (one level only) is performed if this bit position contains a 1 and is not performed if this bit position contains a 0.
- 1-7 <u>Operation Code</u>. This 7-bit field contains the code that designates the operation to be performed. See the inside front and back covers as well as Appendix B for complete listings of operation codes.
- 8-11 <u>R field</u>. For most instructions this 4-bit field designates one of 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 any one of general registers 1-7 of the current register block as an index register. If X is equal to 0, indexing will not be performed; hence, register 0 cannot be used as an index register. (See "Address Modification Examples" for a more complete description of the SIGMA 9 indexing process.)
- 15-31 Reference Address. This 17-bit field normally contains the reference address of the instruction operand. Depending on the type of addressing (real, real extended, or virtual) and address modification (direct/indirect or indexing) required, the reference address is translated into an effective virtual address. (See "Memory Reference Addresses" for further details.)

#### IMMEDIATE OPERAND INSTRUCTIONS

Some SIGMA 9 CPU instructions are of the immediate operand type, which is particularly efficient because the required operand is contained within the instruction word. Hence, memory reference, indirect addressing, and indexing are not required.

| 0 | ļ | С |   | er<br>le |   |   |   |    | ł | 2  |    |    |    |    |     |    |    |    |     |    |    | ra |    |    |    |    |    |    |    |    |    |  |
|---|---|---|---|----------|---|---|---|----|---|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|--|
| 0 | 1 | 2 | 3 | 4        | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 151 | 16 | 17 | 18 | 191 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |  |

|        |          |          | Doubl  | eword  |         |          |        |        |          |         | Double | eword  |          |          |        |
|--------|----------|----------|--------|--------|---------|----------|--------|--------|----------|---------|--------|--------|----------|----------|--------|
| W      | ord (eve | en addre | ss)    | w      | ord (od | d addres | s)     | W      | ord (eve | n addre | ss)    | W      | /ord (od | d addres | ss)    |
| Halfv  | vord 0   | Halfw    | vord 1 | Halfw  | vord 0  | Halfw    | vord 1 | Halfw  | vord 0   | Hal fv  | vord 1 | Hal fw | vord 0   | Halfw    | vord 1 |
| Byte 0 | Byte 1   | Byte 2   | Byte 3 | Byte O | Byte 1  | Byte 2   | Byte 3 | Byte 0 | Byte 1   | Byte 2  | Byte 3 | Byte O | Byte 1   | Byte 2   | Byte   |



#### Bits Description

- 0 This bit position must be coded with a 0. If this bit is coded with a 1, the instruction is interpreted as being nonexistent. (See "Trap System".)
- 1-7 Operation Code. This 7-bit field contains a code that designates the operation that will be performed. When any immediate operand operation code is encountered, the CPU interprets the contents of bits 12-31 of the instruction word as an operand. Immediate operand operation codes are as follows:

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

- 8-11 <u>R field.</u> This 4-bit field designates one of 16 general registers of the current register block. This register may contain another operand and/or be designated as the register in which the results of this operation will 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 (duplicated) to the left through 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. However, the operand field of byte string instructions contains 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 1 in bit position 0, it is treated as a nonexistent instruction by the computer.

#### **MAIN MEMORY**

This section describes the organization and operation of the main memory and the various modes and types of addressing, including indexing.

#### **MEMORY UNIT**

The main memory for SIGMA 9 is physically organized as a group of "units". A memory unit is the smallest, logically

complete part of the system, and the smallest part that can be logically isolated from the rest of the memory system. A memory unit always consists of two physical memory banks. Both memory banks may be concurrently and asynchronously operating. Each memory unit has a set of from 2 to 12 "ports" or access points that are common to both banks within the unit; that is, all ports in a given memory unit provide access to both banks within that unit.

#### MEMORY BANK

A memory bank is the basic functionally independent element of the memory system. It consists of magnetic storage elements, drive and sense electronics, control timing, and data registers. A bank consists of 16,384 memory locations. Each location stores a 32-bit information word (instruction or data), plus a parity bit. Associated with each memory location (or word) is an "actual address".

#### MEMORY INTERLEAVING

Memory interleaving is a built-in hardware feature that distributes sequential addresses into independently operating memory banks. Interleaving increases the probability that a processor can gain access to a given memory location without encountering interference from other processors.

Both banks within a unit may be interleaved two ways. For example, in two-way interleaving, even addresses are assigned to bank A and odd addresses to bank B. Four-way interleaving (the assignment of every fourth address to its respective bank) may occur between two adjacent units.

#### MEMORY UNIT STARTING ADDRESS

Each memory unit in the SIGMA 9 system is provided its individual identity by means of starting address switches. These switches define the range of addresses to which the unit responds when servicing memory requests. All addresses, including the starting address, for a given 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 unit must be on a boundary equal to a multiple of the size of the unit. In the event that the unit is interleaved with another unit, the starting address for the combined units must be on a boundary equal to a multiple of the total size of the interleaved assembly.

#### MEMORY PORTS

The memory ports of a memory unit are the connecting points between processors (IOPs and CPUs) and memory banks, and they permit the processors to access memory locations. Each memory unit may have from 2 to 12 independent access ports. A memory unit port is effectively a switch between all the busses entering that unit and the two banks that make up the unit. As an example, a unit that has four busses connected to it and two banks within it would have a port structure designated as a  $4 \times 2$  switch. The ports examine incoming addresses to determine if the request is for a bank within the memory unit. They also determine the priority of memory requests received simultaneously.

The minimum number of ports for a SIGMA 9 system is two, one for the CPU and one for an IOP. The number of ports may be expanded, in increments of one, to a maximum of 12.

#### PORT PRIORITY

The multiport structure and the dual-bank memory (within each unit) allow two simultaneous requests for memory to be processed immediately, providing that the requests are received on different ports, for different banks, and neither bank is busy. If a requested bank is busy, or if simultaneous requests are received for the same bank, the memory port logic selects the highest priority request first.

Normally, all ports in a memory unit operate on a priority basis, with port number 0 having the highest priority and port number "n" having the lowest. In general, CPUs are connected to the higher priority ports and IOPs are connected to the lower priority ports. If simultaneous requests are received for a single bank on port 2 and port 4, port 2 has access to the memory bank first.

In addition to the normal priority that prevails among the ports, as described above, each port has a high priority level. A processor usually requests the normal priority level; however, under certain conditions a processor may request high priority access to a given port (e.g., an IOP will wait with a low priority memory request until half of its available buffering has been filled on input or emptied on output; it then requests a high priority memory reference). If one port receives a high priority request, that port's priority is then higher than the normal priority of all other ports. If more than one port is on a high priority at the same time, the normal sequence of priority will prevail among those ports on high priority.

#### CPU PORT

When the memory is quiescent, the port selection logic is set to a condition that automatically selects port 0. The elimination of switching time (to select a port) results in a timing preferential for the processor connected to port 0. This is particularly advantageous for a monoprocessing system where the CPU is normally connected to port 0 of each memory unit.

#### VIRTUAL AND REAL MEMORY

Virtual memory is logical memory as seen by an individual program. The maximum size of virtual memory is 128K (131,072) words. A virtual memory for a given program may consist of up to 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. The size of real memory ranges from a minimum of 128K words to 512K words. The 512K maximum size limitation is physical (i.e., based on maximum cable length considerations) rather than logical. Real memory addressing space is over 4 million (2<sup>22</sup>) words.

#### HOMESPACE

In a SIGMA 9 multiprocessing system, all processors address memory in the same manner. However, since the CPUs do not share the same interrupt or trap systems, it is necessary to provide private storage for each CPU to contain its trap and interrupt locations, I/O communication locations, and general registers. This private storage is called Homespace.

Determining the location of Homespace for a CPU is like second-level mapping. Each CPU contains a Homespace bias. The Homespace bias is the actual address of a 16K region of the first 1 million words of main memory, of which the first 1,024 words is Homespace. After an effective real address is generated by a CPU by whatever method, and just before it is sent to memory, the most significant 12 bits are tested. If these bits are all equal to zero, then a 6-bit Homespace bias plus two leading zeros are inserted in place of the most significant eight of these bits. This means that any time a CPU makes a reference to the first 1,024 words of real memory that reference may be relocated by means of the Homespace bias.

The 6-bit Homespace bias is supplied by a set of six switches in a SIGMA 9 CPU. They can be changed manually to move the Homespace region from one area to another within the 64 possible areas.

When multiprocessors are used, a given CPU may reference the Homespace region of other processors by using the normal memory addresses for that region. The only exception to this is that the Homespace of a CPU that is set at real memory location zero, cannot be referenced by any other CPU. However, the CPU that has its Homespace at real location zero may reference the Homespace of all other CPUs.

Each Homespace region contains all the trap locations, interrupt locations, and IOP communication locations for a given CPU (see Table 1). These implicitly assigned memory locations plus the 16 locations that are reserved for the general registers, occupy the first 320 locations of Homespace. The remaining words in the Homespace region can be used as private, independent storage by the CPU.

#### **MEMORY REFERENCE ADDRESS**

Homespace 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. However, an instruction can treat any register of the current register block <u>as if</u> it were a location in main memory. Furthermore, the register block can be used to hold an instruction (or a series of up to 16 instructions) for execution just as if the instruction (or instructions ) were

| Tabl | e 1. | Homespace | Layout |
|------|------|-----------|--------|
|      |      |           |        |

| Dec.             | Hex.            | Function                            |                             |
|------------------|-----------------|-------------------------------------|-----------------------------|
| 000<br>:<br>015  | 000<br>:<br>00F | Addresses of gene<br>(see Figure 2) | eral registers              |
| 016<br>:<br>031  | 010<br>:<br>01F | Reserved for futu                   | re use                      |
| 032<br>033       | 020<br>021      | CPU/IOP commu                       | nication locations          |
| 034<br>:<br>063  | 022<br>:<br>03F | Load routine or r                   | eset recovery routine       |
| 064<br>:<br>079  | 040<br>:<br>04F | Trap locations (se                  | ee Table 4)                 |
| 080<br>:<br>085  | 050<br>:<br>055 | Override group                      |                             |
| 086              | 056             | Processor fault                     |                             |
| 087              | 057             | Memory fault                        | Internal<br>Interrupts,     |
| 088<br>:<br>091  | 058<br>:<br>05B | Counter group                       | group X'0'<br>(see Table 5) |
| 092<br>:<br>095  | 05C<br>:<br>05F | I/O group                           |                             |
| 096<br>:<br>111  | 060<br>:<br>06F | External Interrup<br>(see Table 5)  | nts, group X'2'             |
| :                | :               | :                                   |                             |
| 304<br>:<br>319  | 130<br>:<br>13F | External Interrup<br>(see Table 5)  | ots, group X'F'             |
| 320<br>:<br>1023 | 140<br>:<br>3FF | Reserved locatio                    | ns                          |

in main memory. The only restriction upon the use of the register block for instruction storage is:

If an instruction accessed from a general register uses the R field of the instruction word to designate the next higher-numbered register, and execution of the instruction would alter the contents of the register so designated, the contents of that register should not be used as the next instruction in sequence because the operation of the instruction in the affected register would be unpredictable.

Description of the various types of addressing used in the SIGMA 9 are based upon terms and concepts defined below. References are made to Figure 4, which illustrates the control flow and data flow during address generation.

Instruction Address. This is the address of the next instruction to be executed. For real and virtual addressing, the 17-bit instruction address is contained within bits 15-31 of the program status doubleword. For real extended addressing, the 22-bit instruction address is comprised of bits 16-31 concatenated with bits 42-47 of the program status doubleword.

<u>Reference Address</u>. This is the 17- or 22-bit address associated with any instruction except a trap or interrupt instruction that has bit position 10 equal to 0. (See 20-Bit Reference Address, below.) For real and virtual addressing, the reference address is the address contained within bits 15-31 of the instruction itself. For real extended addressing, the reference address is comprised of bits 16-31 of the instruction concatenated with bits 42-47 of the program status doubleword. 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. (See Figure 4.)

20-Bit Reference Address. If bit position 10 of any trap or interrupt instruction is a 0, bits 12-31 of that instruction are used as a 20-bit reference address. A 20-bit reference address may be modified only by using indirect addressing. A 20-bit reference address can not be indexed or mapped.

Direct Reference Address. If neither indirect addressing nor indexing is called for by the instruction (i.e., if bit position 0 and the X field of the instruction are 0), the reference address of the instruction (as defined above) becomes the effective virtual address. Direct addressing may be used during all addressing modes, including trap and interrupt operations. Direct addressing during virtual addressing does not preclude memory mapping.

Indirect Reference Address. The 7-bit operation code field of the SIGMA 9 instruction word format provides up to 128 instruction operation codes, nearly all of which can use indirect addressing (except immediate operand and byte string instructions). If indirect addressing is called for by the instruction (when bit position 0 contains 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 10-31 for certain real





extended addressing operations. The indirect addressing operation is limited to one level. Indirect addressing does not proceed to further levels, 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 reference address field of the instruction is used to obtain a word, and the 17 or 22 loworder 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 "Address Modification Examples".)

Index Reference Address. If indexing is called for by the instruction (a nonzero value in bit positions 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 "Address Modification Examples" for further details.)

<u>Displacements</u>. Displacements are the 16- to 24-bit values used in index registers and by byte string instructions to generate effective addresses of the appropriate size (byte, halfword, word, or doubleword).

Register Address. If any instruction produces a virtual address that is a memory reference (i.e., a direct, indirect, or indexed reference address) in the range 0 through 15, the CPU does not attempt to read from or write into main memory. Instead, the four low-order bits of the reference address are used as a general register address, and the general register (of the current register block) corresponding to this address is used as the operand location or result destination. Thus, the instruction can use any register 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 referred to as a "register-to-register" operation.

Actual Address. An actual address is the address value actually used by the CPU to access main memory via the memory address register (see Figure 4). If the effective virtual address is X'0' - X'F', one of the general registers is addressed. If the computer is operating in virtual addressing mode, all virtual addresses above 15 are transformed (usually into addresses in a different memory page) by the memory map, and these then become actual addresses. However, if the computer is operating in either real or real extended mode, no transformation via the memory map takes place. All actual addresses are 21, 22, 23, or 24 bits, as required to address a doubleword, word, halfword, or byte.

Effective Address. The effective address is defined as the final virtual address computed for an instruction (output from the address generator in Figure 4). The effective address is usually used as the virtual address of an operand location or result destination. However, 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).

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, this definition of an effective location assumes, where applicable, the transformation of a virtual address into an actual address.

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 definition of an effective operand also presupposes the transformation of a virtual address into an actual address.

#### TYPES OF ADDRESSING

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

#### REAL ADDRESSING

Real addressing is a type of addressing where a one-to-one relationship prevails between the effective virtual address of each instruction and the actual address used to access main memory. Characteristics of real addressing are:

- 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, for doubleword, word, halfword, or byte operations; and the effective virtual address is either a 16-bit doubleword address, 17-bit word address, 18-bit halfword address, or a 19-bit byte address.
- 4. Memory mapping and memory access protection are never invoked.
- 5. Memory write protection is automatically invoked because the reference word will always be located within the first 128K words of real memory. Memory locations outside the first 128K words of real memory are not accessible with real addressing.
- 6. Leading zeros are automatically appended to the effective address to generate an actual word address as required by the main memory.

7. Real addressing may be used in master or slave mode and is specified when bits 9 and 40 of the Program Status Doubleword (PSD 9 and PSD 40) are both 0.

#### VIRTUAL ADDRESSING

Virtual addressing is a type of addressing that uses a 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. Characteristics of virtual addressing are:

- 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, for doubleword, word, halfword, or byte operation; and the effective virtual address is either a 16-bit doubleword address, 17-bit word address, 18-bit halfword address, or a 19-bit byte address.
- Virtual memory access protection is always invoked. If the access protection code is invalid, the instruction aborts and traps to Homespace location X'40'. (See "Trap Systems".)
- 5. Memory mapping translates the 8 most significant bits of the effective virtual address (the page portion) into a 13-bit page address. This page address is concatenated with the 9 least significant bits of the reference address. The resultant 22-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 up to 128K words (256 pages) located throughout a real or actual memory of up to four million words (8192 pages). Although the virtual memory is physically fragmented, logically it is contiguous.

In addition, a special SIGMA 7 compatible mapping mode is provided. In this mode, the memory map is loaded with 8-bit page addresses. The most significant 8 bits of the effective virtual address are then translated into the designated 8-bit page address. This compatibility feature allows all SIGMA 7 programs to run on SIGMA 9 computers with no change to the mapping structure required.

- 6. If the actual address is within the first 128K words of real memory, the memory write protection feature is also invoked.
- 7. Virtual addressing may be used in all modes and is specified when PSD 9 is a 1.

#### **REAL EXTENDED ADDRESSING**

Real extended addressing is similar to real addressing in that there is a direct relationship between the effective virtual address of each instruction and the actual address. Real extended addressing facilitates operating with memories larger than 128K words. It permits the operating system to communicate with any user directly via real memory rather than through a part of the user's map. In addition, it provides a method for the operating system to control channel control word chains that work in real memory space. Characteristics of real extended addressing are:

- 1. Memory mapping and access protection are not invoked.
- Memory write protection is invoked only if the actual address is within the first 128K words of real memory.
- 3. Real extended addressing is specified whenever PSD 9 is a 0 and PSD 40 is a 1.

Further descriptions of real extended addressing is provided in three parts:

- 1. Instruction and reference addresses in instructions.
- 2. Other addresses and displacements.
- 3. Branching and branch addresses.
- <u>Note:</u> The extended address fields and displacements described below are applicable <u>only</u> when real extended addressing is used.

Instruction and Reference Addresses in Instructions.

General Instruction Format:

| Γ. | Γ | ( | วี | pe | eı | -0 | ıti | 10 | n | T  |   | <u> </u> |   |    |    | 、  | ,  | T | 0  |    | A  | ١d | dr | es | s  | in  | 1  | st | 6  | 41 | <  | w  | orc | ls |    |
|----|---|---|----|----|----|----|-----|----|---|----|---|----------|---|----|----|----|----|---|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|-----|----|----|
| Î  |   | ¢ | c  | bd | ę  |    |     |    |   |    |   | ĸ        |   |    |    | 1  |    | Γ | 1  |    | Lo | ۶w | 1  | 6  |    | its |    |    |    |    |    |    |     |    |    |
| 0  | 1 | 1 | 2  | 3  | Т  | 4  | 5   | 6  | 7 | 18 | 5 | 1        | 0 | 11 | 12 | 13 | 14 |   | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22  | 23 | 24 | 25 | 26 | 27 | 28 | 29  | 30 | 31 |

Resultant full memory address

The instruction address field of the PSD and the reference address field of each instruction is 17 bits. The address field in both places is divided into two parts. Bit position 15 is used as a flag and bit positions 16-31 are used as a displacement. The displacement field is 16 bits allowing direct resolution to 64K words. The flag (bit 15) is called the Extension Selector and indicates which of two regions is addressed by the 16-bit displacement.

If the Extension Selector equals 0 then the displacement address is to a word within the first 64K of real memory. If the Extension Selector equals 1, then the displacement addresses a word within the 64K region that is identified by bits 42–47 of the PSD, called the Extension Address. When bit position 15 equals 1, a full memory address<sup>†</sup> is formed by concatenating PSD 42–47 with bits 16–31 of the address field.

<sup>&</sup>lt;sup>t</sup>Full memory address consists of 21 bits for a doubleword address, 22 bits for a word address, 23 bits for a halfword address, and 24 bits for a byte address.

The logic treats bits 16-31 of the PSD as a 16-bit counter. The Extension Address (PSD bits 42-47) does not have associated count logic. This means, for example, that if the program is in the real extended addressing mode and the flag bit in position 15 is a 1 and if the location of the instruction presently being executed is X'02FFF', the next instruction executed will be X'020000'. This occurs because the count logic on bits 16-31 of the PSD does not change bit 15 to a 0 and the Extension Address is still in effect. The Extension Address (PSD bits 42-47) remained at the value X'02'.

Other Addresses and Displacements. Except for reference address fields and the instruction address of the PSD, all address and displacement fields are extended into adjacent (previously undefined) fields to address all memory directly. The places affected are as follows:

 An indirect address location contains either a 22-bit word address or a 16-bit region address and an Extension Selector (ES) flag.

Indirect Address Location Formats:



2. An index register contains an extended displacement of from 21 to 24 bits, depending on the size of the unit being referenced.

Index Register Formats:



3. The stack pointer for push/pull instructions contains a 22-bit word address for the top of stack address field.

Stack Pointer Format for Push/Pull Instructions:

| Γ |   |   |   |   |    |   |   |   | 4  |   |    |    |    |    |    | To | op | ) c | of | stc  | cł  | < a  | dd | dre | ess | ;  |    | _  |    |    |    |
|---|---|---|---|---|----|---|---|---|----|---|----|----|----|----|----|----|----|-----|----|------|-----|------|----|-----|-----|----|----|----|----|----|----|
| 5 | ) | 1 | 2 | 3 | 14 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17  | 18 | 19 2 | 0 2 | 1 22 | 23 | 24  | 25  | 26 | 27 | 28 | 29 | 30 | 31 |

| T<br>S |    |    |    |    |    | •  |    | e  |    |    |    |    |    |    |    | Ť  |    |    |    |     |    |    |    |    | :0 |    |    |    |    |    |    |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|
| 32     | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 152 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 |

4. The sign in bit position 12 of byte string instructions is extended before the displacement is added to the destination address. In addition, the registers that describe the source byte address and the destination byte address for a byte string instruction are 24-bit byte addresses.

Register Formats for Byte-String Instructions:

|   | C | od | le |   |   |   |   |   |    |   | R  |    |     |    |    | si  | gı | nŢ | ex | te | d  | de | d  | be | efo | ore | e  | US |    |    |    |    |
|---|---|----|----|---|---|---|---|---|----|---|----|----|-----|----|----|-----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|
| 0 | 1 | 2  | 3  | 1 | 4 | 5 | 6 | 7 | Τe | 9 | 10 | 11 | 112 | 13 | 14 | 151 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24  | 25  | 26 | 27 | 28 | 29 | 30 | 31 |

|   |   |   |   | · . | Fi |   |   |   |   |    |    |    |    |    |    |    |    |    |    |    |    |    | ess |    |    |    |    |    |    |    |    |  |
|---|---|---|---|-----|----|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|--|
| 0 | 1 | 2 | 3 | 14  | 5  | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23  | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |  |

|   |   |   |   |   |    |    |   |   |   |   | _  |    |    |    |    |    |    |    |    |     |    |     |     |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|----|----|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|-----|-----|----|----|----|----|----|----|----|----|----|
|   |   |   |   | C | οu | nt | • |   |   |   |    |    |    | ۵  | )e | st | in | at | io | n I | by | /te | e ( | ad | dı | es | s  |    |    |    |    |    |
| 1 | 0 | 1 | 2 | 3 | 14 | 5  | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21  | 22  | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

When any of the addresses mentioned above are used, they reference memory fully without the use of the extended address field in the PSD. The only exception is the 22-bit word address used for indirect addressing.

Branching and Branch Addresses. The Extension Address field of the program status doubleword (PSD bits 42-47) may be loaded at the time a new PSD is loaded by an XPSD or LPSD instruction. This field is modified automatically by branch instructions.

If the effective address of a branch instruction is outside the first 64K of real memory, the high-order 6 bits of this full effective address are loaded into the Extension Address field of the PSD. The remaining part of the effective branch address is loaded into positions 16-31 of the PSD. In addition, bit position 15 of the PSD, the Extension Selector, is set to 1.

If the effective branch address is to a location within the first 64K of memory, the extension address field of the PSD will <u>not</u> be modified. The effective address is loaded into the 16 low-order positions of the instruction address field and the Extension Selector (bit 15) is set to 0. This means that once the Extension Address is set it remains set until it is either changed by the loading of a new PSD or by the actual branching into another 64K word region of memory.

A BRANCH AND LINK instruction in real extended addressing stores the full address of the next instruction in the link register. If the Extension Selector in the PSD at the time BRANCH AND LINK is executed is equal to 0, the address stored in the link register will be the incremented 16-bit displacement from positions 16-31 of the PSD. Zeros will be placed in the high-order address positions. If the Extension Selector is equal to 1 in the PSD, the address stored will be the incremented 16-bit displacement (PSD 16-31) plus the contents of the Extension Address (PSD 42-47) which will be placed into bit positions 10-15 of the link register. In both cases, bit positions 0-9 of the link register are set to 0's.

#### INTERRUPT AND TRAP ENTRY ADDRESSING

1

An interrupt instruction is defined as one that is in an interrupt location and is executed as the direct result of an interrupt. Both elements of the definition must be satisfied simultaneously for it to be an interrupt instruction. An instruction is <u>not</u> an interrupt instruction even though it may be in an interrupt location if, for example, it is executed as the result of the program branching to the interrupt location under normal program control. Similarly, a trap instruction is defined as one that is in a trap location and is executed as the direct result of a trap. The only valid interrupt instructions are XPSD, MTW, MTH, and MTB. The only valid trap instruction is XPSD.

#### Interrupt and Trap Instruction Format:

| * | Operation<br>code | 0         | Address in 1st million words                                |
|---|-------------------|-----------|-------------------------------------------------------------|
| 0 | 1 2 3 4 5 6 7     | 8 9 10 11 | 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

The address of the instruction executed as a result of an interrupt or trap depends on bit 10 of the XPSD

If bit 10 of the XPSD in an interrupt or trap location is a 0, a real address is generated independently of the addressing mode specified by the current PSD. If bit 0 (the indirect bit) of the XPSD instruction is a 0, bits 12-31 of the XPSD instruction are used as a 20-bit reference address, which permits direct addressing of the first one million words of memory. If bit 0 of the XPSD instruction is a 1, indirect addressing is invoked, and bits 12-31 of the XPSD instruction point to a word in memory that contains the reference address in bit positions 10-31. Note that the indirect word must be programmed with bit 0 containing a 0 and bits 10-31 containing the reference address (so called long form). This 22-bit reference address allows addressing a 4 million word memory.

If bit 10 of the XPSD in a trap or interrupt location is a 1, the address will be generated as prescribed by the current PSD (i.e., real, real extended, or virtual addressing).

Any modify and test instruction encountered in an interrupt location uses the 20-bit reference address in the same manner as described above for the XPSD.

Any XPSD, MTW, MTH, or MTB instruction that is executed as a normal instruction, not an interrupt or trap instruction, uses the 17-bit reference address in the same manner as any other memory reference instruction. Bit 10 has no effect on the execution of an XPSD instruction that is executed as a normal instruction.

#### **ADDRESS MODIFICATION EXAMPLES**

#### INDEXING (REAL AND VIRTUAL ADDRESSING)

Figure 5 shows how the indexing operation takes place during real and virtual addressing operations. As the instruction is brought from memory, it is loaded into a 34-bit instruction register that initially contains 0's 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 addressing type of the instruction; that is, if it is a byte operation, the displacement is lined up so that its low-order bit is alianed with the least significant bit of the 34-bit instruction register. The displacement is 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, which is referred to as the effective address of the instruction. High-order bits of the 32-bit displacement field 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). However, the displacement value 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 highorder 1's (i.e., if the displacement is a negative integer in two's complement form.

The effective virtual address of an instruction is always a 19-bit byte address value. However, this value is automatically adjusted to the SIGMA 9 information boundary conventions. Thus, for halfword operations, the low-order bit of the effective halfword address is 0; for word operations, the two low-order bits of the effective word address are 0's; and for doubleword operations, the 3 low-order bits of the effective doubleword address are 0's.

If no indexing is used with a byte operation, the effective byte is the first byte (bit positions 0-7) of a word location; if no indexing is used with a halfword operation, the effective halfword is the first halfword (bit positions 0-15) of a word location. A doubleword operation always involves a word at an even-numbered word address and the word at the next sequential (odd-numbered) word address. If an oddnumbered word location is specified for a doubleword operation, the low-order bit of the effective address field (bit position 31) is automatically forced to 0. Thus, an odd-numbered word address designates the same doubleword as an even-numbered word address, when used for a doubleword operation.

If the addressing mode is real, the 19-bit effective virtual address is concatentated with 5 leading zeros to form a 24-bit actual address. If the addressing mode is virtual, the 8 most significant bits of the 19-bit effective virtual address (SIGMA 7 page address) are transformed into a 13-bit SIGMA 9 page address. The new page address and the 11 least significant bits of the 19-bit effective virtual address are combined to form a 24-bit actual address.

#### INDEXING (REAL EXTENDED ADDRESSING)

Figure 6 illustrates that the indexing process for real extended addressing is similar to that performed for real and virtual addressing. The differences are:

Bit 15 of the instruction word is not a part of the reference address. It is used as a control flag. If bit 15 is a 1, the contents of the Extension Register (bits 42-47 of the PSD) are concatenated to bits 16-31 of the instruction register to form a 22-bit reference address.



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

If bit 15 is a zero, six leading zeros are concatenated to the 16 bits of the instruction word. In either case, the 22-bit word address is converted into an equivalent byte address by appending two zeros on the right.

 Displacement values have an extended number of bits, 24 bits for byte displacements, 23 bits for halfword displacements, 22 bits for word displacements, and 21 bits for doubleword displacements.

## INDIRECT, INDEXED HALFWORD (VIRTUAL ADDRESSING SIGMA 9 MODE)

Figure 7 illustrates the address modification and mapping process for an indirectly addressed, indexed, halfword operation. As the figure shows, 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, it is converted from a 19-bit reference address to a 24-bit actual address by the memory map. 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 in the X field of the instruction is then aligned for incrementing at the halfwordaddress level. The final effective virtual address is formed by the address generator and if the value of the reference address is greater than 15, it is transformed through the memory map into an actual address. The final 24-bit 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 exactly the same except that the reference address and the final effective address are concatenated with 5 leading zeros rather than being transformed by the memory map.



Figure 6. Index Displacement Alignment (Real Extended Addressing)

## INDIRECT, INDEX HALFWORD (REAL EXTENDED ADDRESSING)

Figure 8 illustrates the address modification process for real extended, indirect, indexed addressing.

Bit 15 of the instruction word is used as a control flag. When bit 15 equals 1, the 16-bit reference address of the instruction is concatenated with the 6 bits contained within the Extension Register (PSD 42-47). When bit 15 equals 0, the 16-bit reference address of the instruction is concatenated with 6 leading zeros and the contents of the Extension Register are not used nor changed.

The word in memory pointed to by the indirect reference address may be one of three types, differentiated by bit 0 and bit 15 of the direct address.

If bit 0 is a 0, bits 10 to 31 are used as the 22-bit direct address. If bit 0 is a 1 and bit 15 is a 0, then bits 16-31 are concatenated with 6 leading zeros to form a 22-bit

direct address. When bit 0 is a 1 and bit 15 is a 1, bits 16-31 are concatenated with the contents of the Extension Register to form a 22-bit direct address.

In either case, the 22-bit direct address is then modified by 23-bit displacement value (halfword alignment of index) to produce a 24-bit effective virtual address that has a 0 in the least significant position. Since real extended addresses are not subjected to mapping, the final effective address is equivalent to the actual address.

#### **MEMORY ADDRESS CONTROL**

In a SIGMA 9 computer, two methods are available for controlling the use of main memory by a program; they are the memory map and the memory lock. The memory map provides for dynamic relocatability of programs and for access protection through inhibitions imposed on slave or master-protected mode programs. The memory lock provides memory write protection for all modes of programs within the first 131,072 words of memory.





Figure 8. Generation of Effective Virtual Address, Real Extended Addressing

#### MEMORY MAP AND ACCESS PROTECTION

The SIGMA 9 memory map is physically an array of 256 registers, each containing 13 bits. The array is stored in the CPU's fast memory. Each register has an 8-bit address and contains a 13-bit actual memory page address code for a specific 512-word page of virtual addresses.

The memory page address codes are assigned to pages of virtual addresses as follows:

| Memory page X    | Memory page K    | <br>Memory page N  |
|------------------|------------------|--------------------|
| (13 bits)        | (13 bits)        | (13 bits)          |
| Virtual 8-bit    | Virtual 8-bit    | <br>Virtual 8-bit  |
| addresses        | addresses        | addresses          |
| X'10'-X'1FF'     | X'200'-X'3FF'    | X'1FE00'-X'1FFFF'  |
| (virtual page 0) | (virtual page 1) | (virtual page 255) |

The most significant 8 bits of a 17-bit virtual address is considered to be the virtual page number. Just prior to a memory reference, the virtual page number is used as an address of an element of the map. The 13 bits contained within that element are then used in conjunction with the loworder 9 bits of the 17-bit virtual address.

When SIGMA 9 is operating in the SIGMA 7-compatible mode, the map appears identical to the SIGMA 7 map. This is accomplished by retaining the SIGMA 7 version of the MOVE TO MEMORY CONTROL (MMC) instruction to load the map in a compatible manner. In this form of the instruction, 8-bit quantities from memory are transmitted into the map. The 8 bits are stored in the low-order 8 bits of each map element and the upper 5 bit positions are set to zero. This means that the map will always relocate to some address in the first 128K of real memory, which is compatible for SIGMA 7 programs.

Associated with the memory map feature is another series of 256 2-bit registers, also located in CPU fast memory. Each of these registers 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.

The access control codes are assigned as follows:



The memory page address and access control codes can be changed only by means of the privileged instruction MOVE TO MEMORY CONTROL (see "Control Instructions"). Access protection is in effect whenever the memory map is in effect (PSD 9 = 1) and the computer is operating in the slave mode (PSD 8 = 1) or in the master-protected mode (PSD 40 = 1). Access protection is not in effect when the computer 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 loworder bits of the virtual address comprise a general register address. However, if an instruction produces a virtual address greater than 15, the 8 high-order bits of the virtual address are used to obtain the appropriate memory page address and access control codes. For example, if the 8 highorder 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 0000 0001, the second page address and access control codes are used, etc., through the 256th page address and 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, the CPU performs a test to determine whether there are any inhibitions on using the virtual address by a slave or master-protected mode program. (If the CPU is in the master mode, this test is not performed.)

The four types of access protection are as follows:

- 00 A slave or master-protected program can write into, read from, or access instructions from this page of virtual addresses.
- 01 A slave or master-protected program cannot write into, but can read from or access instructions from this page of virtual addresses.
- 10 A slave or master-protected program cannot write into or access instructions from, but can read from this page of virtual addresses.
- 11 A slave or master-protected program is denied any access to this page of virtual addresses.

If the instruction being executed by the slave or masterprotected mode program fails this test, the instruction execution is aborted and the computer traps to Homespace location X'40', the "nonallowed operation" trap (see "Trap System").

If the instruction being executed by the slave or masterprotected mode program passes this test (or the CPU is in the master mode), the page address bits in the accessed element of the memory map replace 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 (22-bit word address which is automatically adjusted as required for doubleword, word, halfword, or byte operation).

If the page address bits in the accessed element of the memory map are all 0's, and an actual address is produced that corresponds to a word address in the range 0 through 15, when the page address is combined with 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 actual main memory locations rather than general registers.

#### REAL MEMORY WRITE LOCKS

An additional memory protection feature, independent of the access protection, is provided by a lock and key technique. A 2-bit write protect lock (WL) is provided for each 512-word page of the first 128K words of actual memory addresses. The write-protect locks consist of 256 2-bit write locks, each assigned to a 512-word page of actual addresses as follows:



The write-protect locks can be changed only by executing the privileged instruction MOVE TO MEMORY CONTROL (see "Control Instruction").

The write key (a 2-bit field in PSD for any operating program) works in conjunction with the lock storage to determine whether any program (slave, master-protected, or master mode) can write into a specific page of main memory locations. The keys and locks control access for writing, according to the following rules:

- 1. A lock value of 00 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 00 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 00 for a memory page permits write access to that page only if the key value is identical to the lock value.

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

Note that the memory access protection feature is used during virtual addressing modes and operates on virtual addresses, whereas the memory write protection feature operates always on the first 128K words of actual memory addresses. Thus, if the access protection feature is invoked (that is, the CPU is in the master-protected or slave mode and is using the memory map), the access protection codes are examined at the time the virtual address is converted into an actual address. Then, the locks and keys 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 computer aborts the instruction, and traps to Homespace location X'40', which is the "nonallowed operation" trap (see "Trap System").

All pages of main memory beyond address 128K are considered to have a lock of 00, and are open for writing by any program. Adding Homespace bias to the address does not affect the write lock selection; write locks for page 0 or 1 continue to be used.

#### **PROGRAM STATUS DOUBLEWORD**

The critical control conditions of a SIGMA 9 CPU are defined within 64 bits of information. These 64 bits are collectively referred to as the current program status doubleword (PSD). The current PSD may be considered as a 64-bit internal CPU register, although it actually exists as a collection of separate registers and flip-flops. When stored in memory, the PSD has the following format:



Desig-

nation Function

CC <u>Condition code</u>. This generalized 4-bit code indicates the nature of the results of an instruction. The significance of the condition code bits depends on the particular instruction just executed. After an instruction is executed, the instructions BRANCH ON CONDITIONS SET (BCS) and BRANCH ON CONDITIONS RESET (BCR) 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 CC1 refers to the first bit of the condition code, CC2 to the second bit, CC3 to the third bit, and CC4 to the fourth bit. Any program can change the current value of the condition code by executing either the instruction LOAD CONDITIONS AND FLOATING CONTROL IMMEDIATE (LCFI) or the instruction LOAD CONDITIONS AND FLOATING CONTROL (LCF). Any program can store the current condition code by executing STORE CONDITIONS AND FLOATING CONTROL (STCF). These instructions are described in Chapter 3, "Load/Store Instructions".

- FS Floating significance mode control.
- FZ Floating zero mode control.

#### Designation

#### Function

- FN Floating normalize mode control. The three floating-point mode bits (FS, FZ, and FN) control the operation of the computer with respect to floating-point significance checking, the generation of zero results, and the normalization of the results of floating-point additions and subtractions, respectively. (The floating-point mode controls are described in Chapter 3, "Floating-point Instruction".) Any program can change the state of the current floating-point mode controls by executing either the instruction LCFI or the instruction LCF. Any program can store the current state of the current floatingpoint mode controls by executing the instruction STCF.
- MS Master/slave mode control. The computer is in the master mode when this bit and the Mode Altered bit are both 0; it is in the slave mode when this bit is a 1. (See description of MA for master-protected mode.) A master or masterprotected mode program can change the mode control by executing either the instruction LOAD PROGRAM STATUS DOUBLEWORD (LPSD) or the instruction EXCHANGE PROGRAM STATUS DOUBLEWORD (XPSD). These two privileged instructions are described in Chapter 3, "Control Instructions".
- MM Memory map control. The memory map is in effect when this bit is a 1. A master or masterprotected mode program can change the memory map control, by executing either the instruction LPSD or the instruction XPSD.
- DM Decimal mask. The decimal arithmetic trap (see "Trap System") is in effect when this bit is a 1. 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 or a master-protected mode program executing either the instruction LPSD or the instruction XPSD.
- AM Arithmetic mask. The fixed-point arithmetic overflow trap is in effect when this bit is a 1. The instructions that can cause fixed-point overflow are described in the section "Trap System". The arithmetic trap mask can be changed by a master or master-protected mode program executing either the instruction LPSD or the instruction XPSD.
- AS ANSCII Control. This bit controls a feature that facilitates the generation of ANSCII character codes. When this bit is a 1, ANSCII codes are generated. When this bit is a 0, EBCDIC codes are generated.

#### Designation

Function

- IA Instruction address. This 17-bit field contains the virtual address of the next instruction to be executed.
- ES Extension selector. In real extended type of addressing this bit indicates whether the region that is addressed by bits 16-31 of the instruction address field is the zero region or another 64K word region, as defined by the Extension Address (bits 42-47 of the PSD).
- ED Extended displacement. Bits 16-31 of the instruction address specify the displacement within the region defined by EA (extension address bits 42-47) and ES (bit 15).
- WΚ Write key. This field contains the 2-bit key used in conjunction with the memory protection feature. A master or master-protected mode program can change the write key by executing either the instruction LPSD or the instruction XPSD.
- CI Counter interrupt group inhibit.
- П Input/output interrupt group inhibit.
- ΕI External interrupt group inhibit. The three inhibit bits (CI, II, and EI) determine whether certain interrupts may occur. The functions of the interrupt inhibits are described in the section "Interrupt System". A master or master-protected mode program can change the interrupt inhibits by executing LPSD, XPSD, or the instruction WRITE DIRECT (WD). The WD instruction is described in Chapter 3, "Control Instructions".
- MA Mode altered. This bit is used to invoke both the master-protected mode of operation and the real extended type of addressing. Table 2 indicates the function of this bit used in conjunction with MS (bit 8) and MM (bit 9).
- ΕA Extension address. This field is used in real extended addressing to define the alternate region of 64K words that can be referenced by a given 16-bit address field (ED). It is used when ES (bit 15) is equal to 1.
- TSF Trapped status field. This field is reserved for fault tracing during trap conditions. It is used for an access protection or write lock violation that results in a nonallowed operation trap to Homespace location X'40', condition code setting CC4 equal to 1. This trap occurs due to violating memory protection as a result of an instruction, indirect address access, or operand access. (See "Memory Protection Violation", "Trap Condition Code", and Table 5.)
- RP Register pointer. This 4-bit field selects one of the four possible blocks of general-purpose registers as the current register block. Unused codes within this field are reserved for future use. A master or master-protected mode program can

Designation

Function

- RP change the register pointer by executing LPSD,
- (cont.) XPSD, or the instruction LOAD REGISTER POINTER (LRP). The LRP instruction is described in Chapter 3, "Control Instructions".
- RA Register altered bit. In the event of a trap entry, this bit is set to 1 when any general register or location in memory has been altered in the execution or partial execution of the instruction that caused the trap.

| Table 2. | Computer | Operatina | and | Addressing Mod      | les |
|----------|----------|-----------|-----|---------------------|-----|
| 10010 2. | Gomporer | operaning | ana | riddi cooring ritoc | .00 |

| MS | мм | "МА | State                                             |
|----|----|-----|---------------------------------------------------|
| 0  | 0  | 0   | Master, real addressing (128K<br>words, maximum). |
| 0  | 0  | 1   | Master, real extended addressing.                 |
| 0  | 1  | 0   | Master, virtual addressing.                       |
| 0  | 1  | 1   | Master-protected, virtual addressing.             |
| 1  | 0  | 0   | Slave, real addressing (128K<br>words, maximum).  |
| 1  | 0  | 1   | Slave, real extended addressing.                  |
| 1  | 1  | -   | Slave, virtual addressing (MA may be 1 or 0).     |

### INTERRUPT SYSTEM

When a condition that will result in an interrupt is sensed, a signal is sent to an interrupt level. If that level is "armed", it advances to the waiting state. When all the conditions for its acknowledgment have been achieved, the interrupt level advances to the active state, where it causes the computer to take an instruction from a specific location in memory. The computer may execute many instructions between the time that the interrupt-requesting condition is sensed and the time that the actual interrupt acknowledgment occurs.

Up to 238 interrupt levels are normally available, each with a unique location (see Table 3) assigned in main memory, with a unique priority, and capable of being selectively armed and/or enabled by the CPU. Also, any interrupt level can be "triggered" by the CPU (supplied with 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 the testing of special systems programs before the special systems equipment is actually attached to the computer, and also permits an interrupt-servicing 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 may occur before the deferred interrupt response is processed.

SIGMA 9 interrupts are arranged in groups that are connected in a predetermined priority chain by groups of levels. The priority of each level within a group is fixed; the first level has the highest priority and the last level has the lowest. The user has the option of ordering a machine with a priority chain starting with the override group and connecting all remaining groups in any sequence. This allows the user

| Loco<br>Dec. | ntion<br>Hex. | WRITE DIRECT<br>Register bit <sup>t</sup> | Function                 | Availability | PSD<br>Inhibit | WRITE DIRECT<br>Group code <sup>tt</sup> |
|--------------|---------------|-------------------------------------------|--------------------------|--------------|----------------|------------------------------------------|
|              |               |                                           |                          |              |                |                                          |
| 80           | 50            | none                                      | Power on <sup>ttt</sup>  | standard     |                | none                                     |
| 81           | 51            |                                           | Power off <sup>ttt</sup> |              |                |                                          |
| 82           | 52            | 16                                        | Counter 1 count pulse    | optional     |                |                                          |
| 83           | 53            | 17                                        | Counter 2 count pulse    | (as a set)   | none           |                                          |
| 84           | 54            | 18                                        | Counter 3 count pulse    |              | - ·            |                                          |
| 85           | 55            | 19                                        | Counter 4 count pulse    | standard     |                |                                          |
| 86           | 56            | 20                                        | Processor fault          |              |                | VIO                                      |
| 87           | 57            | 21                                        | Memory fault             |              |                | X'0'                                     |
| 88           | 58            | 22                                        | Counter 1 zero           | optional     |                |                                          |
| 89           | 59            | 23                                        | Counter 2 zero           | (as a set)   | CI             |                                          |
| 90           | 5A            | 24                                        | Counter 3 zero           | standard     |                |                                          |
| 91           | 5B            | 25                                        | Counter 4 zero           |              |                | · .                                      |

Table 3. SIGMA 9 Interrupt Locations

<sup>†</sup>When the privileged instruction WRITE DIRECT is used in the interrupt control mode to operate on interrupt levels, the interrupt levels are selected by specific bit positions in register R. The numbers in this column indicate the bit position in register R that corresponds to the various interrupt levels.

<sup>t†</sup>The numbers in this column indicate the group codes (for use with WRITE DIRECT) of the various interrupt levels.

<sup>ttt</sup>These interrupts cannot be disarmed, disabled, or inhibited.

| Loco<br>Dec.    | ation<br>Hex.      | WRITE DIRECT<br>Register bit <sup>†</sup> | Function                                           | Availability | PSD<br>Inhibit | WRITE DIRECT<br>Group code <sup>tt</sup> |
|-----------------|--------------------|-------------------------------------------|----------------------------------------------------|--------------|----------------|------------------------------------------|
| 92<br>93        | 5C<br>5D           | 26<br>27                                  | Input/Output<br>Control Panel                      | standard     | 11             | X'0'                                     |
| 94<br>95        | 5E<br>5F           |                                           | Reserved for future use<br>Reserved for future use |              |                | ×0                                       |
| 96<br>:<br>111  | 60<br>:<br>6F      | 16<br>: -<br>31                           | External Group 2                                   |              |                | X'2'                                     |
| 112<br>:<br>127 | 70<br>:<br>:<br>7F | 16<br>:<br>31                             | External Group 3                                   |              |                | X'3'                                     |
| •               | ÷                  | :                                         | •                                                  | optional     | EI             | :<br>:                                   |
| 288<br>:<br>303 | 120<br>:<br>12F    | 16<br>:<br>31                             | External Group 14                                  |              |                | X'E'                                     |
| 304<br>:<br>319 | 130<br>:<br>13F    | 16<br>:<br>31                             | External Group 15                                  |              |                | X'F'                                     |

Table 3. SIGMA 9 Interrupt Locations (cont.)

<sup>T</sup>When the privileged instruction WRITE DIRECT is used in the interrupt control mode to operate on interrupt levels, the interrupt levels are selected by specific bit positions in register R. The numbers in this column indicate the bit position in register R that corresponds to the various interrupt levels.

<sup>tt</sup>The numbers in this column indicate the group codes (for use with WRITE DIRECT) of the various interrupt levels.

to establish external interrupts above, between, or below the counter and input/output groups of internal interrupts. Figure 9 illustrates this with a configuration that a user might establish, where (after the override group) the counter group of internal interrupts is given the second-highest priority, followed by the first group of external interrupts, then the input/output group of internal interrupts, and finally all succeeding groups of external interrupts.

#### **INTERNAL INTERRUPTS**

Internal interrupts include those standard interrupts that are normally supplied with a SIGMA 9 system, as well as the additional counter interrupts.

#### OVERRIDE GROUP (LOCATIONS X'50' TO X'57')

The eight interrupt levels of this group always have the highest priority in a SIGMA 9 system. The power fail-safe feature includes the power on and power off interrupt levels. A system can contain 2 or 4 count-pulse interrupt levels that 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



Figure 9. Typical Interrupt Priority Chain

frequencies – the commercial line frequency, 500 Hz, 2 kHz, or a user-supplied external signal – that may be different for each counter. (All counter frequencies are synchronous except for the line frequency and the signal supplied by the user.) Each of the count-pulse interrupt locations must contain one of the modify and test instructions (MTB, MTH, or MTW) or an XPSD instruction. When the modification (of the effective byte, halfword, or word) causes a zero result, the appropriate counter-equals-zero interrupt (see "Counter-Equals-Zero Group") is triggered.

The override group also includes a processor fault and a memory fault interrupt location. Both of these locations normally contain an XPSD instruction. The processor fault interrupt level is triggered by a signal from an input/output processor (IOP) or another CPU when these devices detect certain fault conditions. 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" for further details on processor and memory faults).

# COUNTER-EQUALS-ZERO GROUP (LOCATIONS X'58' TO X'5B')

Each interrupt level in the counter-equals-zero group (called a counter-equals-zero interrupt) is associated with a count-pulse interrupt in the override group. When the execution of a modify and test instruction in the countpulse interrupt location causes a zero result in the effective byte, halfowrd, or word location, the corresponding counterequals-zero interrupt is triggered. The counter-equals-zero interrupt locations normally contain an XPSD instruction and they can be inhibited or permitted as a group. If bit position 37 (CI) of the current program status doubleword contains a 0, the counter-equals-zero interrupts are allowed to interrupt the program being executed. However, if the CI bit is a 1, the counter-equals-zero interrupts are not allowed to interrupt the program. These interrupts wait until the CI bit is reset to 0 and then interrupt the program according to priority.

#### INPUT/OUTPUT GROUP (LOCATIONS X'5C' AND X'5D')

This interrupt group includes two standard interrupts: the I/O interrupt and the control panel interrupt. The I/O interrupt level accepts interrupt signals from the standard I/O system. The I/O interrupt location is assumed to contain an EXCHANGE PROGRAM STATUS DOUBLEWORD (XPSD) instruction that transfers program control to a routine for servicing all I/O interrupts. The I/O routine then contains an ACKNOWLEDGE I/O INTERRUPT (AIO) instruction that identifies the source and reason for the interrupt.

The control panel interrupt level is connected to the INTER-RUPT button on the processor control panel. The control panel interrupt location normally contains an XPSD instruction and can thus be triggered by the computer operator, allowing him to initiate a specific routine.

The interrupts in the input/output group can be inhibited or permitted by means of bit position 38 (II) of the program status doubleword. If II is a 0, the interrupts in the I/O group are allowed to interrupt the program being executed. However, if the II bit is a 1, the interrupts are inhibited from interrupting the program.

#### EXTERNAL INTERRUPTS

A SIGMA 9 system can contain up to 14 groups of optional interrupt levels, with 16 levels in each group. As shown in Figure 9, the groups can be connected in any priority sequence.

All external interrupt locations normally contain XPSD instructions and can be inhibited or permitted by means of bit position 39 (EI) of the program status doubleword. If EI is a 0, external interrupts are allowed to interrupt the program. However, if EI is a 1, all external interrupts are inhibited from interrupting the program.

#### **STATES OF AN INTERRUPT LEVEL**

A SIGMA 9 interrupt level is mechanized by means of three flip-flops. Two of the flip-flops are used to define any of four mutually exclusive states: disarmed, armed, waiting, and active. The third flip-flop is used as a level-enable. The various states and the conditions causing them to change state are described in the following paragraphs. A conceptual diagram of the operational states of the interrupt system is shown in Figure 10.

#### DISARMED

When an interrupt level is in the disarmed state, no signal to that interrupt level is admitted; that is, no record is retained of the existence of the signal, nor is any program interrupt caused by it at any time.

#### 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. (If the level is already in a waiting or active state, the signal has no effect.)

#### WAITING

When an interrupt level in the armed state receives an interrupt signal, it advances to the waiting state, and remains in the waiting state until it is allowed to advance to the active state. If the level-enable flip-flop is off, the interrupt level can undergo all state changes except that of moving from the waiting to the active state. Furthermore, if this flip-flop is off, the interrupt level is completely removed from the chain that determines the priority of access to the CPU. Thus, an interrupt level in the waiting state with its level-enable in the off condition does not prevent an enabled, waiting interrupt of lower priority from moving to the active state. Any signals received by an interrupt level 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 exist simultaneously before the level advances to the active state.

- 1. The level must be enabled (i.e., its level-enable flipflop must be set to 1).
- 2. The group inhibit (CI, II, or EI, if applicable) must be a 0.
- 3. No higher-priority interrupt level is in the active state or is in the waiting state and totally enabled (i.e., enabled and not inhibited).
- The CPU must be at an interruptable point in the execution of a program.

#### ACTIVE

When an interrupt meets all of the conditions necessary to permit it to move from the waiting state to the active state, it is permitted to do so by being acknowledged by the computer, which then executes the contents of the assigned interrupt location as the next instruction. The instruction address portion of the program status doubleword remains unchanged until the instruction in the interrupt location is executed.

The instruction in the interrupt location must be one of the following: XPSD, 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 active state, an instruction exception trap occurs.

If the instruction in the interrupt location is an XPSD instruction with bit 10 set to 1, or if a modify and test instruction in the Counter 4 count-pulse location (see "Single-Instruction Interrupts"), the effective address is generated subject to the current active addressing mode (real, real extended, or virtual). If, for XPSD, bit 10 and bit 0 are equal to 0, bits 12-31 of the instruction unconditionally specify a direct address within the first 1 million ( $2^{20}$ ) words of real memory. Since the index field is used for addressing, indexing is not possible. If bit 10 is equal to 0 and indirect addressing is specified (bit 0 = 1), the indirect address (interpreted as in real extended addressing) is found in the word specified by bits 12-31.

The use of the privileged instruction XPSD in an interrupt location permits an interrupt-servicing routine to save the entire current machine environment and establish a new 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, which results in the assignment of a new block of 16 registers to the routine. It is also accomplished by setting bit 8 of the XPSD instruction to 1.

An interrupt level remains in the active state until it is cleared (removed from the active state) by the execution of the LPSD instruction or the WD instruction. An interruptservicing routine can itself be interrupted (whenever a higher priority interrupt level meets all of the conditions for becoming active) and then continued (after the higher priority interrupt is cleared). However, an interruptservicing routine cannot be interrupted by a lower priority interrupt 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.

### **CONTROL OF THE INTERRUPT SYSTEM**

The SIGMA 9 system has two points of interrupt control. One point of interrupt control is at the individual interrupt level. The WD instruction can be used to individually arm, disarm, enable, disable, or trigger any interrupt level except for the power fail-safe interrupts (which are always armed, always enabled, and cannot be triggered).

The second point of interrupt control is achieved by means of the interrupt inhibits (CI, II, and EI) in the program status doubleword. If an interrupt inhibit is set to 1, all interrupt levels in the corresponding group are effectively disabled, i.e., no interrupt in the group may advance from the waiting state to the active state and the group is removed from the interrupt recognition priority chain. Thus, a waiting, enabled interrupt level (in a group that is not inhibited) is not prevented from interrupting the program by a higher priority, waiting, enabled interrupt level in a group that is inhibited. However, if an interrupt group is inhibited while a level in that group is in the active state, no lower priority interrupt level may advance to the active state.

The RD instruction may be used to determine which interrupt levels in a selected group are in the armed or waiting state, in the waiting or active state, or enabled. Chapter 3 contains a description of the RD instruction.

#### TIME OF INTERRUPT OCCURRENCES

The SIGMA 9 CPU permits an interrupt to occur during the following time intervals (related to the execution cycle of an instruction) provided that the control panel COMPUTE switch is in the RUN position and no "halt" condition exists:

- 1. Between instructions: an interrupt is permitted between the completion of any instruction and the initiation of the next instruction.
- Between instruction iterations: 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 intermediate 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 the point in 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 doubleword 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 a situation where 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 for the single instruction).

If any of the following instructions is executed in any interrupt location, then that interrupt automatically becomes 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 the section "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 or not the memory map is currently being used. Counter 4 uses the mapped location if mapping is currently invoked in the PSD. The execution of a modify and test instruction in an interrupt location, including mapped and unmapped counter 4, is independent of the memory access protection codes and the writeprotection locks; thus, a memory protection violation trap cannot occur (a nonexistent memory address will cause an instruction exception trap). Also, the fixed-point overflow 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, in addition to the following: if the resultant value in the effective location is zero, the corresponding counterequals-zero interrupt is triggered.

## TRAP SYSTEM

#### TRAP

A trap is similar to an interrupt in that program execution automatically branches to a predesignated location when a trap condition occurs. A trap differs from an interrupt in that a trap location must contain an XPSD instruction. Depending on the type of trap, the trap instruction is either executed immediately (i.e., current instruction is aborted) or upon completion of the current instruction. The trap instruction is not held in abeyance by higher priority traps. Interrupts on the other hand may have an entire sequence of instructions executed before actual interupt action occurs.

#### TRAP ENTRY SEQUENCE

A trap entry sequence begins when the CPU detects the trap condition and ends when the new PSD has successfully replaced the old PSD. Detection of any condition listed in Table 4, which summarizes the trap system, results in a trap to a unique location in memory. When a trap condition occurs, the CPU sets the trap state. The operation currently being performed by the CPU may or may not be carried to completion, depending on the type of trap. In any event, the instruction is terminated with a trap sequence. In this sequence, the program counter is not advanced; instead, the XPSD instruction in the location associated with the trap is executed. If any interrupt level is ready to enter the active state at the same time that an XPSD trap instruction is in process, the interrupt acknowledgement will not occur until the XPSD trap instruction is completed. If the trap location does not contain an XPSD instruction, a second trap sequence is immediately invoked. (See "Instruction Exception Trap".) The operation of the XPSD instruction is described in Chapter 3, under "Control Instructions".

#### **TRAP MASKS**

The programmer may mask the four trap conditions described below. Other traps can not be masked.

- 1. The push-down stack limit trap is masked within the stack pointer doubleword for each individual stack.
- The fixed-point overflow trap is masked in bit position 11 (AM) of the PSD. If bit position 11 (AM) of the PSD contains a 1, the trap is allowed to occur. If bit position 11 contains a 0, the trap is not allowed to occur. AM can be masked by operator intervention or by execution of either of the privileged instructions XPSD or LPSD.
- 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 (see "Floating-Point Arithmetic Fault Trap").

FS, FZ, and FN can be set or cleared by the execution of any of the following instructions:

LOAD CONDITIONS AND FLOATING CON-TROL (LCF)

LOAD CONDITIONS AND FLOATING CON-TROL IMMEDIATE (LCFI)

EXCHANGE PROGRAM STATUS DOUBLEWORD (XPSD)

LOAD PROGRAM STATUS DOUBLEWORD (LPSD)

4. The decimal arithmetic fault trap is masked by bit position 10 (DM) of the PSD. If bit position 10 (DM) of the PSD contains a 1, the trap is allowed. If DM is a 0, the trap is not allowed. DM can be masked by execution of either of the privileged XPSD or LPSD instructions.

#### TRAP CONDITION CODE

For the traps push-down stack limit, fixed-point overflow, floating-point fault, and decimal fault, the normal condition code register, CC1-CC4, is loaded with more detailed information about the trap condition just before the trap occurs. This condition code is saved as part of the old PSD when the XPSD instruction is executed in response to the trap.

For the traps nonallowed operation, watchdog timer runout, memory parity error, instruction exception, and calls, a special register, the trap condition code TCC1-TCC4, is loaded just before the trap occurs. When the XPSD instruction is executed in response to the trap, this register is added to the new program address if bit 9 of the XPSD is set to 1; TCC1-TCC4 is also logically ORed with the condition code bits of the new PSD when loading CC1-CC4.

#### TRAP ADDRESSING

During the trap entry sequence, the XPSD instruction in the trap location is accessed without mapping, regardless of the current addressing mode.

If bit 10 of the XPSD is a 1, the effective address is generated subject to the current active addressing mode (real, real extended, or virtual). If, however, bit 10 and bit 0 are equal to a zero, bits 12-31 of the instruction unconditionally specify a direct address within the first  $2^{20}$  words of real memory. Since the index field is used for addressing, indexing is not possible. If bit 10 is equal to a zero and indirect addressing is specified (bit 0 = 1), the indirect address (interpreted as in real extended addressing) is found in the word specified by bits 12-31. Bit 10 of the XPSD has no effect when the XPSD is executed as a nontrap instruction.

|                    | ation    |                                                          | PSD                 |                                                                                                                                                                                                       |                                                                                                                                                                            |
|--------------------|----------|----------------------------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dec.               | Hex.     | Function                                                 | Mask Bit            | Time of Occurrence                                                                                                                                                                                    | Trap Condition Code                                                                                                                                                        |
| 64                 | 40       | Nonallowed operation<br>1. Nonexistent<br>instruction    | None                | At instruction decode.                                                                                                                                                                                | Set TCC1                                                                                                                                                                   |
|                    |          | 2. Nonexistent<br>memory address                         | None                | Prior to memory access.                                                                                                                                                                               | Set TCC2                                                                                                                                                                   |
|                    |          | <ol> <li>Privileged instruction in slave mode</li> </ol> | None                | At instruction decode.                                                                                                                                                                                | Set TCC3                                                                                                                                                                   |
|                    |          | <ol> <li>Memory protec-<br/>tion violation</li> </ol>    | None                | Prior to memory access.                                                                                                                                                                               | Set TCC4                                                                                                                                                                   |
| 65                 | 41       | Unimplemented instruction                                | None                | At instruction decode.                                                                                                                                                                                | None                                                                                                                                                                       |
| 66                 | 42       | Push-down stack<br>limit reached                         | τw, τs <sup>t</sup> | At the time of stack limit<br>detection. (The aborted<br>push-down instruction does<br>not change memory, regis-<br>ters, or the condition code.)                                                     | None                                                                                                                                                                       |
| 67                 | 43       | Fixed-point<br>arithmetic overflow                       | AM                  | For all instructions except<br>DW and DH, trap occurs<br>after completion of in-<br>struction. For DW and<br>DH, instruction is aborted<br>with memory, registers,<br>CC1, CC3, and CC4<br>unchanged. | None                                                                                                                                                                       |
| 68                 | 44       | Floating-point<br>arithmetic fault                       |                     | At detection.                                                                                                                                                                                         |                                                                                                                                                                            |
|                    |          | <ol> <li>Characteristic<br/>overflow</li> </ol>          | None                | (The floating-point<br>instruction is aborted                                                                                                                                                         | None                                                                                                                                                                       |
|                    |          | 2. Divide by zero                                        | None                | without changing any registers. The condition code is set to indicate                                                                                                                                 | None                                                                                                                                                                       |
|                    |          | 3. Significance check                                    | FS, FZ, FN          | the reason for the trap.)                                                                                                                                                                             | None                                                                                                                                                                       |
| 69                 | 45       | Decimal arithmetic<br>fault                              | DM                  | At detection. (The aborted<br>decimal instruction does<br>not change memory, reg-<br>isters, CC3, or CC4.)                                                                                            | None                                                                                                                                                                       |
| 70                 | 46       | Watchdog Timer<br>Runout                                 | None                | At runout. (The Processor<br>Detected Fault or PDF flag<br>will be set.)                                                                                                                              | Set TCC1 if instruction successfully<br>completed (TCC2–4 reset).<br>Set TCC2 if processor bus hang-up.<br>Set TCC3 if memory bus hang-up.<br>Set TCC4 if DIO bus hang-up. |
| 71                 | 47       | Reserved                                                 |                     |                                                                                                                                                                                                       |                                                                                                                                                                            |
| 72                 | 48       | CALLI                                                    | None                | At instruction decode.                                                                                                                                                                                | Equal to R field of CALL instruction.                                                                                                                                      |
| <sup>†</sup> The 1 | FW and T | S mask bits are contained w                              | rithin the Stac     | k Pointer Doubleword for each                                                                                                                                                                         | n push–down stack.                                                                                                                                                         |

Table 4. Summary of SIGMA 9 Trap Locations

.

| Loc  | ation |                               | PSD      |                             |                                                                                                                                                                                                                                                                                                                     |
|------|-------|-------------------------------|----------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dec. | Hex.  | Function                      | Mask Bit | Time of Occurrence          | Trap Condition Code                                                                                                                                                                                                                                                                                                 |
| 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    | Parity Error                  | None     | (The PDF flag will be set.) | Set TCC2 if map parity error.<br>Set TCC3 if data bus parity error<br>detected by CPU.<br>Reset TCC1-4 if memory parity error.                                                                                                                                                                                      |
| 77   | 4D    | Instruction Exception<br>Trap | None     | (The PDF flag will be set.) | Set TCC1 if trap or interrupt se-<br>quence and register pointer set to<br>nonexistent register block.<br>Set TCC = 0 if an XPSD, LPSD, or<br>LRP instruction not in a trap or inter-<br>rupt sequence tries to set register<br>pointer to nonexistent register block.<br>Set TCC3 if MMC configuration<br>illegal. |
|      |       |                               |          |                             | Set TCC = X'C' if trap or interrupt<br>sequence with illegal instruction.<br>Set TCC = X'F' if trap or interrupt<br>sequence and processor detected fault                                                                                                                                                           |
|      |       |                               |          |                             | Set TCC4 if invalid register desig-<br>nation (odd register on AD, SD,<br>FAL, FSL, FML, FDL, TBS, TTBS,<br>EBS, and register 0 on EBS).                                                                                                                                                                            |
| 78   | 4E    | Reserved                      |          |                             |                                                                                                                                                                                                                                                                                                                     |
| 79   | 4F    | Reserved                      |          |                             |                                                                                                                                                                                                                                                                                                                     |

Table 4. Summary of SIGMA 9 Trap Locations (cont.)

#### **NONALLOWED OPERATION TRAP**

The occurrence of a nonallowed operation always causes the computer to abort the instruction being executed at the time that the nonallowed operation is detected and to immediately execute the XPSD instruction in Homespace trap location X'40'. A nonallowed operation trap cannot be masked.

### NONEXISTENT INSTRUCTION

Any instruction that is not standard on SIGMA 9 is defined as nonexistent. This includes immediate operand instructions that are indirectly addressed (1 in bit position 0 of instruction). If a nonexistent instruction is detected, the computer traps to Homespace location X'40' at the time the nonexistent instruction is decoded. No general registers or memory locations are changed, and the PSD points to the instruction trapped. The operation of the XPSD in Homespace trap location X'40' (with respect to the condition code and instruction address portions of the PSD) is as follows:

- 1. Store the current PSD. The condition codes stored are those that existed at the end of the last instruction prior to the nonexistent instruction.
- 2. Load the new PSD. The current PSD is replaced by the contents of the doubleword location following the doubleword location in which the current PSD was stored.
- 3. Modify the new PSD.
  - a. Set CC1 to 1. The other condition code bits remain unchanged from the values loaded from memory.

 b. If bit position 9 of XPSD contains a 1, the program counter is incremented by 8. If bit position 9 of XPSD contains a 0, 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 Homespace location X'40' 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 CPU is in the map mode, the program address will already have been modified by the memory map to generate an actual (but nonexistent) address. (Refer to Table 6 for possible changes to registers and memory locations.) The operation of the XPSD in Homespace trap location X'40' is as follows:

- 1. Store the current PSD.
- 2. Load the new PSD.
- 3. Modify the new PSD.
  - a. Set CC2 to 1. The other condition code bits remain unchanged from the values loaded from memory.
  - b. If bit position 9 of XPSD contains a 1, the program counter is incremented by 4. If bit position 9 of XPSD contains a 0, 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 CPU is in the slave mode causes a trap to Homespace location X'40' before the privileged operation is performed. No general registers or memory locations are changed, and the PSD points to the instruction trapped. The operation of the XPSD in Homespace trap location X'40' is as follows:

- 1. Store the current PSD.
- 2. Load the new PSD.
- 3. Modify the new PSD.
  - a. Set CC3 to 1. The other condition code bits remain unchanged from the values loaded from memory.
  - b. If bit position 9 of XPSD contains a 1, the program counter is incremented by 2. If bit position 9 of XPSD contains a 0, the program counter remains unchanged from the values loaded from memory.

The operation codes OC and OD, and their indirectly addressed forms, 8C and 8D, are both nonexistent and privileged. If any one of these operation codes is used while the CPU is in the slave mode, both CC1 and CC3 are set to 1's after the current PSD is modified, and if bit position 9 of XPSD contains a 1, the program counter is incremented by 10. All other nonexistent operation codes are treated as nonprivileged and, if used, will trap with CC1 set to 1.

#### MEMORY PROTECTION VIOLATION

A memory protection violation occurs either because of a memory map access control bit violation (by a program executed in the slave or master-protected mode using the memory map), or because of a memory write-lock violation (by any program) within the first 128K words of real memory. When either type of memory protection violation occurs, the CPU aborts execution of the current instruction without changing protected memory and traps to Homespace location X'40'. (Refer to Table 6 for possible changes to registers and memory locations.) The operation of the XPSD in Homespace trap location X'40' is as follows:

- 1. Store the current PSD. Set trapped status field to virtual page address of protected page.
- 2. Load the new PSD.
- 3. Modify the new PSD.
  - a. Set CC4 to 1. The other condition code bits remain unchanged from the values loaded from memory.
  - b. If bit position 9 of XPSD contains a 1, the program counter is incremented by 1. If bit position 9 of XPSD contains a 0, the program counter remains unchanged from the value loaded from memory.

An attempt to access a memory location that is both protected and nonexistent causes both CC2 and CC4 to be set to 1's after the current PSD has been modified, and if bit position 9 of XPSD contains a 1, the program counter is incremented by 5.

When the memory protection violation trap occurs, an XPSD instruction is executed that stores the current PSD in the doubleword pointed to by the effective address of the instruction. If this trap condition (CC4 = 1) occurs, the particular virtual page address that caused the trap will be stored in the trapped status field, bit positions 48–55, of the same doubleword. This information only appears in memory and only at the time of the trap. Subsequent XPSD instructions that are not executed as a result of this trap will not store information in bit positions 48–55.

#### UNIMPLEMENTED INSTRUCTION TRAP

When the DECIMAL switch on the processor control panel is in the OVERRIDE position, the decimal unit is disabled. The decimal unit includes the following instructions.

| Instruction Name | Mnemonic | Operation<br>Code |
|------------------|----------|-------------------|
| Decimal Load     | DL       | X'7E'             |
| Decimal Store    | DST      | X'7F'             |
| Decimal Add      | DA       | X'79'             |
| Decimal Subtract | DS       | X'78'             |
| Decimal Multiply | DM       | X'7B'             |
| Decimal Divide   | DD       | X'7A'             |

| Instruction              | Mnemonic | Operation<br>Code |
|--------------------------|----------|-------------------|
| Decimal Compare          | DC       | X'7D'             |
| Decimal Shift Arithmetic | DSA      | X'7C'             |
| Pack Decimal Digits      | ΡΑϹΚ     | X'76'             |
| Unpack Decimal Digits    | UNPK     | X'77'             |
| Edit Byte String         | EBS      | X'63'             |

If an attempt is made to execute a decimal instruction (directly or indirectly addressed) when the DECIMAL switch is in the OVERRIDE position, the computer traps to Homespace location X'41', the unimplemented instruction trap. An indirectly addressed EBS instruction is always treated as a nonexistent instruction rather than as an unimplemented instruction.

The operation of the XPSD in trap Homespace location X'41' is as follows:

- 1. Store the current PSD. The condition code stored is that which existed at the end of the instruction immediately prior to the unimplemented instruction.
- Load the new PSD. The condition code and the instruction address portions of the PSD remain at the values 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<br>Code |
|----------------------|----------|-------------------|
| Push Word            | PSW      | X'09'             |
| Pull Word            | PLW      | X'08'             |
| Push Multiple        | PSM      | Х'ОВ'             |
| Pull Multiple        | PLM      | X'0A'             |
| Modify Stack Pointer | MSP      | X'13'             |

During the execution of any stack-manipulating instruction (see "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<sup>15</sup>-1, the instruction is aborted with memory and registers unchanged. If TS (bit 32) of the stack pointer doubleword is set to 0, the CPU traps to Homespace location X'42'. If TS is set to 1, the trap is inhibited and the CPU processes

38 Trap System

the next instruction. If execution of the instruction would cause the words (W) field to become less than 0 or greater than 2<sup>15</sup>-1, the instruction is aborted with memory and registers unchanged. If TW (bit 48) of the stack pointer doubleword is set to 0, the CPU traps to Homespace location X'42'. If TW is set to 1, the trap is inhibited and the CPU 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 in Homespace trap location X'42' is as follows:

- 1. Store the current PSD. The condition codes that are stored are those that existed prior to execution of the aborted push-down instruction.
- Load the new PSD. The condition code and instruction address portions of the PSD remain at the values loaded from memory.

#### **FIXED-POINT OVERFLOW TRAP**

Overflow can occur for any of the following instructions:

Onerstian

| Instruction                | Mnemonic | Operation<br>Code |
|----------------------------|----------|-------------------|
| Load Absolute Word         | LAW      | X'3B'             |
| Load Absolute Doubleword   | LAD      | X'1B'             |
| Load Complement Word       | LCW      | X'3A'             |
| Load Complement Doubleword | LCD      | X'1A'             |
| Add Halfword               | AH       | X'50'             |
| Subtract Halfword          | SH       | X'58'             |
| Divide Halfword            | DH       | X'56'             |
| Add Immediate              | AI       | X'20'             |
| Add Word                   | AW       | X'30'             |
| Subtract Word              | SW       | X'38'             |
| Divide Word                | DW       | X'36'             |
| Add Doubleword             | AD       | X'10'             |
| Subtract Doubleword        | SD       | X'18'             |
| Modify and Test Halfword   | мтн      | X'53'             |
| Modify and Test Word       | MTW      | X'33'             |
| Add Word to Memory         | AWM      | X'66'             |

Except for the instructions DIVIDE HALFWORD (DH) and DIVIDE WORD (DW), the 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 PSD) is a 1, the CPU traps to Homespace location X'43' 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; but CC1, CC3, 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 CPU traps to location X'43' instead of executing the next instruction in sequence.

The execution of XPSD in Homespace trap location X'43' is as follows:

1. Store the current PSD. If the instruction trapped was any instruction other than DW or DH, the stored condition code is interpreted as follows:

| <u>CC1</u> † | CC2 | CC3 | <u>CC4</u> | Meaning                                                                           |
|--------------|-----|-----|------------|-----------------------------------------------------------------------------------|
| _**          | 1   | 0   | 0          | Result after overflow is zero.                                                    |
| -            | 1   | 0   | 1          | Result after overflow is negative.                                                |
| -            | 1   | 1   | 0          | Result after overflow is positive.                                                |
| 0            | -   | -   | -          | No carry out of bit 0<br>of the adder (add and<br>subtract instructions<br>only). |
| 1            | -   | -   | -          | Carry out of bit 0 of<br>the adder (add and<br>subtract instructions<br>only).    |

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

| <u>CC1</u> | CC2 | CC3 | <u>CC4</u> | Meaning  |
|------------|-----|-----|------------|----------|
| _**        | 1   | -   | -          | Overflow |

<sup>†</sup>CC1 remains unchanged for instructions LCW, LAW, LCD, and LAD.

2. Load the new PSD. The condition code and instruction address portions of the PSD 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, the 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 computer traps to Homespace location X'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 doubleword are set to the appropriate state.

If a floating-point instruction traps, the execution of XPSD in Homespace trap location X'44' is as follows:

1. Store the current PSD. If division is attempted with a zero divisor or if characteristic overflow occurs, the stored condition code is interpreted as follows:

| <u>CC1</u> | CC2 | <u>CC3</u> | <u>CC4</u> | Meaning                                      |
|------------|-----|------------|------------|----------------------------------------------|
| 0          | 1   | 0          | 0          | Zero divisor.                                |
| 0          | 1   | 0          | 1          | Characteristic overflow, negative result.    |
| 0          | 1   | 1          | 0          | Characteristic overflow,<br>positive result. |

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:

| <u>CC1</u> | CC2 | <u>CC3</u> | <u>CC4</u> | Meaning                                         |
|------------|-----|------------|------------|-------------------------------------------------|
| 1          | 1   | 0          | 1          | Characteristic under-<br>flow, negative result. |
| 1          | 1   | 1          | 0          | Characteristic under–<br>flow, positive result. |

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

| <u>CC1</u> | CC2 | CC3 | <u>CC4</u> | Meaning                                 |
|------------|-----|-----|------------|-----------------------------------------|
| 1          | 0   | 0   | 0          | Zero result of addition or subtraction. |

<sup>&</sup>lt;sup>tt</sup>A hyphen indicates that the condition code bits are not affected by the condition given under the "Meaning" heading.

| <u>CC1</u> | <u>CC2</u> | <u>CC3</u> | CC4 | Meaning                                                        |
|------------|------------|------------|-----|----------------------------------------------------------------|
| 1          | 0          | 0          | 1   | More than two post-<br>normalizing shifts,<br>negative result. |
| 1          | 0          | 1          | 0   | More than two post-<br>normalizing shifts,<br>positive result. |

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

#### DECIMAL ARITHMETIC FAULT TRAP

When either of two decimal fault conditions occurs (see "Decimal Instructions"), the normal sequencing of instruction execution is halted, CC1 and CC2 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 computer traps to Homespace 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              |
| Decimal Divide              | DD       | Overflow, illegal<br>digit |
| Decimal Compare             | DC       | Illegal digit              |
| Decimal Shift<br>Arithmetic | DSA      | Illegal digit              |
| Pack Decimal<br>Digits      | РАСК     | Illegal digit              |
| Unpack Decimal<br>Digits    | UNPK     | Illegal digit              |
| Edit Byte String            | EBS      | Illegal digit              |

The execution of XPSD in Homespace trap location X'45' is as follows:

1. Store the current PSD. The stored condition code is interpreted as follows:

| CC1 | CC2 | <u>CC3</u>     | <u>CC4</u> | Meaning                        |
|-----|-----|----------------|------------|--------------------------------|
| 0   | 1   | _ <sup>t</sup> | -          | All digits legal and overflow. |
| Ĭ   | 0   | -              | -          | Illegal digit detected.        |

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

#### CALL INSTRUCTION TRAP

The four CALL instructions (CAL1, CAL2, CAL3, and CAL4) cause the computer to trap to Homespace location X'48' (for CAL1), X'49' (for CAL2), X'4A' (for CAL3), or X'4B' (for CAL4). Execution of XPSD in the trap location is as follows:

- 1. Store the current PSD. The stored condition code bits are those that existed prior to the CALL instruction.
- 2. Load the new PSD.
- 3. Modify the new PSD.
  - a. The R Field of the CALL instruction is logically ORed with the condition code register as loaded from memory.
  - b. If bit 9 of XPSD contains a 1, the R field of the CALL instruction is added to the program counter.
     If bit 9 of XPSD 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.

#### **PROCESSOR DETECTED FAULTS**

The Processor Detected Fault (PDF) flag is a hardware flag used in the SIGMA 9 system to aid in solving the multiple error problem. Most traps occur because of some 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 computer is

<sup>&</sup>lt;sup>t</sup>A hyphen indicates that the condition code bit is not affected by the condition given under the "Meaning" heading.

attempting to recover from the first error, unpredictable results occur. Included in this class of traps is the parity 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. At the same time, a bit in the fault status register is set indicating the type of fault.

When the PDF flag is set, the processor fault interrupt, the memory fault interrupt, and count pulse interrupts are automatically inhibited. The other interrupts, with the exception of power fail-safe, may or may not be inhibited as specified by the PSD, which is loaded when the trap entry XPSD is executed. The PDF flag is normally reset by the last instruction of a trap routine, which is an <u>LPSD instruction having bit 10 equal to 0 and bit 11 equal to 1</u>. At the same time, the fault status register is also cleared.

If a second PDF is detected before the PDF flag is reset, the CPU becomes "hung-up" just prior to executing the XPSD associated with the last trap condition. This condition can be recognized by the operator observing that the PDF, HALT lights are on but not the PCP or CPU phase lights. This condition can be cleared by the operator pressing the CPU RESET or the SYS RESET switches on the processor control panel; or, in a multiprocessor system, by another CPU executing an RIO instruction.

If the operator wants to resume operation without recovery, or to stop and examine the current state of the system, he sets the COMPUTE switch to the IDLE position. The CPU will then complete execution of the XPSD (with the exception noted below) associated with the last trap to occur and then return to the IDLE state with the PDF flag still set. In the special case, the last trap was an instruction exception trap and an invalid instruction is situated in the associated memory location; the CPU cannot reach the IDLE state (PCP1) when the COMPUTE switch is returned to IDLE but repetitively reenters the trap sequence attempting to execute the invalid instruction. For this case, the operator must press CPU RESET or SYS RESET to clear this state and enter the IDLE state.

The reset (RIO) function on a processor bus addressing a CPU will cause a reset of that CPU. If the CPU is "hung-up", 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.
- The PSD is cleared to zero except that the instruction address is set to Homespace location X'26'. This is the same condition for the PSD that results from pressing the SYS RESET switch on the processor control panel.
- 4. The CPU will begin execution with the instruction contained in Homespace location X'26'.

#### WATCHDOG TIMER RUNOUT TRAP

The watchdog timer is a two-phase timer that monitors and controls the maximum amount of CPU 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 completed before the end of phase 1, the timer is reset. If the instruction is completed after phase 1 but before the end of phase 2, a trap to Homespace location X'46' occurs immediately after the instruction is completed. TCC1 is set to indicate successful completion of the instruction, and TCC2, 3, and 4 are set to zero. TCC1 is set only if no other trap is pending at the end of the completed instruction, and indicates that the return address stored by the XPSD should point to the next instruction to be executed.

If the instruction is not completed by the time the watchdog timer has advanced through phase 2, the instruction is aborted, TCC1 is set to 0, and a trap occurs immediately to Homespace location X'46'. TCC2 is set if the CPU was using the processor bus, TCC3 is set if the CPU was using the memory bus, or TCC4 is set if the CPU was using the DIO bus. The return address stored by the XPSD is valid only if TCC2 or TCC4 are set, and points to the trapped instruction. The register altered flag of the PSD is also set if any register or main memory location had been changed when the trap occurred.

A watchdog timer runout is considered a CPU fault and the PDF flag is set. The first stage watchdog timer trap, however, is inhibited during the time the PDF flag is set, or the Power On/Off interrupt level is in the waiting and enabled or active state, to avoid entering a double fault hang-up state.

#### INSTRUCTION EXCEPTION TRAP

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

The different conditions that cause the instruction exception trap are:

- 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 on interrupt or trap; (b) accessing the instruction in the interrupt or trap location; and (c) executing that instruction, including the exchange of the PSD, if required. Note that instructions executed as a result of the interrupt or trap other than the instruction located at 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 interrupt (not XPSD, MTB, MTH, MTW) location when executing a trap or interrupt sequence.
- The register pointer (bits 56–59) of the PSD is set to a nonexistent register block as a result of an LRP, LPSD, or XPSD.

- 4. Bit positions 12–14 of the MOVE TO MEMORY CONTROL (MMC) instruction are interpreted as an illegal configuration. That is, any configuration other than 100, 010, 001, or 101.
- 5. 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:<sup>†</sup>

Register 0 Specified

Edit Byte String (EBS)

Odd Register Specified

Add Doubleword (AD)

Subtract Doubleword (SD)

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)

<u>Trap Condition Code</u>. The Trap Condition Code (TCC) differentiates between the different fault types. Some of the fault conditions (as listed in Table 5) may occur and/or be detected during a trap or interrupt entry sequence. In this case, the trapped status field, bits 48-55 of the PSD, are set to equal the least significant eight bits of the address of the trap or interrupt instruction in which the trap occurred; that is, the trapped status field will point to the trap or interrupt location that was in effect when the fault occurred. In the event that the fault occurs in a normal program instruction, the trapped status field has no meaning.

Table 5 shows the settings of the TCC and trapped status field for the various fault types.

#### PARITY ERROR TRAP

Three types of parity errors may be detected in the addressing and memory logic.

1. <u>Map Check</u>. When the CPU is operating with the memory map, a parity check is made on the page

Table 5. TCC Setting for Instruction Exception Trap X'4D'

| Fault Type                                                                                                                           | TCC<br>1 2 3 4 | Trapped Status<br>Field (PSD bits<br>48–55)                  |
|--------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------|
| XPSD in trap or<br>interrupt location tries<br>to set register pointer<br>to nonexistent register<br>block.                          | 1000           | 8 least significant<br>bits of trap or<br>interrupt address. |
| XPSD, LPSD, or LRP<br>not in a trap or inter-<br>rupt sequence tries to<br>set register pointer to<br>nonexistent register<br>block. | 0000           | No meaning.                                                  |
| Trap or interrupt<br>sequence and pro–<br>cessor detected fault.                                                                     | 1111           | 8 least significant<br>bits of trap or<br>interrupt address. |
| Trap or interrupt<br>sequence with<br>invalid instruction.                                                                           | 1100           | 8 least significant<br>bits of trap or<br>interrupt address. |
| MMC configuration invalid.                                                                                                           | 0010           | No meaning.                                                  |
| Invalid register<br>designation.                                                                                                     | 0001           | No meaning.                                                  |

addresses retrieved from the map. If an error is found, this fault occurs. The CPU aborts the memory request, traps to Homespace location X'4C' and sets TCC2 to 1.

- Data Bus Check. If the CPU detects<sup>t</sup> a parity error on data received from memory and the memory does not also indicate a parity error on the information sent, a data bus check occurs. The data bus check causes the CPU to trap to Homespace location X'4C', and sets TCC3 to 1.
- Memory Parity Error. When a CPU receives<sup>†</sup> a signal from the memory indicating memory parity error, this fault occurs. The CPU traps to Homespace location X'4C'. In addition, on a memory-detected parity error trap, the memory bank will "snapshot" the address causing the trap.

The memory parity error signal is generated:

1. When the memory is performing a read operation and a parity error is detected in the data as read from the memory elements.

<sup>&</sup>lt;sup>†</sup>"Invalid register designation" faults do not set the PDF flag.

<sup>&</sup>lt;sup>t</sup>Note exceptions in "Trap Conditions During 'Anticipate' Operations".

- When the memory is performing a partial write operation and a parity error is detected when reading the word to be changed. This is done before the new information is inserted and the data restored to memory; memory is not changed.
- 3. When a parity error is detected in the memory on an address received on the memory bus. If the address bus check occurs on a write request, the memory is not accessed. On a read request, dummy data with incorrect parity is sent to the processor.
- 4. When a parity error is detected on data received by the memory from the memory bus. The memory is not accessed and the data is not used.
- 5. If the memory has a port selection error in attempting to establish priority for requests received on two or more ports. The memory parity error signal is generated on the busses for all ports affected by the selection error.
- 6. If the LOAD MEMORY STATUS instruction is used and the condition code set prior to execution of the instruction is reserved (i.e., not implemented in the memory logic), the memory will interpret it as a read-type instruction, send back a parity error signal and all zeros on the data bus, and "snapshot" the address in the Memory Status Register.

In addition, any of these six conditions will always cause a Memory Fault Interrupt to occur.

# TRAP CONDITIONS DURING "ANTICIPATE"

During the time that the SIGMA 9 is executing a current instruction, it is also performing operations in anticipation of the next instruction, as specified by the instruction address. These operations (accessing the next instruction, the associated operand, and/or indirect address, etc.) may encounter trapping conditions. Whether a corresponding trap will occur is contingent on the current instruction. Traps due to the current instruction and traps due to branch operations will inhibit traps due to operations performed in anticipation of the next instruction. If the current instruction is a successful branch instruction, the instruction sequence is changed. Therefore, operations performed in anticipation of the next instruction are no longer valid, and any traps associated with these operations are disregarded.

If the current instruction encounters a trap, it takes precedence over the next instruction and any anticipated trap. At the end of the trap routine these operations will be reperformed and the proper trap action will occur at this time.

At the end of the execution of current (nonbranching) instructions, trap conditions detected during "anticipate" operations have priority over an interrupt. These trap conditions include nonexistent memory, access protection violation, nonexistent instruction, privileged instruction in slave mode, and parity error.

#### **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 PSD be changed when the trap occurs. If any of these registers or flags are changed, the Register Altered bit (60) of the old PSD is set to 1 and is saved by the trap XPSD.

Changes to CC1-4 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 PSD 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 half of the PSD until a possible trap condition due to access of the second half could have been detected. Table 6 contains a list of SIGMA 9 instructions and indicates for these instructions what registers, memory locations, and PSD bits, if any, have been changed when a trap due to an operand access memory cycle occurs.

#### Table 6. Registers Changed at Time of a Trap Due to an Operand Access

| Instructions                                            | Changes                                                                                         |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| AI, CI, LCFI, LI, MI                                    | Immediate type, no operand access.                                                              |
| CAL1-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 condition codes are set instead. |

| Table 6. Registers | Changed at | Time of a | Trap Due to | o an Operand | Access (cont. | ) |
|--------------------|------------|-----------|-------------|--------------|---------------|---|
|--------------------|------------|-----------|-------------|--------------|---------------|---|

| Instructions                                                                                                                                                                                          | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LB, LCF, LRP, CB<br>LH, LAH, LCH, AH, SH, MH, DH, CH<br>LW, LAW, LCW, AW, SW, MW, DW, CW<br>LD, LAD, LCD, AD, SD, CD, CLM, CLR<br>EOR, OR, AND, LS, INT, CS<br>FAS, FSS, FMS, FDS, FAL, FSL, FML, FDL | No operand store, registers and PSD unchanged when trap due to<br>operand fetch. CC1-4 may be changed but are not used as input<br>to any of these instructions.                                                                                                                                                                                                                                                                                           |
| AWM, XW, STS, MTB, MTH, MTW<br>STB, STCF, STH, STW, LAS                                                                                                                                               | Registers and memory are preserved, condition codes may be changed<br>but are not used as input to these instructions.                                                                                                                                                                                                                                                                                                                                     |
| STD                                                                                                                                                                                                   | If a trap occurs, the first word (odd address) may have been stored already. The Register Altered bit is set in this case.                                                                                                                                                                                                                                                                                                                                 |
| EXU, BCR, BCS<br>BAL, BDR, BIR                                                                                                                                                                        | If the branch condition is true (always for EXU and BAL) and a trap<br>occurs due to access of the indirect address or of the next (branched<br>to or executed) instruction, the register used is left unchanged and<br>the program address saved in the PSD is the address of the branch or<br>execute instruction.                                                                                                                                       |
| MBS, CBS, TBS, TTBS, EBS, MMC<br>DA, DS, DL, DST, DC, DM, DD, PACK,<br>UNPK, LM, STM, PLM, PSM                                                                                                        | These instructions check for protection violations and nonexistent<br>memory at both ends of the data area at the beginning of execution<br>(see individual instruction descriptions). If any traps occur during<br>execution, e.g., because of parity errors, the instruction is aborted,<br>indicating in the registers at which point. In general, memory will<br>be altered and the Register Altered bit set.                                          |
| CVA, CVS                                                                                                                                                                                              | If a trap occurs, the instruction will be aborted before altering registers. CC1-4 may be changed but not used as input to any of these instructions.                                                                                                                                                                                                                                                                                                      |
| XPSD, LPSD                                                                                                                                                                                            | If a trap occurs due to storing the old PSD or fetching the new PSD,<br>the instruction is aborted before changing the old PSD.                                                                                                                                                                                                                                                                                                                            |
| SIO, TIO, TDV, HIO, AIO                                                                                                                                                                               | Operand access protection violations are not possible during execu-<br>tion of these instructions; therefore, a trap will only occur due to a<br>parity error when accessing the CPU/IOP communication locations<br>(Homespace location X'20' or X'21'). If a parity error trap does<br>occur when accessing these locations (either by the CPU or IOP),<br>the instruction will abort with CC3 set to 1. (See "Input/Output<br>Instructions", Chapter 3.) |

# 3. INSTRUCTION REPERTOIRE

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

- 1. Load and Store
- 2. Analyze and Interpret
- 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)
- SIGMA 9 instructions are described in the following format:

MNEMONIC<sup>(1)</sup> INSTRUCTION NAME (Addressing Type<sup>(3)</sup>, Privileged<sup>(4)</sup>, Interrupt Action<sup>(5)</sup>) (6) **Reference** address Operation R Operand Description<sup>()</sup> Trap (9 Affected (8 Symbolic Notation Condition Code Settings Trap Action<sup>12</sup> Example<sup>13</sup>

1. MNEMONIC is the code used by the SIGMA 9 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.
  - 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 1), the instruction is treated as a nonexistent instruction, and the computer unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to Homespace location X'40', 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 computer treats the instruction as a nonexistent instruction, and the computer unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to Homespace location X'40'. Indexing does not apply to this type of instruction.
- 4. If the instruction is not executable while the computer is in the slave mode, it is labeled "privileged". If execution of a privileged instruction is attempted while the computer is in the slave mode, the computer unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to Homespace location X'40'.

- 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 indirect addressing; however, 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 Homespace location X'40').
  - b. Operation code The operation code field (bit positions 1–7) of the instruction is shown in hexa-decimal notation.
  - c. R 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/O 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". This 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 word "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 computer (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 I/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 computer 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 doubleword 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.
- All trap conditions that may be invoked by the execution of the instruction are listed after the word "Trap". SIGMA 9 trap locations are summarized in the section "Trap System" in Chapter 2.
- The symbolic notation presents the instruction operation as a series of generalized symbolic statements. The symbolic terms used in the notation are defined in Appendix E, "Glossary of Symbolic Terms".
- 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 by the reason given for the condition code bit(s) containing a 0 or 1. For example, the following condition code settings are given for a comparison instruction:
  - 1 2 3 4 Result of comparison
  - - 0 0 Equal.
  - 0 1 Register operand is arithmetically less than effective operand.
  - 1 0 Register operand is arithmetically greater than effective operand.
  - 1 - The logical product of the two operands is nonzero.
  - 0 The logical product (AND) of the two operands is zero.

CC1 is unchanged by the instruction. CC2 indicates whether or not the two operands have 1'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 1's in corresponding bit positions. For example, if the register operand is arithmetically less than the effective operand and the two operands both have 1's in at least one corresponding bit position, the condition code setting for the comparison instruction is:

- 1 2 3 4
- 1 0 1

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 (PSD 60) is set to 1 if a register has been altered. Then the appropriate trap location is activated.

12. Actions taken by the computer 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 computer. In order to avoid unnecessary repetition, the three trap conditions that apply to all instructions (i.e., non-allowed 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.

#### LOAD/STORE INSTRUCTIONS

The following load/store instructions are implemented in SIGMA 9 computers:

| Instruction Name | Mnemonic |
|------------------|----------|
| Load Immediate   | LI       |
| Load Byte        | LB       |
| Load Halfword    | LH       |
| Load Word        | LW       |
| Load Doubleword  | LD       |

| Instruction Name                                  | Mnemonic |
|---------------------------------------------------|----------|
| 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 Real 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<br>Immediate | LCFI     |
| Load Conditions and Floating Control              | LCF      |
| 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     |
|                                                   |          |

SIGMA 9 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:

- 1 2 3 4 Result
- 0 0 Zero the result in the affected register(s) is all 0's.
- 0 1 Negative register R contains a 1 in bit position 0.

#### 1 2 3 4 Result

- 1 0 Positive register R contains a 0 in bit position 0, and at least one 1 appears in the remainder of the affected registers(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 (Immediate operand)

| 0 | 0 22 |   |   |   |   |   |   |   | R |    |    |    |    |    |    |    |    |    |    | ١  | /a | lυ | e  |    |    |    |    |    |    |    |    |
|---|------|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1    | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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)<br>12-31SE → R      | if bit 0 is a 1.               |

Condition code settings:

1 2 3 4 Result in R

- - 0 0 Zero
- - 0 1 Negative
- - 1 0 Positive

If LI 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 Homespace location X'40' with the contents of register R and the condition code unchanged.

| L | B |                                                    |   |   |   | - |   | _ | _ | Y1<br>de | _  |    | ig | nr | ne | nt | )  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
|---|---|----------------------------------------------------|---|---|---|---|---|---|---|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|
| * |   | (Byte index alignment)<br>72 R X Reference address |   |   |   |   |   |   |   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
| 0 | 1 | 2                                                  | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10       | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |  |

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  

$$EB \xrightarrow{R} 24-31; 0 \xrightarrow{R} 0-23$$

Condition code settings:

- 1 2 3 4 Result in R
- - 0 0 Zero
- - 1 0 Nonzero

#### LH LOAD HALFWORD (Halfword index alignment)

| * |   |   | 5 | 52 |   |   |   |   | F | 2  |    |    | Х  |    |    |    |    | I  | Re | fe | re | en | ce | a  | dd | dr | es | s  |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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.

Condition code settings:

| 1 | 2 | 3 | 4 | Result | in | R |
|---|---|---|---|--------|----|---|
|   |   |   |   |        |    |   |

- - 0 0 Zero
- – 0 1 Negative
- - 1 0 Positive

LW LOAD WORD (Word index alignment)

| * |   |   | 3 | 32 |   |   |   |    | F | 2  |    |    | Х  |    |    |    |    |    | R  | efe | ər | en | ce | e ( | ad | dr | es | s  |    |    |    |
|---|---|---|---|----|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | ó | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21 | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

LOAD WORD loads the effective word into register R.

Affected: (R), CC3, CC4 EW  $\longrightarrow$  R

Condition code settings:

- <u>1 2 3 4</u> Result in R
- - 0 0 Zero
- - 0 1 Negative
- - 1 0 Positive

#### LOAD DOUBLEWORD (Doubleword index alignment)

| * |    |       |   | 11 | -<br>> |   |   |     |    | I | 2          |     |    | x  |    |      |    |    | P  | of  | ~ ~ | ~  |    |    |    | 14 |    | ss |    |    |    | ٦  |
|---|----|-------|---|----|--------|---|---|-----|----|---|------------|-----|----|----|----|------|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|
| Ļ | L, | <br>_ | _ | +  | -      |   |   |     |    |   | ` <u> </u> |     |    | ~  |    |      |    |    |    |     |     |    |    |    |    |    | -  |    |    |    |    |    |
| 0 | 1  | 2     | 3 | 1  | 4      | 5 | 6 | - 7 | 18 | 9 | 10         | 111 | 12 | 13 | 14 | 15 I | 16 | 17 | 18 | 191 | 20  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

LOAD DOUBLEWORD loads the 32 low-order bits of the effective doubleword into register Ru1 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), (Ru1), CC3, CC4  $ED_{32-63} \longrightarrow Ru1; ED_{0-31} \longrightarrow R$ 

Condition code settings:

1 2 3 4 Effective doubleword

- 0 0 Zero
- 0 1 Negative
- 1 0 Positive

Example 1, even R field value:

|         | Before execution    | After execution     |
|---------|---------------------|---------------------|
| ED =    | X'0123456789ABCDEF' | X'0123456789ABCDEF' |
| (R) =   | xxxxxxx             | X'01234567'         |
| (Ru1) = | xxxxxxx             | X'89ABCDEF'         |
| CC =    | xxxx                | ××10                |
|         |                     |                     |

Example 2, odd R field value:

|   | Before execution    | After execution                                                    |
|---|---------------------|--------------------------------------------------------------------|
| = | X'0123456789ABCDEF' | X'0123456789ABCDEF'                                                |
| = | xxxxxxx             | X'01234567'                                                        |
| = | xxxx                | ××10                                                               |
|   | =                   | Before execution<br>= X'0123456789ABCDEF'<br>= xxxxxxxxx<br>= xxxx |

Example 3, odd R field value:

|     |   | Before execution   | After execution    |
|-----|---|--------------------|--------------------|
| ED  | = | X'000000012345678' | X'000000012345678' |
| (R) | = | xxxxxxx            | X'0000000'         |
| сс  | = | xxxx               | ××10               |

#### LOAD COMPLEMENT HALFWORD LCH (Halfword index alignment)

| * |   | 5,  | Ą |   |   |   |   | F | 2  | i  |    | Х  |    |    |    |    | F  | Ref | fe | re | nc | e  | a  | dc | lre | ess |    |    |    |    |
|---|---|-----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 | 2 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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  
- 
$$[EH_{SE}] \longrightarrow R$$

Condition code settings:

| 1_ | 2 | 3 | 4 | Result in R |
|----|---|---|---|-------------|
| -  | - | 0 | 0 | Zero        |
| -  | - | 0 | 1 | Negative    |

- 1 0 Positive
- LAH LOAD ABSOLUTE HALFWORD (Halfword index alignment)

| * |   |   |   | 5 | B  |   |   |   |   |   | F | २  |    |    | х  |    |    |    |    | F  | le | Fe | re | nc | e  | a  | dd | lre | ss |    |    |    |    |
|---|---|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|
| 0 | 1 | 1 | 2 | 3 | Ι. | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27 | 28 | 29 | 30 | 31 |

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 EH<sub>SE</sub> ------ R

Condition code settings:

| 1 | 2 | 3 | 4 | Result | in | R |
|---|---|---|---|--------|----|---|
|   |   |   |   |        |    |   |

| 0 0 Z | ero |
|-------|-----|
|-------|-----|

LCW

1 0 Nonzero

LOAD COMPLEMENT WORD (Word index alignment)

| * |     | 3   | BA |   |   |   |   | R | 2  |    |    | Х  |    |    |    |    | F  | lef | fei | re | nc | e  | a  | dd | lre | ess |    |    |    |    |
|---|-----|-----|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 3 | 2 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20  | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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'8000000'), 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. -EW -----→ R

Condition code settings:

| 1 | 2 | 3 | 4 | Result | ŀ | in | R |
|---|---|---|---|--------|---|----|---|
|   |   |   |   |        |   |    |   |

- 0 0 Zero 0
- 1 Negative 0

Ω 1 0 Positive

- No fixed-point overflow
- 1 0 1 Fixed-point overflow

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1, the computer traps to Homespace location X'43' after execution of LOAD COMPLEMENT WORD; otherwise, the computer executes the next instruction in sequence.

#### LOAD ABSOLUTE WORD LAW (Word index alignment)

| Г |     |      |   |      |      |   |   |      |   | Γ     |   |        |    |    |   |    |   |     |     |    |    |    |    |    |  |
|---|-----|------|---|------|------|---|---|------|---|-------|---|--------|----|----|---|----|---|-----|-----|----|----|----|----|----|--|
| * |     | 3    | В |      |      | R | ł |      | Х |       |   | R      | ef | er | e | ٦c | е | a   | bb  | re | ss |    |    |    |  |
| Ļ | L., | <br> | h | <br> | <br> |   |   | <br> |   | <br>L | 1 | <br>18 | 10 |    | - |    |   | 0.0 | 0.5 | 24 | 07 | 00 | 20 | 20 |  |

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}$  (X'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-point overflow |EW| -----→ R

Condition code settings:

- 1 2 3 4 Result in R
- 0 0 0 Zero
- 1 0 Nonzero
- No fixed-point overflow
- 1 0 1 Fixed-point overflow (sign bit on)

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1, the computer traps to Homespace location X'43' after execution of LOAD ABSOLUTE WORD; otherwise, the computer executes the next instruction in sequence.

#### LOAD COMPLEMENT DOUBLEWORD LCD (Doubleword index alignment)

| * |   |   | 1. | A |   |   |   |   | F | 2  |    |    | Х  |    |    |    |    | R  | ef | er | ·eı | ٦c | е  | ac | ht | re | ss |    |    |    |  |
|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|--|
| Ļ | L | 2 | 3  | 1 | 5 | 6 | 7 | 8 | 0 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21  | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 |  |

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 Ru1, 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<sup>63</sup> (X'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

$$\left[-\text{ED}\right]_{32-63} \longrightarrow \text{Ru1}; \left[-\text{ED}\right]_{0-31} \longrightarrow \text{R}$$

Condition code settings:

| 1 | 2 | 3 | 4 | Two's complement of effective doubleword |  |
|---|---|---|---|------------------------------------------|--|
|   |   |   |   |                                          |  |
|   |   |   |   |                                          |  |

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

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1, the computer traps to Homespace location X'43' after execution of LOAD COMPLEMENT DOUBLEWORD; otherwise, the computer executes the next instruction in sequence.

Example 1, even R field value:

|       |   | Before execution    | After execution     |
|-------|---|---------------------|---------------------|
| ED    | = | X'0123456789ABCDEF' | X'0123456789ABCDEF' |
| (R)   | = | ****                | X'FEDCBA98'         |
| (Ru1) | = | ****                | X'76543211'         |
| сс    | = | xxxx                | ×001                |

Example 2, odd R field value:

|     |   | Before execution    | After execution     |
|-----|---|---------------------|---------------------|
| ED  | = | X'0123456789ABCDEF' | X'0123456789ABCDEF' |
| (R) | = | ****                | X'FEDCBA98'         |
| сс  | = | xxxx                | ×001                |

LAD

#### LOAD ABSOLUTE DOUBLEWORD (Doubleword index alignment)

| * |   |   | 1 | В |   |   |   |   | R | 2  |    |    | Х  |    |    |    |    |    | Re | efe | er | en | ce | e ( | bc | dr | es | s  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|
| 6 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21 | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

If the effective doubleword is positive, LOAD ABSOLUTE DOUBLEWORD loads the 32 low-order bits of the effective doubleword into register Ru1, 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 Ru1, 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 high-order 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'80000000000000000), in which case the result in registers R and Ru1 is  $-2^{63}$  and CC2 is set to 1; otherwise, CC2 is reset to 0.

| Affected:            | (R), (Ru1), CC2, | Trap: | Fixed-point overflow |
|----------------------|------------------|-------|----------------------|
|                      | CC3,CC4          |       | -                    |
| ED  <sub>32-63</sub> | Ru1;  ED 0-31    |       | R                    |

Condition code settings:

1 2 3 4 Absolute value of effective doubleword

- 0 0 0 Zero
- - 1 0 Nonzero
- 0 - No fixed-point overflow

- 1 0 1 Fixed-point overflow (sign bit on)

If CC2 is set to 1 and the fixed-point arithmetic trap mask (AM) is a 1, the computer traps to Homespace location X'43' after execution of LOAD ABSOLUTE DOUBLEWORD; otherwise, the computer executes the next instruction in sequence.

Example 1, even R field value:

|       |   | Before execution    | After execution     |
|-------|---|---------------------|---------------------|
| ED    | = | X'0123456789ABCDEF' | X'0123456789ABCDEF' |
| (R)   | = | xxxxxxxx            | X'01234567'         |
| (Ru1) | = | xxxxxxx             | X'89ABCDEF'         |
| CC    | = | xxxx                | ×010                |

#### Example 2, even R field value:

|         | Before execution    | After execution     |
|---------|---------------------|---------------------|
| ED =    | X'FEDCBA9876543210' | X'FEDCBA9876543210' |
| (R) =   | ***                 | X'01234567'         |
| (Rul) = | ****                | X'89ABCDF0'         |
| CC =    | хххх                | ×010                |
|         |                     |                     |

Example 3, odd R field value:

|     |   | Before execution    | After execution     |
|-----|---|---------------------|---------------------|
| ED  | = | X'0123456789ABCDEF' | X'0123456789ABCDEF' |
| (R) | = | xxxxxxx             | X'01234567'         |
| сс  | = | xxxx                | ×010                |

#### LAS LOAD AND SET (Word index alignment)

| * |   |   | 2 | 6 |   |   |   |   | R | ł  |    |    | Х  |    |    |    |    |    | Re | efe | ere | en | ce | c  | d  | dr | es | s  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

LOAD AND SET loads the effective word into R and unconditionally sets bit 0 of the effective word location in memory to 1. Register R contains the previous contents of the effective word location (i.e., before being modified, if required). The effective address always references memory even if it is less than 16.

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

Condition code settings:

| 1 | 2 | 3 | 4 | <u>Result in R</u> |
|---|---|---|---|--------------------|
| - | - | 0 | 0 | <sup>,</sup> Zero  |
| - | - | 0 | 1 | Negative           |
| - | - | 1 | 0 | Positive           |

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

LS LOAD SELECTIVE (Word index alignment)

| * |   |   | 4 | A |   |   |   |   | I | २  |    |    | Х  |    |    |    |    |    | Re | əf | er | e  | ٦c | e  | ac | łd | re | ss |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

Register Ru1 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 Ru1. The contents of register R are not affected in those bit positions selected by a 0 in corresponding bit positions of register Ru1. 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 1'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,  $[EWn(Ru1)]u[(R)n(\overline{Ru1})] \longrightarrow R]$ 

If R is odd,  $EWn(R) \longrightarrow R$ 

Condition code settings:

| 1 | 2 | 3 | 4 | Result in | R |
|---|---|---|---|-----------|---|
|   |   |   |   |           |   |

- - 0 0 Zero.
- - 0 1 Bit O of register R is a 1.
- 1 0 Bit 0 of register R is a 0 and bit positions 1–31 of register R contain at least one 1.

Example 1, even R field value:

|       |   | Before execution | After execution |
|-------|---|------------------|-----------------|
| EW    | = | X'01234567'      | X'01234567'     |
| (Ru1) | = | X'FF00FF00'      | X'FF00FF00'     |
| (R)   | = | ****             | X'01xx45xx'     |
| сс    | = | xxxx             | ××10            |

Example 2, odd R field value:

|     |   | Before execution | After execution |
|-----|---|------------------|-----------------|
| EW  | = | X'89ABCDEF'      | X'89ABCDEF'     |
| (R) | = | X'F0F0F0F0'      | X'80A0C0E0'     |
| СС  | = | xxxx             | ××01            |

#### LM LOAD MULTIPLE (Word index alignment)

| * |   |   | 2 | A |   |   |   |   | R | 2  |    |    | Х  |    |    |    |    |    | Re | efe | ere | en | ce | e c | bb | dr | es | s  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 (R+CC-1)

 $(EWL \longrightarrow R; (EWL+1) \longrightarrow R+1), \dots, (EWL+CC-1) \longrightarrow R+CC-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. In either case, it will be detected before the actual operation begins and the trap will occur immediately.

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 core memory. In this case the results will be unpredictable if any of the source registers are also used as destination registers.

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

| 0 | 02            | CF                    |                         | CC SZN                  |
|---|---------------|-----------------------|-------------------------|-------------------------|
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 | 16 17 18 19 20 21 22 23 | 24 25 26 27 28 29 30 31 |

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 29 through 31 of the instruction word into the floating significance (FS), floating zero (FZ), and floating normalize (FN) mode control bits, respectively (in the program status doubleword); however, if bit 11 is 0, the FS, FZ, and FN control bits are not affected. The functions of the floating-point control bits are described in the section "Floating-Point Arithmetic Instructions".

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

If (I)<sub>10</sub> = 1, (I)<sub>24-27</sub> 
$$\longrightarrow$$
 CC

If  $(I)_{10} = 0$ , CC is not affected.

If (I) 
$$= 1$$
, (I)  $= 7$ , FS, FZ, FN

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

| 1                 | 2                 | 3                   | 4                 |
|-------------------|-------------------|---------------------|-------------------|
| <sup>(I)</sup> 24 | <sup>(I)</sup> 25 | . <sup>(I)</sup> 26 | <sup>(I)</sup> 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 Homespace location X'40' with the condition code unchanged.

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

| * |   |   | 7 | 0 |   |   |   |    |   | с  | F  |    | Х  |    |    |    |    |    | Re | efe | ere | en | ce | e c | b  | dr | es | s  |    |    |    |
|---|---|---|---|---|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 location 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 5 through 7 of the effective byte into the floating significance (FS), floating zero (FZ), and floating normalize (FN) mode control bits, respectively; however, if bit 11 is 0, the FS, FZ, and FN control bits are not affected. The functions of the floating-point mode control bits are described in the section "Floating-Point Arithmetic Instructions".

If (I)<sub>10</sub> = 1,  $EB_{0-3} \longrightarrow CC$ 

If (I) $_{10} = 0$ , CC not affected

If (I)<sub>11</sub> = 1, 
$$EB_{5-7} \longrightarrow FS, FZ, FN$$

If  $(I)_{11} = 0$ , FS, FZ, FN not affected

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

$$\frac{1}{(EB_0)} = \frac{2}{(EB)_1} = \frac{3}{(EB)_2} = \frac{4}{(EB)_3}$$

XW EXCHANGE WORD (Word index alignment)

| * | 46            | R         | x        | Reference address                                  |
|---|---------------|-----------|----------|----------------------------------------------------|
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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

Affected: (R), (EWL), CC3, CC4 (R) ↔ (EWL) Condition code settings:

| 1 | 2 | 3 | 4 | <u>Result in R</u> |
|---|---|---|---|--------------------|
| - | - | 0 | 0 | Zero               |
| - | - | 0 | 1 | Negative           |
| - | - | 1 | 0 | Positive           |
|   |   |   |   |                    |

STORE BYTE

\* 75 R X Reference address

(Byte index alignment)

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

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

STB

STH STORE HALFWORD (Halfword index alignment)

| * |   |   | ţ | 55 |   |   |   |   | R |    |    |    | Х  |    |    |    |    |    |    |    |    |    |    |    |    |    | ess |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

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 (R)<sub>16-31</sub> → EHL

Condition code settings:

- 0 - - (R)<sub>0-16</sub> = all 0's or all 1's.

STW STORE WORD (Word index alignment)

| * |   |   | 3 | 5 |   |   |   |   | R |    |    |    | Х  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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

Affected: (EWL) (R) → EWL

## STORE DOUBLEWORD (Doubleword index alignment)

| * |   |   | 1 | 5 |   |   |   |   | F | र  |    |    | Х  |    |    |    |    |    |    |    |    |    |    |    |    |    | ess | -  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

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 Ru1 into the 32 low-order bit positions of the effective doubleword location.

Affected: (EDL)  
(R) 
$$\longrightarrow$$
 EDL<sub>0-31</sub>; (Ru1)  $\longrightarrow$  EDL<sub>32-63</sub>

Example 1, even R field value:

|         | Before execution      | After execution     |
|---------|-----------------------|---------------------|
| (R) =   | X'01234567'           | X'01234567'         |
| (Ru1) = | X'89ABCDEF'           | X'89ABCDEF'         |
| (EDL) = | ****                  | X'0123456789ABCDEF' |
| Example | 2, odd R field value: |                     |
|         | Before execution      | After execution     |
| (R) =   | X'89ABCDEF'           | X'89ABCDEF'         |

(EDL) = xxxxxxxxxxxxx X'89ABCDEF89ABCDEF'

#### STS STORE SELECTIVE (Word index alignment)

| + |   |   | 4 | 7 |   |   |   |    | F | R  |    |    | Х  |    |    |    |    |    |    |    |    |    |    |    | br |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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) \cap (Ru1)] \cup [EW (\overline{Ru1})] \longrightarrow EWL$ 

If R is odd, (R) u EW-----EWL

| Example | 1, even R field value: |                 |
|---------|------------------------|-----------------|
|         | Before execution       | After execution |
| (R) =   | X' 12345678'           | X' 12345678'    |
| (Ru1) = | X'F0F0F0F0'            | X'F0F0F0F0'     |
| EW =    | ****                   | X'1x3x5x7x'     |
| Example | 2, odd R field value:  |                 |
|         | Before execution       | After execution |

| (R) | = | X'00FF00FF'  | X'00FF00FF' |
|-----|---|--------------|-------------|
| EW  | = | X' 12345678' | C'12FF56FF' |

| STM | STORE  | MULTIPLE |  |
|-----|--------|----------|--|
|     | /s.s./ |          |  |

(Word index alignment)

| * |   |   | 2 | В |   |   |   |   |   | २  |    |    | Х  |    |    |    |    |    | Re | fe | ere | en | ce | e c | bi | dr | es | s  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21  | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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$  EWL, (R+1)  $\longrightarrow$  EWL+1, ..., (R+CC-1)  $\longrightarrow$  EWL+CC-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 any of these cases, the trap will be detected before the actual operation begins and it will occur immediately.

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 in core 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)

| * |   |     |   | 74 | 4 |   |   |   | and a second second |   |   |    |   |    |    | Х  |    |    |     |    |    | Re | əfe | er | en | ce | e c | br | dr | es | s  |    |    |    |
|---|---|-----|---|----|---|---|---|---|---------------------|---|---|----|---|----|----|----|----|----|-----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 1 1 | > | 3  | 4 | 5 | 6 | 7 | T                   | 8 | 0 | 10 | 1 | 11 | 12 | 12 | 14 | 15 | 1.6 | 17 | 10 | 10 | 20  | 21 | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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



Affected: (EBL) (PSD)<sub>0-7</sub>  $\longrightarrow$  EBL

# ANALYZE/INTERPRET INSTRUCTIONS

| ANLZ | ANALYZE                |
|------|------------------------|
|      | (Word index alignment) |

| * | 44            | R           | x           | Reference address                               |
|---|---------------|-------------|-------------|-------------------------------------------------|
| Ļ | 1 2 3 4 5 6 7 | 8 9 10 11 1 | 12 13 14 15 | 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

The ANALYZE instruction evaluates the effective word as a SIGMA 9 instruction. The ANALYZE instruction always sets the condition codes to indicate the addressing type of the analyzed instruction (see condition code settings and Table 7, below). Except when 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 Homespace location X'40' is always the virtual address of the ANLZ instruction.

#### The detailed operation of ANALYZE is as follows:

- 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

| 0-  |     |   |   |   |   | -0 |   |   |    |    |    |    |    | bi |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----|-----|---|---|---|---|----|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 1 | 1 2 | 3 | 4 | 5 | 6 | 7  | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

Halfword

| 0-  |   |   |   |   |   |   | - 0 |   |    |    |    |    |    | oit |    |    |    |    |    |    |    | •  |    |    |    |    |    |    |    |    |  |
|-----|---|---|---|---|---|---|-----|---|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|
| 0 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18  | 9 | 10 | 11 | 12 | 13 | 14 | 15  | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |  |

Word

| P                   |                                                                   |
|---------------------|-------------------------------------------------------------------|
| 00                  | 22-bit word displacement                                          |
|                     |                                                                   |
| 0 1 2 3 4 5 6 7 8 9 | 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

Doubleword



When the ANALYZE instruction is executed in the masterprotected mode and a trap condition occurs, it <u>never</u> traps. 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 5, 6, and 7 of register R to indicate which memory access

<sup>&</sup>lt;sup>†</sup>Note that for real or virtual addressing, byte displacement is 19 bits, halfword displacement is 18 bits, word displacement is 17 bits, and doubleword displacement is 16 bits.

initiated by the ANLZ would have trapped. The meaning of the possible codes in R5-R7 is as follows:

Magning

DE

D۷

D7

0 0 1 The indirect reference of the analyzed instruction 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 R8-R31 contain the virtual address of the indirect reference of the analyzed instruction aligned as a word displacement.

0 1 1 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). R8-R31 contain the effective virtual address of the ANLZ instruction aligned as a word displacement.

1 1 1 An indirect ANLZ instruction where the indirect reference 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 be fetched (nonexistent memory). R8-R31 contain the virtual address of the indirect reference 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 7 shows the SIGMA 9 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'02', X'20', X'21', X'22', or X'23', then CC1 is set to 1, CC2 is set to 0, CC3 is set to 0 (when analyzed instruction specifies direct addressing), and CC4 is set to 1. The decimal equivalent of the condition code setting

#### Table 7. ANALYZE Table for SIGMA 9 Operation Codes

|                      | U                                                | peration Cod                                                                  | Jes                                                                          |                                                                            |
|----------------------|--------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| X'n'                 | X'00'+n                                          | X'20'+n                                                                       | X'40'+n                                                                      | X'60'+n                                                                    |
| 00                   | -                                                | AI                                                                            | TTBS                                                                         | CBS                                                                        |
| 01                   | -                                                | CI                                                                            | TBS #                                                                        | MBS                                                                        |
| 02                   | LCFI (9)                                         | LI                                                                            | - 1                                                                          | –                                                                          |
| 03                   | -                                                | MI                                                                            | -                                                                            | EBS                                                                        |
| 04                   | CAL1                                             | 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                                                                           | OR                                                                           | BCS                                                                        |
| 0A                   | PLM                                              | LM                                                                            | LS                                                                           | BAL                                                                        |
| 0B                   | PSM                                              | STM                                                                           | AND                                                                          | INT                                                                        |
| OC<br>OD<br>OE<br>OF | –<br>LPSD <sup>†</sup> (12)<br>XPSD <sup>†</sup> | LRA <sup>†</sup><br>LMS <sup>†</sup><br>WAIT <sup>†</sup><br>LRP <sup>†</sup> | SIO <sup>†</sup><br>TIO <sup>†</sup><br>TDV <sup>†</sup><br>HIO <sup>†</sup> | RD <sup>†</sup><br>WD <sup>†</sup><br>AIO <sup>†</sup><br>MMC <sup>†</sup> |
| 10                   | AD                                               | AW                                                                            | AH                                                                           | LCF                                                                        |
| 11                   | CD                                               | CW                                                                            | CH                                                                           | CB                                                                         |
| 12                   | LD                                               | LW                                                                            | LH                                                                           | LB                                                                         |
| 13                   | MSP                                              | MTW                                                                           | MTH                                                                          | MTB                                                                        |
| 14                   | –                                                | –                                                                             | –                                                                            | STCF                                                                       |
| 15                   | STD                                              | STW                                                                           | STH <del>II</del>                                                            | STB <b>H</b>                                                               |
| 16                   | –                                                | DW                                                                            | DH (4)                                                                       | PACK ()                                                                    |
| 17                   | –                                                | MW                                                                            | MH                                                                           | UNPK                                                                       |
| 18                   | SD                                               | SW                                                                            | SH                                                                           | DS                                                                         |
| 19                   | CLM                                              | CLR                                                                           | –                                                                            | DA                                                                         |
| 1A                   | LCD                                              | LCW                                                                           | LCH                                                                          | DD                                                                         |
| 1B                   | LAD                                              | LAW                                                                           | LAH                                                                          | DM                                                                         |
| 1C<br>1D<br>1E<br>1F | FSL<br>FAL<br>FDL<br>FML                         | FSS<br>FAS<br>FDS<br>FMS                                                      | -<br>-<br>-                                                                  | DSA<br>DC<br>DL<br>DST                                                     |
|                      |                                                  |                                                                               |                                                                              |                                                                            |

<sup>†</sup>Privileged instructions.

<sup>tt</sup>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.

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 7 should be increased by 2.

Affected: (R), CC

Condition code settings:

| 1 | 2 | 3 | 4 | Instruction addressing type               |
|---|---|---|---|-------------------------------------------|
| 0 | 0 | - | 0 | Byte                                      |
| 0 | 0 | - | 1 | Immediate, byte                           |
| 0 | 1 | - | 0 | Halfword                                  |
| 1 | 0 | - | 0 | Word                                      |
| 1 | 0 | - | 1 | Immediate, word                           |
| 1 | 1 | - | 0 | Doubleword                                |
| - | - | 0 | - | Direct addressing ( $EW_0 = 0$ )          |
| - | - | 1 | - | Indirect addressing (EW <sub>0</sub> = 1) |
|   |   |   |   |                                           |

INT INTERPRET (Word index alignment)

| , | + |     |   | 6 | В |   |   |   | T  |   | R  |    |     | х  |    |    |    |    | R  | efe | ər | e  | ٦C | е  | ad | bb | re | ss |    |    |    |    |
|---|---|-----|---|---|---|---|---|---|----|---|----|----|-----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 |   | 1 2 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 112 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 Ru1 (and loads 0's into bit positions 0-15 of register Ru1, 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 16-31 of the effective word into bit positions 16-31 of register R, and loads 0's 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).

Affected: (R), (Ru1), CC

$$EW_{0-3} \longrightarrow CC$$

$$EW_{4-15} \longrightarrow R_{20-31}; 0 \longrightarrow R_{0-19}$$

$$EW_{16-31} \longrightarrow R_{0} 1_{16-31}; 0 \longrightarrow R_{0} 1_{0-15}$$

Condition code settings:

| 1   | 2  | 3   | 4   |
|-----|----|-----|-----|
| EWO | EW | EW2 | EW3 |

Example 1, even R field value:

|       |   | Before execution | After execution |
|-------|---|------------------|-----------------|
| EW    | = | X'12345678'      | X'12345678'     |
| (R)   | = | ****             | X'00000234'     |
| (Ru1) | = | ****             | X'00005678'     |
| сс    | = | xxxx             | 0001            |

# FIXED-POINT ARITHMETIC INSTRUCTIONS

The following fixed-point arithmetic instructions are included as a standard feature of the SIGMA 9 computer.

| Instruction Name         | <u>Mnemonic</u> |
|--------------------------|-----------------|
| Add Immediate            | AI              |
| Add Halfword             | АН              |
| Add Word                 | AW              |
| Add Doubleword           | AD              |
| Subtract Halfword        | SH              |
| Subtract Word            | SW              |
| Subtract Doubleword      | SD              |
| Multiply Immediate       | MI              |
| Multiply Halfword        | мн              |
| Multiply Word            | MW              |
| Divide Halfword          | DH              |
| Divide Word              | DW              |
| Add Word to Memory       | AWM             |
| Modify and Test Byte     | мтв             |
| Modify and Test Halfword | мтн             |
| 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:

<u>1 2 3 4 Result</u>

- 0 0 Zero – the result in the specified general register(s) is all zeros.

1 2 3 4 Result

- 0 1 Negative the instruction has produced a fixed-point negative result.
- 1 0 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.
- O - No carry for an add or subtract instruction, there was no carry of a 1-bit out of the highorder (sign) bit position of the result.
- 1 - Carry for an add or subtract instruction, there was a 1-bit carry out of the sign bit position of the result. (Subtracting zero will always produce carry.)

#### AI ADD IMMEDIATE (Immediate operand)

| _ |   |   |   |   |   |   |   | - |   |    | _  |    |    |    |    |    |    |    |      | _    |    |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|----|----|----|
| 0 |   |   | 2 | 0 |   |   |   |   | R | 2  |    |    |    |    |    |    |    | ١  | /al  | U    | е  |    |    |    |    |    |    |    |    |    |    |
| 1 |   |   | _ |   |   |   |   |   |   | •  |    |    |    |    |    |    |    |    |      | -    | -  |    |    |    |    |    |    |    |    |    |    |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 2 | 20 3 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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.

| Fixed-point overflow;                            |
|--------------------------------------------------|
| or nonexistent instruc-<br>tion if bit 0 is a 1. |
|                                                  |

Condition code settings:

| 1 | 2 | 3 | 4 | Result in R                  |
|---|---|---|---|------------------------------|
| - | - | 0 | 0 | Zero                         |
| - | - | 0 | 1 | Negative                     |
| - | - | 1 | 0 | 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 computer unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to Homespace location X'40' 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 computer traps to Homespace location X'43' after loading the sum into register R; otherwise, the computer executes the next instruction in sequence.

# AH ADD HALFWORD

(Halfword index alignment)

| * |   |   | 5 | 0 |   |   |   |   |   | R  |    |    | Х  |    |    |    |    | R  | ef | er | er | ٦C | e  | ac | bb | re | \$\$ |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27   | 28 | 29 | 30 | 31 |

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 |
|------------------------|-------|----------------------|
| (R) + EH <sub>SF</sub> | ·     |                      |

Condition code settings:

- <u>1 2 3 4</u> Result in R
- - 0 0 Zero
- - 0 1 Negative
- - 1 0 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 computer traps to Homespace location X'43' after loading the sum into register R; otherwise, the computer executes the next instruction in sequence.

| AW | ADD WORD               |
|----|------------------------|
|    | (Word index alignment) |

| * | 30 | R | х | Reference address |
|---|----|---|---|-------------------|

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

Affected: (R), CC Trap: Fi (R) + EW  $\longrightarrow$  R

Trap: Fixed-point overflow

Condition code settings:

~

| 1 | 2  | 3          | 4 | Result in R                  |
|---|----|------------|---|------------------------------|
| - | -  | 0          | 0 | Zero                         |
| - | -  | 0          | 1 | Negative                     |
| - | -  | 1          | 0 | Positive                     |
| - | 0  | -          | - | No fixed-point overflow      |
| - | 1  | -          | - | Fixed-point overflow         |
| 0 | -  | -          | - | No carry from bit position 0 |
| 1 | -  | -          | - | Carry from bit position 0    |
|   | ~~ | <b>.</b> . |   |                              |

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

#### AD ADD DOUBLEWORD (Doubleword index alignment)

| *        | 10            | R X                | Reference address                                  |
|----------|---------------|--------------------|----------------------------------------------------|
| <u> </u> | 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

ADD DOUBLEWORD adds the effective doubleword to the contents of registers R and Ru1 (treated as a single, 64-bit register); loads the 32 low-order bits of the sum into register Ru1 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 computer traps with the contents in register R unchanged.

| Affected: (R), (Ru1), CC | Trap: | Fixed-point overflow, |
|--------------------------|-------|-----------------------|
| (R, Ru1) + ED → R, Ru1   |       | instruction exception |

Condition code settings:

| 1 | 2 | 3 | 4 | Result | in | R, | Ruʻ | l |
|---|---|---|---|--------|----|----|-----|---|
|   |   |   |   |        |    |    |     |   |

- - 0 0 Zero
- – 0 1 Negative
- - 1 0 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 computer traps to Homespace location X'43' after loading the sum into registers R and Ru1; otherwise, the computer executes the next instruction in sequence.

The R field of the AD instruction must be an even value for proper operation of the instruction; if the R field of AD is an odd value, the instruction traps to Homespace location X'4D', instruction exception trap.

Example 1, even R field value:

|       |   | Before execution   | After execution    |
|-------|---|--------------------|--------------------|
| ED    | = | X'33333333EEEEEEE' | X'33333333EEEEEEE' |
| (R)   | = | יוווווווי×         | X'4444445'         |
| (Ru1) | = | X'33333333'        | X'22222221'        |
| сс    | = | xxxx               | 0010               |

SH SUBTRACT HALFWORD

|   | (L) | L     | :     | ~ 1 | :        |
|---|-----|-------|-------|-----|----------|
| ( | na  | rword | Index | aı  | ignment) |

| * |   |   | 5 | 8 |   |   |   |   |   | R  |    |    | Х  |    |    |    |    | R  | ef | er | e  | nc | e  | a  | bb | re | ss |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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<br>-EH <sub>SE</sub> + (R) $\longrightarrow$ R | Trap: Fixed-point overflow                                             |
|------------------------------------------------------------------|------------------------------------------------------------------------|
| Condition code settings                                          | :                                                                      |
| <u>1234</u> Result in                                            | <u>R</u>                                                               |
| 0 0 Zero                                                         |                                                                        |
| – – 0 1 Negative                                                 |                                                                        |
| 1 0 Positive                                                     |                                                                        |
| - 0 No fixed                                                     | -point overflow                                                        |
| - 1 Fixed-po                                                     | int overflow                                                           |
| 0 – – – No carry                                                 | from bit position 0                                                    |
| 1 – – – Carry fro                                                | m bit position 0                                                       |
|                                                                  | he fixed-point arithmetic trap mask<br>ter traps to Homespace location |

(AM) is a 1, the computer traps to Homespace location X'43' after loading the sum into register R; otherwise, the computer executes the next instruction in sequence.

SW SUBTRACT WORD

(Word index alignment)

| *        | 38            | R           | х        | Reference address                                  |
|----------|---------------|-------------|----------|----------------------------------------------------|
| <u> </u> | 1 2 3 4 5 6 7 | 8 9 10 11 1 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 -EW + (R)  $\longrightarrow$  R

Condition code settings:

1 2 3 4 Result in R

- - 0 0 Zero

– – 0 1 Negative

– – 1 0 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 computer traps to Homespace location X'43' after loading the sum into register R; otherwise, the computer executes the next instruction in sequence.

| SD | SUBTRACT DOUBLEWORD          |
|----|------------------------------|
|    | (Doubleword index alignment) |

| * |     | 18  |   |   |   |   | F | र  |    |    | Х  |    |    |    |    | R  | lei | fe | re | nc | e  | a  | dd | re | ss |    |    |    |    |
|---|-----|-----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 2 | 3 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

SUBTRACT DOUBLEWORD forms the 64-bit two's complement of the effective doubleword, adds the complemented doubleword to the contents of registers R and Ru1 (treated as a single, 64-bit register), loads the 32 low-order bits of the sum into register Ru1 and 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 computer traps with the contents in register R unchanged.

 Trap: Fixed-point overflow, instruction exception

Condition code settings:

1 2 3 4 Result in R, Rul

- - 0 0 Zero
- - 0 1 Negative
- - 1 0 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 computer traps to Homespace location X'43' after the result is loaded into registers R and Ru1; otherwise, the computer 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 Homespace location X'4D', instruction exception trap.

#### MULTIPLY IMMEDIATE (Immediate operand)

MI

| _  |   |   |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |     |    | _  |    |
|----|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|-----|----|----|----|
|    |   |   | 2 | 2 |   |   |   |   | г | ,  |    |    |    |    |    |    |    | `  | 1  | <b>.</b> | _  |    |    |    |    |    |    |     |    |    |    |
| 10 |   |   | 2 | J |   |   |   |   | r | ς  |    |    |    |    |    |    |    | V  | a  | lυ       | е  |    |    |    |    |    |    |     |    |    |    |
|    |   |   |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |     |    |    |    |
| 0  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20       | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 128 | 29 | 30 | 31 |

The value field (bit positions 12-31 of the instruction word) is treated as a 20-bit, two's complement integer. MULTI-PLY 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 Ru1, then loads the 32 high-order bits of the product into register R, and then loads the 32 loworder bits of the product into register Ru1.

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), (Ru1), CC2, CC3, CC4 | Trap: | Nonexistent    |
|-------------------------------------|-------|----------------|
| (Ru1) × (I)<br>12-31SE −−−−► R, Ru1 |       | instruction if |
| 12-3136                             |       | bit 0 is a 1.  |

Condition code settings:

#### 1 2 3 4 64-bit product

- - 0 0 Zero.
- – 0 1 Negative.
- – 1 0 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 computer unconditionally aborts execution of the instruction (at the time of operation code decoding) and traps to Homespace location X'40' with the contents of register R, register Ru1, and the condition code unchanged; otherwise, the computer executes the next instruction in sequence.

#### Example 1, even R field value:

|                      |   | Before execution | After execution |
|----------------------|---|------------------|-----------------|
| <sup>(I)</sup> 12-31 | = | X'70000'         | X'70000'        |
| (R)                  | = | ****             | X'00007000'     |
| (Ru1)                | = | X'10001000'      | ×'70000000'     |
| СС                   | = | xxxx             | ×110            |

Example 2, odd R field value:

|                        | Before execution | After execution |
|------------------------|------------------|-----------------|
| (I) <sub>12-31</sub> = | X'01234'         | X'01234'        |
| (R) =                  | X'00030002'      | X'369C2468'     |
| CC =                   | xxxx             | ×010            |

#### MH MULTIPLY HALFWORD (Halfword index alignment)

|   |           | 1            | 1         |                                                    |
|---|-----------|--------------|-----------|----------------------------------------------------|
|   | 57        | D            |           | Reference address                                  |
| 1 | 1 57      |              |           | Reference address                                  |
|   | 1 .       |              |           |                                                    |
| 0 | 1 2 3 4 5 | 6 7 8 9 10 1 | 112 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 Ru1 (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: (Ru1), CC3, CC4 (R) $_{16-31} \times EH \longrightarrow Ru1$ 

Condition code settings:

1 2 3 4 Result in Rul

- - 0 0 Zero

– – 0 1 Negative

- - 1 0 Positive

Example 1, even R field value:

|       |   | <b>Before execution</b> | After execution |
|-------|---|-------------------------|-----------------|
| EH    | = | X'FFFF'                 | X'FFFF'         |
| (R)   | = | X'xxxx000A'             | X'xxxx000A'     |
| (Ru1) | = | ****                    | X'FFFFFF6'      |
| CC    | = | xxxx                    | ××01            |

#### Example 2, odd R field value:

|      |   | Before execution | After execution |
|------|---|------------------|-----------------|
| EH 🕔 | = | X'FFFF'          | X'FFFF'         |
| (R)  | = | X'xxxx000A'      | X'FFFFFFF6'     |
| сс   | = | xxxx             | ××01            |

#### MW MULTIPLY WORD (Word index alignment)

| *        | 37          |       | R       | х        | Reference address                                  |
|----------|-------------|-------|---------|----------|----------------------------------------------------|
| <u>ل</u> | 1 2 3 4 5 6 | 7 8 9 | 2 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 low-order bits of the product into register Rul (overflow cannot occur).

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.

Affected: (R), (Ru1), CC $(Ru1) \times EW \longrightarrow R, Ru1$ 

Condition code settings:

- 1 2 3 4 64-bit product
- - 0 0 Zero.
- - 0 1 Negative.
- - 1 0 Positive.
- 0 - Result is correct, as represented in register Ru1.
- 1 0 0 Result is not correctly representable in register Rul alone.

DH DIVIDE HALFWORD

(Halfword index alignment)

| * |   |   | 5 | 6 |   |   |   |   | F | 2  |    |    | Х  |    |    |    |    |    |    |    |    |    |    | a  |    |    |    | ·  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 CC1, CC3, and CC4 are unchanged.

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

Condition code settings:

- 1 2 3 4 Result in R
- 0 0 0 Zero quotient, no overflow.
- 0 1 Negative quotient, no overflow.
- 1 0 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 computer traps to Homespace location X'43' with the contents of register R, CC1, CC3, and CC4 unchanged.

#### DW **DIVIDE WORD** (Word index alignment)

| * | 36            | R         | х        | Reference address                                  |
|---|---------------|-----------|----------|----------------------------------------------------|
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 Ru1, CC1, CC3, and CC4 remain unchanged; otherwise, CC2 is reset to 0, CC3 and CC4 reflect the quotient in register Ru1, and CC1 is unchanged.

Affected: (R), (Ru1), CC2 Trap: Fixed-point overflow CC3, CC4  $(R, Ru1) \div EW \longrightarrow R$  (remainder), Ru1(quotient)

Condition code settings:

- 1 2 3 4 Result in Ru1
- 0 0 0 Zero quotient, no overflow.
- 0 1 Negative quotient, no overflow. 0

#### 1 2 3 4 Result in Ru1

- 0 1 0 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 computer traps to Homespace location X'43' with the original contents of register R, register Ru1, CC1, CC3, and CC4 unchanged; otherwise, the computer executes the next instruction in sequence.

#### ADD WORD TO MEMORY AWM (Word index alignment)

| * |   |   | ( | 66 | , |   |   |   | F | २  |    |    | Х  |    |    |    | _  |    | Re | efe | ere | en | ce | e c | d  | dr | es | s  |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 |
|--------------------------------|-------|----------------------|
| $EW + (R) \longrightarrow EWL$ |       |                      |

Condition code settings:

- 1 2 3 4 Result in EWL
- 0 0 Zero
- 0 1 Negative
- 1 0 Positive
- - No fixed-point overflow 0
- 1 - Fixed-point overflow
- - No carry from bit position 0 0
- 1 - Carry from bit position 0

If CC2 is set to 1 and fixed-point arithmetic trap mask (AM) is a 1, the computer traps to Homespace location X'43' after the result is stored in the effective word location; otherwise, the computer executes the next instruction in sequence.

#### MTB MODIFY AND TEST BYTE (Byte index alignment)

| * |   |   |   | 73 | } |   |   |   | I | २  |    |    | Х  |    |    |    |    | 1  | Re | fe | re | ene | ce | a  | do | dre | ess | 5  |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22  | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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

Affected: CC if (I)<sub>8-11</sub> = 0; (EBL) and CC if (I)<sub>8-11</sub>  $\neq 0$ 

If (I) $_{8-11} \neq 0$ , EB + (I) $_{8-11SE} \longrightarrow EBL$  and set CC

If 
$$(I)_{8-11} = 0$$
, test byte and set CC

Condition code settings:

| 1 | 2 | 3 | 4 | Resu | lt. | in | EBL |  |
|---|---|---|---|------|-----|----|-----|--|
|   |   |   |   |      |     |    |     |  |

- 0 0 0 Zero

- 0 1 0 Nonzero

0 – – – No carry from byte

1 - - - Carry from byte

If MTB is executed in an interrupt location<sup>†</sup>, the condition code is not affected (see Chapter 2, "Single–Instruction Interrupts").

#### MTH MODIFY AND TEST HALFWORD (Halfword index alignment)

| * |   |   |   | 53 | } |   |   |   |   | R  |    |    | Х  |    |    |    |    |    | Ref  | er | en   | ce | e o | dd | dre | es | s  |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|------|----|------|----|-----|----|-----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 2 | 02 | 1 22 | 23 | 24  | 25 | 26  | 27 | 28 | 29 | 30 | 31 |

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 (I)<sub>8-11</sub> = 0; Trap: Fixed-point overflow (EHL) and CC if (I)<sub>8-11</sub>  $\neq$  0

If  $(I)_{8-11} = 0$ , test halfword and set CC

If (I)<sub>8-11</sub>  $\neq$  0, EH + (I)<sub>8-11SE</sub>  $\longrightarrow$  EHL and set CC

Condition code settings:

| 1 | 2 | 3 | 4 | Result in EHL           |
|---|---|---|---|-------------------------|
| - | - | 0 | 0 | Zero                    |
| - | - | 0 | 1 | Negative                |
| - | - | 1 | 0 | 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 computer traps to Homespace location X'43' after the result is stored in the effective halfword location; otherwise, the computer executes the next instruction in sequence. However, if MTH is executed in an interrupt location<sup>†</sup>, the condition code is not affected (see Chapter 2, "Single-Instruction Interrupts".

#### MTW MODIFY AND TEST WORD (Word index alignment)

| *        |            |   | 3 | 3  |   |   |   |    | R | 2  |    | 2   | Х  |    |    |    |    | Re | efe  | re   | nc | e | 0  | ide | dr | es | s  |    |    |      | ] |
|----------|------------|---|---|----|---|---|---|----|---|----|----|-----|----|----|----|----|----|----|------|------|----|---|----|-----|----|----|----|----|----|------|---|
| <u> </u> | <u>ب</u> ـ | ~ |   | h  |   |   |   |    | _ |    |    | L   |    |    | _  |    |    | •  | -    |      |    |   |    | _   |    |    |    |    |    |      |   |
| 0        | 1          | 2 | 3 | 14 | 5 | 6 | 1 | 18 | 9 | 10 | 11 | 112 | 13 | 14 | 15 | 16 | 17 | 18 | 19 2 | 20 2 | 12 | 2 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 3 | 1 |

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 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 the condition code is set according to the value of the resultant

<sup>&</sup>lt;sup>t</sup>Other than counter 4, which uses the current active addressing mode (real, real extended, or virtual).

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: CC if (I)<sub>8-11</sub> = 0; Trap: Fixed-point overflow (EWL) and CC if (I)<sub>8-11</sub>  $\neq$  0

If  $(I)_{8-11} = 0$ , test word and set CC

If (I)
$$_{8-11} \neq 0$$
, EW + I $_{8-11SE}$  ------EWL and set CC

Condition code settings:

| 1 | 2 | 3 | 4 | Result in EWL |
|---|---|---|---|---------------|
|   |   |   |   |               |

- - 0 0 Zero
- - 0 1 Negative
- - 1 0 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 (AM) is a 1, the computer traps to Homespace location X'43' after the result is stored in the effective word location; otherwise, the computer executes the next instruction in sequence. However, if MTW is executed in an interrupt location<sup>†</sup>, the condition code is not affected (see Chapter 2, "Single-Instruction Interrupts".

## **COMPARISON INSTRUCTIONS**

The following comparison instructions are available to SIGMA 9 computers:

| Instruction Name  | Mnemonic |
|-------------------|----------|
| Compare Immediate | CI       |
| Compare Byte      | СВ       |
| Compare Halfword  | СН       |
| Compare Word      | CW       |

| Instruction Name                | Mnemonic |
|---------------------------------|----------|
| Compare Doubleword              | CD       |
| Compare Selective               | CS       |
| Compare With Limits in Register | CLR      |
| Compare With Limits in Memory   | CLM      |

All SIGMA 9 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 COMPARE IMMEDIATE (Immediate operand)

| 0 |   |   | 2 | 1 |   |   |   |   | R |    |    |    |    |    |    |    |    | ١  | /a | lυ | e  |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 the results of the comparison.

Affected: CC2,CC3,CC4 (R): (I) 12-31SE

Condition code settings:

- 1 2 3 4 Result of Comparison
- - 0 0 Equal.
- - 0 1 Register value less than immediate value.
- 1 0 Register value greater than immediate value.
- 0 - No 1-bits compare, (R) (I) 12-325F = 0.
- 1 One or more 1-bits compare, (R)  $\cap$  (I)<sub>12-325E</sub>  $\neq$  0.

If CI 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 then traps to Homespace location X'40' with the condition code unchanged.

CB COMPARE BYTE (Byte index alignment)

| * |   |   | 7 | 1 |   |   |   |   | F | 2  |    |    | Х  |    |    |    |    | Re | efe | re | en | ce | ; c | d  | dr | es | s  |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23  | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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)<sub>24-31</sub>: <sup>EB</sup>

Condition code settings:

| 1 | 2 | 3 | 4 | Result of | Comparison |
|---|---|---|---|-----------|------------|
|---|---|---|---|-----------|------------|

- - 0 0 Equal.
- - 0 1 Register byte less than effective byte.
- - 1 0 Register byte greater than effective byte.
- 0 - No 1-bits compare, (R)<sub>24-31</sub> n EB = 0.
- 1 - One or more 1-bits compare, (R)<sub>24-31</sub> ∩ EB ≠ 0.

#### CH COMPARE HALFWORD (Halfword index alignment)

| * | 51            | R         | х        | Reference address                                  |
|---|---------------|-----------|----------|----------------------------------------------------|
| Ļ | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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) : EH<sub>SF</sub>

Condition code settings:

- 1 2 3 4 Result of Comparison
- - 0 0 Equal.
- 0 1 Register word less than effective halfword with sign extended.
- 1 0 Register word greater than effective halfword with sign extended.
- 0 - No 1-bits compare, (R)  $\cap$  EH<sub>SE</sub> = 0.
- 1 One or more 1-bits compare, (R)  $\cap EH_{SF} \neq 0$ .

CW COMPARE WORD

(Word index alignment)

| * |   |   |   | 3 | 31 |   |   |   |   |   |   | F | 2  |    |    | Х  |    |    |    |    | Re | əf | er | en | ce | e o | d  | dr | es | s  |    |    |    |    |
|---|---|---|---|---|----|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|
| 0 | 1 | 1 | 2 |   | 3  | 4 | 5 | 6 | 7 | t | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23  | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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:

| 1 2 3 4 Result of Compa | arison |
|-------------------------|--------|
|-------------------------|--------|

- - 0 0 Equal.
- - 0 1 Register word less than effective word.
- - 1 0 Register word greater than effective word.
- 0 - No 1-bits compare, (R) n EW = 0.
- 1 - One or more 1-bits compare, (R)  $\cap EW \neq 0$ .
- CD COMPARE DOUBLEWORD

#### (Doubleword index alignment)

| * |   |  | 1 |   |   |   |   |   | F | 2  |    |    | Х  |    |    |    |    | Re | efe | er | en | ce | e o | b  | dr | es | s  |    |    |    |    |
|---|---|--|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|
| 0 | 1 |  | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23  | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

COMPARE DOUBLEWORD compares the effective doubleword with the contents of registers R and Ru1 (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 CD is an odd value, CD 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-bit register operand. The condition code settings are based on the 64-bit comparison.

Affected: CC3,CC4 (R,Ru1): ED

Condition code settings:

- 1
   2
   3
   4
   Result of Comparison

   0
   0
   Equal.

   0
   1
   Register doubleword less
  - 0 1 Register doubleword less than effective doubleword.
  - 1 0 Register doubleword greater than effective doubleword.

CS

#### COMPARE SELECTIVE (Word index alignment)

| * |   |   | 4 | 5 |   |   |   |   | F | 2  |    |    | х  |    |    |    |    | Re | əf | er | en | ce | э ( | ad | dr | es | s  |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23  | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 Ru1 (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 Ru1. 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 CS 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)  $\cap$  (Ru1) : EW  $\cap$  (Ru1) If R is odd: (R) : EW  $\cap$  (R)

#### Condition code settings:

1 2 3 4 Results of Comparison under Mask in Rul

- - 0 0 Equal.
- - 0 1 Register word less than effective word.
- 1 0 Register word greater than effective word. (if R is even)

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

| * |   |   | 3 | 9 |   |   |   |    |     | R   |   |    |    | Х  |    |    |    |    | Re | efe | er | en | Ce | e ( | ad | dr | es | s  |    |    |    |    |  |
|---|---|---|---|---|---|---|---|----|-----|-----|---|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|--|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 8 9 | 7 1 | 0 | nl | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23  | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |  |

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

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

Condition code settings:

1 2 3 4 Result of Comparison

- - 0 0 Contents of R equal to effective word.
- - 0 1 Contents of R less than effective word.
- - 1 0 Contents of R greater than effective word.
- 0 0 - Contents of Rul equal to effective word.
- 0 1 - Contents of Rul less than effective word.
- 1 0 - Contents of Rul greater than effective word.

CLM COMPARE WITH LIMITS IN MEMORY (Doubleword index alignment)

| * |   |   | 1 | 19 | > |   |   |   |   | F | {  |    |    | Х  |    |    |    |    |    |    | fe |    |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 |    | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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) : ED<sub>0-31</sub>; (R) : ED<sub>32-63</sub>

Condition code settings:

- 1 2 3 4 Result of Comparison
  - 0 0 Contents of R equal to most significant word, (R) = ED<sub>0-31</sub>.
- 0 1 Contents of R less than most significant word, (R) < ED<sub>0-31</sub>.
- - 1 0 Contents of R greater than most significant word,  $(R) > ED_{0-31}$ .
- 0 1 Contents of R less than least significant word, (R)  $< ED_{32-63}$
- 1 0 - Contents of R greater than least significant word, (R) > ED<sub>32-63</sub>.

## 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 OR WORD (Word index alignment)

| * |   |   | 4 | .9 |   |   |   |   | F | 2  |    |    | Х  |    |    |    |    |    |    |    |    |    |    |    | dc |    |    |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 14 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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$  EW  $\longrightarrow$  R, where  $0 \cup 0 = 0, 0 \cup 1 = 1, 1 \cup 0 = 1, 1 \cup 1 = 1$ 

Condition code settings:

1 2 3 4 Result in R

- - 0 0 Zero.

- – 0 1 Bit O of register R is a 1.
- 1 0 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)

| * |   |   | 4 | 8 |   |   |   |   | F | 2  |    |    | Х  |    |    |    |    |    |    |    |    |    |    |    |    |    | ess |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

EXCLUSIVE OR WORD logically exclusive ORs the effective word into register R. If corresponding bits of register R and the effective word are different, a 1 is 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) 0 EW  $\xrightarrow{}$  R, where 0 0 0 = 0, 0 0 1 = 1, 1 0 0 = 1, 1 0 1 = 0

Condition code settings:

| 1 | 2 | 3 | 4 | Result in | R |
|---|---|---|---|-----------|---|
|   |   |   |   |           |   |

- - 0 0 Zero.
- – 0 1 Bit O of register R is a 1.
- 1 0 Bit 0 of register R is a 0 and bit positions 1–31 of register R contain at least one 1.

AND AND WORD (Word index alignment)

| *        | 4B            | R X                | Reference address                                  |
|----------|---------------|--------------------|----------------------------------------------------|
| <u>ب</u> | 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 (R)  $\cap EW \longrightarrow R$ , where  $0 \cap 0 = 0$ ,  $0 \cap 1 = 0$ ,  $1 \cap 0 = 0$ ,  $1 \cap 1 = 1$  Condition code settings:

| 1 | 2 | 3 | 4 | Result | in | R |
|---|---|---|---|--------|----|---|
|   |   |   |   |        |    |   |

- - 0 0 Zero.
- 0 1 Bit O of register R is a 1.

 – 1 0 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<br>(Word index alignment) |
|---|---------------------------------|
|   |                                 |

|   |     | 2 | 5 |   |   |   |   |   | П  |    |    | v  |    |    |    |    |    | Re | fe | re | ene | ce | a  | dc | łre | ess |    |    |    | ٦  |
|---|-----|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|-----|----|----|----|----|
| ľ | 25  |   |   |   |   |   |   | 1 | ĸ  |    |    | X  |    |    |    |    |    |    |    | Ty | yp  | е  |    |    | C   | lo  | υn | t  |    |    |
| 0 | 1 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22  | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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 | 22 | 23 | Shift Type                  |
|----|----|----|-----------------------------|
| 0  | 0  | 0  | Logical, single register    |
| 0  | 0  | 1  | Logical, double register    |
| 0  | 1  | 0  | Circular, single register   |
| 0  | 1  | 1  | Circular, double register   |
| 1  | 0  | 0  | Arithmetic, single register |
| 1  | 0  | 1  | Arithmetic, double register |
| 1  | 1  | 0  | Searching, single register  |
| 1  | 1  | 1  | Searching, double register  |
|    |    |    |                             |

Shift Instructions 67

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 \le C \le +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 highorder 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 2 3 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 R<sup>†</sup>.
- 0 - No overflow on left shift.
- 1 - Overflow on left shift.
- – 1 Searching shift terminated with R<sub>0</sub> equal 1.

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

1 2 3 4

0 0 - -

Logical Shift, Single Register

| * | 25            | D         | V           | Reference address                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|---------------|-----------|-------------|---------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
|   | 25            | ĸ         |             | 000 Count                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 14 | 5 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |

If the shift count, C, is positive, the contents of register R are shifted left C places, with 0's copied into vacated bit

68 Shift Instructions

positions on the right. (Bits shifted past R<sub>0</sub> 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<sub>31</sub> are lost.)

Affected: (R), CC1, CC2

Logical Shift, Double Register

| * | 25            | D           | v       | Reference address                                  |
|---|---------------|-------------|---------|----------------------------------------------------|
|   | 25            | К           | ^       | 001 Count                                          |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 1 | 2 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

If the shift count, C, is positive, the contents of registers R and Ru1 are shifted left C places, with 0's copied into vacated bit positions on the right. Bits shifted past bit position 0 of register Ru1 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 Ru1 are shifted right |C| 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 Ru1. (Bits shifted past Ru1 are lost.)

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

Circular Shift, Single Register

|   | 05            | -         | V          | Reference address                                  |
|---|---------------|-----------|------------|----------------------------------------------------|
| Î | 25            | к         |            | 0 1 0 Count                                        |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 1 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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), CC1, CC2

Circular Shift, Double Register

| <u>.</u> | 25 |   |   |    |   |   | Γ |   |   |    | v  | Γ  | Reference address |    |    |    |    |    |    |    |    |    |    |      |    |     |        |      |      |    |
|----------|----|---|---|----|---|---|---|---|---|----|----|----|-------------------|----|----|----|----|----|----|----|----|----|----|------|----|-----|--------|------|------|----|
| *        | 25 |   |   |    |   |   | ŀ | ł |   |    | х  |    |                   |    |    |    |    |    | 0  | 1  | 1  | *  |    | 1    | Ç  | our | nt     |      |      |    |
| 0        | 1  | 2 | 3 | 14 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13                | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 2 | 52 | 6   | 27   2 | 28 2 | 7 30 | 31 |

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), (Ru1), CC1, CC2

Arithmetic Shift, Single Register

| [ | 05            |           | ~           | Reference address                               |
|---|---------------|-----------|-------------|-------------------------------------------------|
| Ĺ | 25            | ĸ         | X           | 100 Count                                       |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 15 | 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

If the shift count, C, is positive, the contents of register R are shifted left C places, with 0's copied into

<sup>&</sup>lt;sup>r</sup>Not applicable for searching shift.

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), CC1, CC2

#### Arithmetic Shift, Double Register

|   |   |   | 2 | 5 |   |   |   |    | C | ,  |    |     | v  |    |    |    |    | R  | e  | fei | e  | nc | е  | ac | bk | re | SS |    |    |    |    |
|---|---|---|---|---|---|---|---|----|---|----|----|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|
| Ĺ |   |   | 2 | 5 |   |   |   |    | г | `  |    |     |    |    |    |    |    |    |    |     | 1  | 0  |    |    |    |    | ~  | ~  | Jn | •  |    |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 112 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

If the shift count, C, is positive, the contents of registers R and Ru1 are shifted left C places, with 0's copied into vacated bit positions on the right. Bits shifted past bit position 31 of register Ru1 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 Ru1 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 Ru1. (Bits shifted past Ru1are left.)

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

## Searching Shift, Single Register

| <u>ا</u> | Τ |   |    | ~  | -  |    |    |     |    |    |    |    |       | V  |    |    |    |    | R    | ef | er | e  | ۱c  | е  | ac  | bk | re | ss |     |    |    |    |
|----------|---|---|----|----|----|----|----|-----|----|----|----|----|-------|----|----|----|----|----|------|----|----|----|-----|----|-----|----|----|----|-----|----|----|----|
| Î        |   |   |    | 2  |    |    |    |     |    | R  | (  |    |       | X  |    |    |    |    |      |    |    | 1  | 1   | 0  |     |    |    | Cq |     |    |    |    |
| 0        |   | 1 | 2  | 3  | 4  | 5  | 6  | 7   | 8  | 9  | 10 | 11 | 12    | 13 | 14 | 15 | 16 | 17 | 18   | 19 | 20 | 21 | 22  | 23 | 24  | 25 | 26 | 27 | 28  | 29 | 30 | 31 |
| Т        | h | е | se | ea | rc | hi | ng | y s | hi | ft | is | c  | ; i r | cu | ١l | ar | in | e  | ei t | he | er | di | ire | ec | tic | on | •  | If | i t | hε | e  |    |

shift count, C, is positive, the contents of register R are 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 CC2 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

| Ţ   |   |   | 2 | E |   |   |   |    | r |    |    |    | v  |    |    |    |    | R  | ef | er | e  | ٦C | е  | ac | d  | re | ss |    |    |    |    |
|-----|---|---|---|---|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| l°. |   |   | 2 | 5 |   |   |   |    | r | ς  |    |    | ^  |    |    |    |    |    |    |    | 1  | 1  | 1  |    |    |    | Cç | วบ | nt |    |    |
| 0   | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 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 CC2 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), (Ru1), CC2, CC4

#### FLOATING-POINT SHIFT

Floating-point numbers are defined in the "Floating-Point Arithmetic Instructions" section. The format for the floating-point shift instruction is:

| SF | Shift floating                         |          |
|----|----------------------------------------|----------|
|    | (Word index alignment)                 |          |
|    | (····································· | <i>'</i> |

| Ļ | 24 | D | V | Reference | address |
|---|----|---|---|-----------|---------|
| Ĺ | 24 | ĸ | ^ | D         | 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 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 position 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:

 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, CC1 is set to 1.

- 2. If the fraction field is all 0'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.
- 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 1'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 registers(s).
- 5. The condition code settings following a floating-point left shift are as follows:
  - 1 2 3 4 Result
  - – 0 0 True zero (all 0's).
  - - 0 1 Negative.
  - - 1 0 Positive.
  - 0 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):

- 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'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'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:

| 1 | 2 | 3 | 4 | Result                                          |
|---|---|---|---|-------------------------------------------------|
| - | - | 0 | 0 | True zero (all zeros).                          |
| - | - | 0 | 1 | Negative.                                       |
| - | - | 1 | 0 | Positive.                                       |
| 0 | 0 | - | - | C  digits shifted (no characteristic overflow). |

0 1 - - Characteristic overflow.

Floating Shift, Single Register

| Ţ | 24            | <b>_</b>   | V        | Reference address                                  |
|---|---------------|------------|----------|----------------------------------------------------|
| Î | 24            | ĸ          |          | 0 Count                                            |
| 0 | 1 2 3 4 5 6 2 | 8 9 .10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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

Affected: (R), CC

Floating Shift, Double Register

| Ţ | 24            |           | V        | Reference                  | address                 |
|---|---------------|-----------|----------|----------------------------|-------------------------|
| Ĺ | 24            | к         | X        | 1                          | Count                   |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 | 24 25 26 27 28 29 30 31 |

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), (Ru1), CC

## **CONVERSION INSTRUCTIONS**

The following two conversion instructions are provided by the SIGMA 9 computer:

| 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 Ru1. 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 CPU registers until the instruction is completed; the result is then loaded into the appropriate general register. Both instructions use a counter (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 have 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)

|   | [             |           |          |                                                    |
|---|---------------|-----------|----------|----------------------------------------------------|
| * | 20            | D         | V I      | Reference address                                  |
|   | 27            |           | ~        | Reference dadress                                  |
|   |               |           |          |                                                    |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 nth 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}$ , CC1 is set to 1; otherwise, CC1 is reset to 0.

Affected: (R), CC1, CC3, CC4 0  $\longrightarrow$  A, 0  $\longrightarrow$  n

If  $(Ru1)_n = 1$ , then  $(EWL + n) + (A) \longrightarrow A$ ,  $n + 1 \longrightarrow n$ 

If  $(Ru1)_n = 0$ , then  $n + 1 \longrightarrow n$ 

If n < 32, repeat; otherwise, (A)  $\longrightarrow R$  and continue to next instruction.

Condition code settings:

1 2 3 4 Result in R

- - 0 0 Zero.

– – 0 1 Bit O of register R is a 1.

<u>1 2 3 4</u> Result in R

- - 1 0 Bit 0 of register R is a 0 and bit positions 1-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.

CVS CONVERT BY SUBTRACTION (Word index alignment)

| * |   |   | 2 | 28 | ; |   |   |   |   |   | R  |    |    | Х  |    |    |    |    | R  | e  | fei | rei | nc | e  | a  | bb | re | ss |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | Г  | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 nth 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 nth 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 nth 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), (Ru1), CC3, CC4

- $(R) \longrightarrow A, 0 \longrightarrow B; 0 \longrightarrow n$
- If  $(EWL + n) \le (A)$  then  $A (EWL + n) \longrightarrow A$ ,  $1 \longrightarrow B_n$ ,  $n + 1 \longrightarrow n$

If (EWL + n) > (A) then  $n + 1 \rightarrow n$ 

If n < 32, repeat; otherwise, (A)  $\longrightarrow R$ , (B)  $\longrightarrow Ru1$  and continue to the next instruction.

Condition code settings:

- <u>1 2 3 4</u> Result in Ru1
- - 0 0 Zero.
- - 0 1 Bit O of register Rulis a 1.
- 1 0 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 following floating-point arithmetic instructions are available to SIGMA 9 computers:

| Instruction Name        | Mnemonic |
|-------------------------|----------|
| Floating Add Short      | FAS      |
| Floating Add Long       | FAL      |
| Floating Subtract Short | FSS      |
| Floating Subtract Long  | FSL      |
| Floating Multiply Short | FMS      |
| Floating Multiply Long  | FML      |
| Floating Divide Short   | FDS      |
| Floating Divide Long    | FDL      |
|                         |          |

#### **FLOATING-POINT NUMBERS**

SIGMA 9 accommodates two number formats for floatingpoint arithmetic: short and long. A short-format floatingpoint number consists of a sign (bit 0), a biased<sup>†</sup>, 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 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 SIGMA 9 floating-point number (N) has the following format:

+ Character-- istic (C) 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

Extra Fractional Precision

A floating-point number (N) has the following formal definition:

1. N = F x  $16^{C-64}$  where F = 0 or  $16^{-6} \le |F| \le 1$  (short format) or

 $16^{-14} \le |\mathsf{F}| \le 1$  (long format)

and  $0 \le C \le 127$ .

- 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, 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 ≤ 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 1111 0000 ... 0000

is normalized, and a floating-point number of the form

1xxx xxxx 0000 0000 ... 0000

is illegal and, whenever generated by floating-point instructions, is converted to the form

1ууу уууу 1111 0000 ... 0000

where yy ... y is 1 less than xx ... x. Table 8 contains examples of floating-point numbers.

#### Modes of Operation

SIGMA 9 contains three mode control bits that are used to qualify floating-point operations. These mode control bits are identified as FS (floating significance), FZ (floating zero), and FN (floating normalize), and are contained in bit positions 5, 6, and 7, respectively, of the program status doubleword (PSD<sub>5-7</sub>).

The floating-point mode is established by setting the three 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<br>Immediate | LCFI     |
| Load Program Status Doubleword                    | LPSD     |
| Exchange Program Status Doubleword                | XPSD     |

<sup>&</sup>lt;sup>t</sup>The bias value of 40<sub>16</sub> 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.

|                                  |             |                |        | ring-roi  |         |      |      |      |      |     |                |
|----------------------------------|-------------|----------------|--------|-----------|---------|------|------|------|------|-----|----------------|
|                                  |             |                |        | nort Floo | ating-P |      | rmat |      |      |     |                |
| Decimal Number                   | ±           | С              |        |           |         | F    |      |      |      | He× | adecimal Value |
| $+(16^{+63})(1-2^{-24})$         | 0           | 111            | 1111   | 1111      | 1111    | 1111 | 1111 | 1111 | 1111 | 7F  | FFFFF          |
| +(16 <sup>+3</sup> )(5/16)       | 0           | 100            | 0011   | 0101      | 0000    | 0000 | 0000 | 0000 | 0000 | 43  | 500000         |
| +(16 <sup>-3</sup> )(209/256)    | 0           | 011            | 1101   | 1101      | 0001    | 0000 | 0000 | 0000 | 0000 | 3D  | D10000         |
| +(16 <sup>-63</sup> )(2047/4096) | 0           | 000            | 0001   | 0111      | 1111    | 1111 | 0000 | 0000 | 0000 | 01  | 7FF000         |
| +(16 <sup>-64</sup> )(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         |
| -(16 <sup>-64</sup> )(1/16)      | 1           | 111            | 1111   | 1111      | 0000    | 0000 | 0000 | 0000 | 0000 | FF  | F00000         |
| -(16 <sup>-63</sup> )(2047/4096) | 1           | 111            | 1110   | 1000      | 0000    | 0001 | 0000 | 0000 | 0000 | FE  | 801000         |
| -(16 <sup>-3</sup> )(209/256)    | 1           | 100            | 0010   | 0010      | 1111    | 0000 | 0000 | 0000 | 0000 | C2  | 2F0000         |
| -(16 <sup>+3</sup> )(5/16)       | 1           | 011            | 1100   | 1011      | 0000    | 0000 | 0000 | 0000 | 0000 | BC  | B00000         |
| $-(16^{+63})(1-2^{24})$          | 1           | 000            | 0000   | 0000      | 0000    | 0000 | 0000 | 0000 | 0001 | 80  | 000001         |
| Special Case                     |             |                |        |           |         |      |      |      |      |     |                |
| -(16 <sup>e</sup> )(1)           | 1           | e              |        | 0000      | 0000    | 0000 | 0000 | 0000 | 0000 |     |                |
| is changed to                    |             |                |        |           |         |      |      |      |      |     |                |
| -(16 <sup>e+1</sup> )(1/16)      | 1           | <del>e +</del> | ī      | 1111      | 0000    | 0000 | 0000 | 0000 | 0000 |     |                |
| whenever generated as the        | e result of | a float        | ing-po | int instr | uction. |      |      |      |      |     |                |

Table 8. Floating-Point Number Representation

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 Doubleword    | XPSD     |

#### FLOATING-POINT ADD AND SUBTRACT

The 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:

FN Floating normalize:

FN = 0 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 an 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 FZ = 0, an underflow generated in the process of postnormalizing is ignored.)
- FZ = 1 Characteristic underflow causes the computer to trap to Homespace location X'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 FN = 0)

- FS = 0 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 computer executes the next instruction in sequence. If more than two hexadecimal places of postnormal-ization shifting are required and character-istic 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 computer executes the next instruction in sequence. (Exception: if characteristic underflow occurs with FS = 0, FZ determines the resultant action.)
- FS = 1 The computer traps to Homespace location X'44' 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 FZ = 1, the results of significance testing are ignored.)

If characteristic overflow occurs, the CPU always traps to Homespace 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 zero (FZ) mode control bit alone determines the operation of floating-point multiplication and division (if characteristic overflow does not occur and division by zero is not attempted) as follows:

FZ Floating zero:

- FZ = 0 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 computer to trap to Homespace 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 FZ = 0.

If the divisor is zero in a floating-point division, the computer always traps to Homespace location X'44' with the general registers unchanged and the condition code set to 0100. If characteristic overflow occurs, the computer always traps to Homespace 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.

#### CONDITION CODES FOR FLOATING-POINT INSTRUCTIONS

The condition code settings for floating-point instructions are summarized in Table 9. The following provisions apply to all floating-point instructions:

- 1. Underflow 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 and truncation 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 (Word index alignment)

| * | 3D            | R         | х        | Reference address                                  |
|---|---------------|-----------|----------|----------------------------------------------------|
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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,

| Coi               | nditic      | on Co        | ode         | Meaning If No Trap to Homespace                                                                                                                                                                                             | Meaning If Trap to Homespace                                                                                                                                                           |
|-------------------|-------------|--------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                 | 2           | 3            | 4           | Location X'44'                                                                                                                                                                                                              | Location X'44' Occurs                                                                                                                                                                  |
| 0                 | 0           | 0            | 0           | A x 0, 0/A, or -A +A <sup>(1)</sup> with FN=1                                                                                                                                                                               | *                                                                                                                                                                                      |
| 0                 | 0           | 0            | 1           | N < 0                                                                                                                                                                                                                       | *                                                                                                                                                                                      |
| 0                 | 0           | 1            | 0           | N > 0                                                                                                                                                                                                                       | *                                                                                                                                                                                      |
| 0                 | 1           | 0            | 0           | *                                                                                                                                                                                                                           | Divide by zero                                                                                                                                                                         |
| 0                 | 1           | 0            | 1           | *                                                                                                                                                                                                                           | Overflow, N < 0                                                                                                                                                                        |
| 0                 | 1           | 1            | 0           | *                                                                                                                                                                                                                           | Overflow, N > 0                                                                                                                                                                        |
| []<br>]<br>]<br>] | 0<br>0<br>0 | 0<br>0<br>1  | 0<br>1<br>0 | $ \begin{array}{c} -A + A^{(1)} \\ N < 0 \\ N > 0 \end{array} \right\} > 2 \text{ Postnormal-} \\ \text{izing shifts} \end{array} \right\} \begin{array}{c} FS=0, \\ FN=0, \text{ and} \\ \text{no underflow} \end{array} $ | $ \begin{array}{c} -A + A \\ N < 0 \\ N > 0 \end{array} > 2 Postnormal - izing shifts \\ \end{array} \right\} \begin{array}{c} FS=1, FN=0, and no \\ underflow with FZ=1 \end{array} $ |
| 1                 | ן           | 0            | 0           | Underflow with FZ=0 and no trap by FS=1                                                                                                                                                                                     | *                                                                                                                                                                                      |
| 1                 | ו           | 0            | 1           | *                                                                                                                                                                                                                           | Underflow, N < 0                                                                                                                                                                       |
| 1                 | ו           | 1            | 0           | *                                                                                                                                                                                                                           | Underflow, N > 0 $FZ=1$                                                                                                                                                                |
| No                | tes:        | 1)<br>②<br>③ | 11 * 11     | It set to true zero<br>indicates impossible configurations<br>lies to add and subtract only where FN=0                                                                                                                      | -                                                                                                                                                                                      |

Table 9. Condition Code Settings for Floating-Point Instructions

extending them to seven hexadecimal digits each. FAS then forms the floating-point sum of the two numbers. If no floating-point arithmetic fault occurs, the sum is loaded into register R as a short-format floating-point number.

Affected: (R), CC (R) + EW  $\longrightarrow$  R Trap: Floating-point arithmetic fault

FAL FLOATING ADD LONG (Doubleword index alignment)

| , | *   |     |     | D   |     |    |     |    | I  | ł  |     |    | Х  |    |    |    |    |     |    |    |    | nc |    |     |     |     |    |    |    |    |    |
|---|-----|-----|-----|-----|-----|----|-----|----|----|----|-----|----|----|----|----|----|----|-----|----|----|----|----|----|-----|-----|-----|----|----|----|----|----|
| 6 | 1   | 2   | 3   | 14  | 5   | 6  | 7   | 8  | 9  | 10 | 11  | 12 | 13 | 14 | 15 | 16 | 17 | 18  | 19 | 20 | 21 | 22 | 23 | 24  | 25  | 26  | 27 | 28 | 29 | 30 | 31 |
| T | ĥe  | e e | eff | ec  | :ti | ve | e ( | lo | υb | ١e | w   | or | d  | ar | ۱d | с  | :0 | nte | en | ts | с  | of | re | eg  | ist | tei | rs | R  |    |    |    |
| a | ind | łF  | ใบไ | 1 ( | ar  | е  | lo  | ad | e  | łi | inf | to | a  | se | et | of | Fi | nt  | er | 'n | ıl | re | ea | ist | e   | rs. |    |    |    |    |    |

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 not appended to the fractions, and R must be an even value for correct results. If no floating-point arithmetic fault occurs, the sum is loaded into registers R and Rul as a long-format floating-point number. Affected: (R), (Ru1), CC $(R, Ru1) + ED \longrightarrow R, Ru1$  Trap: Floating-point arithmetic fault, instruction exception

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 Homespace location X'4D', instruction exception trap.

## FSS FLOATING SUBTRACT SHORT (Word index alignment)

| * |   |   | 3 | BC |   |   |   |   |   | F | 2  |   |    | Х  |    |    |    |    | R  | ef | eı | e  | nc | e  | a  | bb | re | ss |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 5 | 7 | 8 | 9 | 10 | Π | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 2ó | 27 | 28 | 29 | 30 | 31 |

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 arith- |
|-------------------|-------|-----------------------|
| (R) − EW −−−−→ R  |       | metic fault           |

## FSL FLOATING SUBTRACT LONG (Doubleword index alignment)

| * |   |   | 1 | С |   |   |   |    | R | 2  |    |    | Х  |    |    |    |    | R  | ef | er | er | nc | е  | ac | ld | re | ss |    |    |    |    |
|---|---|---|---|---|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

The effective doubleword and the contents of registers R and Ru1 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 Ru1 as a long-format floating-point number.

| Affected: (R), (Ru1), CC | Trap: Floating-point arith- |
|--------------------------|-----------------------------|
| (R, Ru1) - ED            | metic fault, instruc-       |
|                          | 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 Homespace location X'4D', instruction exception trap.

#### FMS FLOATING MULTIPLY SHORT (Word index alignment)

| * |   |   | 3 | F |   |   |   |   |   | R  |    |    | Х  |    |    |    |    |    |    |    |    |    | -  |    | bb |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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). The product of the fractions contains 12 hexadecimal digits. If no floating-point arithmetic fault occurs, the product is loaded into register R as a properly truncated short-format floating-point number.

The result of floating-multiply is always postnormalized. At most, one place of postnormalizing shift may be required. Truncation takes place after postnormalization.

| Affected: (R), CC                 | Trap: | Floating-point arith- |
|-----------------------------------|-------|-----------------------|
| $(R) \times EW \longrightarrow R$ |       | metic fault           |

## FML FLOATING MULTIPLY LONG (Doubleword index alignment)

|   | * |   |   | 1 | F |   |   |   |   | R | ł  |    |    | Х  |    |    |    |    | F  | le | fe | re | nc | e  | a  | dd | re | ess |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
| - | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

The effective doubleword (multiplier) and the contents of registers R and Ru1 (multiplicand) are loaded into a set of internal registers. FLOATING MULTIPLY LONG then

operates identically to FLOATING MULTIPLY SHORT (FMS), except that the multiplier and the multiplicand fractions are each 14 hexadecimal digits long, the product fraction is 28 hexadecimal digits long, and R must be an even value for correct results. If no floating-point arithmetic fault occurs, the postnormalized product is truncated to a long-format floating-point number and loaded into registers R and Ru1.

| Affected:         | (R),(Rul),CC  | Trap: | Floating-point arith- |
|-------------------|---------------|-------|-----------------------|
| $(R, Ru1) \times$ | ED ──→ R, Ru1 |       | metic fault, instruc- |
|                   |               |       | tion exception        |

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 Homespace location X'4D', instruction exception trap.

#### **FDS** FLOATING DIVIDE SHORT (Word index alignment)

| * |   |   | 3 | E |   |   |   |   | F | R  |    |    | Х  |    |    |    |    | F  | (e | fe | re | nc | e  | a  | dd | lre | ess |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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). FLOATING DIVIDE SHORT then forms a floating-point quotient with a 6-digit, normalized hexadecimal fraction. If no floating-point arithmetic fault occurs, the quotient is loaded into register R as a short-format floating-point number.

| Affected: (R), CC               | Trap: | Floating-point arith- |
|---------------------------------|-------|-----------------------|
| $(R) \div EW \longrightarrow R$ |       | metic fault           |

## FDL FLOATING DIVIDE LONG (Doubleword index alignment)

| * |   |   | 1 | E  |   |   |   |   | R | R  |    |    | Х  |    |    |    |    | F  | le | fe | re | nc | e  | a  | dd | lre | ess |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 14 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

The effective doubleword (divisor) and the contents of registers R and Ru1 (dividend) are loaded into a set of internal registers. FLOATING DIVIDE LONG then operates identically to FLOATING DIVIDE SHORT (FDS), except that the divisor, dividend, and quotient fractions are each 14 hexadecimal digits long, and R must be an even value for correct results. If no floating-point arithmetic fault occurs, the quotient is loaded into registers R and Ru1 as a long-format floating-point number.

\ Affected: (R), (Ru1), CC
 (R, Ru1) ÷ ED → R, Ru1
 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 Homespace location X'4D', instruction exception trap.

## **DECIMAL INSTRUCTIONS**

The following instructions comprise the decimal instruction  $\mathsf{set}^\dagger:$ 

| 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                                              | PACK     |
| Unpack Decimal Digits                                            | UNPK     |
| Edit Byte String (described under<br>"Byte-String Instructions") | EBS      |

#### PACKED DECIMAL NUMBERS

All SIGMA 9 decimal arithmetic instructions operate on packed decimal numbers, each consisting of from 1 to 31 decimal digits<sup>1†</sup> (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, 0111 = 7, 1000 = 8, and 1001 = 9. A positive decimal sign is a 4-bit code of the form: 1010(X'A'), 1100(X'C'), 1110(X'E'), or 1111(X'F'). A negative decimal sign is a 4-bit code of the form: 1011(X'B') or 1101(X'D'). However, the decimal sign codes generated for the result of a decimal instruction are: 1100 (EBCDIC) and 1010 (ANSCII) for positive results, and 1101 (EBCDIC) and 1011 (ANSCII) for negative results. The format of packed decimal numbers is:

| diait   | diait   | digit | digit   |   | digit   | sign    |
|---------|---------|-------|---------|---|---------|---------|
|         |         |       |         | N | -       |         |
| 0 1 2 3 | 4 5 6 7 | 0123  | 4 5 6 7 |   | 0 1 2 3 | 4 5 6 7 |

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 within bit positions 4–7 of a byte, and bit positions 0–3 of 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:

|         |       |         |         |      |         | Í. |
|---------|-------|---------|---------|------|---------|----|
| zone    | digit | zone    | digit   | sign | digit   |    |
| 0 1 2 3 | 4567  | 0 1 2 3 | 4 5 6 7 | 0123 | 4 5 6 7 | 1  |

The sign and zones are determined by bit 12 of the PSD. If bit 12 is zero, the sign format is EBCDIC and the zones are 1111. If it is one, the sign format is ASCII and zones are 0011.

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 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:

| * |   | D <br>:0 |   | erc<br>Ə | ıti | or | ו |    | L | •  |    |    | Х  |    |    |    |    |    | Refe |   |    |    |    |    |    |    |    |    |    |    |
|---|---|----------|---|----------|-----|----|---|----|---|----|----|----|----|----|----|----|----|----|------|---|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2        | 3 | 14       | 5   | 6  | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 2 | 2 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 SIGMA 9 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 computer checks all decimal operands for the presence of illegal decimal digits or illegal decimal signs. For all decimal arithmetic instructions except DECIMAL MULTIPLY and DECIMAL DIVIDE, an illegal decimal digit is a sign code (i.e., in the range X'A' through X'F') 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'0'

<sup>&</sup>lt;sup>r</sup>For disabling of decimal instructions, see "Unimplemented Instruction Trap", Chapter 2.

<sup>&</sup>lt;sup>ff</sup>Except EDIT BYTE STRING (EBS), which has no limit on the size of numbers.

through X'9') that appears in the sign position of the packed decimal number.

For the instructions DECIMAL MULTIPLY and DECIMAL DIVIDE, the effective decimal operand is checked for illegal digits or signs as above. However, the operand in the decimal accumulator is checked to verify that there is at least one legal decimal sign code somewhere in the number. (This type of check is a result of the interruptibility of these instructions, which may leave the decimal accumulator with a partially-completed result containing an internal code.) For these two instructions, the illegal sign and digit check also includes a check for an illegal L field in the instruction. Illegal L fields are X'0' and the range X'9' to X'F'.

For the instructions DECIMAL ADD, DECIMAL COMPARE, and DECIMAL SUBTRACT, the decimal accumulator may not be fully checked for illegal signs.

If an illegal digit or sign is detected, the computer unconditionally aborts the execution of the instruction (at the time that the illegal digit or sign is detected), sets CC1 to 1 and resets CC2 to 0. If the decimal arithmetic fault trap mask (bit position 10 of the program status doubleword) is a 0, the computer then executes the next instruction in sequence; however, if the decimal arithmetic fault trap mask (PSD<sub>10</sub>) is a 1, the computer traps to Homespace location X'45'. 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:

DECIMAL ADD: overflow occurs when the sum of the two decimal numbers exceeds the 31-digit capacity of the decimal accumulator  $(+10^{31} - 1 \text{ to } -10^{31} + 1)$ .

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 15th 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 computer unconditionally aborts execution of the instruction (at the time of overflow detection), resets CC1 to 0, and sets CC2 to 1. Then, if the decimal arithmetic fault trap mask (PSD<sub>10</sub>) is a 1, the computer traps to Homespace location X'45'; if the decimal arithmetic fault trap mask is a 0, the computer 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, DECIMAL SUBTRACT, DECIMAL MULTIPLY, DECI-MAL 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 byte 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 CC1 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

- 0 0 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.
- 0 1 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.
- 1 0 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

# L DECIMAL LOAD

(Byte index alignment)

| * |   |       | 7 | E  |   |   |   |   |   | I | -  |    |    | х  |    |    |    |    |    | Re | fe | ere | en | ce | a  | dd | dre | es | 5  |    |    |    |
|---|---|-------|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|-----|----|----|----|----|----|
| 0 | 1 | <br>2 | 3 | 17 | - | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21  | 22 | 23 | 24 | 25 | 26  | 27 | 28 | 29 | 30 | 31 |

If no illegal digit or illegal 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.

Affected: (DECA), CC Trap: Decimal arithmetic (EBL to EBL + L − 1) → DECA

Condition code settings:

| 1 2 3 4 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 illegal sign detected, instruction completed
- DST DECIMAL STORE (Byte index alignment)

| * | 7F            | L X          | x     | Reference address                                  |
|---|---------------|--------------|-------|----------------------------------------------------|
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 12 | 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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-1. 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; otherwise, CC2 is reset to 0. If the result in memory is zero, the converted sign remains unchanged.

Affected: (EBL to EBL + L-1), Trap: Decimal arithmetic CC1, CC2

(DECA) low-order bytes ----- EBL to EBL + L - 1

Condition code settings:

| 1 | 2 | 3 | 4 | Result | of | DST |
|---|---|---|---|--------|----|-----|
|   |   |   |   |        |    |     |

stored

| 1 | 0 | - | - | Illegal digit or sign detected, instruction |
|---|---|---|---|---------------------------------------------|
|   |   |   |   | aborted                                     |

 0 0 - - All significant information stored
 0 1 - - Some significant information not
 No illegal digit or illegal sign detected, instruction completed DA DECIMAL ADD

(Byte index alignment)

| * |   |   | 7 | 9 |   |   |    |   | L |    |    |    | Х  |    |    |    |    | I  | Ref | eı | re | nc | e  | a  | dc | dre | ess | ;  |    |    | ٦  |
|---|---|---|---|---|---|---|----|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7. | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 191 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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, CC2 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 (DECA) + EDO → DECA

Condition code settings:

| 1 | 2 | 3 |   | Result in D                | ECA                                                                         |
|---|---|---|---|----------------------------|-----------------------------------------------------------------------------|
| 1 | 0 | - | - | Illegal dig<br>sign detect | ed lnstruction aborted                                                      |
| 0 | 1 | - | - | Overflow                   |                                                                             |
| 0 | 0 | 0 | 0 | Zero                       |                                                                             |
| 0 | 0 | 0 |   | Negative                   | No illegal digit or sign<br>detected, no overflow,<br>instruction completed |
| 0 | 0 | 1 | 0 | Positive                   | instruction completed                                                       |

DECIMAL SUBTRACT (Byte index alignment)

DS

| * |   |   | 7 | 8 |   |   |   |   | l | -  |    |    | Х  |    |    |    |    |    | Ret |    |    |    |     |    |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 231 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

If no illegal digit or sign is detected in the effective decimal operand or in the decimal accumulator, DECIMAL SUB-TRACT 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 then  $10^{31}$ ), in which case CC1 is reset to 0, CC2 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: | Decima | arithmetic |
|----------------------|-------|--------|------------|
| (DECA) - EDO DECA    | -     |        |            |

Condition code settings:

| 1 | 2 | 3 | 4 | Result in DECA                                                                         |
|---|---|---|---|----------------------------------------------------------------------------------------|
| 1 | 0 | - | - | Illegal digit or<br>sign detected<br>Instruction aborted                               |
| 0 | 1 | - | - | Overflow                                                                               |
| 0 | 0 | 0 | 0 | Zero                                                                                   |
| 0 | 0 | 0 | 1 | No illegal digit or sign<br>Negative > detected, no overflow,<br>instruction completed |
| 0 | 0 | 1 | 0 | Positive                                                                               |

DM DECIMAL MULTIPLY (Byte index alignment, continue after interrupt)

| * |   |   | 7 | В |   |   |   |    | l | -  |    |    | Х  |    |    |    |    |    |    |    |    |    |    |    |    |    | ess |    |    |    |    |
|---|---|---|---|---|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

If no illegal digit or sign is detected in the effective decimal operand and there is at least one decimal sign in the decimal accumulator, DECIMAL MULTIPLY multiplies the effective decimal operand (multiplicand) by the entire contents of the decimal accumulator (multiplier) and then loads the product into the decimal accumulator. If the result in the decimal accumulator is zero, the resulting sign is forced to the positive form.

No overflow can occur; however, an indeterminate result occurs (with an incorrect condition code indication, and with no trap activation) if any of the following conditions are not satisfied before the initial execution of DECIMAL MULTIPLY:

- 1. The four low-order bit positions of the decimal accumulator must contain the sign of the multiplier.
- The 16 high-order digit positions of the decimal accumulator (i.e., general registers 12 and 13) must contain all 0's.

This instruction can be interrupted during the course of its execution, and then be resumed, without producing an erroneous product (provided that the contents of the decimal accumulator are not altered between the interruption and continuation). Actually, the instruction is reexecuted, but since there is no initializing phase, it begins with the same iteration that was started prior to the interrupt.

Affected: (DECA), CC Trap: Decimal arithmetic (DECA) x EDO → DECA Condition code settings:

| 1 | 2 | 3 | 4 | Result | in | DECA |
|---|---|---|---|--------|----|------|
|   |   |   |   |        |    |      |

1 0 - - Illegal digit or sign detected, instruction aborted

| 0 | 0 | 0 | 0 | Zero     | No illegal digit or sign                                       |
|---|---|---|---|----------|----------------------------------------------------------------|
| 0 | 0 | 0 | 1 | Negative | No illegal digit or sign<br>detected, instruction<br>completed |
| 0 | 0 | 1 | 0 | Positive |                                                                |

## DD DECIMAL DIVIDE

(Byte index alignment, continue after interrupt)

| * |   | _ | 7 | A |   |   |   |   | L | -  |    |    | Х  |    |    |    |    | I  | Re | fe | re | no | ce | a  | dc | Ire | ess |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 6 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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 computer 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 can occur 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.

This instruction can be interrupted during the course of its execution, and can then be resumed without producing an erroneous result (provided that the contents of the decimal accumulator are not altered between interruption and continuation). Actually, the instruction is reexecuted, but since there is no initializing phase, it begins with the same iteration that was started prior to the interrupt.

Affected: (DECA), CC (DECA) ÷ EDO → DECA Trap: Decimal arithmetic

Condition code settings:

| 1 | 2 | 3 | 4 | Result in DECA                    |                                                                |
|---|---|---|---|-----------------------------------|----------------------------------------------------------------|
| 1 | 0 | - | - | Illegal digit or<br>sign detected | Instruction aborted                                            |
| 0 | 1 | - | - | Overflow                          |                                                                |
| 0 | 0 | 0 | 0 | Zero quotient                     | No illegal digit or                                            |
| 0 | 0 | 0 | 1 | Negative quotient                 | No illegal digit or<br>sign detected, no<br>overflow, instruc- |
| 0 | 0 | 1 | 0 | Positive quotient                 | tion completed                                                 |
|   |   |   |   |                                   |                                                                |

DC DECIMAL COMPARE (Byte index alignment)

| * |   |   | 7 | D |   |   |   |   | I | _  |    |    | х  |    |    |    |    |    | · · · |    |    | nc |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19    | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

If there is no illegal digit or illegal 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:

2 3 4 Result of comparison

- 0 \_ Illegal digit or sign detected, instruction \_ aborted
- 0 0 0 (DECA) equals EDO 0

| 0 | 0 | 0 | 0 | (DECA) equals EDO `                         |                                                      |
|---|---|---|---|---------------------------------------------|------------------------------------------------------|
| 0 | 0 | 0 | 1 | (DECA) less than EDO<br>(DECA) greater than | No illegal digit or<br>sign detected,<br>instruction |
| 0 | 0 | 1 | 0 | (DECA) greater than EDO                     | completed                                            |

#### DECIMAL SHIFT ARITHMETIC DSA (Byte index alignment)

| * |   |   | 7 | c |   |   |   |    |   |    |    |    | x      |    |    |    |    |    | Re | efe | ere | en | ce | c  | ıdo | dr | es | s  |    |    |    |
|---|---|---|---|---|---|---|---|----|---|----|----|----|--------|----|----|----|----|----|----|-----|-----|----|----|----|-----|----|----|----|----|----|----|
|   |   |   |   |   |   |   |   |    |   |    |    |    | $\sim$ |    |    |    |    |    |    |     |     | C  | o  | JN | t   |    |    |    |    |    |    |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13     | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24 | 25  | 26 | 27 | 28 | 29 | 30 | 31 |

If no illegal digit or sign is detected in the 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 contents 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's, and any digits shifted out of the decimal accumulator are lost. Although the range of possible values for C is  $2^{-15} \le C \le 2^{15}$ -1, a shift count greater than +31 or less than -31 is interpreted as a shift count of exactly +31 or -31.

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:

- 1 2 3 4 Result in DECA
- Illegal digit or sign detected, instruction 0 - aborted
- 0 0 Zero
- Negative
- Positive 0
- 0 Right shift or no nonzero digit shifted out of DECA on left shift

No illegal digit or sign detected, instruction completed

- 0 1 -One or more nonzero digit(s) shifted out of DECA on left shift
- PACK PACK DECIMAL DIGITS (Byte index alignment)

| * |   |   | 70 | 5 |   |   |   |   | L |    |    |    | Х  |    |    |    |    | [  | Re | fe | re | eno | ce | a  | do | dre | ess |    |    |    |    |
|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 | 2 | 3  | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22  | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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 forming 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 2L-1 bytes (where L = 0 implies a length of 31 bytes for the effective decimal operand).

Affected: (DECA), CC Trap: Decimal arithmetic packed (EBL to EBL + 2L - 2) ----> DECA

Condition code settings:

1 2 3 4 Result in DECA

| 1 | 0 | - | - | Illegal digi<br>aborted | t or sign detected, instruction |
|---|---|---|---|-------------------------|---------------------------------|
| 0 | 0 | 0 | 0 | Zero                    | No illegal digit or sign        |
| 0 | 0 | 0 | 1 | Negative                |                                 |
| 0 | 0 | 1 | 0 | Positive                | completed                       |

Example 1, L = 6:

|        |   | Before execution                                     | After execution                                 |
|--------|---|------------------------------------------------------|-------------------------------------------------|
| EDO    | = | X'F0F1F2F3<br>F4F5F6F7<br>F8F9F0'                    | X'F0F1F2F3<br>F4F5F6F7<br>F8F9F0'               |
| (DECA) | = | xxxxxxxx<br>xxxxxxxx<br>xxxxxxxx<br>xxxxxxxx<br>xxxx | X'00000000<br>00000000<br>00000123<br>4567890C' |
| СС     | = | xxxx                                                 | 0010                                            |

Example 2, L = 6:

|        |   | Before execution | After execution |
|--------|---|------------------|-----------------|
| EDO    | = | X'000938F7       | X'000938F7      |
|        |   | E655B483         | E655B483        |
|        |   | 02F1B0'          | 02F1B0'         |
| (DECA) | = | ****             | ×'00000000      |
|        |   | xxxxxxx          | 00000000        |
|        |   | xxxxxxx          | 00000987        |
|        |   | ****             | 6543210D'       |
| сс     | = | xxxx             | 0001            |

UNPACK DECIMAL DIGITS

(Byte index alignment, continue after interrupt)

| * |   |   | 7 | 7 |   |   |   |   | l | _  |    |    | Х  |    |    |    |    | ۱  | Re | fe | re | n  | ce | a  | dc | ire | ess | 5  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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, if bit 12 of the PSD is zero, the zones are 1111 (EBCDIC), and if bit 12 is one, the zones are 0011 (ASCII). The contents of the decimal accumulator remain unchanged, and only 2L-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 + 2L -2), Trap: Decimal arithmetic CC1, CC2

zoned (DECA)  $\longrightarrow$  EBL to EBL + 2L - 2

Condition code settings:

1 2 3 4 Result of UNPK

- 1 0 – Illegal digit or sign detected, instruction aborted
- 0 0 – All significant infor– mation zoned and stored

information not zoned and stored

0 1 - - Some significant

No illegal digit or sign detected, instruction completed

Example 1, L = 10:

|        |   | Before execution                                     | After execution                                           |
|--------|---|------------------------------------------------------|-----------------------------------------------------------|
| (DECA) | = | X'00000000<br>00000001<br>23456789<br>0123456D'      | X'00000000<br>00000001<br>23456789<br>0123456D'           |
| EDO    | Ξ | xxxxxxxx<br>xxxxxxxx<br>xxxxxxxx<br>xxxxxxxx<br>xxxx | X'F0F0F0F1<br>F2F3F4F5<br>F6F7F8F9<br>F0F1F2F3<br>F4F5D6' |
| сс     | = | xxxx                                                 | 00xx                                                      |

Example 2, L = 8:

|            | Before execution                              | After execution                                                    |
|------------|-----------------------------------------------|--------------------------------------------------------------------|
| (DECA) =   | X'0000000<br>2300000<br>10001234<br>0012345C' | X'00000000<br>23000000<br>10001234<br>0012345C'                    |
| EDO =      | xxxxxxxx<br>xxxxxxxx<br>xxxxxxxx<br>xxxxxxx   | X'F1F0F0F0<br>F1F2F3F4<br>F0F0F1F2<br>F3F4C5'                      |
| CC =       | xxxx                                          | 01××                                                               |
|            |                                               |                                                                    |
| Example 3, | L = 4:                                        |                                                                    |
| Example 3, | L = 4:<br><u>Before execution</u>             | After execution                                                    |
| ·          |                                               | After execution<br>X'00001001<br>00001002<br>00001003<br>00001004' |

XXXXXXXX

 $= x \times x \times x$ 

CC

# **BYTE-STRING INSTRUCTIONS**

F0F0C4'

01xx

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      |
| Translate Byte String          | TBS      |
| Translate and Test Byte String | TTBS     |
| Edit Byte String               | EBS      |

These instructions are in the immediate displacement 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. These instructions may be interrupted at various stages of their execution; upon return, execution continues 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 |   | :0 | de | Э   |   |   | n |   |   | f | र  |    |    |    |    | +  |    |    |    |    | sp |    |    |    |    |    |    |    |    |    |    |    |
|---|---|----|----|-----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2  |    | 314 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

| Contents of regis      | ter R:                                                                                                                                                                                                                                                                                                   |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mask/Fill              | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31                                                                                                                                                                                                                                     |
| Contents of regis      |                                                                                                                                                                                                                                                                                                          |
| Count                  | 9 10 11 11 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31                                                                                                                                                                                                                                      |
| Designation            | Function                                                                                                                                                                                                                                                                                                 |
| Operation              | The 7-bit operation code of the instruc-<br>tion. (If any byte-string instruction is<br>indirectly addressed, the computer traps<br>to Homespace location X'40' at the time<br>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<br>byte displacement value, used to form an<br>effective byte address. The displacement<br>value is right-justified in the 20-bit<br>field, and negative values are in two's<br>complement form.                                                                   |
| Mask/Fill              | An 8-bit field used only with TRANSLATE<br>AND TEST BYTE STRING and EDIT BYTE<br>STRING. The purpose of this field is<br>explained in the detailed discussion of<br>the TTBS and EBS instructions.                                                                                                       |
| Source Address         | A 19- or 24-bit field <sup>t</sup> that normally con-<br>tains the byte address of the first (most<br>significant) byte of the source byte<br>string operand. The effective source<br>address is the source address in register R<br>plus the displacement value in the in-<br>struction word.           |
| Count                  | An 8-bit field that contains the true<br>count (from 0 to 255) of the number of<br>bytes involved in the operation. This<br>field is decremented by 1 as each byte<br>in the destination byte string is processed.<br>A 0 count means "no operation" with re-<br>spect to the registers and main memory. |
| Destination<br>Address | A 19- or 24-bit field <sup>t</sup> that contains the<br>byte address of the first (most significant)                                                                                                                                                                                                     |

byte address of the first (most significant) byte of the destination byte-string operand. This field is incremented by 1 as each byte in the destination byte string is processed.

<sup>&</sup>lt;sup>t</sup>For real extended addressing mode, this is a 24-bit field (bits 8-31); for real and virtual addressing modes it is a 19-bit field (13-31).

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 instruction (except for TRANSLATE AND TEST BYTE STRING and 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 I: 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 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, (I)<sub>12-31</sub>.
- SA Source address, (R)<sub>13-31</sub><sup>t</sup>.
- ESA Effective source address,  $[(R)_{13-31} + (I)_{12-31}]_{13-31}^{t}$ . The contents of bit positions  $13-31^{t}$  of register R are added (right aligned) to the contents of bit positions 12-31 of the instruction word; the 19 or 24 low order bits<sup>t</sup> of the result are used as the
- C Count, (Ru1)<sub>0-7</sub>.
- DA Destination address, (Ru1)<sub>13-31</sub>t.

effective source address.

- SBS Source byte string, the byte string that begins with the byte location pointed to by the 19- or 24-bit<sup>t</sup> effective source address and is C bytes in length (if R is nonzero) or is 1 byte 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 byte strings addressed come from pages of memory that are protected either through access protection or through write locks. A trap also occurs if either byte string is fully or partly contained within pages of memory that are physically not present. A check for these access trap conditions are made prior to initiation of any byte relocation or general register change. These tests are performed for MOVE BYTE STRING and COMPARE BYTE STRING. These tests are performed only for the source byte string for TRANSLATE BYTE STRING, TRANSLATE AND TEST BYTE STRING, and EDIT BYTE STRING, since there is no assurance that the translate table or decimal digit bytes will be accessed in their 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 partially executed condition. The registers would be restored, however, in such a manner that the instruction could be resumed after the protection violation had been corrected. When a trap occurs resulting in a partially executed instruction, the Register Altered indicator will be set.

#### MBS MOVE BYTE STRING

(Immediate displacement, continue after interrupt)

| 0 |   |   | ( | 51 |   |   |   |   | F | 2  |    |    |    |    |    |    |    |    |    |    |    |    | me |    |    |    |    |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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

84 Byte-String Instructions

<sup>&</sup>lt;sup>t</sup>For real extended addressing mode, this is a 24-bit field (bits 8-31); for real and virtual addressing modes it is a 19-bit field (13-31).

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), (Ru1) (SBS) ----- DBS

If MBS 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 Homespace location X'40' 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 (Ru1=R+1)

Contents of register R:

|   |   |   |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    | S  | οu | rc | e  | a  | dd | re | ss | t  |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

Contents of register R+1:

|   |   |   |   | οU |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    | inc  |     |    |    |    |    |    |    |       |    |    |    |
|---|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|-------|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | ( | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 2 | 0 2 | 21 | 22 | 23 | 24 | 25 | 26 | 27 28 | 29 | 30 | 31 |

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 fie | ld ( | (Ru1= | 1) |
|-----------|------|-------|------|-------|----|
|-----------|------|-------|------|-------|----|

Contents of register 1

|   |   | C | Co | ur | nt |   |   |   |   |    |     |    |    |    |    |    |    |    | •••• |    | • - |    | ac |    |    |    |    |    |    |    |    |
|---|---|---|----|----|----|---|---|---|---|----|-----|----|----|----|----|----|----|----|------|----|-----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3  | 4  | 5  | 6 | 7 | 8 | 9 | 10 | 111 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19   | 20 | 21  | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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.

## CBS COMPARE BYTE STRING (Immediate displacement, continue after interrupt)

| 0 |   |   | é | 50 |   |   |   |   | F | 2  |    |    |    |    |    |    |    | D  | is | pl | ac | e  | me | en | t  |    |    |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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), (Ru 1), CC3, CC4 (SBS) : (DBS)

Condition code settings:

- 1 2 3 4 Result of CBS.
- 0 0 Source byte string equals destination byte string.
- 0 1 Source byte string less than destination byte string.
- 1 0 Source byte string greater than destination byte string.

If CBS 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 Homespace location X'40' 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.

<sup>&</sup>lt;sup>t</sup>For real extended addressing mode, this is a 24-bit field (bits 8–31); for real and virtual addressing modes it is a 19-bit field (13–31).

## Case I: even, nonzero R field (Ru1=R+1)

#### Contents of register R

|   |   |   |   |   |   |   |   |   |   |    |    |    |    |    | +  |    |    | So | ου | rc | e  | a  | bb | re | ss | t  |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

Contents of register R+1

|   |   | С | 0 | Jn | t |   |   |   |   |    |    |    |    |    |    |    | De | est | in | al | ic | on | a  | dc | lre | ess | t  |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18  | 19 | 20 | 21 | 22 | 23 | 24 | 25  | 26  | 27 | 28 | 29 | 30 | 31 |

The source byte string begins with the byte location 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 R+1. Both byte strings are C bytes in length.

## Case II: odd R field (Rul=R)

Contents of register R:

|   |   | C | :0 | ur | nt |   |   |   |   |   |    |    |    |    |    |    |    | De | est | in | a  | tic | on | a  | dc | lre | ess | †  |    |    |    |    |
|---|---|---|----|----|----|---|---|---|---|---|----|----|----|----|----|----|----|----|-----|----|----|-----|----|----|----|-----|-----|----|----|----|----|----|
| 0 | 1 | 2 | 3  | 4  | 5  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18  | 19 | 20 | 21  | 22 | 23 | 24 | 25  | 26  | 27 | 28 | 29 | 30 | 31 |

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 Destination address t

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)

| 0 |   |   |   | 41 |   |   |   |   | R | 2  |    |    |    |    |    |    |    | D  | )is | pl | a  | ce | me | en | t  |    |    |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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 Ru1, 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<sup>†</sup> 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<sup>t</sup> of register R (source address).
- 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<sup>t</sup> of register (Ru1).

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 Homespace location X'4D', instruction exception trap.

If TBS 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 Homespace location X'40' 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 (Ru1=R+1

Contents of register R

|                 |                       | Source address                                  |
|-----------------|-----------------------|-------------------------------------------------|
| 0 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 | 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

Contents of register R+1

|   |   | C | :01 | ur | nt |   |   |   |   |   |    |    |    |    |    |    |    | De | est | ir | na | tic | on | a  | dc | ire | ess | †<br>5 |    |    |    |    |
|---|---|---|-----|----|----|---|---|---|---|---|----|----|----|----|----|----|----|----|-----|----|----|-----|----|----|----|-----|-----|--------|----|----|----|----|
| 0 | 1 | 2 | 3   | 4  | 5  | ; | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18  | 19 | 20 | 21  | 22 | 23 | 24 | 25  | 26  | 27     | 28 | 29 | 30 | 31 |

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.

<sup>&</sup>lt;sup>r</sup>For real extended addressing mode, this is a 24-bit field (bits 8-31); for real and virtual addressing modes it is a 19-bit field (13-31).

#### Case II: odd R field (Ru1=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

|   | <u> </u>        |                                                                       |
|---|-----------------|-----------------------------------------------------------------------|
|   | Count           | Destination address                                                   |
| 1 | 0 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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                                                |
|---|---------------|-----------|-------------------------------------------------------------|
|   |               |           |                                                             |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 translation 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), (Ru1), CC4

Trap: Instruction exception

f translated (SBS) n mask  $\neq$  0, translated (SBS) n mask  $\longrightarrow$  mask and stop

f translated (SBS) n mask = 0, continue

Condition code settings:

## 1 2 3 4 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 1 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 Homespace location X'4D', instruction exception trap.

If TTBS 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 Homespace location X'40' 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 (Ru1=R+1)

Contents of register R

| _        |   |     |    |      |   |   |   | 1 |   |    |    | -   |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |  |
|----------|---|-----|----|------|---|---|---|---|---|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|----|----|--|
|          |   |     |    |      |   |   |   | 1 |   |    |    | - 1 |    |    |    |    |    | -  |    |    |    |    |    |     | 1  | F . |    |    |    |    |    |  |
|          |   | ۰N  | ۸a | sk   |   |   |   |   |   |    |    | i   |    |    |    |    |    | Sc | วม | rc | е  | a  | bŀ | re  | SS |     |    |    |    |    |    |  |
|          |   | ••• |    | •••• |   |   |   | 1 |   |    |    | - 1 |    |    |    |    |    |    |    |    | -  |    |    | • • |    |     |    |    |    |    |    |  |
| <u> </u> | 1 | 2   | 3  | 14   | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12  | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24  | 25 | 26  | 27 | 28 | 29 | 30 | 31 |  |

Contents of register R+1

| Count           | Destination address <sup>†</sup>                                      |
|-----------------|-----------------------------------------------------------------------|
| 0 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 interruptable 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.

<sup>&</sup>lt;sup>t</sup>For real extended addressing mode, this is a 24-bit field (bits 8-31); for real and virtual addressing modes it is a 19-bit field (13-31).

## Case III. zero R field (Ru1=1)

#### Contents of register 1

|     |   |   | С | o | J | nt | ŀ |   |   |   |   |   |    |    |    |    |    |    |    | De | est | ir | na | tio | on | a  | do | dre | ess | ţ  |    |    |    |    |
|-----|---|---|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|-----|----|----|-----|----|----|----|-----|-----|----|----|----|----|----|
| - 7 | 0 | 1 | 2 | 3 | Т | Ā  | 5 | _ | 4 | 7 | 0 | 0 | 10 | 11 | 12 | 12 | 14 | 15 | 14 | 17 | 10  | 10 | 20 | 21  | 22 | 22 | 24 | 25  | 24  | 27 | 20 | 20 | 20 | 21 |

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 1's. (This is an exception to the general rule, used in the other byte-string instructions, that register 0 provides all 0's as its contents.)

## EBS EDIT BYTE STRING

(Immediate displacement, continue after interrupt)

| 0 |   |   | ( | 53 |   |   |   |   |   | R  |    |    |    |    |    |    |    | D  | isp | olo | ac | er | ne | nt | •  |    |    |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

EDIT BYTE STRING converts a decimal information field from packed decimal format to zoned decimal format, under control of the editing pattern in the destination byte string, and replaces the destination byte string with the edited, zoned result. The decimal formats on which EBS operates are governed by bit 12 of the PSD (ANSCII/EBCDIC) mask bit). If PSD12 is zero, EBCDIC codes are used; if it is one, ANSCII codes are used. (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 1) 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 computer traps to Homespace location X'4D', instruction exception trap, with the contents in register R unchanged.

Contents of register R

| ſ |   |   | Fi | 11 |   |   |   |   |   |    |    |     |    |    |    |    |    | -  |    | urc | -  |    |    |    |    |    |    |    |    |    |    |
|---|---|---|----|----|---|---|---|---|---|----|----|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3  | 14 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 112 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

<sup>&</sup>lt;sup>t</sup>For real extended addressing mode, this is a 24-bit field (bits 8-31); for real and virtual addressing modes it is a 19-bit field (13-31).

#### Contents of register R+1

|   |   | C | 20 | ur | nt |   |   |   |   |   |    |    |    |    |    |    |    | D  | es | tin  | a  | ti | on | o  | ide | dr | es | s <sup>†</sup> |    |    |    |    |
|---|---|---|----|----|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|------|----|----|----|----|-----|----|----|----------------|----|----|----|----|
| 0 | 1 | 2 | 3  | 14 |    | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 2 | 20 | 21 | 22 | 23 | 24  | 25 | 26 | 27             | 28 | 29 | 30 | 31 |

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 |
|-------------------|-----------------------------------|--------------|
| 0010 0000 (X'20') | Digit selector                    | ds           |
| 0010 0001 (X'21') | Significance start                | SS           |
| 0010 0010 (X'22') | Field separation                  | fs           |
| 0010 0011 (X'23') | Immediate signifi–<br>cance start | si           |

Before executing EBS, the condition code should be set to 0000 if the high-order digit of the decimal 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:

- 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 X'23' (immediate significance start), which begins significance with the current decimal digit.
  - b. The pattern byte is X'21' (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.
- After significance is encountered, each pattern byte that is X'20' (digit selector), X'21' (significance start), X'22' (field separator), or X'23' (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 occur:
  - 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'22' (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 computer executes the next instruction in sequence.

The detailed operation of EDIT BYTE STRING is as given below.

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 on the next page will help clarify the discussion below.

- 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 computer executes the next instruction in sequence.
- If the pattern byte is a digit selector (X'20'), a significance start (X'21'), or immediate significance start (X'23'), 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 computer automatically aborts execution of EBS and traps to Homespace location X'45', 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 computer automatically aborts execution of EBS and traps to Homespace location X'45', 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 pattern<br>byte location, and set<br>CC4 to 1 (start<br>significance).                             | Mode 1 |
| Pattern byte=SS(X'21')<br>CC4 = 1            | Expand digit to zoned<br>format and store in<br>pattern byte location<br>(because CC4=1 means<br>significance already<br>encountered).       | None   |
| Pattern byte = SS<br>CC4 =0<br>nonzero digit | Expand digit to zoned<br>format, store in pat-<br>tern byte location<br>(because nonzero digit<br>begins significance),<br>and set CC4 to 1. | Mode 1 |
| Pattern byte = SS<br>CC4 = 0<br>digit = 0    | Store fill character in<br>pattern byte location<br>(because significance<br>starts with next pattern<br>byte) and set CC4 to 1.             | Mode 2 |

Byte-String Instructions 89

|                             |                                                                                                                                |                                                              |                                                                                                                                                                                                                                                                          | 2, , , , , , , , , , , , , , , , , , ,                                                    |  |  |  |  |  |  |  |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Conditio                    | ons                                                                                                                            |                                                              | Action                                                                                                                                                                                                                                                                   | <u>Mark</u>                                                                               |  |  |  |  |  |  |  |
| Pattern<br>CC4 = 1          | byte=DS(X                                                                                                                      | '20')                                                        | Expand digit to zoned None<br>format, and store digit<br>in pattern byte location.                                                                                                                                                                                       |                                                                                           |  |  |  |  |  |  |  |
| Pattern<br>CC4=0<br>nonzero | byte = DS<br>digit                                                                                                             |                                                              | Expand digit to zoned<br>format, store digit in<br>pattern byte location,<br>and set CC4 to 1 to.<br>signal significance                                                                                                                                                 | Mode 1                                                                                    |  |  |  |  |  |  |  |
| Pattern<br>CC4=0<br>digit=0 | byte=DS                                                                                                                        |                                                              | Store fill character in<br>pattern byte location<br>(because significance<br>not encountered yet).                                                                                                                                                                       | None                                                                                      |  |  |  |  |  |  |  |
| e.                          | decimal b<br>CC1 is se<br>address in<br>is current<br>mal byte<br>and CC4<br>is increment<br>the source                        | yte a<br>t to 1<br>regis<br>are a<br>are b<br>ented<br>e add | ntly reset to 0 and if bits<br>re a positive decimal sign<br>, CC4 is reset to 0, and t<br>ster R is incremented by 1<br>et to 0 and if bits 4–7 of<br>negative decimal sign cou<br>oth set to 1, and the sourc<br>by 1. Otherwise, CC2 is<br>ress and then CC2 is inver | code,<br>he source<br>. If CC2<br>the deci-<br>de, CC1<br>e address<br>s added to<br>ted. |  |  |  |  |  |  |  |
| f.                          |                                                                                                                                |                                                              | nvoked at set d, above, or<br>marking operations are pe                                                                                                                                                                                                                  |                                                                                           |  |  |  |  |  |  |  |
|                             |                                                                                                                                | positi                                                       | bits 13–31 of register R+1<br>ons 13–31 of register 1; b<br>0–12 of register are unpre                                                                                                                                                                                   | it posi-                                                                                  |  |  |  |  |  |  |  |
|                             | Mode 2:                                                                                                                        | positi<br>incre<br>bit p                                     | bits 13–31 of register R+1<br>ons 13–31 of register 1 an<br>ment the contents of regis<br>ositions 0–12 of register<br>dictable.                                                                                                                                         | d then<br>ter 1 by 1;                                                                     |  |  |  |  |  |  |  |
|                             | If marking is not applicable (i.e., significance has<br>not been encountered), the contents of register 1<br>are not affected. |                                                              |                                                                                                                                                                                                                                                                          |                                                                                           |  |  |  |  |  |  |  |
| ch<br>CC                    | aracter is st                                                                                                                  | fored                                                        | is a field separator (X'22'<br>in the pattern byte locatio<br>all reset to 0's, and CC2                                                                                                                                                                                  | on. CC1,                                                                                  |  |  |  |  |  |  |  |
|                             |                                                                                                                                |                                                              | is not a digit selector, sig<br>gnificance start, or field s                                                                                                                                                                                                             |                                                                                           |  |  |  |  |  |  |  |

| Conditions | Action                                     |
|------------|--------------------------------------------|
| CC1 = 0    | Store fill character in pattern byte       |
| CC4 = 0    | location.                                  |
| CC1=1      | Store blank character(X'40' if EBCDIC or   |
| CC4=0      | X'20' if ANSCII) in pattern byte location. |
| CC4 = 1    | None (pattern byte remains unchanged).     |

one of the following actions are performed:

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), (Ru1)<br>(register 1), | Traps: Nonexistent instruc-<br>tion, decimal arith-<br>metic, instruction |
|---------------------------------------|---------------------------------------------------------------------------|
| (DBS), CC<br>edited (SBS) DBS         | exception                                                                 |

Condition code settings:

| 1 | 2 | 3 | 4 | Result of EBS |  |
|---|---|---|---|---------------|--|
|   |   |   |   |               |  |

- Significance is not present, no sign digit 0 has been encountered.
- Significance is present, no sign digit has 0 - 1 been encountered.
- 0 A positive sign has been encountered.
- 1 A negative sign has been encountered.
- Next digit to be processed is left digit of byte.
- Next digit to be processed is right digit of byte.
- No nonzero digit has been encountered. 0
- A nonzero digit has been encountered. 1

If EBS 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 Homespace location X'40' with the contents of register R, register Rul, 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 of EBS is an odd value or equal to zero, the instruction traps to Homespace location X'4D', instruction exception trap.

If an illegal digit or sign is detected in the decimal information field, the computer unconditionally aborts execution of the instruction (at the time the illegal digit or sign is encountered) and traps to Homespace location X'45' 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. Note that the check for access trap conditions is done only for the source byte string.

In the following examples, the hexadecimal codes for the digit selector (X'20'), the significance start (X'21'), the field separation (X'22'), and the immediate significance

start (X'23') are represented by the character groups ds, ss, fs, and si, respectively. Also, the symbol b is used to represent the character blank (X'40').

Example 1, before execution:

The instruction word is:

X'63600000'

The contents of register 6 are:

X'5C000100'

The contents of register 7 are:

X'0C001000'

The contents of the decimal information field beginning at byte location X'100' are:

00 00 00 0+

The contents of the destination byte string beginning at byte location X'1000' are:

ds ds , ds ds ss . ds ds to C R

The condition code is:

0000

Example 1, after execution:

The instruction word is unchanged.

The new contents of register 6 are:

X'5C000104'

The new contents of register 7 are:

X'0000100C'

The contents of the decimal information field are unchanged.

The new contents of the destination byte string are:

\* \* \* \* \* \* . 00555

The new condition code is:

1000

The contents of register 1 are:

X'xxx01006'

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:

06 54 32 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 t C R

The new condition code is:

1011

The new contents of register 1 are:

X'xxx01001'

Example 3, before execution:

The initial conditions are identical to example 1, except that the contents of the decimal field are:

00 54 32 1+

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:

\* \* \* 5 4 3 . 2 1 5 5 5

The new condition code is:

1010

The new contents of register 1 are:

X'xxx01003'

### Example 4, before execution:

The instruction word is:

X'63400100'

The contents of register 4 are:

X'7B001000'

The contents of register 5 are:

X'19002000'

The contents of the decimal information field beginning at byte location X'1100' are:

06 12 50 0+ 01 23 4+ 03 5-

The contents of the destination byte string beginning at byte location X'2000' are:

A ds ds si . ds ds ds fs B ds ds ss . ds ds C fs 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'00002019'

The decimal information field is unchanged.

The new contents of the destination byte string are:

#612.500###12.345##035END

The new condition code is:

1011

The new contents of register 1 are:

X'xxx02013'

## **PUSH-DOWN INSTRUCTIONS**

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 SIGMA 9 computer provides for simplified and efficient programming of push-down processing by means of the following instructions:

| Instruction Name     | Mnemonic |
|----------------------|----------|
| Push Word            | PSW      |
| Pull Word            | PLW      |
| Push Multiple        | PSM      |
| Pull Multiple        | PLM      |
| Modify Stack Pointer | MSP      |

#### **STACK POINTER DOUBLEWORD (SPD)**

Each of these instructions operates with respect to a memory stack that is defined by a doubleword located at the effective address of the instruction. This doubleword, referred to as a stack pointer doubleword (SPD), has the following structure:

|   |   |   |   |    |   |   |   |   |   |    |    |    |    |    |    |    |    |    |    |    |    |    | ck |    |    |    |    |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 14 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

| T<br>S | Space count                                  | т<br>w | Word count                                   |
|--------|----------------------------------------------|--------|----------------------------------------------|
| 32     | 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | 48     | 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |

Bit positions 15 through 31<sup>t</sup> of the SPD contain a 17-bit address field<sup>t</sup> 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-ofstack 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

<sup>&</sup>lt;sup>t</sup>For real extended mode of addressing this is a 22-bit field (10-31); for real and virtual addressing modes it is a 17-bit field (15-31).

pull operation, the space count is incremented by 1 and the word count is decremented by 1. At the beginning of all 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 computer unconditionally aborts execution of the instruction, with the stack, the stack pointer doubleword, and the contents of general registers unchanged. Ordinarily, the computer traps to Homespace location X'42' 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 computer will trap to Homespace location X'42' as a result of impending overflow or underflow of the space count (SPD<sub>33-47</sub>), as follows:

- TS Space count overflow/underflow action
- 0 If the execution of a pull instruction would cause the space count to exceed 2<sup>15-1</sup>, or if the execution of a push instruction would cause the space count to be less than 0, the computer traps to Homespace location X'42' with the condition code unchanged.
- Instead of trapping to Homespace location X'42', the computer sets CC1 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 computer will trap to Homespace location X'42' 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 2<sup>15-1</sup>, or if the execution of a pull instruction would cause the word count to be less than 0, the computer traps to Homespace location X'42' with the condition code unchanged.
- Instead of trapping to Homespace location X'42', the computer 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 computer traps to Homespace location X'42', 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 1's) to indicate the reason for aborting the pushdown instruction, as follows:

#### 1 2 3 4 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 (SPD<sub>AR</sub>).
- O 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 (SPD<sub>32</sub>).
- 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 push-down stack limit trap was inhibited by both the TW and the TS bits.

If a push-down instruction is successfully executed, CC1 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:

- 1 2 3 4 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 computer does not trap to Homespace location X'42' 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, only those condition code configurations are given that can actually be produced by the instruction, provided that the computer does not trap to Homespace location X'42'.

# PSW PUSH WORD

(Doubleword index alignment)

|   |     |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ٦  |    |    |    |    |
|---|-----|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| * | 09  |   |   |   |   |   |   | F | ł  |    | Х  |    |    |    |    | ŀ  | le | e  | re | nc | e  | a  | dd | re | ss |    |    |    |    |    |
| 0 | 1 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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:

- The current top-of-stack address (SPD<sub>15-31</sub>)<sup>†</sup> 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.
- 3. The space count (SPD $_{33-47}$ ) 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), Trap: Push-down stack limit CC

$$(SPD)_{15-31} + 1 \longrightarrow SPD_{15-31}^{\dagger}$$

$$(R) \longrightarrow (SPD_{15-31})^{\dagger}$$

$$(SPD)_{33-47}^{-1} \longrightarrow SPD_{33-47}^{\phantom{\dagger}}$$

$$(SPD)_{49-63} + 1 \longrightarrow SPD_{49-63}^{\phantom{\dagger}}$$

Condition code settings:

| 1 | 2 | 3 | 4 | Result of PSW |
|---|---|---|---|---------------|
|   |   |   |   |               |

| 0 | 0 | 0 | 0 | Space count is greater<br>than 0.                                           | Instruction<br>completed |
|---|---|---|---|-----------------------------------------------------------------------------|--------------------------|
| 0 | 1 | 0 | 0 | Space count is now 0.                                                       | compreted                |
| 0 | 0 | 1 | 0 | Word count = 2 <sup>15</sup> -1,<br>TW = 1.                                 | Í                        |
| 1 | 1 | 0 | 0 | Space count = 0,<br>TS = 1.                                                 | Instruction              |
| 1 | 1 | 0 | 1 | Space count = 0, word<br>count = 0, TS = 1.                                 | aborted                  |
| 1 | 1 | 1 | 0 | Word count = 2 <sup>15</sup> -1,<br>space count = 0,<br>TW = 1, and TS = 1. | J                        |

For real extended mode of addressing this is a 22-bit field (10-31); for real and virtual addressing modes it is a 17-bit field (15-31).

PLW PULL WORD

(Doubleword index alignment)

| * | 08            | R            | x       | Reference address                                  |
|---|---------------|--------------|---------|----------------------------------------------------|
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 12 | 13 14 1 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

PULL WORD 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 pull operation can be performed successfully, the instruction operates as follows:

- Register R is loaded with the contents of the location pointed to by the current top-of-stack address (SPD<sub>15-31</sub>)<sup>†</sup>.
- 2. The current top-of-stack address is decremented by 1, to point to the new top-of-stack location.
- 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  $((SPD)_{15-31}) \longrightarrow R; (SPD)_{15-31} - 1 \longrightarrow SPD_{15-31}t$   $(SPD)_{33-47} + 1 \longrightarrow SPD_{33-47};$   $(SPD)_{49-63} - 1 \longrightarrow SPD_{49-63}$ 

Condition code settings:

1 2 3 4 Result of PLW

| 0  | 0 | 0 | 0  | Word count is greater than 0.                                               | Instruction<br>completed |
|----|---|---|----|-----------------------------------------------------------------------------|--------------------------|
| 0  | 0 | 0 | 1  | Word count is now 0. 🤝                                                      |                          |
| 0  | 0 | 1 | 1  | Word count = 0, TW = 1.                                                     |                          |
| 0  | 1 | 1 | 1  | Space count = 0,<br>word count = 0, TW = 1.                                 |                          |
| 1  | 0 | 0 | 0  | Space count = 2 <sup>15</sup> -1,<br>TS = 1.                                | Instruction<br>aborted   |
| 1  | 0 | 1 | 1  | Space count = 2 <sup>15</sup> -1,<br>word count = 0, TS = 1,<br>and TW = 1. |                          |
| PS | M |   | PU | SH MULTIPLE                                                                 |                          |

(Doubleword index alignment)

OB Х Reference address R 19 20 21 22 23 24 25 26 27 28 29 30

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 is assumed to 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 16 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 into the stack is register R + CC -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:

- The contents of registers R to R + CC 1 are stored in ascending sequence, beginning with the location pointed to by the current top-of-stack address (SPD<sub>15-31</sub>)<sup>†</sup> plus 1 and ending with the current topof-stack address plus CC.
- 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  $(SPD_{33-47})$  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 (SPD)_{15-31} + 1 \dots (R+CC-1) \longrightarrow (SPD)_{15-31}^{\dagger} + CC$ 

$$(SPD)_{15-31} + CC \longrightarrow SPD_{15-31}^{\dagger}$$

$$(SPD)_{33-47} - CC \longrightarrow SPD_{33-47}^{\dagger}$$

$$(SPD_{49-63} + CC \longrightarrow SPD_{49-63}^{\dagger}$$

Condition code settings:

| 1 | 2 | 3 |   | Result of PSM           |             |
|---|---|---|---|-------------------------|-------------|
| 0 | 0 | 0 | 0 | Space count > 0.        | Instruction |
| 0 | 1 | 0 | 0 | Space count = 0. $\int$ | completed   |

<sup>&</sup>lt;sup>t</sup>For real extended mode of addressing this is a 22-bit field (10-31); for real and virtual addressing modes it is a 17-bit field (15-31).

| 1 | 2 | 3 | 4 | Result of PSM                                                            |   |                        |
|---|---|---|---|--------------------------------------------------------------------------|---|------------------------|
| 0 | 0 | 1 | 0 | Word count + CC > $2^{15}-1$ ,<br>TW = 1.                                |   |                        |
| 1 | 0 | 0 | 0 | Space count < CC, TS = 1.                                                |   |                        |
| 1 | 0 | 0 | 1 | Space count < CC, word<br>count = 0, TS = 1.                             |   |                        |
| 1 | 0 | 1 | 0 | Space count < CC, word<br>count + CC > $2^{15}-1$<br>TS = 1, and TW = 1. | } | Instruction<br>aborted |
| 1 | 1 | 0 | 0 | Space count = 0, $TS = 1$ .                                              |   |                        |
| 1 | 1 | 0 | 1 | Space count = 0, word<br>count = 0, TS = 1.                              |   |                        |
| 1 | 1 | 1 | 0 | Space count = 0, word<br>count + CC > 215-1,<br>TS = 1, and TW = 1.      |   |                        |

If the instruction operation extends into a page of memory that is 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. In either case, if a trap is to occur during the execution of this instruction, it will be detected before the actual operation begins and the trap will occur immediately.

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 core memory. In this case the results will be unpredictable if any source registers are also used as destination registers.

| PLM |      | MULTI |   | alignment) |         |
|-----|------|-------|---|------------|---------|
| *   | 0A . | R     | Х | 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 is assumed to 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+CC-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.

11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 3

If there is a sufficient number of words in the stack to load all of the specified registers, PLM operates as follows:

 Registers R+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  $(SPD_{15-31})^{t}$  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.
- The space count (SPD<sub>33-47</sub>) 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

$$((SPD)_{15-31})^{\dagger} \longrightarrow R + CC - 1, \dots,$$

$$((SPD)_{15-31} - |CC - 1|) \longrightarrow R^{\dagger}$$

$$(SPD)_{15-31} - CC \longrightarrow SPD_{15-31}^{\dagger}$$

$$(SPD)_{33-47} + CC \longrightarrow SPD_{33-47}$$

$$(SPD)_{49-63} - CC \longrightarrow SPD_{49-63}$$

Condition code settings:

| 1 | 2 | 3 | 4 | Result of PLM                                                                    |                        |
|---|---|---|---|----------------------------------------------------------------------------------|------------------------|
| 0 | 0 | 0 | 0 | Word count >0                                                                    | Instruction            |
| 0 | 0 | 0 | 1 | Word count = 0                                                                   | completed              |
| 0 | 0 | 1 | 0 | Word count < CC,<br>TW = 1                                                       |                        |
| 0 | 0 | 1 | 1 | Word count = 0,<br>TW = 1                                                        |                        |
| 0 | 1 | 1 | 0 | Space count = 0,<br>word count < CC,<br>TW = 1                                   |                        |
| 0 | 1 | 1 | 1 | Space count = 0,<br>word count = 0,<br>TW = 1                                    | Instruction<br>aborted |
| 1 | 0 | 0 | 0 | Space count+CC > 2 <sup>15</sup> -1,<br>TS = 1                                   |                        |
| 1 | 0 | 1 | 0 | Space count + CC > 2 <sup>15</sup> -1,<br>word count < CC, TS = 1,<br>and TW = 1 |                        |
| 1 | 0 | 1 | 1 | Space count + CC $> 2^{15}$ -1,<br>word count = 0, TS = 1,<br>and TW = 1         |                        |

If the instruction operation extends into a page of memory that is protected either by the access protection codes or write locks, the memory protection can occur. If the operation extends into a memory region that is physically not present, the nonexistent memory address trap can occur. In either case, if a trap is to occur during the execution of this instruction, it will be detected before the actual operation begins and the trap will occur immediately.

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 taken from the general registers rather than from core 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)

| * |   |   | 1 | 13 |   |   |   |   |   | ł | र  |    |    | Х  |    |    |    |    | R  | lef | e  | re | nc | e  | a  | dd | re | ss |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

MODIFY STACK POINTER modifies the stack pointer doubleword, located at the effective doubleword address of MSP by the contents of register R. Register R is assumed to have the following format:

|   |   |   |   |    |   |   |   |   |   |    |    |    |    |    |    | ±  |    |    |       |    | Μ  | 00 | lif | ie | r  |    |    |      |      |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-------|----|----|----|-----|----|----|----|----|------|------|----|
| 0 | 1 | 2 | 3 | 14 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 20 | 21 | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 ; | 30 3 | ī. |

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 computer either traps to Homespace location X'42' 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:

- The modifier in register R is algebraically added to the current top-of-stack address (SPD 15-31)<sup>†</sup>, 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  $(SPD_{33-47})$  and the result becomes the new space count.
- 3. The modifier is algebraically added to the current word count (SPD<sub>49-63</sub>) 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.

<sup>&</sup>lt;sup>t</sup>For real extended mode of addressing this is a 22-bit field (10-31); for real and virtual addressing modes it is a 17-bit field (15-31).

$$(SPD)_{15-31} + (R)_{16-31SE} \longrightarrow SPD_{15-31}^{\dagger} (SPD)_{33-47} - (R)_{16-31} \longrightarrow SPD_{33-47}^{\phantom{\dagger}} (SPD)_{49-63} + (R)_{16-31} \longrightarrow SPD_{49-63}^{\phantom{\dagger}}$$

Condition code settings:

| 1 | 2 | 3 | 4 | Result of MSP                                        |   |                          |
|---|---|---|---|------------------------------------------------------|---|--------------------------|
| 0 | 0 | 0 | 0 | Space count > 0,<br>word count > 0.                  | ) |                          |
| 0 | 0 | 0 | 1 | Space count > 0,<br>word count = 0.                  |   |                          |
| 0 | 1 | 0 | 0 | Space count = 0,<br>word count > 0.                  |   | Instruction<br>completed |
| 0 | 1 | 0 | 1 | Space count = 0,<br>word count = 0,<br>modifier = 0. |   |                          |

If CC1, or CC3, or both CC1 and CC3 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<sub>32</sub>), by the trap-on-word inhibit (SPD<sub>48</sub>), or both. The condition code is set to reflect the reason for aborting as follows:

|   |   | Ũ |   |                                                                                           |
|---|---|---|---|-------------------------------------------------------------------------------------------|
| 1 | 2 | 3 | 4 | Status of space and word counts                                                           |
| - | - | - | 0 | Word count >0.                                                                            |
| - | - | - | 1 | Word count = $0$ .                                                                        |
| - | - | 0 | - | $0 \leq \text{word count } + \text{ modifier} \leq 2^{15} - 1.$                           |
| - | - | 1 | - | Word count + modifier < 0, and TW = 1 or word count + modifier > $2^{15}$ -1, and TW = 1. |
| - | 0 | - | - | Space count >0.                                                                           |
| - | 1 | - | - | Space count = 0.                                                                          |
| 0 | - | - | - | $0 \leq \text{space count} - \text{modifier} \leq 2^{15} - 1.$                            |

1 - - - Space count - modifier < 0, and TS = 1 or space count - modifier > 2<sup>15</sup>-1, and TS = 1.

## **EXECUTE/BRANCH INSTRUCTIONS**

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 unconditional (or conditional and the branch 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.

#### **BRANCHES IN REAL EXTENDED ADDRESSING MODE**

The extension address field of the PSD will be modified automatically by branch instructions. If the effective address of a branch instruction is outside the first 64K of real memory (region 0 is defined as the first 64K of real memory), the high-order bits of this full effective address will automatically be loaded into the Extension Address field of the PSD if the branch is taken. The remaining part of the effective branch address will, of course, be loaded into bit positions 16-31 of the PSD. In addition, bit position 15 of the PSD, the Extension Selector, will be set to 1.

If the effective branch address is to a location within the first 64K of memory, then the Extension Address field of the PSD will <u>not</u> be modified. The effective address will be loaded into the 16 low-order positions of the instruction address field and the Extension Selector (bit 15) will be cleared (set equal to zero). This means that once the Extension Address field has been set, it will remain set until it is either changed by the loading of a new PSD or by actually branching into another 64K region of memory (excluding region 0).

A BRANCH AND LINK instruction in real extended addressing will store the full address of the next instruction in the link register. If the Extension Selector in the PSD at the time BRANCH AND LINK is executed is zero, then the address stored in the link register will be the incremented 16-bit displacement from positions 16-31 of the PSD and zeros in the high-order address positions. If the Extension Selector in the PSD is one, then the address stored will be the incremented 16-bit displacement (PSD 16-31) concatenated with the contents of the Extension Address field (PSD 42-47), which are loaded into bit positions 10-15 of the link register. In both cases, positions 0-9 of the link register will be cleared.

#### NONALLOWED OPERATION TRAP DURING EXECUTION OF BRANCH INSTRUCTION

A branch instruction has two possible places from which the next instruction may be taken: the location following the branch instruction or the location that may be branched to. It is possible that 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.

<sup>&</sup>lt;sup>t</sup>For real extended mode of addressing this is a 22-bit field (10-31); for real and virtual addressing modes it is a 17-bit field (15-31).

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 non-existent or unavailable for read access to the program in the slave mode.
- 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 computer 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 doubleword contain the virtual address of the instruction, referred to as the instruction address. At this time, the computer traps to Homespace location X'40' if the actual address of the instruction is nonexistent or instructionaccess protected. If the instruction address is existent and is not instruction-access protected, the instruction is accessed and the instruction address portion of the program status doubleword 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 computer 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.

#### EXU EXECUTE (Word index alignment)

| _ | - |   |   |   |    |   |   |   | <del></del> |   |    |    | _  |    |    | _  |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    |    | • |
|---|---|---|---|---|----|---|---|---|-------------|---|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|---|
| * |   |   |   | Ċ | 57 | , |   |   |             |   |    |    |    | Х  |    |    |    |    | R  | lef | fei | e  | nc | e  | a  | bb | re | ss |    |    |    |    |   |
|   | 1 |   |   |   |    |   |   |   |             |   |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    |    |   |
| 0 | 1 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8           | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |   |

EXECUTE causes the computer 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 computer 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 computer 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 computer 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: | Determined by       | Traps: | Determined by       |
|-----------|---------------------|--------|---------------------|
|           | subject instruction | -      | subject instruction |

Condition code settings: Determined by subject instruction

## BCS BRANCH ON CONDITIONS SET (Word index alignment)

| * | • |   |   | ė | 59 | , |   |   |   |   |   | २  |    |    | Х  |    |    |    |    |    | Re | fe | re | n  | ce | a  | do | dre | ess | 5  |    |    |    |
|---|---|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 6 |   | 1 | 2 | 3 | 4  | 4 | ; | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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<sup>†</sup> 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 CC  $\cap R \neq 0$ 

If  $CC \cap (I)_{8-11} \neq 0$ ,  $EVA_{15-31} \longrightarrow IA^{-1}$ 

If CC  $\cap$  (I)<sub>8-11</sub> = 0, IA not affected

If the R field of BCS 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.

<sup>&</sup>lt;sup>t</sup>See "Branches in Real Extended Addressing Mode" in the introductory description under "Execute/Branch Instructions".

| *  |   |   | ć | 58 |   |   |   |   | F | R  |    |    | Х  |    |    |    |    |    | Re | fe   | re | n  | ce  | a  | Ide | dr | es | s  |    |    |    |  |
|----|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|------|----|----|-----|----|-----|----|----|----|----|----|----|--|
| ٥. | T | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 2 | 21 | 22 | 231 | 24 | 25  | 26 | 27 | 28 | 29 | 30 | 31 |  |

BRANCH ON CONDITIONS RESET forms the 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<sup>†</sup> of the BCR 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  $CC \cap R = 0$ 

If 
$$CC \cap (I)_{8-11} = 0$$
,  $EVA_{15-31} \longrightarrow IA_{15-31}$ 

If CC  $\cap$  (I)<sub>8-11</sub>  $\neq$  0, IA not affected

If the R field of BCR is 0, the next instruction to be executed after BCR is always the instruction located at the effective address of BCR, thus effectively producing a "branch unconditionally" instruction.

BIR BRANCH ON INCREMENTING REGISTER (Word index alignment)

| * | 6     | 5 |   |   |   |   |   | R  |    |    | Х  |    |    |    |    |    | Ref | -  |    |    |    |    |    |    |    |    |    |    |    |  |
|---|-------|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|--|
| 0 | 1 2 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |  |

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<sup>†</sup> 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)

If 
$$(R)_0 = 1$$
,  $EVA_{15-31} \longrightarrow IA$ 

If 
$$(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 computer aborts execution of the BIR instruction and traps to Homespace location X'40'. In this case, the instruction address stored by the XPSD instruction in location X'40' is the virtual address of the aborted BIR instruction. If the computer 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 computer aborts execution of the BIR and traps to Homespace location X'4C' with register R unchanged.

| BDR | BRANCH ON DECREMENTING REGISTER |
|-----|---------------------------------|
|     | (Word index alignment)          |

| * |   |   |   | ( | 54 |   |   |   |   | R |    |    |    | Х  |    |    |    |    | 1  | Re | fe | ere | ene | ce | a  | do | dre | es | s  |    |    |    |
|---|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|-----|----|----|----|----|----|
| 0 | 1 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21  | 22  | 23 | 24 | 25 | 26  | 27 | 28 | 29 | 30 | 31 |

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<sup>†</sup> 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)<sub>0</sub> = 0 and (R)<sub>1-31</sub>  $\neq$  0, EVA<sub>15-31</sub>  $\longrightarrow$  IA  
If (R)<sub>0</sub> = 1 or (R) = 0, IA not affected

If the effective address of BDR 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 BDR is nonexistent, the computer aborts execution of the BDR instruction and traps to Homespace location X'40'. In this case, the instruction address stored by the XPSD instruction in location X'40' is the virtual address of the aborted BDR instruction. If the computer 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 computer aborts execution of the BDR and traps to Homespace location X'4C' with register R unchanged.

BAL BRANCH AND LINK (Word index alignment)

| * |   |   | 6 | A |   |   |   |   | I | र  |    |    | Х  |    |    |    |    |    | Re | fe | re  | n  | ce | a  | do | dre | ess | 5  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21. | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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.

<sup>&</sup>lt;sup>†</sup>See "Branches in Real Extended Addressing Mode" in the introductory description under "Execute/Branch Instructions".

The BAL instruction in real extended addressing will store the full address of the next instruction in the specified R register. If the Extension Selector in the PSD at the time BAL is executed is equal to zero, then the address stored in the specified R register will be the incremented 16-bit displacement from positions 16-31 of the PSD, and zeros in the high-order address positions. If the Extension Selector in the PSD is equal to one, then the address stored will be the incremented 16-bit displacement (PSD 16-31) concatenated with the contents of the Extension Address (PSD 42-47). In both cases, positions 0-9 of the specified R register will be set equal to zero.

Affected: (R), (IA)

$$IA \longrightarrow R_{15-31}; 0 \longrightarrow R_{0-14}; EVA_{15-31} \longrightarrow IA$$

If the effective address of BAL 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 computer aborts execution of the BAL instruction and traps to Homespace location X'40' (nonallowed operation trap). In this case, the instruction address stored by the XPSD instruction in location X'40' is the virtual address of the aborted BAL instruction. If the computer 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 computer aborts execution of the BAL and traps to Homespace location X'4C' with register R changed to the updated instruction address.

## **CALL INSTRUCTIONS**

Each of the four CALL instructions causes the computer to trap to a specific location for the next instruction in sequence. The four CALL instructions, their mnemonics, and the locations to which the computer traps are:

| Instruction<br>Name | Mnemonic | Trap Home-<br>space Location |
|---------------------|----------|------------------------------|
| CALL 1              | CAL1     | X'48'                        |
| CALL 2              | CAL2     | X'49'                        |
| CALL 3              | CAL3     | X'4A'                        |
| CALL 4              | CAL4     | X'4B'                        |

Each of these four trap locations must contain an EXCHANGE PROGRAM STATUS DOUBLEWORD (XPSD) instruction. Execution of XPSD in the trap location for a CALL instruction is described under "Control Instructions, XPSD Exchange Program Status Doubleword". 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 computer to branch to a specific routine; thus, the four CALL instructions can be used to enter any of as many as 64 unique routines. If an indirect address in nonexistent memory is specified, the computer traps to Homespace location X'40'. The effective address of a CALL instruction is not used for a memory reference and, therefore, can not cause a trap.

#### CALL CALL 1

(Word index alignment)

| *        |   |   |   |   | 0 | 4 |   |   |   |   |   | R |    |    |    | Х  |    |    |    |    |    | Re | efe | ere | en | ce | e 0 | Ide | dr | es | s  |    |    |    |
|----------|---|---|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|-----|----|----|----|----|----|----|
| <u> </u> | - | 1 | 2 | 3 | + | 4 | 5 | 6 | - | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24  | 25  | 26 | 27 | 28 | 29 | 30 | 31 |

CALL 1 causes the computer to trap to Homespace location  $X^{\prime}48^{\prime}.$ 

# CAL2 CALL 2

(Word index alignment)

| * |   |   | ( | 05 |   |   |   |   | R |    |    |    | Х  |    |    |    |    |    | Re | efe | ere | en | ce | e c | dd | dr | es | s  |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

CALL 2 causes the computer to trap to Homespace location X'49'.

## CAL3 CALL 3

(Word index alignment)

| * |   |     | 06 |   |   |   |   | R |    |    |    | Х  |    |    |    |    |    | Re | efe | ere | en | ce | e c | d  | dr | es | s  |    |    |    |
|---|---|-----|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 2 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

CALL 3 causes the computer to trap to Homespace location  $X^\prime 4A^\prime.$ 

#### CAL4 CALL 4

(Word index alignment)

| * |   |   | ( | 07 | , |   |   |   | R | 2  |    |    | X  |    |    |    |    |    | Re | fe | ere | en | ce | c  | ıdı | dr | es | s  |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21  | 22 | 23 | 24 | 25  | 26 | 27 | 28 | 29 | 30 | 31 |

CALL 4 causes the computer to trap to Homespace location X'4B'.

## **CONTROL INSTRUCTIONS**

The following privileged instructions are used to control the basic operating conditions of the SIGMA 9 computer:

| Instruction Name                   | Mnemonic |
|------------------------------------|----------|
| Load Program Status Doubleword     | LPSD     |
| Exchange Program Status Doubleword | XPSD     |
| Load Register Pointer              | LRP      |
| Move to Memory Control             | ММС      |
| 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 computer is in the slave mode (i.e., while bit 8 of the current program status doubleword is a 1), the computer unconditionally traps to Homespace location X'40' prior to executing the instruction.

#### **PROGRAM STATUS DOUBLEWORD**

The SIGMA 9 program status doubleword has the following structure when stored in memory:

| CC                | SZNSM                                | D A A S E S                | IA 17 18 19 20 21 22 23 | -       | 28 29 30 31           |  |  |  |  |  |  |  |
|-------------------|--------------------------------------|----------------------------|-------------------------|---------|-----------------------|--|--|--|--|--|--|--|
| WK 32 33 34 35 36 | C I E M<br>I I I A<br>37 38 39 40 41 | EA<br>42 43 44 45 46 47    | TSF                     | RP      | R<br>A<br>60 61 62 63 |  |  |  |  |  |  |  |
| Bit<br>Position   | Desig–<br>nation                     | Function                   |                         |         |                       |  |  |  |  |  |  |  |
| 0-3               | СС                                   | Condition                  | code                    |         |                       |  |  |  |  |  |  |  |
| 5                 | FS                                   | Floating s                 | ignificance ma          | sk      |                       |  |  |  |  |  |  |  |
| 6                 | FZ                                   | Floating z                 | zero mask               |         |                       |  |  |  |  |  |  |  |
| 7                 | FN                                   | Floating r                 | ormalize mask           |         |                       |  |  |  |  |  |  |  |
| 8                 | MS                                   | Master/slave mode control  |                         |         |                       |  |  |  |  |  |  |  |
| 9                 | мм                                   | Memory map mode control    |                         |         |                       |  |  |  |  |  |  |  |
| 10                | DM                                   | Decimal c                  | arithmetic trap         | mask    |                       |  |  |  |  |  |  |  |
| 11                | AM                                   | Fixed-poi<br>mask          | nt arithmetic o         | verflow | ' trap                |  |  |  |  |  |  |  |
| 12                | AS                                   | ANSCII n                   | nask                    |         |                       |  |  |  |  |  |  |  |
| 15                | ES                                   | Extension                  | selector                |         |                       |  |  |  |  |  |  |  |
| 16-31             | IA                                   | Instructio                 | n address               |         |                       |  |  |  |  |  |  |  |
| 34,35             | WΚ                                   | Write key                  | ,                       |         |                       |  |  |  |  |  |  |  |
| 37                | CI                                   | Counter i                  | nterrupt group          | inhibit |                       |  |  |  |  |  |  |  |
| 38                | II                                   | I/O inter                  | rupt group inhi         | bit     |                       |  |  |  |  |  |  |  |
| 39                | EI                                   | External interrupt inhibit |                         |         |                       |  |  |  |  |  |  |  |
| 40                | MA                                   | Mode altered               |                         |         |                       |  |  |  |  |  |  |  |
| 42-47             | EA                                   | Extension address          |                         |         |                       |  |  |  |  |  |  |  |
| 48-55             | T SF                                 | Trap status field          |                         |         |                       |  |  |  |  |  |  |  |
| 56-59             | RP                                   | Register pointer           |                         |         |                       |  |  |  |  |  |  |  |
| 60                | RA                                   | Register altered           |                         |         |                       |  |  |  |  |  |  |  |

The detailed functions of the various portions of the SIGMA 9 program status doubleword are described in Chapter 2, "Program Status Doubleword".

LPSD LOAD PROGRAM STATUS DOUBLEWORD (Doubleword index alignment, privileged)

| * |   |   |   |   | 0 | E |   |   |   | L<br>P |   | C<br>L | A<br>D |    | х  |    |    |    |    |    | ef |    |    |    | -  |    |    |    | · · . |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|--------|---|--------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|
| 0 | - | 1 | 2 | ; | 3 | 4 | 5 | 6 | 7 | 8      | 9 | 10     | 11     | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27    | 28 | 29 | 30 | 31 |

LOAD PROGRAM STATUS DOUBLEWORD replaces bits 0 through 39 of the current program status doubleword with bits 0 through 39 of the effective doubleword.

Control bits used in the LPSD instruction are:

| Bit<br>Position | Desig <b>-</b><br>nation | Control<br><u>Function</u>  |
|-----------------|--------------------------|-----------------------------|
| 8               | LP                       | Load pointer control        |
| 10              | CL                       | Clearing of interrupt level |
| 11              | AD                       | Armed/disarmed state        |

The following conditional operations are performed:

- If bit position 8 (LP) of LPSD contains a 1, bits 56 through 59 of the current program status doubleword (register pointer) are replaced by bits 56 through 59 of the effective doubleword; if bit 8 of LPSD is a 0, the current register pointer value remains unchanged.
- 2. If bit position 10 (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 po  | osition        |                                   |
|---------|----------------|-----------------------------------|
| 10 (CL) | <u>11 (AD)</u> | Function                          |
| 1       | 0              | Clear and disarm interrupt level. |
| 1       | 1              | Clear and arm interrupt level.    |
| 0       | 1              | Clear PDF flag.                   |
| 0       | 0              | No control action.                |

 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.

Those portions of the effective doubleword that correspond to undefined fields in the program status doubleword are ignored.

| Affected: (PSD), interrupt system if (I) $_{10} = 1$                                 |
|--------------------------------------------------------------------------------------|
| $ED_{0-3} \longrightarrow CC; ED_{5-7} \longrightarrow FS, FZ, FN$                   |
| ED <sub>8</sub> −−−→ MS; ED <sub>9</sub> −−−→ MM                                     |
| ED <sub>10</sub> → DM; ED <sub>11</sub> → AM                                         |
| ED <sub>15</sub> → ES                                                                |
| $ED_{16-31} \longrightarrow IA; ED_{34-35} \longrightarrow WK$                       |
| $ED_{37-39} \longrightarrow CI, II, EI; if (I)_8 = 1, ED_{56-59} \longrightarrow RP$ |
| If (I) $_{10} = 1$ and (I) $_{11} = 1$ , clear and arm interrupt                     |
| If (I) $_{10} = 1$ and (I) $_{11} = 0$ , clear and disarm interrupt                  |

Control Instructions 101

## **XPSD** EXCHANGE PROGRAM STATUS DOUBLEWORD (Doubleword index alignment, privileged)

|   | 05            | L | A | A    | 8   | Х    | (    | Τ   | +          |    | F   | ٢e | fe | re | nc | e  | a  | dd | re | ess |    |    |    |    |
|---|---------------|---|---|------|-----|------|------|-----|------------|----|-----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
| * | OF            | Р | I | T    |     |      |      | 2   | <b>0</b> - | bi | t i | re | fe | re | nc | e  | a  | dd | re | ess |    |    |    |    |
| 0 | 1 2 3 4 5 6 7 | 8 | 9 | 10 1 | 111 | 2 13 | 3 14 | 1 1 | 5 16       | 17 | 18  | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

EXCHANGE PROGRAM STATUS DOUBLEWORD stores the currently active PSD 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 PSD 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 | Desig–<br>nation | Control<br>Function     | Where Used                     |
|-----------------|------------------|-------------------------|--------------------------------|
| 8               | LP               | Load pointer<br>control | All XPSDs                      |
| 9               | AI               | Address increment       | Trap XPSD                      |
| 10              | AT               | Addressing type .       | Trap XPSD or<br>interrupt XPSD |

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 effective address is generated according to the rules for addressing then in effect as described by the currently active PSD; that is, the CPU 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.

## XPSD (interrupt instruction)

An XPSD instruction (in an interrupt location) executed as a result of an interrupt is called an interrupt instruction. Bit position 10 determines the type of addressing to be used by the XPSD. If bit positions 10 and 0 are equal to zero, bit positions 12–31 of the instruction unconditionally specify a direct address within the first 1,048,576 words of real memory. Since the index field is used for addressing, indexing is not possible. If bit 10 is equal to zero and indirect addressing is specified (bit 0 = 1), the indirect address, interpreted as in real extended addressing, is found in the word specified by bits 12–31. (In brief, the current type of addressing has no bearing on the execution of this instruction.) Bit position 9 is not effective during an interrupt instruction and must be a zero.

If bit 10 is a 1, the effective address of the XPSD is generated subject to the current active addressing mode (real, real extended, or virtual), and indexing is permitted.

## XPSD (trap instruction)

An XPSD instruction (in a trap location) executed as a result of a trap entry operation is called a trap instruction. Bit positions 9 and 10 are both effective in this instruction. Bit position 10 determines the type of addressing to be used by the XPSD. If bit positions 10 and 0 are equal to zero, bits 12–31 of the instruction unconditionally specify a direct address within the first 1,048,576 words of real memory. Since the index field is used for addressing, indexing is not possible. If bit 10 is equal to zero and indirect addressing is specified (bit 0 = 1), the indirect address, interpreted as in real extended addressing, is found in the word specified by bits 12–31. (In brief, the effective address is generated independently of the type of addressing being used by the program that was trapped.)

If bit position 10 is a 1, the effective address is generated subject to the same current active addressing mode (real, real extended, or virtual) as the program that was trapped, and indexing is permitted.

The following additional operations are performed on the new program status doubleword if, and only if, the XPSD is being executed as the result of a nonallowed operation (trap to Homespace location X'40') or a CALL instruction (trap to Homespace location X'48', X'49', X'4A', or X'4B'):

- Nonallowed operations the following additional functions are performed when XPSD is being executed as a result of a trap to Homespace location X'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 doubleword (CC1) is set to 1. Then, if bit 9 (A1) of XPSD is a 1, bit positions 15–31 of the new program status doubleword (next instruction address) are incremented by 8.<sup>†</sup>
  - 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 doubleword (CC2) is set to 1. Then, if bit 9 of XPSD is a 1, the instruction address portion of the new program status doubleword is incremented by 4.<sup>†</sup>
  - c. Privileged instruction violation if the reason for the trap condition is an attempt to execute a privileged instruction while the computer is in the slave mode, bit position 2 of the new program status doubleword (CC3) is set to 1. Then, if bit position 9 of XPSD is 1, the instruction address portion of the new program status doubleword is incremented by 2.<sup>†</sup>

<sup>&</sup>lt;sup>t</sup>If the CPU is in a real extended addressing mode and the effective address of the trap XPSD instruction is generated subject to that current mode, the addition of the condition code is restricted to bits 16 to 31 of the Instruction Address. The Extension Selector (bit 15) and Extension Address (bits 42-47) will not be affected if a carry should result.

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 doubleword (CC4) is set to 1. Then, if bit 9 of XPSD is a 1, the instruction address portion of the new program status doubleword is incremented by 1.<sup>†</sup>

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'0C' and X'0D'. If either of these operation codes is used as an instruction while the computer is in the slave or master-protected mode, CC1 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 doubleword 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 doubleword 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 Homespace location X'48', X'49', X'4A', or X'4B'.
  - a. The R field of the CALL instruction causing the trap is logically inclusively ORed into bit positions 0-3 (CC) of the new PSD.
  - 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 PSD.
- 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 Homespace location X'46', X'4C', or X'4D', respectively.
  - a. The contents of TCC 1-4 are logically inclusively ORed into bit positions 0-3 (CC) of the new PSD.
  - 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 PSD.

If bit position 9 of XPSD contains a 0, the instruction address portion of the new PSD 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 doubleword is stored in the doubleword location pointed to by the effective address of XPSD in the following form:

Program status doubleword

| ſ |   | _ | _ |   | Τ |   | F | F | F | м | м | D  | A  |     |    |    | ES |    |    |    |    |    |    |    | IÅ | 1  |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|---|---|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |   | 0 | C |   |   |   | s | z | Ν | s | M | м  | м  |     |    |    |    |    |    |    |    |    |    | ]  | A  |    |    |    |    |    |    |    |    |
|   | 0 | 1 | 2 | 3 | T | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 112 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

| WK C I E<br>I I I       | Å EA                    | TSF                     | RP          | R<br>A      |
|-------------------------|-------------------------|-------------------------|-------------|-------------|
| 32 33 34 35 36 37 38 39 | 40 41 42 43 44 45 46 47 | 48 49 50 51 52 53 54 55 | 56 57 58 59 | 60 61 62 63 |

The current program status doubleword (as illustrated above) is replaced by a new program status doubleword 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, 40, and 42-47 of the current program status doubleword are unconditionally replaced by bits 0-35, 40, and 42-47 of the second effective doubleword. The affected portions of the program status doubleword are:

| Bit<br>Position | Desig–<br>nation | Function                                  |
|-----------------|------------------|-------------------------------------------|
| 0-3             | СС               | Condition code                            |
| 5-7             | FS, FZ,<br>FN    | Floating control                          |
| 8               | MS               | Master/slave mode control                 |
| 9               | мм               | Mapping mode control                      |
| 10              | DM               | Decimal arithmetic trap mask              |
| 11              | AM               | Fixed-point arithmetic trap mask          |
| 15              | ES               | Extension selector<br>Instruction address |
| 16-31           | IA               | Instruction address                       |
| or              |                  |                                           |
| 15-31           | IA               | Instruction address (real or virtual)     |
| 34-35           | WK               | Write key                                 |
| 40              | MA               | Mode altered                              |
| 42-47           | EA               | Extension address                         |
|                 |                  |                                           |

3. A logical inclusive OR is performed between bits 37 through 39 of the current program status doubleword and bits 37 through 39 of the second effective doubleword.

| Desig–<br>nation | Function                   |
|------------------|----------------------------|
| CI               | Counter interrupt inhibit  |
| II               | I/O interrupt inhibit      |
| EI               | External interrupt inhibit |
|                  | nation<br>CI<br>II         |

<sup>&</sup>lt;sup>t</sup> If the CPU is in a real extended addressing mode and the effective address of the trap XPSD instruction is generated subfect to that current mode, the addition of the condition code s restricted to bits 16 to 31 of the Instruction Address. The fixtension Selector (bit 15) and Extension Address (bits 42-47) vill not be affected if a carry should result.

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 doubleword remain unchanged; if any (or all) of bits 37, 38, or 39 of the second effective doubleword are 1's, the corresponding bits in the current program status doubleword are set to 1'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 56 through 59 of the current program status doubleword (register pointer) are replaced by bits 56 through 59 of the second effective doubleword; if bit 8 of XPSD is a 0, the current register pointer value remains unchanged.

Affected: (EDL), (PSD)

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$$

$$ED2_{0-3} \longrightarrow CC; ED2_{5-7} \longrightarrow FS, FZ, FN$$

$$ED2_{8} \longrightarrow MS; ED2_{9} \longrightarrow MM$$

$$ED2_{10} \longrightarrow DM; ED2_{11} \longrightarrow AM; ED_{15-31} \longrightarrow IA$$
or
$$ED2_{15} \longrightarrow ES$$

$$ED2_{16-31} \longrightarrow IA; ED2_{34-35} \longrightarrow WK$$

$$ED2_{37-39} \cup CI, II, EI \longrightarrow CI, II, EI; ED2_{40} \longrightarrow MA$$

$$ED_{42-47} \longrightarrow EA$$
If (1)<sub>8</sub> = 1, ED2\_{56-59} \longrightarrow RP
If (1)<sub>8</sub> = 0, RP not affected  
If nonexistent instruction, 1 \longrightarrow CC1 then, if (1)\_{9} = 1, IA + 8 \longrightarrow IA

If nonexistent memory address,  $1 \longrightarrow CC2$  then, if  $(I)_{o} = 1$ ,  $IA + 4 \rightarrow IA$ 

If privileged instruction violation,  $1 \longrightarrow CC3$  then, if  $(I)_{o} = 1$ ,  $IA + 2 \longrightarrow IA$ 

If memory protection violation,  $1 \rightarrow CC4$  then, if  $(I)_{9} = 1$ ,  $IA + 1 \rightarrow IA$ 

If CALL instruction, CC u CALL<sub>8-11</sub>  $\rightarrow$  CC then, if (I)<sub>9</sub> = 1,  $IA + CALL_{8-11} \longrightarrow IA$ 

If (I)q = 0, IA not affected

If watchdog timer, parity error, or instruction exception trap,  $ED2_{0-3}$  u TCC1-4  $\rightarrow$  CC1-4 then, if (I)<sub>q</sub> = 1, IA + TCC1-4 → IA

#### LRP LOAD REGISTER POINTER (Word index alignment, privileged)

| * |   |   | 2 | ?F |   |      | R        | 2  |      |    | Х  |    |   |    |    | ۱  | Re | fe | re   | no   | ce | a   | do | łre | ess | ;  |    | ٦    |
|---|---|---|---|----|---|------|----------|----|------|----|----|----|---|----|----|----|----|----|------|------|----|-----|----|-----|-----|----|----|------|
| Ļ | Ļ | 2 | - |    | - | <br> | <u>.</u> | 10 | - 11 | 10 | 12 | 17 | 1 | 14 | 17 | 10 | 10 | 00 | - 11 | - 20 | 22 | 127 | 25 | 0/  | 27  | 20 | 20 | <br> |

LOAD REGISTER POINTER loads bits 26 and 27 of the effective word into the register pointer (RP) portion of the current program status doubleword. Bit positions 0 through 25 and 28 through 31 of the effective word are ignored, and no other portion of the program status doubleword 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 computer traps to Homespace location X'4D'.

Affected: RP

Trap: Instruction exception

#### MMC MOVE TO MEMORY CONTROL (Word index alignment, privileged, continue

after interrupt)

| * |   |   | ć | 5F |   |   |   |    | R | l  |    |    |    | ol |    |    |    |    | Re |    |    |    |    |    |    |    |    |    |    |    |    |  |
|---|---|---|---|----|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |  |

MOVE TO MEMORY CONTROL loads a string of one or more words into one of the three blocks of memory control registers (memory control registers are described in Chapter 2, under "Memory Address Control". Bit positions 12-14 of MMC are not used as an index register address; instead, they are used to specify which block of memory control registers is to be loaded, as follows:

### **Bit Position**

MA

| 12 | 13 | 14 | Function                            |
|----|----|----|-------------------------------------|
| 0  | 0  | 1  | Load memory write protection locks. |
| 0  | 1  | 0  | Load access protection.             |
| 1  | 0  | 0  | Load memory map (8–bit format).     |
| 1  | 0  | 1  | Load memory map (13-bit format).    |

An attempt to execute an MMC instruction with any code other than the four above causes the instruction to trap to Homespace location X'4D', instruction exception trap.

Bit positions 15–31 of MMC are ignored insofar as the operation of the instruction is concerned, and the results of the instruction are the same whether MMC is indirectly addressed or not.

The R field of MMC designates an even-odd pair of general registers (R and Ru1) that are used to control the loading of the specified bank of memory control registers. Registers R and Ru1 are assumed to contain the following information:

### **Register** R:

|   | 8 | 8 |   | 8 |   |   |       |   | 8 | 8 |    |   |    |   |   |    |    |    |    | +  |    |    |    |    |    |    | in  |    |    |    |    |   |    |    |    |    |    |
|---|---|---|---|---|---|---|-------|---|---|---|----|---|----|---|---|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|---|----|----|----|----|----|
|   |   |   |   |   |   |   |       |   |   |   |    |   | (  | С | o | nt | rc | Ы  | iı | 'n | a  | ge | a  | Id | dr | es | ss, | r  | ec | ıl | е  | x | te | n  | de | d  |    |
| 0 | 1 |   | 2 | 1 | 3 | 4 | <br>5 | 6 |   | 7 | 18 | 9 | 10 | 1 | n | 12 | 13 | 14 | 1  | 51 | 16 | 17 | 18 | 19 | 20 | 2  | 22  | 23 | 24 | 2  | 52 | 6 | 27 | 28 | 29 | 30 | 31 |

#### Register Rul:

| Γ |   |   | 0  |   | + |   |   |   |   |    |    |    |    |    | Γ  |    | C   | on  | tr | Ы  |    |    |    |    |    |    |    |    |    |    |    |
|---|---|---|----|---|---|---|---|---|---|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |   | ~ | 00 |   |   |   |   |   |   |    |    |    |    |    |    |    | sto | art | ł  |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 | 1 | 2 | 3  | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17  | 18  | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

Register R contains the address of the first word of the control image to be loaded into the specified block of memory control registers. Bit positions 0 through 7 of register Rul contain a count of the number of words to be loaded. (If bits 0-7 of register Rul are initially all 0's, a word count of 256 is implied.)

Bit positions 15 through 22 of register Rul point to the beginning of the memory region controlled by the registers to be loaded. The significance of this field is different for the four modes of MMC.

The R field of the MMC instruction must be an even value for proper operation of the instruction; if the R field of MMC is an odd value, the instruction traps to Homespace location X'4D', instruction exception trap.

If MMC is indirectly addressed and the indirect reference address is nonexistent, the nonallowed operation trap (Homespace location X'40') is not activated. The effective virtual address of the MMC instruction, however, is not used as a memory reference (thus does not affect the normal operation of the instruction).

| Affected: | (R), (Ru1),            | Trap: | Instruction |
|-----------|------------------------|-------|-------------|
|           | memory control storage |       | exception   |

### LOADING THE MEMORY MAP

The following diagrams represent the configuration of MMC, register R, and register Rul that are required to load the memory map in either the 8-bit or 13-bit format:

The 8-bit instruction format is:

| 0 |   |   | ł | 5F |   |   |   |   | R | 2  |    | 1  | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

The 13-bit instruction format is:

| 0 |   |   | 6 | F |   |   |   |    | F | 2  |   | 1  | 0  | 1  |    |    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|----|---|----|---|----|----|----|----|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | П | 12 | 13 | 14 | 15 | Ti | 6 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

In the following description, the top of the diagram depicts the 8-bit format and the bottom the 13-bit format.

## The contents of register R are:

|   |   |   |   |    |   |   |   |   |   |   |   |    |    |    |    |     |     |     |    |     | Ν  | ۱a | р  | in | na | ge | c  | dd | dro | es | s  |    |    |    |
|---|---|---|---|----|---|---|---|---|---|---|---|----|----|----|----|-----|-----|-----|----|-----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|
|   |   |   |   |    |   |   |   |   |   |   |   |    |    | M  | ap | ) i | im  | ià  | ge | e ( | ac | d  | re | SS | re | a  | 6  | эx | te  | nc | le | d  |    |    |
| 0 | 1 | 2 | 5 | ۱. | 4 | 5 | 6 | 7 | Т | 8 | 9 | 10 | 11 | 12 | 13 | 1   | 4 1 | 5 1 | 16 | 17  | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27 | 28 | 29 | 30 | 31 |

### The contents of register Rul are:

| Count         |                        | Control                 |                         |
|---------------|------------------------|-------------------------|-------------------------|
|               |                        |                         |                         |
| 0 1 2 3 4 5 6 | 18 9 10 11 12 13 14 15 | 16 17 18 19 20 21 22 23 | 24 25 26 27 28 29 30 31 |

### MEMORY MAP CONTROL IMAGE

The initial address value in bit positions 15-31<sup>T</sup> of register R is the virtual address of the first word of the memory map control image. The word length of the control image to be loaded is specified by the initial count in bit positions 0-7 of register Ru1. A word count of 64 is sufficient to load the entire block of 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 causes the first registers loaded to be overwritten.

Each word of the memory map control image is assumed to be in the following 8- or 13-bit format:

|                 |                       | Page address            |                         |
|-----------------|-----------------------|-------------------------|-------------------------|
| Extende         |                       |                         |                         |
| 0 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 | 16 17 18 19 20 21 22 23 | 24 25 26 27 28 29 30 31 |

### MEMORY MAP LOADING PROCESS

Bit positions 15-22 of register Rul initially point to the first 512-word page of virtual addresses that is to be controlled by the map image being loaded. MMC moves the map image into the memory map control registers one word at a time, thus loading the page address for four (two if 13-bit format selected) consecutive memory map registers with each image word. As each word is loaded into the memory map, the virtual address of the image area is incremented by 1, the word count is decremented by 1, and the value in bit positions 15-22 of register Rul is incremented by 4 (by 2 if 13-bit format selected); this process continues until the word count is reduced to 0.

When the loading process is completed, bit positions 15-31<sup>T</sup> of register R contain a value equal to the sum of the initial map image address plus the initial word count. Also, bit positions 0-7 of register Rul contain all 0's, and bit positions 15-22 of register Rul contain a value equal to the sum of the initial contents plus four times the initial word count (two times the initial word count if 13-bit format selected).

<sup>r</sup>For real extended mode, bits 10-31.

# LOADING THE ACCESS PROTECTION CONTROLS

The following diagrams represent the configurations of MMC, register R, and register Ru1 that are required to load the access protection controls:

The instruction format is:

| 0 |   |   | ł | 5F |   |       |   |   | I | R  |    | 0  | 1  | 0  |    |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---|---|---|---|----|---|-------|---|---|---|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4  | 5 | <br>6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 511 | 5 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

The contents of register R are:

|   |   |   |   |   |   |   |   |    |   |    |    |    |    |    | Ŕ  | rc | gı  | ar | nc   | or | ntr | oľ | ir | na | ıgı | e  | ad | dro  | ess   |
|---|---|---|---|---|---|---|---|----|---|----|----|----|----|----|----|----|-----|----|------|----|-----|----|----|----|-----|----|----|------|-------|
|   |   |   |   |   |   |   |   |    |   | P  | ro | gı | ar | n  | сç | n  | fro | Ы  | im   | ag | e   | ad | dr | es | s,  | re | al | e>   | ct.   |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17  | 18 | 19 2 | 21 | 22  | 23 | 24 | 25 | 26  | 27 | 28 | 29 3 | 30 31 |

# The contents of register Rul are:

| Γ |   | <i>c</i> | `_ | un | ÷ |   |   |    |     |    |    |    |    |    |    | C  | on | tr | ol |    |    |    |    |    |    |    |    |    |    |    |    |
|---|---|----------|----|----|---|---|---|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |   |          | .0 | UN | 1 |   |   |    |     |    |    |    |    |    |    | st | ar | t  |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0 | 1 | 2        | 3  | 4  | 5 | 6 | 7 | 18 | . 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

#### ACCESS PROTECTION CONTROL IMAGE

The initial address value in register R is the virtual address of the first word of the access control image, and the word length of the first control image is specified by the initial count in register Ru1. A word count of 16 is sufficient to load the entire block of 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. Each word of the access control image is assumed to be in the following format:

| 4 | ٩C | A | с |   | A | с | A | с |   | A | с | A  | с  | . ^ | с  | A  | с  | A  | с  | •  | с  | A  | c  | A  | c  | A  | c, | A  | с  | A  | с  | •  | с  |
|---|----|---|---|---|---|---|---|---|---|---|---|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1  | 2 | 3 | T | 4 | 5 | 6 | 7 | Т | 8 | 9 | 10 | 11 | 12  | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

# ACCESS CONTROL LOADING PROCESS

Bit positions 15-20 of register Rul initially point to the first 512-word page of virtual addresses that is to be controlled by the access control image. MMC moves the access control image into the access control registers one word at a time, thus loading the controls for 16 consecutive 512-word pages with each image word. As each word is loaded, the virtual address of the control image is incremented by 1, the word count is decremented by 1, and the value in bit positions 15-20 of register Rul is incremented by 4; this process continues until the word count is reduced to 0. When the loading process is completed, register R contains a value equal to the sum of the initial control image address plus the initial word count. Also, the final word count is 0, and bit positions 15-20 of register Ru1 contain a value equal to the sum of the initial contents plus four times the initial word count.

### LOADING THE MEMORY WRITE PROTECTION LOCKS

The following diagrams represent the configurations of MMC, register R, and register Rul that are required to load the memory write protection locks:

| 0 | 6F            | RC          | 001         |                         |                         |
|---|---------------|-------------|-------------|-------------------------|-------------------------|
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 1 | 12 13 14 15 | 16 17 18 19 20 21 22 23 | 24 25 26 27 28 29 30 31 |

#### The contents of register R are:

| *** |   |   |   |    |   |   |   |    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | e o |    |    |    |    |    |    |    |
|-----|---|---|---|----|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
|     |   |   |   |    |   |   |   |    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |
| 0   | 1 | 2 | 3 | 14 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

#### The contents of register Rul are:

| Count           | Control<br>start                    |                                    |
|-----------------|-------------------------------------|------------------------------------|
| 0 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 16 17 18 19 2 | 0 21 22 23 24 25 26 27 28 29 30 31 |

# MEMORY LOCK CONTROL IMAGE

The initial address value in register R is the virtual address of the first word of the memory lock control image, and word length of the image is specified by the initial count in register Rul. A word count of 16 is sufficient to load the entire block of memory locks. The memory lock registers are treated as a circular set, with the register for memory addresses 0 through X'1FF' immediately following the register for memory addresses X'1FE00' through X'1FFFF'; thus, a word count greater than 16 causes the first registers loaded to be overwritten. Each word of the lock image is assumed to be in the following format:

| w | 'L | v | ٧L | V  | ٧L | v | ٧L | ~ | /L | w  | 'L | w  | L  | w  | ί  | w  | 'L | w  | 'n | w  | 'L | v  | 'n | w  | 'L | v  | 'n | w  | 'L | w  | L  |  |
|---|----|---|----|----|----|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|
| 0 | 1  | 2 | 3  | 14 | 5  | 6 | 7  | 8 | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |  |

# MEMORY LOCK LOADING PROCESS

Bit positions 15-20 of register Rul initially point to the first 512-word page of actual memory addresses that will be controlled by the memory lock image. MMC moves the lock image into the lock registers one word at a time, thus loading the locks for 16 consecutive 512-word pages with each image word. As each word is loaded, the virtual address of the lock image is incremented by 1, the word count is decremented by 1, and the value in bit positions 15-20 of register Rul is incremented by 4; this process continues until the word count is reduced to 0. When the loading process is completed, register R contains a value equal to the sum of the initial lock image address plus the initial word count. 'Also, the final word count is 0, and bit positions 15–20 of register Ru1 contain a value equal to the sum of the initial contents plus four times the initial word count.

#### **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 interrupt location is executed, the instruction address portion of the program status doubleword 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. A check of these access trap conditions is made prior to initiation of any memory control changes. The registers R and Ru1 will be unaltered for either of the above cases. 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 Ru1 will be unchanged from their initial values.

| LRA | LOAD REAL ADDRESS                  |
|-----|------------------------------------|
|     | (Word index alignment, privileged) |

| * |   |   | 2 | C |   |   |   |   | F | 2  |   |    | Х  |    |    |    |    |    | R  | efe | ər | en | ce | e ( | ad | dr | es | s  |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|---|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | П | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21 | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

LOAD REAL ADDRESS takes the effective word, treats the address portion of it as a virtual address, and loads register R with the corresponding real address and additional control information. The current addressing mode of the CPU is invoked in obtaining the effective word. All standard trapping conditions are in effect during the process of obtaining the effective word. The address portion of the effective word is then treated as a virtual address. This virtual address is then converted to a real address through the map. The addressing type is determined according to the settings of CC1 and CC2 immediately before the execution of LRA:

| <u>CC1</u> | <u>CC2</u> | Addressing Type |
|------------|------------|-----------------|
| 0          | 0          | Byte            |
| 0          | 1          | Halfword        |
| 1          | 0          | Word            |
| 1          | 1          | Doubleword      |

Note that in order to take this address through the map, it is shifted to a word address alignment (i.e., two bits to the right if it is a byte address, one bit to the right if it is a halfword address, and one bit to the left if it is a doubleword address). This mapping takes place independently of the state of the map bit in the current PSD. If the result of the mapping is an address on page 0 or 1, Homespace bias will also be added. The resulting actual word address is then shifted back to the alignment designated by the condition code setting and the original low order one or two bit(s) of the virtual address (in the byte and halfword cases) are inserted in their appropriate places. This final 21- to 24bit address is then loaded into the low order 21, 22, 23, or 24 bits of the register designated by the R field of the instruction. Note that this structure exactly matches the results obtained by an ANALYZE instruction.

Register R is loaded with the following information:

| Bit<br>Position | <u>Contents</u>                                                                  |
|-----------------|----------------------------------------------------------------------------------|
| 0               | Always zero.                                                                     |
| 1               | Set to one if Homespace bias is used in resul-<br>tant real address calculation. |
| 2               | Parity error in map.                                                             |
| 3-5             | Always zero.                                                                     |
| 6,7             | Write lock codes.                                                                |
| 8-31            | Contents of effective address aligned as indi-<br>cated above.                   |

The condition code is set as a result of the execution of this instruction according to the following rules:

| Co | ndi | tior | <u>Code</u> | <u>Result in R</u>                                                                                                          |
|----|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| 1  | 2   | 3    | 4           |                                                                                                                             |
| 0  | 0   | -    | -           | No abnormal condition.                                                                                                      |
| 0  | 1   | -    | -           | Not possible.                                                                                                               |
| 1  | 0   | -    | -           | Not possible.                                                                                                               |
| 1  | 1   | -    | -           | Final actual address not in implemented memory.                                                                             |
| 1  | 1   | 0    | 0           | Final virtual address is a register address.                                                                                |
|    |     |      |             | (Note: If the virtual address is a register<br>address, the effective word of the LRA<br>will be the result in register R.) |
| -  | -   | 0    | 0           |                                                                                                                             |
| -  | -   | 0    | 1           |                                                                                                                             |
| -  | -   | 1    | 0           | Access Protect codes on the page.                                                                                           |
| -  | -   | 1    | 1           |                                                                                                                             |

During determination of the final actual address, certain traps are inhibited even if events which would normally invoke them occur. The specific events that do not result in traps are as follows:

- 1. Parity error in map.
- 2. Access-protect violation (since LRA is privileged, this could only occur in the master-protected mode).
- 3. Final actual address not in implemented memory.

The above conditions are reported in the condition code and specified R register after completion of the instruction. However, if a bus check error or memory parity error is detected during the access of the final actual address, a parity error trap will occur.

Affected: (R), CC

### LOAD MEMORY STATUS (Word index alignment, privileged)

| * |   |   | 2 | 20 | ) |   |   |   |    |   | R  |    |     | Х    |    |     |    |    |    |    |    |    |    |    |    |    |    |    | es |    |    |    |    |
|---|---|---|---|----|---|---|---|---|----|---|----|----|-----|------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 1  | 4 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | Tī: | 2 13 | 14 | 1 1 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

LOAD MEMORY STATUS is used to determine memory bank status and/or to perform diagnostic action on a memory bank. The effective address is used to determine the memory bank. 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:

| 1 | 2 | 3 | 4 | LMS | Action |
|---|---|---|---|-----|--------|
| _ |   |   |   |     |        |

- 0 0 0 0 Load 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 0 0 1 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). It does, however, generate the Memory Parity Error signal. The CPU inhibits the trap that would ordinarily occur for the memory parity error.
- 0 0 1 0 Read and set bad parity loads the effective word into R. The memory reads the location and unconditionally restores the word with the invalid parity bit. The parity bit transmitted to the processor is the original parity bit. Parity error traps and memory fault interrupts are not inhibited by this instruction.
- 0 0 1 1 Reserved.
- 0 1 0 0 Reserved.
- 0 1 0 1 Reserved.
- 0 1 1 0 Reserved.
- 0 1 1 1 Set memory clock margin transfers the effective word from R to memory. The memory bank will interpret the word and change its own timing as follows:

### Word Bits

- 8 9 10 11 12 Interpretation
- 1 0 0 0 0 Set clock margin 0, early write half cycle.

# Word Bits

|   |   |   | vvc      | ora                                                                      | DITS                   | •            |              |                                                                                      |  |  |  |  |  |
|---|---|---|----------|--------------------------------------------------------------------------|------------------------|--------------|--------------|--------------------------------------------------------------------------------------|--|--|--|--|--|
|   |   |   | 8        | 9                                                                        | 10                     | 11           | 12           | Interpretation                                                                       |  |  |  |  |  |
|   |   |   | 0        | 1                                                                        | 0                      | 0            | 0            | Set clock margin 1, late write half cycle.                                           |  |  |  |  |  |
|   |   |   | 0        | 0                                                                        | 1                      | 0            | 0            | Set clock margin 2, early<br>strobe.                                                 |  |  |  |  |  |
|   |   |   | 0        | 0                                                                        | 0                      | 1            | 0            | Set clock margin 3, late<br>strobe.                                                  |  |  |  |  |  |
|   |   |   | 0        | 0                                                                        | 0                      | 0            | 1            | Set clock margin 4, early<br>data release parity error,<br>parity o.k. (read cycle). |  |  |  |  |  |
|   | 0 | 0 |          |                                                                          |                        |              | vord<br>able | 0 <sup>†</sup> — Ioads status word 0<br>10).                                         |  |  |  |  |  |
|   | 0 | 1 |          |                                                                          |                        |              | vord<br>able | 1 <sup>†</sup> — Ioads status word 1<br>11).                                         |  |  |  |  |  |
|   | 1 | 0 | Re<br>ir | ead<br>nto                                                               | stat<br>R (se          | us v<br>ee T | vord<br>able | 2 <sup>†</sup> — loads status word 2<br>12).                                         |  |  |  |  |  |
| I | 1 | 1 | R        | esei                                                                     | ved                    |              |              |                                                                                      |  |  |  |  |  |
|   | 0 | 0 |          |                                                                          |                        |              | vord<br>and  | 0 and clear status bits of<br>2. <sup>tt</sup>                                       |  |  |  |  |  |
|   | 0 | 1 | R        | ese                                                                      | rved                   |              |              |                                                                                      |  |  |  |  |  |
|   | 1 | 0 | R        | Read status word 2 <sup>t</sup> and clear all status bits. <sup>tt</sup> |                        |              |              |                                                                                      |  |  |  |  |  |
|   | 1 | 1 | A        | 114                                                                      | ir me<br>traps<br>atio | s are        | alla         | clears the effective word.<br>wed including write protect                            |  |  |  |  |  |

Condition code settings after execution:

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:

- CC1: Memory Parity Error (from memory)
- CC2: Data Bus Check (from CPU)
- CC3: Parity Bit (from memory)
- CC4: 0

1 0

1 0

1 0

1 0

1 1

1 1

1 1

1 1

<sup>&</sup>lt;sup>†</sup>Primarily of diagnostic concern.

<sup>&</sup>lt;sup>tt</sup>Memory Fault Interrupt signal is also cleared implicitly.

Table 10. Status Word 0

| Field                      | Bits  | Comments                                                                                                                                |
|----------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Memory fault               | 0     | Reserved.                                                                                                                               |
| types                      | 1     | Data parity error detected on read.                                                                                                     |
|                            | 2     | Data parity error detected<br>on partial write.                                                                                         |
|                            | 3     | Address bus parity error.                                                                                                               |
|                            | 4     | Data bus parity error on<br>full or partial write.                                                                                      |
|                            | ·5    | Loop check data parity<br>error.                                                                                                        |
|                            | 6     | Port selection error.                                                                                                                   |
|                            | 7     | Basic memory unit over-<br>temperature or power<br>supply failures.                                                                     |
|                            | 8     | A prior LMS instruction with<br>a "reserved" initial condition<br>code setting was detected.                                            |
|                            | 9-11  | Reserved.                                                                                                                               |
| Subsequent<br>faults       | 12    | After a snapshot is taken,<br>this bit is a 1 if one or<br>more subsequent memory<br>faults occur before status<br>register is cleared. |
| Last parity<br>bit written | 13    | When initial snapshot was<br>taken, the value of the<br>last parity bit written into<br>main memory is stored in<br>this position.      |
| Bank number                | 14    | Bit 14 is the most signifi-<br>cant bit of bank number<br>in the unit.                                                                  |
|                            | 15    | Bit 15 is the least signifi–<br>cant bit of bank number<br>in the unit.                                                                 |
|                            | 16-19 | Reserved.                                                                                                                               |
| Port number                | 20    | Port 1                                                                                                                                  |
|                            | 21    | Port 2                                                                                                                                  |
|                            | 22    | Port 3                                                                                                                                  |
|                            | 23    | Port 4                                                                                                                                  |

Table 10. Status Word 0 (cont.)

| Field       | Bits | Comments                                                |
|-------------|------|---------------------------------------------------------|
| Port number | 24   | Port 5                                                  |
| (cont.)     | 25   | Port 6                                                  |
|             | 26   | Fort 7 Group 2                                          |
|             | 27   | Port 8                                                  |
|             | 28   | Port 9                                                  |
|             | 29   | Port 10<br>Group 3                                      |
|             | 30   | Port 11                                                 |
|             | 31   | Port 12                                                 |
|             |      | <u>Note:</u> Ports are installed<br>in groups as shown. |

Table 11. Status Word 1

| Field                 | Bits | Comments                                                                                                                                         |
|-----------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Interleave<br>mode    | 0,1  | <ul> <li>0 1</li> <li>0 No interleave</li> <li>0 1 Two-way interleave</li> <li>1 0 Four-way interleave</li> <li>1 1 Reserved</li> </ul>          |
| Bank size             | 2,3  | 2       3         0       0       8K         0       1       16K         1       0       Reserved         1       1       Reserved               |
| Memory unit<br>number | 4-7  | This field specifies the<br>memory unit number, as<br>follows: bit 4 is the<br>most significant bit;<br>bit 7 is the least sig-<br>nificant bit. |

Table 11. Status Word 1 (cont.)

| Field        | Bits  | Comments                                                                          |
|--------------|-------|-----------------------------------------------------------------------------------|
| Unit size    | 8,9   | <u>89</u>                                                                         |
|              |       | 0 0 8K                                                                            |
|              |       | 0 1 16К                                                                           |
|              |       | 1 0 24K                                                                           |
|              |       | 1 1 32K                                                                           |
|              | 10-12 | Reserved                                                                          |
|              | 13    | Power normal                                                                      |
| Clock margin | 14    | Clock margin 0, early<br>write half cycle.                                        |
|              | 15    | Clock margin 1, late write<br>half cycle.                                         |
|              | 16    | Clock margin 2, early<br>strobe.                                                  |
|              | 17    | Clock margin 3, late strobe.                                                      |
|              | 18    | Clock margin 4, early data<br>release, parity error, parity<br>o.k. (read cycle). |
|              | 19-31 | Reserved                                                                          |

Table 12. Status Word 2

| Field                              | Bits  | Comments |
|------------------------------------|-------|----------|
|                                    | 0-9   | Reserved |
| Interleaved<br>address of<br>fault | 10-31 |          |

### WAIT WAIT

(Word index alignment, privileged)

| * | 2E            | R X                | Reference address                                  |
|---|---------------|--------------------|----------------------------------------------------|
| Ļ | 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

WAIT causes the CPU to cease all operations until an interrupt activation occurs, or until the computer operator manually moves the COMPUTE switch on the processor control panel from the RUN position to IDLE and then back to RUN. The instruction address portion of the PSD is updated before the computer begins waiting; therefore, while the CPU is waiting, the INSTRUCTION ADDRESS indicators contain the virtual address of the next location in ascending sequence after WAIT and the contents of the next location are displayed in the DISPLAY indicators on the processor control panel. 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 CPU is waiting, the computer 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 COMPUTE switch is moved from RUN to IDLE and back to RUN while the CPU 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 Homespace location X'40' 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)

|   | Γ |   |   |    |   |   |   | F |   | <br>\ |    |    | ~  |    |    |    |    | R  | ef | er | er | ٦C | e  | ac | h  | re | SS |      |      |      |  |
|---|---|---|---|----|---|---|---|---|---|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|--|
| * |   |   | Ċ | SC |   |   |   |   | ŀ | (     |    |    | X  |    |    |    | Λ٥ |    |    |    |    |    |    |    |    |    | oņ |      |      |      |  |
| 6 | ī | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9 | 10    | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 2 | 9 30 | ) 31 |  |

The CPU is capable of directly communicating with other elements of the SIGMA 9 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 CPU circuits and to special systems equipment.

READ DIRECT causes the CPU to present bits 16 through 31 of the effective virtual address to other elements of the SIGMA 9 system on the RD/WD address lines. Bits 16-31 of the effective virtual address identify a specific element of the SIGMA 9 system that is expected to return information (two condition code bits plus a maximum of 32 data bits) to the CPU. The significance and number of data bits returned to the CPU 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. The specified element may return information to set the condition code. Bits 16–19 of the effective virtual address of RD determine the mode of the RD instruction, as follows:

| Bit    | Posit | ion |     |                                                                               |
|--------|-------|-----|-----|-------------------------------------------------------------------------------|
| 16     | 17    | 18  | 19  | Mode                                                                          |
| 0      | 0     | 0   | 0   | Internal computer control.                                                    |
| 0      | 0     | 0   | 1   | Interrupt control.                                                            |
| 0      | 0     | 1   | 0   | XDS testers.                                                                  |
| 0<br>: | 0     | 1   | 1   | Assigned to various groups of standard XDS products                           |
| 1      | 1     | 1   | 0 ] |                                                                               |
| 1      | 1     | 1   | ľ   | Special systems control (for customer use with specially designed equipment). |

If bits 16–19 select mode 2 through mode F, CC1 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.

# READ DIRECT, INTERNAL COMPUTER CONTROL (MODE 0)

In this mode, the computer is able to read the sense switches, the CPU clock margin controls, the interrupt inhibit bits of the PSD, and the "snapshot" register, as follows:

# READ SENSE SWITCHES

The following configuration of RD can be used to read the four SENSE switches on the control panel.

| * |       | <u>.</u> |   |   |   |   |   | ,<br>, |    |    | v  |    |    |   |    |    | Re | efe | ere | эn | ce | e c | ade | dr | es | s  |    |    |    |
|---|-------|----------|---|---|---|---|---|--------|----|----|----|----|----|---|----|----|----|-----|-----|----|----|-----|-----|----|----|----|----|----|----|
|   |       | ,<br>,   |   |   |   |   | г | (      |    |    | ^  |    |    | ( | 00 | 00 | )  | (   | )0  | 00 | )  | (   | 00  | 00 | )  |    | 00 | 00 | ק  |
| 0 | 1 2 3 | 4        | 5 | 6 | 7 | 8 | 9 | 10     | 11 | 12 | 13 | 14 | 15 |   | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24  | 25  | 26 | 27 | 28 | 29 | 30 | 31 |

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 "SENSE" in Chapter 5).

In this case, only the condition code is affected.

# READ INTERNAL CONTROLS

Each CPU in a system is provided with local switch modules that are set at system installation time. The setting of these modules can be read with this internal READ DIRECT. Also, this instruction provides the system with information pertaining to the clock margin controls and power supply status.

The following RD configuration is used to read the CPU internal controls:

| * |   |   |   | 60 | ~ |   |   |   |     |    |    |    | x  |    | 1  |    |    |    |    |    |    |    |    |    | d  |    |    |    |    |    | ٦  |
|---|---|---|---|----|---|---|---|---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |   |   |   |    | _ |   |   |   | . ' | `  |    |    | ^  |    |    | (  | 00 | 00 | )  | (  | 20 | 00 | )  | (  | 01 | 00 | )  | (  | )1 | 01 |    |
| 0 | 1 | 2 | 3 | 4  | 5 | 6 | 7 | 8 | 9   | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

Sits 6 and 7 of the specified R register are a 2-bit number epresenting the CPU number.

The internal CPU margin controls are read into bits 8 and 9 of the specified R register, as follows:

| Bit 8 | <u>Bit 9</u> | Clock Margins |
|-------|--------------|---------------|
| 0     | 0            | Norm          |
| 0     | 1            | Hi            |
| 1     | 0            | Lo            |
| 1     | 1            | Unused        |
|       |              |               |

Bit 10 of the specified R register is always zero.

The power supply status is read into bit 11 of the specified R register as follows:

| <u>Bit 11</u> | Status           |
|---------------|------------------|
| 0             | Power not normal |
| 1             | Power normal     |

Bits 12–17 of the specified R register represent the Homespace bias for this CPU. All other bits of the specified R register are zero.

Affected: (R)

 $0 \longrightarrow R_{0-5}; 0 \longrightarrow R_{10}; 0 \longrightarrow R_{18-31}$ CPU number  $\longrightarrow R_6, R_7$ Clock margins  $\longrightarrow R_8, R_9$ Power supply status  $\longrightarrow R_{11}$ 

Homespace bias ---- R<sub>12-17</sub>

READ INTERRUPT INHIBITS

The following configuration of RD can be used to read the contents of the interrupt inhibit field:

| * | 10            |           | V        |    | Re          | ference     | addres      | s           |
|---|---------------|-----------|----------|----|-------------|-------------|-------------|-------------|
| Ĺ |               | к         | X        |    | 0000        | 0000        | 0100        | 1000        |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 | 16 17 18 19 | 20 21 22 23 | 24 25 26 27 | 28 29 30 31 |

If the R field of RD is nonzero, the contents of the interrupt inhibit field (bits 37, 38, 39) of the program status doubleword 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)

$$(PSD)_{37-39} \longrightarrow R_{29-31}$$
  
 $0 \longrightarrow R_{0-28}$ 

# READ SNAPSHOT SAMPLE REGISTER

Each CPU will contain an internal snapshot sample register to aid in diagnostic programming. The following configuration of RD is used to record the snapshot sample register and disarm the snapshot feature if a snapshot has not yet occurred:

| * |     |   | <u> </u> |   |   |   | Γ |   | ,<br>, |    |    | v  |    |    |    |    |    | Re | efe | ere | en | ce | e c | d  | dr | es | s  |    |    |    |
|---|-----|---|----------|---|---|---|---|---|--------|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|----|----|----|----|----|
| 1 |     | C | , C      |   |   |   |   | r | ۲      |    |    | X  |    |    | (  | 00 | 00 | )  | C   | 00  | 00 | )  | (   | 21 | 00 | С  | 1  | 00 | )1 |    |
| 0 | 1 2 | 3 | 4        | 5 | 6 | 7 | 8 | 9 | 10     | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20  | 21  | 22 | 23 | 24  | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

If the R field of RD is nonzero, the contents of the snapshot sample register are transferred to the specified R register.

Affected: (R), CC

Condition code settings:

1 2 3 4 Result

- 0 0 Clock Counter = 0, end of instruction not reached.
- - 0 1 Clock Counter = 0, end of instruction.
- 1 0 Armed but not "snapped".

### **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 CPU interrupt system:

| * | 40            | D         | X        |    |          | Refe  | erence   | addres      | s           |
|---|---------------|-----------|----------|----|----------|-------|----------|-------------|-------------|
|   |               | ĸ         | ^        |    | 000      |       |          | 0000        |             |
| 0 | 1 2 3 4 5 6 7 | 8 9-10 11 | 12 13 14 | 15 | 16 17 18 | 19 20 | 21 22 23 | 24 25 26 27 | 28 29 30 31 |

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'0', see Table 3. 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 <u>Read Armed or Waiting State</u>. 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 <u>Read Waiting or Active State</u>. 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. All other bits are reset to zero.
- 100 <u>Read Enabled.</u> 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.

WD

# (Word index alignment, privileged)

WRITE DIRECT

| * | Γ |   | 6 | D |   |   |   | F |   | R   |    |    | x  |    |    |    |    | F  | ٢e | fe | re | nc | e  | a  | dd | re | ess |    |    |    | ٦  |
|---|---|---|---|---|---|---|---|---|---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
|   |   |   |   |   |   |   |   |   |   | · · |    |    | ~  |    |    | ٨  | ٨c | de | ə  |    |    |    | F  | ur | ٦C | ti | on  |    |    |    | 7  |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10  | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

WRITE DIRECT causes the CPU to present bits 16-31 of the effective virtual address to other elements of the SIGMA 9 system on the RD/WD address lines (see READ DIRECT). Bits 16-31 of the effective virtual address identify a specific element of the SIGMA 9 system that is to receive control information from the CPU. 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, 32 0'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:

| <u>[</u> | Bit F | Posit | ion    |    |                                                                               |
|----------|-------|-------|--------|----|-------------------------------------------------------------------------------|
| -        | 16    | 17    | 18     | 19 | Mode                                                                          |
| (        | )     | 0     | 0      | 0  | Internal computer control.                                                    |
|          | )     | 0     | 0      | 1  | Interrupt control.                                                            |
| (        | )     | 0     | 1      | 0  | Xerox computer testers.                                                       |
| (        |       | 0     | 1<br>1 | 1  | Assigned to various groups<br>of Xerox computer products.                     |
| Ī        | 1     | 1     | 1      | 1  | Special systems control (for customer use with specially designed equipment). |

If bits 16–19 select mode 2 through mode F, CC1 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.

### WRITE DIRECT, INTERNAL COMPUTER CONTROL (MODE 0)

### SET INTERRUPT INHIBITS

The following configuration of WD can be used to set the interrupt inhibits (bit positions 37–39 of the PSD):

| Ţ |   |   |   |   |   |   |   | Ι |   | n  |    |    | ~  |    |    |    |    | F  | Re | fe | re | nc | ce | a  | dd | re | ess |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
| ſ |   |   | C |   |   |   |   |   |   | ĸ  |    |    | ~  |    |    | (  | 00 | 00 | )  | (  | 00 | 00 | 2  | (  | 00 | 11 | _   | 0  | с  | I  | E  |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

A logical inclusive OR is performed between bits 29-31 of the effective virtual address and bits 37-39 of the PSD. If any (or all) of bits 29-31 of the effective virtual address are 1's, the corresponding inhibit bits in the PSD are set to 1's; the current state of an inhibit bit is not affected if a corresponding bit position of the effective virtual address contains a 0.

### RESET INTERRUPT INHIBITS

The following configuration of WD can be used to reset the interrupt inhibits:

| *  | (5      |       |           |             | Re          | ference     | address     |             |
|----|---------|-------|-----------|-------------|-------------|-------------|-------------|-------------|
| l" | 00      |       | ĸ         | ^ 🛛         | 0000        | 0000        | 0010        | 0 C I E     |
| 0  | 1 2 3 4 | 5 6 7 | 8 9 10 11 | 12 13 14 15 | 16 17 18 19 | 20 21 22 23 | 24 25 26 27 | 28 29 30 31 |

If any (or all) of bits 29-31 of the effective virtual address are 1's, the corresponding inhibit bits in the PSD are reset to 0's; the current state of an inhibit bit is not affected if a corresponding bit position of the effective virtual address contains a 0.

# SET ALARM INDICATOR

The following configuration of WD is used to set the ALARM indicator on the maintenance section of the processor control panel:

| Ţ | 15            |              | V          |             | ference     | address     |             |
|---|---------------|--------------|------------|-------------|-------------|-------------|-------------|
| ^ | 6D            | ĸ            | X          | 0000        | 0000        | 0100        | 0001        |
| _ | 1 2 3 4 5 6 7 | 8 9 10 11 13 | 2 13 14 15 | 16 17 18 19 | 20 21 22 23 | 24 25 26 27 | 28 29 30 31 |

If the COMPUTE switch on the processor control panel is in the RUN position and the AUDIO switch on the maintenance section of the processor control panel is in the ON position, a 1000-Hz signal is transmitted to the computer speaker. The signal maybe interrupted by moving the COMPUTE switch to the IDLE position, 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:

| * |   |   | 6 | n |   |   |   |   |   | >  |    |    | v  |    |    |    |    | F  | le | fe | re | nc | e  | a  | dd | lre | ess |    |    |    |    |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
|   |   |   | 0 | υ |   |   |   |   | 1 | 2  |    |    | ^  |    |    | (  | 00 | 00 | )  | (  | 00 | 00 | )  | 1  | 01 | 00  | C   | (  | 00 | 00 | 7  |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

The ALARM indicator is also reset by means of either the CPU RESET/CLEAR switch or the SYS RESET/CLEAR switch on the processor control panel.

# TOGGLE PROGRAM-CONTROLLED-FREQUENCY FLIP-FLOP

The following configuration of WD is used to set and reset the CPU program-controlled-frequency (PCF) flip-flop:

| * | (5            |              | ~       |          | Re    | ference     | address     |             |
|---|---------------|--------------|---------|----------|-------|-------------|-------------|-------------|
| Ĩ | 6D            | ĸ            | X       | 00       | 00    | 0000        | 0100        | 0010        |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 1: | 2 13 14 | 15 16 17 | 18 19 | 20 21 22 23 | 24 25 26 27 | 28 29 30 31 |

The output of the PCF flip-flop is transmitted to the computer speaker through the AUDIO switch on the maintenance section of the processor 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  $(PSD_{37-39})$ .

| * |   |   | 4 | S D | , |   |   |   |   | R    |    |    | x      |    |     |    | R  | Ret | fe | re | nc | e  | a  | bb | re | ss |    |    |    |    |
|---|---|---|---|-----|---|---|---|---|---|------|----|----|--------|----|-----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|
|   |   |   |   |     | · |   |   |   |   | IN . |    |    | $\sim$ |    | 1 ( | 00 | 00 | )   | (  | 00 | 00 | )  | (  | 21 | 00 | )  |    | 10 | 00 |    |
| 0 | 1 | 2 | 3 | 4   | 5 | 6 | 7 | 8 | 9 | 10   | 11 | 12 | 13     | 14 | 16  | 17 | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

Affected: (PSD<sub>37-39</sub>)

(R29-31) → PSD37-39

# LOAD SNAPSHOT CONTROL REGISTER

The following configuration of WD is used to arm the snapshot feature:

|   | (5            | D         | V        |    |   | I     | Re | feren   | ce   | ac | ldre  | ss |    |     |    |    |
|---|---------------|-----------|----------|----|---|-------|----|---------|------|----|-------|----|----|-----|----|----|
| 1 | 6D            | к         | X        | *  | 0 | 0000  | )  | 000     | 0    | С  | 100   | )  | 1  | 100 | 21 | ٦  |
| 4 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 |   | 17 18 | 19 | 20 21 2 | 2 23 | 24 | 25 26 | 27 | 28 | 29  | 30 | 31 |

The contents of the specified R register are transferred to the snapshot control register with the following format:

| CC                     | 5 6 7 8 9        | CS                   | Instruction address                                                                                                                    |
|------------------------|------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit<br><u>Position</u> | Desig-<br>nation | Function             | <u>1</u>                                                                                                                               |
| 0-7                    | СС               | clock pu<br>the snap | ounter. Contains the number of<br>Jlses, which determine the time<br>shot sample register is strobed<br>struction address recognition. |
| 8                      | IF               | PCP inte             | <u>t Flag.</u> If this bit is a 1, the<br>errupt is triggered at the time<br>oshot occurs.                                             |
| 10-14                  | CS               | several              | on <u>Select</u> . Determines which of possible internal states of the e to record. <sup>†</sup>                                       |
| 15-31                  | IA               | by the s<br>address  | ion Address. The address used<br>napshot feature is the 17–bit<br>in positions 15–31 of the PSD,<br>sss of the mode of operation.      |
|                        |                  | -                    |                                                                                                                                        |

Affected: (Snapshot Control Register)

(R) ----- Snapshot Control Register

#### TURN ON MODE ALTERED FLAG

The following configuration of WD is used to set the Mode Altered Flag (PSD 40) to 1:

| [. | 40            | D         | ×        | Refe          | rence addr        | ess            |
|----|---------------|-----------|----------|---------------|-------------------|----------------|
| *  | 00            | ĸ         | ^        | 0000 0        | 010 010           | 0 0111         |
| 0  | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 6 17 18 19 20 | 21 22 23 24 25 26 | 27 28 29 30 31 |

#### TURN OFF MODE ALTERED FLAG

The following configuration of WD is used to reset the Mode Altered Flag (PSD 40) to 0:

| * | 40            | D         | V        |    | Re          | ference     | address     |             |
|---|---------------|-----------|----------|----|-------------|-------------|-------------|-------------|
|   | 60            | ĸ         | ^        |    | 0000        | 0000        | 0100        | 0110        |
| 0 | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 | 16 17 18 19 | 20 21 22 23 | 24 25 26 27 | 28 29 20 21 |

### SET INTERNAL CONTROLS

The following configuration of WD is used to set the CPU clock margin controls:

| <b>*</b> |   |   | 4 | 5 |   |   |   |   |   |   | D  |    |     | v  |    |    |    |    | F  | Re | fe | re | no | :e | a  | dc | Ire | ess |    |    |    |    |
|----------|---|---|---|---|---|---|---|---|---|---|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
|          |   |   | C |   |   |   |   |   |   | 1 | ĸ  |    |     | ^  |    |    | (  | 00 | 00 | )  | (  | 00 | 00 | )  | (  | 21 | 00  | )   |    | 01 | 01 |    |
| 0        | 1 | 2 | 3 | 4 | 5 | 2 | 6 | 7 | 8 | 9 | 10 | 11 | 112 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

<sup>T</sup>A separate document, Xerox SIGMA 9 Engineering Support Manual will contain this information. The contents of the specified R register, bits 8 and 9, are used to set the internal CPU margin controls as follows:

| <u>Bit 8</u> | <u>Bit 9</u> | Clock Margins |
|--------------|--------------|---------------|
| 0            | 0            | Norm          |
| 0            | 1            | Ht            |
| 1            | 0            | Lo            |
| 1            | 1            | Unused        |

All unused bits of the specified R register are disregarded.

# 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 CPU interrupt system:

| * |   |   | 2 | n |   |   |   |   |   |   | D  |    |    | v  |    |    |     |    | F  | Кe | fe | re | nc  | :e | a  | dc | Ire | ess |    |     |    |    |
|---|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|-----|----|----|----|----|----|-----|----|----|----|-----|-----|----|-----|----|----|
|   |   |   |   | υ |   |   |   |   |   |   | N  |    |    | ^  |    |    | . ( | 00 | 01 |    | 0  | ¢  | Cod | le | (  | 00 | 00  | )   | C  | Gra | vp |    |
| 0 | 1 | 2 | 3 | 4 | 5 | , | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16  | 17 | 18 | 19 | 20 | 21 | 22  | 23 | 24 | 25 | 26  | 27  | 28 | 29  | 30 | 31 |

Bits 28-31 of the effective address specify the identification number (see Table 3) 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'0', see Table 3.

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 Set active all selected levels currently in the armed or waiting states.
- 001<sup>†</sup> Disarm all levels selected by a 1; all levels selected by a 0 are not affected.
- 010<sup>r</sup> Arm and enable all levels selected by a 1; all levels selected by a 0 are not affected.
- 011<sup>†</sup> 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.

# 114 Input/Output Instructions

# **INPUT/OUTPUT INSTRUCTIONS**

The I/O instruction set for the SIGMA 9 CPU 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                 | RIO      |
| Poll Processor                     | POLP     |
| Poll Processor and Reset           | POLR     |
| Acknowledge Input/Output Interrupt | AIO      |

# **OVERALL CHARACTERISTICS**

All I/O instructions are privileged and can be performed only when the CPU is in either the master or master-protected mode. If the CPU attempts to execute an I/O instruction when it is in the slave mode (bit 8 of the current PSD is a 1), the instruction is aborted at the time the operation code is decoded and the CPU traps to Homespace location X'40'. 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 (CC1-CC3) represent a summary description of the I/O operation and conditions within the addressed I/O subsystem. Specific condition code settings and meanings (unique for each I/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.) The presence (or absence) and validity of the requested I/O status information is indicated by condition code bits CC1 and CC3, respectively.

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 described in Table 13 and illustrated in Figure 11.

<sup>&</sup>lt;sup>t</sup>These codes clear the current interrupts, i.e., remove from the active or waiting state all levels selected by a 1 (see Figure 10).

Table 13. Description of I/O Instructions

| Bit<br>Position | Applicable Instructions<br>(Mnemonics) | Function and/or Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | All I/O instructions                   | If this bit is a 1, bits 15–31 of the initial I/O instruction are modified by indirect addressing.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1-7             | SIO, TIO, TDV,<br>and AIO              | For these four instructions, the operation code uniquely defines the $I/O$ operation that is to be performed.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 | HIO, RIO, POLP,<br>and POLR            | Within bit positions 1–7, these four instructions all have the same operation code (X'4F'). The instructions are differentiated by using bits 15, 16, and 17 as an ex-<br>tension of the operation code field.                                                                                                                                                                                                                                                                                                                                       |
| 8-11            | SIO, TIO, TDV,<br>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 0, no status information is requested. If the value of the R field is even and not 0, two words of status information are requested to be loaded into registers R and Ru1. 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<br>any value as required by the program. For example: by indirect addressing and/or<br>indexing, the RIO instruction may be changed into an HIO, POLP, or POLR instruc-<br>tion. Thus, the R field of the RIO instruction must be coded with a value as required<br>by the subsequent HIO, POLP, or POLR instruction.                                                                                                                                         |
|                 | POLP and POLR                          | This field specifies which general register (including register 0) is to receive processor (MIOP, HSRIOP, or CPU) fault information.                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | AIO                                    | If the R field is 0, no status information is requested. If the R field is not 0, the designated general register is to be loaded with the requested status information.                                                                                                                                                                                                                                                                                                                                                                             |
| 12-14           | All I/O instructions                   | The X field may be used to specify indexing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15-17           | SIO, TIO, TDV,<br>and AIO              | After the $I/O$ address is generated, these bits are reserved and must be coded with zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                 | HIO, RIO, POLP,<br>and POLR            | These bits are an extension to the operation code field (bits 1–7) and permit each of these instructions to be uniquely defined.                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 |                                        | Note that these bits are subject to modifications due to indirect addressing or indexing. The final configuration of these bits must be as shown below:                                                                                                                                                                                                                                                                                                                                                                                              |
|                 |                                        | HIO = 000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 |                                        | RIO = 001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 |                                        | POLP = 010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                 |                                        | POLR = 011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 18              | All I/O instructions                   | After the $I/O$ address is generated, this bit is reserved and must be coded with a zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

....

| Bit<br>Position | Applicable Instructions<br>(Mnemonics) | Function and/or Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19-31           | All I/O instructions<br>(except AIO)   | The I/O address (after any indirect addressing and/or indexing) is contained within<br>these bits. Depending upon the I/O instruction, the required I/O address may be<br>comprised of (1) a processor address only; (2) a processor address and a device con-<br>troller address; or (3) a processor address, a device controller address, and a device<br>address.                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 |                                        | Subfields of the final I/O address field are described below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19-23           | All I/O instructions<br>(except AIO)   | These bits constitute the processor address (PA) field of an $I/O$ instruction. The 32 processor addresses may be assigned in the following manner:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                                        | <ol> <li>The assignment of addresses is mutually exclusive, that is, no two processors may<br/>have the same address.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                 |                                        | <ol> <li>The four highest addresses (X'IC' – X'IF') are reserved for addressing CPUs in a<br/>multiprocessor system.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                 |                                        | 3. The remaining 28 addresses may be assigned to MIOPs, HSRIOPs, or to any other IOP that is compatible with the SIGMA 9 computer system.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 |                                        | a. SIGMA 9 MIOPs require an even-odd pair of addresses. The even address<br>(bit 23 is a 0) selects Channel A and the next odd address (bit 23 is a 1) se-<br>lects Channel B. If the MIOP only has Channel A, the next odd address is<br>preempted and reserved. An RIO instruction resets both Channel A and<br>Channel B of an MIOP regardless of bit 23.                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 |                                        | b. A SIGMA 9 HSRIOP must be assigned an even address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 | AIO                                    | After the I/O address is generated, these bits are reserved and must be coded with zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 24              | SIO, TIO, TDV,<br>and HIO              | If the I/O instruction is addressed to a single-unit device controller, this bit must be coded as a 0. If the I/O instruction is addressed to a multiunit device controller, this bit must be coded as a 1. Note that bit 24 is not considered as part of the device controller address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | RIO, POLP, POLR, and AIO               | After the I/O address is generated, this bit is reserved and must be coded with a zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 25-31           | SIO, TIO, TDV,<br>and HIO              | If the I/O instruction is addressed to a single-unit device controller (bit 24 is a 0),<br>bits 25-31 represent one of 24 possible device controller addresses (X'00' - X'17').<br>There is no need to specify a device address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                 |                                        | If the I/O instruction is addressed to a multiunit (e.g., magnetic tape) device con-<br>troller (bit 24 is a 1), bits 25–27 represent one of eight possible device controller<br>addresses (X'0' – X'7') and bits 28–31 represent one of 16 possible device addresses<br>(X'0' – X'F').                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ·               |                                        | Device controller addresses assigned to controllers within the same I/O channel (e.g.,<br>Channel A of MIOP), must be mutually exclusive. Note that bit 24, which must be<br>a 0 when addressing a single-unit device controller and a 1 when addressing a multi-<br>unit device controller is not considered a part of the device controller address. Thus,<br>for example, if the device controller address X'0' is assigned to a multiunit device<br>controller within Channel A of an MIOP, no other device controller (single or multi-<br>unit) within Channel A may have an address of X'0'. This does not preclude using<br>X'0' as a device controller address for either a single or multiunit device controller<br>within Channel B or any other I/O channel. |
|                 | RIO, POLP, POLR,<br>and AIO            | After the I/O address is generated, these bits are reserved and must be coded with zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

# Table 13. Description of I/O Instructions (cont.)

\*

44

----

|          | *     | Operc                 | ition Code       | R                | x           |               |       | Reference Ad      | ddress                                             | Initial I/O                                                |
|----------|-------|-----------------------|------------------|------------------|-------------|---------------|-------|-------------------|----------------------------------------------------|------------------------------------------------------------|
|          |       |                       |                  |                  | 1           | <br>          |       |                   |                                                    | Instruction                                                |
|          | *     | Operc                 | ition Code       | R                | x           | OCE           |       | ]                 | I/O Address                                        | Instruction after<br>indirect addressin<br>and/or indexing |
| Anemonic |       | Operation<br>(Hexadec |                  |                  |             | •<br>15 •     | 18    |                   | <u>•</u>                                           | 31                                                         |
| 510      | *     | 4                     | с                | R                | x           |               |       | PA 0              | 1 DCA DA                                           |                                                            |
| 10       | *     | 4                     | D                | R                | x           |               |       | PA 0              | 0 DCA<br>1 DCA DA                                  |                                                            |
| DV       | *     | 4                     | E                | R                | x           |               |       | PA 0              | 0 DCA<br>1 DCA DA                                  |                                                            |
| IO       | *     | 4                     | F                | R                | х           | 0 0 0         |       | PA 0              | 0 DCA<br>1 DCA DA                                  | Ę                                                          |
| NO       | *     | 4                     | F                | R                | х           | 0 0 1         |       | PA 🕔              |                                                    |                                                            |
| OLP      | *     | 4                     | F                | R                | х           | 0 1 0         |       | PA                |                                                    | 0                                                          |
| POLR     | *     | 4                     | F                | , R              | х           | 0 1 1         |       | PA                |                                                    | U                                                          |
| NIO      | *     | 6                     | E .              | R                | х           |               |       | 0 0 0 0 0         |                                                    |                                                            |
| ensur    | e pr  | ogram comp            | atibility with p | ossible enhance  | ments to so | oftware and/o | - hai | rdware.           | generated) and must be cod<br>DA = device address. | ed with zeros to                                           |
| ) To ad  | ldres | s Channel A           | A of an MIOP,    | bit 23 must be a | 0; to add   | Iress Channel | Bof   | an MIOP, bit 23 n | must be a 1.                                       |                                                            |
|          |       |                       |                  |                  |             |               |       |                   | oller, bit 24 must be a 1.                         |                                                            |

ą.

.

Input/Output Instructions

117

Figure 11. Formats of I/O Instructions

# 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 Ru1.

The following I/O status information may be loaded into register R only when the R field is coded with an even (non-zero) value.

|   | B<br>C<br>F | C<br>F |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    | and  |      |    |    |    |    |    |    |    |    |    |    |
|---|-------------|--------|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|----|----|
| 0 | 1           | 2      | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 2 | 0 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

The significance of each bit within register R is described in Table 14.

| Table 14. | I/O Status | Information | (Register   | R)  |
|-----------|------------|-------------|-------------|-----|
|           |            | inormation  | (incegiorer | ••• |

| Bit<br>Position                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reserved <sup>†</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| 1 <sup>##</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <u>Bus Check Fault.</u> This bit is set to 1 if a dis-<br>crepancy exists between the parity error status<br>in the memory unit and the IOP when an IOP<br>is performing a main memory read cycle. If<br>the error occurs while accessing data then the<br>device halt is controlled by the Halt-on-<br>Transmission-Error flag (bit position 36 of an<br>I/O command doubleword). If the error occurs<br>while fetching a command, the operation is<br>terminated immediately with an "unusual end". |  |  |  |  |  |  |
| 2 <sup>††</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <u>Control Check Fault</u> . This bit is set to 1 when<br>a parity error occurs during a subchannel read<br>operation within the MIOP. The operation<br>terminates immediately with an "unusual end".<br>For HSRIOP operations, this bit is always set<br>to 0.                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| 3-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reserved <sup>†</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| 11-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <u>Current Command Doubleword Address.</u> The<br>21 high-order bits of the main memory address<br>from which the command doubleword for the<br>I/O operation currently being processed by<br>the addressed I/O subsystem is fetched.                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| <sup>t</sup> To ensure program compatibility with possible software<br>and/or hardware enhancements, it is recommended that<br>reserved bits be treated as indeterminate and not used<br>(i.e., masked).<br><sup>tt</sup> The IOP unconditionally sets the Processor Fault Indi-<br>cator (PFI) whenever a Bus Check or Control Check fault<br>occurs. The IOP fault status register is set with status in-<br>formation as listed under the POLP or POLR instructions. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |

The following I/O status information may be loaded into register R if the R field is odd or into register Ru1 if the R field is even and not zero.

The format of information within the specified general register (R or Ru1) is shown below.

|   | D<br>Si | ła | tu | s  | B | y |   |   | 1. | S | )p(<br>tat | tu: | s E | 3y | te |    |    |    |    |    |    | . 1 | · · | e  | _  |    |    |    |    |    |    |    |
|---|---------|----|----|----|---|---|---|---|----|---|------------|-----|-----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|
| 0 | 1       | 2  | 3  | 14 |   | 5 | 6 | 7 | 18 | 9 | 10         | 11  | 12  | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21  | 22  | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

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.

Table 15. Device Status Byte (Register R or Ru1) (SIO, TIO, and HIO only)

| Bit<br>Position | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | Interrupt Pending. This bit is set to a 1 if the<br>addressed device has requested an interrupt<br>that has not been acknowledged by the CPU<br>with an AIO instruction. If this bit is a 1, the<br>current SIO instruction is not accepted. Con-<br>dition code bits are set to reflect this action<br>and any requested status information is loaded<br>into the designated general register(s). SIO<br>instructions will not be accepted until the<br>interrupt pending condition is cleared. |
|                 | Normally, before a device can request an in-<br>terrupt, the following conditions must prevails                                                                                                                                                                                                                                                                                                                                                                                                  |
|                 | <ol> <li>Appropriate flag(s) (IZC, ICE, and/or IUE<br/>bit positions 33, 35, and 37, respectively<br/>within the IOP command doubleword must<br/>be set to 1.</li> </ol>                                                                                                                                                                                                                                                                                                                         |
|                 | 2. The flagged event (byte count reduced to<br>zero for the IZC flag, channel end condi-<br>tion for the ICE flag, or unusual end con-<br>dition for the IUE flag) must occur.                                                                                                                                                                                                                                                                                                                   |
|                 | An I/O interrupt may also be requested by cer-<br>tain devices via M modifier bits within the<br>basic order for that device (see Operational<br>Command Doublewords).                                                                                                                                                                                                                                                                                                                           |
|                 | A CPU will respond to an interrupt request from<br>a particular I/O subsystem if (1) the I/O in-<br>terrupt.level (X'5C') is armed, enabled, and<br>not inhibited; and (2) that there is no higher<br>priority interrupt level in the active or wait-<br>ing state.                                                                                                                                                                                                                              |

Table 15.Device Status Byte (Register R or Ru1)<br/>(SIO, TIO, and HIO only) (cont.)

| Bit<br>Position | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1,2             | <u>Device Condition.</u> If bits 1 and 2 are 00 (device ready), all device conditions required 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<br>in the "automatic" mode; if this bit is 0, the<br>device is in the "manual" mode and requires<br>operator intervention. This bit can be used in<br>conjunction with bits 1 and 2 to determine the<br>type of action required. For example, assume<br>that a card reader is able to operate, but no<br>cards are in the hopper. The card reader<br>would be in state 000 (device "ready", but<br>manual intervention required), where the<br>state is indicated by bits 1, 2, and 3 of the<br>I/O status response. If the operator subse-<br>quently loads the card hopper and presses the<br>card reader START switch, the reader would<br>advance to state 001 (device "ready" and in<br>automatic operation). If the card reader is<br>in state 000 when an SIO instruction is exe-<br>cuted, the SIO would be accepted by the<br>reader and the reader would advance to<br>state 110 (device "busy", but operator inter-<br>vention required). Should the operator then<br>place cards in the hopper and press the START<br>switch, the card reader state would advance<br>to 111 (device "busy" and in "automatic"<br>mode), and the input operation would pro-<br>ceed. Should the card reader subsequently<br>become empty (or the operator press the<br>STOP switch) and command chaining is being<br>used to read a number of cards, the card<br>reader would return to state 110. If the card<br>reader would return to state 110. If the card<br>reader is in state 001 when an SIO instruction<br>is executed, the reader advances to state 111,<br>and the input operation continues as normal.<br>Should the operator press the card reader<br>STOP switch) and command chaining is being<br>used to read a number of cards, the reader<br>would go to state 110 until the operator cor-<br>rected the situation. |

| Table 15. | Device Status Byte (Register R or Ru1) |
|-----------|----------------------------------------|
|           | (SIO, TIO, and HIO only) (cont.)       |

| _ |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | it<br>osition | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4 |               | Unusual End. If this bit is a 1, the previous $I/O$ operation terminated in an "unusual end".<br>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 func-<br>tion of these two bits is dependent upon the<br>type of IOP (MIOP or HSRIOP) addressed by<br>the I/O instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|   |               | MIOP Operations: If bits 5 and 6 are 00 (de-<br>vice controller "ready"), all device controller<br>conditions required for its proper operation are<br>satisfied. If bits 5 and 6 are 01 (device con-<br>troller "not operational"), some condition has<br>developed that does not allow it to operate<br>properly. Operator intervention is usually<br>required. If bits 5 and 6 are 10 (device con-<br>troller "unavailable"), the device controller<br>is currently engaged in an operation controlled<br>by an IOP other than the one addressed by the<br>I/O instruction. If bits 5 and 6 are 11 (device<br>controller "busy"), the device controller has<br>accepted a previous SIO instruction and is cur-<br>rently engaged in performing an operation for<br>the addressed IOP. |
|   |               | HSRIOP Operations: If bits 5 and 6 are 00 (IOP "ready"), all HSRIOP conditions re-<br>quired for its proper operation are satisfied.<br>If bits 5 and 6 are 11 (IOP "busy"), the IOP<br>has accepted a previous SIO instruction and<br>is currently engaged in performing that $I/O$<br>operation. If bits 5 and 6 are either 01 or 10,<br>the IOP is in an undefined state.                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7 |               | <u>Reserved.</u> To ensure program compatibility<br>with possible software and/or hardware en-<br>hancements, it is recommended that this bit<br>be treated as indeterminate and not used<br>(i.e., masked).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Operational Status Byte. Bits 8-14 of the specified general register (R or Ru1) indicate either the presence (1) or absence (0) of various errors which may have occurred during an I/O operation. Bit 15 indicates the status of the HSRIOP. 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.

| Bit<br>Position | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Bit<br>Position |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 8               | Incorrect Length. This bit is set to 1 if an in-<br>correct length condition occurred within the<br>responding subchannel since its last accepted<br>SIO instruction. An incorrect length condition<br>is caused by a channel end (or end of record)<br>condition occurring before the device control-<br>ler has a "count done" signal from the IOP (in-<br>dicating that the byte count has been reduced<br>to zero), or is caused by the device controller<br>receiving a count done signal before channel<br>end (or end of record): e.g., count done be-                                                                                                                               | 12              |
|                 | fore 80 columns have been read from a card.<br>When set to a 1, the incorrect length bit, by<br>itself, always signifies that an incorrect<br>length condition has occurred. If the SIL flag<br>(bit 38 of the I/O command doubleword) is<br>coded with a 0, the detected incorrect length<br>condition is to be interpreted as an error con-<br>dition. If the SIL flag is coded with a 1, the<br>detected incorrect length condition is to be<br>interpreted as a nonerror condition. If an in-<br>correct length condition is to result in a de-<br>vice halt, the SIL flag must be coded with a 0<br>and the HTE flag (bit 36 of the I/O command<br>doubleword) must be coded with a 1. | 14              |
| 9               | Transmission Data Error. This bit is set to 1<br>if, since the last accepted SIO instruction<br>addressed to this subchannel, the device con-<br>troller or IOP detected a parity error or data<br>overrun in the transmitted information. A<br>device halt occurs as a result of a transmission<br>data error only if the HTE flag of the I/O<br>command doubleword is coded with a 1.                                                                                                                                                                                                                                                                                                     |                 |
| 10              | Transmission Memory Error. This bit is set to 1<br>if, since the last accepted SIO instruction<br>addressed to this subchannel, a memory parity<br>error was detected during a data input/output<br>operation. A device halt occurs as a result<br>of a transmission memory error only if the HTE<br>flag of the I/O command doubleword is coded<br>with a 1.                                                                                                                                                                                                                                                                                                                               | 15              |
| 11              | Memory Address Error. This bit is set to 1 if a<br>nonexistent memory address is detected during<br>a chaining operation or a data input/output<br>operation. The I/O operation is terminated<br>with an "unusual end".                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |

Table 16. Operational Status Byte (Register Ru1) (cont.)

| Bit<br>Position | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12              | <u>IOP Memory Error.</u> This bit is set to 1 if the<br>IOP detects a memory parity error while fetch-<br>ing a command. The I/O operation is termi-<br>nated with an "unusual end".                                                                                                                                                                                                                                                         |
| 13              | IOP Control Error. This bit is set to 1 if the<br>IOP detects two successive Transfer in Chan-<br>nel commands. Operation is terminated with<br>"unusual end".                                                                                                                                                                                                                                                                               |
| 14              | <u>IOP Halt.</u> This bit is set to 1 if an error con-<br>dition is detected which causes the IOP to<br>issue a halt order to the addressed I/O device.<br>Error conditions which may cause an IOP halt<br>(independent of the HTE flag within the I/O<br>command doubleword) are:                                                                                                                                                           |
|                 | <ol> <li>Bus check fault that occurs while fetch-<br/>ing a command</li> </ol>                                                                                                                                                                                                                                                                                                                                                               |
|                 | 2. Control check fault                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                 | 3. Memory address error                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 4. IOP memory error                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                 | 5. IOP control error                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                 | Error conditions which may cause an IOP halt<br>only if the HTE flag is coded with a 1 are:                                                                                                                                                                                                                                                                                                                                                  |
|                 | <ol> <li>Bus check fault that occurs while fetching<br/>data</li> </ol>                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 2. Transmission memory error                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 3. Transmission data error                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                 | <ol> <li>Incorrect length condition occurring<br/>while the SIL flag is coded with a 0</li> </ol>                                                                                                                                                                                                                                                                                                                                            |
|                 | An IOP halt condition causes the current<br>operation to terminate immediately as an<br>"unusual end".                                                                                                                                                                                                                                                                                                                                       |
| 15              | <u>IOP Busy.</u> For I/O instructions addressed to<br>an MIOP, this bit is always set to a 0. For<br>I/O instructions addressed to an HSRIOP, this<br>bit is set to a 1 if an HIO instruction is ad-<br>dressed to a busy HSRIOP. If a busy HSRIOP<br>is addressed with an SIO, TIO, or TDV instruc-<br>tion, the status information (as requested by<br>the R field of the I/O instruction) is not re-<br>turned (see Condition Code Bits). |



Table 17. Status Response Bits for I/O Instructions

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 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 (CC1-CC3) are set to reflect the I/O conditions.

# POLP and POLR INSTRUCTIONS

The R field of these two instructions always specifies a general register (including register 0) that may receive up to six bits of fault status information from an addressed CPU, MIOP, or HSRIOP. Each bit indicates the presence (1) or absence (0) of a specific fault condition within the polled processor, as listed in Table 18. Note that the information represented by a particular bit is also dependent upon the type of processor polled (e.g., bit 26 may indicate a memory parity error in the CPU or a Control Check fault within an MIOP).

| Table 18. | Processor | Fault | Status |
|-----------|-----------|-------|--------|
|-----------|-----------|-------|--------|

| <b>_</b>        | Fault Status                  |                   |                   |
|-----------------|-------------------------------|-------------------|-------------------|
| Bit<br>Position | CPU                           | MIOP              | HSRIOP            |
| 24              | Instruction<br>exception trap | Reserved          | Reserved          |
| 25              | Data bus<br>check             | Data bus<br>check | Data bus<br>check |
| 26              | Memory<br>parity error        | Control<br>check  | Reserved          |
| 27              | Watchdog<br>timer runout      | Reserved          | Reserved          |
| 28              | Map parity error              | Reserved          | Reserved          |
| 29              | Reserved                      | Reserved          | Re <b>ser</b> ved |

# 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'1' through X'F', the specified register may receive one word of I/O information pertaining to an I/O interrupt.

| DC and Device   | IOP                   | IOP                     | 0 DCA                |    |
|-----------------|-----------------------|-------------------------|----------------------|----|
| Status Byte     | Status Byte           | Address                 | 1 DCA DA             |    |
| 0 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 | 16 17 18 19 20 21 22 23 | 24 25 26 27 28 29 30 | 31 |

<u>Device and Device Controller Status Byte</u>. 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.

<u>IOP Status Byte.</u> 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 function of individual bits within the IOP Status Byte are described in Table 19.

Table 20 is a summary description of the Device/Device Controller Status Byte and the IOP Status Byte.

| Table 19. | IOP | Status | Byte |
|-----------|-----|--------|------|
|-----------|-----|--------|------|

| Bit<br>Position | Significance                                                                                                                                                                                                                                         |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8               | Incorrect Length. This bit is set to 1 if an in-<br>correct length condition occurred within the<br>responding subchannel since its last accepted<br>SIO instruction. An incorrect length condition<br>is caused by a channel end (or end of record) |

| Bit<br>Position | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8<br>(cont.)    | condition occurring before the device control-<br>ler has a "count done" signal from the IOP (in-<br>dicating that the byte count has been reduced<br>to zero), or is caused by the device controller<br>receiving a count done signal before channel<br>end (or end of record): e.g., count done be-<br>fore 80 columns have been read from a card.                                                                                                                                                                                                                                                                                         |
|                 | When set to a 1, the incorrect length bit, by<br>itself, always signifies that an incorrect<br>length condition has occurred. If the SIL flag<br>(bit 38 of the I/O command doubleword) is<br>coded with a 0, the detected incorrect length<br>condition is to be interpreted as an error con-<br>dition. If the SIL flag is coded with a 1, the<br>detected incorrect length condition is to be<br>interpreted as a nonerror condition. If an in-<br>correct length condition is to result in a de-<br>vice halt, the SIL flag must be coded with a 0<br>and the HTE flag (bit 36 of the I/O command<br>doubleword) must be coded with a 1. |
| 9               | Transmission Data Error. This bit is set to 1<br>if, since the last accepted SIO instruction<br>addressed to this subchannel, the device con-<br>troller or IOP detected a parity error or data<br>overrun in the transmitted information. A<br>device halt occurs as a result of a transmission<br>data error only if the HTE flag of the I/O<br>command doubleword is coded with a 1.                                                                                                                                                                                                                                                      |
| 10              | Zero Byte Count Interrupt. This bit is set to 1<br>if the interrupt on zero byte count flag is 1<br>and zero byte count is detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11              | <u>Channel End Interrupt.</u> This bit is set to 1 if<br>the interrupt at channel end flag is 1 and chan-<br>nel end is reported by the device to the IOP.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12              | Unusual End Interrupt. This bit is set to 1 if<br>the interrupt at unusual end flag is 1 and un-<br>usual end is reported by the device to the<br>IOP, or if the IOP halt is signaled to the de-<br>vice controller by the IOP.                                                                                                                                                                                                                                                                                                                                                                                                              |
| 13-15           | Reserved. To ensure program compatibility<br>with future enhancements, it is recommended<br>that these bits be treated as indeterminate and<br>not used (i.e., masked).                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

<u>Bits 16-18.</u> 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).

| Position and State in Register R                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device Status Byte                                   | Operational Status Byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0 1 2 3 4 5 6 7                                      | <u>8 9 10 11 12 13 14 15</u> Significance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$ |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                      | 1       -       -       -       -       incorrect length         -       1       -       -       -       transmission data error         -       1       -       -       -       zero byte count interrupt         -       -       1       -       -       -       channel end interrupt         -       -       1       -       -       -       unusual end interrupt         -       -       -       -       -       -       -         -       -       -       -       -       -       -         -       -       -       -       -       -       -         -       -       -       -       -       -       -         -       -       -       -       -       -       -         -       -       -       -       -       -       -       -         -       -       -       -       -       -       -       -       -         -       -       -       -       -       -       -       -       -         -       -       -       -       -       - |

Status Response Bits for AIO Instruction

Table 20.

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 single-unit device controller address or a processor address, a multiunit device controller address, and a device address. The sub-fields of the I/O address are described in Table 21.

Table 21. I/O Address (AIO Response)

| Bit<br>Position | Significance                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19-23           | <u>Processor Address.</u> These bits contain the address of the processor within the responding I/O subsystem (operation with the highest priority).                                                                                                                                                                                                                                                                                           |
| 24              | Type of Device Controller. This bit is set to 0<br>if response is from a single-unit device con-<br>troller, or set to a 1 if response is from an<br>HSRIOP or from a multiunit device controller.<br>Note that the device controller function is<br>performed by the HSRIOP.                                                                                                                                                                  |
| 25-31           | Device Controller/Device Address. These bits<br>may represent either the address of a respond-<br>ing single-unit device controller (bits 25-31,<br>with values of X'0' - X'17') or the address of<br>a multiunit device controller (bits 25-27, with<br>values of X'0' - X'7') concatenated with the<br>device address (bits 28-31, with values of<br>X'0' - X'F'). The device controller address<br>from a responding HSRIOP is always X'7'. |

# SIO START INPUT/OUTPUT (Word index alignment, privileged)

Instruction Register



General Register 0



START INPUT/OUTPUT performs the following:

- 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).
- Specifies which IOP, channel, device controller, and input/output device is to be selected (bits 19-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 11–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).

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 (CC1-CC3). 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:

|                 | Status Byte           | Byte Count                                      |
|-----------------|-----------------------|-------------------------------------------------|
| 0 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 | 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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:

| BCF | C<br>C<br>F |   |   |   |   |   |   |   |    | C  | Cu | rre | ən | t  | cc | m  | ma | 'n | d  | do | ου | Ы  | ev | vo | orc | l c | ıd | dre | ess | ;  |
|-----|-------------|---|---|---|---|---|---|---|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|-----|-----|----|
| 0 1 | 2           | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13  | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29  | 30  | 31 |

These responses provide the program with information necessary to determine the current status of the addressed I/Osubsystem. 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), (Ru1), CC1, CC2, CC3

The meaning of the condition code bits during an SIO instruction is:

- 1 2 3 4 Meaning
- 0 0 0 I/O address recognized, SIO accepted, and status information in general registers is correct.
- 0 0 1 I/O address recognized and SIO accepted; however, status information in general registers may be incorrect.
- 0 1 0 I/O address recognized, SIO not accepted, and status information in general registers is correct.
- 0 1 1 I/O address recognized, SIO not accepted because device controller or device is busy, and status information in general registers may be incorrect.

- 1 2 3 4 Meaning
- 0 0 I/O address recognized but SIO is not accepted because device controller is attached to a busy HSRIOP or an MIOP operating in the "burst" mode; or for specific device controllers, is currently busy with another device. No status information is returned to general registers.
- 1 0 1 Not possible.
- 1 1 0 I/O address not recognized, SIO not accepted, and no status information returned to general registers.
- 1 1 No I/O address recognized and SIO was aborted because an error was 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 CPU to the IOP via main memory. No status information returned to general registers.

# TIO TEST INPUT/OUTPUT

(Word index alignment, privileged)

|   |   |   |   |    |   |   |   | T |   |    |    |    | ~  |    |    |    |    | R  | Ref | fei | re | nc | e  | a   | bb | re | ss   |      |     |     | ] |
|---|---|---|---|----|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|-----|----|----|------|------|-----|-----|---|
| 1 |   |   | 4 | 4D |   |   |   |   | ĸ |    |    |    | Х  |    |    |    |    |    |     |     |    | Ī/ | ′C | ) ( | ıd | dr | ess  |      |     |     | 1 |
| 6 | 1 | 2 | 3 | 14 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20  | 21 | 22 | 23 | 24  | 25 | 26 | 27 2 | 28 2 | 9 3 | 0 3 | 1 |

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 are 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:

|   |   | э |   |   |   |   |   |    | Sto | oe<br>atu | JS | B  | yt | е  |    |    |    |    |      |      | yt |    |    |    |    |    |    |    |    |    |
|---|---|---|---|---|---|---|---|----|-----|-----------|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 18 | 9   | 10        | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 2 | 0 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

If the R field of the TIO instruction is an even value and not 0, the condition code is set, register Ru1 is loaded as shown above, and register R is loaded as follows:

|   | B<br>C<br>F | C<br>C<br>F |     |   |   |   |   |   |   |    | C  | Cu | rr | en | t  | cc | m  | m  | an | d  | do | ou | bl | e١ | w  | oro | d d | bc | dr | es | s  |
|---|-------------|-------------|-----|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 0 | 1           | 2           | 3 T | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

Refer to Tables 14–17 for functions of individual bits within status words.

Affected: (R), (Ru1), CC1, CC2, CC3

# 1 2 3 4 Result of TIO

- 0 0 0 I/O address recognized, acceptable SIO is currently possible, and status information in general registers is correct.
- 0 0 1 I/O address recognized, acceptable SIO is currently possible; however, status information in the general registers may be incorrect.
- 0 1 0 I/O address recognized but acceptable SIO is not currently possible because device controller or device is busy. Status information in general registers is correct.
- 0 1 1 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.
- 1 0 0 I/O address recognized but an acceptable SIO is not currently possible because device controller is attached to a busy high-speed RIOP or an MIOP operating in the "burst" mode; or for specific device controllers, is currently busy with another device. No status information is returned to general registers.
- 1 0 1 Not possible.
- 1 1 0 I/O address not recognized, TIO not accepted, and no status information is returned to general registers.
- 1 1 No I/O address recognized and TIO was aborted because an error was detected when the IOP attempted to read and transfer the TIO parameters (device/device controller address and R field information) from the CPU to the IOP via main memory. No status information returned to general registers.

TDV TEST DEVICE (Word index alignment, privileged)

| [. | 45            | 2         | V        | Reference address                                  |
|----|---------------|-----------|----------|----------------------------------------------------|
| *  | 4E            | к         | X        | I/O address                                        |
| 0  | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |

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 are 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.

It 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<br>Byte | Operational<br>Status Byte Byte Count                           |       |
|-----------------------|-----------------------------------------------------------------|-------|
| 0 1 2 3 4 5 6 7       | 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | 30 31 |

If the value of the R field of TDV is an even value and not 0, the condition code is set, register Ru1 is loaded as shown above, and register R is loaded as follows:

|   | B<br>C<br>F | C<br>C<br>F |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    | inc |    |    |    |    |    |    |    |    |    |    |    | - 1 |
|---|-------------|-------------|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|-----|
| 0 | 1           | 2           | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31  |

Refer to applicable peripheral reference manual for description of Device Status Byte. Refere to Tables 16 and 17 for functions of other bits within status words.

Affected: (R), (Ru1), CC1, CC2, CC3

The meaning of the condition code during a TDV is:

1 2 3 4 Result of TDV

- 0 0 0 I/O address recognized, no device-dependent condition present, and status information in general registers is correct.
- 0 0 1 I/O address recognized and no devicedependent condition present; however, status information in general registers may be incorrect.
- 0 1 0 I/O address recognized and device-dependent condition is present or device controller is in test mode.
- 0 1 1 I/O address recognized, device-dependent condition is present or device controller is in test mode but status information in the general registers may be incorrect.
- 0 0 I/O address recognized but device controller is attached to a busy high-speed RIOP or an MIOP operating in the "burst" mode, or for specific device controllers, is currently busy with another device. No status information is returned to general registers.
- 1 0 1 Not possible.
- 1 0 I/O address not recognized, TDV not accepted, and no status information is returned to the general registers.
- 1 1 No I/O address recognized and TDV was aborted because an error was detected when the IOP attempted to read and transfer the TDV parameters (device/device controller address and R field information) from the CPU to the IOP via main memory. No status information returned to general registers.

# HIO HALT INPUT/OUTPUT

(Word index alignment, privileged)

| * |   |   |   | 4 | = |   |   |   |   |   | I | २  |    |     | Х    | Ś  | 0  | 1  | 2 | 0  |    | Re | fe | re | ene<br>I, | се<br>/( | -    |    |    | _ | ss<br>ess |      |    |    |   |
|---|---|---|---|---|---|---|---|---|---|---|---|----|----|-----|------|----|----|----|---|----|----|----|----|----|-----------|----------|------|----|----|---|-----------|------|----|----|---|
| 0 | 1 | 2 | 3 | 1 | 4 | 5 | ć | 5 | 7 | 8 | 9 | 10 | 11 | 112 | 2.13 | 14 | 15 | Ti | 6 | 17 | 18 | 19 | 20 | 21 | 22        | 23       | 1 24 | 25 | 26 | 2 | 7 2       | 3 29 | 30 | 31 | - |

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.

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.

| D<br>B | e<br>yt | vi | ce |   | St | α | tu | JS | ( | O <sub>l</sub> | oe<br>at | ra<br>Us | ti<br>B | on<br>yt | al<br>e |    |    |    |    |    |    | B  | yt | e  | C  | ου | nt | ł  |    |    |    |    |
|--------|---------|----|----|---|----|---|----|----|---|----------------|----------|----------|---------|----------|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <br>0  | 1       | 2  | 3  | 4 | -  | 5 | 6  | 7  | 8 | 9              | 10       | 11       | 12      | 13       | 14      | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

If the R field of HIO is an even value and not 0, the condition code is set, register Ru1 is loaded as shown above, and register R contains the following information:

 B | C | F |
 Current command doubleword address

 0
 1
 2
 3
 4
 5
 6
 7
 18
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31

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 Tables 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 X'4F' as an operation code (bits 1-7).

Affected: (R), (Ru1), CC1, CC2, CC3

The meaning of the condition code during an HIO instruction is:

- 1 2 3 4 Result of HIO
- 0 0 0 I/O address recognized, HIO accepted, device controller not busy at time of HIO and status information in general registers is correct.
- 0 0 1 I/O address recognized, HIO accepted, and device controller not busy at time of HIO but status information in general registers may be correct.

- 1 2 3 4 Result of HIO
- 0 1 0 I/O address recognized, HIO accepted and device controller was busy at the time of the HIO, and status information is correct.
- 0 1 1 I/O address recognized, HIO accepted, and device controller was busy at the time of the HIO but the status information in the general registers may be incorrect.
- 1 0 0 Not possible.
- 1 0 1 Not possible.
- 1 1 0 I/O address not recognized, HIO not accepted, and no status information returned to general registers.
- 1 1 No I/O address recognized and HIO was aborted because an error was detected when the IOP attempted to read and transfer the HIO parameters (device/device controller address and R field information) from the CPU to the IOP via main memory. No status information returned to general registers.

# **RIO** RESET INPUT/OUTPUT (Word index alignment,<sup>†</sup> privileged)

| Γ              | Γ |   |   |   | - |   |   |       |   |   | _  |    |     | $\overline{\mathbf{v}}$ |    |    |    |    | ł  | ٦e | fe | re | no | ce | a  | da | dre | ess | ;  |    |    |    |
|----------------|---|---|---|---|---|---|---|-------|---|---|----|----|-----|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|
| 1 <sup>*</sup> |   |   | • | 4 | F |   |   |       |   | 1 | К  |    |     | Х                       |    | 0  | 0  | 1  |    | P  | ro | c. | n  | 0  |    |    |     |     |    |    |    |    |
| 0              | 1 | 2 | 3 | 1 | 4 | 5 | 6 | <br>7 | 8 | 9 | 10 | 11 | 112 | 13                      | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26  | 27  | 28 | 29 | 30 | 31 |

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 X'4F', bits 15, 16, and 17 must be coded as 001, respectively.

An RIO instruction resets the selected IOP in the same manner as the I/O RESET switch on the Processor Control Panel (PCP). However, unlike the switch, the RIO instruction resets only the addressed IOP and may be controlled by the executing program. An RIO instruction, when addressed to an MIOP, resets both channels (A and B).

Processor addresses (bits 19-23) having values of X'1C', X'1D', X'1E', and X'1F' are reserved for CPUs in a multiprocessor system. Addresses between X'00' - X'1B' may be assigned to other processors in the system. An RIO instruction addressed to a CPU is used to reset that CPU only in a special case. This special case is the result of a double fault (described in the "Trap System", Chapter 2). When the double fault occurs, the CPU raises the Processor Fault Interrupt (PFI), loads the error status register, and the CPU hangs up (PDF indicator on and none of the PHASE indicators on). The CPU that responds to the PFI will use the POLP or POLR instruction to determine the source of the PFI. The error statús may be logged (as programmed). The responding CPU may then issue an RIO instruction to the "faulted" CPU, which resets and forces execution to start at location X'26'.

<sup>&</sup>lt;sup>t</sup>When indexing operation code 4F instructions (HIO, RIO, POLP, POLR), the programmer must make certain that the summation of the contents of the index register and the I/O address (bits 19-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.

The result of a CPU executing an RIO instruction addressed to itself is undefined and should not be coded.

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 Result of RIO |
|-----------------------|
|-----------------------|

- 0 0 0 I/O address recognized.
- 1 1 0 I/O address not recognized.

POLP POLL PROCESSOR (Word index alignment,<sup>†</sup> privileged)

| [] | 45            | <u> </u>  |          | Reference address                               |
|----|---------------|-----------|----------|-------------------------------------------------|
| Ĩ. | 41-           | к         | X        | 0 1 0 Proc. no.                                 |
| 0  | 1 2 3 4 5 6 7 | 8 9 10 11 | 12 13 14 | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |

POLL PROCESSOR causes the addressed processor to return processor fault status in bits 24 to 29 of register R. This status information is processor dependent, as follows:

| D*.             | Fc                            | iult Status       |                   |
|-----------------|-------------------------------|-------------------|-------------------|
| Bit<br>Position | CPU                           | MIOP              | HSRIOP            |
| 24              | Instruction<br>exception trap | Reserved          | Reserved          |
| 25              | Data bus<br>check             | Data bus<br>check | Data bus<br>check |
| 26              | Memory<br>parity error        | Control<br>check  | Reserved          |
| 27              | Watchdog<br>timer runout      | Reserved          | Reserved          |
| 28              | Map parity<br>error           | Reserved          | Reserved          |
| 29              | Reserved                      | Reserved          | Reserved          |

In addition to the operation code of X'4F', bits 15, 16, and 17 must be coded as 010, respectively.

The result of a CPU executing a POLP instruction addressed to itself is undefined and should not be coded.

Affected: (R), CC1, CC2, CC3

Condition code settings are as shown below:

I 2 3 4 Result of POLP

0 0 0 - Processor fault interrupt not pending.

- 0 1 0 Processor fault interrupt pending.
- 1 1 0 Processor address not recognized.

<sup>†</sup>See footnote to HIO instruction.

# **POLR** POLL AND RESET PROCESSOR (Word index alignment,<sup>†</sup> privileged)

| <b>[</b> * | Γ |   |   |   |   |   |   | T | <br>r | ,<br>, |    |    | ~  |    |    |    |    | R  | ef | e  | re | nc | e  | a  | bb | re | ss |    |    |    | ٦  |
|------------|---|---|---|---|---|---|---|---|-------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|            |   |   | 4 | Г |   |   |   |   | r     | ς      |    |    | ^  |    | 0  | 1  | 1  |    | P  | 00 | с. | n  | ٥. |    |    |    |    |    |    |    |    |
| 0          | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9     | 10     | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |

POLL AND RESET PROCESSOR causes the selected processor to return processor fault status in bits 24 to 29 of register R. This status information is processor dependent, as follows:

| <b>D</b>        | Fc                            | ult Status        |                   |
|-----------------|-------------------------------|-------------------|-------------------|
| Bit<br>Position | CPU                           | MIOP              | HSRIOP            |
| 24              | Instruction<br>exception trap | Reserved          | Reserved          |
| 25              | Data bus<br>check             | Data bus<br>check | Data bus<br>check |
| 26              | Memory<br>parity error        | Control<br>check  | Reserved          |
| 27              | Watchdog<br>timer runout      | Reserved          | Reserved          |
| 28              | Map parity<br>error           | Reserved          | Reserved          |
| 29              | Reserved                      | Reserved          | Reserved          |

The POLR also resets and clears the Processor Fault Interrupt signal and the error status register. In addition to the operation code of X'4F', bits 15, 16, and 17 must be coded as 011, respectively.

The result of a CPU executing a POLR instruction addressed to itself is undefined and should not be coded.

Affected: (R), CC1, CC2, CC3

Condition code settings for the POLR instruction are:

- 1 2 3 4 Result of POLR
- 0 0 0 Processor fault interrupt not pending.
- 0 1 0 Processor fault interrupt pending.
- 1 1 0 Processor address not recognized.

# AIO ACKNOWLEDGE INPUT/OUTPUT INTERRUPT (Word index alignment, privileged)

|   |   |   | , | -  |   |   |   |    |   |    |    |    | ~  |    |    |    |    | R  | e  | fe | re | nc | e  | a  | dd | re | ess |    |    |    |    |
|---|---|---|---|----|---|---|---|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
|   |   |   | ć | )E |   |   |   |    | k |    |    |    | X  |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  |    |    |    |     |    |    |    |    |
| 0 | 1 | 2 | 3 | 14 | 5 | 6 | 7 | 18 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28 | 29 | 30 | 31 |

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 19 through 23 of the effective virtual address of the AIO instruction (normally used to specify the processor portion of the I/O address field) must be coded 00000 to specify the standard I/O system interrupt acknowledgment (other coding 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 (IOCD) that comprise the command list for the I/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 I/O interrupt is requested by that I/O subsystem to indicate the end of that I/O operation. If the IZC flag is coded as a 0, no I/O interrupt will be requested as a result of the byte count being decremented to zero).

If two or more flags are coded to cause an 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).

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 indicate the presence (1) or absence (0) of that interrupt condition are listed below:

| Condition                                                          | Control Flags<br>Coding          | Status<br>Bit Set |
|--------------------------------------------------------------------|----------------------------------|-------------------|
| Zero byte count                                                    | IZC = 1                          | 10                |
| Channel end                                                        | ICE = 1                          | 11                |
| Transmission memory error                                          | IUE = 1, HTE = 1                 | 12                |
| Incorrect length                                                   | IUE = 1, HTE = 1,<br>and SIL = 0 | 8, 12             |
| Memory address error,<br>IOP memory error, or<br>IOP control error | IUE = 1                          | 12                |
| Transmission data error                                            | IUE = 1, $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 applicable peripheral reference manual for further details. When a device interrupt condition occurs, the IOP forwards the request to the CPU interrupt system I/O interrupt level. If this interrupt level is armed, enabled, and not inhibited, the CPU eventually acknowledges the interrupt request and executes the XPSD instruction in main memory location X'5C', which 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 I/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            | IOP<br>address          | DC<br>address           |
|-----------------|-----------------------|-------------------------|-------------------------|
| 0 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 | 16 17 18 19 20 21 22 23 | 24 25 26 27 28 29 30 31 |

The function 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 19, 20, and 21.

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), CC1, CC2, CC3

Condition code settings for AIO are shown below:

1 2 3 4 Result of AIO

0

- ) 0 0 Normal interrupt recognized and reset. Status information in general register is correct.
- 0 0 1 Normal interrupt recognized and reset. Status information in the general register may be incorrect.
  - 0 Unusual condition interrupt recognized and reset. Status information in general register is correct.
- 0 1 1 Unusual condition interrupt recognized and reset. Status information in the general register may be incorrect.
- 1 0 - Interrupt recognized and reset but IOP detected a parity error in the address received from device controller. No status information returned to the general register.
- 1 0 No I/O device requesting an interrupt and no status information returned to the general register.
- 1 1 1 Not possible.

# 4. INPUT/OUTPUT OPERATIONS

In a SIGMA9 system, input/output operations are primarily under control of one or more input/output processors (IOPs). This allows the CPU to concentrate on program execution, free from the time-consuming details of I/O operations. Any I/O event that requires CPU intervention is brought to its attention by means of the interrupt system (see Chapter 2). For a detailed description of SIGMA 9 I/O instructions, see Chapter 3.

In the following discussion, the terminology conventions used are: The CPU executes instructions, the IOP executes commands, and the device controllers and I/O devices execute orders. To illustrate, the CPU will execute the START INPUT/OUTPUT (SIO) instruction to initiate an I/O operation. During the course of an I/O operation, the IOP might issue a command called Control, to transmit a byte to a device controller or I/O device that interprets the byte as an order, such as Rewind.

Each SIGMA 9 IOP operates independently after being started by a CPU. An IOP automatically picks up a chain of one or more commands from memory and executes these commands until the chain is completed or truncated as the result of an "unusual end" condition.

A multiplexor IOP can simultaneously operate up to 32 device controllers using both Channels A and B. Each device controller is assigned its own subchannel and chain of I/O commands. A high-speed RAD IOP (HSRIOP) can communicate with up to four Model 7212 RAD storage units. However, due to its high transfer rate capability, the HSRIOP remains connected until termination of the data in/data out sequence.

The flexible SIGMA 9 I/O structure permits both command chaining (making possible multiple-record operations) and data chaining (making possible scatter-read and gatherwrite operations) without intervening CPU control. Command chaining refers to the execution of a sequence of I/O commands, under control of an IOP, on more than one physical record. Thus, a new command must be issued for each physical record even if the operation to be performed for a record is the same as that performed for the previous record. Data chaining refers to the execution of a sequence of I/O commands, under control of an IOP, that gather (or scatter) information within one physical record from (or to) more than one region of memory. Thus, a new command must be issued for each portion of a physical record when the data associated with that physical record appears (or is to appear) in noncontiguous locations in memory. For example, if information in specific columns of two cards in a file are to be stored in specific regions of memory, the I/O command list might appear as follows:

- 1. Read card, store columns 1-10, data chain.
- 2. Store columns 11-60, data chain.
- 3. Store columns 61-80, command chain.

- 4. Read card, store columns 1-40, data chain.
- 5. Store columns 41-80.

The SIGMA 9 CPU plays a minor role in the execution of an I/O operation. The CPU-executed program is responsible for creating and storing the command list (prepared prior to the initiation of any I/O operation) and for supplying the IOP with a pointer to the first command in the I/O command list. Most of the communication between the CPU and the I/O system is carried out through memory.

The following is an example of the sequence of events that occurs during an I/O operation:

- 1. A CPU-executed program writes a sequence of I/O commands (doublewords) in memory.
- 2. The CPU executes the START INPUT/OUTPUT (SIO) instruction and furnishes the IOP with a 13-bit I/Oaddress (designating the device to be started) and a 21-bit first command address (designating the actual memory doubleword location where the first command for this device is located). At this point, either the device is started (if in the "ready" condition with no device interrupt pending) or an instruction reject occurs. The CPU is informed by condition code settings which of the two alternatives has occurred. If the SIO instruction is accepted, the command counter portion of the IOP register associated with the designated device controller is loaded with the first command address. From this time until the full sequence of I/Ocommands has been executed, the main program of the CPU need play no role in the I/O operation. At any time, however, the CPU may obtain status information on the progress of the I/O operation without interfering with it.
- 3. The device is now in the "busy" condition. When the device determines that it has the highest priority for access to the IOP, it requests service from the IOP with a service call. The IOP obtains the address of the first command doubleword of the I/O sequence (from the command counter associated with this device). The IOP then fetches the I/O command doubleword from memory, loads the doubleword into another register associated with the device, and transmits the first order (extracted from the command doubleword) to it.
- 4. Each command counter contains the memory address of the current I/O command in the sequence for its device. When the device requires further servicing, it makes a request to the IOP, which then repeats a process similar to that of step 3.
- 5. If a data transmission order has been sent to a device, control of the transmission resides in it. As each character is obtained by the I/O device, the IOP is signaled

that data is available. The IOP uses the information stored in its own registers to control the information interchange between the I/O device and the memory, on either a word-by-word or character-by-character basis, depending on the nature of the device.

6. When all information exchanges called for by a single I/O command doubleword have been completed, the IOP uses the command counter to obtain the next command doubleword for execution. This process continues until all such command doublewords associated with the I/O sequence have been executed.

# **OPERATIONAL COMMAND DOUBLEWORDS**

Operational command doublewords have the following format:



# ORDER

Bit positions 0 through 7 of the command doubleword contain the I/O order for the device controller or device. The I/O orders are shown below<sup>†</sup>. Bits represented by the letter "M" specify orders or special conditions to the device and are unique for each type of device.

| Bit | posi | ti | ons |
|-----|------|----|-----|
|     |      |    |     |

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | Order         |
|---|---|---|---|---|---|---|---|---------------|
| м | м | м | м | м | м | 0 | 1 | Write         |
| м | М | М | М | М | М | 1 | 0 | Read          |
| м | М | м | М | м | м | 1 | 1 | Control       |
| М | м | М | м | 0 | 1 | 0 | 0 | Sense         |
| м | М | м | м | 1 | 1 | 0 | 0 | Read Backward |
|   |   |   |   |   |   |   |   |               |

Write. The Write order causes certain device controllers to initiate an output operation. Bytes are read in ascending sequence from the memory location specified by the memory byte address field of the command doubleword. The output operation continues until the device signals "channel end", or until the byte count is reduced to 0 and no further data chaining is specified. Channel end occurs when the device has received all information associated with the output operation, completed all checks, and no longer requires the use of IOP facilities for the operation. Data chaining is described later in this chapter. <u>Read.</u> The Read order causes certain device controllers to initiate an input operation. Bytes are stored in memory in ascending sequence, beginning at the location specified by the memory byte address field of the command doubleword. The input operation continues until the device signals channel end, or until the byte count is reduced to 0 and no data chaining is specified. Channel end occurs when the device has transmitted all information associated with the input operation and no longer requires the use of IOP facilities for the operation.

<u>Control</u>. The Control order is used to initiate special operations by certain devices. For magnetic tape, it is used to issue orders such as Rewind, Backspace Record, Backspace File, etc. Most orders can be specified by the M bits of the Control order; however, if additional information is required for a particular operation (e.g., the starting address of a disk seek), the memory byte address field of the command doubleword specifies the starting address of the bytes that are to be transmitted to the device controller for the additional information. When all bytes necessary for the operation have been transmitted, the device controller signals channel end.

<u>Sense</u>. The Sense order causes certain devices to transmit one or more bytes of information, describing its current state. The bytes are stored in memory in ascending sequence, beginning with the address specified by the memory byte address field of the command doubleword. The number of bytes transmitted is a function of the device and the condition it describes. The Sense order can be used to obtain the current sector address from a disk or RAD storage unit.

<u>Read Backward</u>. The Read Backward order causes certain devices (at present, 9-track magnetic tape units) to be started in reverse, and bytes to be transmitted to the IOP for storage into memory in descending sequence, beginning at the location specified by the memory byte address field of the command doubleword. In all other respects, Read Backward is identical to Read, including reducing the byte count with each byte transmitted.

### **MEMORY BYTE ADDRESS**

For all operational I/O command doublewords, bit positions 8-31 of the doubleword provide a 24-bit memory byte address, designating the memory location for the next byte of data. For all orders other than Read Backward, this field (as stored in an IOP register) is incremented by 1 for each byte transmitted in the I/O operation; for the Read Backward order, the field is decremented by 1 for each byte transmitted.

### FLAGS

For all operational I/O command doublewords, bit positions 32–39 of the doubleword provide the IOP with eight flags that specify how to handle chaining, error, and interrupt situations.

<sup>&</sup>lt;sup>t</sup>Not all I/O devices recognize all the orders shown. See the particular Xerox SIGMA peripheral reference manual for orders applicable to that device.

The three flags (IZC, ICE, and IUE) pertaining to IOP interrupt action control whether the IOP will request an I/O interrupt to be triggered when a specified condition occurs during an I/O operation. These flags do not affect the I/O interrupt levels. Furthermore, in order for the flags to be effective, the I/O interrupt level (X'5C') must first be placed in the desired state (i.e., armed and enabled) via interrupt write control instructions (mode 1).

The functions of the eight flags are explained below.

# Bit

Position Function

- 32 (DC) Data chain. If this flag is 1, data chaining is called for when the current byte count is reduced to 0. The next command doubleword is fetched and loaded into the IOP register associated with the device controller, but the new order code is not passed out to the device controller; thus, the operation called for by the previous order is continued. (Except for Transfer in Channel command doublewords, which are explained later in this chapter, the new command doubleword is used only to supply a new memory address, a new count, and new flags.) If the data chain flag is 0, no further data chaining is called for. Channel end is initiated either by the device running out of information, or by the byte count being reduced to 0. At channel end, the device may accept a new SIO instruction, provided that a device interrupt is not pending and no "unusual end" condition exists.
- 33 (IZC) Interrupt at zero byte count. If this flag is 1, the IOP requests the I/O interrupt (location X'5C') to be triggered when the byte count of this command doubleword (as stored in the IOP register) is reduced to 0. An AIO instruction executed after the interrupt is acknowledged results in a 1 in bit position 10 of register R (status information) to indicate the reason for the interrupt.

34 (CC) Command chain. If this flag is 1, command chaining is called for when channel end occurs. If the previous operation did not terminate with an "unusual end" condition, the next command doubleword is fetched and loaded into the IOP register associated with the device controller, and the new order code is passed out to the device controller. If the CC flag is 0, no further command chaining is called for. If both data and command chaining are called for in the same command doubleword, data chaining occurs if the byte count is reduced to 0 before channel end, and command chaining occurs if channel end occurs before the byte count is reduced to 0.

Bit

Position Function

- 35 (ICE) Interrupt at channel end. If this flag is 1, the IOP requests the I/O interrupt (location X'5C') to be triggered when channel end occurs for the operation being controlled by this command doubleword. An AIO instruction executed after the interrupt is acknowledged results in a 1 in bit position 11 of register R (status information) to indicate the reason for the interrupt. If the ICE flag is 0, no interrupt is requested.
- 36 (HTE) <u>Halt on transmission error</u>. If this flag is 1, any error condition associated with data transmission (transmission data error, transmission memory error, incorrect length error) detected in the device controller or IOP results in halting the I/O operation being controlled by this command doubleword. If the HTE flag is 0, an error condition does not cause the I/O operation to halt, although the error conditions are recorded in the IOP register and returned as part of the status information for the instructions SIO, HIO, and TIO.

The HTE flag must be coded identically in every command doubleword associated with the same physical record. This means that when data chaining occurs, the HTE flag in the new IOP command doubleword must be the same as the HTE flag in the previous IOP command doubleword. This restriction applies to data chaining only, and not to command chaining.

- 37 (IUE) Interrupt on unusual end. If this flag is 1, the device controller requests the I/O interrupt (location X'5C') to be triggered when an "unusual end" condition is encountered. When an "unusual end" condition is detected, further servicing of the commands for that device is suspended. An AIO instruction executed after the interrupt is acknowledged results in a 1 in bit position 12 of register R (status information) to indicate the reason for the interrupt. If the IUE flag is 0, no interrupt is requested.
- 38 (SIL) Suppress incorrect length. If this flag is 1, an incorrect length indication by the device controller is not to be classified as an error by the IOP, although the IOP retains the incorrect length indication and provides an indicator (bit 8 of register Ru1, the status response for SIO, HIO, AIO, and TIO) to the program. If the SIL flag is 0, an incorrect length is considered an error and the IOP performs as specified by the HTE and IUE flags. Incorrect length is caused by a "channel end" condition occurring before the device controller has received a "count done"

# Bit Position Function

- 38 (SIL) signal from the IOP, or is caused by the device (cont.) controller receiving a count done signal before end of record, e.g., count done before 80 columns have been read from a card. Normally, a count done signal is sent to the device controller by the IOP to indicate that all data transfer associated with the current operation has been completed. The IOP is capable of suppressing an error condition on incorrect length, since there are situations in which incorrect length is not an error.
- 39 (S) Skip. If this flag is 1, the input operation (Read or Read Backward) controlled by this command doubleword continues normally, except that no information is stored in memory. When used in conjunction with data chaining, the skip operation provides the capability for selective reading of portions of a record.

If the S flag is 1 for an output (Write) operation, the IOP does not access memory, but transmits zeros as data instead (i. e., the IOP transmits the number of X'00' bytes specified in the byte count of the command doubleword). This allows a program to punch a blank card (by using the S bit and a Punch Binary order with a byte count of 120) without requiring memory access for data. If the S flag is 0, the I/O operation proceeds normally.

### BYTE COUNT

For all operational I/O command doublewords, bit positions 48-63 of the doubleword provide for a 16-bit count of the number of bytes to be transmitted in the I/O operation; thus, 1 to 65, 536 bytes (16, 384 words) can be specified for transfer before command or data chaining is required. This field (as stored in an IOP register) is decremented by 1 for each byte transmitted; thus, it always contains a count of the number of bytes yet to be transmitted to or from memory, and this count is returned as part of the response information for the instructions, SIO, HIO, TIO, and TDV. An initial byte count of 0 is interpreted as 65, 536 bytes.

# **CONTROL COMMAND DOUBLEWORDS**

In addition to the operational command doubleword, there are two control command doublewords with different formats that provide control information for the IOP. The Transfer in Channel command doubleword has the following format:



# 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63

Transfer in Channel. The Transfer in Channel command is executed within the IOP and has no direct effect on any of the I/O system elements external to the addressed IOP. The primary purpose of this command is to permit branching within the command list so that the IOP can, for example, repeatedly transmit the same set of information a number of times. When the IOP executes the Transfer in Channel command, it loads the command counter for the device controller it is currently servicing with the next command address field of the Transfer in Channel command, loads the new command doubleword specified by this address into the IOP registers associated with the device controller, and then executes the new command. (Bit positions 0-3, 8-10, and 32-63 of the command doubleword for Transfer in Channel are ignored.) Transfer in Channel thus allows a command list to be broken into noncontiguous groups of commands. When used in conjunction with command chaining, Transfer in Channel facilitates the control of devices such as unbuffered card punches or unbuffered line printers. The current flags are not altered during this command; thus, the type of chaining called for in the previous command doubleword is retained until changed by a command doubleword following Transfer in Channel.

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, when twelve rows have been punched, causes the IOP to skip the command it would be executing next. Thus, a command list for punching two cards might look like the following example:

| Location | Command                                                                                        |
|----------|------------------------------------------------------------------------------------------------|
| :<br>A   | :<br>Punch row for card 1, command chain.                                                      |
| В        | Transfer in Channel to A.<br>Punch row for card 2, command chain.<br>Transfer in Channel to B. |
| :        | Stop.                                                                                          |

The Transfer in Channel command also can be used in conjunction with data chaining. As one example, consider a situation often encountered in data acquisition applications, where data is transmitted in extremely long, continuous 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 look like the following example:

| Location | Command                                          |
|----------|--------------------------------------------------|
| :<br>A   | :<br>Read data, store into buffer 1, data chain. |
|          | Store into buffer 2, data chain.                 |
|          | Transfer in Channel to A.                        |
| •        |                                                  |
|          | •                                                |

If the IOP encounters two successive Transfer in Channel commands, this is considered an IOP control error, resulting in the IOP setting the IOP control error status bit (bit 13 of register Ru1) and issuing an "IOP Halt" signal to the device controller. The IOP then halts further servicing of this command list. The Stop command doubleword has the following formats:

| 1 | 0 |   |   |   |   |   | -0 |    |   |   |     |    |    |    |    |    |     |     |    |   |     |    |    |    |   |     |    |   |    |    |     |    |    |   |    |
|---|---|---|---|---|---|---|----|----|---|---|-----|----|----|----|----|----|-----|-----|----|---|-----|----|----|----|---|-----|----|---|----|----|-----|----|----|---|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7  | 18 | 9 | 1 | 0 1 | 11 | 12 | 13 | 14 | 12 | 511 | 5 1 | 71 | 8 | 191 | 20 | 21 | 22 | 2 | 3 2 | 42 | 5 | 26 | 27 | 128 | 29 | 93 | 0 | 31 |
| 0 |   |   |   |   |   |   | 0  |    |   |   |     |    |    |    |    |    |     |     |    |   |     |    |    |    |   |     |    |   |    |    |     |    |    |   |    |

Stop. The Stop command causes certain devices to stop, generate a "channel end" condition, and also request the I/O interrupt (location X'5C') to be triggered if bit 0 in the Stop command is a 1. An AIO instruction executed after the interrupt is acknowledged results in a 1 in bit position 7 of register R (status information) to indicate the reason for the interrupt. (Bit positions 32-39 of the command doubleword for Stop must be zero; bit positions 8-31 and 40-63 are ignored). 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.

# 5. OPERATOR CONTROLS

# **PROCESSOR CONTROL PANEL**

The SIGMA 9 processor control panel (PCP) is shown in Figure 12. The controls and indicators are divided into two sections. The upper section, which is labeled MAINTE-NANCE SECTION, contains most of the controls and indicators used by maintenance personnel. The DISPLAY FORMAT indicator and FORMAT SEL switch located in the lower section are also primarily used by maintenance personnel. All other controls and indicators located in the lower section of the PCP are normally used by operating personnel to load, execute, and troubleshoot programs.

A three-position rotary switch, located in the upper lefthand corner and labeled EXT CONT/LOCALNORM/LOCAL MAINT, is a control mode selector for the PCP. It is set either to the LOCAL NORM position for normal operations or to the LOCAL MAINT position for maintenance operations. The EXTCONT position is reserved for future use. Hereafter, this switch will be referred to as the Control Mode switch.

### **CONTROL MODE**

When the Control Mode switch is in the LOCAL MAINT position, all switches on the control panel are enabled. When the Control Mode switch is in the LOCAL NORM position, all switches are enabled except the following:

1. The FORMAT SEL switch is disabled and forced to appear in the NORMAL position, regardless of the position of that switch.



Figure 12. Processor Control Panel

- 2. The SNAP switches are disabled.
- 3. The EXT DIO switch is disabled.
- 4. The CLOCK MARGINS switch is disabled and forced to appear in the NORM position.
- 5. The CLOCK MODE switch is disabled and forced to appear in the CONT position.
- 6. The SCAN switches are disabled.

#### POWER

The POWER switch controls ac power to the central processor and to units under its direct control. The POWER indicator is lighted when ac power is on.

### **MEMORY CLEAR**

The MEMORY CLEAR switch clears all CPU memory. When this switch is pressed, the SCAN light illuminates and remains on until all memory is cleared. The contents of the general registers remain unaltered during the operation. It is recommended that CPU RESET be pressed before using the MEMORY CLEAR switch. Homespace bias is automatically suppressed during the clear operation.

#### SYS RESET

The SYS RESET (system reset) switch performs the combined functions of the CPU RESET switch and the I/O RESET switch. The SYS RESET switch also initializes all memories connected to the system. The initialization of memories does not change the contents of any memory locations; only memory port logic is reset.

### I/O RESET

The I/O RESET switch initializes the standard input/output system. When the switch is pressed, all peripheral devices under control of the central processor are reset to the "ready" condition, and all status, interrupt, and control indicators in the input/output system are reset. The I/O RESET switch does not affect the central processor.

#### LOAD

The LOAD switch is active only when the COMPUTE switch is in the IDLE position. When this momentary action switch is pressed, a load program is written into memory locations X'22' through X'2B' for an input operation that uses the peripheral unit selected by the UNIT ADDRESS switches. CPU RESET or SYSTEM RESET must be performed before using this switch.

Detailed loading operation is described in the section "Loading Operation".

### UNIT ADDRESS

Four UNIT ADDRESS switches select the peripheral unit to be used in the loading process. The two switches on the left designate an input/output processor (IOP). The leftmost switch has two positions, numbered 0 and 1. The next switch has 16 positions, numbered hexadecimally 0 through F. The two rightmost switches each have 16 positions, numbered hexadecimally 0 through F, which designate the device controller/device that is under control of the selected IOP.

#### SENSE

The four SENSE switches and indicators are monitored under program control to set the condition code portion of the program status doubleword (PSD). When a READ DIRECT instruction is executed in the internal control mode, the condition code is set according to the state of the four SENSE switches. If a SENSE switch is in the set (1) position (indicator lighted), the corresponding bit of the condition code is set to 1; if a SENSE switch is in the reset (0) position (indicator unlighted), the corresponding bit of the condition code is reset to 0.

#### NOT NORMAL

The NOT NORMAL indicator informs the user that normal program execution may be inhibited by the PCP. The NOT NORMAL indicator is lighted when any of the following occurs:

- 1. The Control Mode switch is in the LOCAL MAINT position.
- 2. The DECIMAL OVERRIDE switch is in the OVERRIDE position.
- 3. The INTERLEAVE SEL switch is in the DISABLE position.
- The W.D. TIMER switch is in the OVERRIDE position.
- 5. The MEMORY FAULT switch is in the HALT position.
- 6. The CPU power supply voltage is not normal.

When the NOT NORMAL momentary action switch is depressed, a control panel lamp test is performed. This test turns on all indicators in the MAINTENANCE section, the DISPLAY lights, and the STOP and NOT HERE lights, without affecting machine operation.

#### HALT

The HALT indicator is lighted when the CPU is in the IDLE state.

Processor Control Panel 135

# WAIT

# RUN

The WAIT indicator is lighted when any of the following halt conditions exists:

- 1. The computer has executed a WAIT instruction.
- 2. The CPU RESET or SYS RESET switch is pressed when the COMPUTE switch is in the IDLE position.
- 3. The COMPUTE switch is in the IDLE position and the SYSTEM POWER switch turns power on or power is applied to the CPU.

The RUN indicator is lighted when the COMPUTE switch is in the RUN position.

# **PROGRAM STATUS DOUBLEWORD INDICATORS**

Two rows of binary indicators display the current PSD. For convenience, the second portion of the PSD, labeled PSW2, is arranged above the first portion, labeled PSW1. The PSD display consists of the indicators shown in Table 22.

| PSD<br>Portion | Indicator    | Function                              | PSD Bit<br>Position | PSD<br>Designation |
|----------------|--------------|---------------------------------------|---------------------|--------------------|
| PSW2           | WRITE KEY    | Write key status                      | 34, 35              | WΚ                 |
|                | INTRPT INHIB | Interrupt inhibits status             |                     |                    |
|                | CI           | Counter interrupt group inhibit       | 37                  | CI                 |
|                | II           | Input/output interrupt group inhibit  | 38                  | 11                 |
|                | EI           | External interrupt inhibit            | 39                  | EI                 |
|                | MA           | Mode altered                          | 40                  | МА                 |
|                | EXT ADDR     | Extension address                     | 42-47               | EA                 |
|                | POINTER      | Register block pointer                | 58-59               | RP                 |
| PSW 1          | COND CODE    | Condition code                        |                     |                    |
|                | 1            | Condition code 1                      | 0                   | CC1                |
|                | 2            | Condition code 2                      | 1                   | CC2                |
|                | 3            | Condition code 3                      | 2                   | ССЗ                |
|                | 4            | Condition code 4                      | 3                   | CC4                |
|                | FLOAT MODE   | Floating-point mode controls          |                     |                    |
|                | SIG          | Significance trap mask                | 5                   | FS                 |
|                | ZERO         | Zero trap mask                        | 6                   | FZ                 |
|                | NRMZ         | Normalize mask                        | 7                   | FN                 |
|                | MODE         | Computer mode and memory map controls |                     |                    |
|                | SLV          | Master/slave mode control             | 8                   | MS                 |
|                | МАР          | Memory map control                    | 9                   | мм                 |

# Table 22. Program Status Doubleword (PSD) Indicators

| PSD<br>Portion  | Indicator              | Function                                               | PSD Bit<br>Position | PSD<br>Designation |
|-----------------|------------------------|--------------------------------------------------------|---------------------|--------------------|
| PSW1<br>(cont.) | TRAP                   | Arithmetic trap mask                                   |                     |                    |
|                 | DEC                    | Decimal arithmetic fault trap mask                     | 10                  | DM                 |
|                 | AR                     | Fixed-point arithmetic overflow trap mask              | 11                  | АМ                 |
|                 | ASCI                   | ANSCII mask                                            | 12                  | AS                 |
|                 | INSTRUCTION<br>ADDRESS | Instruction address or extension selector/displacement | 15-31               | IA                 |
|                 | 2                      | Extension selector                                     | 15                  | ES                 |
|                 | ,                      | Displacement                                           | 16-31               | D                  |

### Table 22. Program Status Doubleword (PSD) Indicators (cont.)

# INSERT

The INSERT switch permits manual changes to the PSD. The switch is stationary and inactive in the center (normal) position and momentary in the upper (PSW2) and lower (PSW1) positions. When the INSERT switch is moved to the PSW1 or PSW2 position, the corresponding half of the PSD is changed, as necessary, and the corresponding indicators display the information that has been entered from the 32 DATA switches located at the bottom of the control panel. The INSERT switch is active only when the COMPUTE switch is in the IDLE position.

### CPU RESET

The CPU RESET switch initializes the central processor. When this switch is pressed, the following operations are performed:

- 1. All interrupt levels are reset to the disarmed and disabled state.
- 2. The ALARM indicators (visual and audio) are reset.
- 3. All PSD bits are reset except for the INSTRUCTION ADDRESS.
- 4. The INSTRUCTION ADDRESS indicators are set to X'26'.
- 5. The WAIT indicator is set, indicating the CPU is in the WAIT state.

The CPU RESET switch does not affect any operation that may be in process in the standard input/output system and is active only if the COMPUTE switch is in the IDLE position.

## INTERRUPT

The operator uses the INTERRUPT switch to activate the control panel interrupt. If the control panel interrupt (level X'5D') is armed when the INTERRUPT switch is pressed, a single pulse is transmitted to the interrupt level, advancing it to the waiting state. The INTERRUPT indicator is lighted when the control panel interrupt level is in the waiting or active state. If the control panel interrupt level is disarmed (or already in the active state) when the INTERRUPT switch is pressed, no computer or control panel action occurs. The INTERRUPT indicator goes off only when the level leaves these states and the switch is released. Thus, the light indicates that pushing the switch triggered the interrupt and that no new interrupt can be triggered until the switch is released and the level is cleared. The INTERRUPT switch is always operative.

### **ADDRESS STOP**

The ADDRESS STOP section of the control panel consists of two switches, a STOP indicator, and a NOT HERE indicator.

The two ADDRESS STOP switches latch in all positions and are labeled INSTR/NORM/MEM REF and PAGE/WORD/WD/ WRT. They are used in conjunction with the SELECT AD-DRESS switches and the COMPUTE switch to cause the CPU to establish a halt condition and turn on the ADDRESS STOP indicator whenever the CPU accesses a selected instruction or a real memory address.

# PAGE/WORD/WD/WRT

When the PAGE/WORD/WD/WRT switch is in the PAGE position, it causes the address stop feature to ignore the nine least significant SELECT ADDRESS switches. In effect, this enables the address stop feature when any word in a selected page is addressed.

When the PAGE/WORD/WD/WRT switch is in the WORD position, 22 SELECT ADDRESS switches specify an address. Note that although there are 24 SELECT ADDRESS switches, the two leftmost switches are not used during address stop operations.

When the PAGE/WORD/WD/WRT switch is in the WD/WRT position (word write), all actions of the WORD positions of the switch apply. However, memory reference address stops are enabled only for memory write cycles.

## INSTR/NORM/MEM REF

When the INSTR/NORM/MEM REF (instruction/normal/ memory reference) switch is in the NORM position, it is inactive and the address stop feature is inhibited.

When this switch is in the MEM REF position and the COM-PUTE switch is in the RUN position, a halt condition occurs when the CPU accesses a real memory reference address equal to the address contained by the 22 SELECT ADDRESS switches, subject to the constraints of the PAGE/WORD/ WD/WRT switch, as described above. The value of the INSTRUCTION ADDRESS indicators at the time of the halt is determined by the sequence of instructions being executed at the time of memory reference.

When the INSTR/NORM/MEM REF switch is in the INSTR position and the COMPUTE switch is in the RUN position, a halt condition occurs when the CPU accesses an instruction whose virtual address is equal to that contained in the 17 least significant SELECT ADDRESS switches, subject to the constraints of the PAGE/WORD/WD/WRT switch. The INSTRUCTION ADDRESS indicators at the time of the halt normally will equal the SELECT ADDRESS value, and the instruction pointed to by the INSTRUCTION ADDRESS will appear on the DISPLAY indicators.

The ADDRESS STOP halt condition is reset when the COMPUTE switch is moved from RUN to IDLE; if the COMPUTE switch is then moved back to RUN (or to STEP), the instruction shown in the DISPLAY indicators is the next instruction executed. No interrupt is allowed to proceed from the waiting to the active state while the ADDRESS STOP halt condition exists.

The ADDRESS STOP function is disabled during the time that the SNAP is armed.

### STOP

The STOP indicator lights to indicate that the machine has halted due to either an INSTR-ADDRESS STOP or MEM REF-ADDRESS STOP. The STOP indicator is turned off when the COMPUTE switch is moved from RUN to IDLE.

# NOT HERE

The NOT HERE indicator is lighted whenever a nonexistent memory location is referenced. It is automatically reset at the end of each memory cycle, or when the RESET switch is depressed.

# SELECT ADDRESS

The SELECT ADDRESS switches are used in conjunction with

- 1. The ADDRESS STOP switches (INSTR/NORM/MEM REF and PAGE/WORD/WD/WRT) to select the virtual or real address at which a program will be halted.
- 2. The STORE switch to select the location to be altered.
- 3. The DISPLAY switch to select the word to be displayed.
- 4. The SCAN MODE switches to establish an upper boundary of the memory scan operation.
- 5. The SCAN-START ADDR switch to enter a starting address of the memory scan operation.
- 6. The EXT DIO switch to determine the DIO address lines.

Each SELECT ADDRESS switch represents a 1 in the upper position or a 0 in the lower position.

### STORE

The STORE switch alters the contents of a general register or a memory location. The switch is stationary and inactive in the center (unmarked) position and momentary in the INSTR ADDR and SELECT ADDR positions. When the switch is moved to the INSTR ADDR position, the current value of the DATA switches is stored in the location pointed to by the INSTRUCTION ADDRESS indicators; when the switch is moved to the SELECT ADDR position, the current value of the DATA switches is stored in the location pointed to by the SELECT ADDR position, the current value of the DATA switches is stored in the location pointed to by the SELECT ADDRESS switches. The address is modified by the computer mode bits of the PSD. The contents of the addressed location are altered regardless of write protection. The STORE switch is active only when the COMPUTE switch is in the IDLE position.

### **INSTR ADDR**

The INSTR ADDR (instruction address) switch is latching and inactive in the NORM position, latching in the HOLD position, and momentary in the INCRM position.

When the INSTR ADDR switch is in the HOLD position, the normal process of incrementing the INSTRUCTION ADDRESS portion of the PSD with each instruction execution is inhibited. With the INSTR ADDR switch in the HOLD position and the COMPUTE switch in the RUN position, the instruction in the location pointed to by the value of the INSTRUC-TION ADDRESS indicators is executed repeatedly, with the INSTRUCTION ADDRESS indicators remaining unchanged. Moving the COMPUTE switch to the momentary STEP position while the INSTR ADDR switch is in the HOLD position causes the instruction in the location pointed to by the value of the INSTRUCTION ADDRESS indicators to be executed once each time the COMPUTE switch is moved to the STEP position. The INSTRUCTION ADDRESS indicators normally remain unchanged. During HOLD operations, the INSTRUCTION ADDRESS may be altered as a result of a trap, interrupt, LPSD, XPSD, or branch instruction.

Each time the INSTR ADDR switch is moved from the NORM position to the INCRM position, the following operations are performed:

- 1. The current value of the INSTRUCTION ADDRESS indicators is incremented by 1.
- Using the new value of the INSTRUCTION ADDRESS indicators as a virtual address value (i.e., subject to the current memory map if the MAP mode indicator is lighted), the contents of the location pointed to by the INSTRUCTION ADDRESS are displayed in the DISPLAY indicators.

If the final memory address is nonexistent, the CPU does not trap and the DISPLAY indicators are indeterminate. The access protection status of the virtual address does not affect the operation of the INSTR ADDR switch.

## **DISPLAY (INDICATORS)**

The 32 DISPLAY indicators may display an instruction, data word, or maintenance data. When the Control Mode switch is in the LOCAL NORM position, the FORMAT SEL switch is forced into the NORMAL mode and the DISPLAY switch, COMPUTE switch, and INSTR ADDR switch can be used to display the contents of a memory location or the current contents of the internal CPU instruction register.

When the DISPLAY switch is placed in the INSTR ADDR position, the contents of the location indicated by the INSTRUCTION ADDRESS indicators are displayed in the DISPLAY indicators. When the DISPLAY switch is placed in the SELECT ADDR position, the contents of the location selected by the SELECT ADDRESS switches is displayed in the DISPLAY indicators. When the INSTR ADDR switch is placed in the INCRM position, the INSTRUCTION ADDRESS is incremented by one and the contents of the location is displayed in the DISPLAY indicators.

When the COMPUTE switch is placed in the STEP position, the contents of the location displayed in the INSTRUCTION ADDRESS will be executed and the next instruction in the sequence in the internal CPU instruction register will be displayed in the DISPLAY indicators.

To display maintenance data, the Control Mode switch must be in the LOCAL MAINT position, and the FORMAT SEL switch may be placed in either the CONTROL position or the REGISTER position to have control words or internal register contents displayed in the DISPLAY indicators. The specific control word or internal register selected is controlled by the thumbwheel adjacent to the roll chart on the DISPLAY FORMAT.

## **DISPLAY FORMAT**

The DISPLAY FORMAT feature, which is used by maintenance personnel, is inactive whenever the Control Mode switch is in the LOCAL NORM position. A chart comprised of 16 lines of printed information is mounted on a roller located directly behind the slot in the panel labeled DISPLAY FORMAT. Associated with the chart is a 16-position switch (thumbwheel-actuated) and a 3-position FORMAT SEL switch, which selects various internal registers of the CPU for display.

#### FORMAT SEL

The 3-position FORMAT SEL (format select) switch is labeled CONTROL/NORMAL/REGISTER. In the NORMAL position, the DISPLAY lights show the CPU internal instruction register, and the DISPLAY FORMAT and FORMAT SEL features are inactive. When the Control Mode switch is not in the LOCAL MAINT position, the FORMAT SEL switch is overridden and the DISPLAY indicators always show the CPU internal instruction register (NORMAL position). When the FORMAT SEL switch is in either the REGISTER position or the CONTROL position, and the Control Mode switch is in the LOCAL MAINT position, the DISPLAY indicators are used primarily for maintenance and/or diagnostic operations. In the REGISTER position, the contents of the selected internal register (indicated by the line on the panel that is drawn from the legend "REGISTER" to the display window) will appear in the DISPLAY indicators. In the CONTROL position, specific control information (indicated by the line on the panel that is drawn from the legend "CONTROL" to the display window), as indicated by the display format labels, appears in the DISPLAY indicators. The definitions of the individual labels on the display format chart are found in the glossary for the appropriate SIGMA 9 Engineering Support Manual (CPU, Publication 90 24 35; Decimal, Publication 90 24 36).

#### DATA

The 32 DATA switches alter the contents of the PSD when used in conjunction with the INSERT switch, or alter the contents of memory or a general register when used in conjunction with the STORE switch. Each DATA switch is latching in both the upper and center positions. In the center position, a DATA switch represents a 0; in the upper position, a 1.

## **DISPLAY (SWITCH)**

The DISPLAY switch displays the contents of a general register or a memory location. The DISPLAY switch is stationary and inactive in the center (unmarked) position and momentary in the INSTR ADDR and SELECT ADDR positions. When the switch is moved to the INSTR ADDR or SELECT ADDR position, the contents of the location pointed to by the INSTRUCTION ADDRESS indicators or the SELECT ADDRESS switches, respectively, are shown in the DISPLAY indicators. The real memory address is modified according to the CPU mode bits of the PSD.

If the final memory address is nonexistent, the CPU does not trap and the DISPLAY indicators are indeterminate. The access protection status of the virtual memory does not affect the operation of the DISPLAY switch. The DISPLAY switch is active only when the COMPUTE switch is in the IDLE position.

#### COMPUTE

The COMPUTE switch controls the execution of instructions. The IDLE and RUN positions are both latching; the STEP position is momentary. When the COMPUTE switch is in the IDLE position, all other control panel switches are operative and the ADDRESS STOP halt and the WAIT instruction halt conditions are reset (cleared). No interrupts are allowed in this mode.

When the COMPUTE switch is moved from IDLE to RUN, the RUN indicator is lighted and the current setting of the INSTRUCTION ADDRESS indicators is taken as the address of the next instruction to be executed, regardless of the contents of the DISPLAY indicators.

When the COMPUTE switch is in the RUN position, the only operative switches are POWER, INTERRUPT, ADDRESS STOP, INSTR ADDR (in the HOLD position), and the switches in the maintenance section except SCAN, EXT DIO, and SNAP ENTER.

Each time the COMPUTE switch is moved from IDLE to STEP, the following operations occur:

- 1. The instruction pointed to by the current value of the INSTRUCTION ADDRESS indicators is executed.
- 2. The current value of the INSTRUCTION ADDRESS indicators is incremented by 1. If the "stepped" instruction (executed by moving the COMPUTE switch from IDLE to STEP) is a branch instruction and the branch should occur, the INSTRUCTION ADDRESS indicators are set to the value of the effective address of the branch instruction.
- 3. The instruction in the location pointed to by the new value of the INSTRUCTION ADDRESS indicators is displayed in the DISPLAY indicators.

If an instruction is being stepped, all interrupt levels are temporarily inhibited while the instruction is being executed; however, a trap condition can occur while the instruction is being executed. In this case, the XPSD instruction in the appropriate trap location is executed as if the COMPUTE switch were in the RUN position. Thus, if a trap condition occurs during a stepped instruction, the PSD display automatically reflects the effects of the XPSD instruction, and the DISPLAY indicators then contain the first instruction of the trap routine.

## **MAINTENANCE CONTROLS**

The controls and indicators located in the MAINTENANCE SECTION of the PCP, as well as the DISPLAY FORMAT and FORMAT SEL switches (described previously), are used primarily during computer maintenance and diagnostic operations.

#### ALARM

Audio and visual alarms may be used to attract the computer operator's attention. The alarms are turned on and off (under program control) by executing a properly coded WRITE DIRECT instruction. When the visual ALARM indicator is lighted and the AUDIO switch is ON, a 1000-Hz signal is sent to the computer speaker; when the AUDIO switch is not in the ON position, the speaker is disconnected. (The AUDIO switch does not affect the state of the visual ALARM indicator.) The ALARM indicator is reset (turned off) whenever either the CPU RESET or the SYS RESET switch is pressed or a properly coded WRITE DIRECT instruction is executed.

The AUDIO switch controls all signals to the computer speaker, whether from the 1000-Hz signal or program-controlled frequency flip-flop.

## PDF

The PDF (processor detected fault) indicator is on when the PDF flag is set (see Chapter 2, Trap System, Processor Detected Faults).

#### CLOCK MARGINS

The CPU clock frequency may be changed to values above and below the normal operating values by manually setting the CLOCK MARGIN switch or by programming via an appropriate internal WRITE DIRECT instruction. The CLOCK MARGIN switch overrides program control when set to the FAST or SLOW position. When set to the NORMAL position, clock margins are under program control. The NOT NORM clock indicator will be lighted whenever the clock frequency is not normal due to programming or switch settings of FAST or SLOW.

#### PHASES

The PHASES indicators display certain internal operating phases of the computer. The PREPARATION indicators display computer phases during preparation sequences. The PCP indicators display computer phases during processor control panel operations. The EXECUTION indicators display computer phases during the execution portion of an instruction cycle. The INT/TRAP (interrupt/trap) indicators are individually lighted when an interrupt or a trap condition occurs. When the COMPUTE switch is in the IDLE position, all PHASES indicators are normally off except for the rightmost PCP indicator (indicating the idle phase for processor control panel functions).

#### CLOCK MODE

The CLOCK MODE switch controls the internal computer clock. When the switch is in the CONT (continuous) position, the clock operates at normal speed. However, when the CLOCK MODE switch is in the inactive (center) position, the clock enters an idle state and can be made to generate one clock pulse each time the switch is moved to the SINGLE STEP position. When the clock is pulsed by the CLOCK MODE switch, the PHASES indicators reflect the computer phase during each pulse of the clock.

### SNAP

All logic that is displayable on the PCP can be monitored with the snapshot control logic. Snapshot control logic is preset (armed) by executing a WRITE DIRECT (Load Snapshot Control Register) instruction or, when the COMPUTE switch is in the IDLE position, by moving the SNAP ENTER switch to the ENTER position. Moving the ENTER switch from the latching and inactive center position selects the following conditions (duplicates the function performed by the appropriate internal WRITE DIRECT instruction):

- 1. A clock count number (obtained from DATA switches 0-7).
- 2. An interrupt flag (obtained from DATA switch 8). If this bit is equal to 1, the PCP interrupt is triggered at the time the snapshot occurs.
- 3. DATA switch 9 must be set to 0 (down position).
- 4. A register or group of control elements to be recorded (obtained from DATA switches 10-14).
- 5. A virtual instruction address (obtained from DATA switches 15-31).

When the COMPUTE switch is in the RUN position and the selected virtual address matches the instruction address of the PSD, the clock counter is decremented by each CPU clock pulse, starting with the first phase of execution. When the clock counter reaches a value of one, the selected logic is clocked by the current selected CPU clock into a 32-bit "snap" register and the snap condition is reset. The contents of the "snap" register can then be recorded by a READ DIRECT instruction under program control or visually displayed with the use of FORMAT SEL and DISPLAY FORMAT switches. The SNAP STOP switch can be used to stop the clock at time of the snap condition by setting it to the ON position. This switch is inactive in the NORM position. The halt condition, resulting from the SNAP STOP switch stopping clock at snap time, can be reset by placing the STOP switch to the NORM position, which disables the STOP switch, or by placing the CLOCK MODE switch to center (unmarked) position, which keeps the clock stopped, then moving the SNAP STOP switch to the NORM position and SINGLE STEP the CLOCK MODE switch to reset the stop on snap condition, and then set the CLOCK MODE switch to CONT position.

#### **SNAP MODE**

The SNAP MODE indicator shows that the snap feature is armed and waiting to "snap", and is reset only if the snap has occurred or CPU RESET, SYS RESET, or a READ DIRECT for the SNAP register has been performed.

#### MEMORY MODE

MEMORY MODE switches and indicator are comprised of an INTERLEAVE SEL switch, a MEMORY FAULT switch, and a MEMORY FAULT indicator.

## INTERLEAVE SEL

When the INTERLEAVE SEL (interleave select) switch is in the NORM position, memory address interleaving occurs normally depending on the interleave switches of the memory; however, when the switch is in the DISABLE position, memory addresses are not interleaved between memory banks.

## MEMORY FAULT

The MEMORY FAULT switch in the CONT position has no effect on the CPU operation, but enables the MEMORY FAULT light to display the state of the Memory Fault Interrupt line in addition to momentarily displaying a CPUdetected bus or core parity error condition. When it is set to the HALT position, a CPU-detected parity error (core or bus) resulting from a memory operation will establish a CPU halt condition by stopping the CPU clock at the time of detection. At this time the MEMORY FAULT light is on, but the state of the Memory Fault Interrupt line is not displayed. The halt condition is cleared by CPU RESET, SYS RESET, or by setting the MEMORY FAULT switch to the CONT position.

#### **OVERRIDE MODE**

The OVERRIDE MODE portion of the control panel consists of the W. D. TIMER switch and the DECIMAL switch.

#### W.D. TIMER

When the W. D. TIMER (watchdog timer) switch is in the NORM position, the watchdog timer is operative; when the switch is in the OVERRIDE position, the watchdog timer is inactive.

#### DECIMAL

When the DECIMAL switch is in the OVERRIDE position, the decimal unit appears nonexistent to the CPU. When the DECIMAL switch is in the NORM position, the switch is inactive. The switch is latching in both positions.

#### SCAN

The SCAN portion of the control panel consists of the MODE switch, SCAN light, MEMORY MODE switch, and START ADDR switch. These controls enable the operator to continuously cycle memory between selected lower and upper addresses at a rate simulating the faster CPU operation with memory. Only memory is affected. All the switches are active only when the COMPUTE switch is in the IDLE position. Homespace bias is suppressed during the scan operation.

Prior to using this feature, the MAP mode bit of the PSD must be reset.

The starting address (first address read or modified by the scan operation) is entered by using the START ADDR switch in conjunction with the SELECT ADDRESS switches, which are active only when the COMPUTE switch is in the IDLE position. Placing the START ADDR switch in the ENTER position enters the contents of the SELECT ADDRESS switches into an internal CPU register (P), which designates a starting address.

The upper address (the last address read or modified by the scan operation) is then set into the SELECT ADDRESS switches, and the ADDRESS STOP switch set to the MEM REF position.

The memory scan operation can be initiated by first placing the MEMORY MODE switch to DATA (for a store or display) or CLEAR (only for a store operation), then the MODE switch to STORE or DISPLAY. When this is performed, the scan operation starts continuously reading from or storing into consecutive memory locations, as a function of whether the MODE switch was set to DISPLAY or STORE, respectively. The scan operation begins with the starting address (set into P), and continues until the real memory address equals the value of the SELECT AD-DRESS switches. Then, if the ADDRESS STOP switch is set to MEM REF, the scan continues again from the starting address. If the ADDRESS STOP switch is in the NORM position, all memory will be scanned. The scan operation continues indefinitely in this manner until the MEMORY MODE switch is set to the NORM position, which forces the CPU to the IDLE state. The SCAN light is on during the memory scan operation.

During a store scan, if the MEMORY MODE switch is set to DATA, the contents of the DATA switches are written into memory. If the MEMORY MODE switch is set to CLEAR, the memory is cleared in the "operational" mode.

During a display scan, the MEMORY MODE switch must be in the DATA position. Data from memory is displayed on the DISPLAY lights when the display is selecting the CPU bus.

The MEMORY FAULT switch can be used during the scan to halt the operation on a memory parity error. At the time of the halt, the memory parity error light is on and the DISPLAY lights indicate the failing data when the display is selecting the CPU bus. CPU RESET will reset this condition.

## MODE

The MODE switch is effective only when the COMPUTE switch is in the IDLE position and the Control Mode switch is in the LOCAL MAINT position. This is a three-position switch, latching in the inactive center position and momentary in the DISPLAY and STORE positions where it initiates a memory scan operation in conjunction with the MEMORY MODE switch.

## MEMORY MODE

The MEMORY MODE switch is a three-position (all latching) switch, which must be set to either the DATA or CLEAR position, prior to setting the MODE switch to STORE or DIS-PLAY to start a scan operation. The memory scan operation is terminated when the MEMORY MODE switch is returned to NORM.

## START ADDR - LMS

The START ADDR switch is effective only when the COM-PUTE switch is in the IDLE position and the Control Mode switch is in the LOCAL MAINT position. This is a threeposition switch, latching in the center position where it is inactive. In the momentary ENTER position, it enters the state of the SELECT ADDRESS switches into an internal CPU register (P), which designates the starting address of the scan. In the momentary STAT 0 position, the contents of the SELECT ADDRESS switches determine the memory address of an LMS operation that performs a read status word zero without changing the memory status bits. The status word is returned to the DISPLAY indicators.

#### SCAN

The SCAN indicator is on during memory scan operations initiated by the MODE switch or the MEMORY CLEAR switch.

## EXT DIO

The EXT DIO (external direct input/output) switch controls the DIO interface directly from the PCP switches. This switch is active only when the COMPUTE switch is in the IDLE position.

When the EXT DIO switch is in the momentary RD (read direct) position, the least significant 16 switches of the SELECT ADDRESS switches directly control the DIO address lines. The read/write direct line on the DIO interface is set to indicate a read direct operation. The read direct operation is completed with the data response returned to the SNAP register.

The WD (write direct) position is also momentary. Operations in the WD position are the same as described above for the RD position, except that the contents of the DATA switches are sent on the DIO data lines, and the read/write direct line indicates a write direct operation.

The EXT DIO switch is inactive in the center position (latching).

## **OPERATING PROCEDURES**

### LOADING OPERATION

This section describes the procedures for initially loading programs into memory from certain peripheral units attached to an input/output processor (IOP) in the SIGMA 9 system. The computer operator may initiate a loading program from the processor control panel (with the Control Mode switch in the LOCAL MAINT or LOCAL NORM position).

## BOOTSTRAP LOADING PROGRAM

The LOAD switch and the UNIT ADDRESS switches prepare a SIGMA 9 computer for a load operation. When the LOAD switch is pressed, the following bootstrap program is stored in memory locations X'22' through X'2B':

| Locc<br>(Hex. ) | (Dec.) | Contents<br>(Hexadecimal) | Symbolic Form<br>of Instruction |  |  |  |  |
|-----------------|--------|---------------------------|---------------------------------|--|--|--|--|
| 22              | 34     | 22110029                  | LI, 1                           |  |  |  |  |
| 23              | 35     | 64100023                  | BDR, 1                          |  |  |  |  |
| 24              | 36     | 68000028                  | BCR, 0 40                       |  |  |  |  |
| 25              | 37     | 0000×××× <sup>†</sup>     |                                 |  |  |  |  |
| 26              | 38     | 220yy015 <sup>††</sup>    | LI, 0                           |  |  |  |  |
| 27              | 39     | CC000025                  | SIO, 0 *37                      |  |  |  |  |
| 28              | 40     | CD000025                  | TIO,0 *37                       |  |  |  |  |
| 29              | 41     | 69C00022                  | BCS, 12 34                      |  |  |  |  |
| 2A              | 42     | 02yy00A8 <sup>tt</sup>    |                                 |  |  |  |  |
| 2B              | 43     | 0E000058                  |                                 |  |  |  |  |

When the LOAD switch is pressed, the selected peripheral device is not activated and no other indicators or controls are affected; only memory is altered.

## LOAD PROCEDURE

To ensure correct loading operation, the following sequence should always be used to initiate the loading process:

- 1. Place the COMPUTE switch in the IDLE position.
- 2. Press the SYS RESET switch.
- 3. Set the UNIT ADDRESS switches to the address of the desired peripheral unit.
- 4. Press the LOAD switch.
- 5. Place the COMPUTE switch in the RUN position.

After the COMPUTE switch is placed in the RUN position, in step 5, the following actions occur:

- The first record on the selected peripheral device is read into memory locations X'2A' through X'3F'. (The previous contents of general register 0 are destroyed as a result of executing the bootstrap program in locations X'26' through X'29'.)
- 2. After the record has been read, the next instruction is taken from location X'2A' (provided that no error condition has been detected by the device or the IOP).
- 3. When the instruction in location X'2A' is executed, the unit device and device controller selected for loading 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'25'.

## LOAD OPERATION DETAILS

The first executed instruction of the bootstrap program (in location X'26') loads general register 0 with the doubleword address of the first I/O command doubleword. The I/O address for the SIO instruction in location X'27' is the 13 low-order bits of location X'25' (which have been set equal to the load unit address as a result of pressing the LOAD switch). During execution of the SIO instruction, general register 0 points to locations X'2A' and X'2B' as the first I/O command doubleword for the selected device. This command doubleword contains an order that instructs the selected peripheral device to read 88 (X'58') bytes into consecutive memory locations starting at word location X'2A' (byte location X'A8'). At the completion of the read operation, neither data chaining nor command chaining is called for in the I/O command doubleword. Also, the Suppress Incorrect Length flag is set to 1 so that an incorrect length indication will not be considered an error. (This means that no transmission error halt will result if the first record is either less than or greater than 88 bytes. If the record is greater than 88 bytes, only the first 88 bytes will be stored in memory.)

<sup>&</sup>lt;sup>r</sup>The x's in location X'25' represent the value of the UNIT ADDRESS switches at the time the LOAD switch is pressed. The values can range from X'0000' to X'1FFF'.

<sup>&</sup>lt;sup>tt</sup>The y's in locations X'26' and X'2A' represent the value of the Homespace bias at the time the LOAD switch is pressed. Homespace bias is loaded automatically (from Homespace bias switches) into bit positions 13 through 18 in X'26' and bit positions 10 through 15 in X'2A'.

After the SIO instruction has been executed, the computer 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'29' will cause a branch to X'22' (a LOAD IMMEDIATE instruction), if either CC1 or CC2 (or both) is set to 1. Execution of the LI instruction at X'22' loads a count of X'10029' into register 1. The following BDR instruction at X'23' uses this as a "delay" count before execution of the BCR instruction in X'24', which unconditionally branches to the TIO in X'28'. Sufficient delay is introduced between execution of consecutive TIO instructions when testing the IOP so that excessive interference with the IOP cannot occur. In normal operation, CC1 is reset to 0 and CC2 remains set to 1 until the device can accept another SIO instruction, at which time the next instruction will be taken from location X'2A'.

If a transmission error or equipment malfunction is detected by either the device or the IOP, the IOP instructs the device to halt and initiate an "unusual end" interrupt signal (as specified by the appropriate flags in the I/O command doubleword). The "unusual end" interrupt will be ignored, however, since all interrupt levels have been disarmed by pressing the SYS RESET/CLEAR switch prior to loading. The device will not accept another SIO while the device interrupt is pending and, therefore, 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 load procedure. If there is no I/O address recognition of the load unit, the SIO instruction will not cause any I/O action and CC1 will continue to be set to 1 by the SIO and TIO instructions thus causing the BCS instruction to branch.

## FETCHING AND STORING DATA

Note: In the following operations, it is assumed that control bits PSD 9 and PSD 40 are both 0. This ensures that the address designated by the SELECT ADDRESS switches will be the actual address of a memory location and not a virtual address

To fetch data from a memory location and display it:

- 1. Set COMPUTE switch to IDLE.
- 2. Set SELECT ADDRESS switches to desired address.
- 3. Depress DISPLAY switch to SELECT ADDR.

Contents of designated memory location will be displayed in the DISPLAY indicators.

To fetch and display data from successive memory locations:

- 1. Set COMPUTE switch to IDLE.
- 2. Set DATA switches to desired address.
- 3. Depress INSERT switch to PSW1.
- 4. Depress DISPLAY switch to INSTR ADDR.

Contents of first memory location will be displayed in the DISPLAY indicators.

5. Depress INSTR ADDR switch to INCRM.

Contents of successive memory locations will be displayed in the DISPLAY indicators for each depression of the INSTR ADDR switch.

To store data in a designated memory location:

- 1. Set COMPUTE switch to IDLE.
- 2. Set SELECT ADDRESS switches to desired address.
- 3. Set DATA switches to desired storage value.
- 4. Depress STORE switch to SELECT ADDR.

# APPENDIX A. REFERENCE TABLES

This appendix contains the following reference material:

Title

Standard Symbols and Codes

Standard 8-Bit Computer Codes (EBCDIC)

Standard 7-Bit Communication Codes (ANSCII)

Standard Symbol-Code Correspondences

Hexadecimal Arithmetic

Addition Table Multiplication Table Table of Powers of Sixteen10 Table of Powers of Ten16

Hexadecimal-Decimal Integer Conversion Table

Hexadecimal-Decimal Fraction Conversion Table

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

57-character set: uppercase letters, numerals, space, and & - / . < > ( ) + | \$ \* : ; , % # @ ' =

63-character set: same as above plus ¢ ! ?

89-character set: same as 63-character set plus lowercase letters

2. ANSCII

64-character set: uppercase letters, numerals, space, and ! " \$ % & ' ( ) \* + , -. /  $\setminus$  ; : = < > ? @ \_ [ ]

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 DEL (hybrid code SP is considered part of all 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)

| _                  |      |          |            |          |      |      |      |                       | Most           | Signif | icant | Digits |      |                |      |      |         |            |
|--------------------|------|----------|------------|----------|------|------|------|-----------------------|----------------|--------|-------|--------|------|----------------|------|------|---------|------------|
| ſ                  | Hexa | adecimal | 0          | 1        | 2    | 3    | 4    | 5                     | 6              | 7      | 8     | 9      | A    | B              | с    | D    | E       | F          |
|                    |      | Binary   | 0000       | 0001     | 0010 | 0011 | 0100 | 0101                  | 0110           | 0111   | 1000  | 1001   | 1010 | 1011           | 1100 | 1101 | 1110    | 1111       |
|                    | 0    | 0000     | NUL        | DLE      | ds   |      | SP   | &                     | -              |        |       |        |      |                |      |      |         | 0          |
|                    | 1    | 0001     | soh        | DC1      | 55   |      |      |                       | 1              |        | a     | j      |      | \ <b>'</b>     | A    | J    |         | 1          |
|                    | 2    | 0010     | STX        | DC2      | fs   |      |      |                       |                |        | ь     | k      | s    | { <sup>1</sup> | В    | к    | S       | 2          |
|                    | 3    | 0011     | ETX        | DC3      | si   |      |      |                       | <i>\///</i>    |        | с     | I      | t    | }'             | с    | L    | т       | 3          |
|                    | 4    | 0100     | EOT        | DC4      |      |      |      |                       |                |        | d     | m      | U    | ['             | D    | м    | υ       | 4          |
| 2                  | 5    | 0101     | нт         | LF<br>NL |      |      |      |                       | e assi         |        | e     | n      | v    | ינ             | E    | N    | v       | 5          |
| Digit              | 6    | 0110     | АСК        | SYN      |      |      |      |                       |                |        | f     | 0      | w    |                | F    | 0    | w       | 6          |
| cant               | 7    | 0111     | BEL        | ETB      |      |      |      |                       |                |        | g     | р      | ×    |                | G    | Р    | x       | 7          |
| Significant Digits | 8    | 1000     | E OM<br>BS | CAN      |      |      |      |                       |                |        | h     | ٩      | у    |                | н    | Q    | Y       | 8          |
| Least S            | 9    | 1001     | ENQ        | EM       |      |      |      |                       |                |        | i     | r      | z    |                | I    | R    | z       | 9          |
| ڐ                  | A    | 1010     | NAK        | SUB      |      |      | ¢ 2  | !                     | ~ <sup>1</sup> | :      |       |        |      |                |      |      |         |            |
|                    | в    | 1011     | VT         | ESC      |      |      |      | \$                    | ,              | #      |       |        |      |                |      |      |         |            |
|                    | с    | 1100     | FF         | FS       |      |      | <    | *                     | %              | @      |       |        |      |                | Wil  |      | be assi |            |
|                    | D    | 1101     | CR         | GS       |      |      | (    | )                     | _              | •      |       |        |      |                |      |      |         |            |
|                    | E    | 1110     | so         | RS       |      |      | +    | ;                     | >              | =      |       |        |      |                |      |      |         | <i>\//</i> |
|                    | F    | 1111     | SI         | US       |      |      | 2    | <b>-</b> <sup>2</sup> | ?              | "      | 1     |        |      |                |      |      | V///    | DEL        |
|                    |      |          | <u> </u>   | 3        | ,    | -    | -    |                       | · ·            |        |       |        | 5    |                | ,    |      |         |            |

#### NOTES:

- The characters ^ \ { } [ ] 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 ∉ | → appear in the 63- and 89-character EBCDIC sets but not in either of the ANSCII-based sets. However, Xerox software translates the characters c into ANSCII characters as follows:

| EBCDIC | = | ANSCII         |
|--------|---|----------------|
| ¢      |   | <b>`</b> (6-0) |
| I      |   | (7-12)         |
| -      |   | ~ (7-14)       |

- 3 The EBCDIC control codes in columns 0 and 1 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.

# STANDARD 7-BIT COMMUNICATION CODES (ANSCII)<sup>1</sup>

|--|

- 1 Most significant bit, added for 8-bit format, is either 0 or even parity.
- 2 Columns 0-1 are control codes.
- 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

| ^ | is | t   | (5-14)             |
|---|----|-----|--------------------|
| _ | is | -   | (5-15)             |
| ~ | is | ESC | or ALTMODE control |

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  $\uparrow$  as  $\Lambda$ .)

(7-14)

5 On the Xerox 7670 Remote Batch Terminal, the symbol

| 1 | is | 1 | (2-1)  |
|---|----|---|--------|
| ſ | is | ¢ | (5-11) |
| ] | is | ! | (5-13) |
| ^ | is | - | (5-14) |

and none of the symbols appearing in columns 6–7 are provided. Except for the four symbol differences noted above, therefore, this terminal provides all the characters in the 64– character ANSCII set.

|                          |              |          |          |      | Most | Signit | icant | Digits         |      |      |
|--------------------------|--------------|----------|----------|------|------|--------|-------|----------------|------|------|
|                          | Dec<br>(rows |          | 0        | 1    | 2    | 3      | 4     | 5              | 6    | 7    |
|                          | Ļ            | Binary 1 | ×000     | ×001 | ×010 | ×011   | ×100  | ×101           | ×110 | ×111 |
|                          | 0            | 0000     | NUL      | DLE  | SP   | 0      | @     | Р              | ١    | р    |
|                          | 1            | 0001     | soh      | DC1  | 1 5  | 1      | A     | Q              | a    | 9    |
|                          | 2            | 0010     | STX      | DC 2 | "    | 2      | В     | R              | Ь    | r    |
|                          | 3            | 0011     | ETX      | DC3  | #    | 3      | с     | S              | с    | s    |
|                          | 4            | 0100     | EOT      | DC4  | \$   | 4      | D     | T              | d    | t    |
| s                        | 5            | 0101     | ENQ      | NAK  | %    | 5      | E     | υ              | e    | υ    |
| Least Significant Digits | 6            | 0110     | АСК      | SYN  | 8    | 6      | F     | v              | f    | v    |
| icant                    | 7            | 0111     | BEL      | ETB  | •    | 7      | G     | w              | g    | ~    |
| Signif                   | 8            | 1000     | BS       | CAN  | (    | 8      | н     | x              | h    | ×    |
| east                     | 9            | 1001     | нт       | EM   | )    | 9      | 1     | Y              | i    | у    |
| -                        | 10           | 1010     | LF<br>NL | SUB  | *    | :      | L     | z              | j    | z    |
|                          | 11           | 1011     | ∨т       | ESC  | +    | ;      | к     | [ 5            | k    | {    |
|                          | 12           | 1100     | FF       | FS   | ,    | <      | L     | $\backslash$   | I    | ł    |
|                          | 13           | 1101     | CR       | GS   | -    | =      | м     | ] <sup>5</sup> | m    | }    |
|                          | 14           | 1110     | so       | RS   |      | >      | И     | 4~5            | n    | ~ 4  |
|                          | 15           | 1111     | SI       | US   | /    | ?      | 0     | -4             | 0    | DEL  |
|                          |              |          | _        | ž    |      |        |       | 3              |      |      |

Most Significant Digits

٢

# STANDARD SYMBOL-CODE CORRESPONDENCES

|                  | DIC      | Sumbal                            | Card Code            | ANSCII <sup>tt</sup> | Moories                              | Remarks                                 |
|------------------|----------|-----------------------------------|----------------------|----------------------|--------------------------------------|-----------------------------------------|
| Hex.             | Dec.     | Symbol                            |                      |                      | Meaning                              |                                         |
| 00<br>01         | 0        | NUL<br>SOH                        | 12-0-9-8-1<br>12-9-1 | 0-0<br>0-1           | null<br>start of header              | 00 through 23 and 2F are control codes. |
| 02               | 2        | STX                               | 12-9-2               | 0-2                  | start of text                        |                                         |
| 03               | 3        | ETX                               | 12-9-3               | 0-3                  | end of text                          |                                         |
| 04               | 4        | EOT                               | 12-9-4               | 0-4                  | end of transmission                  |                                         |
| 05               | 5        | нт                                | 12-9-5               | 0-9                  | horizontal tab                       |                                         |
| 06               | 6        | ACK                               | 12-9-6               | 0-6                  | acknowledge (positive)               |                                         |
| 07               | 7        | BEL                               | 12-9-7               | 0-7                  | bell                                 |                                         |
| 08               | 8        | BS or EOM                         | 12-9-8               | 0-8                  | backspace or end of message          | EOM is used only on Xerox Keyboard/     |
| 09               | 9        | ENQ                               | 12-9-8-1             | 0-5                  | enquiry                              | Printers Models 7012, 7020, 8091,       |
| 0A               | 10       | NAK<br>VT                         | 12-9-8-2<br>12-9-8-3 | 1-5<br>0-11          | negative acknowledge<br>vertical tab | and 8092.                               |
| OB<br>OC         | 11<br>12 | FF                                | 12-9-8-4             | 0-12                 | form feed                            |                                         |
| 0D               | 13       | CR                                | 12-9-8-5             | 0-12                 | carriage return                      |                                         |
| OE               | 14       | so                                | 12-9-8-6             | 0-14                 | shift out                            |                                         |
| OF               | 15       | SI                                | 12-9-8-7             | 0-15                 | shift in                             |                                         |
| 10               | 16       | DLE                               | 12-11-9-8-1          | 1-0                  | data link escape                     |                                         |
| 11               | 17       | DC1                               | 11-9-1               | 1-1                  | device control 1                     |                                         |
| 12               | 18       | DC2                               | 11-9-2               | 1-2                  | device control 2                     |                                         |
| 13               | 19       | DC3                               | 11-9-3               | 1-3                  | device control 3                     |                                         |
| 14               | 20       | DC4                               | 11-9-4               | 1-4                  | device control 4                     |                                         |
| 15               | 21       | LF or NL                          | 11-9-5               | 0-10                 | line feed or new line                |                                         |
| 16               | 22       | SYN                               | 11-9-6               | 1-6                  | sync                                 |                                         |
| 17               | 23       | ETB                               | 11-9-7               | 1-7                  | end of transmission block            |                                         |
| 18               | 24       | CAN                               | 11-9-8               | 1-8                  | cancel                               |                                         |
| 19               | 25       | EM                                | 11-9-8-1             | 1-9                  | end of medium                        |                                         |
| 1A<br>1B         | 26<br>27 | SUB<br>ESC                        | 11-9-8-2             | 1-10<br>1-11         | substitute                           | Replaces characters with parity error.  |
| 10               | 28       | FS                                | 11-9-8-4             | 1-12                 | escape<br>file separator             |                                         |
| 10               | 29       | GS                                | 11-9-8-5             | 1-13                 | group separator                      |                                         |
| 1E               | 30       | RS                                | 11-9-8-6             | 1-14                 | record separator                     |                                         |
| 1F               | 31       | US                                | 11-9-8-7             | 1-15                 | unit separator                       |                                         |
| 20               | 32       | ds                                | 11-0-9-8-1           |                      | digit selector                       | 20 through 23 are used with             |
| 21               | 33       | 55                                | 0-9-1                |                      | significance start                   | Sigma EDIT BYTE STRING (EBS)            |
| 22               | 34       | fs                                | 0-9-2                |                      | field separation                     | instruction - not input/output con-     |
| 23               | 35       | si                                | 0-9-3                |                      | immediate significance start         | trol codes.                             |
| 24               | 36       |                                   | 0-9-4                |                      |                                      | 24 through 2E are unassigned.           |
| 25               | 37       |                                   | 0-9-5                |                      |                                      |                                         |
| 26<br>27         | 38<br>39 |                                   | 0-9-6<br>0-9-7       |                      |                                      |                                         |
| 27               | 40       |                                   | 0-9-9                |                      |                                      |                                         |
| 29               | 41       |                                   | 0-9-8-1              |                      |                                      |                                         |
| 2A               | 42       |                                   | 0-9-8-2              |                      |                                      |                                         |
| 2B               | 43       |                                   | 0-9-8-3              |                      |                                      |                                         |
| 2C               | 44       |                                   | 0-9-8-4              |                      |                                      |                                         |
| 2D               | 45       |                                   | 0-9-8-5              |                      |                                      |                                         |
| 2E               | 46       |                                   | 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<br>34         | 51<br>52 |                                   | 9-3                  |                      |                                      |                                         |
| 34               | 52       |                                   | 9-4<br>9-5           |                      |                                      |                                         |
| 36               | 54       |                                   | 9-6                  | l                    |                                      |                                         |
| 37               | 55       |                                   | 9-7                  |                      |                                      |                                         |
| 38               | 56       |                                   | 9-8                  |                      |                                      |                                         |
| 39               | 57       |                                   | 9-8-1                |                      |                                      |                                         |
| 3A               | 58       |                                   | 9-8-2                |                      |                                      |                                         |
| 3B               | 59       |                                   | 9-8-3                |                      |                                      |                                         |
| 3C               | 60       |                                   | 9-8-4                |                      |                                      |                                         |
| 3D               | 61       |                                   | 9-8-5                |                      |                                      |                                         |
| 3E<br>3F         | 62<br>63 |                                   | 9-8-6<br>9-8-7       |                      |                                      |                                         |
| t <sub>Hex</sub> | adecir   | nal and decima<br>notation (colun | I notation.          | L                    | L                                    | 4                                       |

## STANDARD SYMBOL-CODE CORRESPONDENCES (cont.)

| EBCDIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | C <sup>†</sup> Symbol                                                                                                                                                                                                    | Card Code                                                                                                                                                                        | ANSCII                                            | Meaning                                                                                                        | Remarks                                                                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Dec.                                                                                                                                                                                                                     | Cala Code                                                                                                                                                                        | ANJOI                                             | Medning                                                                                                        | Remarks                                                                                                                                                                                                                                                        |
| 41       6         42       6         43       6         44       6         45       6         46       7         47       7         48       7         49       7         48       7         48       7         48       7         48       7         40       7         42       40         42       7         42       7         44       7         45       6         46       7         47       7         48       7         44       7         45       7         46       7         47       7         48       7         40       7         42       7         42       7         44       7         45       7         46       7         47       7         48       7         49       7         40       7         42 <t< td=""><td>64 SP<br/>65<br/>66<br/>67<br/>68<br/>69<br/>70<br/>71<br/>72<br/>73<br/>74 ∉ or `<br/>75<br/>76 &lt;<br/>77<br/>(<br/>78 +<br/>79   or ¦</td><td>blank<br/>12-0-9-1<br/>12-0-9-2<br/>12-0-9-3<br/>12-0-9-4<br/>12-0-9-5<br/>12-0-9-7<br/>12-0-9-7<br/>12-0-9-8<br/>12-8-1<br/>12-8-2<br/>12-8-3<br/>12-8-4<br/>12-8-5<br/>12-8-6<br/>12-8-7</td><td>2-0<br/>6-0<br/>2-14<br/>3-12<br/>2-8<br/>2-11<br/>7-12</td><td>blank<br/>cent or accent grave<br/>period<br/>less than<br/>left parenthesis<br/>plus<br/>vertical bar or broken bar</td><td><ul> <li>41 through 49 will not be assigned.</li> <li>Accent grave used for left single quote. On model 7670, <sup>1</sup> not available, and ∉ = ANSCII 5-11.</li> <li>On Model 7670, <sup>1</sup>/<sub>1</sub> not available, and I = ANSCII 2-1.</li> </ul></td></t<> | 64 SP<br>65<br>66<br>67<br>68<br>69<br>70<br>71<br>72<br>73<br>74 ∉ or `<br>75<br>76 <<br>77<br>(<br>78 +<br>79   or ¦                                                                                                   | blank<br>12-0-9-1<br>12-0-9-2<br>12-0-9-3<br>12-0-9-4<br>12-0-9-5<br>12-0-9-7<br>12-0-9-7<br>12-0-9-8<br>12-8-1<br>12-8-2<br>12-8-3<br>12-8-4<br>12-8-5<br>12-8-6<br>12-8-7      | 2-0<br>6-0<br>2-14<br>3-12<br>2-8<br>2-11<br>7-12 | blank<br>cent or accent grave<br>period<br>less than<br>left parenthesis<br>plus<br>vertical bar or broken bar | <ul> <li>41 through 49 will not be assigned.</li> <li>Accent grave used for left single quote. On model 7670, <sup>1</sup> not available, and ∉ = ANSCII 5-11.</li> <li>On Model 7670, <sup>1</sup>/<sub>1</sub> not available, and I = ANSCII 2-1.</li> </ul> |
| 51         8           52         8           53         8           54         8           55         8           56         8           57         8           58         8           59         8           5A         9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 30         &           31         32           33         34           35         36           36         37           38         39           20         !                                                              | 12<br>12-11-9-1<br>12-11-9-2<br>12-11-9-3<br>12-11-9-4<br>12-11-9-5<br>12-11-9-6<br>12-11-9-7<br>12-11-9-8<br>11-8-1<br>11-8-2                                                   | 2-6                                               | ampersand<br>exclamation point                                                                                 | 51 through 59 will not be assigned.<br>On Model 7670, ! is 1.                                                                                                                                                                                                  |
| 5C 9<br>5D 9<br>5E 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 21 \$<br>22 *<br>23 )<br>24 ;<br>25 ~ or ¬                                                                                                                                                                               | 11-8-3<br>11-8-4<br>11-8-5<br>11-8-6<br>11-8-7                                                                                                                                   | 2-4<br>2-10<br>2-9<br>3-11<br>7-14                | dollars<br>asterisk<br>right parenthesis<br>semicolon<br>tilde or logical not                                  | On Model 7670, ~ is not available,<br>and $\neg = ANSCII 5-14$ .                                                                                                                                                                                               |
| 60         9.           61         9.           62         9.           63         9.           64         10.           65         10.           66         10.           67         10.           68         10.           69         10.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 77 /<br>78 /<br>79 /<br>70 /<br>71 /<br>72 /<br>73 /<br>74 /                                                                                                                                                             | 11<br>0-1<br>11-0-9-2<br>11-0-9-3<br>11-0-9-4<br>11-0-9-5<br>11-0-9-6<br>11-0-9-7<br>11-0-9-8<br>0-8-1                                                                           | 2-13<br>2-15                                      | minus, dash, hyphen<br>slash                                                                                   | 62 through 69 will not be assigned.                                                                                                                                                                                                                            |
| 6A 10<br>6B 10<br>6C 10<br>6D 10<br>6E 11<br>6F 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 06 ~ ,<br>07 , ,<br>08 %<br>09                                                                                                                                                                                           | 12-11<br>0-8-3<br>0-8-4<br>0-8-5<br>0-8-5<br>0-8-6<br>0-8-7                                                                                                                      | 5-14<br>2-12<br>2-5<br>5-15<br>3-14<br>3-15       | circumflex<br>comma<br>percent<br>underline<br>greater than<br>question mark                                   | On Model 7670 ^ is ¬. On Model<br>7015 ^ is ∧ (caret).<br>Underline is sometimes called "break<br>character"; may be printed along<br>bottom of character line.                                                                                                |
| 70         11;           71         11;           72         11;           73         11;           74         11;           75         11;           76         11;           77         11;           78         12;           78         12;           7C         12;           7D         12;           7F         12;           7F         12;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3<br>4<br>5<br>6<br>7<br>8<br>9<br>9<br>0<br>0<br>11<br>22 :<br>3<br>4<br>4<br>25 :<br>6<br>6<br>=<br>7<br>7<br>4<br>4<br>27 :<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7 | 12-11-0<br>12-11-0-9-1<br>12-11-0-9-2<br>12-11-0-9-3<br>12-11-0-9-4<br>12-11-0-9-5<br>12-11-0-9-6<br>12-11-0-9-7<br>12-11-0-9-8<br>8-1<br>8-2<br>8-3<br>8-4<br>8-5<br>8-6<br>8-7 | 3-10<br>2-3<br>4-0<br>2-7<br>3-13<br>2-2          | colon<br>number<br>at<br>apostrophe (right single quote)<br>equals<br>quotation mark                           | 70 through 79 will not be assigned.                                                                                                                                                                                                                            |
| <sup>t</sup> Hexade<br><sup>tt</sup> Decim                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ecimal and decim<br>nal notation (colu                                                                                                                                                                                   | al notation.<br>mn-row).                                                                                                                                                         |                                                   |                                                                                                                |                                                                                                                                                                                                                                                                |

|      |                  |        | STANDA    | rd symbol-           | CODE CORRESPON | DENCES (cont.)                   |
|------|------------------|--------|-----------|----------------------|----------------|----------------------------------|
| EBC  | DIC <sup>†</sup> |        |           |                      |                |                                  |
| Hex. | Dec.             | Symbol | Card Code | ANSCII <sup>tt</sup> | Meaning        | Remarks                          |
| 80   | 128              |        | 12-0-8-1  |                      | 1              | 80 is unassigned.                |
| 81   | 129              | a      | 12-0-1    | 6-1                  |                | 81-89, 91-99, A2-A9 comprise the |
| 82   | 130              | Ь      | 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              | g      | 12-0-7    | 6-7                  |                |                                  |
| 88   | 136              | ĥ      | 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  |                      |                |                                  |
| 8C   | 140              |        | 12-0-8-4  |                      |                |                                  |

84 85 86 87 88 89 8A 8B 8C 141 8D 12-0-8-5 12-0-8-6 8E 142 8F 143 12-0-8-7 90 144 12-11-8-1 91 145 12-11-1 6-10 j 92 146 k 12-11-2 6-11 93 147 T 12-11-3 6-12 94 12-11-4 6-13 148 m 95 149 n 12-11-5 6-14 96 150 12-11-6 6-15 0 97 12-11-7 7-0 151 р 98 152 12-11-8 7-1 q 99 7-2 153 12-11-9 r 9A 12-11-8-2 154 9A through A1 are unassigned. 9B 155 12-11-8-3 9C 12-11-8-4 156 12-11-8-5 9D 157 9E 12-11-8-6 158 12-11-8-7 9F 159 A0 160 11-0-8-1 A1 161 11-0-1 A2 162 11-0-2 7-3 7-4 7-5 7-6 7-7 7-8 s 11-0-3 Α3 163 t A4 164 11-0-4 υ A5 165 11-0-5 v 11-0-6 A6 166 w Α7 167 11-0-7 х 7-9 A8 168 11-0-8 У 7-10 Α9 169 z 11-0-9 170 11-0-8-2 AA AA through BO are unassigned. AB 171 11-0-8-3 AC 172 11-0-8-4 11-0-8-5 AD 173 11-0-8-6 AE 174 AF 175 11-0-8-7 176 BO 12-11-0-8-1 Bl 177 12-11-0-1 5-12 backslash 178 12-11-0-2 7-11 left brace B2 B3 179 12-11-0-3 7-13 right brace On Model 7670, [ is ¢. On Model 7670, ] is !. 180 B4 12-11-0-4 5-11 left bracket B5 181 12-11-0-5 5-13 right bracket 182 12-11-0-6 B6 through BF are unassigned. **B**6 183 12-11-0-7 **B**7 **B**8 184 12-11-0-8 12-11-0-9 B9 185 12-11-0-8-2 ΒA 186 BB 187 12-11-0-8-3 12-11-0-8-4 188 BC BD 189 12-11-0-8-5 190 12-11-0-8-6 BE 12-11-0-8-7 191 BF <sup>†</sup>Hexadecimal and decimal notation. <sup>tt</sup>Decimal notation (column-row).

# STANDARD SYMBOL-CODE CORRESPONDENCES (cont.)

~

|                                                     | 12-0                                                                                                                                                             |                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A<br>B<br>C<br>D<br>E<br>F<br>G<br>H<br>I           | 12-0<br>12-1<br>12-2<br>12-3<br>12-4<br>12-5<br>12-6<br>12-7<br>12-8<br>12-9<br>12-0-9-8-2<br>12-0-9-8-3<br>12-0-9-8-3<br>12-0-9-8-5<br>12-0-9-8-6<br>12-0-9-8-7 | 4-1<br>4-2<br>4-3<br>4-4<br>4-5<br>4-6<br>4-7<br>4-8<br>4-9        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | C0 is unassigned.<br>C1-C9, D1-D9, E2-E9 comprise the<br>uppercase alphabet.<br>CA through CF will not be assigned.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| J K L M N O P Q R                                   | 11-0<br>11-1<br>11-2<br>11-3<br>11-4<br>11-5<br>11-6<br>11-7<br>11-8<br>11-9<br>12-11-9-8-3<br>12-11-9-8-4<br>12-11-9-8-5<br>12-11-9-8-6<br>12-11-9-8-7          | 4-10<br>4-11<br>4-12<br>4-13<br>4-14<br>4-15<br>5-0<br>5-1<br>5-2  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | D0 is unassigned.<br>DA through DF will not be assigned.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| S<br>T<br>V<br>W<br>X<br>Y<br>Z                     | 0-8-2<br>11-0-9-1<br>0-2<br>0-3<br>0-4<br>0-5<br>0-6<br>0-7<br>0-8<br>0-9<br>11-0-9-8-2<br>11-0-9-8-3<br>11-0-9-8-4<br>11-0-9-8-5<br>11-0-9-8-6<br>11-0-9-8-7    | 5-3<br>5-4<br>5-5<br>5-6<br>5-7<br>5-8<br>5-9<br>5-10              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | EO, E1 are unassigned.<br>EA through EF will not be assigned.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>9 | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>12-11-0-9-8-2<br>12-11-0-9-8-3<br>12-11-0-9-8-4<br>12-11-0-9-8-5<br>12-11-0-9-8-6<br>12-11-0-9-8-7             | 3-0<br>3-1<br>3-2<br>3-3<br>3-4<br>3-5<br>3-6<br>3-7<br>3-8<br>3-9 | delete                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | FA through FE will not be assigned.<br>Special — neither graphic nor con-<br>trol symbol.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                     | BCDEFGHI<br>JKLMNOPQR<br>0123456789                                                                                                                              | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$              | B         12-2         4-2           C         12-3         4-3           D         12-4         4-4           E         12-5         4-5           F         12-6         4-6           G         12-7         4-7           H         12-9         4-9           12-0-9-8-3         12-0-9-8-4         12-0-9-8-5           12-0-9-8-6         12-0-9-8-6         12-0-9-8-6           12-0-9-8-7         11-0         4-10           K         11-2         4-11           L         11-3         4-12           M         11-4         4-13           N         11-5         4-14           O         11-6         4-15           P         11-7         5-0           Q         11-8         5-1           R         11-9         5-2           12-11-9-8-3         12-11-9-8-3           12-11-9-8-4         12-11-9-8-5           12-11-9-8-5         5-4           U         0-4         5-5           V         0-5         5-6           W         0-6         5-7           X         0-7         5- | B       12-2       4-2         C       12-3       4-3         D       12-4       4-4         E       12-5       4-5         F       12-6       4-6         G       12-7       4-7         H       12-8       4-8         I       12-9       4-9         12-0-9-8-3       12-0-9-8-4         12-0-9-8-4       12-0-9-8-5         12-0-9-8-7       4-9         12-0-9-8-7       4-9         12-0-9-8-7       4-9         12-0-9-8-7       4-9         12-0-9-8-7       4-10         K       11-2       4-11         L       11-3       4-12         M       11-4       4-13         N       11-5       4-14         O       11-6       4-15         P       11-7       5-0         Q       11-8       5-1         R       11-9       5-2         12-11-9-8-3       12-11-9-8-4         12-11-9-8-4       12-11-9-8-5         12-11-9-8-5       12-11-9-8-5         V       0-5       5-6         W       0-6       5-7 |

# HEXADECIMAL ARITHMETIC

## ADDITION TABLE

| 0 | 1  | 2  | 3  | 4  | 5  | 6  | 7  | . 8 | 9  | A  | В  | с  | D  | E  | F  |
|---|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
| 1 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09  | 0A | OB | 0C | 0D | 0E | 0F | 10 |
| 2 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 0A  | OB | 0C | 0D | 0E | 0F | 10 | 11 |
| 3 | 04 | 05 | 06 | 07 | 08 | 09 | 0A | ОВ  | 0C | 0D | OE | 0F | 10 | 11 | 12 |
| 4 | 05 | 06 | 07 | 08 | 09 | 0A | ОВ | 0C  | 0D | OE | 0F | 10 | 11 | 12 | 13 |
| 5 | 06 | 07 | 08 | 09 | 0A | ОВ | 0C | 0D  | 0E | 0F | 10 | 11 | 12 | 13 | 14 |
| 6 | 07 | 08 | 09 | 0A | ОВ | 0C | 0D | OE  | 0F | 10 | 11 | 12 | 13 | 14 | 15 |
| 7 | 08 | 09 | 0A | ОВ | 0C | 0D | OE | 0F  | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
| 8 | 09 | 0A | OB | 0C | 0D | OE | OF | 10  | 11 | 12 | 13 | 14 | 15 | 16 | 17 |
| 9 | 0A | OB | 0C | 0D | OE | OF | 10 | 11  | 12 | 13 | 14 | 15 | 16 | 17 | 18 |
| A | OB | 0C | 0D | OE | 0F | 10 | 11 | 12  | 13 | 14 | 15 | 16 | 17 | 18 | 19 |
| В | 0C | 0D | OE | 0F | 10 | 11 | 12 | 13  | 14 | 15 | 16 | 17 | 18 | 19 | 1A |
| С | 0D | OE | 0F | 10 | 11 | 12 | 13 | 14  | 15 | 16 | 17 | 18 | 19 | 1A | 1B |
| D | OE | 0F | 10 | 11 | 12 | 13 | 14 | 15  | 16 | 17 | 18 | 19 | 1A | 1B | 1C |
| E | OF | 10 | 11 | 12 | 13 | 14 | 15 | 16  | 17 | 18 | 19 | 1A | 1B | 1C | ١D |
| F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17  | 18 | 19 | 1A | 1B | 1C | ١D | 1E |

## **MULTIPLICATION TABLE**

| 1 | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | A  | В  | С  | D  | E  | F  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 2 | 04 | 06 | 08 | 0A | 0C | OE | 10 | 12 | 14 | 16 | 18 | 1A | 1C | 1E |
| 3 | 06 | 09 | 0C | OF | 12 | 15 | 18 | 1B | ÎE | 21 | 24 | 27 | 2A | 2D |
| 4 | 08 | 0C | 10 | 14 | 18 | 1C | 20 | 24 | 28 | 2C | 30 | 34 | 38 | 3C |
| 5 | 0A | 0F | 14 | 19 | 1E | 23 | 28 | 2D | 32 | 37 | 3C | 41 | 46 | 4B |
| 6 | 0С | 12 | 18 | 1E | 24 | 2A | 30 | 36 | 3C | 42 | 48 | 4E | 54 | 5A |
| 7 | OE | 15 | 1C | 23 | 2A | 31 | 38 | 3F | 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 | 3F | 48 | 51 | 5A | 63 | 6C | 75 | 7E | 87 |
| A | 14 | 1E | 28 | 32 | 3C | 46 | 50 | 5A | 64 | 6E | 78 | 82 | 8C | 96 |
| В | 16 | 21 | 2C | 37 | 42 | 4D | 58 | 63 | 6E | 79 | 84 | 8F | 9A | A5 |
| с | 18 | 24 | 30 | 3C | 48 | 54 | 60 | 6C | 78 | 84 | 90 | 9C | A8 | В4 |
| D | 1A | 27 | 34 | 41 | 4E | 5B | 68 | 75 | 82 | 8F | 9C | A9 | B6 | C3 |
| E | 10 | 2A | 38 | 46 | 54 | 62 | 70 | 7E | 8C | 9A | A8 | B6 | C4 | D2 |
| F | 1E | 2D | 3C | 4B | 5A | 69 | 78 | 87 | 96 | A5 | B4 | С3 | D2 | El |

Appendix A 151

# TABLE OF POWERS OF SIXTEEN 10

|   |     |     |     |     |     | 16 <sup>n</sup> | n  |         |       | 16 <sup>-n</sup> |       |   |                   |
|---|-----|-----|-----|-----|-----|-----------------|----|---------|-------|------------------|-------|---|-------------------|
|   |     |     |     |     |     | ۱               | 0  | 0.10000 | 00000 | 00000            | 00000 | x | 10                |
|   |     |     |     |     |     | 16              | 1  | 0.62500 | 00000 | 00000            | 00000 | x | 10 <sup>-1</sup>  |
|   |     |     |     |     |     | 256             | 2  | 0.39062 | 50000 | 00000            | 00000 | x | 10-2              |
|   |     |     |     |     | 4   | 096             | 3  | 0.24414 | 06250 | 00000            | 00000 | x | 10 <sup>-3</sup>  |
|   |     |     |     |     | 65  | 536             | 4  | 0.15258 | 78906 | 25000            | 00000 | x | 10-4              |
|   |     |     |     | 1   | 048 | 576             | 5  | 0.95367 | 43164 | 06250            | 00000 | x | 10-6              |
|   |     |     |     | 16  | 777 | 216             | 6  | 0.59604 | 64477 | 53906            | 25000 | x | 10 <sup>-7</sup>  |
|   |     |     |     | 268 | 435 | 456             | 7  | 0.37252 | 90298 | 46191            | 40625 | x | 10 <sup>-8</sup>  |
|   |     |     | 4   | 294 | 967 | 296             | 8  | 0.23283 | 06436 | 53869            | 62891 | x | 10 <sup>-9</sup>  |
|   |     |     | 68  | 719 | 476 | 736             | 9  | 0.14551 | 91522 | 83668            | 51807 | x | 10 <sup>-10</sup> |
|   |     | 1   | 099 | 511 | 627 | 776             | 10 | 0.90949 | 47017 | 72928            | 23792 | x | 10 <sup>-12</sup> |
|   |     | 17  | 592 | 186 | 044 | 416             | 11 | 0.56843 | 41886 | 08080            | 14870 | x | 10 <sup>-13</sup> |
|   |     | 281 | 474 | 976 | 710 | 656             | 12 | 0.35527 | 13678 | 80050            | 09294 | x | 10 <sup>-14</sup> |
|   | 4   | 503 | 599 | 627 | 370 | 496             | 13 | 0.22204 | 46049 | 25031            | 30808 | x | 10 <sup>-15</sup> |
|   | 72  | 057 | 594 | 037 | 927 | 936             | 14 | 0.13877 | 78780 | 78144            | 56755 | x | 10-16             |
| 1 | 152 | 921 | 504 | 606 | 846 | 976             | 15 | 0.86736 | 17379 | 88403            | 54721 | × | 10 <sup>-18</sup> |

# TABLE OF POWERS OF TEN 16

|       |         |         |             |          |          | -       |         |         |   |                   |
|-------|---------|---------|-------------|----------|----------|---------|---------|---------|---|-------------------|
|       |         |         | <u>10</u> n | <u>n</u> |          | 10      | n       |         |   |                   |
|       |         |         | 1           | 0        | 1.0000   | 0000    | 0000    | 0000    |   |                   |
|       |         |         | А           | 1        | 0.1999   | 9999    | 9999    | 999A    |   |                   |
|       |         |         | 64          | 2        | 0.28F5   | C28F    | 5 C2 8  | F 5 C 3 | x | 16-1              |
|       |         |         | 3 E 8       | 3        | 0.4189   | 374B    | C6 A7   | E F 9 E | × | 16 <sup>-2</sup>  |
|       |         |         | 2710        | 4        | 0.68DB   | 8 B AC  | 710C    | B296    | x | 16 <sup>-3</sup>  |
|       |         | 1       | 86A0        | 5        | 0.A7C5   | AC47    | 1B47    | 8423    | x | 16-4              |
|       |         | F       | 4240        | 6        | 0.10C6   | F 7 A0  | B5ED    | 8 D3 7  | x | 16-4              |
|       |         | 98      | 9680        | 7        | 0.1 AD7  | F 2 9 A | BCAF    | 4858    | x | 16 <sup>-5</sup>  |
|       |         | 5 F 5   | E100        | 8        | 0.2 AF 3 | 1DC4    | 6118    | 7 3 B F | × | 16-6              |
|       |         | 3 B 9 A | CA00        | 9        | 0.44B8   | 2 F A0  | 9 B 5 A | 52CC    | × | 16 <sup>-7</sup>  |
|       | 2       | 540B    | E400        | 10       | 0.6 DF 3 | 7F67    | 5 E F 6 | E ADF   | × | 16 <sup>-8</sup>  |
|       | 17      | 4876    | E800        | 11       | 0.AFEB   | FFOB    | CB 2 4  | AAF F   | × | 16 <sup>-9</sup>  |
|       | E 8     | D4A5    | 1000        | 12       | 0.1197   | 9981    | 2 DE A  | 1119    | × | 16 <sup>-9</sup>  |
|       | 918     | 4 E 7 2 | A000        | 13       | 0.1C25   | C268    | 4976    | 81C2    | × | 16 <sup>-10</sup> |
|       | 5 AF 3  | 107A    | 4000        | 14       | 0.2 D0 9 | 370D    | 4257    | 3604    | x | 16-11             |
| 3     | 8 D7 E  | A4C6    | 8000        | 15       | 0.480E   | BE7B    | 9 D5 8  | 566D    | × | 16 <sup>-12</sup> |
| 23    | 86F2    | 6FC1    | 0000        | 16       | 0.734A   | CA5 F   | 6226    | FOAE    | × | 16 <sup>-13</sup> |
| 163   | 4578    | 5 D8 A  | 0000        | 17       | 0.B877   | AA3 2   | 36A4    | B449    | × | 16-14             |
| DE 0  | B 6 B 3 | A764    | 0000        | 18       | 0.1272   | 5 DD 1  | D243    | AB A 1  | × | 16-14             |
| 8 AC7 | 2304    | 89E8    | 0000        | 19       | 0.1 D8 3 | C94F    | B 6 D2  | AC35    | x | 16 <sup>-15</sup> |

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:

| ŀ | lexade           | cimal | Deci         | mal  | Hexad | lecimal    | Dec  | imal              |      |      |
|---|------------------|-------|--------------|------|-------|------------|------|-------------------|------|------|
|   | 01 000           |       | 4 (          | )96  | 20    | 000        | 1    | 31 072            |      |      |
|   | 02 000           |       | 8            | 92   | 30    | 000        | 1    | 96 608            |      |      |
|   | 03 000           |       | 12 2         | 288  | 40    | 000        | 2    | 62 144            |      | 2.   |
|   | 04 000           |       | 16 3         | 384  | 50    | 000        | 3    | 27 680            |      |      |
|   | 05 000           |       | 20 4         | 180  | 60    | 000        | 3    | 93 216            |      |      |
|   | 06 000           |       | 24 5         | 576  | 70    | 000        | 4    | 58 752            |      |      |
|   | 07 000           |       | 28 6         |      |       | 000        |      | 24 288            |      | 3.   |
|   | 08 000           |       | 32 7         |      |       | 000        |      | 89 824            |      |      |
|   | 09 000           |       | ° 36 8       |      |       | 000        |      | 55 360            |      |      |
|   | 000 AC           |       | 40 9         |      |       | 000        |      | 20 896            |      |      |
|   | OB 000           |       | 45 (         |      |       | 000        |      | 86 432            |      |      |
|   | OC 000           |       | 49           |      |       | 000        |      | 51 968            |      |      |
|   | DD 000           |       | 53 2         |      |       | 000        |      | 17 504            |      | Dec  |
|   | 0E 000           |       | 57 :         |      |       | 000        |      | 983 040           |      | by : |
|   | 0F 000           |       | 61 4         |      |       | 000        |      | 48 576            |      | Aft  |
|   | 10 000           |       | 65 5         |      |       | 000        |      | 97 152            |      | forr |
|   | 11 000           |       | 69 6         |      |       | 000        |      | 45 728            |      | hex  |
|   | 12 000           |       | 737          |      |       | 000        |      | 94 304            |      | use  |
|   | 13 000           |       | 77 8         |      |       | 000        |      | 42 880            |      | mus  |
|   | 14 000           |       | 81 9         |      |       | 000        |      | 91 456            |      | -    |
|   | 15 000           |       | 86 (         |      |       | 000        |      | 40 032            |      | Exa  |
|   | 16 000           |       | 90           |      |       | 000        |      | 888 608           |      |      |
|   | 17 000<br>18 000 |       | 94 :<br>98 : |      |       | 000<br>000 |      | 37 184<br>85 760  |      |      |
|   | 19 000           |       | 102 4        |      |       | 000        |      | i34 336           |      |      |
|   | IA 000           |       | 102 -        |      |       | 000        |      | 54 330<br>582 912 |      |      |
|   | 1B 000           |       | 110 3        |      |       | 000        |      | 31 488            |      |      |
|   | 1C 000           |       | 114 0        |      |       | 000        |      | 80 064            |      |      |
|   | 1D 000           |       | 1182         |      |       | 000        |      | 28 640            |      |      |
|   | 1E 000           |       | 122          |      | 1 000 |            |      | 77 216            |      |      |
|   | 1F 000           |       | 126          |      | 2 000 |            |      | 54 432            |      |      |
| _ |                  | 0     | 1            | 2    | 3     | 4          | 5    | 6                 | 7    |      |
|   | 000              | 0000  | 0001         | 0002 | 0003  | 0004       | 0005 | 0006              | 0007 | (    |
|   | 010              | 0016  | 0017         | 0018 | 0019  | 0020       | 0021 | 0022              | 0023 | (    |
|   | 020              | 0032  | 0033         | 0034 | 0035  | 0036       | 0037 | 0038              | 0039 | (    |
|   | 030              | 0048  | 0049         | 0050 | 0051  | 0052       | 0053 | 0054              | 0055 | (    |
|   | 040              | 0064  | 0065         | 0066 | 0067  | 0068       | 0069 | 0070              | 0071 | (    |
|   | 050              | 0080  | 0081         | 0082 | 0083  | 0084       | 0085 | 0086              | 0087 | (    |
|   | 060              | 0096  | 0097         | 0098 | 0099  | 0100       | 0101 | 0102              | 0103 | (    |
|   | 070              | 0112  | 0113         | 0114 | 0115  | 0116       | 0117 | 0118              | 0119 | (    |
|   | 080              | 0128  | 0129         | 0130 | 0131  | 0132       | 0133 | 0134              | 0135 | (    |
|   | 090              | 0144  | 0145         | 0146 | 0147  | 0148       | 0149 | 0150              | 0151 | (    |
|   | 0A0              | 0160  | 0161         | 0162 | 0163  | 0164       | 0165 | 0166              | 0167 | (    |
|   | OBO              | 0176  | 0177         | 0178 | 0179  | 0180       | 0181 | 0182              | 0183 |      |
|   | 0C0              | 0192  | 0193         | 0194 | 0195  | 0196       | 0197 | 0198              | 0199 |      |
|   | 000              | 0208  | 0209         | 0210 | 0211  | 0212       | 0213 | 0214              | 0215 |      |

Hexadecimal fractions may be converted to decimal fractions as follows:

 Express the hexadecimal fraction as an integer times 16<sup>-n</sup>, where n is the number of significant hexadecimal places to the right of the hexadecimal point.

2. Find the decimal equivalent of the hexadecimal integer

$$CA9 BF3_{16} = 13 278 195_{10}$$

3. Multiply the decimal equivalent by 16<sup>-n</sup>

Decimal fractions may be converted to hexadecimal fractions by successively multiplying the decimal fraction by 16<sub>10</sub>. After each multiplication, the integer portion is removed to form a hexadecimal fraction by building to the right of the hexadecimal point. However, since decimal arithmetic is used in this conversion, the integer portion of each product must be converted to hexadecimal numbers.

Example: Convert 0.89510 to its hexadecimal equivalent



|     |      |      |      |      |      |      | • • • • • • |      |      |      |      |      |      |      |      |      |
|-----|------|------|------|------|------|------|-------------|------|------|------|------|------|------|------|------|------|
|     | 0    | 1    | 2    | 3    | 4    | 5    | 6           | 7    | 8    | 9    | Α    | В    | С    | D    | E    | F    |
| 000 | 0000 | 0001 | 0002 | 0003 | 0004 | 0005 | 0006        | 0007 | 0008 | 0009 | 0010 | 0011 | 0012 | 0013 | 0014 | 0015 |
| 010 | 0016 | 0017 | 0018 | 0019 | 0020 | 0021 | 0022        | 0023 | 0024 | 0025 | 0026 | 0027 | 0028 | 0029 | 0030 | 0031 |
| 020 | 0032 | 0033 | 0034 | 0035 | 0036 | 0037 | 0038        | 0039 | 0040 | 0041 | 0042 | 0043 | 0044 | 0045 | 0046 | 0047 |
| 030 | 0048 | 0049 | 0050 | 0051 | 0052 | 0053 | 0054        | 0055 | 0056 | 0057 | 0058 | 0059 | 0060 | 0061 | 0062 | 0063 |
| 040 | 0064 | 0065 | 0066 | 0067 | 0068 | 0069 | 0070        | 0071 | 0072 | 0073 | 0074 | 0075 | 0076 | 0077 | 0078 | 0079 |
| 050 | 0080 | 0081 | 0082 | 0083 | 0084 | 0085 | 0086        | 0087 | 0088 | 0089 | 0090 | 0091 | 0092 | 0093 | 0094 | 0095 |
| 060 | 0096 | 0097 | 0098 | 0099 | 0100 | 0101 | 0102        | 0103 | 0104 | 0105 | 0106 | 0107 | 0108 | 0109 | 0110 | 0111 |
| 070 | 0112 | 0113 | 0114 | 0115 | 0116 | 0117 | 0118        | 0119 | 0120 | 0121 | 0122 | 0123 | 0124 | 0125 | 0126 | 0127 |
| 080 | 0128 | 0129 | 0130 | 0131 | 0132 | 0133 | 0134        | 0135 | 0136 | 0137 | 0138 | 0139 | 0140 | 0141 | 0142 | 0143 |
| 090 | 0144 | 0145 | 0146 | 0147 | 0148 | 0149 | 0150        | 0151 | 0152 | 0153 | 0154 | 0155 | 0156 | 0157 | 0158 | 0159 |
| 0A0 | 0160 | 0161 | 0162 | 0163 | 0164 | 0165 | 0166        | 0167 | 0168 | 0169 | 0170 | 0171 | 0172 | 0173 | 0174 | 0175 |
| OBO | 0176 | 0177 | 0178 | 0179 | 0180 | 0181 | 0182        | 0183 | 0184 | 0185 | 0186 | 0187 | 0188 | 0189 | 0190 | 0191 |
| 000 | 0192 | 0193 | 0194 | 0195 | 0196 | 0197 | 0198        | 0199 | 0200 | 0201 | 0202 | 0203 | 0204 | 0205 | 0206 | 0207 |
| 0D0 | 0208 | 0209 | 0210 | 0211 | 0212 | 0213 | 0214        | 0215 | 0216 | 0217 | 0218 | 0219 | 0220 | 0221 | 0222 | 0223 |
| OEO | 0224 | 0225 | 0226 | 0227 | 0228 | 0229 | 0230        | 0231 | 0232 | 0233 | 0234 | 0235 | 0236 | 0237 | 0238 | 0239 |
| 0F0 | 0240 | 0241 | 0242 | 0243 | 0244 | 0245 | 0246        | 0247 | 0248 | 0249 | 0250 | 0251 | 0252 | 0253 | 0254 | 0255 |
|     |      |      |      |      |      |      |             |      |      |      |      |      |      |      |      |      |

| r          |              |              |              |              |              |              |              |              |              |              |              |              |              |              |              |              |
|------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
|            | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | A            | В            | С            | 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        | 0448         | 0449         | 0450         | 0451<br>0467 | 0452         | 0453         | 0454         | 0455         | 0456         | 0457         | 0456         | 0459         | 0480         | 0401         | 0482         | 0483         |
| 1E0        | 0480         | 0481         | 0482         | 0487         | 0488         | 0485         | 0470         | 0471         | 0472         | 0473         | 0474         | 0473         | 0478         | 0477         | 0478         | 0495         |
| 1F0        | 0480         | 0497         | 0498         | 0483         | 0484         | 0485         | 0488         | 048/         | 0488         | 0407         | 0470         | 0507         | 0472         | 0509         | 0474         | 0475         |
|            |              |              |              | ····         |              |              |              |              |              |              |              |              |              |              |              |              |
| 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         |
| 0.40       | 0.57/        | 0577         | 0.570        | 0570         |              |              |              |              |              |              |              |              |              |              |              |              |
| 240        | 0576         | 0577         | 0578         | 0579         | 0580         | 0581         | 0582         | 0583         | 0584         | 0585         | 0586         | 0587         | 0588         | 0589         | 0590         | 0591         |
| 250<br>260 | 0592<br>0608 | 0593         | 0594<br>0610 | 0595         | 0596         | 0597         | 0598         | 0599         | 0600         | 0601         | 0602         | 0603         | 0604         | 0605         | 0606         | 0607         |
| 270        | 0608         | 0609<br>0625 | 0626         | 0611<br>0627 | 0612<br>0628 | 0613         | 0614         | 0615         | 0616         | 0617         | 0618         | 0619         | 0620         | 0621         | 0622         | 0623<br>0639 |
| 2/0        | 0024         | 0625         | 0020         | 0627         | 0028         | 0629         | 0630         | 0631         | 0632         | 0633         | 0634         | 0635         | 0636         | 0637         | 0638         | 0039         |
| 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         |
| 2B0        | 0688         | 0689         | 0690         | 0691         | 0692         | 0693         | 0694         | 0695         | 0696         | 0697         | 0698         | 0699         | 0700         | 0701         | 0702         | 0703         |
|            |              |              |              |              |              |              |              |              |              |              |              |              |              |              |              |              |
| 2C0        | 0704         | 0705         | 0706         | 0707         | 0708         | 0709         | 0710         | 0711         | 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         |
|            | 07/0         |              | 0770         |              | 0770         |              |              |              |              |              |              |              |              |              |              | 0700         |
| 300        | 0768<br>0784 | 0769<br>0785 | 0770<br>0786 | 0771<br>0787 | 0772         | 0773         | 0774         | 0775         | 0776         | 0777         | 0778         | 0779         | 0780         | 0781         | 0782         | 0783         |
| 310<br>320 | 0784         | 0/85         | 0786         | 0/8/<br>0803 | 0788<br>0804 | 0789<br>0805 | 0790<br>0806 | 0791<br>0807 | 0792<br>0808 | 0793         | 0794<br>0810 | 0795         | 0796         | 0797         | 0798         | 0799         |
| 320        | 0800         | 0801         | 0802         | 0803         | 0804         | 0805         | 0806         | 0807         | 0808         | 0809<br>0825 | 0810         | 0811<br>0827 | 0812<br>0828 | 0813<br>0829 | 0814<br>0830 | 0815<br>0831 |
|            | 0010         | 0017         | 0010         | 0017         | 0020         | 0021         | 0022         | 0023         | 0024         | 0025         | 0020         | 002/         | 0020         | 0029         | 0030         | 0031         |
| 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         |
| 3A0        | 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         |
| 3C0        | 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         | 0972         | 0973         | 0974         | 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         | 1000         | 1022         | 1023         |
| 1 - 1      |              |              |              |              |              |              |              |              |              |              |              | ,            | . 520        |              |              | .020         |

| 410         1040         1042         1043         1044         1045         1044         1045         1046         1047         1048         1049         1050         1050         1050         1050         1050         1050         1050         1050         1050         1050         1057         1077         1077         1077         1077         1077         1077         1077         1077         1077         1077         1077         1078         1077         1080         1081         1082         1083         1084         1085         1086         1087         1088         1087         1081         1010         1101         1112         1113         1114         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124         1124                                                                                                                                                                                              |     | 0    | 1    | 2    | 3    | 4    | 5    | 6    | 7    | 8    | 9    | A    | В    | с    | D    | E    | F    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| 420         1056         1057         1076         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1077         1078         1172         1131         1144         1145         1144         1144         1144         1144         1144         1144         1144         1144         1144         1144         1144         1143         1144         1145         1144         1145         1144         1145         1144         1145         1144         1145         1144         1145         1144         1145         1144         1145         1144         1145         1144         1145         1144         1144         1144         1144         1144         1144         1144         1144         1144         1144         1144         1144                                                                                                                                                                                              |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1039 |
| 430         1072         1074         1075         1076         1077         1078         1079         1080         1081         1082         1083         1084         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1085         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185         1185                                                                                                                                                                                              |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| 440         1088         1089         1090         1091         1092         1093         1094         1095         1096         1097         1098         1100         1101         1102         1102           450         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121         1121                                                                                                                                                                                             |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| 450       1104       1105       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108       1107       1108                                                                                                                                                                                                                                                                                 |     |      |      |      |      |      |      |      |      |      |      |      |      | 1004 | 1000 |      | 100/ |
| 440       1120       1121       1122       1123       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1124       1125       1125       1125       1125       1125       1125       1125       1125       1125       1125       1126       1127       1128       1129       1120       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121       1121                                                                                                                                                                                                                                                                                 |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1103 |
| 470       1136       1137       1138       1139       1140       1141       1142       1143       1144       1145       1144       1147       1148       1144       1150       1151         440       1168       1159       1170       1171       1172       1173       1174       1175       1176       1177       1178       1179       1178       1179       1178       1179       1174       1175       1176       1177       1178       1179       1180       1181       1182       1183       1184       1184       1184       1181       1182       1183       1184       1181       1181       1182       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181       1181 <t< td=""><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>1119</td></t<>                                                                                                              |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1119 |
| 480         1152         1153         1156         1157         1158         1159         1160         1161         1162         1164         1165         1166         1167           440         1163         1164         1163         1171         1172         1173         1174         1175         1176         1177         1178         1178         1178         1178         1178         1178         1178         1171         1172         1173         1174         1175         1176         1177         1178         1171         1171         1171         1171         1171         1171         1171         1171         1172         1173         1174         1175         1176         1177         1178         1174         1172         1173         1174         1172         1173         1174         1172         1173         1174         1175         1176         1171         1172         1173         1174         1175         1176         1172         1173         1174         1175         1176         1171         1171         1171         1171         1171         1171         1171         1171         1171         1171         1171         1171         1171         1171                                                                                                                                                                                             |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      | -    |      |
| 440       1168       1169       1170       1172       1173       1174       1175       1177       1179       1199       1190       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1191       1201       1211       1221       1220       1231       1221       1231       1241       1242       1243       1244       1245       1246       1247       1281       1281       1281       1281       1331       1331                                                                                                                                                                                                                                                                                 |     | 1100 | 110/ | 1100 | 1107 | 1140 | 1141 | 1142 | 1145 | 1144 | 1145 | 1140 | 1147 | 1140 | 1149 | 1150 | 1151 |
| 4A0       1184       1185       1187       1188       1189       1190       1191       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192       1192                                                                                                                                                                                                                                                                                 |     |      |      |      | 1155 | 1156 | 1157 | 1158 | 1159 | 1160 | 1161 | 1162 | 1163 | 1164 | 1165 | 1166 | 1167 |
| 480         1200         1201         1202         1203         1204         1205         1206         1207         1208         1209         1211         1212         1213         1214         1215           4C0         1216         1217         1218         1219         1220         1221         1222         1223         1224         1224         1225         1226         1227         1228         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1224         1231         1231         1231         1231         1231         1231         1231         1231         1231         1232         1231         1232         1232         1332         1332         1332         1332         1333                                                                                                                                                                                             |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1183 |
| 4C0         1216         1217         1218         1219         1220         1221         1222         1222         1224         1225         1226         1227         1228         1229         1230         1231         1241         1241         1242         1241         1241         1241         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1244         1242         1241         1242         1242         1242         1242         1242         1242         1242         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241         1241                                                                                                                                                                                              |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1199 |
| 400       1232       1233       1234       1235       1236       1237       1238       1239       1240       1241       1242       1243       1244       1245       1246       1241       1242       1243       1244       1245       1246       1241       1242       1243       1244       1245       1246       1246       1246       1246       1246       1246       1242       1243       1244       1242       1243       1244       1242       1243       1244       1245       1246       1246       1246       1247       1272       1271       1271       1271       1271       1271       1271       1271       1274       1275       1276       1277       1278       1279       1231       1314       1315       1316       1317       1318       1319       1320       1321       1323       1324       1324       1324       1324       1324       1324       1324       1324       1324       1324       1324       1324       1335       1335       1335       1335       1336       1337       1388       1389       1338       1335       1336       1337       1374       1374       1374       1374       1374       1374                                                                                                                                                                                                                                                                                 | 400 | 1200 | 1201 | 1202 | 1203 | 1204 | 1205 | 1200 | 1207 | 1208 | 1209 | 1210 | 1211 | 1212 | 1213 | 1214 | 1215 |
| 400       1232       1233       1234       1235       1237       1238       1239       1240       1241       1242       1243       1244       1244       1244       1244       1244       1244       1244       1244       1244       1244       1244       1244       1244       1245       1260       1261       1262       1251       1254       1257       1257       1257       1257       1257       1257       1277       1278       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279       1279                                                                                                                                                                                                                                                                                 |     | 1216 | 1217 | 1218 | 1219 | 1220 | 1221 | 1222 | 1223 | 1224 | 1225 | 1226 | 1227 | 1228 | 1229 | 1230 | 1231 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |      |      |      |      |      |      |      |      |      |      |      |      | 1244 | 1245 |      | 1247 |
| 500         1280         1281         1282         1281         1282         1281         1282         1281         1282         1281         1291         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1292         1291         1292         1291         1292         1292         1292         1292         1292         1292         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1292         1291         1291         1292         1291         1292         1291         1291         1291         1291         1292         1291         1291         1292         1291         1291         1292         1291         1291         1291         1291         1291         1291                                                                                                                                                                                              |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1263 |
| 510       1296       1297       1298       1299       1300       1301       1302       1303       1304       1305       1306       1307       1308       1307       1308       1307       1308       1307       1308       1307       1308       1307       1308       1307       1308       1307       1321       1322       1323       1324       1322       1324       1322       1324       1322       1324       1322       1324       1322       1324       1321       1321       1321       1321       1321       1321       1321       1321       1322       1324       1321       1321       1321       1321       1321       1321       1321       1321       1321       1321       1321       1321       1321       1331       1321       1331       1321       1331       1321       1331       1321       1332       1333       1334       1337       1371       1371       1371       1371       1372       1373       1374       1374       1374       1374       1374       1374       1375       1388       1389       1380       1381       1382       1383       1384       1384       1384       1384       1431       1440                                                                                                                                                                                                                                                                                 | 4r0 | 1204 | 1205 | 1200 | 1207 | 1208 | 1209 | 12/0 | 1271 | 12/2 | 12/3 | 12/4 | 12/5 | 1276 | 1277 | 1278 | 1279 |
| 510       1296       1297       1298       1297       1298       1297       1308       1301       1302       1303       1304       1305       1304       1305       1302       1321       1322       1323       1324       1325       1324       1325       1324       1325       1324       1324       1324       1324       1324       1324       1324       1324       1344       1342       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1344       1345       1346       1367       1368       1367       1376       1377       1378       1379       1300       1301       1302       1333       1384       1384       1386       1367       1388       1387       1388       1387       1388       1387       1388       1387       1388       1387       1388       1387       1388       1387       1388       1387       1388       1386       1387       1388                                                                                                                                                                                                                                                                                 |     | 1280 | 1281 | 1282 | 1283 | 1284 | 1285 | 1286 | 1287 | 1288 | 1289 | 1290 | 1291 | 1292 | 1293 | 1294 | 1295 |
| 530         1328         1329         1330         1331         1332         1333         1334         1335         1336         1337         1338         1339         1341         1342         1343           540         1344         1345         1344         1347         1348         1347         1348         1347         1348         1357         1353         1354         1355         1356         1357         1373         1374         1375           550         1360         1361         1362         1363         1364         1365         1366         1377         1378         1379         1380         1381         1382         1383         1384         1386         1387         1386         1387         1386         1387         1386         1387         1388         1389         1390         1391         1392         1381         1386         1387         1386         1387         1388         1387         1388         1387         1388         1387         1388         1387         1388         1387         1388         1387         1388         1387         1388         1387         1388         1387         1388         1387         1384         1481 <td></td> <td>_</td> <td></td> <td>1308</td> <td>1309</td> <td>1310</td> <td>1311</td>              |     | _    |      |      |      |      |      |      |      |      |      |      |      | 1308 | 1309 | 1310 | 1311 |
| 540         1344         1345         1346         1347         1348         1349         1350         1351         1352         1353         1355         1356         1357         1358         1357         1358         1357         1358         1357         1358         1357         1358         1357         1374         1372         1373         1374         1375           560         1376         1377         1378         1379         1380         1381         1382         1383         1384         1385         1386         1387         1388         1389         1390         1391           570         1372         1373         1374         1375         1377         1378         1377         1378         1377         1388         1389         1389         1390         1391           570         1372         1373         1374         1375         1377         1374         1374         1372           500         1408         1409         1410         1411         1412         1413         1411         1417         1418         1419         1420         1421         1422         1421         1422         1421         1422         1421                                                                                                                                                                                                                                 |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1327 |
| 550         1360         1361         1362         1363         1364         1365         1366         1377         1378         1371         1372         1373         1374         1375           560         1376         1377         1378         1375         1377         1378         1375         1373         1374         1372         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1373         1374         1375         1376         1375         1388         1385         1386         1387         1386         1387         1388         1387         1388         1387         1388         1387         1388         1438         1430         1431         1432         1433         1434         1435         1436         1437                                                                                                                                                                                             | 530 | 1328 | 1329 | 1330 | 1331 | 1332 | 1333 | 1334 | 1335 | 1336 | 133/ | 1338 | 1339 | 1340 | 1341 | 1342 | 1343 |
| 550         1360         1361         1362         1364         1365         1366         1367         1370         1371         1372         1373         1374         1375           560         1376         1377         1378         1379         1380         1381         1382         1384         1385         1386         1387         1388         1387         1386         1387         1386         1386         1387         1384         1385         1386         1387         1384         1385         1386         1387         1386         1387         1386         1387         1386         1386         1386         1386         1386         1386         1386         1386         1386         1401         1402         1402         1402         1401         1401         1402         1422         1423         1431         1431         1432         1433         1434         1435         1436         14457         1436         14451         1451         1452         1453         1454         1455         1456         1457         1476         1477         1478         1479         1480         1481         1482         1483         1484         1485         1486         14                                                                                                                                                                                             | 540 | 1344 | 1345 | 1346 | 1347 | 1348 | 1349 | 1350 | 1351 | 1352 | 1353 | 1354 | 1355 | 1356 | 1357 | 1358 | 1359 |
| 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       1434       1433       1432       1433       1434       1435       1434       1435       1434       1435       1434       1435       1434       1435       1434       1435       1434       1445       1445       1446       1447       1448       1444       1445       1446       1447       1448       1445       1446       1447       1448       1445       1446       1446       1446       1446       1446       1446       1446       1446       1446       1446       1446       1446       1446       1447       1448       1449       1450       1451       1452       1453       1454       1455       1506       1507       1508       1507       1508       1507       1508       1507       1508       1507       1508       1507 <t< td=""><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>1367</td><td>1368</td><td>1369</td><td>1370</td><td></td><td></td><td></td><td></td><td>1375</td></t<>                                                                                              |     |      |      |      |      |      |      |      | 1367 | 1368 | 1369 | 1370 |      |      |      |      | 1375 |
| 580         1408         1409         1410         1411         1412         1413         1414         1415         1416         1417         1418         1419         1420         1421         1422         1423           590         1424         1425         1426         1427         1428         1429         1431         1431         1431         1431         1431         1432         1433         1434         1435         1433         1434         1435         1436         1437         1438         1435           580         1456         1457         1458         1459         1460         1461         1462         1463         1446         1465         1466         1467         1468         1469         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         1501         1502         1503         1501         1501         1502         1503         1501         1501                                                                                                                                                                                                                     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1391 |
| 590         1424         1425         1426         1427         1428         1429         1430         1431         1432         1433         1435         1436         1437         1438         1439           5A0         1440         1441         1442         1443         1444         1445         1446         1447         1448         1445         1456         1457         1458         1459         1460         1461         1462         1463         1464         1465         1466         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1468         1467         1458         1567         1508         1507         1508         1507         1508         1507         1508                                                                                                                                                                                             | 5/0 | 1392 | 1393 | 1394 | 1395 | 1396 | 1397 | 1398 | 1399 | 1400 | 1401 | 1402 | 1403 | 1404 | 1405 | 1406 | 1407 |
| 590         1424         1425         1426         1427         1428         1429         1430         1431         1432         1433         1435         1436         1437         1438         1435           580         1440         1441         1442         1443         1444         1445         1446         1446         1446         1450         1451         1452         1453         1454         1455           580         1456         1457         1458         1459         1460         1461         1462         1463         1464         1465         1466         1467         1468         1467         1468         1469         1470         1471           5C0         1472         1473         1474         1475         1476         1477         1478         1479         1480         1481         1482         1483         1484         1485         1486         1487           5C0         1505         1506         1507         1508         1509         1510         1511         1512         1513         1531         1532         1533         1534         1534         1534         1534         1534         1534         1534         1532                                                                                                                                                                                                                                 | 580 | 1408 | 1409 | 1410 | 1411 | 1412 | 1413 | 1414 | 1415 | 1416 | 1417 | 1418 | 1419 | 1420 | 1421 | 1422 | 1423 |
| 5B0         1456         1457         1458         1459         1460         1461         1462         1463         1464         1465         1466         1467         1468         1469         1470         1471           5C0         1472         1473         1474         1475         1476         1477         1478         1479         1480         1481         1482         1483         1484         1485         1486         1487           5C0         1472         1473         1474         1475         1476         1477         1478         1479         1480         1481         1482         1483         1484         1485         1486         1487           5D0         1451         1505         1506         1507         1508         1509         1510         1511         1512         1513         1514         1517         1518         1517         1518         1517         1518         1517         1518         1517         1518         1531         1531         1531         1531         1531         1531         1531         1531         1531         1531         1531         1531         1531         1531         1531         1531         1531                                                                                                                                                                                                                     | 1 1 |      |      |      |      |      |      | 1430 |      |      |      |      |      |      |      |      | 1439 |
| 5C0         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         1501         1502         1501         1501         1502         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1501         1511         1512         1513         1511         1512         1531         1532         1533         1534         1535         1550         1551         1550         1551         1556         1557         1558         1559         1560         1561         1564         1564                                                                                                                                                                                             |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1455 |
| 5D0         1488         1489         1490         1491         1492         1493         1494         1495         1496         1497         1498         1499         1500         1501         1502         1502           5E0         1504         1505         1506         1507         1508         1509         1510         1511         1512         1513         1514         1515         1516         1517         1518         1519           5F0         1520         1521         1522         1523         1544         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         1601         1601         1602 <t< td=""><td>580</td><td>1456</td><td>1457</td><td>1458</td><td>1459</td><td>1460</td><td>1461</td><td>1462</td><td>1463</td><td>1464</td><td>1465</td><td>1466</td><td>1467</td><td>1468</td><td>1469</td><td>1470</td><td>1471</td></t<> | 580 | 1456 | 1457 | 1458 | 1459 | 1460 | 1461 | 1462 | 1463 | 1464 | 1465 | 1466 | 1467 | 1468 | 1469 | 1470 | 1471 |
| 5D0         1488         1489         1490         1491         1492         1493         1494         1495         1496         1497         1498         1499         1500         1501         1502         1502           5E0         1504         1505         1506         1507         1508         1509         1510         1511         1512         1513         1514         1515         1516         1517         1518         1519           5F0         1520         1521         1522         1523         1544         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         1601         1601         1602 <t< td=""><td>5C0</td><td>1472</td><td>1473</td><td>1474</td><td>1475</td><td>1476</td><td>1477</td><td>1478</td><td>1479</td><td>1480</td><td>1481</td><td>1482</td><td>1483</td><td>1484</td><td>1485</td><td>1486</td><td>1487</td></t<> | 5C0 | 1472 | 1473 | 1474 | 1475 | 1476 | 1477 | 1478 | 1479 | 1480 | 1481 | 1482 | 1483 | 1484 | 1485 | 1486 | 1487 |
| 5E0         1504         1505         1506         1507         1508         1509         1510         1511         1512         1513         1514         1515         1516         1517         1518         1519           600         1530         1531         1522         1523         1524         1525         1526         1527         1528         1529         1530         1531         1516         1517         1518         1514         1515           600         1536         1537         1538         1539         1540         1541         1542         1543         1544         1545         1546         1547         1548         1549         1550         1551           610         1552         1554         1555         1556         1557         1558         1557         1576         1577         1578         1579         1580         1581         1582         1583           630         1601         1601         1602         1603         1604         1605         1606         1607         1608         1609         1610         1611         1612         1613         1614         1615           640         1601         1601 <t< td=""><td>5D0</td><td>1488</td><td>1489</td><td>1490</td><td>1491</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td>•</td><td></td><td></td><td></td><td></td></t<>                                                | 5D0 | 1488 | 1489 | 1490 | 1491 |      |      |      |      |      |      |      | •    |      |      |      |      |
| 600         1536         1537         1538         1539         1540         1541         1542         1543         1544         1545         1564         1557         1556         1551         1550         1551         1550         1551         1550         1551         1550         1551         1550         1551         1556         1557         1558         1559         1560         1561         1562         1563         1564         1565         1557         1558         1559         1560         1561         1562         1563         1564         1565         1557         1578         1577         1578         1579         1580         1581         1582         1583           630         1584         1585         1586         1587         1573         1574         1575         1576         1577         1578         1579         1580         1581         1582         1583           630         1601         1601         1602         1603         1604         1605         1606         1607         1608         1609         1610         1611         1612         1613         1614         1615           640         1640         1641         1642                                                                                                                                                                                                                     |     |      |      |      |      |      |      |      |      |      |      |      |      | 1516 |      | 1518 | 1519 |
| 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         1572         1573         1574         1575         1576         1577         1578         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                                                                                                                                                                                                                                 | 510 | 1520 | 1521 | 1522 | 1523 | 1524 | 1525 | 1526 | 1527 | 1528 | 1529 | 1530 | 1531 | 1532 | 1533 | 1534 | 1535 |
| 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         1572         1573         1574         1575         1576         1577         1578         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                                                                                                                                                                                                                                 | 600 | 1536 | 1537 | 1538 | 1539 | 1540 | 1541 | 1542 | 1543 | 1544 | 1545 | 1546 | 1547 | 1548 | 1549 | 1550 | 1551 |
| 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       1664       1647       1664       16464       1645       1666       1667       1653       1657       1658       1659       1660       1661       1662       166                                                                                                                                                                                                                                                                                                              | 610 |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| 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       1664       1664       1666       1667       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         680       1664       1665       1667       1668       1669       1670       1671       1672       1673       1674       1675       1676       1677       1678       1679                                                                                                                                                                                                                                                                                                              |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1583 |
| 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         1699           680         1664         1665         1668         1669         1670         1671         1672         1673         1674         1675         1676         1677         1678         1699           640         1697         1698         1699         1700 <t< td=""><td>630</td><td>1584</td><td>1585</td><td>1586</td><td>1587</td><td>1588</td><td>1589</td><td>1590</td><td>1591</td><td>1592</td><td>1593</td><td>1594</td><td>1595</td><td>1596</td><td>1597</td><td>1598</td><td>1599</td></t<> | 630 | 1584 | 1585 | 1586 | 1587 | 1588 | 1589 | 1590 | 1591 | 1592 | 1593 | 1594 | 1595 | 1596 | 1597 | 1598 | 1599 |
| 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         1699           680         1664         1665         1668         1669         1670         1671         1672         1673         1674         1675         1676         1677         1678         1699           640         1697         1698         1699         1700 <t< td=""><td>640</td><td>1600</td><td>1601</td><td>1602</td><td>1603</td><td>1604</td><td>1605</td><td>1606</td><td>1607</td><td>1608</td><td>1609</td><td>1610</td><td>1611</td><td>1612</td><td>1613</td><td>1614</td><td>1615</td></t<> | 640 | 1600 | 1601 | 1602 | 1603 | 1604 | 1605 | 1606 | 1607 | 1608 | 1609 | 1610 | 1611 | 1612 | 1613 | 1614 | 1615 |
| 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       1666       1661       1662       1663         680       1664       1665       1666       1667       1668       1669       1670       1671       1672       1673       1674       1675       1666       1667       1678       1679         640       1696       1697       1698       1699       1700       1701       1702       1703       1704       1705       1706       1707       1708       1709       1710       1711         680       1712       1713       1714       1715       1716       1717       1718       1719       1720       1721       1722 </td <td></td>                                                                                                                                         |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| 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         6A0       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         6C0       1728       1729       1730       1731       1732       1733       1734       1735       1736       1737       1738       1739       1740       1741       1742       1743         6D0       1744       1745       1746       1747       1748       1749       1750       1751       1752       1753       1754 </td <td></td> <td></td> <td></td> <td></td> <td></td> <td>1636</td> <td>1637</td> <td>1638</td> <td>1639</td> <td>1640</td> <td>1641</td> <td>1642</td> <td>1643</td> <td>1644</td> <td>1645</td> <td>1646</td> <td>1647</td>                                                                                         |     |      |      |      |      | 1636 | 1637 | 1638 | 1639 | 1640 | 1641 | 1642 | 1643 | 1644 | 1645 | 1646 | 1647 |
| 690         1680         1681         1682         1683         1684         1685         1686         1687         1688         1689         1691         1691         1692         1693         1694         1695           6A0         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           6C0         1728         1729         1730         1731         1732         1733         1734         1735         1736         1737         1738         1739         1740         1741         1742         1743           6D0         1744         1745         1746         1747         1748         1749         1750         1751         1752         1753         1754         1755         1756         1757         1758         1759           6E0         1760         1761 <t< td=""><td>670</td><td>1648</td><td>1649</td><td>1650</td><td>1651</td><td>1652</td><td>1653</td><td>1654</td><td>1655</td><td>1656</td><td>1657</td><td>1658</td><td>1659</td><td>1660</td><td>1661</td><td>1662</td><td>1663</td></t<> | 670 | 1648 | 1649 | 1650 | 1651 | 1652 | 1653 | 1654 | 1655 | 1656 | 1657 | 1658 | 1659 | 1660 | 1661 | 1662 | 1663 |
| 690         1680         1681         1682         1683         1684         1685         1686         1687         1688         1689         1691         1691         1692         1693         1694         1695           6A0         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           6C0         1728         1729         1730         1731         1732         1733         1734         1735         1736         1737         1738         1739         1740         1741         1742         1743           6D0         1744         1745         1746         1747         1748         1749         1750         1751         1752         1753         1754         1755         1756         1757         1758         1759           6E0         1760         1761 <t< td=""><td>680</td><td>1664</td><td>1665</td><td>1666</td><td>1667</td><td>1668</td><td>1669</td><td>1670</td><td>1671</td><td>1672</td><td>1673</td><td>1674</td><td>1675</td><td>1676</td><td>1677</td><td>1678</td><td>1679</td></t<> | 680 | 1664 | 1665 | 1666 | 1667 | 1668 | 1669 | 1670 | 1671 | 1672 | 1673 | 1674 | 1675 | 1676 | 1677 | 1678 | 1679 |
| 6A0         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           6C0         1728         1729         1730         1731         1732         1733         1734         1735         1736         1737         1738         1739         1740         1741         1742         1743           6D0         1744         1745         1746         1747         1748         1750         1751         1752         1753         1754         1756         1757         1758         1759           6E0         1760         1761         1762         1763         1764         1765         1766         1767         1768         1769         1770         1771         1772         1773         1774         1775                                                                                                                                                                                                                                                                                                               |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1695 |
| 6C0       1728       1729       1730       1731       1732       1733       1734       1735       1736       1737       1738       1739       1740       1741       1742       1743         6D0       1744       1745       1746       1747       1748       1749       1750       1751       1752       1753       1754       1756       1757       1758       1759         6E0       1760       1761       1762       1763       1764       1765       1766       1767       1768       1769       1770       1771       1772       1773       1774       1775                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |      |      |      |      |      | 1701 | 1702 | 1703 | 1704 | 1705 |      | 1707 | 1708 | 1709 | 1710 | 1711 |
| 6D0         1744         1745         1746         1747         1748         1750         1751         1752         1753         1754         1755         1756         1757         1758         1759           6E0         1760         1761         1762         1763         1764         1765         1766         1771         1772         1773         1774         1775                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 6B0 | 1712 | 1713 | 1714 | 1715 | 1716 | 1717 | 1718 | 1719 | 1720 | 1721 | 1722 | 1723 | 1724 | 1725 | 1726 | 1727 |
| 6D0         1744         1745         1746         1747         1748         1750         1751         1752         1753         1754         1755         1756         1757         1758         1759           6E0         1760         1761         1762         1763         1764         1765         1766         1771         1772         1773         1774         1775                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 6C0 | 1728 | 1729 | 1730 | 1731 | 1732 | 1733 | 1734 | 1735 | 1736 | 1737 | 1738 | 1739 | 1740 | 1741 | 1742 | 1743 |
| 6E0 1760 1761 1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774 1775                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 6D0 |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      | 1743 |
| 6F0   1776 1777 1778 1779 1780 1781 1782 1783 1784 1785 1786 1787 1788 1789 1790 1791                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1 1 |      |      |      |      |      | 1765 | 1766 |      | 1768 | 1769 | 1770 | 1771 | 1772 | 1773 |      | 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            | В                    | с                    | D            | E                    | F            |
|------------|----------------------|----------------------|--------------|--------------|----------------------|--------------|--------------|--------------|----------------------|--------------|--------------|----------------------|----------------------|--------------|----------------------|--------------|
| 700        | 1792                 | 1793                 | 1794         | 1795         | 1796                 | 1797         | 1798         | 1799         | 1800                 | 1801         | 1802         | 1803                 | 1804                 | 1805         | 1806                 | 1807         |
| 710<br>720 | 1808<br>1824         | 1809<br>1825         | 1810<br>1826 | 1811<br>1827 | 1812<br>1828         | 1813<br>1829 | 1814<br>1830 | 1815<br>1831 | 1816<br>1832         | 1817<br>1833 | 1818<br>1834 | 1819<br>1835         | 1820<br>1836         | 1821<br>1837 | 1822<br>1838         | 1823<br>1839 |
| 730        | 1840                 | 1841                 | 1842         | 1843         | 1844                 | 1845         | 1846         | 1847         | 1848                 | 1849         | 1850         | 1851                 | 1852                 | 1853         | 1854                 | 1855         |
| 740<br>750 | 1856<br>1872         | 1857<br>1873         | 1858<br>1874 | 1859<br>1875 | 1860<br>1876         | 1861<br>1877 | 1862<br>1878 | 1863<br>1879 | 1864<br>1880         | 1865<br>1881 | 1866<br>1882 | 1867<br>1883         | 1868<br>1884         | 1869<br>1885 | 1870<br>1886         | 1871<br>1887 |
| 760<br>770 | 1888<br>1904         | 1889<br>1905         | 1890<br>1906 | 1891<br>1907 | 1892<br>1908         | 1893<br>1909 | 1894<br>1910 | 1895<br>1911 | 1896<br>1912         | 1897<br>1913 | 1898<br>1914 | 1899<br>1915         | 1900<br>1916         | 1901<br>1917 | 1902<br>1918         | 1903<br>1919 |
| 780        | 1920                 | 1921                 | 1922         | 1923         | 1924                 | 1925         | 1926         | 1927         | 1928                 | 1929         | 1930         | 1931                 | 1932                 | 1933         | 1934                 | 1935         |
| 790<br>7A0 | 1936<br>1952         | 1937<br>1953         | 1938<br>1954 | 1939<br>1955 | 1940<br>1956         | 1941<br>1957 | 1942<br>1958 | 1943<br>1959 | 1944<br>1960         | 1945<br>1961 | 1946<br>1962 | 1947<br>1963         | 1948<br>1964         | 1949<br>1965 | 1950<br>1966         | 1951<br>1967 |
| 7B0<br>7C0 | 1968<br>1984         | 1969<br>1985         | 1970<br>1986 | 1971<br>1987 | 1972<br>1988         | 1973<br>1989 | 1974<br>1990 | 1975<br>1991 | 1976<br>1992         | 1977<br>1993 | 1978<br>1994 | 1979<br>1995         | 1980<br>1996         | 1981<br>1997 | 1982<br>1998         | 1983<br>1999 |
| 7D0        | 2000                 | 2001                 | 2002         | 2003         | 2004                 | 2005         | 2006         | 2007         | 2008                 | 2009         | 2010         | 2011                 | 2012                 | 2013         | 2014                 | 2015         |
| 7E0<br>7F0 | 2016<br>2032         | 2017<br>2033         | 2018<br>2034 | 2019<br>2035 | 2020<br>2036         | 2021<br>2037 | 2022<br>2038 | 2023<br>2039 | 2024<br>2040         | 2025<br>2041 | 2026<br>2042 | 2027<br>2043         | 2028<br>2044         | 2029<br>2045 | 2030<br>2046         | 2031<br>2047 |
| 800<br>810 | 2048<br>2064         | 2049<br>2065         | 2050<br>2066 | 2051<br>2067 | 2052<br>2068         | 2053<br>2069 | 2054<br>2070 | 2055<br>2071 | 2056<br>2072         | 2057<br>2073 | 2058<br>2074 | 2059<br>2075         | 2060<br>2076         | 2061<br>2077 | 2062<br>2078         | 2063<br>2079 |
| 820<br>830 | 2004<br>2080<br>2096 | 2003<br>2081<br>2097 | 2082<br>2098 | 2083<br>2099 | 2000<br>2084<br>2100 | 2085<br>2101 | 2086<br>2102 | 2087<br>2103 | 2072<br>2088<br>2104 | 2089<br>2105 | 2090<br>2106 | 2073<br>2091<br>2107 | 2070<br>2092<br>2108 | 2093<br>2109 | 2094<br>2094<br>2110 | 2095<br>2111 |
| 840        | 2112                 | 2113                 | 2114         | 2115         | 2116                 | 2117         | 2118         | 2119         | 2104                 | 2105         | 2122         | 2123                 | 2100                 | 2107         | 2110                 | 2127         |
| 850<br>860 | 2128<br>2144         | 2129<br>2145         | 2130<br>2146 | 2131<br>2147 | 2132<br>2148         | 2133<br>2149 | 2134<br>2150 | 2135<br>2151 | 2136                 | 2137<br>2153 | 2138         | 2139                 | 2140                 | 2141         | 2142                 | 2143         |
| 870        | 2144<br>2160         | 2145                 | 2140         | 2147         | 2148                 | 2149         | 2166         | 2151<br>2167 | 2152<br>2168         | 2153         | 2154<br>2170 | 2155<br>2171         | 2156<br>2172         | 2157<br>2173 | 2158<br>2174         | 2159<br>2175 |
| 880<br>890 | 2176<br>2192         | 2177<br>2193         | 2178<br>2194 | 2179<br>2195 | 2180<br>2196         | 2181<br>2197 | 2182<br>2198 | 2183<br>2199 | 2184<br>2200         | 2185<br>2201 | 2186<br>2202 | 2187<br>2203         | 2188<br>2204         | 2189<br>2205 | 2190<br>2206         | 2191<br>2207 |
| 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<br>8D0 | 2240<br>2256         | 2241<br>2257         | 2242<br>2258 | 2243<br>2259 | 2244<br>2260         | 2245<br>2261 | 2246<br>2262 | 2247<br>2263 | 2248<br>2264         | 2249<br>2265 | 2250<br>2266 | 2251<br>2267         | 2252<br>2268         | 2253<br>2269 | 2254<br>2270         | 2255<br>2271 |
| 8E0<br>8F0 | 2272<br>2288         | 2273<br>2289         | 2274<br>2290 | 2275<br>2291 | 2276<br>2292         | 2277<br>2293 | 2278<br>2294 | 2279<br>2295 | 2280<br>2296         | 2281<br>2297 | 2282<br>2298 | 2283<br>2299         | 2284<br>2300         | 2285<br>2301 | 2286<br>2302         | 2287<br>2303 |
| 900        | 2304                 | 2305                 | 2306         | 2307         | 2308                 | 2309         | 2310         | 2311         |                      |              |              |                      |                      |              |                      |              |
| 910        | 2320                 | 2321                 | 2322         | 2323         | 2324                 | 2325         | 2326         | 2327         | 2312<br>2328         | 2313<br>2329 | 2314<br>2330 | 2315<br>2331         | 2316<br>2332         | 2317<br>2333 | 2318<br>2334         | 2319<br>2335 |
| 920<br>930 | 2336<br>2352         | 2337<br>2353         | 2338<br>2354 | 2339<br>2355 | 2340<br>2356         | 2341<br>2357 | 2342<br>2358 | 2343<br>2359 | 2344<br>2360         | 2345<br>2361 | 2346<br>2362 | 2347<br>2363         | 2348<br>2364         | 2349<br>2365 | 2350<br>2366         | 2351<br>2367 |
| 940        | 2368                 | 2369                 | 2370         | 2371         | 2372                 | 2373         | 2374         | 2375         | 2376                 | 2377         | 2378         | 2379                 | 2380                 | 2381         | 2382                 | 2383         |
| 950<br>960 | 2384<br>2400         | 2385<br>2401         | 2386<br>2402 | 2387<br>2403 | 2388<br>2404         | 2389<br>2405 | 2390<br>2406 | 2391<br>2407 | 2392<br>2408         | 2393<br>2409 | 2394<br>2410 | 2395<br>2411         | 2396<br>2412         | 2397<br>2413 | 2398<br>2414         | 2399<br>2415 |
| 970        | 2416                 | 2417                 | 2418         | 2419         | 2420                 | 2421         | 2422         | 2423         | 2424                 | 2425         | 2426         | 2427                 | 2428                 | 2429         | 2430                 | 2431         |
| 980<br>990 | 2432<br>2448         | 2433<br>2449         | 2434<br>2450 | 2435<br>2451 | 2436<br>2452         | 2437<br>2453 | 2438<br>2454 | 2439<br>2455 | 2440<br>2456         | 2441<br>2457 | 2442<br>2458 | 2443                 | 2444<br>2460         | 2445<br>2461 | 2446<br>2462         | 2447<br>2463 |
| 990<br>9A0 | 2440                 | 2447                 | 2450         | 2451         | 2452                 | 2455         | 2454<br>2470 | 2455         | 2456<br>2472         | 2437         | 2458         | 2459<br>2475         | 2460                 | 2401         | 2462<br>2478         | 2463         |
| 9B0        | 2480                 | 2481                 | 2482         | 2483         | 2484                 | 2485         | 2486         | 2487         | 2488                 | 2489         | 2490         | 2491                 | 2492                 | 2493         | 2494                 | 2495         |
| 9C0<br>9D0 | 2496<br>2512         | 2497<br>2513         | 2498<br>2514 | 2499<br>2515 | 2500<br>2516         | 2501<br>2517 | 2502<br>2518 | 2503<br>2519 | 2504<br>2520         | 2505<br>2521 | 2506<br>2522 | 2507<br>2523         | 2508<br>2524         | 2509<br>2525 | 2510<br>2526         | 2511<br>2527 |
| 9E0        | 2528                 | 2513                 | 2514<br>2530 | 2515         | 2532                 | 2533         | 2518         | 2535         | 2520                 | 2521         | 2522         | 2523<br>2539         | 2524<br>2540         | 2525<br>2541 | 2526<br>2542         | 2527         |
| 9F0        | 2544                 | 2545                 | 2546         | 2547         | 2548                 | 2549         | 2550         | 2551         | 2552                 | 2553         | 2554         | 2555                 | 2556                 | 2557         | 2558                 | 2559         |

|                              | 0                            | 1                            | 2                            | 3                            | 4                            | 5                            | 6                            | 7                            | 8                            | 9                            | A                            | В                            | С                                    | D                            | E                            | F                            |
|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|--------------------------------------|------------------------------|------------------------------|------------------------------|
| A00                          | 2560                         | 2561                         | 2562                         | 2563                         | 2564                         | 2565                         | 2566                         | 2567                         | 2568                         | 2569                         | 2570                         | 2571                         | 2572                                 | 2573                         | 2574                         | 2575                         |
| A10                          | 2576                         | 2577                         | 2578                         | 2579                         | 2580                         | 2581                         | 2582                         | 2583                         | 2584                         | 2585                         | 2586                         | 2587                         | 2588                                 | 2589                         | 2590                         | 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                         | 2649                         | 2650                         | 2651                         | 2652                                 | 2653                         | 2654                         | 2655                         |
| A60                          | 2656                         | 2657                         | 2658                         | 2659                         | 2660                         | 2661                         | 2662                         | 2663                         | 2664                         | 2665                         | 2666                         | 2667                         | 2668                                 | 2669                         | 2670                         | 2671                         |
| 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                                 | 2717                         | 2718                         | 2719                         |
| AA0                          | 2720                         | 2721                         | 2722                         | 2723                         | 2724                         | 2725                         | 2726                         | 2727                         | 2728                         | 2729                         | 2730                         | 2731                         | 2732                                 | 2733                         | 2734                         | 2735                         |
| AB0                          | 2736                         | 2737                         | 2738                         | 2739                         | 2740                         | 2741                         | 2742                         | 2743                         | 2744                         | 2745                         | 2746                         | 2747                         | 2748                                 | 2749                         | 2750                         | 2751                         |
| AC0                          | 2752                         | 2753                         | 2754                         | 2755                         | 2756                         | 2757                         | 2758                         | 2759                         | 2760                         | 2761                         | 2762                         | 2763                         | 2764                                 | 2765                         | 2766                         | 2767                         |
| AD0                          | 2768                         | 2769                         | 2770                         | 2771                         | 2772                         | 2773                         | 2774                         | 2775                         | 2776                         | 2777                         | 2778                         | 2779                         | 2780                                 | 2781                         | 2782                         | 2783                         |
| AE0                          | 2784                         | 2785                         | 2786                         | 2787                         | 2788                         | 2789                         | 2790                         | 2791                         | 2792                         | 2793                         | 2794                         | 2795                         | 2796                                 | 2797                         | 2798                         | 2799                         |
| AF0                          | 2800                         | 2801                         | 2802                         | 2803                         | 2804                         | 2805                         | 2806                         | 2807                         | 2808                         | 2809                         | 2810                         | 2811                         | 2812                                 | 2813                         | 2814                         | 2815                         |
| B00                          | 2816                         | 2817                         | 2818                         | 2819                         | 2820                         | 2821                         | 2822                         | 2823                         | 2824                         | 2825                         | 2826                         | 2827                         | 2828                                 | 2829                         | 2830                         | 2831                         |
| B10                          | 2832                         | 2833                         | 2834                         | 2835                         | 2836                         | 2837                         | 2838                         | 2839                         | 2840                         | 2841                         | 2842                         | 2843                         | 2844                                 | 2845                         | 2846                         | 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                         | 2908                                 | 2909                         | 2910                         | 2911                         |
| B60                          | 2912                         | 2913                         | 2914                         | 2915                         | 2916                         | 2917                         | 2918                         | 2919                         | 2920                         | 2921                         | 2922                         | 2923                         | 2924                                 | 2925                         | 2926                         | 2927                         |
| B70                          | 2928                         | 2929                         | 2930                         | 2931                         | 2932                         | 2933                         | 2934                         | 2935                         | 2936                         | 2937                         | 2938                         | 2939                         | 2940                                 | 2941                         | 2942                         | 2943                         |
| B80                          | 2944                         | 2945                         | 2946                         | 2947                         | 2948                         | 2949                         | 2950                         | 2951                         | 2952                         | 2953                         | 2954                         | 2955                         | 2956                                 | 2957                         | 2958                         | 2959                         |
| B90                          | 2960                         | 2961                         | 2962                         | 2963                         | 2964                         | 2965                         | 2966                         | 2967                         | 2968                         | 2969                         | 2970                         | 2971                         | 2972                                 | 2973                         | 2974                         | 2975                         |
| BA0                          | 2976                         | 2977                         | 2978                         | 2979                         | 2980                         | 2981                         | 2982                         | 2983                         | 2984                         | 2985                         | 2986                         | 2987                         | 2988                                 | 2989                         | 2990                         | 2991                         |
| BB0                          | 2992                         | 2993                         | 2994                         | 2995                         | 2996                         | 2997                         | 2998                         | 2999                         | 3000                         | 3001                         | 3002                         | 3003                         | 3004                                 | 3005                         | 3006                         | 3007                         |
| BC0                          | 3008                         | 3009                         | 3010                         | 3011                         | 3012                         | 3013                         | 3014                         | 3015                         | 3016                         | 3017                         | 3018                         | 3019                         | 3020                                 | 3021                         | 3022                         | 3023                         |
| BD0                          | 3024                         | 3025                         | 3026                         | 3027                         | 3028                         | 3029                         | 3030                         | 3031                         | 3032                         | 3033                         | 3034                         | 3035                         | 3036                                 | 3037                         | 3038                         | 3039                         |
| BE0                          | 3040                         | 3041                         | 3042                         | 3043                         | 3044                         | 3045                         | 3046                         | 3047                         | 3048                         | 3049                         | 3050                         | 3051                         | 3052                                 | 3053                         | 3054                         | 3055                         |
| BF0                          | 3056                         | 3057                         | 3058                         | 3059                         | 3060                         | 3061                         | 3062                         | -3063                        | 3064                         | 3065                         | 3066                         | 3067                         | 3068                                 | 3069                         | 3070                         | 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                                 | 3133                         | 3134                         | 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                         |
| C 80<br>C 90<br>C A0<br>C B0 | 3200<br>3216<br>3232<br>3248 | 3201<br>3217<br>3233<br>3249 | 3202<br>3218<br>3234<br>3250 | 3203<br>3219<br>3235<br>3251 | 3204<br>3220<br>3236<br>3252 | 3205<br>3221<br>3237<br>3253 | 3206<br>3222<br>3238<br>3254 | 3207<br>3223<br>3239<br>3255 | 3208<br>3224<br>3240<br>3256 | 3209<br>3225<br>3241<br>3257 | 3210<br>3226<br>3242<br>3258 | 3211<br>3227<br>3243<br>3259 | 3170<br>3212<br>3228<br>3244<br>3260 | 3213<br>3229<br>3245<br>3261 | 3214<br>3230<br>3246<br>3262 | 3215<br>3231<br>3247<br>3263 |
| CC0                          | 3264                         | 3265                         | 3266                         | 3267                         | 3268                         | 3269                         | 3270                         | 3271                         | 3272                         | 3273                         | 3274                         | 3275                         | 3276                                 | 3277                         | 3278                         | 3279                         |
| CD0                          | 3280                         | 3281                         | 3282                         | 3283                         | 3284                         | 3285                         | 3286                         | 3287                         | 3288                         | 3289                         | 3290                         | 3291                         | 3292                                 | 3293                         | 3294                         | 3295                         |
| CE0                          | 3296                         | 3297                         | 3298                         | 3299                         | 3300                         | 3301                         | 3302                         | 3303                         | 3304                         | 3305                         | 3306                         | 3307                         | 3308                                 | 3309                         | 3310                         | 3311                         |
| CF0                          | 3312                         | 3313                         | 3314                         | 3315                         | 3316                         | 3317                         | 3318                         | 3319                         | 3320                         | 3321                         | 3322                         | 3323                         | 3324                                 | 3325                         | 3326                         | 3327                         |

| [          | 0            | 1            |              | <br>2        |              | <br>E        |              |              |              |              | •            | <br>D        |              |              |              |              |
|------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
|            | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | Α            | В            | С            | D            | E            | F            |
| D00        | 3328         | 3329         | 3330         | 3331         | 3332         | 3333         | 3334         | 3335         | 3336         | 3337         | 3338         | 3339         | 3340         | 3341         | 3342         | 3343         |
| D10<br>D20 | 3344<br>3360 | 3345<br>3361 | 3346<br>3362 | 3347<br>3363 | 3348<br>3364 | 3349<br>3365 | 3350<br>3366 | 3351<br>3367 | 3352<br>3368 | 3353<br>3369 | 3354<br>3370 | 3355<br>3371 | 3356<br>3372 | 3357<br>3373 | 3358<br>3374 | 3359<br>3375 |
| D30        | 3376         | 3377         | 3378         | 3379         | 3380         | 3381         | 3382         | 3383         | 3384         | 3385         | 3386         | 3387         | 3388         | 3389         | 3390         | 3391         |
|            |              |              |              | ••••         |              |              |              |              |              |              |              |              |              |              | 0070         | 0071         |
| •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         |
| 0.00       | 2500         | 0501         | 0500         | 0500         | 0504         | 0505         | 050/         | 0507         | 0500         | 0500         | 0500         | 2521         | 0500         | 0500         | 0504         | 2525         |
| DC0        | 3520         | 3521         | 3522         | 3523         | 3524         | 3525         | 3526         | 3527         | 3528         | 3529         | 3530<br>3546 | 3531         | 3532         | 3533         | 3534         | 3535         |
| DD0<br>DE0 | 3536<br>3552 | 3537<br>3553 | 3538<br>3554 | 3539<br>3555 | 3540<br>3556 | 3541<br>3557 | 3542<br>3558 | 3543<br>3559 | 3544<br>3560 | 3545<br>3561 | 3540         | 3547<br>3563 | 3548<br>3564 | 3549<br>3565 | 3550<br>3566 | 3551<br>3567 |
| DFO        | 3568         | 3569         | 3570         | 3571         | 3572         | 3573         | 3574         | 3575         | 3576         | 3577         | 3578         | 3579         | 3580         | 3581         | 3582         | 3583         |
|            |              |              |              |              | 0072         |              |              |              |              |              |              |              |              |              |              |              |
| 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         | 2715         | 2714         | 3717         | 3718         | 3719         | 2720         | 2721         | 2722         | 2722         | 2724         | 2725         | 270/         | 2222         |
| E90        | 3712         | 3729         | 3730         | 3715<br>3731 | 3716<br>3732 | 3733         | 3734         | 3735         | 3720<br>3736 | 3721<br>3737 | 3722<br>3738 | 3723<br>3739 | 3724<br>3740 | 3725<br>3741 | 3726<br>3742 | 3727<br>3743 |
| EA0        | 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         |
| ED0        | 3792         | 3793         | 3794         | 3795         | 3796         | 3797         | 3798         | 3799         | 3800         | 3801         | 3802         | 3803         | 3804         | 3805         | 3806         | 3807         |
| EE0        | 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         |
| EAO        | 2004         | 2005         | 2004         | 2007         | 2000         | 2000         | 2010         | 2011         | 2010         | 2012         | 2014         | 2015         | 2017         | 2017         | . 2010       | 2010         |
| F40<br>F50 | 3904<br>3920 | 3905<br>3921 | 3906<br>3922 | 3907<br>3923 | 3908<br>3924 | 3909<br>3925 | 3910<br>3926 | 3911<br>3927 | 3912<br>3928 | 3913<br>3929 | 3914<br>3930 | 3915<br>3931 | 3916<br>3932 | 3917<br>3933 | 3918<br>3934 | 3919<br>3935 |
| F60        | 3936         | 3937         | 3938         | 3939         | 3724<br>3940 | 3923         | 3942         | 3943         | 3728<br>3944 | 3945         | 3930         | 3931         | 3932<br>3948 | 3933         | 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         |
| FA0        | 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         |
| FD0        | 4048         | 4049         | 4050         | 4053         | 4052         | 4053         | 4054         | 4055         | 4056         | 4057         | 4058         | 4059         | 4060         | 4043         | 4062         | 4063         |
| FE0        | 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 FRACTION CONVERSION TABLE

| Hexadecimal  | Decimal      | Hexadecimal  | Decimal      | Hexadecimal  | Decimal      | Hexadecimal  | Decimal      |
|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| .00 00 00 00 | .00000 00000 | .00 00 00 40 | .00000 00149 | .00 00 00 80 | .00000 00298 | .00 00 00 C0 | .00000 00447 |
| .00 00 00 01 | .00000 00002 | .00 00 00 41 | .00000 00151 | .00 00 00 81 | .00000 00300 | .00 00 00 C1 | .00000 00449 |
| .00 00 00 02 | .00000 00004 | .00 00 00 42 | .00000 00153 | .00 00 00 82 | .00000 00302 | .00 00 00 C2 | .00000 00451 |
| .00 00 00 03 | .00000 00006 | .00 00 00 43 | .00000 00155 | .00 00 00 83 | .00000 00305 | .00 00 00 C3 | .00000 00454 |
| .00 00 00 04 | .00000 00009 | .00 00 00 44 | .00000 00158 | .00 00 00 84 | .00000 00307 | .00 00 00 C4 | .00000 00456 |
| .00 00 00 05 | .00000 00011 | .00 00 00 45 | .00000 00160 | .00 00 00 85 | .00000 00309 | .00 00 00 C5 | .00000 00458 |
| .00 00 00 06 | .00000 00013 | .00 00 00 46 | .00000 00162 | .00 00 00 86 | .00000 00311 | .00 00 00 C6 | .00000 00461 |
| .00 00 00 07 | .00000 00016 | .00 00 00 47 | .00000 00165 | .00 00 00 87 | .00000 00314 | .00 00 00 C7 | .00000 00463 |
| .00 00 00 08 | .00000 00018 | .00 00 00 48 | .00000 00167 | .00 00 00 88 | .00000 00316 | .00 00 00 C8 | .00000 00465 |
| .00 00 00 09 | .00000 00020 | .00 00 00 49 | .00000 00169 | .00 00 00 89 | .00000 00318 | .00 00 00 C9 | .00000 00467 |
| .00 00 00 0A | .00000 00023 | .00 00 00 4A | .00000 00172 | .00 00 00 8A | .00000 00321 | .00 00 00 CA | .00000 00470 |
| .00 00 00 0B | .00000 00025 | .00 00 00 4B | .00000 00174 | .00 00 00 8B | .00000 00323 | .00 00 00 CB | .00000 00472 |
| .00 00 00 0C | .00000 00027 | .00 00 00 4C | .00000 00176 | .00 00 00 8C | .00000 00325 | .00 00 00 CC | .00000 00474 |
| .00 00 00 0D | .00000 00030 | .00 00 00 4D | .00000 00179 | .00 00 00 8D | .00000 00328 | .00 00 00 CD | .00000 00477 |
| .00 00 00 0E | .00000 00032 | .00 00 00 4E | .00000 00181 | .00 00 00 8E | .00000 00330 | .00 00 00 CE | .00000 00479 |
| .00 00 00 OF | .00000 00034 | .00 00 00 4F | .00000 00183 | .00 00 00 8F | .00000 00332 | .00 00 00 CF | .00000 00481 |
| .00 00 00 10 | .00000 00037 | .00 00 00 50 | .00000 00186 | .00 00 00 90 | .00000 00335 | .00 00 00 D0 | .00000 00484 |
| .00 00 00 11 | .00000 00039 | .00 00 00 51 | .00000 00188 | .00 00 00 91 | .00000 00337 | .00 00 00 D1 | .00000 00486 |
| .00 00 00 12 | .00000 00041 | .00 00 00 52 | .00000 00190 | .00 00 00 92 | .00000 00339 | .00 00 00 D2 | .00000 00488 |
| .00 00 00 13 | .00000 00044 | .00 00 00 53 | .00000 00193 | .00 00 00 93 | .00000 00342 | .00 00 00 D3 | .00000 00491 |
| .00 00 00 14 | .00000 00046 | .00 00 00 54 | .00000 00195 | .00 00 00 94 | .00000 00344 | .00 00 00 D4 | .00000 00493 |
| .00 00 00 15 | .00000 00048 | .00 00 00 55 | .00000 00197 | .00 00 00 95 | .00000 00346 | .00 00 00 D5 | .00000 00495 |
| .00 00 00 16 | .00000 00051 | .00 00 00 56 | .00000 00200 | .00 00 00 96 | .00000 00349 | .00 00 00 D6 | .00000 00498 |
| .00 00 00 17 | .00000 00053 | .00 00 00 57 | .00000 00202 | .00 00 00 97 | .00000 00351 | .00 00 00 D7 | .00000 00500 |
| .00 00 00 18 | .00000 00055 | .00 00 00 58 | .00000 00204 | .00 00 00 98 | .00000 00353 | .00 00 00 D8 | .00000 00502 |
| .00 00 00 19 | .00000 00058 | .00 00 00 59 | .00000 00207 | .00 00 00 99 | .00000 00356 | .00 00 00 D9 | .00000 00505 |
| .00 00 00 1A | .00000 00060 | .00 00 00 5A | .00000 00209 | .00 00 00 9A | .00000 00358 | .00 00 00 DA | .00000 00507 |
| .00 00 00 1B | .00000 00062 | .00 00 00 5B | .00000 00211 | .00 00 00 9B | .00000 00360 | .00 00 00 DB | .00000 00509 |
| .00 00 00 1C | .00000 00065 | .00 00 00 5C | .00000 00214 | .00 00 00 9C | .00000 00363 | .00 00 00 DC | .00000 00512 |
| .00 00 00 1D | .00000 00067 | .00 00 00 5D | .00000 00216 | .00 00 00 9D | .00000 00365 | .00 00 00 DD | .00000 00514 |
| .00 00 00 1E | .00000 00069 | .00 00 00 5E | .00000 00218 | .00 00 00 9E | .00000 00367 | .00 00 00 DE | .00000 00516 |
| .00 00 00 1F | .00000 00072 | .00 00 00 5F | .00000 00221 | .00 00 00 9F | .00000 00370 | .00 00 00 DF | .00000 00519 |
| .00 00 00 20 | .00000 00074 | .00 00 00 60 | .00000 00223 | .00 00 00 A0 | .00000 00372 | .00 00 00 E0 | .00000 00521 |
| .00 00 00 21 | .00000 00076 | .00 00 00 61 | .00000 00225 | .00 00 00 A1 | .00000 00374 | .00 00 00 E1 | .00000 00523 |
| .00 00 00 22 | .00000 00079 | .00 00 00 62 | .00000 00228 | .00 00 00 A2 | .00000 00377 | .00 00 00 E2 | .00000 00526 |
| .00 00 00 23 | .00000 00081 | .00 00 00 63 | .00000 00230 | .00 00 00 A3 | .00000 00379 | .00 00 00 E3 | .00000 00528 |
| .00 00 00 24 | .00000 00083 | .00 00 00 64 | .00000 00232 | .00 00 00 A4 | .00000 00381 | .00 00 00 E4 | .00000 00530 |
| .00 00 00 25 | .00000 00086 | .00 00 00 65 | .00000 00235 | .00 00 00 A5 | .00000 00384 | .00 00 00 E5 | .00000 00533 |
| .00 00 00 26 | .00000 00088 | .00 00 00 66 | .00000 00237 | .00 00 00 A6 | .00000 00386 | .00 00 00 E6 | .00000 00535 |
| .00 00 00 27 | .00000 00090 | .00 00 00 67 | .00000 00239 | .00 00 00 A7 | .00000 00388 | .00 00 00 E7 | .00000 00537 |
| .00 00 00 28 | .00000 00093 | .00 00 00 68 | .00000 00242 | .00 00 00 A8 | .00000 00391 | .00 00 00 E8 | .00000 00540 |
| .00 00 00 29 | .00000 00095 | .00 00 00 69 | .00000 00244 | .00 00 00 A9 | .00000 00393 | .00 00 00 E9 | .00000 00542 |
| .00 00 00 2A | .00000 00097 | .00 00 00 6A | .00000 00246 | AA 00 00 00. | .00000 00395 | .00 00 00 EA | .00000 00544 |
| .00 00 00 2B | .00000 00100 | .00 00 00 6B | .00000 00249 | .00 00 00 AB | .00000 00398 | .00 00 00 EB | .00000 00547 |
| .00 00 00 2C | .00000 00102 | .00 00 00 6C | .00000 00251 | .00 00 00 AC | .00000 00400 | .00 00 00 EC | .00000 00549 |
| .00 00 00 2D | .00000 00104 | .00 00 00 6D | .00000 00253 | .00 00 00 AD | .00000 00402 | .00 00 00 ED | .00000 00551 |
| .00 00 00 2E | .00000 00107 | .00 00 00 6E | .00000 00256 | .00 00 00 AE | .00000 00405 | .00 00 00 EE | .00000 00554 |
| .00 00 00 2F | .00000 00109 | .00 00 00 6F | .00000 00258 | .00 00 00 AF | .00000 00407 | .00 00 00 EF | .00000 00556 |
| .00 00 00 30 | .00000 00111 | .00 00 00 70 | .00000 00260 | .00 00 00 B0 | .00000 00409 | .00 00 00 F0 | .00000 00558 |
| .00 00 00 31 | .00000 00114 | .00 00 00 71 | .00000 00263 | .00 00 00 B1 | .00000 00412 | .00 00 00 F1 | .00000 00561 |
| .00 00 00 32 | .00000 00116 | .00 00 00 72 | .00000 00265 | .00 00 00 B2 | .00000 00414 | .00 00 00 F2 | .00000 00563 |
| .00 00 033   | .00000 00118 | .00 00 00 73 | .00000 00267 | .00 00 00 B3 | .00000 00416 | .00 00 00 F3 | .00000 00565 |
| .00 00 00 34 | .00000 00121 | .00 00 00 74 | .00000 00270 | .00 00 00 B4 | .00000 00419 | .00 00 00 F4 | .00000 00568 |
| .00 00 00 35 | .00000 00123 | .00 00 00 75 | .00000 00272 | .00 00 00 B5 | .00000 00421 | .00 00 00 F5 | .00000 00570 |
| .00 00 00 36 | .00000 00125 | .00 00 00 76 | .00000 00274 | .00 00 00 B6 | .00000 00423 | .00 00 00 F6 | .00000 00572 |
| .00 00 00 37 | .00000 00128 | .00 00 00 77 | .00000 00277 | .00 00 00 B7 | .00000 00426 | .00 00 00 F7 | .00000 00575 |
| .00 00 00 38 | .00000 00130 | .00 00 00 78 | .00000 00279 | .00 00 00 B8 | .00000 00428 | .00 00 00 F8 | .00000 00577 |
| .00 00 00 39 | .00000 00132 | .00 00 00 79 | .00000 00281 | .00 00 00 B9 | .00000 00430 | .00 00 00 F9 | .00000 00579 |
| .00 00 00 3A | .00000 00135 | .00 00 00 7A | .00000 00284 | .00 00 00 BA | .00000 00433 | .00 00 00 FA | .00000 00582 |
| .00 00 00 3B | .00000 00137 | .00 00 00 7B | .00000 00286 | .00 00 00 BB | .00000 00435 | .00 00 00 FB | .00000 00584 |
| .00 00 00 3C | .00000 00139 | .00 00 00 7C | .00000 00288 | .00 00 00 BC | .00000 00437 | .00 00 00 FC | .00000 00586 |
| .00 00 00 3D | .00000 00142 | .00 00 00 7D | .00000 00291 | .00 00 00 BD | .00000 00440 | .00 00 00 FD | .00000 00589 |
| .00 00 00 3E | .00000 00144 | .00 00 00 7E | .00000 00293 | .00 00 00 BE | .00000 00442 | .00 00 00 FE | .00000 00591 |
| .00 00 00 3F | .00000 00146 | .00 00 00 7F | .00000 00295 | .00 00 00 BF | .00000 00444 | .00 00 00 FF | .00000 00593 |

# HEXADECIMAL-DECIMAL FRACTION CONVERSION TABLE (cont.)

| Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      |
|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|
| .00 00 00 00                 | .00000 00000                 | .00 00 40 00                 | .00000 38146                 | .00 00 80 00                 | .00000 76293                 | .00 00 C0 00                 | .00001 14440                 |
| .00 00 01 00                 | .00000 00596                 | .00 00 41 00                 | .00000 38743                 | .00 00 81 00                 | .00000 76889                 | .00 00 C1 00                 | .00001 15036                 |
| .00 00 02 00                 | .00000 01192                 | .00 00 42 00                 | .00000 39339                 | .00 00 82 00                 | .00000 77486                 | .00 00 C2 00                 | .00001 15633                 |
| .00 00 03 00<br>.00 00 04 00 | .00000 01788<br>.00000 02384 | .00 00 43 00<br>.00 00 44 00 | .00000 39935<br>.00000 40531 | .00 00 83 00                 | .00000 78082                 | .00 00 C3 00                 | .00001 16229                 |
| .00 00 04 00                 | .00000 02384                 | .00 00 44 00                 | .00000 40331                 | .00 00 84 00<br>.00 00 85 00 | .00000 78678<br>.00000 79274 | .00 00 C4 00<br>.00 00 C5 00 | .00001 16825<br>.00001 17421 |
| .00 00 06 00                 | .00000 03576                 | .00 00 46 00                 | .00000 41723                 | .00 00 86 00                 | .00000 79870                 | .00 00 C5 00                 | .00001 17421                 |
| .00 00 07 00                 | .00000 04172                 | .00 00 47 00                 | .00000 42319                 | .00 00 87 00                 | .00000 80466                 | .00 00 C7 00                 | .00001 18613                 |
| .00 00 08 00                 | .00000 04768                 | .00 00 48 00                 | .00000 42915                 | .00 00 88 00                 | .00000 81062                 | .00 00 C8 00                 | .00001 19209                 |
| .00 00 09 00                 | .00000 05364                 | .00 00 49 00                 | .00000 43511                 | .00 00 89 00                 | .00000 81658                 | .00 00 C9 00                 | .00001 19805                 |
| .00 00 0A 00                 | .00000 05960                 | .00 00 4A 00                 | .00000 44107                 | .00 00 8A 00                 | .00000 82254                 | .00 00 CA 00                 | .00001 20401                 |
| .00 00 0B 00                 | .00000 06556                 | .00 00 4B 00                 | .00000 44703                 | .00 00 88 00                 | .00000 82850                 | .00 00 CB 00                 | .00001 20997                 |
| .00 00 0C 00                 | .00000 07152                 | .00 00 4C 00                 | .00000 45299                 | .00 00 8C 00                 | .00000 83446                 | .00 00 CC 00                 | .00001 21593                 |
| .00 00 0D 00<br>.00 00 0E 00 | .00000 07748                 | .00 00 4D 00                 | .00000 45895                 | .00 00 8D 00                 | .00000 84042                 | .00 00 CD 00                 | .00001 22189                 |
| .00 00 0E 00                 | .00000 08344<br>.00000 08940 | .00 00 4E 00<br>.00 00 4F 00 | .00000 46491<br>.00000 47087 | .00 00 8E 00<br>.00 00 8F 00 | .00000 84638<br>.00000 85234 | .00 00 CE 00                 | .00001 22785<br>.00001 23381 |
|                              |                              |                              |                              |                              |                              | .00 00 CF 00                 |                              |
| .00 00 10 00                 | .00000 09536                 | .00 00 50 00                 | .00000 47683                 | .00 00 90 00                 | .00000 85830                 | .00 00 D0 00                 | .00001 23977                 |
| .00 00 11 00<br>.00 00 12 00 | .00000 10132                 | .00 00 51 00                 | .00000 48279                 | .00 00 91 00                 | .00000 86426                 | .00 00 D1 00                 | .00001 24573                 |
| .00 00 12 00                 | .00000 10728<br>.00000 11324 | .00 00 52 00<br>.00 00 53 00 | .00000 48875<br>.00000 49471 | .00 00 92 00                 | .00000 87022<br>.00000 87618 | .00 00 D2 00                 | .00001 25169<br>.00001 25765 |
| .00 00 13 00                 | .00000 11324                 | .00 00 53 00                 | .00000 50067                 | .00 00 93 00                 | .00000 87818                 | .00 00 D3 00<br>.00 00 D4 00 | .00001 25765                 |
| .00 00 15 00                 | .00000 12516                 | .00 00 55 00                 | .00000 50663                 | .00 00 95 00                 | .00000 88810                 | .00 00 D4 00                 | .00001 26957                 |
| .00 00 16 00                 | .00000 13113                 | .00 00 56 00                 | .00000 51259                 | .00 00 96 00                 | .00000 89406                 | .00 00 D6 00                 | .00001 27553                 |
| .00 00 17 00                 | .00000 13709                 | .00 00 57 00                 | .00000 51856                 | .00 00 97 00                 | .00000 90003                 | .00 00 D7 00                 | .00001 28149                 |
| .00 00 18 00                 | .00000 14305                 | .00 00 58 00                 | .00000 52452                 | .00 00 98 00                 | .00000 90599                 | .00 00 D8 00                 | .00001 28746                 |
| .00 00 19 00                 | .00000 14901                 | .00 00 59 00                 | .00000 53048                 | .00 00 99 00                 | .00000 91195                 | .00 00 D9 00                 | .00001 29342                 |
| .00 00 1A 00                 | .00000 15497                 | .00 00 5A 00                 | .00000 53644                 | .00 00 9A 00                 | .00000 91791                 | .00 00 DA 00                 | .00001 29938                 |
| .00 00 1B 00                 | .00000 16093                 | .00 00 5B 00                 | .00000 54240                 | .00 00 9B 00                 | .00000 92387                 | .00 00 DB 00                 | .00001 30534                 |
| .00 00 1C 00<br>.00 00 1D 00 | .00000 16689<br>.00000 17285 | .00 00 5C 00<br>.00 00 5D 00 | .00000 54836<br>.00000 55432 | .00 00 9C 00<br>.00 00 9D 00 | .00000 92983<br>.00000 93579 | .00 00 DC 00                 | .00001 31130                 |
| .00 00 1E 00                 | .00000 17283                 | .00 00 5D 00                 | .00000 55432                 | .00 00 9D 00                 | .00000 93579                 | .00 00 DD 00<br>.00 00 DE 00 | .00001 31726<br>.00001 32322 |
| .00 00 1F 00                 | .00000 18477                 | .00 00 5F 00                 | .00000 56624                 | .00 00 9F 00                 | .00000 94771                 | .00 00 DE 00                 | .00001 32918                 |
| .00 00 20 00                 | .00000 19073                 | .00 00 60 00                 | .00000 57220                 | .00 00 A0 00                 | .00000 95367                 | .00 00 E0 00                 | .00001 33514                 |
| .00 00 21 00                 | .00000 19669                 | .00 00 61 00                 | .00000 57816                 | .00 00 A1 00                 | .00000 95963                 | .00 00 E1 00                 | .00001 34110                 |
| .00 00 22 00                 | .00000 20265                 | .00 00 62 00                 | .00000 58412                 | .00 00 A2 00                 | .00000 96559                 | .00 00 E2 00                 | .00001 34706                 |
| .00 00 23 00                 | .00000 20861                 | .00 00 63 00                 | .00000 59008                 | .00 00 A3 00                 | .00000 97155                 | .00 00 E3 00                 | .00001 35302                 |
| .00 00 24 00                 | .00000 21457                 | .00 00 64 00                 | .00000 59604                 | .00 00 A4 00                 | .00000 97751                 | .00 00 E4 00                 | .00001 35898                 |
| .00 00 25 00<br>.00 00 26 00 | .00000 22053<br>.00000 22649 | .00 00 65 00<br>.00 00 66 00 | .00000 60200<br>.00000 60796 | .00 00 A5 00                 | .00000 98347                 | .00 00 E5 00                 | .00001 36494                 |
| .00 00 27 00                 | .00000 23245                 | .00 00 67 00                 | .00000 61392                 | .00 00 A6 00<br>.00 00 A7 00 | .00000 98943<br>.00000 99539 | .00 00 E6 00<br>.00 00 E7 00 | .00001 37090<br>.00001 37686 |
| .00 00 28 00                 | .00000 23841                 | .00 00 68 00                 | .00000 61988                 | .00 00 A8 00                 | .00001 00135                 | .00 00 E7 00                 | .00001 38282                 |
| .00 00 29 00                 | .00000 24437                 | .00 00 69 00                 | .00000 62584                 | .00 00 A9 00                 | .00001 00731                 | .00 00 E9 00                 | .00001 38878                 |
| .00 00 2A 00                 | .00000 25033                 | .00 00 6A 00                 | .00000 63180                 | .00 00 AA 00                 | .00001 01327                 | .00 00 EA 00                 | .00001 39474                 |
| .00 00 2B 00                 | .00000 25629                 | .00 00 6B 00                 | .00000 63776                 | .00 00 AB 00                 | .00001 01923                 | .00 00 EB 00                 | .00001 40070                 |
| .00 00 2C 00                 | .00000 26226                 | .00 00 6C 00                 | .00000 64373                 | .00 00 AC 00                 | .00001 02519                 | .00 00 EC 00                 | .00001 40666                 |
| .00 00 2D 00                 | .00000 26822                 | .00 00 6D 00                 | .00000 64969                 | .00 00 AD 00                 | .00001 03116                 | .00 00 ED 00                 | .00001 41263                 |
| .00 00 2E 00<br>.00 00 2F 00 | .00000 27418<br>.00000 28014 | .00 00 6E 00<br>.00 00 6F 00 | .00000 65565<br>.00000 66161 | .00 00 AE 00<br>.00 00 AF 00 | .00001 03712                 | .00 00 EE 00                 | .00001 41859                 |
| .00 00 21 00                 |                              |                              |                              |                              | .00001 04308                 | .00 00 EF 00                 | .00001 42455                 |
| .00 00 30 00                 | .00000 28610<br>.00000 29206 | .00 00 70 00<br>.00 00 71 00 | .00000 66757                 | .00 00 B0 00                 | .00001 04904                 | .00 00 F0 00                 | .00001 43051                 |
| .00 00 31 00                 | .00000 29206                 | .00 00 71 00                 | .00000 67353<br>.00000 67949 | .00 00 B1 00<br>.00 00 B2 00 | .00001 05500<br>.00001 06096 | .00 00 F1 00<br>.00 00 F2 00 | .00001 43647<br>.00001 44243 |
| .00 00 32 00                 | .00000 27802                 | .00 00 72 00                 | .00000 68545                 | .00 00 B2 00                 | .00001 06098                 | .00 00 F2 00                 | .00001 44243                 |
| .00 00 34 00                 | .00000 30994                 | .00 00 74 00                 | .00000 69141                 | .00 00 B3 00                 | .00001 07288                 | .00 00 F4 00                 | .00001 44837                 |
| .00 00 35 00                 | .00000 31590                 | .00 00 75 00                 | .00000 69737                 | .00 00 B5 00                 | .00001 07884                 | .00 00 F5 00                 | .00001 46031                 |
| .00 00 36 00                 | .00000 32186                 | .00 00 76 00                 | .00000 70333                 | .00 00 B6 00                 | .00001 08480                 | .00 00 F6 00                 | .00001 46627                 |
| .00 00 37 00                 | .00000 32782                 | .00 00 77 00                 | .00000 70929                 | .00 00 B7 00                 | .00001 09076                 | .00 00 F7 00                 | .00001 47223                 |
| .00 00 38 00                 | .00000 33378                 | .00 00 78 00                 | .00000 71525                 | .00 00 B8 00                 | .00001 09672                 | .00 00 F8 00                 | .00001 47819                 |
| .00 00 39 00                 | .00000 33974                 | .00 00 79 00                 | .00000 72121                 | .00 00 B9 00                 | .00001 10268                 | .00 00 F9 00                 | .00001 48415                 |
| .00 00 3A 00                 | .00000 34570                 | .00 00 7A 00                 | .00000 72717                 | .00 00 BA 00                 | .00001 10864                 | .00 00 FA 00                 | .00001 49011                 |
| .00 00 3B 00<br>.00 00 3C 00 | .00000 35166<br>.00000 35762 | .00 00 7B 00<br>.00 00 7C 00 | .00000 73313<br>.00000 73909 | .00 00 BB 00<br>.00 00 BC 00 | .00001 11460<br>.00001 12056 | .00 00 FB 00<br>.00 00 FC 00 | .00001 49607<br>.00001 50203 |
| .00 00 3C 00                 | .00000 36358                 | .00 00 7C 00                 | .00000 73909                 | .00 00 BC 00                 | .00001 12058                 | .00 00 FC 00                 | .00001 50203                 |
| .00 00 3E 00                 | .00000 36954                 | .00 00 7E 00                 | .00000 75101                 | .00 00 BD 00                 | .00001 12032                 | .00 00 FE 00                 | .00001 51395                 |
| .00 00 3F 00                 | .00000 37550                 | .00 00 7F 00                 | .00000 75697                 | .00 00 BF 00                 | .00001 13844                 | .00 00 FF 00                 | .00001 51991                 |
|                              |                              |                              |                              |                              |                              |                              |                              |

# HEXADECIMAL-DECIMAL FRACTION CONVERSION TABLE (cont.)

| Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      |
|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|
| .00 00 00 00                 | .00000 00000                 | .00 40 00 00                 | .00097 65625                 | .00 80 `00 00                | .00195 31250                 | .00 C0 00 00                 | .00292 96875                 |
| .00 01 00 00                 | .00001 52587                 | .00 41 00 00                 | .00099 18212                 | .00 81 00 00                 | .00196 83837                 | .00 C1 00 00                 | .00294 49462                 |
| .00 02 00 00                 | .00003 05175                 | .00 42 00 00                 | .00100 70800                 | .00 82 00 00                 | .00198 36425                 | .00 C2 00 00                 | .00296 02050                 |
| .00 03 00 00                 | .00004 57763                 | .00 43 00 00                 | .00102 23388                 | .00 83 00 00                 | .00199 89013                 | .00 C3 00 00                 | .00297 54638                 |
| .00 04 00 00                 | .00006 10351                 | .00 44 00 00                 | .00103 75976                 | .00 84 00 00                 | .00201 41601                 | .00 C4 00 00                 | .00299 07225                 |
| .00 05 00 00                 | .00007 62939                 | .00 45 00 00                 | .00105 28564                 | .00 85 00 00                 | .00202 94189                 | .00 C5 00 00                 | .00300 59814                 |
| .00 06 00 00<br>.00 07 00 00 | .00009 15527<br>.00010 68115 | .00 46 00 00                 | .00106 81152                 | .00 86 00 00                 | .00204 46777                 | .00 C6 00 00                 | .00302 12402                 |
| .00 07 00 00                 | .00012 20703                 | .00 47 00 00<br>.00 48 00 00 | .00108 33740<br>.00109 86328 | .00 87 00 00<br>.00 88 00 00 | .00205 99365                 | .00 C7 00 00                 | .00303 64990                 |
| .00 09 00 00                 | .00013 73291                 | .00 48 00 00                 | .00107 88328                 | .00 88 00 00                 | .00207 51953<br>.00209 04541 | .00 C8 00 00<br>.00 C9 00 00 | .00305 17578<br>.00306 70166 |
| .00 0A 00 00                 | .00015 25878                 | .00 4A 00 00                 | .00112 91503                 | .00 8A 00 00                 | .00210 57128                 | .00 CA 00 00                 | .00308 22753                 |
| .00 OB 00 00                 | .00016 78466                 | .00 4B 00 00                 | .00114 44091                 | .00 88 00 00                 | .00212 09716                 | .00 CA 00 00                 | .00309 75341                 |
| .00 0C 00 00                 | .00018 31054                 | .00 4C 00 00                 | .00115 96679                 | .00 8C 00 00                 | .00213 62304                 | .00 CC 00 00                 | .00311 27929                 |
| .00 0D 00 00                 | .00019 83642                 | .00 4D 00 00                 | .00117 49267                 | .00 8D 00 00                 | .00215 14892                 | .00 CD 00 00                 | .00312 80517                 |
| .00 OE 00 00                 | .00021 36230                 | .00 4E 00 00                 | .00119 01855                 | .00 8E 00 00                 | .00216 67480                 | .00 CE 00 00                 | .00314 33105                 |
| .00 OF 00 00                 | .00022 88818                 | .00 4F 00 00                 | .00120 54443                 | .00 8F 00 00                 | .00218 20068                 | .00 CF 00 00                 | .00315 85693                 |
| .00 10 00 00<br>.00 11 00 00 | .00024 41406<br>.00025 93994 | .00 50 00 00                 | .00122 07031                 | .00 90 00 00                 | .00219 72656                 | .00 D0 00 00                 | .00317 38281                 |
| .00 12 00 00                 | .00025 93994<br>.00027 46582 | .00 51 00 00<br>.00 52 00 00 | .00123 59619                 | .00 91 00 00                 | .00221 25244                 | .00 D1 00 00                 | .00318 90869                 |
| .00 12 00 00                 | .00027 48382                 | .00 53 00 00                 | .00125 12207<br>.00126 64794 | .00 92 00 00<br>.00 93 00 00 | .00222 77832                 | .00 D2 00 00                 | .00320 43457                 |
| .00 13 00 00                 | .00030 51757                 | .00 54 00 00                 | .00128 17382                 | .00 93 00 00                 | .00224 30419<br>.00225 83007 | .00 D3 00 00<br>.00 D4 00 00 | .00321 96044<br>.00323 48632 |
| .00 15 00 00                 | .00032 04345                 | .00 55 00 00                 | .00129 69970                 | .00 95 00 00                 | .00227 35595                 | .00 D4 00 00                 | .00325 01220                 |
| .00 16 00 00                 | .00033 56933                 | .00 56 00 00                 | .00131 22558                 | .00 96 00 00                 | .00228 88183                 | .00 D6 00 00                 | .00326 53808                 |
| .00 17 00 00                 | .00035 09521                 | .00 57 00 00                 | .00132 75146                 | .00 97 00 00                 | .00230 40771                 | .00 D7 00 00                 | .00328 06396                 |
| .00 18 00 00                 | .00036 62109                 | .00 58 00 00                 | .00134 27734                 | .00 98 00 00                 | .00231 93359                 | .00 D8 00 00                 | .00329 58984                 |
| .00 19 00 00                 | .00038 14697                 | .00 59 00 00                 | .00135 80322                 | .00 99 00 00                 | .00233 45947                 | .00 D9 00 00                 | .00331 11572                 |
| .00 1A 00 00                 | .00039 67285                 | .00 5A 00 00                 | .00137 32910                 | .00 9A 00 00                 | .00234 98535                 | .00 DA 00 00                 | .00332 64160                 |
| .00 1B 00 00                 | .00041 19873                 | .00 5B 00 00                 | .00138 85498                 | .00 9B 00 00                 | .00236 51123                 | .00 DB 00 00                 | .00334 16748                 |
| .00 1C 00 00                 | .00042 72460                 | .00 5C 00 00                 | .00140 38085                 | .00 9C 00 00                 | .00238 03710                 | .00 DC 00 00                 | .00335 69335                 |
| .00 1D 00 00                 | .00044 25048                 | .00 5D 00 00                 | .00141 90673                 | .00 9D 00 00                 | .00239 56298                 | .00 DD 00 00                 | .00337 21923                 |
| .00 1E 00 00                 | .00045 77636                 | .00 5E 00 00                 | .00143 43261                 | .00 9E 00 00                 | .00241 08886                 | .00 DE 00 00                 | .00338 74511                 |
| .00 1F 00 00                 | .00047 30224                 | .00 5F 00 00                 | .00144 95849                 | .00 9F 00 00                 | .00242 61474                 | .00 DF 00 00                 | .00340 27099                 |
| .00 20 00 00                 | .00043 82812                 | .00 60 00 00                 | .00146 48437                 | .00 A0 00 00                 | .00244 14062                 | .00 E0 00 00                 | .00341 79687                 |
| .00 21 00 00                 | .00050 35400                 | .00 61 00 00                 | .00148 01025                 | .00 A1 00 00                 | .00245 66650                 | .00 E1 00 00                 | .00343 32275                 |
| .00 22 00 00                 | .00051 87988                 | .00 62 00 00                 | .00149 53613                 | .00 A2 00 00                 | .00247 19238                 | .00 E2 00 00                 | .00344 84863                 |
| .00 23 00 00                 | .00053 40576                 | .00 63 00 00                 | .00151 06201                 | .00 A3 00 00                 | .00248 71826                 | .00 E3 00 00                 | .00346 37451                 |
| .00 24 00 00<br>.00 25 00 00 | .00054 93164<br>.00056 45751 | .00 64 00 00<br>.00 65 00 00 | .00152 58789<br>.00154 11376 | .00 A4 00 00                 | .00250 24414                 | .00 E4 00 00                 | .00347 90039                 |
| .00 25 00 00                 | .00057 98339                 | .00 85 00 00                 | .00155 63964                 | .00 A5 00 00<br>.00 A6 00 00 | .00251 77001<br>.00253 29589 | .00 E5 00 00<br>.00 E6 00 00 | .00349 42626<br>.00350 95214 |
| .00 27 00 00                 | .00059 50927                 | .00 67 00 00                 | .00157 16552                 | .00 A7 00 00                 | .00254 82177                 | .00 E7 00 00                 | .00352 47802                 |
| .00 28 00 00                 | .00061 03515                 | .00 68 00 00                 | .00158 69140                 | .00 A8 00 00                 | .00256 34765                 | .00 E8 00 00                 | .00354 00390                 |
| .00 29 00 00                 | .00062 56103                 | .00 69 00 00                 | .00160 21728                 | .00 A9 00 00                 | .00257 87353                 | .00 E9 00 00                 | .00355 52978                 |
| .00 2A 00 00                 | .00064 08691                 | .00 6A 00 00                 | .00161 74316                 | .00 AA 00 00                 | .00259 39941                 | .00 EA 00 00                 | .00357 05566                 |
| .00 2B 00 00                 | .00065 61279                 | .00 6B 00 00                 | .00163 26904                 | .00 AB 00 00                 | .00260 92529                 | .00 EB 00 00                 | .00358 58154                 |
| .00 2C 00 00                 | .00067 13867                 | .00 6C 00 00                 | .00164 79492                 | .00 AC 00 00                 | .00262 45117                 | .00 EC 00 00                 | .00360 10742                 |
| .00 2D 00 00                 | .00068 66455                 | .00 6D 00 00                 | .00166 32080                 | .00 AD 00 00                 | .00263 97705                 | .00 ED 00 00                 | .00361 63330                 |
| .00 2E 00 00                 | .00070 19042                 | .00 6E 00 00                 | .00167 84667                 | .00 AE 00 00                 | .00265 50292                 | .00 EE 00 00                 | .00363 15917                 |
| .00 2F 00 00                 | .00071 71630                 | .00 6F 00 00                 | .00169 37255                 | .00 AF 00 00                 | .00267 02880                 | .00 EF 00 00                 | .00364 68505                 |
| .00 30 00 00                 | .00073 24218                 | .00 70 00 00                 | .00170 89843                 | .00 B0 00 00                 | .00268 55468                 | .00 F0 00 00                 | .00366 21093                 |
| .00 31 00 00                 | .00074 76806                 | .00 71 00 00                 | .00172 42431                 | .00 B1 00 00                 | .00270 08056                 | .00 F1 00 00                 | .00367 73681                 |
| .00 32 00 00                 | .00076 29394                 | .00 72 00 00                 | .00173 95019                 | .00 B2 00 00                 | .00271 60644                 | .00 F2 00 00                 | .00369 26269                 |
| .00 33 00 00<br>.00 34 00 00 | .00077 81982<br>.00079 34570 | .00 73 00 00<br>.00 74 00 00 | .00175 47607                 | .00 B3 00 00                 | .00273 13232                 | .00 F3 00 00                 | .00370 78857                 |
| .00 35 00 00                 | .00079 34570                 | .00 75 00 00                 | .00177 00195<br>.00178 52783 | .00 B4 00 00<br>.00 B5 00 00 | .00274 65820<br>.00276 18408 | .00 F4 00 00<br>.00 F5 00 00 | .00372 31445<br>.00373 84033 |
| .00 36 00 00                 | .00082 39746                 | .00 76 00 00                 | .00180 05371                 | .00 B5 00 00                 | .00278 18408                 | .00 F5 00 00                 | .00373 84033                 |
| .00 37 00 00                 | .00083 92333                 | .00 77 00 00                 | .00181 57958                 | .00 B7 00 00                 | .00279 23583                 | .00 F7 00 00                 | .00376 89208                 |
| .00 38 00 00                 | .00085 44921                 | .00 78 00 00                 | .00183 10546                 | .00 B8 00 00                 | .00280 76171                 | .00 F8 00 00                 | .00378 41796                 |
| .00 39 00 00                 | .00086 97509                 | .00 79 00 00                 | .00184 63134                 | .00 B9 00 00                 | .00282 28759                 | .00 F9 00 00                 | .00379 94384                 |
| .00 3A 00 00                 | .00088 50097                 | .00 7A 00 00                 | .00186 15722                 | .00 BA 00 00                 | .00283 81347                 | .00 FA 00 00                 | .00381 46972                 |
| .00 3B 00 00                 | .00090 02685                 | .00 7B 00 00                 | .00187 68310                 | .00 BB 00 00                 | .00285 33935                 | .00 FB 00 00                 | .00382 99550                 |
| .00 3C 00 00                 | .00091 55273                 | .00 7C 00 00                 | .00189 20898                 | .00 BC 00 00                 | .00286 86523                 | .00 FC 00 00                 | .00384 52148                 |
| .00 3D 00 00                 | .00093 07861                 | .00 7D 00 00                 | .00190 73486                 | .00 BD 00 00                 | .00288 39111                 | .00 FD 00 00                 | .00386 04736                 |
| .00 3E 00 00                 | .00094 60449                 | .00 7E 00 00                 | .00192 26074                 | .00 BE 00 00                 | .00289 91699                 | .00 FE 00 00                 | .00387 57324                 |
| .00 3F 00 00                 | .00096 13037                 | .00 7F 00 00                 | .00193 78662                 | .00 BF 00 00                 | .00291 44287                 | .00 FF 00 00                 | .00389 09912                 |

## HEXADECIMAL-DECIMAL FRACTION CONVERSION TABLE (cont.)

| Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      | Hexadecimal                  | Decimal                      |
|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|
| .00 00 00 00                 | .00000 00000                 | .40 00 00 00                 | .25000 00000                 | .80 00 00 00                 | .50000 00000                 | .C0 00 00 00                 | .75000 00000                 |
| .01 00 00 00                 | .00390 62500                 | .41 00 00 00                 | .25390 62500                 | .81 00 00 00                 | .50390 62500                 | .C1 00 00 00                 | .75390 62500                 |
| .02 00 00 00                 | .00781 25000                 | .42 00 00 00                 | .25781 25000                 | .82 00 00 00                 | .50781 25000                 | .C2 00 00 00                 | .75781 25000                 |
| .03 00 00 00                 | .01171 87500                 | .43 00 00 00                 | .26171 87500                 | .83 00 00 00                 | .51171 87500                 | .C3 00 00 00                 | .76171 87500                 |
| .04 00 00 00<br>.05 00 00 00 | .01562 50000<br>.01953 12500 | .44 00 00 00                 | .26562 50000                 | .84 00 00 00                 | .51562 50000                 | .C4 00 00 00                 | .76562 50000                 |
| .05 00 00 00                 |                              | .45 00 00 00                 | .26953 12500                 | .85 00 00 00                 | .51953 12500                 | .C5 00 00 00                 | .76953 12500                 |
| .07 00 00 00                 | .02343 75000<br>.02734 37500 | .46 00 00 00 .47 00 00 00    | .27343 75000<br>.27734 37500 | .86 00 00 00<br>.87 00 00 00 | .52343 75000                 | .C6 00 00 00                 | .77343 75000                 |
| .08 00 00 00                 | .03125 00000                 | .48 00 00 00                 | .28125 00000                 | .88 00 00 00                 | .52734 37500<br>.53125 00000 | .C7 00 00 00<br>.C8 00 00 00 | .77734 37500<br>.78125 00000 |
| .09 00 00 00                 | .03515 62500                 | .48 00 00 00                 | .28515 62500                 | .89 00 00 00                 | .53515 62500                 | .C9 00 00 00                 | .78515 62500                 |
| .0A 00 00 00                 | .03906 25000                 | .47 00 00 00                 | .28906 25000                 | .87 00 00 00<br>.8A 00 00 00 | .53906 25000                 | .CA 00 00 00                 | .78906 25000                 |
| .0B 00 00 00                 | .04296 87500                 | .4B 00 00 00                 | .29296 87500                 | .8A 00 00 00                 | .54296 87500                 | .CB 00 00 00                 | .79296 87500                 |
| .0C 00 00 00                 | .04687 50000                 | .4C 00 00 00                 | .29687 50000                 | .8C 00 00 00                 | .54687 50000                 | .CC 00 00 00                 | .79687 50000                 |
| .0D 00 00 00                 | .05078 12500                 | .4C 00 00 00                 | .30078 12500                 | .8C 00 00 00                 | .55078 12500                 | .CD 00 00 00                 | .80078 12500                 |
| .0E 00 00 00                 | .05468 75000                 | .4E 00 00 00                 | .30468 75000                 | .8E 00 00 00                 | .55468 75000                 | .CE 00 00 00                 | .80468 75000                 |
| .0F 00 00 00                 | .05859 37500                 | .4F 00 00 00                 | .30859 37500                 | .8F 00 00 00                 | .55859 37500                 | .CF 00 00 00                 | .80859 37500                 |
|                              |                              |                              |                              |                              |                              |                              |                              |
| .10 00 00 00                 | .06250 00000                 | .50 00 00 00                 | .31250 00000                 | .90 00 00 00                 | .56250 00000                 | .D0 00 00 00                 | .81250 00000                 |
| .11 00 00 00                 | .06640 62500                 | .51 00 00 00                 | .31640 62500                 | .91 00 00 00                 | .56640 62500                 | .D1 00 00 00                 | .81640 62500                 |
| .12 00 00 00                 | .07031 25000                 | .52 00 00 00                 | .32031 25000                 | .92 00 00 00                 | .57031 25000                 | .D2 00 00 00                 | .82031 25000                 |
| .13 00 00 00<br>.14 00 00 00 | .07421 87500<br>.07812 50000 | .53 00 00 00<br>.54 00 00 00 | .32421 87500                 | .93 00 00 00                 | .57421 87500                 | .D3 00 00 00                 | .82421 87500                 |
| .14 00 00 00                 | .08203 12500                 |                              | .32812 50000                 | .94 00 00 00                 | .57812 50000                 | .D4 00 00 00                 | .82812 50000                 |
| .16 00 00 00                 | .08203 72300                 | .55 00 00 00                 | .33203 12500                 | .95 00 00 00                 | .58203 12500                 | .D5 00 00 00                 | .83203 12500                 |
| .17 00 00 00                 | .08984 37500                 |                              | .33593 75000                 | .96 00 00 00                 | .58593 75000                 | .D6 00 00 00                 | .83593 75000                 |
| .18 00 00 00                 | .09375 00000                 | .57 00 00 00<br>.58 00 00 00 | .33984 37500                 | .97 00 00 00                 | .58984 37500                 | .D7 00 00 00                 | .83984 37500                 |
| .19 00 00 00                 | .09765 62500                 | .59 00 00 00                 | .34375 00000<br>.34765 62500 | .98 00 00 00<br>.99 00 00 00 | .59375 00000<br>.59765 62500 | .D8 00 00 00<br>.D9 00 00 00 | .84375 00000<br>.84765 62500 |
| .1A 00 00 00                 | .10156 25000                 | .57 00 00 00                 | .35156 25000                 | .97 00 00 00<br>.9A 00 00 00 | .60156 25000                 | .DA 00 00 00                 | .85156 25000                 |
| .1B 00 00 00                 | .10546 87500                 | .5B 00 00 00                 | .35546 87500                 | .9B 00 00 00                 | .60546 87500                 | .DB 00 00 00                 | .85546 87500                 |
| .1C 00 00 00                 | .10937 50000                 | .5C 00 00 00                 | .35937 50000                 | .9C 00 00 00                 | .60937 50000                 | .DC 00 00 00                 | .85937 50000                 |
| .1D 00 00 00                 | .11328 12500                 | .5D 00 00 00                 | .36328 12500                 | .9D 00 00 00                 | .61328 12500                 | .DC 00 00 00                 | .86328 12500                 |
| .1E 00 00 00                 | .11718 75000                 | .5E 00 00 00                 | .36718 75000                 | .9E 00 00 00                 | .61718 75000                 | .DE 00 00 00                 | .86718 75000                 |
| .1F 00 00 00                 | .12109 37500                 | .5F 00 00 00                 | .37109 37500                 | .9F 00 00 00                 | .62109 37500                 | .DF 00 00 00                 | .87109 37500                 |
| .20 00 00 00                 | .12500 00000                 | .60 00 00 00                 | .37500 00000                 | .A0 00 00 00                 | .62500 00000                 | .E0 00 00 00                 | .87500 00000                 |
| .21 00 00 00                 | .12890 62500                 | .61 00 00 00                 | .37890 62500                 | .A1 00 00 00                 | .62890 62500                 | .E1 00 00 00                 | .87890 62500                 |
| .22 00 00 00                 | .13281 25000                 | .62 00 00 00                 | .38281 25000                 | .A2 00 00 00                 | .63281 25000                 | .E2 00 00 00                 | .88281 25000                 |
| .23 00 00 00                 | .13671 87500                 | .63 00 00 00                 | .38671 87500                 | .A3 00 00 00                 | .63671 87500                 | .E3 00 00 00                 | .88671 87500                 |
| .24 00 00 00                 | . 14062 50000                | .64 00 00 00                 | .39062 50000                 | .A4 00 00 00                 | .64062 50000                 | .E4 00 00 00                 | .89062 50000                 |
| .25 00 00 00                 | .14453 12500                 | .65 00 00 00                 | .39453 12500                 | .A5 00 00 00                 | .64453 12500                 | .E5 00 00 00                 | .89453 12500                 |
| .26 00 00 00                 | .14843 75000                 | .66 00 00 00                 | .39843 75000                 | .A6 00 00 00                 | .64843 75000                 | .E6 00 00 00                 | .89843 75000                 |
| .27 00 00 00                 | .15234 37500                 | .67 00 00 00                 | .40234 37500                 | .A7 00 00 00                 | .65234 37500                 | .E7 00 00 00                 | .90234 37500                 |
| .28 00 00 00                 | .15625 00000                 | .68 00 00 00                 | .40625 00000                 | .A8 00 00 00                 | .65625 00000                 | .E8 00 00 00                 | .90625 00000                 |
| .29 00 00 00                 | .16015 62500                 | .69 00 00 00                 | .41015 62500                 | .A9 00 00 00                 | .66015 62500                 | .E9 00 00 00                 | .91015 62500                 |
| .2A 00 00 00                 | .16406 25000                 | .6A 00 00 00                 | .41406 25000                 | .AA 00 00 00                 | .66406 25000                 | .EA 00 00 00                 | .91406 25000                 |
| .28 00 00 00                 | .16796 87500                 | .6B 00 00 00                 | .41796 87500                 | .AB 00 00 00                 | .66796 87500                 | .EB 00 00 00                 | .91796 87500                 |
| .2C 00 00 00                 | .17187 50000                 | .6C 00 00 00                 | .42187 50000                 | .AC 00 00 00                 | .67187 50000                 | .EC 00 00 00                 | .92187 50000                 |
| .2D 00 00 00                 | .17578 12500                 | .6D 00 00 00                 | .42578 12500                 | .AD 00 00 00                 | .67578 12500                 | .ED 00 00 00                 | .92578 12500                 |
| .2E 00 00 00                 | .17968 75000                 | .6E 00 00 00                 | .42968 75000                 | .AE 00 00 00                 | .67968 75000                 | .EE 00 00 00                 | .92968 75000                 |
| .2F 00 00 00                 | .18359 37500                 | .6F 00 00 00                 | .43359 37500                 | .AF 00 00 00                 | .68359 37500                 | .EF 00 00 00                 | .93359 37500                 |
| .30 00 00 00                 | .18750 00000                 | .70 00 00 00                 | .43750 00000                 | .BO 00 00 00                 | .68750 00000                 | .F0 00 00 00                 | .93750 00000                 |
| .31 00 00 00                 | .19140 62500                 | .71 00 00 00                 | .44140 62500                 | .B1 00 00 00                 | .69140 62500                 | .F1 00 00 00                 | .94140 62500                 |
| .32 00 00 00                 | .19531 25000                 | .72 00 00 00                 | .44531 25000                 | .B2 00 00 00                 | .69531 25000                 | .F2 00 00 00                 | .94531 25000                 |
| .33 00 00 00                 | .19921 87500                 | .73 00 00 00                 | .44921 87500                 | .B3 00 00 00                 | .69921 87500                 | .F3 00 00 00                 | .94921 87500                 |
| .34 00 00 00                 | .20312 50000                 | .74 00 00 00                 | .45312 50000                 | .B4 00 00 00                 | .70312 50000                 | .F4 00 00 00                 | .95312 50000                 |
| .35 00 00 00                 | .20703 12500                 | .75 00 00 00                 | .45703 12500                 | .B5 00 00 00                 | .70703 12500                 | .F5 00 00 00                 | .95703 12500                 |
| .36 00 00 00                 | .21093 75000                 | .76 00 00 00                 | .46093 75000                 | .B6 00 00 00                 | .71093 75000                 | .F6 00 00 00                 | .96093 75000                 |
| .37 00 00 00                 | .21484 37500                 | .77 00 00 00                 | .46484 37500                 | .B7 00 00 00                 | .71484 37500                 | .F7 00 00 00                 | .96484 37500                 |
| .38 00 00 00                 | .21875 00000                 | .78 00 00 00                 | .46875 00000                 | .B8 00 00 00                 | .71875 00000                 | .F8 00 00 00                 | .96875 00000                 |
| .39 00 00 00                 | .22265 62500                 | .79 00 00 00                 | .47265 62500                 | .B9 00 00 00                 | .72265 62500                 | .F9 00 00 00                 | .97265 62500                 |
| .3A 00 00 00                 | .22656 25000                 | .7A 00 00 00                 | .47656 25000                 | .BA 00 00 00                 | .72656 25000                 | .FA 00 00 00                 | .97656 25000                 |
| .3B 00 00 00                 | .23046 87500                 | .7B 00 00 00                 | .48046 87500                 | .BB 00 00 00                 | .73046 87500                 | .FB 00 00 00                 | .98046 87500                 |
| .3C 00 00 00                 | .23437 50000                 | .7C 00 00 00                 | .48437 50000                 | .BC 00 00 00                 | .73437 50000                 | .FC 00 00 00                 | .98437 50000                 |
| .3D 00 00 00                 | .23828 12500<br>.24218 75000 | .7D 00 00 00<br>.7E 00 00 00 | .48828 12500<br>.49218 75000 | .BD 00 00 00<br>.BE 00 00 00 | .73828 12500                 | .FD 00 00 00                 | .98828 12500                 |
|                              |                              |                              |                              |                              | .74218 75000                 | .FE 00 00 00                 | .99218 75000                 |
| .3E 00 00 00<br>.3F 00 00 00 | .24609 37500                 | .7F 00 00 00                 | .49609 37500                 | .BF 00 00 00                 | .74609 37500                 | .FF 00 00 00                 | .99609 37500                 |

# **MATHEMATICAL CONSTANTS**

| <u>2<sup>n</sup> n 2<sup>-n</sup></u> | 'n Cor                                                                                                                                               | nstant            | Decimal Value        | Hexadecimal Value |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------|-------------------|
|                                       |                                                                                                                                                      |                   | 3.14159 26535 89793  | 3.243F 6A89       |
| 1 0 1.0<br>2 1 0.5                    |                                                                                                                                                      | 1                 | 0.31830 98861 83790  | 0.517C C1B7       |
| 4 2 0.2                               | 25 .                                                                                                                                                 | _                 | 1.77245 38509 05516  | 1.C5BF 891C       |
| 8 3 0.12                              | 125 V"                                                                                                                                               |                   | 1.14472 98858 49400  | 1.250D 048F       |
| 16 4 0.00<br>32 5 0.00                | 062 5                                                                                                                                                | n                 | 2.71828 18284 59045  | 2.B7E1 5163       |
|                                       |                                                                                                                                                      | ı                 | 0.36787 94411 71442  | 0.5E2D 58D9       |
| 128 7 0.00                            | 007 812 5<br>Ve                                                                                                                                      |                   | 1.64872 12707 00128  | 1.A612 98E2       |
|                                       | 003 906 25                                                                                                                                           | 910 <sup>e</sup>  | 0.43429 44819 03252  | 0.6F2D EC55       |
| 512 9 0.00<br>1 024 10 0.00           |                                                                                                                                                      | -                 | 1.44269 50408 88963  | 1.7154 7653       |
| 2 048 11 0.0                          |                                                                                                                                                      | 2                 | 0.57721 56649 01533  | 0.93C4 67E4       |
| 4 096 12 0.0                          | 000 244 140 625 InY                                                                                                                                  | Y -               | -0.54953 93129 81645 | -0.8CAE 9BC1      |
|                                       | 000 122 070 312 5                                                                                                                                    |                   | 1.41421 35623 73095  | 1.6A09 E668       |
|                                       | 000 061 035 156 25 01 020 000 030 517 578 125 1n2                                                                                                    |                   | 0.69314 71805 59945  | 0.8172 17F8       |
| (5.52) 1/ 0.0                         |                                                                                                                                                      | 9 <sub>10</sub> 2 | 0.30102 99956 63981  | 0.4D10 4D42       |
|                                       | 000 015 258 789 062 5 000 007 629 394 531 25 √1                                                                                                      |                   | 3.16227 76601 68379  | 3.298B 075C       |
|                                       | 000 003 814 697 265 625                                                                                                                              | 10                | 2.30258 40929 94046  | 2.4D76 3777       |
| 524 288 19 0.0                        | 000 001 907 348 632 812 5                                                                                                                            |                   |                      |                   |
|                                       | 000 000 953 674 316 406 25<br>000 000 476 837 158 203 125                                                                                            |                   |                      |                   |
| 4 194 304 22 0.0                      | .000 000 238 418 579 101 562 5                                                                                                                       |                   |                      |                   |
| 8 388 608 23 0.0                      | 000 000 119 209 289 550 781 25                                                                                                                       |                   |                      |                   |
|                                       | .000 000 059 604 644 775 390 625                                                                                                                     |                   |                      |                   |
|                                       | .000 000 029 802 322 387 695 312 5<br>.000 000 014 901 161 193 847 656 25                                                                            |                   |                      |                   |
|                                       | 000 000 007 450 580 596 923 828 125                                                                                                                  |                   |                      |                   |
| 268 435 456 28 0.0                    | .000 000 003 725 290 298 461 914 062 5                                                                                                               |                   |                      |                   |
| 536 870 912 29 0.0                    | .000 000 001 862 645 149 230 957 031 25                                                                                                              |                   |                      |                   |
|                                       | ,000 000 000 931 322 574 615 478 515 625<br>,000 000 000 465 661 287 307 739 257 812 5                                                               |                   |                      |                   |
| 4 204 0(7 204 22 0 0                  | 000 000 000 000 442 452 040 409 004 05                                                                                                               |                   |                      |                   |
|                                       | .000 000 000 232 830 643 653 869 628 906 25<br>.000 000 000 116 415 321 826 934 814 453 125                                                          |                   |                      |                   |
|                                       | .000 000 000 058 207 660 913 467 407 226 562 5<br>.000 000 000 029 103 830 456 733 703 613 281 25                                                    |                   |                      |                   |
|                                       |                                                                                                                                                      |                   |                      |                   |
|                                       | .000 000 000 014 551 915 228 366 851 806 640 625<br>.000 000 000 007 275 957 614 183 425 903 320 312 5                                               |                   |                      |                   |
| 274 877 906 944 38 0.0                | .000 000 000 003 637 978 807 091 712 951 660 156 25                                                                                                  |                   |                      |                   |
| 549 755 813 888 39 0.0                | .000 000 000 001 818 989 403 545 856 475 830 078 125                                                                                                 | ,                 |                      |                   |
|                                       | .000 000 000 000 909 494 701 772 928 237 915 039 062 5                                                                                               |                   |                      |                   |
|                                       | .000 000 000 000 454 747 350 886 464 118 957 519 531 25<br>.000 000 000 000 227 373 675 443 232 059 478 759 765 625                                  |                   |                      |                   |
| 8 796 093 022 208 43 0.0              | .000 000 000 000 113 686 837 721 616 029 739 379 882 812 5                                                                                           |                   |                      |                   |
|                                       | .000 000 000 000 056 843 418 860 808 014 869 689 941 406 25                                                                                          |                   |                      |                   |
|                                       | .000 000 000 000 028 421 709 430 404 007 434 844 970 703 125<br>.000 000 000 000 014 210 854 715 202 003 717 422 485 351 562 5                       |                   |                      |                   |
|                                       | .000 000 000 000 007 105 427 357 601 001 858 711 242 675 781 25                                                                                      |                   |                      |                   |
| 281 474 976 710 656 48 0.0            | .000 000 000 000 003 552 713 678 800 500 929 355 621 337 890 625                                                                                     |                   |                      |                   |
|                                       | .000 000 000 000 001 776 356 839 400 250 464 677 810 668 945 312 5                                                                                   |                   |                      |                   |
|                                       | .000 000 000 000 000 888 178 419 700 125 232 338 905 334 472 656 25<br>.000 000 000 000 000 444 089 209 850 062 616 169 452 667 236 328 125          |                   |                      |                   |
| 4 503 599 627 370 496 52 0.0          | .000 000 000 000 000 222 044 604 925 031 308 084 726 333 618 164 062 5                                                                               |                   |                      |                   |
| 9 007 199 254 740 992 53 0.0          | .000 000 000 000 000 111 022 302 462 515 654 042 363 166 809 082 031 25                                                                              |                   |                      |                   |
|                                       | .000 000 000 000 000 055 511 151 231 257 827 021 181 583 404 541 015 62:<br>.000 000 000 000 000 027 755 575 615 628 913 510 590 791 702 270 507 812 |                   |                      |                   |
|                                       |                                                                                                                                                      |                   |                      |                   |
|                                       | .000 000 000 000 000 013 877 787 807 814 456 755 295 395 851 135 253 90<br>.000 000 000 000 000 006 938 893 903 907 228 377 647 697 925 567 626 95   |                   |                      |                   |
| 288 230 376 151 711 744 58 0.0        | .000 000 000 000 000 003 469 446 951 953 614 188 823 848 962 783 813 476                                                                             | 6 562 5           |                      |                   |
| 576 460 752 303 423 488 59 0.0        | .000 000 000 000 000 001 734 723 475 976 807 094 411 924 481 391 906 734                                                                             | 8 281 2           | 25                   |                   |
|                                       | .000 000 000 000 000 000 867 361 737 988 403 547 205 962 240 695 953 36'                                                                             |                   |                      |                   |
|                                       | ,000 000 000 000 000 000 433 680 868 994 201 773 602 981 120 347 976 68<br>,000 000 000 000 000 000 216 840 434 497 100 886 801 490 560 173 988 34   |                   |                      |                   |
|                                       | .000 000 000 000 000 000 108 420 217 248 550 443 400 745 280 086 994 17                                                                              |                   |                      |                   |
|                                       |                                                                                                                                                      |                   |                      |                   |

# **APPENDIX B. SIGMA 9 INSTRUCTION LIST**

| Mnemonic    | Code     | Instruction Name                                        | Page     | Mnemonic     | Code             | Instruction Name                                                     | Page       |
|-------------|----------|---------------------------------------------------------|----------|--------------|------------------|----------------------------------------------------------------------|------------|
| LOAD/STO    | RE       |                                                         |          | FLOATING-    | POINT A          | RITHMETIC                                                            |            |
| LI          | 22       | Load Immediate                                          | 48       | FAS          | 3D               | Floating Add Short                                                   | 74         |
| LB          | 72       | Load Byte                                               | 48       | FAL          | 1D               | Floating Add Long                                                    | 75         |
| LH          | 52       | Load Halfword                                           | 48       | FSS          | 3C               | Floating Subtract Short                                              | 75         |
| LW<br>LD    | 32<br>12 | Load Word<br>Load Doubleword                            | 48<br>49 | FSL<br>FMS   | 1C<br>3F         | Floating Subtract Long<br>Floating Multiply Short                    | 76<br>76   |
| LCH         | 5A       | Load Complement Halfword                                | 49       | FML          | 1F               | Floating Multiply Long                                               | 76         |
| LAH         | 5B       | Load Absolute Halfword                                  | 49       | FDS          | 3E               | Floating Divide Short                                                | 76         |
| LCW<br>LAW  | 3A<br>3B | Load Complement Word<br>Load Absolute Word              | 49       | FDL          | 16               | Floating Divide Long                                                 | 76         |
| LCD         | 1A       | Load Complement Doubleword                              | 50<br>50 |              |                  |                                                                      |            |
| LAD         | 1B       | Load Absolute Doubleword                                | 51       | DECIMAL      |                  |                                                                      |            |
| LAS         | 26       | Load and Set                                            | 51       | DL           | 7E               | Decimal Load                                                         | 79         |
| LS          | 4A<br>2A | Load Selective<br>Load Multiple                         | 51<br>52 | DST          | 7F               | Decimal Store                                                        | 79         |
| LM<br>LCFI  | 02       | Load Conditions and Floating Control Immediate          | 52       | DA           | 79               | Decimal Add                                                          | 79         |
| LCF         | 70       | Load Conditions and Floating Control                    | 53       | DS<br>DM     | 78<br>7B         | Decimal Subtract<br>Decimal Multiply                                 | 79<br>80   |
| XW          | 46       | Exchange Word                                           | 53       | DD           | 7A               | Decimal Divide                                                       | 80         |
| STB<br>STH  | 75<br>55 | Store Byte<br>Store Halfword                            | 53<br>53 | DC           | 7D               | Decimal Compare                                                      | 81         |
| STW         | 35       | Store Word                                              | 53       | DSA          | 7C               | Decimal Shift Arithmetic                                             | 81         |
| STD         | 15       | Store Doubleword                                        | 54       | PACK<br>UNPK | 76<br>77         | Pack Decimal Digits<br>Unpack Decimal Digits                         | 81<br>82   |
| STS         | 47       | Store Selective                                         | 54       | OTTIK        | ,,               | onpack beennar bigins                                                | 02         |
| STM<br>STCF | 2B<br>74 | Store Multiple<br>Store Conditions and Floating Control | 54<br>54 | BYTE STRIN   | G                |                                                                      |            |
| 5101        | /4       | store conditions and riodining control                  | 54       | DITE STAIL   | <u> </u>         |                                                                      |            |
| analyze/i   | NTERPRET | , ,                                                     |          | MBS          | 61               | Move Byte String                                                     | 84         |
| ,           |          |                                                         |          | CBS          | 60               | Compare Byte String                                                  | 85         |
| ANLZ        | 44       | Analyze                                                 | 55       | TBS<br>TTBS  | 41<br>40         | Translate Byte String<br>Translate and Test Byte String              | 86<br>87   |
| INT         | 6B       | Interpret                                               | 57       | EBS          | 63               | Edit Byte String                                                     | 88         |
|             |          | (FTIC                                                   |          |              |                  | , .                                                                  |            |
| FIXED-POIN  |          | <u>AETIC</u>                                            |          | PUSH DOW     | N                |                                                                      |            |
| AI          | 20       | Add Immediate                                           | 58       |              |                  |                                                                      |            |
| AH          | 50       | Add Halfword                                            | 58       | PSW<br>PLW   | 09<br>08         | Push Word<br>Pull Word                                               | 94<br>94   |
| AW          | 30<br>10 |                                                         | 58       | PSM          | OB               | Push Multiple                                                        | 94         |
| AD<br>SH    | 58       | Add Doubleword<br>Subtract Halfword                     | 59<br>59 | PLM          | 0A               | Pull Multiple                                                        | 95         |
| SW          | 38       | Subtract Word                                           | 59       | MSP          | 13               | Modify Stack Pointer                                                 | 96         |
| SD          | 18       | Subtract Doubleword                                     | 60       |              |                  |                                                                      |            |
| MI          | 23       | Multiply Immediate                                      | 60       | EXECUTE/B    | RANCH            |                                                                      |            |
| MH<br>MW    | 57<br>37 | Multiply Halfword<br>Multiply Word                      | 61<br>61 | EXU          | 67               | Execute                                                              | 98         |
| DH          | 56       | Divide Halfword                                         | 61       | BCS          | 69               | Branch on Conditions Set                                             | 78<br>98   |
| DW          | 36       | Divide Word                                             | 62       | BCR          | 68               | Branch on Conditions Reset                                           | 99         |
| AWM         | 66       | Add Word to Memory                                      | 62       | BIR          | 65               | Branch on Incrementing Register                                      | 99         |
| MTB<br>MTH  | 73<br>53 | Modify and Test Byte<br>Modify and Test Halfword        | 62<br>63 | BDR<br>BAL   | 6 <b>4</b><br>6A | Branch on Decrementing Register<br>Branch and Link                   | 99<br>99   |
| MTW         | 33       | Modify and Test Word                                    | 63       | BAL          | 0A               |                                                                      | 77         |
|             |          |                                                         |          | CALL         |                  |                                                                      |            |
| COMPARISO   | N        |                                                         |          | CALL         |                  |                                                                      |            |
|             |          |                                                         |          | CALI         | 04               | Call 1                                                               | 100        |
| CI<br>CB    | 21<br>71 | Compare Immediate                                       | 64       | CAL2<br>CAL3 | 05               | Call 2                                                               | 100        |
| СН          | 51       | Compare Byte<br>Compare Halfword                        | 64<br>65 | CAL3<br>CAL4 | 06<br>07         | Call 3<br>Call 4                                                     | 100<br>100 |
| CW          | 31       | Compare Word                                            | 65       | 0,121        | •,               |                                                                      | 100        |
| CD          | 11       | Compare Doubleword                                      | 65       | CONTROL      | (privileged      | (4                                                                   |            |
| CS<br>CLR   | 45<br>39 | Compare Selective<br>Compare with Limits in Register    | 66       | LPSD         | OE               | Land Program Status Daublausat                                       | 101        |
| CLM         | 19       | Compare with Limits in Memory                           | 66<br>66 | XPSD         | 0E<br>0F         | Load Program Status Doubleword<br>Exchange Program Status Doubleword | 101<br>102 |
|             |          |                                                         |          | LRP          | 2F               | Load Register Pointer                                                | 104        |
|             |          |                                                         |          | MMC          | 6F               | Move to Memory Control                                               | 104        |
| LOGICAL     |          |                                                         |          | LRA<br>LMS   | 2C<br>2D         | Load Real Address<br>Load Memory Status                              | 107        |
| OR          | 49       | OR Word                                                 | 66       | WAIT         | 2D<br>2E         | Wait                                                                 | 108<br>110 |
| EOR         | 48       | Exclusive OR Word                                       | 67       | RD           | 6C               | Read Direct                                                          | 110        |
| AND         | 4B       | AND Word                                                | 67       | WD           | 6D               | Write Direct                                                         | 112        |
|             |          |                                                         |          | N 101 T (011 |                  |                                                                      |            |
| SHIFT       |          |                                                         |          | INPUT/OUT    | PUI (priv        | (lleged)                                                             |            |
| ç           | 25       | Shift                                                   | 67       | SIO          | 4C               | Start Input/Output                                                   | 123        |
| S<br>SF     | 25<br>24 | Shift Floating                                          | 67<br>69 | TIO          | 4D               | Test Input/Output                                                    | 124        |
| -           |          |                                                         |          |              | 4E               | Test Device                                                          | 125        |
| CONVERSI    | лс       |                                                         |          | HIO<br>RIO   | 4F<br>4F         | Halt Input/Output<br>Reset Input/Output                              | 126<br>126 |
|             |          |                                                         |          | POLP         | 4F               | Poll Processor                                                       | 120        |
| CVA         | 29       | Convert by Addition                                     | 71       | POLR         | 4F               | Poll and Reset Processor                                             | 127        |
| CVS         | 28       | Convert by Subtraction                                  | 71       | AIO          | 6E               | Acknowledge Input/Output Interrupt                                   | 127        |
|             |          |                                                         |          |              |                  |                                                                      |            |

4

## TIMING CONSIDERATIONS

In less complex computers it was quite simple to express the exact times or timing formulas for the execution of each operation. To determine the total time to execute a program it was necessary only to add the times required for each instruction. Simple timing formulas cannot exactly express SIGMA 9 central processor operations because the timing of each operation is dependent in varying degrees upon the previous instruction, the amount of address modification required, and the configuration of the memory system. The degree of overlap depends on the type of problem (i.e., the instruction mix); it varies widely among problems that require predominantly floating-point, decimal, or byte string arithmetic, and is also affected by the number of instructions between branches and by input/output activity. To be accurate, it is necessary to examine the exact timing relationships of the instructions in considerable detail. Even then, the effect of system configurations on performance is not included in that examination. The best method is to program a problem and time its execution under actual system operating environments.

Timings and formulas in Table C-1 are based on the assumption that, whenever the CPU requests a service cycle from a particular memory bank, it never waits for such service due to other devices (such as IOPs), which are connected to that memory bank.

Execution times depend not only on the nature of the specific instructions and the configuration of memory banks in the system but also on the placement of instructions and operands in memory. These basic execution times must be increased to account for the effects of memory interference, indexing, indirect addressing, and register-to-register operations. These effects are discussed below.

Note that formulas given in Table C-1 for long instructions such as shift, decimal, floating, byte string, and multiples are linear averages of nonlinear functions. Programs heavily dependent on the times of these instructions should be benchmarked.

## **EFFECTS OF MEMORY INTERFERENCE**

Memory interference will affect central processor speed, which varies with the memory cycle time, the number of memory banks capable of running in parallel, and the function being executed. Interference is minimized by interleaving memory banks to allow maximum memory overlap. In a typical instruction mix used in scientific/engineering applications, the percentages of the instructions executed might be as follows:

| Type of Instruction                         | Percent |
|---------------------------------------------|---------|
| Floating-point                              | 8.5     |
| Fixed-point<br>(including loads and stores) | 53.0    |
| Branch                                      | 27.5    |
| Miscellaneous                               | 11.0    |

The effect of memory interference on the above instruction mix in an 8-bank system for 100 instructions is an increase of approximately 7.4 microseconds or an average of 74 nanoseconds per instruction. Changing the mix to a commercial application that uses decimal and byte-string instructions does not significantly change the effect of memory interference on the average instruction. Over a wide range of mixes, the effect of memory interference in an 8-bank system changed by less than 10 percent.

## **EFFECTS OF INDEXING**

Indexing causes a maximum increase of .260 microsecond in the execution time of an instruction. Many instructions are limited in speed due to memory access time. Indexing is often performed in conjunction with memory accesses. This overlapping of indexing with memory time allows the effective time due to indexing to be .260 microsecond less the memory overlap time. For a typical scientific mix of instructions, the average memory overlap is .120 microsecond. The typical indexing time would then be .140 microsecond.

## **EFFECTS OF INDIRECT ADDRESSING**

Indirect addressing requires a memory access. This access may be from the general registers or the main memory.

- 1. Indirect addressing from general registers requires a maximum time of .960 microsecond.
- 2. Indirect addressing from main memory requires a maximum time of 1.050 microseconds.

The maximum time required for indirect addressing is reduced when the indirect memory request is overlapped with instruction execution. This effect is instruction dependent.

## **EFFECTS OF REGISTER-TO-REGISTER OPERATIONS**

If the reference address is X'0' through X'F', the operand is accessed from the appropriate general register rather than from main memory. The additional time required for this operation varies from 155 to 445 nanoseconds, depending on the sequence of instructions being executed.

The major factors determining the additional time required for register-to-register operations are the type of instruction (multiple operands versus single-operand instructions) being executed and the type of instruction preceding the instruction in question.

For multiple operand type of instructions (load and store multiples, push/pulls, byte strings, etc.), the average delay for operands other than the first of the string is approximately 260 nanoseconds for load-type instructions and 155 nanoseconds for store-type instructions.

For all initial operands pointed to by the effective address of the instruction, the delay due to register-to-register operations is dependent on the preceding instruction as follows:

- 1. If the preceding instruction is generally greater than 1 microsecond, then the typical delay is 445 nanoseconds.
- 2. If the preceding instruction is generally less than 1 microsecond, then the typical delay is 235 nanoseconds.

### **OTHER SIGMA 9 PERFORMANCE FACTORS**

To achieve improved system performance, SIGMA 9 uses "anticipation logic". By anticipating the access of the next few memory words (i.e., guessing the location of the next words to be obtained from memory) certain machine functions can be overlapped. Factors that affect this capability, and thus machine performance, are outlined below.

- If instruction n + 1 is altered by instruction n, the machine's anticipation logic is cleared (aborted), causing an extra delay of approximately 1.3 microseconds.
- If instruction n + 1 or n + 2 is located in main memory, and if either is modified by instruction n, the anticipation logic is cleared (aborted). Due to hardware considerations this abort occurs if instruction n stores not only into location n + 1 or n + 2 but also into locations 128 + (n + 1 or n + 2), 256 + (n + 1 or n + 2), and 384 + (n + 1 or n + 2). The delay caused by this abort is approximately 1.6 microseconds.

A special case is excluded from this type of abort. This case occurs when the location being modified is the one following the location of an unconditional branch, as in the following example:

Instruction Location:

n STORE WORD INTO n + 2 n + 1 UNCONDITIONAL BRANCH n + 2 X

- Note: The special case occurs only when the unconditional branch branches to the next location. This case works normally (i.e., without an abort) due to n + 2 being accessed with operand timing.
- 3. If the index register being used for operand n+1 is modified by instruction n, then a preparation abort occurs. The indexing for instruction n+1 is performed at the start of execution of n. This is to allow time to overlap the n+1 operand memory access with the execution of instruction n. The delay caused by this type of abort is approximately .89 microsecond.
- 4. Instructions that cause a change in sequential accessing of instructions cause partial aborts of the anticipation logic. These instructions are branches, calls, XPSD, and LPSD.
- 5. Instructions that change the state of the machine cause a complete abort. This is necessary due to the fact that any anticipate operation may have been invalidated. The instructions causing this are: MMC, LRP, XPSD, and LPSD. The times shown in this appendix for these instructions include the extra time due to the anticipation restart.
- 6. Faults that cause traps, if detected for an instruction access (Memory Not Present, Access Protect, Map Parity Error, Memory Parity Error, and Bus Check Fault), cause the anticipation to be aborted. If the fault occurs during restart of the anticipation, the appropriate trap action will then occur.
- 7. Interrupts cause a change in the address from normal sequencing and therefore cause the anticipation to be aborted.
- 8. Instructions accessed from scratchpad cause a delay of from 0 to .355 microsecond.
- 9. SIGMA 9 performance is affected by the amount of memory overlap between instructions and operands. A performance gain will be realized if operands and instructions are located in different memory units. Interleaving will allow overlap between instructions with instructions and operands with operands.

Table C-1. Basic Instruction Timing

| Instruction<br>Mnemonic | Time (µsec) | Notes                                       |
|-------------------------|-------------|---------------------------------------------|
| AD                      | 1.66        |                                             |
| AH                      | .73         | · ·                                         |
| AI                      | .73         |                                             |
| AIO                     | 6.78 + D    | R ≠ 0.                                      |
|                         |             | Includes 3 µsec to claim the processor bus. |
|                         |             | D = turnaround time on the interface.       |
| AIO                     | 5.96 + D    | R = 0.                                      |
|                         | :<br>:      | Includes 3 µsec to claim the processor bus. |
|                         |             | D = turnaround time on the interface.       |
| AND                     | .73         |                                             |
| ANLZ                    | 4.00        |                                             |
| AW                      | .73         |                                             |
| AWM                     | 1.53        | · · · · · · · · · · · · · · · · · · ·       |
| BAL                     | .84         |                                             |
| BCR                     | .83         | Branch                                      |
| BCR                     | 1.57        | No Branch                                   |
| BCS                     | .83         | Branch                                      |
| BCS                     | 1.57        | No Branch                                   |
| BDR                     | 1.08        | Branch                                      |
| BDR                     | 1.57        | No Branch                                   |
| BIR                     | 1.08        | Branch                                      |
| BIR                     | 1.57        | No Branch                                   |
| CAL1-4                  | 8.15        | Includes trap entry and XPSD.               |
| СВ                      | .82         |                                             |

.

| Instruction<br>Mnemonic | Time (µsec)         | Notes                                                                                                                                           |
|-------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| CBS (R is even)         | 7.60 + .6N          | N = number of destination bytes processed.                                                                                                      |
| CBS (R is odd)          | 5.60 + .6N          | N = number of destination bytes processed.                                                                                                      |
| CD                      | 1.41                |                                                                                                                                                 |
| СН                      | .82                 |                                                                                                                                                 |
| CI                      | .84                 |                                                                                                                                                 |
| CLM                     | 1.41                |                                                                                                                                                 |
| CLR                     | .94                 |                                                                                                                                                 |
| CS                      | 1.33                |                                                                                                                                                 |
| CVA                     | 9.16 + <i>.</i> 58N | N = number of bits in the word converted.                                                                                                       |
| CVS                     | 27.43               |                                                                                                                                                 |
| CW                      | .82                 |                                                                                                                                                 |
| DA                      | 5.80 + .4D          | D = number of digits (including the sign) in the effective decimal operand.                                                                     |
| DC                      | 4.70 + .3D          | D = number of digits (including the sign) in the effective decimal operand.                                                                     |
| DD                      | 18.50 + .5K         | K = (D+6) (16-Q); D = number of digits (including the sign) in<br>the effective decimal operand; Q = number of leading zeros in th<br>quotient. |
| DH                      | 9.17                |                                                                                                                                                 |
| DL                      | 3.80 + .2D          | D = number of digits (including the sign) in the effective decimal operand.                                                                     |
| DM                      | 38.20 + .28DN       | D = number of digits (including the sign) in the effective decimal operand; N = number of nonzero decimal digits in the decimal accumulator.    |
| DS                      | 5.80 + .4D          | D = number of digits (including the sign) in the effective decimal operand.                                                                     |
| DSA                     | 11.90               |                                                                                                                                                 |
| DST                     | 5.40 + .5D          | D = number of digits (including the sign) to be stored.                                                                                         |

Table C-1. Basic Instruction Timing (cont.)

| Table | C-1. | Basic | Instruction | Timing | (cont.) |
|-------|------|-------|-------------|--------|---------|
|-------|------|-------|-------------|--------|---------|

| Instruction<br>Mnemonic | Time (µsec)         | Notes                                                                                                                             |  |  |
|-------------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|
| DW                      | 9.48                |                                                                                                                                   |  |  |
| EBS                     | 8.00 + 3.8N         | N = number of bytes in the editing pattern.                                                                                       |  |  |
| EOR                     | .73                 |                                                                                                                                   |  |  |
| EXU                     | .71                 | Add execution time for subject instruction.                                                                                       |  |  |
| FAL                     | 2.72 (min)          | No prealignment or postnormalization required.                                                                                    |  |  |
| FAL                     | 3.93 (typical)      | Assumes one hexadecimal prealignment digit on either operand<br>and one hexadecimal postnormalization digit on the result.        |  |  |
| FAL                     | 9 <b>.</b> 57 (max) | Assumes 14 hexadecimal prealignment digits on either operand<br>and 13 hexadecimal postnormalization digits on the result.        |  |  |
| FAS                     | 2.25 (min)          | No prealignment or postnormalization required.                                                                                    |  |  |
| FAS                     | 3.06 (typical)      | Assumes one hexadecimal prealignment digit on either operand<br>and one hexadecimal postnormalization digit on the result.        |  |  |
| FAS                     | 5.00 (max)          | Assumes six hexadecimal prealignment digits on either operand<br>and five hexadecimal postnormalization digits on the result.     |  |  |
| FDL                     | 17.40 (min)         | Nonzero, normalized operands. Typical time is usually minimum time plus 0.13 microsecond.                                         |  |  |
| FDL                     | 25.00 (max)         | Assumes 13 hexadecimal prenormalization digits on both operands.                                                                  |  |  |
| FDS                     | 7.69 (min)          | Nonzero, normalized operands. Typical time is usually minimum time plus 0.13 microsecond.                                         |  |  |
| FDS                     | 10.96 (max)         | Assumes five hexadecimal prenormalization digits on both operands.                                                                |  |  |
| FML                     | 6.96 (min)          | Nonzero, normalized operands; no postnormalization required.<br>Typical time is usually minimum time plus 0.13 microsecond.       |  |  |
| FML                     | 10.50 (max)         | Assumes 13 hexadecimal postnormalization digits on both operands<br>and one hexadecimal digit of postnormalization on the result. |  |  |
| FMS                     | 3.97 (min)          | Nonzero, normalized operands; no postnormalization required.<br>Typical time is usually minimum time plus 0.13 microsecond.       |  |  |
| FMS                     | 6.00 (max)          | Assumes five hexadecimal prenormalization digits on both operands and one hexadecimal digit of postnormalization on the result.   |  |  |
| FSL                     | 2.72 (min)          | No prealignment or postnormalization required.                                                                                    |  |  |

.

| Instruction<br>Mnemonic | Time (µsec)    | Notes                                                                                                                      |
|-------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------|
| FSL                     | 3.93 (typical) | Assumes one hexadecimal prealignment digit on either operand and one hexadecimal postnormalization digit on the result.    |
| FSL                     | 9.57 (max)     | Assumes 14 hexadecimal prealignment digits on either operand<br>and 13 hexadecimal postnormalization digits on the result. |
| FSS                     | 2.25 (min)     | No prealignment or postnormalization required.                                                                             |
| FSS                     | 3.06 (typical) | Assumes one hexadecimal prealignment digit on either operand and one hexadecimal postnormalization digit on the result.    |
| FSS                     | 5.00 (max)     | Assumes six hexadecimal prealignment digits on either operand and five hexadecimal postnormalization digits on the result. |
| HIO                     | 7.37 + D       | $R = even, \neq 0.$                                                                                                        |
|                         |                | Includes 3 µsec to claim the processor bus.                                                                                |
|                         |                | D = turnaround time on the interface.                                                                                      |
| HIO                     | 6.78 + D       | R = odd.                                                                                                                   |
|                         |                | Includes 3 µsec to claim the processor bus.                                                                                |
|                         |                | D = turnaround time on the interface.                                                                                      |
| HIO                     | 5.96 + D       | $\mathbf{R}=0.$                                                                                                            |
|                         |                | Includes 3 µsec to claim the processor bus.                                                                                |
|                         |                | D = turnaround time on the interface.                                                                                      |
| INT                     | .73            | R = odd                                                                                                                    |
|                         | .75            | R = even                                                                                                                   |
| LAD                     | 1.66           |                                                                                                                            |
| LAH                     | .73            |                                                                                                                            |
| LAS                     | 2.22           |                                                                                                                            |
| LAW                     | .73            | .82 if negative.                                                                                                           |
| LB                      | .73            |                                                                                                                            |
| LCD                     | 1.66           |                                                                                                                            |
| LCF                     | .73            |                                                                                                                            |

Table C-1. Basic Instruction Timing (cont.)

| Instruction<br>Mnemonic | Time (µsec)                                    | Notes                                                                                                                                                                                                                                                                           |
|-------------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LCFI                    | .73                                            |                                                                                                                                                                                                                                                                                 |
| LCH                     | .73                                            |                                                                                                                                                                                                                                                                                 |
| LCW                     | .73                                            |                                                                                                                                                                                                                                                                                 |
| LD                      | 1.58                                           |                                                                                                                                                                                                                                                                                 |
| LH                      | .73                                            |                                                                                                                                                                                                                                                                                 |
| LI                      | .73                                            |                                                                                                                                                                                                                                                                                 |
| LM                      | 2.54 + .83 (N-1)                               | N = number of words moved.                                                                                                                                                                                                                                                      |
| LMS                     | 2.22                                           |                                                                                                                                                                                                                                                                                 |
| LPSD                    | 3.70                                           |                                                                                                                                                                                                                                                                                 |
| LRA                     | 4.40                                           |                                                                                                                                                                                                                                                                                 |
| LRP                     | 2.15                                           |                                                                                                                                                                                                                                                                                 |
| LS                      | 1.00                                           |                                                                                                                                                                                                                                                                                 |
| LW                      | .73                                            |                                                                                                                                                                                                                                                                                 |
| MBS (R is even)         | 7.60 + .6N                                     | N = number of destination bytes processed regardless of word or                                                                                                                                                                                                                 |
| MBS (R is odd)          | 5.60 + .6N                                     | byte boundaries.                                                                                                                                                                                                                                                                |
| мн                      | 2.78                                           |                                                                                                                                                                                                                                                                                 |
| MI                      | 3.78                                           |                                                                                                                                                                                                                                                                                 |
| ммс                     | 3.60 + 2.65N (Σ 7 map)<br>or + 1.96N (Σ 9 map) | N = number of words moved.<br>For SIGMA 7 compatible mode, use 3.60 + 2.65N, where N is<br>the number of words. Maximum N is 64 since each page is one<br>byte. For SIGMA 9 mode, use 3.60 + 1.96N. Maximum N is 128<br>since each page is 13 bits or approximately a halfword. |
| MSP                     | 4.70                                           |                                                                                                                                                                                                                                                                                 |
| мтв                     | 1.80                                           | 1.20 if R = 0.                                                                                                                                                                                                                                                                  |
| мтн                     | 1.80                                           | 1.20 if R = 0.                                                                                                                                                                                                                                                                  |
| MTW                     | 1.53                                           | 1.20 if R = 0.                                                                                                                                                                                                                                                                  |

Table C-1. Basic Instruction Timing (cont.)

| Table | C-1. | Basic | Instruction | Timing | (cont.) |
|-------|------|-------|-------------|--------|---------|
|-------|------|-------|-------------|--------|---------|

| Instruction<br>Mnemonic | Time (µsec)      | Notes                                                          |  |
|-------------------------|------------------|----------------------------------------------------------------|--|
| MW                      | 3.78             |                                                                |  |
| OR                      | .73              |                                                                |  |
| РАСК                    | 3.50 + .55N      | N = number of bytes in zoned number in memory.                 |  |
| PLM                     | 8.40 + .42 (N-1) | N = number of words moved.                                     |  |
| PLW                     | 6.20             |                                                                |  |
| PSM                     | 7.80 + .57 (N-1) | N = number of words moved.                                     |  |
| PSW                     | 5.70             |                                                                |  |
| RD                      | 1.44             | Internal                                                       |  |
| RD                      | 2.07 + 0.24N     | External                                                       |  |
|                         |                  | N = integer (0, 1, 2,), dependent on delay in external device. |  |
| S                       | 1.90 + .06N      | N = number of bit positions shifted.                           |  |
| S (searching left)      | 2.9 + .06N       | N = number of bit positions shifted.                           |  |
| S (searching right)     | 2.90 + .12N      | N = number of bit positions shifted.                           |  |
| SD                      | 1.66             |                                                                |  |
| SF                      | 2.16 + .24N      | N = number of hexadecimal positions shifted.                   |  |
| SH                      | .73              |                                                                |  |
| SIO                     | 7.37 + D         | $R = even, \neq 0.$                                            |  |
|                         |                  | Includes 3 µsec to claim the processor bus.                    |  |
|                         |                  | D = turnaround time on the interface.                          |  |
| SIO                     | 6.78 + D         | R = odd.                                                       |  |
|                         |                  | Includes 3 µsec to claim the processor bus.                    |  |
|                         |                  | D = turnaround time on the interface.                          |  |
| SIO                     | 5.96 + D         | R = 0.                                                         |  |
|                         |                  | Includes 3 µsec to claim the processor bus.                    |  |
|                         |                  | D = turnaround time on the interface.                          |  |

| Ta | ble | C- | 1. | Basic | Instruction | Timing | (cont.) |  |
|----|-----|----|----|-------|-------------|--------|---------|--|
|----|-----|----|----|-------|-------------|--------|---------|--|

| Instruction<br>Mnemonic | Time (µsec)      | Notes                                       |
|-------------------------|------------------|---------------------------------------------|
| STB                     | 1.80             |                                             |
| STCF                    | 1.80             |                                             |
| STD                     | 2.10             |                                             |
| STH                     | 1.92             |                                             |
| STM                     | 3.08 + .57 (N-1) | N = number of words moved.                  |
| STS                     | 1.76             |                                             |
| STW                     | 1.53             |                                             |
| SW                      | .73              |                                             |
| TBS                     | 6.10 + 2.3N      | N = number of destination bytes processed.  |
| TDV                     | 7.37 + D         | $R = even, \neq 0.$                         |
|                         |                  | Includes 3 µsec to claim the processor bus. |
|                         |                  | D = turnaround time on the interface.       |
| TDV                     | 6.78 + D         | R = odd.                                    |
|                         |                  | Includes 3 µsec to claim the processor bus. |
|                         |                  | D = turnaround time on the interface.       |
| TDV                     | 5.96 + D         | R = 0.                                      |
|                         |                  | Includes 3 µsec to claim the processor bus. |
|                         |                  | D = turnaround time on the interface.       |
| TIO                     | 7.37 + D         | $R = even, \neq 0.$                         |
|                         |                  | Includes 3 µsec to claim the processor bus. |
|                         |                  | D = turnaround time on the interface.       |
| TIO                     | 6.78 + D         | R = odd.                                    |
|                         |                  | Includes 3 µsec to claim the processor bus. |
|                         |                  | D = turnaround time on the interface.       |
| TIO                     | 5.96 + D         | R = 0.                                      |
|                         |                  | Includes 3 µsec to claim the processor bus. |
|                         |                  | D = turnaround time on the interface.       |

| Instruction<br>Mnemonic | Time (µsec) | Notes                                                                         |
|-------------------------|-------------|-------------------------------------------------------------------------------|
| TTBS                    | 6.10 + 2.4N | N = number of destination bytes processed.                                    |
| UNPK                    | 7.40 + 1.0N | N = number of bytes to be stored in memory.                                   |
| WAIT                    | .73         | Minimum time.                                                                 |
| WD                      | 1.44        | Internal                                                                      |
| WD                      | 2.07 + .24N | External<br>N = integer (0, 1, 2,), dependent on delay in external<br>device. |
| XPSD                    | 5.43        |                                                                               |
| XW                      | 1.53        |                                                                               |

G.

Table C-1. Basic Instruction Timing (cont.)

## APPENDIX D. SYSTEM RELIABILITY AND MAINTAINABILITY

The SIGMA 9 computer system has many new design features that provide the user with reliable operation and efficient maintenance. For example, the extent to which a system can be partitioned into separate units for either checkout or maintenance is a "fail-soft" feature (i.e., ability to keep remainder of a system operational in case of failure of any given unit), which was a major design goal for SIGMA 9 development.

The new design features are outlined in the following sections:

System Maintainability Features

**CPU** Features

Main Memory Features

Multiplexor Input/Output Processor Features

High-Speed RAD I/O Processor Features

### SYSTEM MAINTAINABILITY FEATURES

SIGMA 9 computer systems are maintained by means of the following:

1. Diagnostic Programs

Diagnostic programs for centralized SIGMA 9 units (CPUs, memory units, and IOPs) use special hardware to detect and isolate system faults. Interface with maintenance personnel is provided through a local keyboard-printer or a remote keyboard-printer connected via a telephone line. Diagnostic programs are designed with a multilevel structure consisting of the following capabilities.

- a. System verification and testing to determine which unit is faulty.
- b. Unit functional testing to determine the specific function that is faulty.
- c. Fault location diagnosis to analyze which component is malfunctioning.
- 2. Snapshot Logic

Snapshot logic enables diagnostic programs to retrieve control flip-flops and internal register contents that are not otherwise "visible" to a program. This feature makes it possible to determine system status at the time a fault occurs and to locate the source of a fault condition down to the level of a small set of replaceable elements. (See "CPU Features".) 3. Status and Fault Retrieval

When a fault is detected, system status and fault information is available for program retrieval and error logging for subsequent analysis.

4. Partitioning Feature

A SIGMA 9 system can be reconfigured through the use of reconfiguration controls. SIGMA 9 units can be partitioned out of the system by selectively disabling them from the busses. Thus, faulty units can be isolated from the system, or an entire subsystem (including a CPU in a multiprocessing environment) can be partitioned from the primary system to permit diagnosis and repair of a faulty unit. Repaired units can be returned to service by reenabling the connections.

#### 5. RESET I/O (RIO) Instruction

This instruction provides programmed I/O Reset that operates exactly as though the I/O Reset had been initiated with the switch on the processor control panel (PCP). The addressed IOP and all peripheral devices connected to it are initialized. Special coding of RIO will reset a CPU (see RIO instruction, Chapter 3.)

6. Parity Checking

Parity on all data and addresses communicated in either direction on busses between memory units and processors (CPUs, MIOPs, and HSRIOPs) is checked. This feature provides fault detection and location capabilities that enhance the ability of an operating system or diagnostic program to quickly determine which unit is faulty.

7. Clock and Voltage Margins

Centralized units are provided with clock and voltage margin capabilities that assist maintenance personnel or diagnostic programs to quickly locate the source of an intermittent fault. Programmable clock margin control is provided and status is available for program retrieval. NOT NORMAL conditions are indicated on the PCP.

8. Alternate Processor Bus (optional)

This feature provides a redundant connection of the IOPs and CPUs in a system. It is used in partitioning centralized units for diagnostic or reconfiguration purposes.

Appendix D 175

#### 9. Unique Processor Numbers

All processors have unique numbers so that they can be identified in communications on the processor bus.

### 10. Processor Fault Interrupt

A processor fault interrupt (PFI) signal is generated by processors (CPUs, MIOPs, and HSRIOPs) when certain fault conditions are detected. The interrupt signal is transmitted via the processor bus to all CPUs in the system (except to the CPU generating the PFI) for special fault handling.

### 11. Status Instructions

The two instructions, POLL PROCESSOR (POLP) and POLL AND RESET PROCESSOR (POLR), are used to determine status. All processors in a SIGMA 9 system retain the status of faults, internal conditions, and processor identification. When a Processor Fault Interrupt (PFI) occurs, the CPU(s) that receives the interrupt must determine which processor caused the PFI and the nature of the fault.

The POLP instruction causes the addressed processor to return the contents of its fault status register and, in the condition code bits, indicate whether the processor had detected a fault and generated PFI. (See POLP instruction, Chapter 3.)

The POLR instruction performs the same functions as POLP but, in addition, causes the addressed processor to reset the contents of the processor fault register and reset the PFI signal. (See POLR instruction, Chapter 3.)

#### **CPU FEATURES**

### 1. Processor Control Panel (PCP)

The PCP (see Chapter 5) is divided into two sections. The upper portion (MAINTENANCE SECTION) contains controls and indicators used exclusively by maintenance personnel. The lower portion is used primarily by operating personnel to load, execute, and troubleshoot programs. A Control Mode switch disables certain maintenance functions during normal operation.

2. Maintenance Display

Various phases, control flip-flops, and registers of the CPU and decimal unit can be displayed on the PCP. A 16-position thumbwheel switch identifies and selects display information during maintenance activities.

3. Snapshot Logic

All CPU logic that can be displayed on the PCP can be monitored by a program with the snapshot logic. At a preselected clock time of a given instruction execution, selected logic is stored into a 32-bit snapshot register. The contents of the snapshot register are then retrieved by a specially coded READ DIRECT instruction. By comparing the "snapped" information with known correct information, the diagnostic program can accurately determine a specific fault. The failing component can then be identified. Snapshot action can also be initiated at the PCP, and the contents of the snapshot register displayed.

4. Clock and Voltage Margins

Clock margin control is accomplished manually at the PCP with the CLOCK MARGIN switch or under program control with a properly coded WRITE DIRECT instruction. Three clock rates are provided:

- NORMAL
- FAST
- SLOW

Voltage margin controls are also provided at each local d.c. power supply within a unit.

5. Memory Clear and Scan

Manual memory clear and scan capabilities are provided to enable operators or maintenance personnel to rapidly clear or read selected data from, or store selected data into, any or all consecutive CPU main memory locations. During the read scan operation, the CPU can be made to halt on a memory parity error, at which time the address and data of the indicated memory location can be displayed.

### 6. Address Stop Feature

This feature (see Chapter 5) allows the operator or maintenance personnel to:

- a. Stop on any instruction whose virtual address equals the SELECT ADDRESS switch value. At the time of the halt, the instruction pointed to by the SELECT ADDRESS appears in the DISPLAY indicators.
- b. Stop on any real memory (read or write) reference indicated by the SELECT ADDRESS switches.
- c. Stop on any real memory write reference indicated by the SELECT ADDRESS switches.
- d. Stop when any word in a selected page is referenced.
- 7. PCP Manual Instruction Execution

The PCP allows manual execution of READ/WRITE DIRECT instructions while the CPU is in the IDLE mode. This feature is in addition to the programmable interrogation provided via the READ/WRITE DIRECT instructions (see Chapter 3). Thus, all devices connected to the direct I/O or maintenance interface may be examined manually by maintenance personnel.

Memory status word zero can be manually displayed on the PCP without clearing memory fault status while the CPU is in the IDLE mode. This action is similar to the programmed LMS instruction with initial condition code setting 1000 (see Chapter 5).

8. Single Clock Mode

The CPU has a single clock mode of operation that enables maintenance personnel to execute an instruction from the PCP, one internal phase at a time.

### 9. Timer and Decimal Override

The operation of the watchdog timer and decimal unit can be selectively overridden to aid maintenance personnel in diagnosing related machine faults (see Chapter 5).

#### 10. CPU Traps

CPU traps are provided for a variety of detected CPU and system fault conditions. The trap system (see Chapter 2) provides a high degree of system recoverability. Indicators and audit trails enable the system programmer to accurately determine the status of the machine at the time of the trap. CPU fault conditions are:

- a. Memory Parity Error When a CPU receives a signal from the memory indicating a memory parity error, the CPU traps. The condition code identifies the memory parity error trap condition.
- b. Data Bus Check If the CPU detects a parity error on data received from memory, and the memory does not also indicate a parity error on the information sent, then a data bus check occurs. Occurrence of the data bus check condition causes the CPU to trap.
- c. Map Check When the CPU is operating with the memory map, a parity check is made on the page address retrieved from the map. If an error is found, the CPU aborts the memory request and traps.
- d. Watch Dog Timer The watch dog timer prevents the CPU from being "hung up" due to internal faults or faults in other units. When the timer times out, the CPU traps and sets the condition code indicating which fault has occurred.
- Instruction Exceptions If a CPU encounters an illegal condition in certain CPU operations, an instruction exception fault is detected and causes a trap. Included as instruction exceptions are:
  - A processor-detected fault occurring during the execution of an interrupt or trap entry sequence.

- An illegal instruction in a trap (not XPSD) or interrupt (not XPSD, MTB, MTH, MTW) location when operating a trap or interrupt sequence.
- The setting of the register pointer of the PSD to a nonexistent register block as a result of an LRP, LPSD, or XPSD instruction.
- An illegal MMC instruction.
- An invalid register (odd) for an instruction (doubleword and byte string) that would yield an unpredictable result.
- 11. Processor Fault Interrupt

Whenever a CPU fault is detected, a Processor Detected Fault (PDF) flag is set in that CPU. If a second fault is detected (with PDF set), the CPU will generate and transmit the Processor Fault Interrupt (PFI) to any other CPUs in the system and enter a WAIT state that requires a Reset function to clear. Another CPU (in a multiprocessor system) may issue an RIO instruction to the malfunctioning CPU, which will clear the machine (in the same way as a CPU RESET or SYS RESET and cause it to resume execution at a predetermined instruction location. For a monoprocessor, operator action is required.

12. Automatic Instruction Fetch Retry

When fault conditions are detected on overlapped instruction fetch operations, the fetch is aborted and an automatic instruction fetch retry is attempted. If the fault recurs on the second attempt, the CPU traps in the normal manner.

13. Partitioning Feature

Various partitioning features in the SIGMA 9 CPU enable system reconfiguration. These features are locally controlled by switches and are readable by specially coded READ DIRECT instructions (see Chapter 3).

- a. Homespace bias switches enable placing the Homespace for each CPU in different physical locations of memory (see "Homespace", Chapter 2).
- b. CPU-IOP control bus selection is provided for the purpose of switching the CPU from primary to alternate processor busses. Thus, a failed CPU may be effectively partitioned out of the system; also, an entire subsystem consisting of an IOP, including attached peripherals, CPU, and memory unit can be partitioned from the primary system via this switch and the memory port disable switches, to allow diagnosis of any unit in the subsystem while the primary system continues operation.

c. The direct I/O bus and the maintenance interface bus may be selectively disabled from the CPU.

#### MAIN MEMORY FEATURES

1. Snapshot Logic

Each memory bank contains snapshot logic that is automatically activated when a memory fault occurs to record the nature and environment of the fault. The contents of the memory snapshot words (each 32 bits in size) can be retrieved by the use of the instruction, LOAD MEMORY STATUS (see Chapter 3). This feature may be used by the operating system for error logging, or by a diagnostic program to assist in fault locating. Notification of a fault occurrence is via the Memory Fault Interrupt.

2. Memory Fault Detection

Memory fault detection covers the following types of faults:

- a. Parity errors detected on information read out of the memory bank.
- b. Parity errors detected on addresses received from processors.
- c. Parity errors detected on data received from processors.
- d. Port selection errors detected if more than one port is simultaneously selected for one bank. Under this condition, the memory aborts the requested operation without modifying the contents of any memory location.
- e. Memory bank operational status, e.g., overtemperature, d.c. voltages out of tolerance, etc.
- f. Data loop checks that provide additional fault detection on read operations. As data is gated onto the memory bus for transmission to a processor, it is also gated from the bus back through the input path, clocked into a register, and checked for parity. Thus, the integrity of the line drivers/receivers at the memory is tested on every read cycle.
- 3. Memory Interleave Switch

The interleaved mode of memory operation may be disabled for certain diagnostic purposes with a switch located on the PCP (see Chapter 5).

4. Clock Margin Switches

Clock margins are controlled manually by means of switches or by use of the LOAD MEMORY STATUS instruction. Voltage margin control is also provided at each local d.c. power supply within a unit. 5. Partitioning of Memory

Partitioning of memory units is allowed on a memory port basis where each memory bus connection may selectively be disabled. Starting address switches allow the memory system to remain a contiguous unit after partitioning. A centrally located reconfiguration control panel for each memory unit is provided for this purpose.

6. Memory Mode Feature

Two additional memory modes of operation are provided for testing memory units. These modes are called Read and Inhibit Parity and Read and Change Parity (see Chapter 3).

- a. During the Read and Inhibit Parity operation, a word is read from memory and transmitted to the requesting processor. If a parity error is detected in the memory bank, the memory is prohibited from taking any snapshot and does not generate the Memory Fault Interrupt. It does transmit the Parity Error signal, however. The CPU recognizes this mode of operation and inhibits the trap that might occur for memory parity error and data bus check and, instead, records these attributes in the condition code at the conclusion of the instruction. If there is no parity error, the instruction is treated as a normal LOAD WORD instruction, except for the setting of the condition code.
- b. During the Read and Change Parity operation, a word is read from memory and transmitted to the requesting processor. In the write half cycle, the word is restored to memory, and the word with an invalid parity bit is unconditionally restored. This allows the parity generation and checking logic of the memory to be tested.

### MULTIPLEXOR INPUT/OUTPUT PROCESSOR (MIOP) FEATURES

1. Maintenance Interface Bus

The maintenance interface bus (a special mode of the direct I/O bus) is connected to each MIOP from the CPU for maintenance purposes. The MIOP responds in the following way to special WRITE DIRECT and READ DIRECT instructions executed by the CPU.

- a. Under RD control, monitors one of 32 selectable groups of MIOP logic.
- b. Under WD control, steps the clock control of the MIOP in a single-phase mode.
- c. Under WD control, a snapshot mode of operation selects a display group and stores it in a snapshot register at the end of a preset countdown for later monitoring by an RD instruction.

- d. Under WD control, writes directly into an addressed subchannel.
- e. Under RD control, reads directly from an addressed subchannel.
- f. Under WD control, sets the clock margins to fast, normal, or slow rates.
- 2. Parity Checking

Parity is checked on information brought out of the MIOP's local memory for each subchannel. A fault is reported to the system via the Processor Fault Interrupt.

3. Maintenance Subcontroller

A maintenance subcontroller feature on each I/O channel assists in diagnosing the I/O system. A diagnostic program controls and monitors the maintenance subcontroller via the maintenance interface and the I/O bus. The following functions can be accomplished:

- a. Simulation of a device controller that responds to commands sent to it by the MIOP and receives and sends strings of data bytes.
- b. Monitoring of IOP bus during diagnostic operations.
- c. Exercising of the IOP at variable rates up to and including its maximum rate.
- d. Self-testing of the maintenance subcontroller logic.
- 4. Clock and Voltage Margins

Clock margins are programmatically controlled by a specially coded WRITE DIRECT instruction (see Chapter 3). Voltage margin controls are provided at each d. c. power supply.

5. Partitioning of MIOPs

Partitioning of MIOPs is accomplished by disabling the primary (or alternate) processor bus connection and disabling the appropriate memory port(s).

#### HIGH-SPEED RAD I/O PROCESSOR (HSRIOP) FEATURES

1. Maintenance Interface Bus

The maintenance interface bus (a special mode of the direct I/O bus) is connected to the HSRIOP from the CPU for maintenance purposes. The HSRIOP responds

in the following way to special WRITE DIRECT and READ DIRECT instructions executed by the CPU:

- Under WD control, selects a phase that causes the HSRIOP to halt when entered during execution of any HSRIOP operation. At this time, the HSRIOP may be "snapped" for diagnostic purposes, via RD control.
- b. Under RD control, "snaps" one of seven selectable groups of internal HSRIOP logic.
- c. Under WD control, steps the clock control of the HSRIOP in a single-phase mode.
- d. Under WD control, selectively sets various fault indicators (e.g., device and memory faults) to simulate actual fault occurrence. This feature allows the diagnostic to test for correct HSRIOP response under these fault conditions.
- e. Under WD control, selectively initiates Test Mode 1 or Test Mode 2 of the HSRIOP in which the HSRIOP responds to normal I/O instructions while simulating action of the storage units. In this way, major portions of the HSRIOP logic can be diagnosed separately from the storage units.
- 2. Test Mode 1.

This mode permits the diagnostic program to check the data paths, control logic, and byte alignment logic from memory to the buffer (with a write operation) and from the buffer to memory (with a read operation).

3. Test Mode 2.

This mode permits the diagnostic program to check most of the RIOP functions without using a RAD. Data patterns for read and check-write operations are simulated and applied to the cable receivers in lieu of RAD output. In addition to the normal functions, the error detection logic is also tested. Although a write operation can not check data paths, all the vital control functions can be tested.

4. Clock and Voltage Margins

Clock margins for the HSRIOP are not applicable because of its unique design. Voltage margin controls are provided at each local d.c. power supply.

5. Partitioning of HSRIOPs

Partitioning of HSRIOPs is accomplished by disabling the primary (or alternate) processor bus connection and inhibiting the appropriate memory port(s).

## **APPENDIX E. GLOSSARY OF SYMBOLIC TERMS**

| Term | Meaning                                                                                                                                                    | Term | Meaning                                                                                                                                                                                                                                 |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ( )  | Contents of.                                                                                                                                               | EA   | Extension address – 6-bit field concatenated<br>to 16-bit extended displacement field to<br>form 22-bit real extended address.                                                                                                          |
| n    | AND (logical product, where $0 \cap 0 = 0$ ,<br>$0 \cap 1 = 0$ , $1 \cap 0 = 0$ , and $1 \cap 1 = 1$ ).                                                    |      |                                                                                                                                                                                                                                         |
| U    | OR (logical inclusive OR, where $0 \cup 0 = 0$ ,                                                                                                           | EB   | Effective byte – 8-bit contents of effective byte location (EBL).                                                                                                                                                                       |
|      | $0 \cup 1 = 1$ , $1 \cup 0 = 1$ , and $1 \cup 1 = 1$ ).                                                                                                    | EBL  | Effective byte location – byte location pointed to by effective virtual address of an                                                                                                                                                   |
| 0    | EOR (logical exclusive OR, where<br>0 () 0 = 0, 0 () 1 = 1, 1 () 0 = 1,<br>and 1 () 1 = 0).                                                                |      | instruction for byte operation.                                                                                                                                                                                                         |
| АМ   | Fixed-point arithmetic trap mask — bit posi-                                                                                                               | ED   | Effective doubleword – 64–bit contents of effective doubleword location (EDL).                                                                                                                                                          |
|      | tion 11 of PSD. If set (=1), computer traps                                                                                                                |      |                                                                                                                                                                                                                                         |
|      | to Homespace location X'43' after executing<br>an instruction causing fixed-point overflow;<br>if not set, computer does not trap.                         | EDL  | Effective doubleword location – doubleword<br>location pointed to by effective virtual ad-<br>dress of an instruction for a doubleword<br>operation. If odd-numbered word location is<br>specified, low-order bit of effective address  |
| AS   | ANSCII control—bit position 12 of PSD. When<br>set (=1), ANSCII codes are generated; when<br>not set, EBCDIC codes are generated.                          |      | field (bit position 31) is automatically forced<br>to 0. Hence, odd-numbered word address (re-<br>ferring to middle of doubleword) designates<br>same doubleword as even-numbered word<br>address when used for a doubleword operation. |
| сс   | Condition code – 4-bit value (bit positions<br>labeled CC1, CC2, CC3, and CC4), estab-<br>lished as part of the execution of most<br>SIGMA 9 instructions. | EDO  | Effective decimal operand.                                                                                                                                                                                                              |
| СІ   | Counter interrupt group inhibit — bit posi-<br>tion 37 of PSD. If set (=1), all interrupt                                                                  | EH   | Effective halfword – 16-bit contents of effective halfword location, or (EHL).                                                                                                                                                          |
| DA   | levels within this group are inhibited.<br>Destination address — in byte string instruc-                                                                   | EHL  | Effective halfword location — halfword loca-<br>tion pointed to by effective virtual address of<br>an instruction for halfword operation.                                                                                               |
|      | tions, address of the destination byte string.                                                                                                             |      | an instruction for narrword operation.                                                                                                                                                                                                  |
| DBS  | Destination byte string – operand specified by byte string instruction.                                                                                    | EI   | External interrupt group inhibit — bit posi-<br>tion 39 of PSD. If set (=1), all interrupt<br>levels within this group are inhibited.                                                                                                   |
| DECA | Decimal accumulator – general registers 12,<br>13,14, and 15 in decimal instructions.                                                                      | ES   | Extension selector — 1-bit flag used during<br>real extended addressing.                                                                                                                                                                |
| DM   | Decimal arithmetic trap mask — bit posi-<br>tion 10 of PSD. When set (=1), decimal<br>arithmetic fault trap is in effect.                                  | ESA  | Effective source address — in byte string in-<br>structions, address of the source byte<br>string.                                                                                                                                      |

| Term | Meaning                                                                                                                                                                                                                                                                                                                     | Term | Meaning                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| EVA  | Effective virtual address – virtual address<br>value obtained as result of indirect addressing<br>and/or indexing. This address value is inde-<br>pendent of the program's actual location in<br>main memory, and is final address value be-<br>fore memory mapping is performed.                                           | MA   | Mode altered – bit position 40 of PSD. This<br>bit is set (=1) during master-protected mode<br>of operation and during real extended type<br>of addressing.                                                                                                                                                                                                                                                       |  |  |
| EW   | Effective word – 32-bit contents of effective word location (EWL).                                                                                                                                                                                                                                                          | ММ   | Memory map mode control — bit position 9 of PSD. When set (=1), the memory map is in effect.                                                                                                                                                                                                                                                                                                                      |  |  |
| EWL  | Effective word location — word location<br>pointed to by effective virtual address of an<br>instruction for a word operation.                                                                                                                                                                                               | MS   | Master/slave mode control – bit position 8 of<br>PSD. When set (=1), computer is in slave<br>mode; when not set, computer may be in<br>master or master-protected mode as deter-<br>mined by bit 40.                                                                                                                                                                                                              |  |  |
| FN   | Floating normalize mode control — bit posi-<br>tion 7 of PSD. If not set, results of floating-<br>point additions and subtractions are to be<br>normalized; if set (=1), results are not<br>normalized.                                                                                                                     | PSD  | Program status doubleword – collection of<br>separate registers and flip–flops treated as a<br>64–bit internal CPU register to store and<br>display critical control information.                                                                                                                                                                                                                                 |  |  |
| FS   | Floating significance mode control – bit posi-<br>tion 5 of PSD. If set (=1), computer traps to<br>location X'44' when more than two hexa-<br>decimal places of postnormalization shifting<br>are required for a floating-point addition or<br>subtraction; if not set, no significance<br>checking is performed.           | R    | General register address value – 4-bit con-<br>tents of bit positions 8-11 (R field) of instruc-<br>tion word, also expressed symbolically as<br>(I)8-11. In instruction descriptions, register R<br>is general register (of current register block)<br>that corresponds to R field address value.                                                                                                                |  |  |
| FZ   | Floating zero mode control – bit position 6<br>of the PSD. If set (=1), computer traps to<br>location X'44' when either characteristic<br>underflow or zero result occurs for a floating-<br>point multiplication or division; if not set,<br>characteristic underflow and zero result are<br>treated as normal conditions. | RA   | Reference address – contents of bit posi-<br>tions 15-31 of instruction word, a 17-bit<br>field capable of directly addressing any<br>general register in current register block (by<br>using a value in range 0-15) or any word in<br>main memory in address range 16 through<br>131,071. This address value is initial ad-<br>dress value for any subsequent address com-<br>putations, memory mapping, or both |  |  |
| Ι    | Instruction register – internal CPU register<br>that holds instructions obtained from memory<br>while they are being decoded.                                                                                                                                                                                               | RP   | Register pointer — bit positions 56-59 of PSD;<br>bits 58 and 59 select one of four possible reg-                                                                                                                                                                                                                                                                                                                 |  |  |
| IA   | Instruction address – 17-bit value that defines<br>virtual address of instruction immediately<br>prior to the time that it is executed.                                                                                                                                                                                     | Ru I | ister blocks; bits 56 and 57 are reserved.<br>Odd register address value — register Ru1 is                                                                                                                                                                                                                                                                                                                        |  |  |
| 11   | I/O interrupt group inhibit – bit position 38<br>of the PSD. If set (=1), all interrupt levels<br>within this group are inhibited.                                                                                                                                                                                          |      | general register pointed to by value obtained<br>by logically ORing 0001 into address for<br>register R. Thus, if R field of instruction<br>contains even value, Ru1 = R + 1 and if R<br>field contains odd value, Ru1 = R.                                                                                                                                                                                       |  |  |
| L    | Numeric value of bits 8–11 of decimal in-<br>struction word (value of 0 is 16 bytes).                                                                                                                                                                                                                                       | SA   | Source address — in byte string instructions, contents of specified R register.                                                                                                                                                                                                                                                                                                                                   |  |  |

| Term | Meaning                                                                                                                                                                                                                                                                               | Term | Meaning<br>Top-of-stack address — pointer that points to<br>highest-numbered address of operand stack in<br>push-down instructions.                                                                                                                                                                                                         |  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| SBS  | Source byte string – operand specified by byte string instruction.                                                                                                                                                                                                                    | TSA  |                                                                                                                                                                                                                                                                                                                                             |  |
| SE   | Sign extension — some instructions operate on<br>two operands of different lengths; they are<br>made equal in length by extending sign of<br>shorter operand by required number of bit<br>positions. For positive operands, result of<br>sign extension is high-order 0's prefixed to | TW   | Trap–on–word inhibit bit — conditions push–<br>down stack limit trap for impending overflow<br>or underflow of word count.                                                                                                                                                                                                                  |  |
|      | the operand; for negative operands, high-<br>order 1's are prefixed to operand. Sign<br>extension process is performed after operand<br>accessed from memory and before operation<br>called for by instruction code is performed.                                                     | WK   | Write key – bit positions 34 and 35 of PSD;<br>they are evaluated by the memory write-<br>protect feature to determine accessibility of<br>real memory by current program.                                                                                                                                                                  |  |
| SPD  | Stack pointer doubleword – contains the<br>context (TSA, space count, word count, and<br>TS, TW inhibit bits) of the push–down<br>instructions.                                                                                                                                       | X    | Index register address value $-3$ -bit contents<br>of bit positions 12-14 (X field) of instruction<br>word. In instruction word, if X = 0, no<br>indexing is performed; if X $\neq$ 0, indexing is<br>performed (after indirect addressing if indi-<br>rect addressing is called for) with general<br>register X in current register block. |  |
| тсс  | Trap condition code – 4-bit value (bit<br>positions labeled TCC1, TCC2, TCC3, and<br>TCC4), established as part of trap operations.                                                                                                                                                   | X'n' | Hexadecimal qualifier – hexadecimal value<br>(n) is unsigned string of hexadecimal digits                                                                                                                                                                                                                                                   |  |
| TS   | Trap-on-space inhibit bit — conditions push-<br>down stack limit trap for impending overflow<br>or underflow of space count.                                                                                                                                                          |      | (0 through 9 and A through F) surrounded by<br>single quotation marks and preceded by the<br>qualifier "X" (for example, 7B0 <sub>16</sub> is writter<br>X'7B0'.                                                                                                                                                                            |  |

## INDEX

Note: For each entry in this index, the number of the most significant page is listed first. Any pages thereafter are listed in

A

access control codes, 26 control loading process, 106 protection, 26 protection control image, 106 accumulator, decimal, 77 active interrupt, 32 address actual, 9,18 branch, 20 direct reference, 16 effective, 18 index reference, 18 indirect reference, 16 input/output, 114-116 instruction, 16 memory byte, 130 memory control, 23 memory reference, 15 memory unit starting, 14 modification examples, 21 nonexistent memory (trap), 37 reference, 16 register, 18 twenty-bit reference, 16 virtual, 9 addressina indirect, 4 interrupt, 21 logic, 17 modes, 29 real, 18,21 real extended, 19,21,23 trap, 33 trap entry, 21 virtual, 19,21,22 Analyze/Interpret instructions, 55-57 armed interrupt, 31

numerical sequence.

## B

block pointer, register, 27,9 bootstrap loading program, 143 branches in real extended addressing mode, 97 branching and branch addresses, 20 byte count, 132 byte format, 11 byte-string instructions, 83-88, 14 byte-string register format, 20

## C

Call instruction trap, 40 instructions, 100,4 central processing unit, 10 channel end, 131 characteristics, general, 1 circular shift, 68 clocks, real-time 30,6 command chaining, 131 command doubleword, input/output, 130 comparison instructions, 64-66 computer modes, 11 condition code, decimal, 78 decimal arithmetic, 40 fixed-point instructions, 57, 39 floating-point instructions, 74, 39 load/store, 47 push-down, 93 control command doublewords, 132 instructions, 100-114 of the interrupt system, 32 panel interrupt (see input/output group interrupt) Control order, 130 conversion instructions, 70,71,4 counter-equals-zero group interrupts, 31 CPU features, 176 port, 15

## D

data chaining, 131 decimal accumulator, 77 arithmetic fault trap, 40 arithmetic hardware, 4 illegal digits, 77 instruction format, 77 instruction nomenclature, 78 instructions, 77-82 overflow, 78 packed format, 77 zoned format, 77 device interrupt, 127 direct data input/output, 6 input/output (DIO), 5 reference address, 16 disabled interrupt, 32,33

<u>Note:</u> For each entry in this index, the number of the most significant page is listed first. Any pages thereafter are listed in numerical sequence.

disarmed interrupt, 31 displacement indexing, 4 displacements, 18 doubleword format, 11 I/O command, 130 program status, 27 stack pointer, 92

## E

effective address, 18 location, 18 operand, 18 enabled interrupt (see states of interrupts) Execute/Branch instructions, 97–99 external interrupts, 31

## F

fault decimal arithmetic trap, 40 floating-point arithmetic (trap), 39 processor-detected, 40 features central processing unit (CPU), 176 general-purpose, 4 high-speed RAD IOP (HSRIOP), 179 main memory, 178 multiplexor IOP (MIOP), 178 multiprocessing, 7 multiusage, 7 real-time, 6 standard and optional, 3 system maintainability, 175 time-sharing, 5 fetching and storing data, 144 fixed-point arithmetic instructions, 57-63 overflow trap, 38 flags, 130 floating-point add and subtract, 73 arithmetic fault trap, 39 arithmetic instructions, 72-76 condition code settings, 74 hardware, 4 multiply and divide, 74 normalize control, 73 numbers, 72,73 shift, 69 significance control, 74 zero control, 74

format

byte, 11 byte-string instruction, 83, 20 decimal instruction, 77 doubleword, 11 general instruction, 19 general registers, 118 halfword, 11 immediate operand, 13 input/output instruction, 114 instruction, 45 interrupt instruction, 21 memory referencing, 13 operational command doubleword, 130 program status doubleword, 27 Stop command, 133 Transfer in Channel command, 132 trap instruction, 21 word, 11

## G

general characteristics, 1 instruction format, 19 registers, 9 general-purpose features, 4 generation of actual memory addresses, 24 of effective virtual address, 25 glossary of symbolic terms, 180

## H

halfword format, 11 high-speed RAD input/output processor (HSRIOP), 5 RAD IOP (HSRIOP) features, 179 Homespace, 15,7,16 bias, 15

## I

illegal digit and sign detection (decimal), 77 immediate operand instruction format, 13 index displacement alignment (real and virtual), 22 displacement alignment (real extended addressing), 23 reference address, 18 register, 20 indexing (real and virtual addressing), 21 (real extended addressing) example, 21 displacement, 4 Note: For each entry in this index, the number of the most significant page is listed first. Any pages thereafter are listed in numerical sequence.

indirect address location, 20 addressing, 4 index halfword (real extended addressing) example, 23 indexed halfword (virtual addressing) example, 22 reference address, 16 information boundaries, 13 inhibits interrupt, 32 push-down traps, 93 input/output capability, 5 command doublewords, 130 group interrupts, 31 instructions, 114-128 interrupts, 31, 127, 131 multiusage, 7 operations, 129-133 processors (IOPs), 129 status information, 117 instruction address, 16 branch, 97 exception trap, 41 format, 45 Interpret, 57,4 register, 13 set, 4,7 timing, 165 unimplemented (trap), 37 instructions Analyze/Interpret, 55-57 byte-string, 83-88 Call, 100,4 comparison, 64-66 control, 100-114 conversion, 70,71,4 decimal, 77-82 Execute/Branch, 97-99 fixed-point, 57-63 floating-point, 72-76 input/output, 114-128 load/store, 47-54 logical, 66,67 nonexistent (trap), 36 privileged in slave mode (trap), 37 push-down, 92-96 Shift, 67-70 translate, 86, 87, 4 internal computer control, Read Direct, 111 computer control, Write Direct, 112 interrupts, 30 Interpret instruction, 57,4 interrupt active, 32 and trap entry addressing, 21 and trap instruction format, 21 channel end, 131 control (Read Direct), 112

control (Write Direct), 114 control panel, 31 device, 127 inhibits, 32 locations, 29 multilevel priority system, 6 operations, 28 priority chain, 30 system, 29 system control of, 32 trigger, 29 unusual end, 131 zero byte count, 131 interruption of Move to Memory Control, 106 interrupts armed, 31 counter-equals-zero group, 31 disabled, 32,33 disarmed, 31 enabled 32,33 external, 31 input/output group, 31 internal, 30 override group, 30 single-instruction, 33 states of (level), 31 time of occurrences, 33 waiting, 31

## L

load interrupt inhibits, 113 operation details, 143 procedure, 143 snapshot control register, 113 load/store instructions, 47–54 loading operation, 143 the access protection controls, 106 the memory map, 105 the memory write protection locks, 106 logical instructions, 66,67 shift, 68

## M

main memory, 14 main memory features, 178 manual partitioning capability, 8 master mode, 11 (see also user protection) master-protected mode, 11 memory access protection, 11 access traps (move to memory control), 107 <u>Note:</u> For each entry in this index, the number of the most significant page is listed first. Any pages thereafter are listed in numerical sequence.

address control, 23 bank, 14 byte address, 130 control storage, 9 interleaving, 14 lock control image, 106 lock loading process, 106 map, 26,9 map control image, 105 map loading process, 105 nonexistent addresses, 37 nonexistent addresses (trap), 37 page address codes, 26 parity error, 42 ports, 14 protection, 6,7 protection violation (trap), 37 real, 15 reference address, 15 referencing instructions format, 13 unit, 14 unit starting address, 14 virtual, 15 write protection, 11 multilevel priority interrupt system, 6 multiple register blocks, 5 multiplexor input/output processor (MIOP), 5 multiplexor IOP (MIOP) features, 178 multiport memory system, 7 multiprocessing features, 7 multiprocessor control function, 8 multiprocessor interlock, 7 multiusage features, 7

## N

nonallowed operation trap, 36 nonallowed operation trap during execution (branch), 97 nonexistent instruction (trap), 36 nonexistent memory address (trap), 37 nonstop operation, 6 normalize control, floating-point, 73 numbers decimal, 77 floating-point, 72 packed decimal, 77 zoned decimal, 77

## 0

operating and addressing modes, 29 operating procedures, 143 operational command doublewords, 130 operator controls, 134-144 overflow detection (decimal), 78 fixed-point, 38 floating-point, 39 override group interrupts, 30

## P

packed decimal format, 77 decimal numbers, 77 parity error, memory, 42 parity error trap, 42 peripheral equipment, 3 port priority, 15 priority interrupt, 7 privileged instruction in slave mode (trap), 37 processor control panel, 134 processor-detected faults, 40 program status doubleword, 27, 101 program status doubleword (PSD) indicators, 136 push-down condition settings, 93 instructions, 92-96 stack limit trap, 38

## R

rapid context saving, 5 rapid context switching, 6 Read order, 130 Backward order, 130 Direct, internal computer control, 111 Direct, interrupt control, 112 read internal controls, 111 interrupt inhibits, 111 sense switches, 111 snapshot sample register, 111 real addressing, 19 memory, 15 memory write locks, 27 real-time clocks, 30,6 real-time features, 6 reference address, 16 reference tables, 145-163 register address, 18 altered bit (trap), 43 block pointer, 27,9 general, 9 instruction, 13 reset alarm indicator, 113 reset interrupt inhibits, 112

<u>Note:</u> For each entry in this index, the number of the most significant page is listed first. Any pages thereafter are listed in numerical sequence.

### S

Sense order, 130 sense switches, 135 set alarm indicator, 113 internal controls, 113 interrupt inhibits, 112 shared input/output, 8 Shift instructions, 67-70 significance control, floating-point, 74 single-instruction interrupts, 33 slave mode, 11 (see also user protection) SNAP, 141 snapshot, 113, 2, 111, 141, 175, 176, 178 stack pointer doubleword (SPD), 92 stack pointer for push/pull instructions, 20 stack-manipulating instructions (see rapid context saving) standard and optional features, 3 states of an interrupt level, 31 status response for I/O instructions, 121 Stop order, 133 storage management, 5 symbolic terms, glossary, 180 system maintainability features, 175 organization, 9 reliability and maintainability, 175

## T

time of interrupt occurrences, 33 time-sharing features, 5 toggle program-controlled frequency (PCF), 113 Transfer in Channel, 132 translate instructions, 86, 87, 4 trap, 34 addressing, 34 Call instruction, 40 condition code, 34,42 conditions during anticipate operations, 43 decimal arithmetic, 40 entry sequence, 34 fixed-point overflow, 38 floating-point arithmetic fault, 39 instruction exception, 41 locations, 35 masks, 34 memory protection violation, 37 nonallowed operation, 36 nonallowed operation (branch), 97 nonexistent instruction, 36 nonexistent memory address, 37

parity error, 42 privileged instruction (slave mode), 37 push-down stack limit, 38 registered altered bit, 43 system, 34 unimplemented instruction, 37 watchdog timer runout, 41 traps by byte-string instructions, 84 turn off mode altered flag, 113 turn on mode altered flag, 113 twenty-bit reference address, 16 types of addressing, 18

### U

unimplemented instructions, 37 unusual end, 131 user protection, 5

## V

variable precision arithmetic, 6 virtual address, 9 addressing, 19 memory, 15

## W

waiting interrupt, 31
watchdog timer runout trap, 41
watchdog timer (see nonstop operation)
word format, 11
Write

Direct (internal computer control), 112
Direct (interrupt control), 114
order, 130
write key, 27
write-protect locks, 27

## Z

zero byte count, 131 byte count interrupt, 131,122 control, floating-point, 74 zoned decimal numbers, 77 .

# Xerox Data Systems

XEROX.

# **READER COMMENT FORM**

| We would appreciate your comments and suggestions for improving this publication. |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------|-------------------------------------------------------------------|--------------|--|--|
| Publication No.                                                                   | Rev. Letter                                                                                                                                                                                                                                 | Title           |                                           |                                                                   | Current Date |  |  |
| How did you use thi                                                               | s publication?                                                                                                                                                                                                                              |                 |                                           | Is the material presented effectively?                            | L            |  |  |
| <ul><li>Learning</li><li>Reference</li></ul>                                      | ☐ Insta<br>□ Maint                                                                                                                                                                                                                          | lling<br>aining | <ul><li>Operating</li><li>Sales</li></ul> | Fully covered     Well illustrated       Clear     Well organized |              |  |  |
| What is your overall                                                              | rating of this                                                                                                                                                                                                                              | publication?    |                                           | What is your occupation?                                          |              |  |  |
| <ul><li>Very good</li><li>Good</li></ul>                                          | ☐ Fair<br>☐ Poor                                                                                                                                                                                                                            |                 | Very poor                                 |                                                                   |              |  |  |
|                                                                                   | Your other comments may be entered here. Please be specific and give page, column, and line number references where applicable. To report errors, please use the XDS Software Improvement or Difficulty Report (1188) instead of this form. |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   | <u></u>      |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
|                                                                                   |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |
| Thank you for your                                                                | interest.                                                                                                                                                                                                                                   |                 | Your name and ret                         | urn address.                                                      |              |  |  |
| Fold and fasten as<br>No postage needed                                           |                                                                                                                                                                                                                                             |                 |                                           |                                                                   |              |  |  |

5

£



FOLD

FOLD